Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

DB Optimization - Email Branding #2255

Open
4 tasks
k-macmillan opened this issue Jan 17, 2025 · 0 comments
Open
4 tasks

DB Optimization - Email Branding #2255

k-macmillan opened this issue Jan 17, 2025 · 0 comments

Comments

@k-macmillan
Copy link
Member

k-macmillan commented Jan 17, 2025

User Story - Business Need

Reducing the number of queries against our data is necessary to maintain a stable product. Email Branding should be cached in local memory.

  • Ticket is understood, and QA has been contacted (if the ticket has a QA label).

User Story(ies)

As a VA Notify reliability dev
I want to reduce unnecessary DB calls
So that our db is only used when necessary

Additional Info and Resources

get_html_email_options checks service.email_branding, which appears to lazy load. That's good (we don't need to query that every time we get the service), but we also don't need to query it if we have already done it once. The service_id could potentially be used as a key. We don't have to use service.email_branding, as there is no way to cache that.

May not need a dataclass, as we likely only need a value or two which would be fine in a tuple.

Image

Acceptance Criteria

  • Uses @cached(cache=TTLCache(maxsize=1024, ttl=600))
  • 10 notifications sent using the same provider should query the database at most once per worker
  • This work is added to the sprint review slide deck (key win bullet point and demo slide)

QA Considerations

Should be no difference for end-users.

Potential Dependencies

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants