@certd/lib-k8s 1.22.0-1

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/.eslintrc ADDED
@@ -0,0 +1,23 @@
1
+ {
2
+ "parser": "@typescript-eslint/parser",
3
+ "plugins": [
4
+ "@typescript-eslint"
5
+ ],
6
+ "extends": [
7
+ "plugin:@typescript-eslint/recommended",
8
+ "plugin:prettier/recommended",
9
+ "prettier"
10
+ ],
11
+ "env": {
12
+ "mocha": true
13
+ },
14
+ "rules": {
15
+ "@typescript-eslint/no-var-requires": "off",
16
+ "@typescript-eslint/ban-ts-comment": "off",
17
+ "@typescript-eslint/ban-ts-ignore": "off",
18
+ "@typescript-eslint/no-explicit-any": "off",
19
+ "@typescript-eslint/no-empty-function": "off",
20
+ // "no-unused-expressions": "off",
21
+ "max-len": [0, 160, 2, { "ignoreUrls": true }]
22
+ }
23
+ }
package/.prettierrc ADDED
@@ -0,0 +1,7 @@
1
+ {
2
+ "printWidth": 160,
3
+ "bracketSpacing": true,
4
+ "singleQuote": true,
5
+ "trailingComma": "es5",
6
+ "arrowParens": "avoid"
7
+ }
package/CHANGELOG.md ADDED
@@ -0,0 +1,11 @@
1
+ # Change Log
2
+
3
+ All notable changes to this project will be documented in this file.
4
+ See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
+
6
+ # [1.22.0](https://github.com/certd/certd/compare/v1.21.2...v1.22.0) (2024-07-19)
7
+
8
+ ### Features
9
+
10
+ * 升级midway,支持esm ([485e603](https://github.com/certd/certd/commit/485e603b5165c28bc08694997726eaf2a585ebe7))
11
+ * 支持postgresql ([3b19bfb](https://github.com/certd/certd/commit/3b19bfb4291e89064b3b407a80dae092d54747d5))
package/README.md ADDED
@@ -0,0 +1,16 @@
1
+ # Vue 3 + TypeScript + Vite
2
+
3
+ This template should help get you started developing with Vue 3 and TypeScript in Vite. The template uses Vue 3 `<script setup>` SFCs, check out the [script setup docs](https://v3.vuejs.org/api/sfc-script-setup.html#sfc-script-setup) to learn more.
4
+
5
+ ## Recommended IDE Setup
6
+
7
+ - [VS Code](https://code.visualstudio.com/) + [Volar](https://marketplace.visualstudio.com/items?itemName=Vue.volar)
8
+
9
+ ## Type Support For `.vue` Imports in TS
10
+
11
+ Since TypeScript cannot handle type information for `.vue` imports, they are shimmed to be a generic Vue component type by default. In most cases this is fine if you don't really care about component prop types outside of templates. However, if you wish to get actual prop types in `.vue` imports (for example to get props validation when using manual `h(...)` calls), you can enable Volar's Take Over mode by following these steps:
12
+
13
+ 1. Run `Extensions: Show Built-in Extensions` from VS Code's command palette, look for `TypeScript and JavaScript Language Features`, then right click and select `Disable (Workspace)`. By default, Take Over mode will enable itself if the default TypeScript extension is disabled.
14
+ 2. Reload the VS Code window by running `Developer: Reload Window` from the command palette.
15
+
16
+ You can learn more about Take Over mode [here](https://github.com/johnsoncodehk/volar/discussions/471).
@@ -0,0 +1 @@
1
+ export * from "./lib/k8s.client.js";
package/dist/index.js ADDED
@@ -0,0 +1,2 @@
1
+ export * from "./lib/k8s.client.js";
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQyJ9
@@ -0,0 +1,35 @@
1
+ export declare class K8sClient {
2
+ kubeConfigStr: string;
3
+ lookup: any;
4
+ client: any;
5
+ constructor(kubeConfigStr: string);
6
+ init(): void;
7
+ /**
8
+ *
9
+ * @param localRecords { [domain]:{ip:'xxx.xx.xxx'} }
10
+ */
11
+ setLookup(localRecords: {
12
+ [key: string]: {
13
+ ip: string;
14
+ };
15
+ }): void;
16
+ /**
17
+ * 查询 secret列表
18
+ * @param opts = {namespace:default}
19
+ * @returns secretsList
20
+ */
21
+ getSecret(opts: {
22
+ namespace: string;
23
+ }): Promise<any>;
24
+ /**
25
+ * 创建Secret
26
+ * @param opts {namespace:default, body:yamlStr}
27
+ * @returns {Promise<*>}
28
+ */
29
+ createSecret(opts: any): Promise<any>;
30
+ updateSecret(opts: any): Promise<any>;
31
+ patchSecret(opts: any): Promise<any>;
32
+ getIngressList(opts: any): Promise<any>;
33
+ getIngress(opts: any): Promise<any>;
34
+ patchIngress(opts: any): Promise<any>;
35
+ }
@@ -0,0 +1,106 @@
1
+ import kubernetesClient from 'kubernetes-client';
2
+ import dns from 'dns';
3
+ import { logger } from '@certd/pipeline';
4
+ //@ts-ignore
5
+ const { KubeConfig, Client, Request } = kubernetesClient;
6
+ export class K8sClient {
7
+ kubeConfigStr;
8
+ lookup;
9
+ client;
10
+ constructor(kubeConfigStr) {
11
+ this.kubeConfigStr = kubeConfigStr;
12
+ this.init();
13
+ }
14
+ init() {
15
+ const kubeconfig = new KubeConfig();
16
+ kubeconfig.loadFromString(this.kubeConfigStr);
17
+ const reqOpts = { kubeconfig, request: {} };
18
+ if (this.lookup) {
19
+ reqOpts.request.lookup = this.lookup;
20
+ }
21
+ const backend = new Request(reqOpts);
22
+ this.client = new Client({ backend, version: '1.13' });
23
+ }
24
+ /**
25
+ *
26
+ * @param localRecords { [domain]:{ip:'xxx.xx.xxx'} }
27
+ */
28
+ setLookup(localRecords) {
29
+ this.lookup = (hostnameReq, options, callback) => {
30
+ logger.info('custom lookup', hostnameReq, localRecords);
31
+ if (localRecords[hostnameReq]) {
32
+ logger.info('local record', hostnameReq, localRecords[hostnameReq]);
33
+ callback(null, localRecords[hostnameReq].ip, 4);
34
+ }
35
+ else {
36
+ dns.lookup(hostnameReq, options, callback);
37
+ }
38
+ };
39
+ this.init();
40
+ }
41
+ /**
42
+ * 查询 secret列表
43
+ * @param opts = {namespace:default}
44
+ * @returns secretsList
45
+ */
46
+ async getSecret(opts) {
47
+ const namespace = opts.namespace || 'default';
48
+ return await this.client.api.v1.namespaces(namespace).secrets.get();
49
+ }
50
+ /**
51
+ * 创建Secret
52
+ * @param opts {namespace:default, body:yamlStr}
53
+ * @returns {Promise<*>}
54
+ */
55
+ async createSecret(opts) {
56
+ const namespace = opts.namespace || 'default';
57
+ const created = await this.client.api.v1.namespaces(namespace).secrets.post({
58
+ body: opts.body,
59
+ });
60
+ logger.info('new secrets:', created);
61
+ return created;
62
+ }
63
+ async updateSecret(opts) {
64
+ const namespace = opts.namespace || 'default';
65
+ const secretName = opts.secretName;
66
+ if (secretName == null) {
67
+ throw new Error('secretName 不能为空');
68
+ }
69
+ return await this.client.api.v1.namespaces(namespace).secrets(secretName).put({
70
+ body: opts.body,
71
+ });
72
+ }
73
+ async patchSecret(opts) {
74
+ const namespace = opts.namespace || 'default';
75
+ const secretName = opts.secretName;
76
+ if (secretName == null) {
77
+ throw new Error('secretName 不能为空');
78
+ }
79
+ return await this.client.api.v1.namespaces(namespace).secrets(secretName).patch({
80
+ body: opts.body,
81
+ });
82
+ }
83
+ async getIngressList(opts) {
84
+ const namespace = opts.namespace || 'default';
85
+ return await this.client.apis.extensions.v1beta1.namespaces(namespace).ingresses.get();
86
+ }
87
+ async getIngress(opts) {
88
+ const namespace = opts.namespace || 'default';
89
+ const ingressName = opts.ingressName;
90
+ if (!ingressName) {
91
+ throw new Error('ingressName 不能为空');
92
+ }
93
+ return await this.client.apis.extensions.v1beta1.namespaces(namespace).ingresses(ingressName).get();
94
+ }
95
+ async patchIngress(opts) {
96
+ const namespace = opts.namespace || 'default';
97
+ const ingressName = opts.ingressName;
98
+ if (!ingressName) {
99
+ throw new Error('ingressName 不能为空');
100
+ }
101
+ return await this.client.apis.extensions.v1beta1.namespaces(namespace).ingresses(ingressName).patch({
102
+ body: opts.body,
103
+ });
104
+ }
105
+ }
106
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiazhzLmNsaWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvazhzLmNsaWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLGdCQUFnQixNQUFNLG1CQUFtQixDQUFDO0FBQ2pELE9BQU8sR0FBRyxNQUFNLEtBQUssQ0FBQztBQUN0QixPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFekMsWUFBWTtBQUNaLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLGdCQUFnQixDQUFDO0FBRXpELE1BQU0sT0FBTyxTQUFTO0lBQ3BCLGFBQWEsQ0FBUztJQUN0QixNQUFNLENBQU87SUFDYixNQUFNLENBQU87SUFDYixZQUFZLGFBQXFCO1FBQy9CLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO1FBQ25DLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7SUFFRCxJQUFJO1FBQ0YsTUFBTSxVQUFVLEdBQUcsSUFBSSxVQUFVLEVBQUUsQ0FBQztRQUNwQyxVQUFVLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUM5QyxNQUFNLE9BQU8sR0FBRyxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFTLENBQUM7UUFDbkQsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ2YsT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztTQUN0QztRQUVELE1BQU0sT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxNQUFNLENBQUMsRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVEOzs7T0FHRztJQUNILFNBQVMsQ0FBQyxZQUErQztRQUN2RCxJ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
@@ -0,0 +1,96 @@
1
+ import * as fs from "fs";
2
+ import * as path from "path";
3
+
4
+ // https://gist.github.com/lovasoa/8691344
5
+ async function* walk(dir) {
6
+ for await (const d of await fs.promises.opendir(dir)) {
7
+ const entry = path.join(dir, d.name);
8
+ if (d.isDirectory()) {
9
+ yield* walk(entry);
10
+ } else if (d.isFile()) {
11
+ yield entry;
12
+ }
13
+ }
14
+ }
15
+
16
+ function resolveImportPath(sourceFile, importPath, options) {
17
+ const sourceFileAbs = path.resolve(process.cwd(), sourceFile);
18
+ const root = path.dirname(sourceFileAbs);
19
+ const { moduleFilter = defaultModuleFilter } = options;
20
+
21
+ if (moduleFilter(importPath)) {
22
+ const importPathAbs = path.resolve(root, importPath);
23
+ let possiblePath = [path.resolve(importPathAbs, "./index.ts"), path.resolve(importPathAbs, "./index.js"), importPathAbs + ".ts", importPathAbs + ".js"];
24
+
25
+ if (possiblePath.length) {
26
+ for (let i = 0; i < possiblePath.length; i++) {
27
+ let entry = possiblePath[i];
28
+ if (fs.existsSync(entry)) {
29
+ const resolved = path.relative(root, entry.replace(/\.ts$/, ".js"));
30
+
31
+ if (!resolved.startsWith(".")) {
32
+ return "./" + resolved;
33
+ }
34
+
35
+ return resolved;
36
+ }
37
+ }
38
+ }
39
+ }
40
+
41
+ return null;
42
+ }
43
+
44
+ function replace(filePath, outFilePath, options) {
45
+ const code = fs.readFileSync(filePath).toString();
46
+ const newCode = code.replace(/(import|export) (.+?) from ('[^\n']+'|"[^\n"]+");/gs, function (found, action, imported, from) {
47
+ const importPath = from.slice(1, -1);
48
+ let resolvedPath = resolveImportPath(filePath, importPath, options);
49
+
50
+ if (resolvedPath) {
51
+ resolvedPath = resolvedPath.replaceAll("\\", "/");
52
+ console.log("\t", importPath, resolvedPath);
53
+ return `${action} ${imported} from "${resolvedPath}";`;
54
+ }
55
+
56
+ return found;
57
+ });
58
+
59
+ if (code !== newCode) {
60
+ fs.writeFileSync(outFilePath, newCode);
61
+ }
62
+ }
63
+
64
+ // Then, use it with a simple async for loop
65
+ async function run(srcDir, options = defaultOptions) {
66
+ const { sourceFileFilter = defaultSourceFileFilter } = options;
67
+
68
+ for await (const entry of walk(srcDir)) {
69
+ if (sourceFileFilter(entry)) {
70
+ console.log(entry);
71
+ replace(entry, entry, options);
72
+ }
73
+ }
74
+ }
75
+
76
+ const defaultSourceFileFilter = function (sourceFilePath) {
77
+ return /\.(js|ts)$/.test(sourceFilePath) && !/node_modules/.test(sourceFilePath);
78
+ };
79
+
80
+ const defaultModuleFilter = function (importedModule) {
81
+ return !path.isAbsolute(importedModule) && !importedModule.startsWith("@") && !importedModule.endsWith(".js");
82
+ };
83
+
84
+ const defaultOptions = {
85
+ sourceFileFilter: defaultSourceFileFilter,
86
+ moduleFilter: defaultModuleFilter,
87
+ };
88
+
89
+ // Switch this to test on one file or directly run on a directory.
90
+ const DEBUG = false;
91
+
92
+ if (DEBUG) {
93
+ replace("./src/index.ts", "./out.ts", defaultOptions);
94
+ } else {
95
+ await run("./src/", defaultOptions);
96
+ }
package/package.json ADDED
@@ -0,0 +1,42 @@
1
+ {
2
+ "name": "@certd/lib-k8s",
3
+ "private": false,
4
+ "version": "1.22.0-1",
5
+ "type": "module",
6
+ "main": "./dist/index.js",
7
+ "types": "./dist/index.d.ts",
8
+ "scripts": {
9
+ "dev": "vite",
10
+ "build": "tsc --skipLibCheck",
11
+ "build3": "rollup -c",
12
+ "build2": "vue-tsc --noEmit && vite build",
13
+ "preview": "vite preview"
14
+ },
15
+ "dependencies": {
16
+ "shelljs": "^0.8.5",
17
+ "kubernetes-client": "^9.0.0"
18
+ },
19
+ "devDependencies": {
20
+ "@certd/pipeline": "^1.22.0",
21
+ "@rollup/plugin-commonjs": "^23.0.4",
22
+ "@rollup/plugin-json": "^6.0.0",
23
+ "@rollup/plugin-node-resolve": "^15.0.1",
24
+ "@rollup/plugin-terser": "^0.4.3",
25
+ "@rollup/plugin-typescript": "^11.0.0",
26
+ "@types/chai": "^4.3.3",
27
+ "@typescript-eslint/eslint-plugin": "^5.38.1",
28
+ "@typescript-eslint/parser": "^5.38.1",
29
+ "eslint": "^8.24.0",
30
+ "eslint-config-prettier": "^8.5.0",
31
+ "eslint-plugin-import": "^2.26.0",
32
+ "eslint-plugin-node": "^11.1.0",
33
+ "eslint-plugin-prettier": "^4.2.1",
34
+ "prettier": "^2.8.8",
35
+ "rollup": "^3.7.4",
36
+ "rollup-plugin-visualizer": "^5.8.2",
37
+ "ts-node": "^10.9.1",
38
+ "tslib": "^2.5.2",
39
+ "typescript": "^4.8.4"
40
+ },
41
+ "gitHead": "47fe3d5826661f678d081ab53e67c847a3239d88"
42
+ }
package/tsconfig.json ADDED
@@ -0,0 +1,41 @@
1
+ {
2
+ "compileOnSave": true,
3
+ "compilerOptions": {
4
+ "target": "ESNext",
5
+ "module": "ESNext",
6
+ "moduleResolution": "node",
7
+ "esModuleInterop": true,
8
+ "experimentalDecorators": true,
9
+ "emitDecoratorMetadata": true,
10
+ "inlineSourceMap":true,
11
+ "noImplicitThis": true,
12
+ "noUnusedLocals": true,
13
+ "stripInternal": true,
14
+ "skipLibCheck": true,
15
+ "pretty": true,
16
+ "declaration": true,
17
+ "forceConsistentCasingInFileNames": true,
18
+ "typeRoots": [ "./typings", "./node_modules/@types"],
19
+ "outDir": "dist",
20
+ "rootDir": "src",
21
+ "composite": true,
22
+ "useDefineForClassFields": true,
23
+ "strict": false,
24
+ // "sourceMap": true,
25
+ "resolveJsonModule": true,
26
+ "isolatedModules": true,
27
+ "lib": ["ESNext", "DOM"],
28
+ },
29
+ "include": [
30
+ "src/**/*.ts",
31
+ "src/**/*.d.ts",
32
+ "src/**/*.json"
33
+ ],
34
+ "exclude": [
35
+ "*.js",
36
+ "*.ts",
37
+ "dist",
38
+ "node_modules",
39
+ "src/test"
40
+ ],
41
+ }