mirror of
https://github.com/whyour/qinglong.git
synced 2025-05-22 22:36:06 +08:00
定时任务支持多个定时规则
This commit is contained in:
parent
042d7d3b8e
commit
acc7443004
|
@ -176,6 +176,7 @@ export default (app: Router) => {
|
||||||
name: Joi.string().optional(),
|
name: Joi.string().optional(),
|
||||||
labels: Joi.array().optional(),
|
labels: Joi.array().optional(),
|
||||||
sub_id: Joi.number().optional().allow(null),
|
sub_id: Joi.number().optional().allow(null),
|
||||||
|
extra_schedules: Joi.array().optional().allow(null),
|
||||||
}),
|
}),
|
||||||
}),
|
}),
|
||||||
async (req: Request, res: Response, next: NextFunction) => {
|
async (req: Request, res: Response, next: NextFunction) => {
|
||||||
|
@ -333,6 +334,7 @@ export default (app: Router) => {
|
||||||
schedule: Joi.string().required(),
|
schedule: Joi.string().required(),
|
||||||
name: Joi.string().optional().allow(null),
|
name: Joi.string().optional().allow(null),
|
||||||
sub_id: Joi.number().optional().allow(null),
|
sub_id: Joi.number().optional().allow(null),
|
||||||
|
extra_schedules: Joi.array().optional().allow(null),
|
||||||
id: Joi.number().required(),
|
id: Joi.number().required(),
|
||||||
}),
|
}),
|
||||||
}),
|
}),
|
||||||
|
|
|
@ -18,6 +18,7 @@ export class Crontab {
|
||||||
last_running_time?: number;
|
last_running_time?: number;
|
||||||
last_execution_time?: number;
|
last_execution_time?: number;
|
||||||
sub_id?: number;
|
sub_id?: number;
|
||||||
|
extra_schedules?: Array<{ schedule: string }>;
|
||||||
|
|
||||||
constructor(options: Crontab) {
|
constructor(options: Crontab) {
|
||||||
this.name = options.name;
|
this.name = options.name;
|
||||||
|
@ -39,6 +40,7 @@ export class Crontab {
|
||||||
this.last_running_time = options.last_running_time || 0;
|
this.last_running_time = options.last_running_time || 0;
|
||||||
this.last_execution_time = options.last_execution_time || 0;
|
this.last_execution_time = options.last_execution_time || 0;
|
||||||
this.sub_id = options.sub_id;
|
this.sub_id = options.sub_id;
|
||||||
|
this.extra_schedules = options.extra_schedules;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -49,7 +51,7 @@ export enum CrontabStatus {
|
||||||
'disabled',
|
'disabled',
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface CronInstance extends Model<Crontab, Crontab>, Crontab {}
|
export interface CronInstance extends Model<Crontab, Crontab>, Crontab { }
|
||||||
export const CrontabModel = sequelize.define<CronInstance>('Crontab', {
|
export const CrontabModel = sequelize.define<CronInstance>('Crontab', {
|
||||||
name: {
|
name: {
|
||||||
unique: 'compositeIndex',
|
unique: 'compositeIndex',
|
||||||
|
@ -75,4 +77,5 @@ export const CrontabModel = sequelize.define<CronInstance>('Crontab', {
|
||||||
last_running_time: DataTypes.NUMBER,
|
last_running_time: DataTypes.NUMBER,
|
||||||
last_execution_time: DataTypes.NUMBER,
|
last_execution_time: DataTypes.NUMBER,
|
||||||
sub_id: { type: DataTypes.NUMBER, allowNull: true },
|
sub_id: { type: DataTypes.NUMBER, allowNull: true },
|
||||||
|
extra_schedules: DataTypes.JSON
|
||||||
});
|
});
|
||||||
|
|
|
@ -48,7 +48,10 @@ export default async () => {
|
||||||
} catch (error) {}
|
} catch (error) {}
|
||||||
try {
|
try {
|
||||||
await sequelize.query('alter table Crontabs add column sub_id NUMBER');
|
await sequelize.query('alter table Crontabs add column sub_id NUMBER');
|
||||||
} catch (error) {}
|
} catch (error) { }
|
||||||
|
try {
|
||||||
|
await sequelize.query('alter table Crontabs add column extra_schedules JSON');
|
||||||
|
} catch (error) { }
|
||||||
|
|
||||||
// 2.10-2.11 升级
|
// 2.10-2.11 升级
|
||||||
const cronDbFile = path.join(config.rootPath, 'db/crontab.db');
|
const cronDbFile = path.join(config.rootPath, 'db/crontab.db');
|
||||||
|
|
|
@ -7,10 +7,13 @@ service Cron {
|
||||||
rpc delCron(DeleteCronRequest) returns (DeleteCronResponse);
|
rpc delCron(DeleteCronRequest) returns (DeleteCronResponse);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
message ISchedule { string schedule = 1; }
|
||||||
|
|
||||||
message ICron {
|
message ICron {
|
||||||
string id = 1;
|
string id = 1;
|
||||||
string schedule = 2;
|
string schedule = 2;
|
||||||
string command = 3;
|
string command = 3;
|
||||||
|
repeated ISchedule extra_schedules = 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
message AddCronRequest { repeated ICron crons = 1; }
|
message AddCronRequest { repeated ICron crons = 1; }
|
||||||
|
|
|
@ -10,78 +10,150 @@ import {
|
||||||
Metadata,
|
Metadata,
|
||||||
ServiceError,
|
ServiceError,
|
||||||
UntypedServiceImplementation,
|
UntypedServiceImplementation,
|
||||||
} from '@grpc/grpc-js';
|
} from "@grpc/grpc-js";
|
||||||
import _m0 from 'protobufjs/minimal';
|
import _m0 from "protobufjs/minimal";
|
||||||
|
|
||||||
export const protobufPackage = 'com.ql.cron';
|
export const protobufPackage = "com.ql.cron";
|
||||||
|
|
||||||
|
export interface ISchedule {
|
||||||
|
schedule: string;
|
||||||
|
}
|
||||||
|
|
||||||
export interface ICron {
|
export interface ICron {
|
||||||
id: string;
|
id: string;
|
||||||
schedule: string;
|
schedule: string;
|
||||||
command: string;
|
command: string;
|
||||||
|
extraSchedules: ISchedule[];
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface AddCronRequest {
|
export interface AddCronRequest {
|
||||||
crons: ICron[];
|
crons: ICron[];
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface AddCronResponse {}
|
export interface AddCronResponse {
|
||||||
|
}
|
||||||
|
|
||||||
export interface DeleteCronRequest {
|
export interface DeleteCronRequest {
|
||||||
ids: string[];
|
ids: string[];
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface DeleteCronResponse {}
|
export interface DeleteCronResponse {
|
||||||
|
}
|
||||||
|
|
||||||
|
function createBaseISchedule(): ISchedule {
|
||||||
|
return { schedule: "" };
|
||||||
|
}
|
||||||
|
|
||||||
|
export const ISchedule = {
|
||||||
|
encode(message: ISchedule, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
||||||
|
if (message.schedule !== "") {
|
||||||
|
writer.uint32(10).string(message.schedule);
|
||||||
|
}
|
||||||
|
return writer;
|
||||||
|
},
|
||||||
|
|
||||||
|
decode(input: _m0.Reader | Uint8Array, length?: number): ISchedule {
|
||||||
|
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
||||||
|
let end = length === undefined ? reader.len : reader.pos + length;
|
||||||
|
const message = createBaseISchedule();
|
||||||
|
while (reader.pos < end) {
|
||||||
|
const tag = reader.uint32();
|
||||||
|
switch (tag >>> 3) {
|
||||||
|
case 1:
|
||||||
|
if (tag !== 10) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
message.schedule = reader.string();
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if ((tag & 7) === 4 || tag === 0) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
reader.skipType(tag & 7);
|
||||||
|
}
|
||||||
|
return message;
|
||||||
|
},
|
||||||
|
|
||||||
|
fromJSON(object: any): ISchedule {
|
||||||
|
return { schedule: isSet(object.schedule) ? String(object.schedule) : "" };
|
||||||
|
},
|
||||||
|
|
||||||
|
toJSON(message: ISchedule): unknown {
|
||||||
|
const obj: any = {};
|
||||||
|
message.schedule !== undefined && (obj.schedule = message.schedule);
|
||||||
|
return obj;
|
||||||
|
},
|
||||||
|
|
||||||
|
create<I extends Exact<DeepPartial<ISchedule>, I>>(base?: I): ISchedule {
|
||||||
|
return ISchedule.fromPartial(base ?? {});
|
||||||
|
},
|
||||||
|
|
||||||
|
fromPartial<I extends Exact<DeepPartial<ISchedule>, I>>(object: I): ISchedule {
|
||||||
|
const message = createBaseISchedule();
|
||||||
|
message.schedule = object.schedule ?? "";
|
||||||
|
return message;
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
function createBaseICron(): ICron {
|
function createBaseICron(): ICron {
|
||||||
return { id: '', schedule: '', command: '' };
|
return { id: "", schedule: "", command: "", extraSchedules: [] };
|
||||||
}
|
}
|
||||||
|
|
||||||
export const ICron = {
|
export const ICron = {
|
||||||
encode(message: ICron, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
encode(message: ICron, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
||||||
if (message.id !== '') {
|
if (message.id !== "") {
|
||||||
writer.uint32(10).string(message.id);
|
writer.uint32(10).string(message.id);
|
||||||
}
|
}
|
||||||
if (message.schedule !== '') {
|
if (message.schedule !== "") {
|
||||||
writer.uint32(18).string(message.schedule);
|
writer.uint32(18).string(message.schedule);
|
||||||
}
|
}
|
||||||
if (message.command !== '') {
|
if (message.command !== "") {
|
||||||
writer.uint32(26).string(message.command);
|
writer.uint32(26).string(message.command);
|
||||||
}
|
}
|
||||||
|
for (const v of message.extraSchedules) {
|
||||||
|
ISchedule.encode(v!, writer.uint32(34).fork()).ldelim();
|
||||||
|
}
|
||||||
return writer;
|
return writer;
|
||||||
},
|
},
|
||||||
|
|
||||||
decode(input: _m0.Reader | Uint8Array, length?: number): ICron {
|
decode(input: _m0.Reader | Uint8Array, length?: number): ICron {
|
||||||
const reader =
|
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
||||||
input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
|
||||||
let end = length === undefined ? reader.len : reader.pos + length;
|
let end = length === undefined ? reader.len : reader.pos + length;
|
||||||
const message = createBaseICron();
|
const message = createBaseICron();
|
||||||
while (reader.pos < end) {
|
while (reader.pos < end) {
|
||||||
const tag = reader.uint32();
|
const tag = reader.uint32();
|
||||||
switch (tag >>> 3) {
|
switch (tag >>> 3) {
|
||||||
case 1:
|
case 1:
|
||||||
if (tag != 10) {
|
if (tag !== 10) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
message.id = reader.string();
|
message.id = reader.string();
|
||||||
continue;
|
continue;
|
||||||
case 2:
|
case 2:
|
||||||
if (tag != 18) {
|
if (tag !== 18) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
message.schedule = reader.string();
|
message.schedule = reader.string();
|
||||||
continue;
|
continue;
|
||||||
case 3:
|
case 3:
|
||||||
if (tag != 26) {
|
if (tag !== 26) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
message.command = reader.string();
|
message.command = reader.string();
|
||||||
continue;
|
continue;
|
||||||
|
case 4:
|
||||||
|
if (tag !== 34) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
message.extraSchedules.push(ISchedule.decode(reader, reader.uint32()));
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
if ((tag & 7) == 4 || tag == 0) {
|
if ((tag & 7) === 4 || tag === 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
reader.skipType(tag & 7);
|
reader.skipType(tag & 7);
|
||||||
|
@ -91,9 +163,12 @@ export const ICron = {
|
||||||
|
|
||||||
fromJSON(object: any): ICron {
|
fromJSON(object: any): ICron {
|
||||||
return {
|
return {
|
||||||
id: isSet(object.id) ? String(object.id) : '',
|
id: isSet(object.id) ? String(object.id) : "",
|
||||||
schedule: isSet(object.schedule) ? String(object.schedule) : '',
|
schedule: isSet(object.schedule) ? String(object.schedule) : "",
|
||||||
command: isSet(object.command) ? String(object.command) : '',
|
command: isSet(object.command) ? String(object.command) : "",
|
||||||
|
extraSchedules: Array.isArray(object?.extraSchedules)
|
||||||
|
? object.extraSchedules.map((e: any) => ISchedule.fromJSON(e))
|
||||||
|
: [],
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -102,6 +177,11 @@ export const ICron = {
|
||||||
message.id !== undefined && (obj.id = message.id);
|
message.id !== undefined && (obj.id = message.id);
|
||||||
message.schedule !== undefined && (obj.schedule = message.schedule);
|
message.schedule !== undefined && (obj.schedule = message.schedule);
|
||||||
message.command !== undefined && (obj.command = message.command);
|
message.command !== undefined && (obj.command = message.command);
|
||||||
|
if (message.extraSchedules) {
|
||||||
|
obj.extraSchedules = message.extraSchedules.map((e) => e ? ISchedule.toJSON(e) : undefined);
|
||||||
|
} else {
|
||||||
|
obj.extraSchedules = [];
|
||||||
|
}
|
||||||
return obj;
|
return obj;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -111,9 +191,10 @@ export const ICron = {
|
||||||
|
|
||||||
fromPartial<I extends Exact<DeepPartial<ICron>, I>>(object: I): ICron {
|
fromPartial<I extends Exact<DeepPartial<ICron>, I>>(object: I): ICron {
|
||||||
const message = createBaseICron();
|
const message = createBaseICron();
|
||||||
message.id = object.id ?? '';
|
message.id = object.id ?? "";
|
||||||
message.schedule = object.schedule ?? '';
|
message.schedule = object.schedule ?? "";
|
||||||
message.command = object.command ?? '';
|
message.command = object.command ?? "";
|
||||||
|
message.extraSchedules = object.extraSchedules?.map((e) => ISchedule.fromPartial(e)) || [];
|
||||||
return message;
|
return message;
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -123,10 +204,7 @@ function createBaseAddCronRequest(): AddCronRequest {
|
||||||
}
|
}
|
||||||
|
|
||||||
export const AddCronRequest = {
|
export const AddCronRequest = {
|
||||||
encode(
|
encode(message: AddCronRequest, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
||||||
message: AddCronRequest,
|
|
||||||
writer: _m0.Writer = _m0.Writer.create(),
|
|
||||||
): _m0.Writer {
|
|
||||||
for (const v of message.crons) {
|
for (const v of message.crons) {
|
||||||
ICron.encode(v!, writer.uint32(10).fork()).ldelim();
|
ICron.encode(v!, writer.uint32(10).fork()).ldelim();
|
||||||
}
|
}
|
||||||
|
@ -134,22 +212,21 @@ export const AddCronRequest = {
|
||||||
},
|
},
|
||||||
|
|
||||||
decode(input: _m0.Reader | Uint8Array, length?: number): AddCronRequest {
|
decode(input: _m0.Reader | Uint8Array, length?: number): AddCronRequest {
|
||||||
const reader =
|
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
||||||
input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
|
||||||
let end = length === undefined ? reader.len : reader.pos + length;
|
let end = length === undefined ? reader.len : reader.pos + length;
|
||||||
const message = createBaseAddCronRequest();
|
const message = createBaseAddCronRequest();
|
||||||
while (reader.pos < end) {
|
while (reader.pos < end) {
|
||||||
const tag = reader.uint32();
|
const tag = reader.uint32();
|
||||||
switch (tag >>> 3) {
|
switch (tag >>> 3) {
|
||||||
case 1:
|
case 1:
|
||||||
if (tag != 10) {
|
if (tag !== 10) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
message.crons.push(ICron.decode(reader, reader.uint32()));
|
message.crons.push(ICron.decode(reader, reader.uint32()));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ((tag & 7) == 4 || tag == 0) {
|
if ((tag & 7) === 4 || tag === 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
reader.skipType(tag & 7);
|
reader.skipType(tag & 7);
|
||||||
|
@ -158,32 +235,24 @@ export const AddCronRequest = {
|
||||||
},
|
},
|
||||||
|
|
||||||
fromJSON(object: any): AddCronRequest {
|
fromJSON(object: any): AddCronRequest {
|
||||||
return {
|
return { crons: Array.isArray(object?.crons) ? object.crons.map((e: any) => ICron.fromJSON(e)) : [] };
|
||||||
crons: Array.isArray(object?.crons)
|
|
||||||
? object.crons.map((e: any) => ICron.fromJSON(e))
|
|
||||||
: [],
|
|
||||||
};
|
|
||||||
},
|
},
|
||||||
|
|
||||||
toJSON(message: AddCronRequest): unknown {
|
toJSON(message: AddCronRequest): unknown {
|
||||||
const obj: any = {};
|
const obj: any = {};
|
||||||
if (message.crons) {
|
if (message.crons) {
|
||||||
obj.crons = message.crons.map((e) => (e ? ICron.toJSON(e) : undefined));
|
obj.crons = message.crons.map((e) => e ? ICron.toJSON(e) : undefined);
|
||||||
} else {
|
} else {
|
||||||
obj.crons = [];
|
obj.crons = [];
|
||||||
}
|
}
|
||||||
return obj;
|
return obj;
|
||||||
},
|
},
|
||||||
|
|
||||||
create<I extends Exact<DeepPartial<AddCronRequest>, I>>(
|
create<I extends Exact<DeepPartial<AddCronRequest>, I>>(base?: I): AddCronRequest {
|
||||||
base?: I,
|
|
||||||
): AddCronRequest {
|
|
||||||
return AddCronRequest.fromPartial(base ?? {});
|
return AddCronRequest.fromPartial(base ?? {});
|
||||||
},
|
},
|
||||||
|
|
||||||
fromPartial<I extends Exact<DeepPartial<AddCronRequest>, I>>(
|
fromPartial<I extends Exact<DeepPartial<AddCronRequest>, I>>(object: I): AddCronRequest {
|
||||||
object: I,
|
|
||||||
): AddCronRequest {
|
|
||||||
const message = createBaseAddCronRequest();
|
const message = createBaseAddCronRequest();
|
||||||
message.crons = object.crons?.map((e) => ICron.fromPartial(e)) || [];
|
message.crons = object.crons?.map((e) => ICron.fromPartial(e)) || [];
|
||||||
return message;
|
return message;
|
||||||
|
@ -195,23 +264,19 @@ function createBaseAddCronResponse(): AddCronResponse {
|
||||||
}
|
}
|
||||||
|
|
||||||
export const AddCronResponse = {
|
export const AddCronResponse = {
|
||||||
encode(
|
encode(_: AddCronResponse, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
||||||
_: AddCronResponse,
|
|
||||||
writer: _m0.Writer = _m0.Writer.create(),
|
|
||||||
): _m0.Writer {
|
|
||||||
return writer;
|
return writer;
|
||||||
},
|
},
|
||||||
|
|
||||||
decode(input: _m0.Reader | Uint8Array, length?: number): AddCronResponse {
|
decode(input: _m0.Reader | Uint8Array, length?: number): AddCronResponse {
|
||||||
const reader =
|
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
||||||
input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
|
||||||
let end = length === undefined ? reader.len : reader.pos + length;
|
let end = length === undefined ? reader.len : reader.pos + length;
|
||||||
const message = createBaseAddCronResponse();
|
const message = createBaseAddCronResponse();
|
||||||
while (reader.pos < end) {
|
while (reader.pos < end) {
|
||||||
const tag = reader.uint32();
|
const tag = reader.uint32();
|
||||||
switch (tag >>> 3) {
|
switch (tag >>> 3) {
|
||||||
}
|
}
|
||||||
if ((tag & 7) == 4 || tag == 0) {
|
if ((tag & 7) === 4 || tag === 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
reader.skipType(tag & 7);
|
reader.skipType(tag & 7);
|
||||||
|
@ -228,15 +293,11 @@ export const AddCronResponse = {
|
||||||
return obj;
|
return obj;
|
||||||
},
|
},
|
||||||
|
|
||||||
create<I extends Exact<DeepPartial<AddCronResponse>, I>>(
|
create<I extends Exact<DeepPartial<AddCronResponse>, I>>(base?: I): AddCronResponse {
|
||||||
base?: I,
|
|
||||||
): AddCronResponse {
|
|
||||||
return AddCronResponse.fromPartial(base ?? {});
|
return AddCronResponse.fromPartial(base ?? {});
|
||||||
},
|
},
|
||||||
|
|
||||||
fromPartial<I extends Exact<DeepPartial<AddCronResponse>, I>>(
|
fromPartial<I extends Exact<DeepPartial<AddCronResponse>, I>>(_: I): AddCronResponse {
|
||||||
_: I,
|
|
||||||
): AddCronResponse {
|
|
||||||
const message = createBaseAddCronResponse();
|
const message = createBaseAddCronResponse();
|
||||||
return message;
|
return message;
|
||||||
},
|
},
|
||||||
|
@ -247,10 +308,7 @@ function createBaseDeleteCronRequest(): DeleteCronRequest {
|
||||||
}
|
}
|
||||||
|
|
||||||
export const DeleteCronRequest = {
|
export const DeleteCronRequest = {
|
||||||
encode(
|
encode(message: DeleteCronRequest, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
||||||
message: DeleteCronRequest,
|
|
||||||
writer: _m0.Writer = _m0.Writer.create(),
|
|
||||||
): _m0.Writer {
|
|
||||||
for (const v of message.ids) {
|
for (const v of message.ids) {
|
||||||
writer.uint32(10).string(v!);
|
writer.uint32(10).string(v!);
|
||||||
}
|
}
|
||||||
|
@ -258,22 +316,21 @@ export const DeleteCronRequest = {
|
||||||
},
|
},
|
||||||
|
|
||||||
decode(input: _m0.Reader | Uint8Array, length?: number): DeleteCronRequest {
|
decode(input: _m0.Reader | Uint8Array, length?: number): DeleteCronRequest {
|
||||||
const reader =
|
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
||||||
input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
|
||||||
let end = length === undefined ? reader.len : reader.pos + length;
|
let end = length === undefined ? reader.len : reader.pos + length;
|
||||||
const message = createBaseDeleteCronRequest();
|
const message = createBaseDeleteCronRequest();
|
||||||
while (reader.pos < end) {
|
while (reader.pos < end) {
|
||||||
const tag = reader.uint32();
|
const tag = reader.uint32();
|
||||||
switch (tag >>> 3) {
|
switch (tag >>> 3) {
|
||||||
case 1:
|
case 1:
|
||||||
if (tag != 10) {
|
if (tag !== 10) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
message.ids.push(reader.string());
|
message.ids.push(reader.string());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ((tag & 7) == 4 || tag == 0) {
|
if ((tag & 7) === 4 || tag === 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
reader.skipType(tag & 7);
|
reader.skipType(tag & 7);
|
||||||
|
@ -282,11 +339,7 @@ export const DeleteCronRequest = {
|
||||||
},
|
},
|
||||||
|
|
||||||
fromJSON(object: any): DeleteCronRequest {
|
fromJSON(object: any): DeleteCronRequest {
|
||||||
return {
|
return { ids: Array.isArray(object?.ids) ? object.ids.map((e: any) => String(e)) : [] };
|
||||||
ids: Array.isArray(object?.ids)
|
|
||||||
? object.ids.map((e: any) => String(e))
|
|
||||||
: [],
|
|
||||||
};
|
|
||||||
},
|
},
|
||||||
|
|
||||||
toJSON(message: DeleteCronRequest): unknown {
|
toJSON(message: DeleteCronRequest): unknown {
|
||||||
|
@ -299,15 +352,11 @@ export const DeleteCronRequest = {
|
||||||
return obj;
|
return obj;
|
||||||
},
|
},
|
||||||
|
|
||||||
create<I extends Exact<DeepPartial<DeleteCronRequest>, I>>(
|
create<I extends Exact<DeepPartial<DeleteCronRequest>, I>>(base?: I): DeleteCronRequest {
|
||||||
base?: I,
|
|
||||||
): DeleteCronRequest {
|
|
||||||
return DeleteCronRequest.fromPartial(base ?? {});
|
return DeleteCronRequest.fromPartial(base ?? {});
|
||||||
},
|
},
|
||||||
|
|
||||||
fromPartial<I extends Exact<DeepPartial<DeleteCronRequest>, I>>(
|
fromPartial<I extends Exact<DeepPartial<DeleteCronRequest>, I>>(object: I): DeleteCronRequest {
|
||||||
object: I,
|
|
||||||
): DeleteCronRequest {
|
|
||||||
const message = createBaseDeleteCronRequest();
|
const message = createBaseDeleteCronRequest();
|
||||||
message.ids = object.ids?.map((e) => e) || [];
|
message.ids = object.ids?.map((e) => e) || [];
|
||||||
return message;
|
return message;
|
||||||
|
@ -319,23 +368,19 @@ function createBaseDeleteCronResponse(): DeleteCronResponse {
|
||||||
}
|
}
|
||||||
|
|
||||||
export const DeleteCronResponse = {
|
export const DeleteCronResponse = {
|
||||||
encode(
|
encode(_: DeleteCronResponse, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
||||||
_: DeleteCronResponse,
|
|
||||||
writer: _m0.Writer = _m0.Writer.create(),
|
|
||||||
): _m0.Writer {
|
|
||||||
return writer;
|
return writer;
|
||||||
},
|
},
|
||||||
|
|
||||||
decode(input: _m0.Reader | Uint8Array, length?: number): DeleteCronResponse {
|
decode(input: _m0.Reader | Uint8Array, length?: number): DeleteCronResponse {
|
||||||
const reader =
|
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
||||||
input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
|
||||||
let end = length === undefined ? reader.len : reader.pos + length;
|
let end = length === undefined ? reader.len : reader.pos + length;
|
||||||
const message = createBaseDeleteCronResponse();
|
const message = createBaseDeleteCronResponse();
|
||||||
while (reader.pos < end) {
|
while (reader.pos < end) {
|
||||||
const tag = reader.uint32();
|
const tag = reader.uint32();
|
||||||
switch (tag >>> 3) {
|
switch (tag >>> 3) {
|
||||||
}
|
}
|
||||||
if ((tag & 7) == 4 || tag == 0) {
|
if ((tag & 7) === 4 || tag === 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
reader.skipType(tag & 7);
|
reader.skipType(tag & 7);
|
||||||
|
@ -352,15 +397,11 @@ export const DeleteCronResponse = {
|
||||||
return obj;
|
return obj;
|
||||||
},
|
},
|
||||||
|
|
||||||
create<I extends Exact<DeepPartial<DeleteCronResponse>, I>>(
|
create<I extends Exact<DeepPartial<DeleteCronResponse>, I>>(base?: I): DeleteCronResponse {
|
||||||
base?: I,
|
|
||||||
): DeleteCronResponse {
|
|
||||||
return DeleteCronResponse.fromPartial(base ?? {});
|
return DeleteCronResponse.fromPartial(base ?? {});
|
||||||
},
|
},
|
||||||
|
|
||||||
fromPartial<I extends Exact<DeepPartial<DeleteCronResponse>, I>>(
|
fromPartial<I extends Exact<DeepPartial<DeleteCronResponse>, I>>(_: I): DeleteCronResponse {
|
||||||
_: I,
|
|
||||||
): DeleteCronResponse {
|
|
||||||
const message = createBaseDeleteCronResponse();
|
const message = createBaseDeleteCronResponse();
|
||||||
return message;
|
return message;
|
||||||
},
|
},
|
||||||
|
@ -369,25 +410,21 @@ export const DeleteCronResponse = {
|
||||||
export type CronService = typeof CronService;
|
export type CronService = typeof CronService;
|
||||||
export const CronService = {
|
export const CronService = {
|
||||||
addCron: {
|
addCron: {
|
||||||
path: '/com.ql.cron.Cron/addCron',
|
path: "/com.ql.cron.Cron/addCron",
|
||||||
requestStream: false,
|
requestStream: false,
|
||||||
responseStream: false,
|
responseStream: false,
|
||||||
requestSerialize: (value: AddCronRequest) =>
|
requestSerialize: (value: AddCronRequest) => Buffer.from(AddCronRequest.encode(value).finish()),
|
||||||
Buffer.from(AddCronRequest.encode(value).finish()),
|
|
||||||
requestDeserialize: (value: Buffer) => AddCronRequest.decode(value),
|
requestDeserialize: (value: Buffer) => AddCronRequest.decode(value),
|
||||||
responseSerialize: (value: AddCronResponse) =>
|
responseSerialize: (value: AddCronResponse) => Buffer.from(AddCronResponse.encode(value).finish()),
|
||||||
Buffer.from(AddCronResponse.encode(value).finish()),
|
|
||||||
responseDeserialize: (value: Buffer) => AddCronResponse.decode(value),
|
responseDeserialize: (value: Buffer) => AddCronResponse.decode(value),
|
||||||
},
|
},
|
||||||
delCron: {
|
delCron: {
|
||||||
path: '/com.ql.cron.Cron/delCron',
|
path: "/com.ql.cron.Cron/delCron",
|
||||||
requestStream: false,
|
requestStream: false,
|
||||||
responseStream: false,
|
responseStream: false,
|
||||||
requestSerialize: (value: DeleteCronRequest) =>
|
requestSerialize: (value: DeleteCronRequest) => Buffer.from(DeleteCronRequest.encode(value).finish()),
|
||||||
Buffer.from(DeleteCronRequest.encode(value).finish()),
|
|
||||||
requestDeserialize: (value: Buffer) => DeleteCronRequest.decode(value),
|
requestDeserialize: (value: Buffer) => DeleteCronRequest.decode(value),
|
||||||
responseSerialize: (value: DeleteCronResponse) =>
|
responseSerialize: (value: DeleteCronResponse) => Buffer.from(DeleteCronResponse.encode(value).finish()),
|
||||||
Buffer.from(DeleteCronResponse.encode(value).finish()),
|
|
||||||
responseDeserialize: (value: Buffer) => DeleteCronResponse.decode(value),
|
responseDeserialize: (value: Buffer) => DeleteCronResponse.decode(value),
|
||||||
},
|
},
|
||||||
} as const;
|
} as const;
|
||||||
|
@ -415,67 +452,36 @@ export interface CronClient extends Client {
|
||||||
): ClientUnaryCall;
|
): ClientUnaryCall;
|
||||||
delCron(
|
delCron(
|
||||||
request: DeleteCronRequest,
|
request: DeleteCronRequest,
|
||||||
callback: (
|
callback: (error: ServiceError | null, response: DeleteCronResponse) => void,
|
||||||
error: ServiceError | null,
|
|
||||||
response: DeleteCronResponse,
|
|
||||||
) => void,
|
|
||||||
): ClientUnaryCall;
|
): ClientUnaryCall;
|
||||||
delCron(
|
delCron(
|
||||||
request: DeleteCronRequest,
|
request: DeleteCronRequest,
|
||||||
metadata: Metadata,
|
metadata: Metadata,
|
||||||
callback: (
|
callback: (error: ServiceError | null, response: DeleteCronResponse) => void,
|
||||||
error: ServiceError | null,
|
|
||||||
response: DeleteCronResponse,
|
|
||||||
) => void,
|
|
||||||
): ClientUnaryCall;
|
): ClientUnaryCall;
|
||||||
delCron(
|
delCron(
|
||||||
request: DeleteCronRequest,
|
request: DeleteCronRequest,
|
||||||
metadata: Metadata,
|
metadata: Metadata,
|
||||||
options: Partial<CallOptions>,
|
options: Partial<CallOptions>,
|
||||||
callback: (
|
callback: (error: ServiceError | null, response: DeleteCronResponse) => void,
|
||||||
error: ServiceError | null,
|
|
||||||
response: DeleteCronResponse,
|
|
||||||
) => void,
|
|
||||||
): ClientUnaryCall;
|
): ClientUnaryCall;
|
||||||
}
|
}
|
||||||
|
|
||||||
export const CronClient = makeGenericClientConstructor(
|
export const CronClient = makeGenericClientConstructor(CronService, "com.ql.cron.Cron") as unknown as {
|
||||||
CronService,
|
new (address: string, credentials: ChannelCredentials, options?: Partial<ClientOptions>): CronClient;
|
||||||
'com.ql.cron.Cron',
|
|
||||||
) as unknown as {
|
|
||||||
new (
|
|
||||||
address: string,
|
|
||||||
credentials: ChannelCredentials,
|
|
||||||
options?: Partial<ClientOptions>,
|
|
||||||
): CronClient;
|
|
||||||
service: typeof CronService;
|
service: typeof CronService;
|
||||||
};
|
};
|
||||||
|
|
||||||
type Builtin =
|
type Builtin = Date | Function | Uint8Array | string | number | boolean | undefined;
|
||||||
| Date
|
|
||||||
| Function
|
|
||||||
| Uint8Array
|
|
||||||
| string
|
|
||||||
| number
|
|
||||||
| boolean
|
|
||||||
| undefined;
|
|
||||||
|
|
||||||
export type DeepPartial<T> = T extends Builtin
|
export type DeepPartial<T> = T extends Builtin ? T
|
||||||
? T
|
: T extends Array<infer U> ? Array<DeepPartial<U>> : T extends ReadonlyArray<infer U> ? ReadonlyArray<DeepPartial<U>>
|
||||||
: T extends Array<infer U>
|
: T extends {} ? { [K in keyof T]?: DeepPartial<T[K]> }
|
||||||
? Array<DeepPartial<U>>
|
|
||||||
: T extends ReadonlyArray<infer U>
|
|
||||||
? ReadonlyArray<DeepPartial<U>>
|
|
||||||
: T extends {}
|
|
||||||
? { [K in keyof T]?: DeepPartial<T[K]> }
|
|
||||||
: Partial<T>;
|
: Partial<T>;
|
||||||
|
|
||||||
type KeysOfUnion<T> = T extends T ? keyof T : never;
|
type KeysOfUnion<T> = T extends T ? keyof T : never;
|
||||||
export type Exact<P, I extends P> = P extends Builtin
|
export type Exact<P, I extends P> = P extends Builtin ? P
|
||||||
? P
|
: P & { [K in keyof P]: Exact<P[K], I[K]> } & { [K in Exclude<keyof I, KeysOfUnion<P>>]: never };
|
||||||
: P & { [K in keyof P]: Exact<P[K], I[K]> } & {
|
|
||||||
[K in Exclude<keyof I, KeysOfUnion<P>>]: never;
|
|
||||||
};
|
|
||||||
|
|
||||||
function isSet(value: any): boolean {
|
function isSet(value: any): boolean {
|
||||||
return value !== null && value !== undefined;
|
return value !== null && value !== undefined;
|
||||||
|
|
|
@ -12,10 +12,10 @@ import {
|
||||||
Metadata,
|
Metadata,
|
||||||
ServiceError,
|
ServiceError,
|
||||||
UntypedServiceImplementation,
|
UntypedServiceImplementation,
|
||||||
} from '@grpc/grpc-js';
|
} from "@grpc/grpc-js";
|
||||||
import _m0 from 'protobufjs/minimal';
|
import _m0 from "protobufjs/minimal";
|
||||||
|
|
||||||
export const protobufPackage = 'com.ql.health';
|
export const protobufPackage = "com.ql.health";
|
||||||
|
|
||||||
export interface HealthCheckRequest {
|
export interface HealthCheckRequest {
|
||||||
service: string;
|
service: string;
|
||||||
|
@ -33,79 +33,71 @@ export enum HealthCheckResponse_ServingStatus {
|
||||||
UNRECOGNIZED = -1,
|
UNRECOGNIZED = -1,
|
||||||
}
|
}
|
||||||
|
|
||||||
export function healthCheckResponse_ServingStatusFromJSON(
|
export function healthCheckResponse_ServingStatusFromJSON(object: any): HealthCheckResponse_ServingStatus {
|
||||||
object: any,
|
|
||||||
): HealthCheckResponse_ServingStatus {
|
|
||||||
switch (object) {
|
switch (object) {
|
||||||
case 0:
|
case 0:
|
||||||
case 'UNKNOWN':
|
case "UNKNOWN":
|
||||||
return HealthCheckResponse_ServingStatus.UNKNOWN;
|
return HealthCheckResponse_ServingStatus.UNKNOWN;
|
||||||
case 1:
|
case 1:
|
||||||
case 'SERVING':
|
case "SERVING":
|
||||||
return HealthCheckResponse_ServingStatus.SERVING;
|
return HealthCheckResponse_ServingStatus.SERVING;
|
||||||
case 2:
|
case 2:
|
||||||
case 'NOT_SERVING':
|
case "NOT_SERVING":
|
||||||
return HealthCheckResponse_ServingStatus.NOT_SERVING;
|
return HealthCheckResponse_ServingStatus.NOT_SERVING;
|
||||||
case 3:
|
case 3:
|
||||||
case 'SERVICE_UNKNOWN':
|
case "SERVICE_UNKNOWN":
|
||||||
return HealthCheckResponse_ServingStatus.SERVICE_UNKNOWN;
|
return HealthCheckResponse_ServingStatus.SERVICE_UNKNOWN;
|
||||||
case -1:
|
case -1:
|
||||||
case 'UNRECOGNIZED':
|
case "UNRECOGNIZED":
|
||||||
default:
|
default:
|
||||||
return HealthCheckResponse_ServingStatus.UNRECOGNIZED;
|
return HealthCheckResponse_ServingStatus.UNRECOGNIZED;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export function healthCheckResponse_ServingStatusToJSON(
|
export function healthCheckResponse_ServingStatusToJSON(object: HealthCheckResponse_ServingStatus): string {
|
||||||
object: HealthCheckResponse_ServingStatus,
|
|
||||||
): string {
|
|
||||||
switch (object) {
|
switch (object) {
|
||||||
case HealthCheckResponse_ServingStatus.UNKNOWN:
|
case HealthCheckResponse_ServingStatus.UNKNOWN:
|
||||||
return 'UNKNOWN';
|
return "UNKNOWN";
|
||||||
case HealthCheckResponse_ServingStatus.SERVING:
|
case HealthCheckResponse_ServingStatus.SERVING:
|
||||||
return 'SERVING';
|
return "SERVING";
|
||||||
case HealthCheckResponse_ServingStatus.NOT_SERVING:
|
case HealthCheckResponse_ServingStatus.NOT_SERVING:
|
||||||
return 'NOT_SERVING';
|
return "NOT_SERVING";
|
||||||
case HealthCheckResponse_ServingStatus.SERVICE_UNKNOWN:
|
case HealthCheckResponse_ServingStatus.SERVICE_UNKNOWN:
|
||||||
return 'SERVICE_UNKNOWN';
|
return "SERVICE_UNKNOWN";
|
||||||
case HealthCheckResponse_ServingStatus.UNRECOGNIZED:
|
case HealthCheckResponse_ServingStatus.UNRECOGNIZED:
|
||||||
default:
|
default:
|
||||||
return 'UNRECOGNIZED';
|
return "UNRECOGNIZED";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function createBaseHealthCheckRequest(): HealthCheckRequest {
|
function createBaseHealthCheckRequest(): HealthCheckRequest {
|
||||||
return { service: '' };
|
return { service: "" };
|
||||||
}
|
}
|
||||||
|
|
||||||
export const HealthCheckRequest = {
|
export const HealthCheckRequest = {
|
||||||
encode(
|
encode(message: HealthCheckRequest, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
||||||
message: HealthCheckRequest,
|
if (message.service !== "") {
|
||||||
writer: _m0.Writer = _m0.Writer.create(),
|
|
||||||
): _m0.Writer {
|
|
||||||
if (message.service !== '') {
|
|
||||||
writer.uint32(10).string(message.service);
|
writer.uint32(10).string(message.service);
|
||||||
}
|
}
|
||||||
return writer;
|
return writer;
|
||||||
},
|
},
|
||||||
|
|
||||||
decode(input: _m0.Reader | Uint8Array, length?: number): HealthCheckRequest {
|
decode(input: _m0.Reader | Uint8Array, length?: number): HealthCheckRequest {
|
||||||
const reader =
|
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
||||||
input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
|
||||||
let end = length === undefined ? reader.len : reader.pos + length;
|
let end = length === undefined ? reader.len : reader.pos + length;
|
||||||
const message = createBaseHealthCheckRequest();
|
const message = createBaseHealthCheckRequest();
|
||||||
while (reader.pos < end) {
|
while (reader.pos < end) {
|
||||||
const tag = reader.uint32();
|
const tag = reader.uint32();
|
||||||
switch (tag >>> 3) {
|
switch (tag >>> 3) {
|
||||||
case 1:
|
case 1:
|
||||||
if (tag != 10) {
|
if (tag !== 10) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
message.service = reader.string();
|
message.service = reader.string();
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ((tag & 7) == 4 || tag == 0) {
|
if ((tag & 7) === 4 || tag === 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
reader.skipType(tag & 7);
|
reader.skipType(tag & 7);
|
||||||
|
@ -114,7 +106,7 @@ export const HealthCheckRequest = {
|
||||||
},
|
},
|
||||||
|
|
||||||
fromJSON(object: any): HealthCheckRequest {
|
fromJSON(object: any): HealthCheckRequest {
|
||||||
return { service: isSet(object.service) ? String(object.service) : '' };
|
return { service: isSet(object.service) ? String(object.service) : "" };
|
||||||
},
|
},
|
||||||
|
|
||||||
toJSON(message: HealthCheckRequest): unknown {
|
toJSON(message: HealthCheckRequest): unknown {
|
||||||
|
@ -123,17 +115,13 @@ export const HealthCheckRequest = {
|
||||||
return obj;
|
return obj;
|
||||||
},
|
},
|
||||||
|
|
||||||
create<I extends Exact<DeepPartial<HealthCheckRequest>, I>>(
|
create<I extends Exact<DeepPartial<HealthCheckRequest>, I>>(base?: I): HealthCheckRequest {
|
||||||
base?: I,
|
|
||||||
): HealthCheckRequest {
|
|
||||||
return HealthCheckRequest.fromPartial(base ?? {});
|
return HealthCheckRequest.fromPartial(base ?? {});
|
||||||
},
|
},
|
||||||
|
|
||||||
fromPartial<I extends Exact<DeepPartial<HealthCheckRequest>, I>>(
|
fromPartial<I extends Exact<DeepPartial<HealthCheckRequest>, I>>(object: I): HealthCheckRequest {
|
||||||
object: I,
|
|
||||||
): HealthCheckRequest {
|
|
||||||
const message = createBaseHealthCheckRequest();
|
const message = createBaseHealthCheckRequest();
|
||||||
message.service = object.service ?? '';
|
message.service = object.service ?? "";
|
||||||
return message;
|
return message;
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -143,10 +131,7 @@ function createBaseHealthCheckResponse(): HealthCheckResponse {
|
||||||
}
|
}
|
||||||
|
|
||||||
export const HealthCheckResponse = {
|
export const HealthCheckResponse = {
|
||||||
encode(
|
encode(message: HealthCheckResponse, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer {
|
||||||
message: HealthCheckResponse,
|
|
||||||
writer: _m0.Writer = _m0.Writer.create(),
|
|
||||||
): _m0.Writer {
|
|
||||||
if (message.status !== 0) {
|
if (message.status !== 0) {
|
||||||
writer.uint32(8).int32(message.status);
|
writer.uint32(8).int32(message.status);
|
||||||
}
|
}
|
||||||
|
@ -154,22 +139,21 @@ export const HealthCheckResponse = {
|
||||||
},
|
},
|
||||||
|
|
||||||
decode(input: _m0.Reader | Uint8Array, length?: number): HealthCheckResponse {
|
decode(input: _m0.Reader | Uint8Array, length?: number): HealthCheckResponse {
|
||||||
const reader =
|
const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
||||||
input instanceof _m0.Reader ? input : _m0.Reader.create(input);
|
|
||||||
let end = length === undefined ? reader.len : reader.pos + length;
|
let end = length === undefined ? reader.len : reader.pos + length;
|
||||||
const message = createBaseHealthCheckResponse();
|
const message = createBaseHealthCheckResponse();
|
||||||
while (reader.pos < end) {
|
while (reader.pos < end) {
|
||||||
const tag = reader.uint32();
|
const tag = reader.uint32();
|
||||||
switch (tag >>> 3) {
|
switch (tag >>> 3) {
|
||||||
case 1:
|
case 1:
|
||||||
if (tag != 8) {
|
if (tag !== 8) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
message.status = reader.int32() as any;
|
message.status = reader.int32() as any;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ((tag & 7) == 4 || tag == 0) {
|
if ((tag & 7) === 4 || tag === 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
reader.skipType(tag & 7);
|
reader.skipType(tag & 7);
|
||||||
|
@ -178,29 +162,20 @@ export const HealthCheckResponse = {
|
||||||
},
|
},
|
||||||
|
|
||||||
fromJSON(object: any): HealthCheckResponse {
|
fromJSON(object: any): HealthCheckResponse {
|
||||||
return {
|
return { status: isSet(object.status) ? healthCheckResponse_ServingStatusFromJSON(object.status) : 0 };
|
||||||
status: isSet(object.status)
|
|
||||||
? healthCheckResponse_ServingStatusFromJSON(object.status)
|
|
||||||
: 0,
|
|
||||||
};
|
|
||||||
},
|
},
|
||||||
|
|
||||||
toJSON(message: HealthCheckResponse): unknown {
|
toJSON(message: HealthCheckResponse): unknown {
|
||||||
const obj: any = {};
|
const obj: any = {};
|
||||||
message.status !== undefined &&
|
message.status !== undefined && (obj.status = healthCheckResponse_ServingStatusToJSON(message.status));
|
||||||
(obj.status = healthCheckResponse_ServingStatusToJSON(message.status));
|
|
||||||
return obj;
|
return obj;
|
||||||
},
|
},
|
||||||
|
|
||||||
create<I extends Exact<DeepPartial<HealthCheckResponse>, I>>(
|
create<I extends Exact<DeepPartial<HealthCheckResponse>, I>>(base?: I): HealthCheckResponse {
|
||||||
base?: I,
|
|
||||||
): HealthCheckResponse {
|
|
||||||
return HealthCheckResponse.fromPartial(base ?? {});
|
return HealthCheckResponse.fromPartial(base ?? {});
|
||||||
},
|
},
|
||||||
|
|
||||||
fromPartial<I extends Exact<DeepPartial<HealthCheckResponse>, I>>(
|
fromPartial<I extends Exact<DeepPartial<HealthCheckResponse>, I>>(object: I): HealthCheckResponse {
|
||||||
object: I,
|
|
||||||
): HealthCheckResponse {
|
|
||||||
const message = createBaseHealthCheckResponse();
|
const message = createBaseHealthCheckResponse();
|
||||||
message.status = object.status ?? 0;
|
message.status = object.status ?? 0;
|
||||||
return message;
|
return message;
|
||||||
|
@ -210,25 +185,21 @@ export const HealthCheckResponse = {
|
||||||
export type HealthService = typeof HealthService;
|
export type HealthService = typeof HealthService;
|
||||||
export const HealthService = {
|
export const HealthService = {
|
||||||
check: {
|
check: {
|
||||||
path: '/com.ql.health.Health/Check',
|
path: "/com.ql.health.Health/Check",
|
||||||
requestStream: false,
|
requestStream: false,
|
||||||
responseStream: false,
|
responseStream: false,
|
||||||
requestSerialize: (value: HealthCheckRequest) =>
|
requestSerialize: (value: HealthCheckRequest) => Buffer.from(HealthCheckRequest.encode(value).finish()),
|
||||||
Buffer.from(HealthCheckRequest.encode(value).finish()),
|
|
||||||
requestDeserialize: (value: Buffer) => HealthCheckRequest.decode(value),
|
requestDeserialize: (value: Buffer) => HealthCheckRequest.decode(value),
|
||||||
responseSerialize: (value: HealthCheckResponse) =>
|
responseSerialize: (value: HealthCheckResponse) => Buffer.from(HealthCheckResponse.encode(value).finish()),
|
||||||
Buffer.from(HealthCheckResponse.encode(value).finish()),
|
|
||||||
responseDeserialize: (value: Buffer) => HealthCheckResponse.decode(value),
|
responseDeserialize: (value: Buffer) => HealthCheckResponse.decode(value),
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
path: '/com.ql.health.Health/Watch',
|
path: "/com.ql.health.Health/Watch",
|
||||||
requestStream: false,
|
requestStream: false,
|
||||||
responseStream: true,
|
responseStream: true,
|
||||||
requestSerialize: (value: HealthCheckRequest) =>
|
requestSerialize: (value: HealthCheckRequest) => Buffer.from(HealthCheckRequest.encode(value).finish()),
|
||||||
Buffer.from(HealthCheckRequest.encode(value).finish()),
|
|
||||||
requestDeserialize: (value: Buffer) => HealthCheckRequest.decode(value),
|
requestDeserialize: (value: Buffer) => HealthCheckRequest.decode(value),
|
||||||
responseSerialize: (value: HealthCheckResponse) =>
|
responseSerialize: (value: HealthCheckResponse) => Buffer.from(HealthCheckResponse.encode(value).finish()),
|
||||||
Buffer.from(HealthCheckResponse.encode(value).finish()),
|
|
||||||
responseDeserialize: (value: Buffer) => HealthCheckResponse.decode(value),
|
responseDeserialize: (value: Buffer) => HealthCheckResponse.decode(value),
|
||||||
},
|
},
|
||||||
} as const;
|
} as const;
|
||||||
|
@ -241,32 +212,20 @@ export interface HealthServer extends UntypedServiceImplementation {
|
||||||
export interface HealthClient extends Client {
|
export interface HealthClient extends Client {
|
||||||
check(
|
check(
|
||||||
request: HealthCheckRequest,
|
request: HealthCheckRequest,
|
||||||
callback: (
|
callback: (error: ServiceError | null, response: HealthCheckResponse) => void,
|
||||||
error: ServiceError | null,
|
|
||||||
response: HealthCheckResponse,
|
|
||||||
) => void,
|
|
||||||
): ClientUnaryCall;
|
): ClientUnaryCall;
|
||||||
check(
|
check(
|
||||||
request: HealthCheckRequest,
|
request: HealthCheckRequest,
|
||||||
metadata: Metadata,
|
metadata: Metadata,
|
||||||
callback: (
|
callback: (error: ServiceError | null, response: HealthCheckResponse) => void,
|
||||||
error: ServiceError | null,
|
|
||||||
response: HealthCheckResponse,
|
|
||||||
) => void,
|
|
||||||
): ClientUnaryCall;
|
): ClientUnaryCall;
|
||||||
check(
|
check(
|
||||||
request: HealthCheckRequest,
|
request: HealthCheckRequest,
|
||||||
metadata: Metadata,
|
metadata: Metadata,
|
||||||
options: Partial<CallOptions>,
|
options: Partial<CallOptions>,
|
||||||
callback: (
|
callback: (error: ServiceError | null, response: HealthCheckResponse) => void,
|
||||||
error: ServiceError | null,
|
|
||||||
response: HealthCheckResponse,
|
|
||||||
) => void,
|
|
||||||
): ClientUnaryCall;
|
): ClientUnaryCall;
|
||||||
watch(
|
watch(request: HealthCheckRequest, options?: Partial<CallOptions>): ClientReadableStream<HealthCheckResponse>;
|
||||||
request: HealthCheckRequest,
|
|
||||||
options?: Partial<CallOptions>,
|
|
||||||
): ClientReadableStream<HealthCheckResponse>;
|
|
||||||
watch(
|
watch(
|
||||||
request: HealthCheckRequest,
|
request: HealthCheckRequest,
|
||||||
metadata?: Metadata,
|
metadata?: Metadata,
|
||||||
|
@ -274,43 +233,21 @@ export interface HealthClient extends Client {
|
||||||
): ClientReadableStream<HealthCheckResponse>;
|
): ClientReadableStream<HealthCheckResponse>;
|
||||||
}
|
}
|
||||||
|
|
||||||
export const HealthClient = makeGenericClientConstructor(
|
export const HealthClient = makeGenericClientConstructor(HealthService, "com.ql.health.Health") as unknown as {
|
||||||
HealthService,
|
new (address: string, credentials: ChannelCredentials, options?: Partial<ClientOptions>): HealthClient;
|
||||||
'com.ql.health.Health',
|
|
||||||
) as unknown as {
|
|
||||||
new (
|
|
||||||
address: string,
|
|
||||||
credentials: ChannelCredentials,
|
|
||||||
options?: Partial<ClientOptions>,
|
|
||||||
): HealthClient;
|
|
||||||
service: typeof HealthService;
|
service: typeof HealthService;
|
||||||
};
|
};
|
||||||
|
|
||||||
type Builtin =
|
type Builtin = Date | Function | Uint8Array | string | number | boolean | undefined;
|
||||||
| Date
|
|
||||||
| Function
|
|
||||||
| Uint8Array
|
|
||||||
| string
|
|
||||||
| number
|
|
||||||
| boolean
|
|
||||||
| undefined;
|
|
||||||
|
|
||||||
export type DeepPartial<T> = T extends Builtin
|
export type DeepPartial<T> = T extends Builtin ? T
|
||||||
? T
|
: T extends Array<infer U> ? Array<DeepPartial<U>> : T extends ReadonlyArray<infer U> ? ReadonlyArray<DeepPartial<U>>
|
||||||
: T extends Array<infer U>
|
: T extends {} ? { [K in keyof T]?: DeepPartial<T[K]> }
|
||||||
? Array<DeepPartial<U>>
|
|
||||||
: T extends ReadonlyArray<infer U>
|
|
||||||
? ReadonlyArray<DeepPartial<U>>
|
|
||||||
: T extends {}
|
|
||||||
? { [K in keyof T]?: DeepPartial<T[K]> }
|
|
||||||
: Partial<T>;
|
: Partial<T>;
|
||||||
|
|
||||||
type KeysOfUnion<T> = T extends T ? keyof T : never;
|
type KeysOfUnion<T> = T extends T ? keyof T : never;
|
||||||
export type Exact<P, I extends P> = P extends Builtin
|
export type Exact<P, I extends P> = P extends Builtin ? P
|
||||||
? P
|
: P & { [K in keyof P]: Exact<P[K], I[K]> } & { [K in Exclude<keyof I, KeysOfUnion<P>>]: never };
|
||||||
: P & { [K in keyof P]: Exact<P[K], I[K]> } & {
|
|
||||||
[K in Exclude<keyof I, KeysOfUnion<P>>]: never;
|
|
||||||
};
|
|
||||||
|
|
||||||
function isSet(value: any): boolean {
|
function isSet(value: any): boolean {
|
||||||
return value !== null && value !== undefined;
|
return value !== null && value !== undefined;
|
||||||
|
|
|
@ -5,16 +5,15 @@ import { scheduleStacks } from './data';
|
||||||
import { runCron } from '../shared/runCron';
|
import { runCron } from '../shared/runCron';
|
||||||
import { QL_PREFIX, TASK_PREFIX } from '../config/const';
|
import { QL_PREFIX, TASK_PREFIX } from '../config/const';
|
||||||
import Logger from '../loaders/logger';
|
import Logger from '../loaders/logger';
|
||||||
import dayjs from 'dayjs';
|
|
||||||
|
|
||||||
const addCron = (
|
const addCron = (
|
||||||
call: ServerUnaryCall<AddCronRequest, AddCronResponse>,
|
call: ServerUnaryCall<AddCronRequest, AddCronResponse>,
|
||||||
callback: sendUnaryData<AddCronResponse>,
|
callback: sendUnaryData<AddCronResponse>,
|
||||||
) => {
|
) => {
|
||||||
for (const item of call.request.crons) {
|
for (const item of call.request.crons) {
|
||||||
const { id, schedule, command } = item;
|
const { id, schedule, command, extraSchedules } = item;
|
||||||
if (scheduleStacks.has(id)) {
|
if (scheduleStacks.has(id)) {
|
||||||
scheduleStacks.get(id)?.cancel();
|
scheduleStacks.get(id)?.forEach((x) => x.cancel());
|
||||||
}
|
}
|
||||||
|
|
||||||
let cmdStr = command.trim();
|
let cmdStr = command.trim();
|
||||||
|
@ -29,15 +28,31 @@ const addCron = (
|
||||||
command,
|
command,
|
||||||
);
|
);
|
||||||
|
|
||||||
scheduleStacks.set(
|
if (extraSchedules?.length) {
|
||||||
id,
|
extraSchedules.forEach(x => {
|
||||||
nodeSchedule.scheduleJob(id, schedule, async () => {
|
|
||||||
Logger.info(
|
Logger.info(
|
||||||
`[schedule][准备运行任务] 命令: ${cmdStr}`,
|
'[schedule][创建定时任务], 任务ID: %s, cron: %s, 执行命令: %s',
|
||||||
|
id,
|
||||||
|
x.schedule,
|
||||||
|
command,
|
||||||
);
|
);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
scheduleStacks.set(id, [
|
||||||
|
nodeSchedule.scheduleJob(id, schedule, async () => {
|
||||||
|
Logger.info(`[schedule][准备运行任务] 命令: ${cmdStr}`);
|
||||||
runCron(`ID=${id} ${cmdStr}`);
|
runCron(`ID=${id} ${cmdStr}`);
|
||||||
}),
|
}),
|
||||||
);
|
...(extraSchedules?.length
|
||||||
|
? extraSchedules.map((x) =>
|
||||||
|
nodeSchedule.scheduleJob(id, x.schedule, async () => {
|
||||||
|
Logger.info(`[schedule][准备运行任务] 命令: ${cmdStr}`);
|
||||||
|
runCron(`ID=${id} ${cmdStr}`);
|
||||||
|
}),
|
||||||
|
)
|
||||||
|
: []),
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
callback(null, null);
|
callback(null, null);
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import nodeSchedule from 'node-schedule';
|
import nodeSchedule from 'node-schedule';
|
||||||
import { ToadScheduler } from 'toad-scheduler';
|
import { ToadScheduler } from 'toad-scheduler';
|
||||||
|
|
||||||
export const scheduleStacks = new Map<string, nodeSchedule.Job>();
|
export const scheduleStacks = new Map<string, nodeSchedule.Job[]>();
|
||||||
|
|
||||||
export const intervalSchedule = new ToadScheduler();
|
export const intervalSchedule = new ToadScheduler();
|
||||||
|
|
|
@ -13,7 +13,7 @@ const delCron = (
|
||||||
'[schedule][取消定时任务], 任务ID: %s',
|
'[schedule][取消定时任务], 任务ID: %s',
|
||||||
id,
|
id,
|
||||||
);
|
);
|
||||||
scheduleStacks.get(id)?.cancel();
|
scheduleStacks.get(id)?.forEach(x => x.cancel());
|
||||||
scheduleStacks.delete(id);
|
scheduleStacks.delete(id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,9 +31,9 @@ export default class CronService {
|
||||||
const tab = new Crontab(payload);
|
const tab = new Crontab(payload);
|
||||||
tab.saved = false;
|
tab.saved = false;
|
||||||
const doc = await this.insert(tab);
|
const doc = await this.insert(tab);
|
||||||
if (this.isSixCron(doc)) {
|
if (this.isSixCron(doc) || doc.extra_schedules?.length) {
|
||||||
await cronClient.addCron([
|
await cronClient.addCron([
|
||||||
{ id: String(doc.id), schedule: doc.schedule!, command: doc.command },
|
{ id: String(doc.id), schedule: doc.schedule!, command: doc.command, extraSchedules: doc.extra_schedules || [] },
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
await this.set_crontab();
|
await this.set_crontab();
|
||||||
|
@ -52,15 +52,16 @@ export default class CronService {
|
||||||
if (doc.isDisabled === 1) {
|
if (doc.isDisabled === 1) {
|
||||||
return newDoc;
|
return newDoc;
|
||||||
}
|
}
|
||||||
if (this.isSixCron(doc)) {
|
if (this.isSixCron(doc) || doc.extra_schedules?.length) {
|
||||||
await cronClient.delCron([String(newDoc.id)]);
|
await cronClient.delCron([String(newDoc.id)]);
|
||||||
}
|
}
|
||||||
if (this.isSixCron(newDoc)) {
|
if (this.isSixCron(newDoc) || doc.extra_schedules?.length) {
|
||||||
await cronClient.addCron([
|
await cronClient.addCron([
|
||||||
{
|
{
|
||||||
id: String(newDoc.id),
|
id: String(newDoc.id),
|
||||||
schedule: newDoc.schedule!,
|
schedule: newDoc.schedule!,
|
||||||
command: newDoc.command,
|
command: newDoc.command,
|
||||||
|
extraSchedules: newDoc.extra_schedules || []
|
||||||
},
|
},
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
@ -463,6 +464,7 @@ export default class CronService {
|
||||||
id: String(doc.id),
|
id: String(doc.id),
|
||||||
schedule: doc.schedule!,
|
schedule: doc.schedule!,
|
||||||
command: doc.command,
|
command: doc.command,
|
||||||
|
extraSchedules: doc.extra_schedules || []
|
||||||
}));
|
}));
|
||||||
await cronClient.addCron(sixCron);
|
await cronClient.addCron(sixCron);
|
||||||
await this.set_crontab();
|
await this.set_crontab();
|
||||||
|
@ -519,7 +521,7 @@ export default class CronService {
|
||||||
var crontab_string = '';
|
var crontab_string = '';
|
||||||
tabs.data.forEach((tab) => {
|
tabs.data.forEach((tab) => {
|
||||||
const _schedule = tab.schedule && tab.schedule.split(/ +/);
|
const _schedule = tab.schedule && tab.schedule.split(/ +/);
|
||||||
if (tab.isDisabled === 1 || _schedule!.length !== 5) {
|
if (tab.isDisabled === 1 || _schedule!.length !== 5 || tab.extra_schedules?.length) {
|
||||||
crontab_string += '# ';
|
crontab_string += '# ';
|
||||||
crontab_string += tab.schedule;
|
crontab_string += tab.schedule;
|
||||||
crontab_string += ' ';
|
crontab_string += ' ';
|
||||||
|
@ -583,6 +585,7 @@ export default class CronService {
|
||||||
id: String(doc.id),
|
id: String(doc.id),
|
||||||
schedule: doc.schedule!,
|
schedule: doc.schedule!,
|
||||||
command: doc.command,
|
command: doc.command,
|
||||||
|
extraSchedules: doc.extra_schedules || []
|
||||||
}));
|
}));
|
||||||
await cronClient.addCron(sixCron);
|
await cronClient.addCron(sixCron);
|
||||||
}
|
}
|
||||||
|
|
|
@ -451,3 +451,9 @@ body[data-mode='phone'] header {
|
||||||
.ant-table.ant-table-middle tfoot > tr > td {
|
.ant-table.ant-table-middle tfoot > tr > td {
|
||||||
padding: 12px 16px;
|
padding: 12px 16px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
body[data-dark='true'] {
|
||||||
|
.ant-popover-arrow-content {
|
||||||
|
--antd-arrow-background-color: rgb(24, 26, 27);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -453,5 +453,6 @@
|
||||||
"主题": "Theme",
|
"主题": "Theme",
|
||||||
"语言": "Language",
|
"语言": "Language",
|
||||||
"中...": "ing...",
|
"中...": "ing...",
|
||||||
"请选择操作符": "Please select operator"
|
"请选择操作符": "Please select operator",
|
||||||
|
"新增定时规则": "New Timing Rules"
|
||||||
}
|
}
|
||||||
|
|
|
@ -453,5 +453,6 @@
|
||||||
"主题": "主题",
|
"主题": "主题",
|
||||||
"语言": "语言",
|
"语言": "语言",
|
||||||
"中...": "中...",
|
"中...": "中...",
|
||||||
"请选择操作符": "请选择操作符"
|
"请选择操作符": "请选择操作符",
|
||||||
|
"新增定时规则": "新增定时规则"
|
||||||
}
|
}
|
||||||
|
|
|
@ -183,6 +183,20 @@ const Crontab = () => {
|
||||||
sorter: {
|
sorter: {
|
||||||
compare: (a, b) => a.schedule.localeCompare(b.schedule),
|
compare: (a, b) => a.schedule.localeCompare(b.schedule),
|
||||||
},
|
},
|
||||||
|
render: (text, record) => {
|
||||||
|
return record.extra_schedules?.length ? (
|
||||||
|
<Popover
|
||||||
|
placement="right"
|
||||||
|
content={record.extra_schedules?.map((x) => (
|
||||||
|
<div>{x.schedule}</div>
|
||||||
|
))}
|
||||||
|
>
|
||||||
|
{text}
|
||||||
|
</Popover>
|
||||||
|
) : (
|
||||||
|
text
|
||||||
|
);
|
||||||
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: intl.get('最后运行时长'),
|
title: intl.get('最后运行时长'),
|
||||||
|
|
|
@ -1,10 +1,11 @@
|
||||||
import intl from 'react-intl-universal';
|
import intl from 'react-intl-universal';
|
||||||
import React, { useEffect, useState } from 'react';
|
import React, { useEffect, useState } from 'react';
|
||||||
import { Modal, message, Input, Form, Button } from 'antd';
|
import { Modal, message, Input, Form, Button, Space } from 'antd';
|
||||||
import { request } from '@/utils/http';
|
import { request } from '@/utils/http';
|
||||||
import config from '@/utils/config';
|
import config from '@/utils/config';
|
||||||
import cronParse from 'cron-parser';
|
import cronParse from 'cron-parser';
|
||||||
import EditableTagGroup from '@/components/tag';
|
import EditableTagGroup from '@/components/tag';
|
||||||
|
import { MinusCircleOutlined, PlusOutlined } from '@ant-design/icons';
|
||||||
|
|
||||||
const CronModal = ({
|
const CronModal = ({
|
||||||
cron,
|
cron,
|
||||||
|
@ -107,6 +108,38 @@ const CronModal = ({
|
||||||
>
|
>
|
||||||
<Input placeholder={intl.get('秒(可选) 分 时 天 月 周')} />
|
<Input placeholder={intl.get('秒(可选) 分 时 天 月 周')} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
|
<Form.List name="extra_schedules">
|
||||||
|
{(fields, { add, remove }, { errors }) => (
|
||||||
|
<>
|
||||||
|
{fields.map(({ key, name, ...restField }) => (
|
||||||
|
<Form.Item key={key} noStyle>
|
||||||
|
<Space className="view-create-modal-sorts" align="baseline">
|
||||||
|
<Form.Item
|
||||||
|
{...restField}
|
||||||
|
name={[name, 'schedule']}
|
||||||
|
rules={[{ required: true }]}
|
||||||
|
>
|
||||||
|
<Input
|
||||||
|
placeholder={intl.get('秒(可选) 分 时 天 月 周')}
|
||||||
|
/>
|
||||||
|
</Form.Item>
|
||||||
|
<MinusCircleOutlined
|
||||||
|
className="dynamic-delete-button"
|
||||||
|
onClick={() => remove(name)}
|
||||||
|
/>
|
||||||
|
</Space>
|
||||||
|
</Form.Item>
|
||||||
|
))}
|
||||||
|
<Form.Item>
|
||||||
|
<a onClick={() => add({ schedule: '' })}>
|
||||||
|
<PlusOutlined />
|
||||||
|
{intl.get('新增定时规则')}
|
||||||
|
</a>
|
||||||
|
</Form.Item>
|
||||||
|
<Form.ErrorList errors={errors} />
|
||||||
|
</>
|
||||||
|
)}
|
||||||
|
</Form.List>
|
||||||
<Form.Item name="labels" label={intl.get('标签')}>
|
<Form.Item name="labels" label={intl.get('标签')}>
|
||||||
<EditableTagGroup />
|
<EditableTagGroup />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
|
|
|
@ -35,4 +35,6 @@ export interface ICrontab {
|
||||||
last_running_time?: number;
|
last_running_time?: number;
|
||||||
last_execution_time?: number;
|
last_execution_time?: number;
|
||||||
nextRunTime: Date;
|
nextRunTime: Date;
|
||||||
|
sub_id: number;
|
||||||
|
extra_schedules?: Array<{ schedule: string; }>;
|
||||||
}
|
}
|
||||||
|
|
|
@ -195,7 +195,7 @@ const ViewCreateModal = ({
|
||||||
<Input placeholder={intl.get('请输入视图名称')} />
|
<Input placeholder={intl.get('请输入视图名称')} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.List name="filters">
|
<Form.List name="filters">
|
||||||
{(fields, { add, remove }) => (
|
{(fields, { add, remove }, { errors }) => (
|
||||||
<div
|
<div
|
||||||
style={{ position: 'relative' }}
|
style={{ position: 'relative' }}
|
||||||
className={`view-filters-container ${
|
className={`view-filters-container ${
|
||||||
|
@ -297,12 +297,13 @@ const ViewCreateModal = ({
|
||||||
{intl.get('新增筛选条件')}
|
{intl.get('新增筛选条件')}
|
||||||
</a>
|
</a>
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
|
<Form.ErrorList errors={errors} />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
</Form.List>
|
</Form.List>
|
||||||
<Form.List name="sorts">
|
<Form.List name="sorts">
|
||||||
{(fields, { add, remove }) => (
|
{(fields, { add, remove }, { errors }) => (
|
||||||
<div
|
<div
|
||||||
style={{ position: 'relative' }}
|
style={{ position: 'relative' }}
|
||||||
className={`view-filters-container ${
|
className={`view-filters-container ${
|
||||||
|
@ -372,6 +373,7 @@ const ViewCreateModal = ({
|
||||||
{intl.get('新增排序方式')}
|
{intl.get('新增排序方式')}
|
||||||
</a>
|
</a>
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
|
<Form.ErrorList errors={errors} />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user