A small, token based container designed for dependency injection 🫙
Using Vault to store and lookup dependencies is as simple as:
// Create a vault
const vault = new Vault();
// Create some tokens
const token = 'my cool token';
// Store dependencies!
vault.store('my secret message', token);
// Look them up at some point in your program
const dependency = vault.lookup<string>(token);
// It should print "just lookup this dependency: my secret message"
console.info(`just lookup this dependency: ${dependency}`);
If you're working in a context based environment and you want to retrieve dependencies based on the context state, then Vault was designed for you. Simply register the vault instance to your context and get the dependencies in some point in your app after. Here's an example on how you can use it in SvelteKit:
// src/routes/+page.ts
export const load = (async () => {
const dependency = new AuthenticationRepositoryImpl(...);
const vault = new Vault();
vault.store(dependency, 'AuthenticationRepository');
setContext('vault', dependency);
});
...
// src/lib/components/AuthenticationStore.ts
const { value } = getContext('vault');
const authenticationRepo = vault.lookup<AuthenticationRepository>('AuthenticationRepository');
const store = writable<AuthenticationState>();
return {
store.subscribe,
authenticate: () => authenticationRepo.loginAnonymously(),
};
Found any bug (including typos) in the package? Do you have any suggestion or feature to include for future releases? Please create an issue via GitHub in order to track each contribution. Also, pull requests are very welcome!
To contribute, start by setting up your local development environment. The setup.md document will onboard you on how to do so!