Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@tramvai/module-common
Advanced tools
Base module consisted of the architectural blocks for typical tramvai app. This module is required at most cases and is used a lot by the other modules.
Base module consisted of the architectural blocks for typical tramvai app. This module is required at most cases and is used a lot by the other modules.
First install @tramvai/module-common
npm i @tramvai/module-common
Add CommonModule to the modules list
import { createApp } from '@tramvai/core';
import { CommonModule } from '@tramvai/module-common';
createApp({
modules: [CommonModule],
});
Module that adds implementation for the commandLineRunner and defines default command lines
This module logs with id command:command-line-runner
Adds state-manager
Implements action system
This module logs with id action:action-page-runner
Add providers that works with cookie. See docs
Implements work with environment variables both on server and client. See docs
Provides PubSub interface to implement communication between components. See docs
This modules logs with id pubsub
Module for logging. Uses @tramvai/module-log
Module that implements caches.
It provides next functionality:
/clear-cache
that will trigger caches clear eventThis modules logs with id cache:papi-clear-cache
You can create different cache types with CREATE_CACHE_TOKEN
factory:
LRU - @tinkoff/lru-cache-nano
This type of cache is created by default. To create it explicitly you must pass 'memory'
as the first argument, and options as the second.
provide({
provide: CACHE_TOKEN,
scope: Scope.SINGLETON,
useFactory: ({ createCache }) =>
createCache('memory', {
max: 100,
ttl: 24 * 60 * 60 * 1000, // 1 day
ttlResolution: 60 * 1000, // 1 minute
allowStale: true,
updateAgeOnGet: true,
}),
deps: {
createCache: CREATE_CACHE_TOKEN,
},
});
LFU - @akashbabu/lfu-cache
To create it you must pass 'memory-lfu'
as the first argument, cache options - as second.
provide({
provide: CACHE_TOKEN,
scope: Scope.SINGLETON,
useFactory: ({ createCache }) =>
createCache('memory-lfu', {
max: 20,
evictCount: 5,
maxAge: 24 * 60 * 60 * 1000, // 1 day
}),
deps: {
createCache: CREATE_CACHE_TOKEN,
},
});
To turn cache hit/miss rate monitoring, cache size, you need to provide cache name in options:
provide({
provide: CACHE_TOKEN,
scope: Scope.SINGLETON,
useFactory: ({ createCache }) =>
createCache('memory', {
name: 'cache-name',
}),
deps: {
createCache: CREATE_CACHE_TOKEN,
},
});
Cache name have to be unique, factory will throw exception in case of cache name duplication.
Metric module should be provided in your application.
Server cache metrics:
By default hit/miss rate is computed as a sum of all data access attempts (methods has
, peek
, get
).
Wrapper for the client request
Wrapper for the client response
import { provide } from '@tramvai/core';
export const providers = [
provide({
provide: MY_MODULE_PROVIDER_FACTORY,
scope: Scope.SINGLETON,
useFactory: ({ createCache }) => {
const cache = createCache('memory', ...args); // type of the cache and any additional options that will be passed to the cache constructor
return someFactory({ cache });
},
deps: {
createCache: CREATE_CACHE_TOKEN,
},
}),
provide({
provide: REGISTER_CLEAR_CACHE_TOKEN,
scope: Scope.SINGLETON,
useFactory: ({ cache }) => {
return async () => {
await cache.reset();
console.log('my module cache cleared');
};
},
deps: {
cache: MY_MODULE_CACHE,
},
}),
provide({
provide: commandLineListTokens.clear,
useFactory: ({ clearCache }) => {
return function clear() {
clearCache(); // clear caches explicitly
};
},
deps: {
clearCache: CLEAR_CACHE_TOKEN,
},
}),
];
FAQs
Base module consisted of the architectural blocks for typical tramvai app. This module is required at most cases and is used a lot by the other modules.
The npm package @tramvai/module-common receives a total of 544 weekly downloads. As such, @tramvai/module-common popularity was classified as not popular.
We found that @tramvai/module-common demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 3 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.