
Product
Socket Now Supports pylock.toml Files
Socket now supports pylock.toml, enabling secure, reproducible Python builds with advanced scanning and full alignment with PEP 751's new standard.
ts-command is a very basic command library utilizing Typescript decorators. It also supports reloading commands on the fly.
ts-command is a very basic command library utilizing Typescript decorators. It also supports reloading commands on the fly.
Note: you have to disable strictFunctionTypes
in your tsconfig
to be able to use the decorators better.
In your tsconfig
set these compiler options:
{
"compilerOptions": {
"experimentalDecorators": true,
"emitDecoratorMetadata": true
}
}
In the entry file, import reflect-metadata
like this:
import 'reflect-metadata';
Now you should be good to go.
CommandManager
. This class will manage all the commands and services you register.import { CommandManager } from 'ts-command';
const manager = new CommandManager();
CommandCollection
.import { Command, Restrict, RestrictClass, Injectable } from 'ts-command';
// Set this to enable service injection
@Injectable()
// Restrict all commands in this class.
@RestrictClass((
// the user (supplied by you)
user: any,
// the collection instance
instance: MyCommandCollection,
) =>
// check whether the user is valid
instance.service.isValid(user),
)
class MyCommandCollection {
// specify the injected services (these get injected for you)
constructor(private service: AuthService) {}
// Restrict the command
@Restrict((user: any) => user.id > 5)
// Specify the command name ('my-command') and arguments ('name')
@Command('my-command', 'name')
// execute the command. The first argument contains the command-arguments, the second the user
myCommand({ name }: { name: string }, user: any) {
return `Hello ${name}! -by ${user.name}`;
}
}
Service
import { Service } from 'ts-command';
@Service()
class AuthService {
isValid(user: any) {
return !!user.id;
}
}
import { CommandManager } from 'ts-command';
// the command manager supports chaining
const manager: CommandManager = new CommandManager().registerService(AuthService).load(MyCommandCollection);
The manager expects a string like this: <command-name> [...args]
.
So you have to check whether it's a command (e.g. check for a prefix and remove the prefix).
const reply = await manager.onCommand(message, user);
Currently, reloading is an opt-in feature.
You can enable it by passing either true
to the CommandManager
or by passing reload-options:
// Enable for all users:
new CommandManager(true);
// Restrict reloading
new CommandManager({
enabled: true,
restrict: (user: any) => user.isAdmin,
});
This will add a reload
command. The signature is: reload <name: command or service>
.
FAQs
ts-command is a very basic command library utilizing Typescript decorators. It also supports reloading commands on the fly.
The npm package ts-command receives a total of 0 weekly downloads. As such, ts-command popularity was classified as not popular.
We found that ts-command demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer 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.
Product
Socket now supports pylock.toml, enabling secure, reproducible Python builds with advanced scanning and full alignment with PEP 751's new standard.
Security News
Research
Socket uncovered two npm packages that register hidden HTTP endpoints to delete all files on command.
Research
Security News
Malicious Ruby gems typosquat Fastlane plugins to steal Telegram bot tokens, messages, and files, exploiting demand after Vietnam’s Telegram ban.