Skip to:
Content
Pages
Categories
Search
Top
Bottom

Time delay for posts, comments, and notifications

  • @pixieblitz

    Participant

    Hi! I’m trying to set up a network with a twist and I’d really appreciate any pointers 🙂

    I want everything anyone posts/comments/stars/etc on the site to remain invisible at first. I’m still on the fence between:

    1) User interactions all become visible X hours after they were initially posted or
    2) User interactions all become visible at the next 8AM localtime that’s at least X hours after the initial post.

    I’m not sure how to implement this thoroughly. My first though was to add child template modifications that check the timestamp and only display the content after the cutoff for each loop, but would this be massively inefficient? And how would I ensure that all email notifications about posts are delayed, but without delaying ALL emails so that password resets and other admin stuff still goes through instantly?

    I hope this makes some sense, and thank you for any ideas or pointers!!!

    Luca

Viewing 2 replies - 1 through 2 (of 2 total)
  • @ngohoangbk93

    Participant

    ideal very good

    @vadimfrost09

    Participant

    Hi Luca! It sounds like you’re building a unique feature with delayed visibility for interactions—cool idea! Let me break this down for you and provide some guidance:

    1. User Interactions Visibility Logic
    You’re debating between two strategies:

    Option 1: Posts become visible after X hours.
    Option 2: Posts become visible at the next 8AM local time, but only if it’s X hours after posting.
    Implementation Thoughts
    Database-level flags: Add a visible_from datetime column to your interaction records (e.g., posts, comments, stars). This way, you calculate when they should become visible at the time of creation.

    For Option 1, set visible_from = created_at + X hours.
    For Option 2, calculate visible_from as the next 8AM that occurs at least X hours after created_at.
    Query filtering: Use this visible_from column in your database queries. For example:

    sql
    Копировать код
    SELECT * FROM interactions WHERE visible_from <= NOW();
    This ensures you’re only fetching interactions that should be visible.

    Efficient templating: Instead of adding logic in templates, handle this at the query level. Templating frameworks (e.g., Django, React) should just display what is passed to them, avoiding inefficiency in loops.

    2. Handling Email Notifications
    You want to delay email notifications about interactions while ensuring administrative emails (like password resets) remain instant.

    Approach
    Separate email queues:
    Use a task queue like Celery (Python) or Sidekiq (Ruby) to handle email sending.
    Assign different priorities or queues for email types:
    High priority: Immediate emails (e.g., password resets).
    Delayed priority: Interaction notifications, where tasks are scheduled to run after visible_from.
    Notification scheduler:
    Add logic to enqueue email notifications for interactions only after they become visible.
    For example, enqueue interaction notifications at visible_from time using delayed task execution.
    Example: Scheduling Emails
    If using Python and Celery:

    python
    Копировать код
    from datetime import timedelta
    from celery import shared_task

    @shared_task
    def send_email(user_email, interaction_id):
    # Logic to send the email notification here
    pass

    # Schedule email when an interaction is created
    interaction_time = … # ‘visible_from’ datetime from logic above
    send_email.apply_async(
    (user_email, interaction_id),
    eta=interaction_time
    )
    3. Additional Considerations
    Time zones: If you’re using local time for visibility, store interactions in UTC and calculate visible_from based on the user’s time zone.
    Edge cases: Consider scenarios like users editing their posts or comments. Decide if you want to reset the delay or leave the visibility timing as-is.
    Testing: Ensure thorough testing, especially for time zone conversions and delays, to prevent unintended visibility or email timing issues.
    Summary Workflow
    On post creation:
    Calculate and store visible_from.
    Schedule any delayed notifications for visible_from.
    On content fetch:
    Query only interactions where visible_from <= NOW().
    Use task queues to handle email delays efficiently while prioritizing admin emails.
    Let me know if you’d like examples tailored to your tech stack or further clarifications! 😊
    You can find more info at our FAQ pages.

Viewing 2 replies - 1 through 2 (of 2 total)
  • You must be logged in to reply to this topic.
Skip to toolbar