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

Local and Online cache data, combined. #53

Open
levibostian opened this issue Mar 29, 2019 · 0 comments
Open

Local and Online cache data, combined. #53

levibostian opened this issue Mar 29, 2019 · 0 comments
Labels
enhancement New feature or request

Comments

@levibostian
Copy link
Owner

levibostian commented Mar 29, 2019

I am using Teller in an app I am working on at the moment. During development, I came up with this scenario:

  • The app keeps track of a history of activity for you. This history of activity is obtained by a GET http call to the network API. That makes a great use of Teller, OnlineRepository.
  • However, activity is also created locally on the device in the local database. When activity rows are added locally to the local database, I should show this local cache to the user. However, what if: the app has never had a successful api sync before? Then, we will never show the local cache that exists.

Is this use case worth solving?

The way to solve this problem right now is to:

  • Create a separate observe() function where you perform a local database query where you can show the cache to the UI.
  • Call refresh(force = false) in the same place that you would have called observe() which will perform a refresh if needed, but not if not needed.
  • Have another call to the OnlineRepository.observe() where you can retrieve the last fetched property.

Is this use case worth solving? I believe so. Why? Because it seems like a use case that is understandable and may happen to more apps. Also the fact that it could be considered a bug in a way because if a refresh call has never been successful before, we will never load the local cache. That is not good!

The current way to solve this problem is not horrible. But, it's also easy to forget about. Having a better solution where the developer can remember to enable some functionality would be better to prevent bugs.

Ideas to solve this problem:

  1. Create another Repository abstract class that has the behavior of, "Be an onlinerepository, but if there is an existing cache, show that."

Pros:

  • Easy for developer. Just change subclass of repository and done.
  • Could customize the with a separate CacheState instance that combines properties from local and online cache state.

Cons:

  • Yet, another repository which means yet another one to learn about.
  • There is so much similarity between this repo and the other 2 that I wonder if there is another way to build this instead. Share more code.
  • If this use case is rare, having another repository subclass added to lib sounds like a lot of work when it's a rare use case.
  1. Modify OnlineRepository to allow the loading of a local cache even before first fetch is done.

Pros:

  • Quick, easy, optional functionality that gets hidden by the main use cases of Teller.
  • Because this is so similar to OnlineRepository, by using it's abstract functions already, the dev doesn't need to change anything.

Cons:

  • How do we handle OnlineCacheState?
@levibostian levibostian added the enhancement New feature or request label Mar 29, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

1 participant