@lark-apaas/miaoda-cli 0.1.1-beta.1f766b6 → 0.1.2-alpha.b2b5ae5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/api/app/api.js +25 -0
- package/dist/api/app/index.js +15 -0
- package/dist/api/app/schemas.js +79 -0
- package/dist/api/app/types.js +58 -0
- package/dist/api/deploy/api.js +60 -0
- package/dist/api/deploy/index.js +16 -0
- package/dist/api/deploy/schemas.js +103 -0
- package/dist/api/deploy/types.js +22 -0
- package/dist/api/index.js +7 -1
- package/dist/api/observability/api.js +52 -0
- package/dist/api/observability/index.js +16 -0
- package/dist/api/observability/schemas.js +39 -0
- package/dist/api/observability/types.js +27 -0
- package/dist/cli/commands/app/index.js +62 -0
- package/dist/cli/commands/deploy/index.js +139 -0
- package/dist/cli/commands/index.js +6 -0
- package/dist/cli/commands/observability/index.js +227 -0
- package/dist/cli/commands/shared.js +37 -3
- package/dist/cli/handlers/app/get.js +48 -0
- package/dist/cli/handlers/app/index.js +7 -0
- package/dist/cli/handlers/app/update.js +59 -0
- package/dist/cli/handlers/deploy/deploy.js +83 -0
- package/dist/cli/handlers/deploy/error-log.js +61 -0
- package/dist/cli/handlers/deploy/get.js +70 -0
- package/dist/cli/handlers/deploy/helpers.js +41 -0
- package/dist/cli/handlers/deploy/history.js +70 -0
- package/dist/cli/handlers/deploy/index.js +14 -0
- package/dist/cli/handlers/deploy/polling.js +139 -0
- package/dist/cli/handlers/observability/analytics.js +189 -0
- package/dist/cli/handlers/observability/helpers.js +66 -0
- package/dist/cli/handlers/observability/index.js +12 -0
- package/dist/cli/handlers/observability/log.js +94 -0
- package/dist/cli/handlers/observability/metric.js +208 -0
- package/dist/cli/handlers/observability/trace.js +102 -0
- package/dist/utils/devops-error.js +28 -0
- package/dist/utils/git.js +29 -0
- package/dist/utils/http.js +32 -0
- package/dist/utils/index.js +13 -1
- package/dist/utils/output.js +338 -7
- package/dist/utils/time.js +132 -0
- package/package.json +7 -5
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getAppInfo = getAppInfo;
|
|
4
|
+
exports.updateAppMeta = updateAppMeta;
|
|
5
|
+
const http_1 = require("../../utils/http");
|
|
6
|
+
const devops_error_1 = require("../../utils/devops-error");
|
|
7
|
+
const DEFAULT_ERR_CODE = "INTERNAL_DEVOPS_ERROR";
|
|
8
|
+
function envelopeOpts(errPrefix) {
|
|
9
|
+
return {
|
|
10
|
+
errPrefix,
|
|
11
|
+
defaultErrCode: DEFAULT_ERR_CODE,
|
|
12
|
+
mapErr: devops_error_1.mapDevopsError,
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
/** GET /v1/devops/app/:appID — 获取应用详情 */
|
|
16
|
+
async function getAppInfo(appID) {
|
|
17
|
+
const url = `/v1/devops/app/${encodeURIComponent(appID)}`;
|
|
18
|
+
return (0, http_1.getInnerApi)(url, envelopeOpts("Failed to get app info"));
|
|
19
|
+
}
|
|
20
|
+
/** POST /v1/devops/app/:appID/meta — 更新应用元数据 */
|
|
21
|
+
async function updateAppMeta(req) {
|
|
22
|
+
const url = `/v1/devops/app/${encodeURIComponent(req.appID)}/meta`;
|
|
23
|
+
// 路径已带 appID,body 里也保留以匹配 BAM IDL 的 sensitive:"no" 透传约定
|
|
24
|
+
return (0, http_1.postInnerApi)(url, req, envelopeOpts("Failed to update app"));
|
|
25
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ArchType = exports.Source = exports.BizType = exports.AppType = exports.AppMode = exports.AppStatus = exports.appMetaSchema = exports.updateAppMeta = exports.getAppInfo = void 0;
|
|
4
|
+
var api_1 = require("./api");
|
|
5
|
+
Object.defineProperty(exports, "getAppInfo", { enumerable: true, get: function () { return api_1.getAppInfo; } });
|
|
6
|
+
Object.defineProperty(exports, "updateAppMeta", { enumerable: true, get: function () { return api_1.updateAppMeta; } });
|
|
7
|
+
var schemas_1 = require("./schemas");
|
|
8
|
+
Object.defineProperty(exports, "appMetaSchema", { enumerable: true, get: function () { return schemas_1.appMetaSchema; } });
|
|
9
|
+
var types_1 = require("./types");
|
|
10
|
+
Object.defineProperty(exports, "AppStatus", { enumerable: true, get: function () { return types_1.AppStatus; } });
|
|
11
|
+
Object.defineProperty(exports, "AppMode", { enumerable: true, get: function () { return types_1.AppMode; } });
|
|
12
|
+
Object.defineProperty(exports, "AppType", { enumerable: true, get: function () { return types_1.AppType; } });
|
|
13
|
+
Object.defineProperty(exports, "BizType", { enumerable: true, get: function () { return types_1.BizType; } });
|
|
14
|
+
Object.defineProperty(exports, "Source", { enumerable: true, get: function () { return types_1.Source; } });
|
|
15
|
+
Object.defineProperty(exports, "ArchType", { enumerable: true, get: function () { return types_1.ArchType; } });
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.appMetaSchema = void 0;
|
|
4
|
+
const output_1 = require("../../utils/output");
|
|
5
|
+
const types_1 = require("./types");
|
|
6
|
+
// Partial<Record<...>>:未来 BAM 加新枚举值时这里没声明也不报错,运行期 lookup 自然得 undefined
|
|
7
|
+
const STATUS_TEXT = {
|
|
8
|
+
[types_1.AppStatus.UNSPECIFIED]: "unknown",
|
|
9
|
+
[types_1.AppStatus.PREPARING]: "preparing",
|
|
10
|
+
[types_1.AppStatus.UNRELEASED]: "unreleased",
|
|
11
|
+
[types_1.AppStatus.RELEASED]: "released",
|
|
12
|
+
[types_1.AppStatus.DELETED]: "deleted",
|
|
13
|
+
[types_1.AppStatus.UPGRADING]: "upgrading",
|
|
14
|
+
};
|
|
15
|
+
const MODE_TEXT = {
|
|
16
|
+
[types_1.AppMode.UNSPECIFIED]: "unknown",
|
|
17
|
+
[types_1.AppMode.STANDARD]: "standard",
|
|
18
|
+
[types_1.AppMode.EXPERT]: "expert",
|
|
19
|
+
};
|
|
20
|
+
const TYPE_TEXT = {
|
|
21
|
+
[types_1.AppType.UNSPECIFIED]: "unknown",
|
|
22
|
+
[types_1.AppType.STANDARD]: "standard",
|
|
23
|
+
[types_1.AppType.PROTOTYPE]: "prototype",
|
|
24
|
+
[types_1.AppType.APPLICATION]: "application",
|
|
25
|
+
[types_1.AppType.DESIGN]: "design",
|
|
26
|
+
[types_1.AppType.OPENCLAW]: "openclaw",
|
|
27
|
+
[types_1.AppType.CLAW_SUB]: "claw_sub",
|
|
28
|
+
};
|
|
29
|
+
const BIZ_TYPE_TEXT = {
|
|
30
|
+
[types_1.BizType.UNSPECIFIED]: "unknown",
|
|
31
|
+
[types_1.BizType.MIAODA]: "miaoda",
|
|
32
|
+
[types_1.BizType.FORCE]: "force",
|
|
33
|
+
};
|
|
34
|
+
const ARCH_TYPE_TEXT = {
|
|
35
|
+
[types_1.ArchType.UNSPECIFIED]: "unknown",
|
|
36
|
+
[types_1.ArchType.FULL_STACK]: "full_stack",
|
|
37
|
+
[types_1.ArchType.NOT_FULL_STACK]: "not_full_stack",
|
|
38
|
+
};
|
|
39
|
+
const SOURCE_TEXT = {
|
|
40
|
+
[types_1.Source.UNSPECIFIED]: "unknown",
|
|
41
|
+
[types_1.Source.CHAT]: "chat",
|
|
42
|
+
[types_1.Source.TEMPLATE]: "template",
|
|
43
|
+
[types_1.Source.IMPORT_ZIP]: "import_zip",
|
|
44
|
+
[types_1.Source.IMPORT_BASE]: "import_base",
|
|
45
|
+
};
|
|
46
|
+
function lookup(table) {
|
|
47
|
+
return (v) => {
|
|
48
|
+
if (typeof v !== "number")
|
|
49
|
+
return undefined;
|
|
50
|
+
return table[v];
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* AppMeta 的 pretty 渲染契约。
|
|
55
|
+
*
|
|
56
|
+
* 注:BAM 没给 createdAt / updatedAt 的单位注解;先按 ms(fmt.ms)渲染,
|
|
57
|
+
* 待 e2e 真值确认后调整。enum 字段通过 derive 翻译成可读字符串,JSON 模式
|
|
58
|
+
* 仍是 BAM 原值(数字枚举),与 BAM 接口契约保持一致。
|
|
59
|
+
*/
|
|
60
|
+
exports.appMetaSchema = {
|
|
61
|
+
columns: [
|
|
62
|
+
{ key: "appID", label: "app-id" },
|
|
63
|
+
{ key: "name" },
|
|
64
|
+
{ key: "description" },
|
|
65
|
+
{ key: "status_text", label: "status", derive: (row) => lookup(STATUS_TEXT)(row.status) },
|
|
66
|
+
{ key: "appType_text", label: "type", derive: (row) => lookup(TYPE_TEXT)(row.appType) },
|
|
67
|
+
{ key: "appMode_text", label: "mode", derive: (row) => lookup(MODE_TEXT)(row.appMode) },
|
|
68
|
+
{ key: "bizType_text", label: "biz-type", derive: (row) => lookup(BIZ_TYPE_TEXT)(row.bizType) },
|
|
69
|
+
{ key: "archType_text", label: "arch", derive: (row) => lookup(ARCH_TYPE_TEXT)(row.archType) },
|
|
70
|
+
{ key: "source_text", label: "source", derive: (row) => lookup(SOURCE_TEXT)(row.source) },
|
|
71
|
+
{ key: "ownedBy", label: "owner" },
|
|
72
|
+
{ key: "createdBy", label: "creator" },
|
|
73
|
+
{ key: "dataBranchID", label: "branch" },
|
|
74
|
+
{ key: "parentAppID", label: "parent-app" },
|
|
75
|
+
{ key: "createdAt", label: "created-at", format: output_1.fmt.ms() },
|
|
76
|
+
{ key: "updatedAt", label: "updated-at", format: output_1.fmt.ms() },
|
|
77
|
+
],
|
|
78
|
+
strict: true,
|
|
79
|
+
};
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// 与 BAM lark.apaas.devops v1.0.326 对齐:
|
|
3
|
+
// - CLIGetAppInfo (4070322) → AppInfo / AppMeta
|
|
4
|
+
// - CLIUpdateAppMeta (4070323) → 入参 name? / description?
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.ArchType = exports.Source = exports.BizType = exports.AppType = exports.AppMode = exports.AppStatus = void 0;
|
|
7
|
+
/** 应用状态 */
|
|
8
|
+
var AppStatus;
|
|
9
|
+
(function (AppStatus) {
|
|
10
|
+
AppStatus[AppStatus["UNSPECIFIED"] = 0] = "UNSPECIFIED";
|
|
11
|
+
AppStatus[AppStatus["PREPARING"] = 1] = "PREPARING";
|
|
12
|
+
AppStatus[AppStatus["UNRELEASED"] = 2] = "UNRELEASED";
|
|
13
|
+
AppStatus[AppStatus["RELEASED"] = 3] = "RELEASED";
|
|
14
|
+
/** BAM 注释为 Deprecated;保留枚举以兼容历史响应数据 */
|
|
15
|
+
AppStatus[AppStatus["DELETED"] = 4] = "DELETED";
|
|
16
|
+
AppStatus[AppStatus["UPGRADING"] = 5] = "UPGRADING";
|
|
17
|
+
})(AppStatus || (exports.AppStatus = AppStatus = {}));
|
|
18
|
+
/** 应用模式 */
|
|
19
|
+
var AppMode;
|
|
20
|
+
(function (AppMode) {
|
|
21
|
+
AppMode[AppMode["UNSPECIFIED"] = 0] = "UNSPECIFIED";
|
|
22
|
+
AppMode[AppMode["STANDARD"] = 1] = "STANDARD";
|
|
23
|
+
AppMode[AppMode["EXPERT"] = 2] = "EXPERT";
|
|
24
|
+
})(AppMode || (exports.AppMode = AppMode = {}));
|
|
25
|
+
/** 应用类型 */
|
|
26
|
+
var AppType;
|
|
27
|
+
(function (AppType) {
|
|
28
|
+
AppType[AppType["UNSPECIFIED"] = 0] = "UNSPECIFIED";
|
|
29
|
+
AppType[AppType["STANDARD"] = 1] = "STANDARD";
|
|
30
|
+
AppType[AppType["PROTOTYPE"] = 2] = "PROTOTYPE";
|
|
31
|
+
AppType[AppType["APPLICATION"] = 3] = "APPLICATION";
|
|
32
|
+
AppType[AppType["DESIGN"] = 4] = "DESIGN";
|
|
33
|
+
AppType[AppType["OPENCLAW"] = 5] = "OPENCLAW";
|
|
34
|
+
AppType[AppType["CLAW_SUB"] = 6] = "CLAW_SUB";
|
|
35
|
+
})(AppType || (exports.AppType = AppType = {}));
|
|
36
|
+
/** 业务线 */
|
|
37
|
+
var BizType;
|
|
38
|
+
(function (BizType) {
|
|
39
|
+
BizType[BizType["UNSPECIFIED"] = 0] = "UNSPECIFIED";
|
|
40
|
+
BizType[BizType["MIAODA"] = 1] = "MIAODA";
|
|
41
|
+
BizType[BizType["FORCE"] = 2] = "FORCE";
|
|
42
|
+
})(BizType || (exports.BizType = BizType = {}));
|
|
43
|
+
/** 应用来源 */
|
|
44
|
+
var Source;
|
|
45
|
+
(function (Source) {
|
|
46
|
+
Source[Source["UNSPECIFIED"] = 0] = "UNSPECIFIED";
|
|
47
|
+
Source[Source["CHAT"] = 1] = "CHAT";
|
|
48
|
+
Source[Source["TEMPLATE"] = 2] = "TEMPLATE";
|
|
49
|
+
Source[Source["IMPORT_ZIP"] = 3] = "IMPORT_ZIP";
|
|
50
|
+
Source[Source["IMPORT_BASE"] = 4] = "IMPORT_BASE";
|
|
51
|
+
})(Source || (exports.Source = Source = {}));
|
|
52
|
+
/** 架构类型 */
|
|
53
|
+
var ArchType;
|
|
54
|
+
(function (ArchType) {
|
|
55
|
+
ArchType[ArchType["UNSPECIFIED"] = 0] = "UNSPECIFIED";
|
|
56
|
+
ArchType[ArchType["FULL_STACK"] = 1] = "FULL_STACK";
|
|
57
|
+
ArchType[ArchType["NOT_FULL_STACK"] = 2] = "NOT_FULL_STACK";
|
|
58
|
+
})(ArchType || (exports.ArchType = ArchType = {}));
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createRelease = createRelease;
|
|
4
|
+
exports.listPipelineInstances = listPipelineInstances;
|
|
5
|
+
exports.getErrorLog = getErrorLog;
|
|
6
|
+
exports.queryPipelineInstance = queryPipelineInstance;
|
|
7
|
+
const http_1 = require("../../utils/http");
|
|
8
|
+
const devops_error_1 = require("../../utils/devops-error");
|
|
9
|
+
const DEFAULT_ERR_CODE = "INTERNAL_DEVOPS_ERROR";
|
|
10
|
+
function envelopeOpts(errPrefix) {
|
|
11
|
+
return {
|
|
12
|
+
errPrefix,
|
|
13
|
+
defaultErrCode: DEFAULT_ERR_CODE,
|
|
14
|
+
// deploy 与 app 走同一个 PSM;业务码映射复用
|
|
15
|
+
mapErr: devops_error_1.mapDevopsError,
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
/** POST /v1/devops/app/:appID/release — 触发发布 */
|
|
19
|
+
async function createRelease(req) {
|
|
20
|
+
const url = `/v1/devops/app/${encodeURIComponent(req.appID)}/release`;
|
|
21
|
+
return (0, http_1.postInnerApi)(url, req, envelopeOpts("Failed to create release"));
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* POST /v1/pipeline/app/:appID/instance/list — 分页查询发布历史
|
|
25
|
+
*
|
|
26
|
+
* 走 lark.apaas.devops_platform PSM(同 queryPipelineInstance)。
|
|
27
|
+
* 不复用 mapDevopsError——那是 lark.apaas.devops 的业务码映射。
|
|
28
|
+
*/
|
|
29
|
+
async function listPipelineInstances(req) {
|
|
30
|
+
const url = `/v1/pipeline/app/${encodeURIComponent(req.appID)}/instance/list`;
|
|
31
|
+
return (0, http_1.postInnerApi)(url, req, {
|
|
32
|
+
errPrefix: "Failed to list deploys",
|
|
33
|
+
defaultErrCode: DEFAULT_ERR_CODE,
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* GET /v1/pipeline/app/:appID/instance/:instanceID/error_log — 获取发布错误日志
|
|
38
|
+
*
|
|
39
|
+
* 走 lark.apaas.devops_platform PSM;instanceID 即 pipelineTaskID == deploy-id。
|
|
40
|
+
* BAM CliGetToolInstanceErrorJobs(4073972),路径段无 body。
|
|
41
|
+
*/
|
|
42
|
+
async function getErrorLog(req) {
|
|
43
|
+
const url = `/v1/pipeline/app/${encodeURIComponent(req.appID)}/instance/${encodeURIComponent(req.instanceID)}/error_log`;
|
|
44
|
+
return (0, http_1.getInnerApi)(url, {
|
|
45
|
+
errPrefix: "Failed to get error log",
|
|
46
|
+
defaultErrCode: DEFAULT_ERR_CODE,
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* GET /v1/pipeline/app/:appID/instance/:instanceID/detail — 轮询发布状态
|
|
51
|
+
*
|
|
52
|
+
* 走 lark.apaas.devops_platform PSM;URL 前缀不同但共用同一管理端 gateway。
|
|
53
|
+
*/
|
|
54
|
+
async function queryPipelineInstance(req) {
|
|
55
|
+
const url = `/v1/pipeline/app/${encodeURIComponent(req.appID)}/instance/${encodeURIComponent(req.instanceID)}/detail`;
|
|
56
|
+
return (0, http_1.getInnerApi)(url, {
|
|
57
|
+
errPrefix: "Failed to query pipeline",
|
|
58
|
+
defaultErrCode: DEFAULT_ERR_CODE,
|
|
59
|
+
});
|
|
60
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NodeStatus = exports.nodeStatusFromText = exports.nodeStatusText = exports.errorJobSchema = exports.deployGetSchema = exports.deployHistorySchema = exports.queryPipelineInstance = exports.getErrorLog = exports.listPipelineInstances = exports.createRelease = void 0;
|
|
4
|
+
var api_1 = require("./api");
|
|
5
|
+
Object.defineProperty(exports, "createRelease", { enumerable: true, get: function () { return api_1.createRelease; } });
|
|
6
|
+
Object.defineProperty(exports, "listPipelineInstances", { enumerable: true, get: function () { return api_1.listPipelineInstances; } });
|
|
7
|
+
Object.defineProperty(exports, "getErrorLog", { enumerable: true, get: function () { return api_1.getErrorLog; } });
|
|
8
|
+
Object.defineProperty(exports, "queryPipelineInstance", { enumerable: true, get: function () { return api_1.queryPipelineInstance; } });
|
|
9
|
+
var schemas_1 = require("./schemas");
|
|
10
|
+
Object.defineProperty(exports, "deployHistorySchema", { enumerable: true, get: function () { return schemas_1.deployHistorySchema; } });
|
|
11
|
+
Object.defineProperty(exports, "deployGetSchema", { enumerable: true, get: function () { return schemas_1.deployGetSchema; } });
|
|
12
|
+
Object.defineProperty(exports, "errorJobSchema", { enumerable: true, get: function () { return schemas_1.errorJobSchema; } });
|
|
13
|
+
Object.defineProperty(exports, "nodeStatusText", { enumerable: true, get: function () { return schemas_1.nodeStatusText; } });
|
|
14
|
+
Object.defineProperty(exports, "nodeStatusFromText", { enumerable: true, get: function () { return schemas_1.nodeStatusFromText; } });
|
|
15
|
+
var types_1 = require("./types");
|
|
16
|
+
Object.defineProperty(exports, "NodeStatus", { enumerable: true, get: function () { return types_1.NodeStatus; } });
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.errorJobSchema = exports.deployGetSchema = exports.deployHistorySchema = void 0;
|
|
4
|
+
exports.nodeStatusText = nodeStatusText;
|
|
5
|
+
exports.nodeStatusFromText = nodeStatusFromText;
|
|
6
|
+
const output_1 = require("../../utils/output");
|
|
7
|
+
const types_1 = require("./types");
|
|
8
|
+
const NODE_STATUS_TEXT = {
|
|
9
|
+
[types_1.NodeStatus.UNSPECIFIED]: "unknown",
|
|
10
|
+
[types_1.NodeStatus.TODO]: "todo",
|
|
11
|
+
[types_1.NodeStatus.RUNNING]: "running",
|
|
12
|
+
[types_1.NodeStatus.SUCCESS]: "success",
|
|
13
|
+
[types_1.NodeStatus.FAILED]: "failed",
|
|
14
|
+
[types_1.NodeStatus.CANCELED]: "canceled",
|
|
15
|
+
[types_1.NodeStatus.HOLD_ON]: "hold_on",
|
|
16
|
+
};
|
|
17
|
+
function nodeStatusText(v) {
|
|
18
|
+
if (typeof v !== "number")
|
|
19
|
+
return undefined;
|
|
20
|
+
return NODE_STATUS_TEXT[v];
|
|
21
|
+
}
|
|
22
|
+
/** NodeStatus 文本(CLI flag 字符串)→ 枚举数值 */
|
|
23
|
+
function nodeStatusFromText(text) {
|
|
24
|
+
const lower = text.toLowerCase();
|
|
25
|
+
for (const [num, label] of Object.entries(NODE_STATUS_TEXT)) {
|
|
26
|
+
if (label === lower)
|
|
27
|
+
return Number(num);
|
|
28
|
+
}
|
|
29
|
+
return undefined;
|
|
30
|
+
}
|
|
31
|
+
function pipelineDurationMs(row) {
|
|
32
|
+
// SimpleInstance.createdAt / updatedAt:BAM IDL 未注单位,e2e 看是 ms。
|
|
33
|
+
const start = Number(row.createdAt);
|
|
34
|
+
const end = Number(row.updatedAt);
|
|
35
|
+
if (!Number.isFinite(start) || !Number.isFinite(end))
|
|
36
|
+
return undefined;
|
|
37
|
+
return end - start;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* deploy history 列表的 pretty 渲染契约。
|
|
41
|
+
*
|
|
42
|
+
* BAM 返回 SimpleInstance(pipeline 实例),状态走 NodeStatus。
|
|
43
|
+
* 默认列:deploy-id(=ID)/ status / creator / created-at / duration(updatedAt-createdAt)。
|
|
44
|
+
*/
|
|
45
|
+
exports.deployHistorySchema = {
|
|
46
|
+
columns: [
|
|
47
|
+
{ key: "ID", label: "deploy-id" },
|
|
48
|
+
{
|
|
49
|
+
key: "status_text",
|
|
50
|
+
label: "status",
|
|
51
|
+
derive: (row) => nodeStatusText(row.status),
|
|
52
|
+
},
|
|
53
|
+
{ key: "creator", label: "creator" },
|
|
54
|
+
{ key: "createdAt", label: "created-at", format: output_1.fmt.ms() },
|
|
55
|
+
{
|
|
56
|
+
key: "duration",
|
|
57
|
+
label: "duration",
|
|
58
|
+
format: output_1.fmt.durationMs(),
|
|
59
|
+
derive: pipelineDurationMs,
|
|
60
|
+
},
|
|
61
|
+
],
|
|
62
|
+
strict: true,
|
|
63
|
+
};
|
|
64
|
+
/**
|
|
65
|
+
* deploy get 单条详情的 key-value 渲染契约(基于 SimpleInstance)。
|
|
66
|
+
*
|
|
67
|
+
* 由于 BAM 没有 by-ID 的查询接口,handler 用 listPipelineInstances 在最近窗口
|
|
68
|
+
* 里筛一条 SimpleInstance 透传过来。
|
|
69
|
+
*/
|
|
70
|
+
exports.deployGetSchema = {
|
|
71
|
+
columns: [
|
|
72
|
+
{ key: "ID", label: "deploy-id" },
|
|
73
|
+
{
|
|
74
|
+
key: "status_text",
|
|
75
|
+
label: "status",
|
|
76
|
+
derive: (row) => nodeStatusText(row.status),
|
|
77
|
+
},
|
|
78
|
+
{ key: "creator", label: "creator" },
|
|
79
|
+
{ key: "updater", label: "updater" },
|
|
80
|
+
{ key: "createdAt", label: "created-at", format: output_1.fmt.ms() },
|
|
81
|
+
{ key: "updatedAt", label: "updated-at", format: output_1.fmt.ms() },
|
|
82
|
+
{
|
|
83
|
+
key: "duration",
|
|
84
|
+
label: "duration",
|
|
85
|
+
format: output_1.fmt.durationMs(),
|
|
86
|
+
derive: pipelineDurationMs,
|
|
87
|
+
},
|
|
88
|
+
{ key: "templateID", label: "template" },
|
|
89
|
+
{ key: "description" },
|
|
90
|
+
{ key: "parameters" },
|
|
91
|
+
{ key: "envVariables", label: "env-vars" },
|
|
92
|
+
],
|
|
93
|
+
strict: true,
|
|
94
|
+
};
|
|
95
|
+
/** deploy error-log 表格渲染契约 */
|
|
96
|
+
exports.errorJobSchema = {
|
|
97
|
+
columns: [
|
|
98
|
+
{ key: "jobID", label: "job-id" },
|
|
99
|
+
{ key: "componentName", label: "component" },
|
|
100
|
+
{ key: "errorMsg", label: "error", format: output_1.fmt.truncate(120) },
|
|
101
|
+
],
|
|
102
|
+
strict: true,
|
|
103
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// 与 BAM lark.apaas.devops v1.0.326 / 1.0.327 + lark.apaas.devops_platform v1.0.247 对齐:
|
|
3
|
+
// - CLICreateForceRelease (4070318) 创建发布 lark.apaas.devops
|
|
4
|
+
// - CliQueryPipelineInstance (4069872) 轮询发布状态 lark.apaas.devops_platform
|
|
5
|
+
// - CliListPipelineInstances (4073969) 分页获取发布历史 lark.apaas.devops_platform
|
|
6
|
+
// - CliGetToolInstanceErrorJobs (4073972) 获取发布错误日志 lark.apaas.devops_platform
|
|
7
|
+
//
|
|
8
|
+
// 发布单的唯一标识是 pipelineTaskID,对外即 deploy-id;error-log 等接口直接用它做
|
|
9
|
+
// URL 路径段(instanceID)。曾经的 Release/releaseID 概念已全面废弃。
|
|
10
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
11
|
+
exports.NodeStatus = void 0;
|
|
12
|
+
/** Pipeline 节点状态(devops_platform) */
|
|
13
|
+
var NodeStatus;
|
|
14
|
+
(function (NodeStatus) {
|
|
15
|
+
NodeStatus[NodeStatus["UNSPECIFIED"] = 0] = "UNSPECIFIED";
|
|
16
|
+
NodeStatus[NodeStatus["TODO"] = 1] = "TODO";
|
|
17
|
+
NodeStatus[NodeStatus["RUNNING"] = 2] = "RUNNING";
|
|
18
|
+
NodeStatus[NodeStatus["SUCCESS"] = 3] = "SUCCESS";
|
|
19
|
+
NodeStatus[NodeStatus["FAILED"] = 4] = "FAILED";
|
|
20
|
+
NodeStatus[NodeStatus["CANCELED"] = 5] = "CANCELED";
|
|
21
|
+
NodeStatus[NodeStatus["HOLD_ON"] = 6] = "HOLD_ON";
|
|
22
|
+
})(NodeStatus || (exports.NodeStatus = NodeStatus = {}));
|
package/dist/api/index.js
CHANGED
|
@@ -33,10 +33,16 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.db = exports.file = exports.plugin = void 0;
|
|
36
|
+
exports.deploy = exports.app = exports.observability = exports.db = exports.file = exports.plugin = void 0;
|
|
37
37
|
const _plugin = __importStar(require("../api/plugin/index"));
|
|
38
38
|
const _file = __importStar(require("../api/file/index"));
|
|
39
39
|
const _db = __importStar(require("../api/db/index"));
|
|
40
|
+
const _observability = __importStar(require("../api/observability/index"));
|
|
41
|
+
const _app = __importStar(require("../api/app/index"));
|
|
42
|
+
const _deploy = __importStar(require("../api/deploy/index"));
|
|
40
43
|
exports.plugin = { ..._plugin };
|
|
41
44
|
exports.file = { ..._file };
|
|
42
45
|
exports.db = { ..._db };
|
|
46
|
+
exports.observability = { ..._observability };
|
|
47
|
+
exports.app = { ..._app };
|
|
48
|
+
exports.deploy = { ..._deploy };
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.searchLogs = searchLogs;
|
|
4
|
+
exports.searchTraces = searchTraces;
|
|
5
|
+
exports.getTraces = getTraces;
|
|
6
|
+
exports.queryMetricsData = queryMetricsData;
|
|
7
|
+
exports.queryAnalyticsData = queryAnalyticsData;
|
|
8
|
+
const http_1 = require("../../utils/http");
|
|
9
|
+
const DEFAULT_ERR_CODE = "INTERNAL_OB_ERROR";
|
|
10
|
+
// ── 日志 ──
|
|
11
|
+
async function searchLogs(req) {
|
|
12
|
+
const url = `/v1/observability/app/${encodeURIComponent(req.appID)}/logs/search`;
|
|
13
|
+
return (0, http_1.postInnerApi)(url, req, {
|
|
14
|
+
errPrefix: "Failed to search logs",
|
|
15
|
+
defaultErrCode: DEFAULT_ERR_CODE,
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
// ── 链路 ──
|
|
19
|
+
async function searchTraces(req) {
|
|
20
|
+
const url = `/v1/observability/app/${encodeURIComponent(req.appID)}/traces/search`;
|
|
21
|
+
return (0, http_1.postInnerApi)(url, req, {
|
|
22
|
+
errPrefix: "Failed to search traces",
|
|
23
|
+
defaultErrCode: DEFAULT_ERR_CODE,
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
async function getTraces(req) {
|
|
27
|
+
const url = `/v1/observability/app/${encodeURIComponent(req.appID)}/traces/${encodeURIComponent(req.traceID)}`;
|
|
28
|
+
return (0, http_1.postInnerApi)(url, req, {
|
|
29
|
+
errPrefix: "Failed to get trace",
|
|
30
|
+
defaultErrCode: DEFAULT_ERR_CODE,
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
// ── 监控指标 ──
|
|
34
|
+
async function queryMetricsData(req) {
|
|
35
|
+
const url = `/v1/observability/app/${encodeURIComponent(req.appID)}/metrics/data/query`;
|
|
36
|
+
return (0, http_1.postInnerApi)(url, req, {
|
|
37
|
+
errPrefix: "Failed to query metrics",
|
|
38
|
+
defaultErrCode: DEFAULT_ERR_CODE,
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
// ── 运营指标 ──
|
|
42
|
+
//
|
|
43
|
+
// 走 BAM v1.0.122 起的批量端点 CLIBatchQueryAnalyticsData:
|
|
44
|
+
// - 路径 /analytics/data/batch_query(旧版 /analytics/data/query 已废弃)
|
|
45
|
+
// - 支持 metricTypes 数组,单次拉多个指标
|
|
46
|
+
async function queryAnalyticsData(req) {
|
|
47
|
+
const url = `/v1/observability/app/${encodeURIComponent(req.appID)}/analytics/data/batch_query`;
|
|
48
|
+
return (0, http_1.postInnerApi)(url, req, {
|
|
49
|
+
errPrefix: "Failed to query analytics",
|
|
50
|
+
defaultErrCode: DEFAULT_ERR_CODE,
|
|
51
|
+
});
|
|
52
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StatusCode = exports.SpanKind = exports.WordOperator = exports.spanSchema = exports.logItemSchema = exports.queryAnalyticsData = exports.queryMetricsData = exports.getTraces = exports.searchTraces = exports.searchLogs = void 0;
|
|
4
|
+
var api_1 = require("./api");
|
|
5
|
+
Object.defineProperty(exports, "searchLogs", { enumerable: true, get: function () { return api_1.searchLogs; } });
|
|
6
|
+
Object.defineProperty(exports, "searchTraces", { enumerable: true, get: function () { return api_1.searchTraces; } });
|
|
7
|
+
Object.defineProperty(exports, "getTraces", { enumerable: true, get: function () { return api_1.getTraces; } });
|
|
8
|
+
Object.defineProperty(exports, "queryMetricsData", { enumerable: true, get: function () { return api_1.queryMetricsData; } });
|
|
9
|
+
Object.defineProperty(exports, "queryAnalyticsData", { enumerable: true, get: function () { return api_1.queryAnalyticsData; } });
|
|
10
|
+
var schemas_1 = require("./schemas");
|
|
11
|
+
Object.defineProperty(exports, "logItemSchema", { enumerable: true, get: function () { return schemas_1.logItemSchema; } });
|
|
12
|
+
Object.defineProperty(exports, "spanSchema", { enumerable: true, get: function () { return schemas_1.spanSchema; } });
|
|
13
|
+
var types_1 = require("./types");
|
|
14
|
+
Object.defineProperty(exports, "WordOperator", { enumerable: true, get: function () { return types_1.WordOperator; } });
|
|
15
|
+
Object.defineProperty(exports, "SpanKind", { enumerable: true, get: function () { return types_1.SpanKind; } });
|
|
16
|
+
Object.defineProperty(exports, "StatusCode", { enumerable: true, get: function () { return types_1.StatusCode; } });
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.spanSchema = exports.logItemSchema = void 0;
|
|
4
|
+
const output_1 = require("../../utils/output");
|
|
5
|
+
/** LogItem 渲染契约(log search) */
|
|
6
|
+
exports.logItemSchema = {
|
|
7
|
+
columns: [
|
|
8
|
+
{ key: "timestampNs", label: "time", format: output_1.fmt.ns("yyyy-MM-dd HH:mm:ss.SSS") },
|
|
9
|
+
{ key: "severityText", label: "level" },
|
|
10
|
+
{ key: "body" },
|
|
11
|
+
],
|
|
12
|
+
strict: true,
|
|
13
|
+
};
|
|
14
|
+
/** Span 渲染契约(trace list / trace get 复用)。
|
|
15
|
+
* duration 是 client-derived(BAM 只给 start/end,没有原生 durationNs 字段)。 */
|
|
16
|
+
exports.spanSchema = {
|
|
17
|
+
columns: [
|
|
18
|
+
{ key: "startTimeUnixNano", label: "start-time", format: output_1.fmt.ns("yyyy-MM-dd HH:mm:ss.SSS") },
|
|
19
|
+
{ key: "name", label: "root-span" },
|
|
20
|
+
{
|
|
21
|
+
key: "user-id",
|
|
22
|
+
derive: (row) => {
|
|
23
|
+
return row.attributes?.user_id;
|
|
24
|
+
},
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
key: "duration",
|
|
28
|
+
label: "duration",
|
|
29
|
+
format: output_1.fmt.durationMs(),
|
|
30
|
+
derive: (row) => {
|
|
31
|
+
return row.attributes?.duration_ms;
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
{ key: "traceID", label: "trace-id" },
|
|
35
|
+
],
|
|
36
|
+
strict: true,
|
|
37
|
+
};
|
|
38
|
+
// metric / analytics 都改用 BAM v1.0.123 起的合并响应(points: {timestamp, values}),
|
|
39
|
+
// pretty 渲染走 handler 内 pivot 后的临时 schema;不再导出固定 schema。
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// ── 通用结构 ──
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.StatusCode = exports.SpanKind = exports.WordOperator = void 0;
|
|
5
|
+
/** 模糊搜索词运算符(对应后端 WordOperator) */
|
|
6
|
+
var WordOperator;
|
|
7
|
+
(function (WordOperator) {
|
|
8
|
+
WordOperator[WordOperator["AND"] = 0] = "AND";
|
|
9
|
+
WordOperator[WordOperator["OR"] = 1] = "OR";
|
|
10
|
+
})(WordOperator || (exports.WordOperator = WordOperator = {}));
|
|
11
|
+
/** OpenTelemetry SpanKind(BAM 透传) */
|
|
12
|
+
var SpanKind;
|
|
13
|
+
(function (SpanKind) {
|
|
14
|
+
SpanKind[SpanKind["UNSPECIFIED"] = 0] = "UNSPECIFIED";
|
|
15
|
+
SpanKind[SpanKind["INTERNAL"] = 1] = "INTERNAL";
|
|
16
|
+
SpanKind[SpanKind["SERVER"] = 2] = "SERVER";
|
|
17
|
+
SpanKind[SpanKind["CLIENT"] = 3] = "CLIENT";
|
|
18
|
+
SpanKind[SpanKind["PRODUCER"] = 4] = "PRODUCER";
|
|
19
|
+
SpanKind[SpanKind["CONSUMER"] = 5] = "CONSUMER";
|
|
20
|
+
})(SpanKind || (exports.SpanKind = SpanKind = {}));
|
|
21
|
+
/** Span 状态码(BAM 透传) */
|
|
22
|
+
var StatusCode;
|
|
23
|
+
(function (StatusCode) {
|
|
24
|
+
StatusCode[StatusCode["UNSET"] = 0] = "UNSET";
|
|
25
|
+
StatusCode[StatusCode["OK"] = 1] = "OK";
|
|
26
|
+
StatusCode[StatusCode["ERROR"] = 2] = "ERROR";
|
|
27
|
+
})(StatusCode || (exports.StatusCode = StatusCode = {}));
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.registerAppCommands = registerAppCommands;
|
|
4
|
+
const shared_1 = require("../../../cli/commands/shared");
|
|
5
|
+
const index_1 = require("../../../cli/handlers/app/index");
|
|
6
|
+
function registerAppCommands(program) {
|
|
7
|
+
const appCmd = program.command("app").description("应用元数据管理:查看 / 修改");
|
|
8
|
+
appCmd.action(() => {
|
|
9
|
+
appCmd.outputHelp();
|
|
10
|
+
});
|
|
11
|
+
appCmd.addHelpText("after", `
|
|
12
|
+
作用范围
|
|
13
|
+
仅供 Agent 在妙搭沙箱内调用。
|
|
14
|
+
应用上下文:沙箱内的默认应用。
|
|
15
|
+
`);
|
|
16
|
+
registerAppGet(appCmd);
|
|
17
|
+
registerAppUpdate(appCmd);
|
|
18
|
+
}
|
|
19
|
+
function registerAppGet(parent) {
|
|
20
|
+
const cmd = parent
|
|
21
|
+
.command("get")
|
|
22
|
+
.description("查看应用元数据(status / type / mode / branch / 时间戳 等)")
|
|
23
|
+
.addOption((0, shared_1.appIdOption)().hideHelp())
|
|
24
|
+
.addHelpText("after", `
|
|
25
|
+
JSON 输出
|
|
26
|
+
{"data": {"appID": "...", "name": "...", ...}}
|
|
27
|
+
|
|
28
|
+
示例
|
|
29
|
+
$ miaoda app get
|
|
30
|
+
$ miaoda app get --json
|
|
31
|
+
`);
|
|
32
|
+
cmd.action((0, shared_1.withHelp)(cmd, async (rawOpts) => {
|
|
33
|
+
(0, shared_1.rejectCliOverride)(cmd, "appId");
|
|
34
|
+
await (0, index_1.handleAppGet)({
|
|
35
|
+
appId: rawOpts.appId,
|
|
36
|
+
});
|
|
37
|
+
}));
|
|
38
|
+
}
|
|
39
|
+
function registerAppUpdate(parent) {
|
|
40
|
+
const cmd = parent
|
|
41
|
+
.command("update")
|
|
42
|
+
.description("修改应用名称 / 描述(至少传 --name 或 --description)")
|
|
43
|
+
.addOption((0, shared_1.appIdOption)().hideHelp())
|
|
44
|
+
.option("--name <name>", "新应用名称")
|
|
45
|
+
.option("--description <desc>", "新应用描述")
|
|
46
|
+
.addHelpText("after", `
|
|
47
|
+
JSON 输出
|
|
48
|
+
与 'app get' 一致:{"data": {...新 meta...}, "next_cursor": null, "has_more": false}
|
|
49
|
+
|
|
50
|
+
示例
|
|
51
|
+
$ miaoda app update --name my-store
|
|
52
|
+
$ miaoda app update --description "在线商城应用"
|
|
53
|
+
`);
|
|
54
|
+
cmd.action((0, shared_1.withHelp)(cmd, async (rawOpts) => {
|
|
55
|
+
(0, shared_1.rejectCliOverride)(cmd, "appId");
|
|
56
|
+
await (0, index_1.handleAppUpdate)({
|
|
57
|
+
appId: rawOpts.appId,
|
|
58
|
+
name: rawOpts.name,
|
|
59
|
+
description: rawOpts.description,
|
|
60
|
+
});
|
|
61
|
+
}));
|
|
62
|
+
}
|