-
-
Notifications
You must be signed in to change notification settings - Fork 30
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
PersistedState: Add a way to validate values #151
Comments
This would be an enhancement! So you're thinking of providing a |
Not exactly. Actually, our private version at work has 2 functions: I don't like it very much. There's some overlapping, right? I designed it like that, but I'm not happy. Anyway, the lifecycle of the value starts by reading the value. Maybe you're reading it for the first time after upgrading your logic. Now this guy needs to be "upgraded" before its first use. So in my terms:
When the reactive variable changes:
This is opinionated. If invalid, normalize? Why not reject it as in rollback to the previous value? Things are getting fuzzy. I decided to normalize at work, but I admit it doesn't have any backing other than me saying so. So there: Something along these lines. I think something like this is definitely needed so one can reliably work with the store directly while its value evolves over time. |
Oh, but every time you call |
I have been juggling around some ideas for this, and this is what I have so far. Let's see if this is acceptable. Let's start with some type definitions. This is export interface ValueSerializer<T> {
serialize(value: T): string;
deserialize(value: string): T;
}
export type PushedValueHandler<T> = (value: T | null) => void;
export interface StorageMedium<T> {
read(): Promise<T | null>;
write(value: T | null): Promise<void>;
start?: () => (() => void) | void;
onPushValue?: (handler: PushedValueHandler<T>) => (() => void);
} StorageMediumThe idea here is to define an asynchronous contract for any storage medium people might think of, from the obvious local and session storage, to Redis, Mongo, cookies, indexedDB, The startThis is a method that is meant to be invoked to perform any startup tasks the storage medium requires. Now that I think about it, it probably should be asynchronous. The return value is the cleanup function, if one is needed. onPushValueThe storage medium may have the ability to receive updates from outside the persisted state object. The perfect example is the PersistedStateWith this, persisted state options are completely removed, as they are specific to local or session storage, and constructor(initialValue: T, storage: StorageMedium<T>, options: PersistedStateOptions<T> = {}) The options are now of an entirely different nature. Let's see about my proposal for options. PersistedStateOptionstype PersistedStateOptions<T> = {
onReadError?: 'ignore' | 'warn' | ((cause: any) => void);
onWriteError?: 'ignore' | 'warn' | ((cause: any) => void);
validator?: (value: T) => [boolean, T?];
}; Through options, we allow consumers of the class to specify what should happen if an error is thrown while reading or writing the value to storage. You can probably infer the details by looking at the type. validatorThis one is more interesting. It is a function that is given any new value that comes either via the If the value, is
PossibilitiesI know @huntabyte wants to be able to store a value simultaneously to a cookie. This design currently allows for just one storage medium. We could: a. Allow the specification of multiple storage media (so say, session storage and a cookie storage). The former has some demons: What storage should have preference when reading or writing the value? Should one storage be used for reading and the other for writing? What happens with I think the more sensible one would be the latter option. People can then answer the questions above by themselves for their own scenario. |
Describe the feature in detail (code, mocks, or screenshots encouraged)
I have already gone through this with svelte-persisted-store: Software evolves, and so the shapes of the data that is stored in local/session storage. Today, I store a Boolean, but tomorrow I may add a third option, so now I want to store an enum. The store should have a way to validate stored data and potentially upgrade it/fix it. Yes, fixing should be an option: People can mess with the value by hand.
What type of pull request would this be?
Enhancement
Provide relevant links or additional information.
*Don't know the difference between "Enhancement" and "New Feature".
The text was updated successfully, but these errors were encountered: