@cdp-forge/plugin-pipeline-sdk 1.1.10 → 1.1.11
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/config/default.ts +43 -0
- package/config/test.ts +1 -0
- package/dist/ConfigListener.d.ts +1 -0
- package/dist/ConfigListener.d.ts.map +1 -1
- package/dist/ConfigListener.js +10 -3
- package/dist/ConfigListener.js.map +1 -1
- package/dist/PipelineStage.d.ts +1 -0
- package/dist/PipelineStage.d.ts.map +1 -1
- package/dist/PipelineStage.js +9 -2
- package/dist/PipelineStage.js.map +1 -1
- package/dist/config/default.ts +43 -0
- package/dist/config/test.ts +1 -0
- package/dist/index.d.ts +2 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -3
- package/dist/index.js.map +1 -1
- package/dist/startServer.d.ts.map +1 -1
- package/dist/startServer.js +10 -12
- package/dist/startServer.js.map +1 -1
- package/package.json +6 -3
- package/config/config.yml +0 -7
- package/config/plugin.yml +0 -4
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { Config } from "@cdp-forge/types";
|
|
2
|
+
type Parsed = string | number | boolean | string[] | number[];
|
|
3
|
+
|
|
4
|
+
function env<T extends Parsed>(key: string, fallback: T, type: 'string' | 'number' | 'boolean' | 'string[]' | 'number[]' = 'string'): T {
|
|
5
|
+
const val = process.env[key];
|
|
6
|
+
if (val === undefined) return fallback;
|
|
7
|
+
switch (type) {
|
|
8
|
+
case "string[]":
|
|
9
|
+
return val.split(',').map(s => s.trim()) as T;
|
|
10
|
+
case "number[]":
|
|
11
|
+
return val.split(',').map(s => Number(s.trim())) as T;
|
|
12
|
+
case "boolean":
|
|
13
|
+
return (val.toLowerCase() === 'true') as T;
|
|
14
|
+
case "number":
|
|
15
|
+
return Number(val) as T;
|
|
16
|
+
case "string":
|
|
17
|
+
return val as T;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
const config: Config = {
|
|
22
|
+
kafka: {
|
|
23
|
+
brokers: env<string[]>('KAFKA_BROKERS', ['cdp-forge-kafka-kafka-bootstrap:9092'], 'string[]'),
|
|
24
|
+
fistPipelineTopic: env("KAFKA_BASE_TOPIC", "logs")
|
|
25
|
+
},
|
|
26
|
+
mysql: {
|
|
27
|
+
uri: env("MYSQL_URI","mysql://root:cdp-forge-root-2024@cdp-forge-mysql:3306/cdpforge")
|
|
28
|
+
},
|
|
29
|
+
opensearch:{
|
|
30
|
+
url: env("OPENSEARCH_URL","https://opensearch-cluster-master:9200"),
|
|
31
|
+
username: env("OPENSEARCH_USERNAME","admin"),
|
|
32
|
+
password: env("OPENSEARCH_PASSWORD","CdpForge@2024!")
|
|
33
|
+
},
|
|
34
|
+
pipelinemanager: {
|
|
35
|
+
config_topic: env("PIPELINEMANAGER_CONFIG_TOPIC","config"),
|
|
36
|
+
url: env("PIPELINEMANAGER_URL","http://cdp-forge-core-pipeline-manager")
|
|
37
|
+
},
|
|
38
|
+
pod: {
|
|
39
|
+
name: env("CLIENT_ID", Math.random().toString(36).substring(2, 10))
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
export default config;
|
package/config/test.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default {};
|
package/dist/ConfigListener.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConfigListener.d.ts","sourceRoot":"","sources":["../src/ConfigListener.ts"],"names":[],"mappings":"AACA,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAiB,MAAM,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"ConfigListener.d.ts","sourceRoot":"","sources":["../src/ConfigListener.ts"],"names":[],"mappings":"AACA,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAiB,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAGzD,MAAM,CAAC,OAAO,OAAO,cAAc;IAC/B,OAAO,CAAC,KAAK,CAAQ;IACrB,OAAO,CAAC,QAAQ,CAAW;IAC3B,OAAO,CAAC,KAAK,CAAgB;IAC7B,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,cAAc,CAAgB;gBAE1B,KAAK,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM;IAc1C,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAgB/B"}
|
package/dist/ConfigListener.js
CHANGED
|
@@ -1,16 +1,22 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
2
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
6
|
const kafkajs_1 = require("kafkajs");
|
|
4
|
-
const
|
|
7
|
+
const config_1 = __importDefault(require("config"));
|
|
5
8
|
class ConfigListener {
|
|
6
9
|
constructor(stage, config) {
|
|
7
10
|
this.config = config;
|
|
8
11
|
this.kafka = new kafkajs_1.Kafka({
|
|
9
|
-
clientId: config.plugin.name + `plugin-${
|
|
12
|
+
clientId: config.plugin.name + `plugin-${config_1.default.get("pod.name")}`,
|
|
10
13
|
brokers: config.kafkaConfig.brokers,
|
|
11
14
|
});
|
|
12
|
-
this.consumer = this.kafka.consumer({ groupId: config.plugin.name + `plugin-${
|
|
15
|
+
this.consumer = this.kafka.consumer({ groupId: config.plugin.name + `plugin-${config_1.default.get("pod.name")}` });
|
|
13
16
|
this.stage = stage;
|
|
17
|
+
this.consumerReadyP = new Promise((resolve) => {
|
|
18
|
+
this.consumer.on("consumer.fetch_start", () => resolve());
|
|
19
|
+
});
|
|
14
20
|
}
|
|
15
21
|
async start() {
|
|
16
22
|
await this.consumer.connect();
|
|
@@ -25,6 +31,7 @@ class ConfigListener {
|
|
|
25
31
|
await this.consumer.commitOffsets([{ topic, partition, offset: (BigInt(message.offset) + 1n).toString() }]);
|
|
26
32
|
}
|
|
27
33
|
});
|
|
34
|
+
await this.consumerReadyP;
|
|
28
35
|
}
|
|
29
36
|
}
|
|
30
37
|
exports.default = ConfigListener;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConfigListener.js","sourceRoot":"","sources":["../src/ConfigListener.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ConfigListener.js","sourceRoot":"","sources":["../src/ConfigListener.ts"],"names":[],"mappings":";;;;;AAAA,qCAA4D;AAG5D,oDAAmC;AAEnC,MAAqB,cAAc;IAO/B,YAAY,KAAoB,EAAE,MAAc;QAC5C,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,KAAK,GAAG,IAAI,eAAK,CAAC;YACnB,QAAQ,EAAE,MAAM,CAAC,MAAO,CAAC,IAAI,GAAG,UAAU,gBAAa,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE;YACzE,OAAO,EAAE,MAAM,CAAC,WAAY,CAAC,OAAO;SACrC,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,MAAM,CAAC,MAAO,CAAC,IAAI,GAAG,UAAU,gBAAa,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,EAAC,CAAC,CAAC;QAEnH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,cAAc,GAAG,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;YAChD,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,sBAAsB,EAAE,GAAE,EAAE,CAAC,OAAO,EAAE,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;IACP,CAAC;IAED,KAAK,CAAC,KAAK;QACP,MAAM,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC9B,MAAM,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,OAAQ,CAAC,YAAY,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC;QAClG,MAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC;YACpB,UAAU,EAAE,KAAK;YACjB,WAAW,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAuB,EAAE,EAAE;gBACtE,MAAM,MAAM,GAAkB,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;gBAE1F,IAAI,MAAM,IAAI,MAAM,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM,CAAC,MAAO,CAAC,IAAI,EAAE,CAAC;oBACvD,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;gBACpE,CAAC;gBACD,MAAM,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC;YAChH,CAAC;SACJ,CAAC,CAAC;QACH,MAAM,IAAI,CAAC,cAAc,CAAC;IAC9B,CAAC;CACJ;AArCD,iCAqCC"}
|
package/dist/PipelineStage.d.ts
CHANGED
|
@@ -9,6 +9,7 @@ export default class PipelineSTage {
|
|
|
9
9
|
input: string | null;
|
|
10
10
|
output: string | null;
|
|
11
11
|
currentOperation: Promise<void>;
|
|
12
|
+
consumerReadyP: Promise<void>;
|
|
12
13
|
constructor(plugin: PipelinePluginI, config: Config);
|
|
13
14
|
start(inputTopic: string, outputTopic?: string | null): Promise<void>;
|
|
14
15
|
private _start;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PipelineStage.d.ts","sourceRoot":"","sources":["../src/PipelineStage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAsB,MAAM,SAAS,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAO,MAAM,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"PipelineStage.d.ts","sourceRoot":"","sources":["../src/PipelineStage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAsB,MAAM,SAAS,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAO,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAG/C,MAAM,CAAC,OAAO,OAAO,aAAa;IAC9B,MAAM,EAAE,eAAe,CAAC;IACxB,QAAQ,EAAE,QAAQ,CAAC;IACnB,QAAQ,EAAE,QAAQ,CAAC;IACnB,KAAK,EAAE,KAAK,CAAC;IACb,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,gBAAgB,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;IAChC,cAAc,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;gBAElB,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM;IAgB7C,KAAK,CAAC,UAAU,EAAE,MAAM,EAAE,WAAW,GAAE,MAAM,GAAG,IAAW,GAAG,OAAO,CAAC,IAAI,CAAC;YASnE,MAAM;IA6Bd,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;YAMb,KAAK;IAKb,OAAO,CAAC,UAAU,EAAE,MAAM,EAAC,WAAW,EAAE,MAAM,GAAC,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;CAIjF"}
|
package/dist/PipelineStage.js
CHANGED
|
@@ -1,16 +1,22 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
2
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
6
|
const kafkajs_1 = require("kafkajs");
|
|
4
|
-
const
|
|
7
|
+
const config_1 = __importDefault(require("config"));
|
|
5
8
|
class PipelineSTage {
|
|
6
9
|
constructor(plugin, config) {
|
|
7
10
|
this.plugin = plugin;
|
|
8
11
|
this.kafka = new kafkajs_1.Kafka({
|
|
9
|
-
clientId: config.plugin.name + `plugin-${
|
|
12
|
+
clientId: config.plugin.name + `plugin-${config_1.default.get("pod.name")}`,
|
|
10
13
|
brokers: config.kafkaConfig.brokers,
|
|
11
14
|
});
|
|
12
15
|
this.consumer = this.kafka.consumer({ groupId: config.plugin.name + `plugin` });
|
|
13
16
|
this.producer = this.kafka.producer();
|
|
17
|
+
this.consumerReadyP = new Promise((resolve) => {
|
|
18
|
+
this.consumer.on("consumer.fetch_start", () => resolve());
|
|
19
|
+
});
|
|
14
20
|
this.input = null;
|
|
15
21
|
this.output = null;
|
|
16
22
|
this.currentOperation = Promise.resolve();
|
|
@@ -49,6 +55,7 @@ class PipelineSTage {
|
|
|
49
55
|
}
|
|
50
56
|
},
|
|
51
57
|
});
|
|
58
|
+
await this.consumerReadyP;
|
|
52
59
|
}
|
|
53
60
|
async stop() {
|
|
54
61
|
await this.currentOperation;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PipelineStage.js","sourceRoot":"","sources":["../src/PipelineStage.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PipelineStage.js","sourceRoot":"","sources":["../src/PipelineStage.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { Config } from "@cdp-forge/types";
|
|
2
|
+
type Parsed = string | number | boolean | string[] | number[];
|
|
3
|
+
|
|
4
|
+
function env<T extends Parsed>(key: string, fallback: T, type: 'string' | 'number' | 'boolean' | 'string[]' | 'number[]' = 'string'): T {
|
|
5
|
+
const val = process.env[key];
|
|
6
|
+
if (val === undefined) return fallback;
|
|
7
|
+
switch (type) {
|
|
8
|
+
case "string[]":
|
|
9
|
+
return val.split(',').map(s => s.trim()) as T;
|
|
10
|
+
case "number[]":
|
|
11
|
+
return val.split(',').map(s => Number(s.trim())) as T;
|
|
12
|
+
case "boolean":
|
|
13
|
+
return (val.toLowerCase() === 'true') as T;
|
|
14
|
+
case "number":
|
|
15
|
+
return Number(val) as T;
|
|
16
|
+
case "string":
|
|
17
|
+
return val as T;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
const config: Config = {
|
|
22
|
+
kafka: {
|
|
23
|
+
brokers: env<string[]>('KAFKA_BROKERS', ['cdp-forge-kafka-kafka-bootstrap:9092'], 'string[]'),
|
|
24
|
+
fistPipelineTopic: env("KAFKA_BASE_TOPIC", "logs")
|
|
25
|
+
},
|
|
26
|
+
mysql: {
|
|
27
|
+
uri: env("MYSQL_URI","mysql://root:cdp-forge-root-2024@cdp-forge-mysql:3306/cdpforge")
|
|
28
|
+
},
|
|
29
|
+
opensearch:{
|
|
30
|
+
url: env("OPENSEARCH_URL","https://opensearch-cluster-master:9200"),
|
|
31
|
+
username: env("OPENSEARCH_USERNAME","admin"),
|
|
32
|
+
password: env("OPENSEARCH_PASSWORD","CdpForge@2024!")
|
|
33
|
+
},
|
|
34
|
+
pipelinemanager: {
|
|
35
|
+
config_topic: env("PIPELINEMANAGER_CONFIG_TOPIC","config"),
|
|
36
|
+
url: env("PIPELINEMANAGER_URL","http://cdp-forge-core-pipeline-manager")
|
|
37
|
+
},
|
|
38
|
+
pod: {
|
|
39
|
+
name: env("CLIENT_ID", Math.random().toString(36).substring(2, 10))
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
export default config;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default {};
|
package/dist/index.d.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
|
+
import clusterConfig from 'config';
|
|
1
2
|
export type { PipelinePluginI } from './plugin/PipelinePluginI';
|
|
2
3
|
export { default as PipelineStage } from './PipelineStage';
|
|
3
4
|
export { default as ConfigListener } from './ConfigListener';
|
|
4
|
-
export {
|
|
5
|
+
export { clusterConfig };
|
|
5
6
|
export { start } from './startServer';
|
|
6
7
|
export type * from '@cdp-forge/types';
|
|
7
8
|
export { GoogleTopicsMap } from '@cdp-forge/types';
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,aAAa,MAAM,QAAQ,CAAC;AACnC,YAAY,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,CAAC;AACzB,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACtC,mBAAmB,kBAAkB,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA"}
|
package/dist/index.js
CHANGED
|
@@ -3,13 +3,15 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.GoogleTopicsMap = exports.start = exports.
|
|
6
|
+
exports.GoogleTopicsMap = exports.start = exports.clusterConfig = exports.ConfigListener = exports.PipelineStage = void 0;
|
|
7
|
+
const dotenv_1 = __importDefault(require("dotenv"));
|
|
8
|
+
dotenv_1.default.config();
|
|
9
|
+
const config_1 = __importDefault(require("config"));
|
|
10
|
+
exports.clusterConfig = config_1.default;
|
|
7
11
|
var PipelineStage_1 = require("./PipelineStage");
|
|
8
12
|
Object.defineProperty(exports, "PipelineStage", { enumerable: true, get: function () { return __importDefault(PipelineStage_1).default; } });
|
|
9
13
|
var ConfigListener_1 = require("./ConfigListener");
|
|
10
14
|
Object.defineProperty(exports, "ConfigListener", { enumerable: true, get: function () { return __importDefault(ConfigListener_1).default; } });
|
|
11
|
-
var ConfigReader_1 = require("./ConfigReader");
|
|
12
|
-
Object.defineProperty(exports, "ConfigReader", { enumerable: true, get: function () { return __importDefault(ConfigReader_1).default; } });
|
|
13
15
|
var startServer_1 = require("./startServer");
|
|
14
16
|
Object.defineProperty(exports, "start", { enumerable: true, get: function () { return startServer_1.start; } });
|
|
15
17
|
var types_1 = require("@cdp-forge/types");
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;AAAA,oDAA4B;AAC5B,gBAAM,CAAC,MAAM,EAAE,CAAC;AAEhB,oDAAmC;AAI1B,wBAJF,gBAAa,CAIE;AAFtB,iDAA2D;AAAlD,+HAAA,OAAO,OAAiB;AACjC,mDAA6D;AAApD,iIAAA,OAAO,OAAkB;AAElC,6CAAsC;AAA7B,oGAAA,KAAK,OAAA;AAEd,0CAAkD;AAAzC,wGAAA,eAAe,OAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"startServer.d.ts","sourceRoot":"","sources":["../src/startServer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC1C,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAC5C,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAE9C,wBAAsB,KAAK,CAAC,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM;;;
|
|
1
|
+
{"version":3,"file":"startServer.d.ts","sourceRoot":"","sources":["../src/startServer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC1C,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAC5C,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAE9C,wBAAsB,KAAK,CAAC,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM;;;GAyBhE"}
|
package/dist/startServer.js
CHANGED
|
@@ -9,19 +9,17 @@ const ConfigListener_1 = __importDefault(require("./ConfigListener"));
|
|
|
9
9
|
async function start(plugin, config) {
|
|
10
10
|
const stage = new PipelineStage_1.default(plugin, config);
|
|
11
11
|
const configListener = new ConfigListener_1.default(stage, config);
|
|
12
|
-
configListener.start()
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
}).then(res => {
|
|
20
|
-
if (!res.ok) {
|
|
21
|
-
throw new Error(`Failed to register plugin with Template Manager: ${res.statusText}, request: ${JSON.stringify(config.plugin)}`);
|
|
22
|
-
}
|
|
23
|
-
});
|
|
12
|
+
await configListener.start();
|
|
13
|
+
const res = await fetch(`${config.manager.url}/register`, {
|
|
14
|
+
method: 'POST',
|
|
15
|
+
headers: {
|
|
16
|
+
'Content-Type': 'application/json',
|
|
17
|
+
},
|
|
18
|
+
body: JSON.stringify(config.plugin),
|
|
24
19
|
});
|
|
20
|
+
if (!res.ok) {
|
|
21
|
+
throw new Error(`Failed to register plugin with Template Manager: ${res.statusText}, request: ${JSON.stringify(config.plugin)}`);
|
|
22
|
+
}
|
|
25
23
|
const handleExit = async () => {
|
|
26
24
|
console.log('Arresto del server in corso...');
|
|
27
25
|
await stage.stop();
|
package/dist/startServer.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"startServer.js","sourceRoot":"","sources":["../src/startServer.ts"],"names":[],"mappings":";;;;;AAKA,
|
|
1
|
+
{"version":3,"file":"startServer.js","sourceRoot":"","sources":["../src/startServer.ts"],"names":[],"mappings":";;;;;AAKA,sBAyBG;AA5BH,oEAA4C;AAC5C,sEAA8C;AAEvC,KAAK,UAAU,KAAK,CAAC,MAAuB,EAAE,MAAc;IAC/D,MAAM,KAAK,GAAG,IAAI,uBAAa,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChD,MAAM,cAAc,GAAG,IAAI,wBAAc,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IACzD,MAAM,cAAc,CAAC,KAAK,EAAE,CAAC;IAC7B,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,MAAM,CAAC,OAAQ,CAAC,GAAG,WAAW,EAAE;QACvD,MAAM,EAAE,MAAM;QACd,OAAO,EAAE;YACP,cAAc,EAAE,kBAAkB;SACnC;QACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC;KACtC,CAAC,CAAC;IACH,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;QACV,MAAM,IAAI,KAAK,CAAC,oDAAoD,GAAG,CAAC,UAAU,cAAc,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACrI,CAAC;IAED,MAAM,UAAU,GAAG,KAAK,IAAI,EAAE;QAC5B,OAAO,CAAC,GAAG,CAAC,gCAAgC,CAAC,CAAC;QAC9C,MAAM,KAAK,CAAC,IAAI,EAAE,CAAC;QACnB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC,CAAC;IACF,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;IACjC,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;IAElC,OAAO,CAAC,GAAG,CAAC,uDAAuD,CAAC,CAAC;IACrE,OAAO,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC;AACnC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cdp-forge/plugin-pipeline-sdk",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.11",
|
|
4
4
|
"description": "SDK for pipeline plugins for CDP Forge platform",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -35,16 +35,19 @@
|
|
|
35
35
|
"homepage": "https://github.com/CDPForge/plugin-pipeline-template#readme",
|
|
36
36
|
"dependencies": {
|
|
37
37
|
"@cdp-forge/types": "^1.1.4",
|
|
38
|
+
"config": "^4.0.0",
|
|
39
|
+
"dotenv": "^17.2.0",
|
|
38
40
|
"kafkajs": "^2.2.4",
|
|
39
|
-
"node-fetch": "^3.3.2"
|
|
40
|
-
"yaml": "^2.7.0"
|
|
41
|
+
"node-fetch": "^3.3.2"
|
|
41
42
|
},
|
|
42
43
|
"devDependencies": {
|
|
44
|
+
"@types/config": "^3.3.5",
|
|
43
45
|
"@types/jest": "^29.5.14",
|
|
44
46
|
"@types/node": "^20.12.12",
|
|
45
47
|
"jest": "^29.7.0",
|
|
46
48
|
"nodemon": "^3.1.0",
|
|
47
49
|
"ts-jest": "^29.2.5",
|
|
50
|
+
"ts-node": "^10.9.2",
|
|
48
51
|
"typescript": "^5.7.3"
|
|
49
52
|
},
|
|
50
53
|
"engines": {
|
package/config/config.yml
DELETED
package/config/plugin.yml
DELETED