xuan_sm2tsservice
v1.0.1
Published
swagger or yapi mock to typescript services and models
Downloads
1
Readme
sm2tsservice
推荐替换为 tkit-service npm i -D tkit-service
start
cd yourProjectName
java -version
npm i sm2tsservice -D
config
edit json2service.json
,也可用 xxx.js
,然后配置 -c xxx.js
| 参数 | 值 | 说明 |
| ---------------- | ------------------------ | -------------------------------------------------------------------------------------------------------------------------------------------------- |
| url | url 或者文件地址 | swagger、yapi 文档 url 地址或者文件目录,注意:如果是本地文件,文件名不能以 http 开头 |
| requestConfig | | 拉取远程文档配置 |
| | url | 同 url |
| | headers | 请求头配置,见 headers |
| type | yapi、swagger | 标记类型,默认是 swagger |
| swaggerParser | | swagger-code-gen 配置 |
| | -o | 输出 typescript 代码目录,默认是当前 src/services |
| | -t | 模板目录,默认是工具内置模板目录 plugins/typescript-tkit/,避免修改 |
| | -l | 模板目录,默认是 typescript-angularjs,避免修改 |
| validateResponse | boolean | 是否生成校验逻辑,默认 false,详细文档 |
| yapiConfig | | yapi 相关配置 |
| | required | 当直接使用 yapi json 定义返回数据格式的时候,生成的 typescript 文件,默认情况下,所有字段都是可选的,配置成 true,则所有字段都是不可缺省的 |
| | bodyJsonRequired | 当直接使用 yapi json 定义 json 格式 body 参数的时候,生成的 typescript 文件,默认情况下,所有字段都是可选的,配置成 true,则所有字段都是不可缺省的 |
| | categoryMap | 对象,yapi 项目接口分类中英文映射,如 { "公共分类": "Common" }
|
| guardConfig | mode | 缺省, safe, strict |
| | methodUrl2OperationIdMap | 对象,http method + url => operationId 映射,如 {"get /api/xxx/xxx": "operationId"}
|
| | badParamsReg | 非法参数格式校验正则,默认 /[^a-z0-9_.[]$]/gi
,仅配置文件是 *.js
可用 |
| | prefixReg | 生成 url + Using + http method
时,需移除 url 前缀正则,默认是 /^(\/)?api\//g
,仅配置文件是 *.js
可用 |
{
"url": "./api.json", // 文件路径或url
"requestConfig": {
"url": "./api.json" // 文件路径或url
// 以下所有 request 支持的参数
// headers?: Headers;
// baseUrl?: string;
// callback?: RequestCallback;
// jar?: CookieJar | boolean;
// formData?: { [key: string]: any };
// form?: { [key: string]: any } | string;
// auth?: AuthOptions;
// oauth?: OAuthOptions;
// aws?: AWSOptions;
// hawk?: HawkOptions;
// qs?: any;
// qsStringifyOptions?: any;
// qsParseOptions?: any;
// json?: any;
// jsonReviver?: (key: string, value: any) => any;
// jsonReplacer?: (key: string, value: any) => any;
// multipart?: RequestPart[] | Multipart;
// agent?: http.Agent | https.Agent;
// agentOptions?: http.AgentOptions | https.AgentOptions;
// agentClass?: any;
// forever?: any;
// host?: string;
// port?: number;
// method?: string;
// body?: any;
// family?: 4 | 6;
// followRedirect?: boolean | ((response: http.IncomingMessage) => boolean);
// followAllRedirects?: boolean;
// followOriginalHttpMethod?: boolean;
// maxRedirects?: number;
// removeRefererHeader?: boolean;
// encoding?: string | null;
// pool?: any;
// timeout?: number;
// localAddress?: string;
// proxy?: any;
// tunnel?: boolean;
// strictSSL?: boolean;
// rejectUnauthorized?: boolean;
// time?: boolean;
// gzip?: boolean;
// preambleCRLF?: boolean;
// postambleCRLF?: boolean;
// withCredentials?: boolean;
// key?: Buffer;
// cert?: Buffer;
// passphrase?: string;
// ca?: string | Buffer | string[] | Buffer[];
// har?: HttpArchiveRequest;
// useQuerystring?: boolean;
},
"type": "yapi",
"yapiConfig": {
"required": false,
"bodyJsonRequired": false,
"categoryMap": {
"中文": "English" // yapi 接口分类中英文映射
}
},
"swaggerParser": {
"-o": "tmp/services"
},
"validateResponse": false, // 是否生成校验逻辑
"guardConfig": {
// + strict 严格模式
// - 校验 swagger tags【yapi 接口分类】是否是纯英文
// - 方法名使用 http method + url 驼峰形式
// - 新项目采用
// + safe 安全模式
// - 方法名使用 http method + url 驼峰形式
// - 老项目升级,不会校验 tags,会生成方法调用替换映射表
// + 默认
// - http method + url => operationId 映射锁定
// - 老项目维持现状
"mode": "strict",
// swagger 处理重复 operationId 逻辑有风险,因此需要锁定映射关系
"methodUrl2OperationIdMap": {
"get /api/xxx/xxx": "operationId"
}
}
}
参考下方代码,实现 ajax 类【如果使用的 axios,且后端返回数据结构遵循 { code?:number;message?:string;result: any }
,可直接复制使用】
推荐使用 tkit-ajax npm i tkit-ajax
import axios, { AxiosError } from 'axios';
import qs from 'qs';
const inst = axios.create({
timeout: 2000,
withCredentials: true,
headers: {}
});
// @cc: 检测 axios 响应状态
function onStatusError(error: AxiosError | Error) {
const err =
'response' in error && error.response
? {
code: error.response.status,
message: error.response.statusText
}
: { code: 10001, message: error.message };
if (err.code === 401 || err.code === 403) {
// @todo 未登录未授权
// EventCenter.emit('common.user.status', err);
}
return err;
}
export type AjaxPromise<R> = Promise<R>;
export interface ExtraFetchParams {
extra?: any;
}
export interface WrappedFetchParams extends ExtraFetchParams {
method: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'OPTIONS' | 'PATCH' | 'HEAD';
url: string;
data?: any; // post json
form?: any; // post form
query?: any;
header?: any;
path?: any;
}
export class WrappedFetch {
/**
* @description ajax 方法
*/
public ajax(
{ method, url, data, form, query, header, extra }: WrappedFetchParams,
path?: string,
basePath?: string
) {
let config = {
...extra,
method: method.toLocaleLowerCase(),
headers: { ...header }
};
// json
if (data) {
config = {
...config,
headers: {
...config.headers,
'Content-Type': 'application/json'
},
data
};
}
// form
if (form) {
config = {
...config,
headers: {
...config.headers,
'Content-Type': 'application/x-www-form-urlencoded'
},
data: qs.stringify(form)
};
}
return inst
.request({ ...config, url, params: query })
.then(res => res.data)
.catch(onStatusError);
}
/**
* @description 接口传参校验
*/
public check<V>(value: V, name: string) {
if (value === null || value === undefined) {
const msg = `[ERROR PARAMS]: ${name} can't be null or undefined`;
// 非生产环境,直接抛出错误
if (process.env.NODE_ENV === 'development') {
throw Error(msg);
}
}
}
}
export default new WrappedFetch();
配置 tsconfig.json[如未使用 ts-loader,还需要配置 webpack alias]
{
"paths": {
"@ajax": ["你的实现文件地址"]
}
}
./node_modules/.bin/service # 使用默认配置
./node_modules/.bin/service -c config.json # 指定配置文件
./node_modules/.bin/service --clear # 清空上次生成产物
或可以写入 package.json
,通过 npm run api
使用
{
"scripts": {
"api": "service --clear"
}
}