Simple library to store SSM parameters in memory with multi-region, automatic renewal, expiration and parsing support.
@aws-sdk/client-ssm is a peer dependency, make sure that you provide it yourself if needed
⚠️ aws-sdk v2 is no longer supported upward of ssm-cfg-manager Version 2.0.0
Use it wisely! 🎉
To get an instance of a SSMHandler which is a singleton with caching build in.
You need to call the getInstance
method on the StaticSSMHandler
class.
This will return a singleton instance of SSMHandler with caching. So for each region you can create an instance and caching will be bound to it. For when you have the same keys stored in multiple regions.
const ssmHandler: SSMHandler = StaticSSMHandler.getInstance(region: string = "eu-west-1");
When you want to retrieve data from SSM but not cache the value use the unCached
methods.
// return a JSON object of generic type T
const parsed: T = await this.getUnCachedJson<T>(key);
// returns a string
const text: string = await this.getUnCachedText(key);
When you want to cache data you can use the getText
and getJson
method from the
SSMHandler instance.
Cache for limited time
If you specify a timeout, the library will expire the cached entry. When an entry has expired, the library will attempt to fetch it again from the AWS Parameter Store.
This is done on demand and not proactively.
// return a JSON object of generic type T and cache it for 5 seconds
const parsed: T = await ssmHandler.getJson<T>(key, 5000);
// returns a string and cache it for 5 seconds
const text: string = await ssmHandler.getText(key, 5000);
When you cached something ones with a timer, there is no need to specify it in other calls.
// cache it for 5 seconds
const parsed: T = await ssmHandler.getJson<T>(key, 5000);
// cache it for 5 seconds as it remembers the time from the first call
const text: string = await ssmHandler.getText(key);
Cache without expiration
If you specify no timeout the object will never expire and live in memory until the application stops or you remove the entry manually from the cache.
// return a JSON object of generic type T and cache it permanently
const parsed: T = await ssmHandler.getJson<T>(key);
// returns a string and cache it permanently
const text: string = await ssmHandler.getText(key);
Clearing the cache
When you need to wipe the cash for some reason you can use the clearCache
method on
the SSMHandler or the flush
method on the CacheHandler
.
ssmHandler.clearCache();
// or
ssmHandler.cacheHandler.flush();
Acting on the cache
To interact with the cache, use the CacheHandler
instance from the SSMHandler
.
This however isn't necessary for using the library.
/*
* Safely checks if an key exists in cache.
* this will remove the object if it has expired/
*/
ssmHandler.cacheHandler.has(key: string): boolean;
/*
* Check if a key exists without removing it when it expired.
*/
ssmHandler.cacheHandler.hasUnsafe(key: string): boolean;
/*
* Put an item in the cache for the given time or no time at all
* when a time has been set before it will remember it based on the key.
*/
public put<T>(key: string, value: T, cacheForMs?: number): void;
/*
* Remove the given item from the cache
*/
public remove(key: string): void
/*
* Gets an obejct from the cache
* Will throw NotFoundError when the object does not exist on cache
* Will throw ExpiredError when the object exists but has been expired
*/
public get<T>(key: string): CachedObject<T>
Feel free to open a PR, writing unit tests is required. If you have any questions or issues feel free to open up an issue and I will get back to you asap.
This project is not prone to change as it's just a simple implementation to make using SSM parameters a bit easier.
If it does change, SemVer applies.