0.4.0 • Published 5 months ago
@kazura/node-util v0.4.0
@kazura/node-util
Node Util 是一个提供常用工具函数的 Node.js 工具包,包括文件操作、Git 操作、TOTP 验证、Worker 线程等功能。
特性
- 文件系统操作
- Git 仓库操作
- TOTP 双因素认证
- Worker 线程池管理
- 任务工作者基类
- 类型安全
安装
npm install @kazura/node-util使用方法
文件操作
import { lookupFile, writeFile, md5, getHash, getPkgJson, getPkgName } from '@kazura/node-util'
// 查找文件
const config = lookupFile(process.cwd(), ['config.json', 'config.js'])
// 写入文件
writeFile('output.txt', 'Hello, World!')
// 生成 MD5 哈希
const hash = md5('Hello, World!')
// 生成短哈希
const shortHash = getHash('Hello, World!')
// 获取 package.json
const pkg = getPkgJson(process.cwd())
// 获取包名
const name = getPkgName('@kazura/node-util')Git 操作
import { GitUtil } from '@kazura/node-util'
const git = new GitUtil(process.cwd())
// 获取分支名
const branch = await git.getBranchName()
// 获取提交 ID
const commitId = await git.getCommitId()
// 获取短提交 ID
const shortCommitId = await git.getShortCommitId()
// 获取用户名和邮箱
const username = await git.getUserName()
const email = await git.getUserEmail()
// 添加文件
await git.add('file.txt')
await git.addAll()
// 提交更改
await git.commit('feat: add new feature')
await git.commitAll('feat: add new feature')
// 更新子模块
await git.submodulesUpdateInit()
// 拉取更新
await git.pullRebaseOrigin()
await git.pullNoRebaseOrigin()
// 切换分支
await git.checkout('main')
await git.checkoutOrigin('feature')
// 推送更改
await git.pushOrigin('main')TOTP 验证
import { Totp } from '@kazura/node-util'
// 生成密钥
const secret = Totp.generateSecret()
// 生成验证码
const passcode = Totp.generatePasscodes(secret)
// 验证验证码
const isValid = Totp.validate(passcode, secret)
// 生成 TOTP URL
const url = Totp.generateUrl('MyApp', 'user@example.com', secret)Worker 线程池
import { Worker } from '@kazura/node-util'
// 创建 Worker 实例
const worker = new Worker('./worker.js', {
max: 4, // 最大并发数
})
// 运行任务
const result = await worker.run(1, 2)
// 停止所有工作线程
worker.stop()任务工作者
import { TaskWorker } from '@kazura/node-util'
// 创建任务工作者
class MyWorker extends TaskWorker<[number, number], number> {
public async doWork(a: number, b: number): Promise<number> {
return a + b
}
}
new MyWorker()API 参考
文件操作
lookupFile
function lookupFile(dir: string, formats: string[], options?: LookupFileOptions): string | undefined在文件系统中查找特定文件。
参数:
dir: 起始目录formats: 要查找的文件格式数组options: 查找选项pathOnly: 是否只返回文件路径rootDir: 根目录predicate: 文件条件检查函数
返回值:
- 文件内容或路径,如果未找到则返回 undefined
writeFile
function writeFile(filename: string, content: string | Uint8Array): void将内容写入文件。
参数:
filename: 文件名content: 文件内容
md5
function md5(text: string): string生成 MD5 哈希。
参数:
text: 要哈希的文本
返回值:
- MD5 哈希字符串
getHash
function getHash(text: string): string生成短哈希。
参数:
text: 要哈希的文本
返回值:
- 8 位十六进制哈希字符串
getPkgJson
function getPkgJson(root: string): PackageJson获取 package.json 内容。
参数:
root: 项目根目录
返回值:
- package.json 对象
getPkgName
function getPkgName(name: string): string获取包名。
参数:
name: 完整包名
返回值:
- 包名(不含作用域)
Git 操作
GitUtil
class GitUtil {
constructor(cwd: string)
getBranchName(): Promise<string>
getCommitId(): Promise<string>
getShortCommitId(): Promise<string>
getUserName(): Promise<string>
getUserEmail(): Promise<string>
add(file: string): Promise<void>
addAll(): Promise<void>
commit(message: string): Promise<void>
commitAll(message: string): Promise<void>
submodulesUpdateInit(): Promise<void>
pullRebaseOrigin(): Promise<void>
pullNoRebaseOrigin(): Promise<void>
checkout(branch: string): Promise<void>
checkoutOrigin(branch: string): Promise<void>
pushOrigin(branch: string): Promise<void>
}Git 工具类,提供 Git 仓库操作功能。
TOTP 验证
Totp
class Totp {
static generateSecret(): string
static generatePasscodes(secret: string): string[]
static validate(passcode: string, secret: string): boolean
static generateUrl(issuer: string, accountName: string, secret: string): string
}TOTP 工具类,提供双因素认证功能。
Worker 线程池
Worker
class Worker {
constructor(filename: string, options?: WorkerOptions)
run(...args: any[]): Promise<any>
stop(): void
}Worker 线程池类,提供多线程任务处理功能。
任务工作者
TaskWorker
abstract class TaskWorker<TArgs extends any[], TResult> {
abstract doWork(...args: TArgs): Promise<TResult>
}任务工作者基类,用于创建自定义任务处理类。
注意事项
- 文件操作函数都是同步的
- Git 操作需要 Git 命令行工具
- TOTP 验证需要时间同步
- Worker 线程池需要合理设置并发数
- 任务工作者需要实现 doWork 方法
示例
文件操作示例
import { lookupFile, writeFile, md5 } from '@kazura/node-util'
// 查找配置文件
const config = lookupFile(process.cwd(), ['config.json', 'config.js'], {
pathOnly: true,
})
if (config) {
// 读取配置
const content = require(config)
// 修改配置
content.version = '1.0.0'
// 写入配置
writeFile(config, JSON.stringify(content, null, 2))
}
// 生成文件哈希
const fileHash = md5('file.txt')Git 操作示例
import { GitUtil } from '@kazura/node-util'
async function updateGitRepo() {
const git = new GitUtil(process.cwd())
// 获取当前分支
const branch = await git.getBranchName()
console.log('Current branch:', branch)
// 拉取更新
await git.pullRebaseOrigin()
// 添加所有更改
await git.addAll()
// 提交更改
await git.commit('chore: update dependencies')
// 推送更改
await git.pushOrigin(branch)
}TOTP 验证示例
import { Totp } from '@kazura/node-util'
function setupTOTP() {
// 生成密钥
const secret = Totp.generateSecret()
// 生成验证码
const passcodes = Totp.generatePasscodes(secret)
// 生成 TOTP URL
const url = Totp.generateUrl('MyApp', 'user@example.com', secret)
// 验证验证码
const isValid = Totp.validate(passcodes[0], secret)
return { secret, url, isValid }
}Worker 线程池示例
import { Worker } from '@kazura/node-util'
async function processTasks() {
const worker = new Worker('./worker.js', { max: 4 })
try {
// 并行处理多个任务
const results = await Promise.all([worker.run(1, 2), worker.run(3, 4), worker.run(5, 6)])
console.log('Results:', results)
} finally {
// 停止所有工作线程
worker.stop()
}
}文档
更多详细信息请查看 文档。
许可证
MIT
Author
👤 kazura233
- Website: https://github.com/kazura233
- Github: @kazura233
🤝 Contributing
Contributions, issues and feature requests are welcome!Feel free to check issues page.
Show your support
Give a ⭐️ if this project helped you!