...
This investigation was in response to a request to assess the impact of the HTTP Cache feature introduced as part of
Jira Legacy | ||||||
---|---|---|---|---|---|---|
|
...
I've looked at the OKAPI HTTP Cache feature and based on my understanding of the code can see two types of changes we might have to make in order to ensure consistent and correct operation of the acquisitions apps when this feature is enabled in OKAPI:
- Potentially add a response header "Cache-control: no-store" to GET responses w/ status code 200. There are roughly 157 places where this might apply - spanning 9 backend modules
- Potentially add a request header "Cache-control: no-store" to GET requests out to other modules. There are roughly 217 places where this might apply - spanning 15 frontend and backend repositories
We 'll could either need to evaluate each of the ~375 places in the code and determine if we want to use the cache, or simply "opt-out" and by blindly add adding the headers in all those places w/o giving each case thought. The latter is less work and probably safer as it effectively means the cache shouldn't be used for any interactions to/from acquisitions code. That said, care must be taken going forward when writing new code that we either add the necessary headers or think through the implications of not (and using the cache for those particular calls).
...
I will say that there are likely some cases where it might make sense to use a cache - things like when looking up controlled vocabulary values which aren't likely to change frequently, if ever. However, there's bound to be times when something is cached and a user is wondering why they're not seeing something that they just changed - this leads to frustration and distrust of the system. The devil is in the details here. We need to be very careful about what we cache, how long we cache it, what the cache key is, and how we might invalidate cache entries if needed.
There might be shortcuts that can be taken if going with the opt-out approach - within a given module we might have or be able to introduce code in one or a few places that ALWAYS adds the request header for any GET requests that module makes instead of having to add the header in N different places. This might help reduce the scope of the changes within that module, but still doesn't reduce the number of stories required.
...