custom Open Technical Architecture
data:image/s3,"s3://crabby-images/0c880/0c880e85e5bc77a23135758fd8ac2bfafe96819e" alt="npm"
Easily extend and enhance existing code using a standard decorator syntax.
The extension plugin is written following the style of Koa Middleware
.
Quick Start
import custom from 'custom-decorators';
class ClassA {
@custom('ClassA.method')
async method(name) {
console.log(`hello ${name}`);
}
}
custom('ClassA.method', async function(context, next) {
const { args } = context;
console.log(this, 'before', args[0]);
await next();
console.log(this, 'after', args[0]);
})
const instancea = new ClassA();
instancea.method('world');
Architecture
data:image/s3,"s3://crabby-images/d6fac/d6fac45330302e0e58149e83799155c3f3eb1336" alt="image"
Features
- Support both
async
and sync
functions depending on your declaration.
class ClassA {
@custom('ClassA.method')
method(name) {
console.log(`hello ${name}`);
}
}
custom('ClassA.method', function(context, next) {
const { args } = context;
console.log(this, 'before', args[0]);
next();
console.log(this, 'after', args[0]);
})
- Support the return value.
class ClassA {
@custom('ClassA.method')
async get(name) {
return `hello ${name}`;
}
}
custom('ClassA.method', async function(context, next) {
const returnValue = await next();
return `before ${returnValue} after`;
})
const instancea = new ClassA();
console.log(instancea.get('world'));
- Support for private extension (by not exports your symbol objects)
const PRIVATE_EXTENSION = Symbol('private_extension');
class ClassA {
@custom(PRIVATE_EXTENSION)
async method(name) {
console.log(`hello ${name}`);
}
}
custom(PRIVATE_EXTENSION, async function(context, next) {
})
License
MIT
Copyright (c) 2024-present, Zhoukekestar