@daiso-tech/core
Version:
The library offers flexible, framework-agnostic solutions for modern web applications, built on adaptable components that integrate seamlessly with popular frameworks like Next Js.
132 lines • 4.26 kB
JavaScript
/**
* @module Cache
*/
import { DefaultAdapterNotDefinedError, resolveOneOrMore, UnregisteredAdapterError, } from "../../../../utilities/_module-exports.js";
import { Cache, } from "../../../../cache/implementations/derivables/cache/_module.js";
import { Namespace } from "../../../../utilities/_module-exports.js";
/**
* The `CacheFactory` class is immutable.
*
* IMPORT_PATH: `"@daiso-tech/core/cache"`
* @group Derivables
*/
export class CacheFactory {
settings;
/**
* @example
* ```ts
* import { CacheFactory } from "@daiso-tech/core/cache";
* import { MemoryCacheAdapter, RedisCacheAdapter } from "@daiso-tech/core/cache/adapters";
* import { Serde } from "@daiso-tech/core/serde";
* import type { ISerde } from "@daiso-tech/core/serde/contracts";
* import { SuperJsonSerdeAdapter } from "@daiso-tech/core/serde/adapters";
* import Redis from "ioredis"
*
* const serde = new Serde(new SuperJsonSerdeAdapter());
* const cacheFactory = new CacheFactory({
* adapters: {
* memory: new MemoryCacheAdapter(),
* redis: new RedisCacheAdapter({
* database: new Redis("YOUR_REDIS_CONNECTION"),
* serde,
* }),
* },
* defaultAdapter: "memory",
* });
*/
constructor(settings) {
this.settings = settings;
}
setNamespace(namespace) {
return new CacheFactory({
...this.settings,
namespace,
});
}
setDefaultTtl(ttl) {
return new CacheFactory({
...this.settings,
defaultTtl: ttl,
});
}
setEventBus(eventBus) {
return new CacheFactory({
...this.settings,
eventBus,
});
}
setLazyPromiseFactory(factory) {
return new CacheFactory({
...this.settings,
lazyPromiseFactory: factory,
});
}
setSchema(schema) {
return new CacheFactory({
...this.settings,
schema,
});
}
setType() {
return new CacheFactory(this.settings);
}
/**
* @example
* ```ts
* import { CacheFactory } from "@daiso-tech/core/cache";
* import { MemoryCacheAdapter, RedisCacheAdapter } from "@daiso-tech/core/cache/adapters";
* import { Serde } from "@daiso-tech/core/serde";
* import type { ISerde } from "@daiso-tech/core/serde/contracts";
* import { SuperJsonSerdeAdapter } from "@daiso-tech/core/serde/adapters";
* import { TimeSpan } from "@daiso-tech/core/utilities";
* import Redis from "ioredis"
*
* const serde = new Serde(new SuperJsonSerdeAdapter());
* const cacheFactory = new CacheFactory({
* adapters: {
* memory: new MemoryCacheAdapter(),
* redis: new RedisCacheAdapter({
* database: new Redis("YOUR_REDIS_CONNECTION"),
* serde,
* }),
* },
* defaultAdapter: "memory",
* });
*
* // Will add key to cache using the default adapter which is MemoryCacheAdapter
* await cacheFactory
* .use()
* .add("a", 1);
*
* // Will add key to cache using the redis adapter which is RedisCacheAdapter
* await cacheFactory
* .use("redis")
* .add("a", 1);
*
* // You can change the default settings of the returned Cache instance.
* await cacheFactory
* .setDefaultTtl(TimeSpan.fromMinutes(2))
* .use("sqlite")
* .add("a", 1);
* ```
*/
use(adapterName = this.settings.defaultAdapter) {
if (adapterName === undefined) {
throw new DefaultAdapterNotDefinedError(CacheFactory.name);
}
const adapter = this.settings.adapters[adapterName];
if (adapter === undefined) {
throw new UnregisteredAdapterError(adapterName);
}
const { namespace = new Namespace(["@", "cache"]) } = this.settings;
return new Cache({
...this.settings,
adapter,
namespace: new Namespace([
...resolveOneOrMore(namespace._getInternal().original),
adapterName,
]),
});
}
}
//# sourceMappingURL=cache-factory.js.map