
Security News
New CNAPulse Dashboard Tracks CNA Activity and Disclosure Trends
Open source dashboard CNAPulse tracks CVE Numbering Authorities’ publishing activity, highlighting trends and transparency across the CVE ecosystem.
@tntd/lib-service
Advanced tools
主要用于生成服务(请求方法)集合,支持特性如下:
npm install new-lib-service --save
import service from 'new-lib-service';
// 带全局配置的创建服务方法
const createService = service({
baseUrl: '/api',
redirectUrl: '/login/logout',
dataType: 'json', // json、formdata、x-www-form-urlencoded, 默认是formdata
// request headers
headers: {
csrfToken: 'csrf_token'
},
// 全局返回拦截器
interceptors: res => ({
success: res.code === 200,
data: res.result
}),
// 请求拦截器
requestInterceptors: (url, options) => {
if (req.fullUrl?.length > 2000) {
throw new Error('不能超过2000');
}
return true;
},
401: res => {
console.log('自定义401状态码处理', res);
},
403: res => console.log('自定义403状态码处理', res);
// 全局通用错误处理
onError: err => {
// message.error(err.message || '服务器未知错误');
console.error(err.message || err.msg || '服务器未知错误')
}
});
const userService = createService({
query: {
url: '/users'
},
detail: {
url: '/users/:id'
}
add: {
url: '/users',
method: 'post'
},
update: {
url: '/users/:id',
method: 'put'
},
remove: {
url: '/users/:id',
method: 'delete'
}
});
userService.query({
current: 1,
pageSize: 20
}).then(data => console.log(data));
userService.detail({ id: 1 }).then(user => console.log(user));
userService.add({
name: 'zhangsan',
age: 22,
job: 'developer'
}).then(
data => console.log(data)
);
userService.update({
id: 1,
name: 'zhangsan',
age: 25,
job: 'FE'
}).then(
data => console.log(data)
);
userService.remove({ id: 1 });
目前 service 里面默认处理是依据报文 success 字段来判断请求结果是否正常,如果是 true 则认为请求正常,且返回的是 response 的 data 字段,否则任务请求异常会走到 catch,返回的是原始的 response 报文。如果服务端 Response 数据结构如 service 内部定义的骨架结构,可以通过全局 interceptors 来做一个 Response 数据结构转换成符合规则的结构。
{
"success": true, // true 请求成功, false 请求异常
"data": {} // 请求返回的主体数据
}
interceptors 主要是用来对 Response 数据做数据处理和转换的,什么时候需要用到 interceptors 配置?
import service from 'lib-service';
const createService = service({
// 全局拦截器,凡是用 createService方法创建的服务都会支持这个拦截器
interceptors: res => ({
success: res.code === 200,
data: res.result
}),
onError: err => console.err('兜底错误处理...', err)
});
const userService = createService({
query: {
url: '/users'
},
login: {
url: '/login'
}
}, {
interceptors: [{
// 匹配所有请求
'.*': res => ({
..res,
data: res.result
}),
}, {
// 匹配 /users请求
'/users': res => ({
...res,
current: res.curPage
})
}]
});
userService.query({
current: 1,
pageSize: 20
}).then(
data => console.log(data)
).catch(err => {
// 自定义处理
alert(err);
// 如果throw 出去则会继续走兜底错误处理,否则不会执行兜底错误处理
throw err;
});
userService.login().then(data => console.log(data));
const [confirmLoading, setConfirmLoading] = useState(false);
const onSubmit = values => {
setConfirmLoaindg(true);
service.create({
name: 'zhangsan'
}).then(
() => setConfirmLoading(false);
).catch(err => {
// 请求失败了,需要重置loading
setConfirmLoading(false);
// 记住这里catch的err 需要 throw出去,不然兜底错误不会执行
throw err;
});
};
const service = createService({
update: {
url: "/update?id={id}",
method: "POST",
},
});
// case 1
service.update({
id: 1,
name: "Hello",
});
// url: /update?id=1
// request body: { id: 1, name: "Hello" }
// case 2 (特殊情况)
service.update(
{
id: 1,
roles: [{ name: "admin", value: 1 }],
},
{
// 如果设置了body 则request body 会忽略第一个参数
body: [{ name: "admin", value: 1 }],
}
);
// url: /update?id=1
// request body: [{ name: 'admin', value: 1 }]
FAQs
create services by json config
We found that @tntd/lib-service demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 13 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
Open source dashboard CNAPulse tracks CVE Numbering Authorities’ publishing activity, highlighting trends and transparency across the CVE ecosystem.
Product
Detect malware, unsafe data flows, and license issues in GitHub Actions with Socket’s new workflow scanning support.
Product
Add real-time Socket webhook events to your workflows to automatically receive pull request scan results and security alerts in real time.