@akanjs/devkit 0.0.39 → 0.0.40
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/index.d.ts +24 -0
- package/index.js +21 -1950
- package/package.json +2 -20
- package/src/aiEditor.d.ts +10 -0
- package/src/aiEditor.js +61 -0
- package/src/auth.d.ts +12 -0
- package/src/auth.js +79 -0
- package/src/baseDevEnv.d.ts +12 -0
- package/src/baseDevEnv.js +50 -0
- package/src/capacitorApp.d.ts +27 -0
- package/src/capacitorApp.js +186 -0
- package/src/constants.d.ts +21 -0
- package/src/constants.js +47 -0
- package/src/createTunnel.d.ts +8 -0
- package/src/createTunnel.js +47 -0
- package/src/dependencyScanner.d.ts +11 -0
- package/src/dependencyScanner.js +171 -0
- package/src/executors.d.ts +279 -0
- package/src/executors.js +715 -0
- package/src/extractDeps.d.ts +7 -0
- package/src/extractDeps.js +114 -0
- package/src/getCredentials.d.ts +18 -0
- package/src/getCredentials.js +43 -0
- package/src/getDependencies.d.ts +6 -0
- package/src/getDependencies.js +67 -0
- package/src/getModelFileData.d.ts +17 -0
- package/src/getModelFileData.js +67 -0
- package/src/getRelatedCnsts.d.ts +11 -0
- package/src/getRelatedCnsts.js +145 -0
- package/src/index.d.ts +101 -0
- package/src/index.js +55 -0
- package/src/installExternalLib.d.ts +8 -0
- package/src/installExternalLib.js +34 -0
- package/src/selectModel.d.ts +3 -0
- package/src/selectModel.js +50 -0
- package/src/streamAi.d.ts +7 -0
- package/src/streamAi.js +69 -0
- package/src/types.d.ts +20 -0
- package/src/types.js +15 -0
- package/src/uploadRelease.d.ts +11 -0
- package/src/uploadRelease.js +82 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@akanjs/devkit",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.40",
|
|
4
4
|
"type": "commonjs",
|
|
5
5
|
"publishConfig": {
|
|
6
6
|
"access": "public"
|
|
@@ -14,23 +14,5 @@
|
|
|
14
14
|
"engines": {
|
|
15
15
|
"node": ">=22"
|
|
16
16
|
},
|
|
17
|
-
"dependencies": {
|
|
18
|
-
"@inquirer/prompts": "^7.2.1",
|
|
19
|
-
"@langchain/core": "^0.3.27",
|
|
20
|
-
"@langchain/openai": "^0.3.16",
|
|
21
|
-
"@next/bundle-analyzer": "^15.1.3",
|
|
22
|
-
"@nx/devkit": "^20.7.2",
|
|
23
|
-
"@trapezedev/project": "^7.1.3",
|
|
24
|
-
"axios": "^1.7.9",
|
|
25
|
-
"commander": "^13.1.0",
|
|
26
|
-
"dayjs": "^1.11.13",
|
|
27
|
-
"form-data": "^4.0.1",
|
|
28
|
-
"js-yaml": "^4.1.0",
|
|
29
|
-
"next-pwa": "^5.6.0",
|
|
30
|
-
"ora": "^3.4.0",
|
|
31
|
-
"pluralize": "^8.0.0",
|
|
32
|
-
"reflect-metadata": "^0.2.2",
|
|
33
|
-
"tunnel-ssh": "^5.2.0",
|
|
34
|
-
"typescript": "^5.8.3"
|
|
35
|
-
}
|
|
17
|
+
"dependencies": {}
|
|
36
18
|
}
|
package/src/aiEditor.js
ADDED
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var aiEditor_exports = {};
|
|
20
|
+
__export(aiEditor_exports, {
|
|
21
|
+
AiEditor: () => AiEditor
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(aiEditor_exports);
|
|
24
|
+
var import_prompts = require("@langchain/core/prompts");
|
|
25
|
+
var import_runnables = require("@langchain/core/runnables");
|
|
26
|
+
var import_openai = require("@langchain/openai");
|
|
27
|
+
class AiEditor {
|
|
28
|
+
static {
|
|
29
|
+
__name(this, "AiEditor");
|
|
30
|
+
}
|
|
31
|
+
chat;
|
|
32
|
+
constructor(apiKey = process.env.DEEPSEEK_API_KEY) {
|
|
33
|
+
this.chat = new import_openai.ChatOpenAI({
|
|
34
|
+
modelName: "deepseek-reasoner",
|
|
35
|
+
temperature: 0.7,
|
|
36
|
+
streaming: true,
|
|
37
|
+
configuration: {
|
|
38
|
+
baseURL: "https://api.deepseek.com/v1",
|
|
39
|
+
apiKey
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
#createProcessingChain() {
|
|
44
|
+
return import_runnables.RunnableSequence.from([
|
|
45
|
+
import_prompts.PromptTemplate.fromTemplate(`Answer concisely: {question}`),
|
|
46
|
+
this.chat
|
|
47
|
+
]);
|
|
48
|
+
}
|
|
49
|
+
async edit(question) {
|
|
50
|
+
const chain = this.#createProcessingChain();
|
|
51
|
+
const stream = await chain.stream({
|
|
52
|
+
question
|
|
53
|
+
});
|
|
54
|
+
for await (const chunk of stream) {
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
59
|
+
0 && (module.exports = {
|
|
60
|
+
AiEditor
|
|
61
|
+
});
|
package/src/auth.d.ts
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { AkanGlobalConfig, HostConfig } from './constants.js';
|
|
2
|
+
|
|
3
|
+
declare const getAkanGlobalConfig: () => AkanGlobalConfig;
|
|
4
|
+
declare const setAkanGlobalConfig: (akanConfig: AkanGlobalConfig) => void;
|
|
5
|
+
declare const getHostConfig: (host?: string) => HostConfig;
|
|
6
|
+
declare const setHostConfig: (host?: string, config?: HostConfig) => void;
|
|
7
|
+
declare const getSelf: (token: string) => Promise<{
|
|
8
|
+
id: string;
|
|
9
|
+
nickname: string;
|
|
10
|
+
} | null>;
|
|
11
|
+
|
|
12
|
+
export { getAkanGlobalConfig, getHostConfig, getSelf, setAkanGlobalConfig, setHostConfig };
|
package/src/auth.js
ADDED
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var auth_exports = {};
|
|
30
|
+
__export(auth_exports, {
|
|
31
|
+
getAkanGlobalConfig: () => getAkanGlobalConfig,
|
|
32
|
+
getHostConfig: () => getHostConfig,
|
|
33
|
+
getSelf: () => getSelf,
|
|
34
|
+
setAkanGlobalConfig: () => setAkanGlobalConfig,
|
|
35
|
+
setHostConfig: () => setHostConfig
|
|
36
|
+
});
|
|
37
|
+
module.exports = __toCommonJS(auth_exports);
|
|
38
|
+
var import_fs = __toESM(require("fs"));
|
|
39
|
+
var import_constants = require("./constants");
|
|
40
|
+
const getAkanGlobalConfig = /* @__PURE__ */ __name(() => {
|
|
41
|
+
const akanConfig = import_fs.default.existsSync(import_constants.configPath) ? JSON.parse(import_fs.default.readFileSync(import_constants.configPath, "utf8")) : import_constants.defaultAkanGlobalConfig;
|
|
42
|
+
return akanConfig;
|
|
43
|
+
}, "getAkanGlobalConfig");
|
|
44
|
+
const setAkanGlobalConfig = /* @__PURE__ */ __name((akanConfig) => {
|
|
45
|
+
import_fs.default.mkdirSync(import_constants.basePath, {
|
|
46
|
+
recursive: true
|
|
47
|
+
});
|
|
48
|
+
import_fs.default.writeFileSync(import_constants.configPath, JSON.stringify(akanConfig, null, 2));
|
|
49
|
+
}, "setAkanGlobalConfig");
|
|
50
|
+
const getHostConfig = /* @__PURE__ */ __name((host = import_constants.akanCloudHost) => {
|
|
51
|
+
const akanConfig = getAkanGlobalConfig();
|
|
52
|
+
return akanConfig[host] ?? import_constants.defaultHostConfig;
|
|
53
|
+
}, "getHostConfig");
|
|
54
|
+
const setHostConfig = /* @__PURE__ */ __name((host = import_constants.akanCloudHost, config = {}) => {
|
|
55
|
+
const akanConfig = getAkanGlobalConfig();
|
|
56
|
+
akanConfig[host] = config;
|
|
57
|
+
setAkanGlobalConfig(akanConfig);
|
|
58
|
+
}, "setHostConfig");
|
|
59
|
+
const getSelf = /* @__PURE__ */ __name(async (token) => {
|
|
60
|
+
try {
|
|
61
|
+
const res = await fetch(`${import_constants.akanCloudBackendUrl}/user/getSelf`, {
|
|
62
|
+
headers: {
|
|
63
|
+
Authorization: `Bearer ${token}`
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
const user = await res.json();
|
|
67
|
+
return user;
|
|
68
|
+
} catch (e) {
|
|
69
|
+
return null;
|
|
70
|
+
}
|
|
71
|
+
}, "getSelf");
|
|
72
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
73
|
+
0 && (module.exports = {
|
|
74
|
+
getAkanGlobalConfig,
|
|
75
|
+
getHostConfig,
|
|
76
|
+
getSelf,
|
|
77
|
+
setAkanGlobalConfig,
|
|
78
|
+
setHostConfig
|
|
79
|
+
});
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { SshOptions } from 'tunnel-ssh';
|
|
2
|
+
|
|
3
|
+
interface BaseDevEnv {
|
|
4
|
+
appName?: string;
|
|
5
|
+
repoName: string;
|
|
6
|
+
serveDomain: string;
|
|
7
|
+
env: "testing" | "debug" | "develop" | "main";
|
|
8
|
+
}
|
|
9
|
+
declare const baseDevEnv: BaseDevEnv;
|
|
10
|
+
declare const getSshTunnelOptions: (appName: string, environment: string) => SshOptions;
|
|
11
|
+
|
|
12
|
+
export { baseDevEnv, getSshTunnelOptions };
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var baseDevEnv_exports = {};
|
|
20
|
+
__export(baseDevEnv_exports, {
|
|
21
|
+
baseDevEnv: () => baseDevEnv,
|
|
22
|
+
getSshTunnelOptions: () => getSshTunnelOptions
|
|
23
|
+
});
|
|
24
|
+
module.exports = __toCommonJS(baseDevEnv_exports);
|
|
25
|
+
const appName = process.env.NEXT_PUBLIC_APP_NAME;
|
|
26
|
+
const repoName = process.env.NEXT_PUBLIC_REPO_NAME;
|
|
27
|
+
if (!repoName) throw new Error("NEXT_PUBLIC_REPO_NAME is not set");
|
|
28
|
+
const serveDomain = process.env.NEXT_PUBLIC_SERVE_DOMAIN;
|
|
29
|
+
if (!serveDomain) throw new Error("NEXT_PUBLIC_SERVE_DOMAIN is not set");
|
|
30
|
+
const env = process.env.NEXT_PUBLIC_ENV ?? "debug";
|
|
31
|
+
if (!env) throw new Error("NEXT_PUBLIC_ENV is not set");
|
|
32
|
+
const baseDevEnv = {
|
|
33
|
+
...appName ? {
|
|
34
|
+
appName
|
|
35
|
+
} : {},
|
|
36
|
+
repoName,
|
|
37
|
+
serveDomain,
|
|
38
|
+
env
|
|
39
|
+
};
|
|
40
|
+
const getSshTunnelOptions = /* @__PURE__ */ __name((appName2, environment) => ({
|
|
41
|
+
host: `${appName2}-${environment}.${serveDomain}`,
|
|
42
|
+
port: process.env.SSU_TUNNEL_PORT ? parseInt(process.env.SSU_TUNNEL_PORT) : 32767,
|
|
43
|
+
username: process.env.SSU_TUNNEL_USERNAME ?? "root",
|
|
44
|
+
password: process.env.SSU_TUNNEL_PASSWORD ?? repoName
|
|
45
|
+
}), "getSshTunnelOptions");
|
|
46
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
47
|
+
0 && (module.exports = {
|
|
48
|
+
baseDevEnv,
|
|
49
|
+
getSshTunnelOptions
|
|
50
|
+
});
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { AppExecutor } from './executors.js';
|
|
2
|
+
import { MobileProject } from '@trapezedev/project';
|
|
3
|
+
import { AndroidProject } from '@trapezedev/project/dist/android/project';
|
|
4
|
+
import { IosProject } from '@trapezedev/project/dist/ios/project';
|
|
5
|
+
import 'next';
|
|
6
|
+
import 'child_process';
|
|
7
|
+
import './types.js';
|
|
8
|
+
|
|
9
|
+
declare class CapacitorApp {
|
|
10
|
+
#private;
|
|
11
|
+
private readonly app;
|
|
12
|
+
project: MobileProject & {
|
|
13
|
+
ios: IosProject;
|
|
14
|
+
android: AndroidProject;
|
|
15
|
+
};
|
|
16
|
+
iosTargetName: string;
|
|
17
|
+
constructor(app: AppExecutor);
|
|
18
|
+
init(): Promise<this>;
|
|
19
|
+
save(): Promise<void>;
|
|
20
|
+
releaseIos(): Promise<void>;
|
|
21
|
+
releaseAndroid(): Promise<void>;
|
|
22
|
+
addCamera(): Promise<void>;
|
|
23
|
+
addContact(): Promise<void>;
|
|
24
|
+
addLocation(): Promise<void>;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export { CapacitorApp };
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var capacitorApp_exports = {};
|
|
30
|
+
__export(capacitorApp_exports, {
|
|
31
|
+
CapacitorApp: () => CapacitorApp
|
|
32
|
+
});
|
|
33
|
+
module.exports = __toCommonJS(capacitorApp_exports);
|
|
34
|
+
var import_common = require("@akanjs/common");
|
|
35
|
+
var import_project = require("@trapezedev/project");
|
|
36
|
+
var import_fs = __toESM(require("fs"));
|
|
37
|
+
class CapacitorApp {
|
|
38
|
+
static {
|
|
39
|
+
__name(this, "CapacitorApp");
|
|
40
|
+
}
|
|
41
|
+
app;
|
|
42
|
+
project;
|
|
43
|
+
iosTargetName;
|
|
44
|
+
constructor(app) {
|
|
45
|
+
this.app = app;
|
|
46
|
+
this.iosTargetName = "App";
|
|
47
|
+
}
|
|
48
|
+
async init() {
|
|
49
|
+
const project = new import_project.MobileProject(this.app.cwdPath, {
|
|
50
|
+
android: {
|
|
51
|
+
path: "android"
|
|
52
|
+
},
|
|
53
|
+
ios: {
|
|
54
|
+
path: "ios/App"
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
await project.load();
|
|
58
|
+
if (!project.android) throw new Error(`Android is not added, Please add platform first
|
|
59
|
+
akan serve-android ${this.app.name}`);
|
|
60
|
+
if (!project.ios) throw new Error(`iOS is not added, Please add platform first
|
|
61
|
+
akan serve-ios ${this.app.name}`);
|
|
62
|
+
this.project = project;
|
|
63
|
+
return this;
|
|
64
|
+
}
|
|
65
|
+
async save() {
|
|
66
|
+
await this.project.commit();
|
|
67
|
+
}
|
|
68
|
+
async releaseIos() {
|
|
69
|
+
const isAdded = import_fs.default.existsSync(`${this.app.cwdPath}/ios/App/Podfile`);
|
|
70
|
+
if (!isAdded) {
|
|
71
|
+
await this.app.spawn("npx cap add ios");
|
|
72
|
+
await this.app.spawn("npx @capacitor/assets generate");
|
|
73
|
+
} else this.app.log(`iOS already added, skip adding process`);
|
|
74
|
+
await this.app.spawn("cross-env", [
|
|
75
|
+
"APP_OPERATION_MODE=release",
|
|
76
|
+
"npx",
|
|
77
|
+
"cap",
|
|
78
|
+
"sync",
|
|
79
|
+
"ios"
|
|
80
|
+
]);
|
|
81
|
+
}
|
|
82
|
+
async releaseAndroid() {
|
|
83
|
+
const isAdded = import_fs.default.existsSync(`${this.app.cwdPath}/android/app/build.gradle`);
|
|
84
|
+
if (!isAdded) {
|
|
85
|
+
await this.app.spawn("npx cap add android");
|
|
86
|
+
await this.app.spawn("npx @capacitor/assets generate");
|
|
87
|
+
} else this.app.log(`android already added, skip adding process`);
|
|
88
|
+
await this.app.spawn("cross-env", [
|
|
89
|
+
"APP_OPERATION_MODE=release",
|
|
90
|
+
"npx",
|
|
91
|
+
"cap",
|
|
92
|
+
"sync",
|
|
93
|
+
"android"
|
|
94
|
+
]);
|
|
95
|
+
}
|
|
96
|
+
async addCamera() {
|
|
97
|
+
await this.#setPermissionInIos({
|
|
98
|
+
cameraUsageDescription: "$(PRODUCT_NAME) requires access to the camera to take photos.",
|
|
99
|
+
photoAddUsageDescription: "$(PRODUCT_NAME) requires access to the photo library to take photos.",
|
|
100
|
+
photoUsageDescription: "$(PRODUCT_NAME) requires access to the photo library to take photos."
|
|
101
|
+
});
|
|
102
|
+
this.#setPermissionsInAndroid([
|
|
103
|
+
"READ_MEDIA_IMAGES",
|
|
104
|
+
"READ_EXTERNAL_STORAGE",
|
|
105
|
+
"WRITE_EXTERNAL_STORAGE"
|
|
106
|
+
]);
|
|
107
|
+
}
|
|
108
|
+
async addContact() {
|
|
109
|
+
await this.#setPermissionInIos({
|
|
110
|
+
contactsUsageDescription: "$(PRODUCT_NAME) requires access to the contacts to add new contacts."
|
|
111
|
+
});
|
|
112
|
+
this.#setPermissionsInAndroid([
|
|
113
|
+
"READ_CONTACTS",
|
|
114
|
+
"WRITE_CONTACTS"
|
|
115
|
+
]);
|
|
116
|
+
}
|
|
117
|
+
async addLocation() {
|
|
118
|
+
await this.#setPermissionInIos({
|
|
119
|
+
locationAlwaysUsageDescription: "$(PRODUCT_NAME) requires access to the location to get the user's location.",
|
|
120
|
+
locationWhenInUseUsageDescription: "$(PRODUCT_NAME) requires access to the location to get the user's location."
|
|
121
|
+
});
|
|
122
|
+
this.#setPermissionsInAndroid([
|
|
123
|
+
"ACCESS_COARSE_LOCATION",
|
|
124
|
+
"ACCESS_FINE_LOCATION"
|
|
125
|
+
]);
|
|
126
|
+
this.#setFeaturesInAndroid([
|
|
127
|
+
"android.hardware.location.gps"
|
|
128
|
+
]);
|
|
129
|
+
}
|
|
130
|
+
async #setPermissionInIos(permissions) {
|
|
131
|
+
const updateNs = Object.fromEntries(Object.entries(permissions).map(([key, value]) => [
|
|
132
|
+
`NS${(0, import_common.capitalize)(key)}`,
|
|
133
|
+
value
|
|
134
|
+
]));
|
|
135
|
+
await Promise.all([
|
|
136
|
+
this.project.ios.updateInfoPlist(this.iosTargetName, "Debug", updateNs),
|
|
137
|
+
this.project.ios.updateInfoPlist(this.iosTargetName, "Release", updateNs)
|
|
138
|
+
]);
|
|
139
|
+
}
|
|
140
|
+
#setFeaturesInAndroid(features) {
|
|
141
|
+
for (const feature of features) {
|
|
142
|
+
if (this.#hasFeatureInAndroid(feature)) {
|
|
143
|
+
this.app.logger.info(`${feature} already exists in android`);
|
|
144
|
+
return this;
|
|
145
|
+
}
|
|
146
|
+
this.app.logger.info(`Adding ${feature} to android`);
|
|
147
|
+
this.project.android.getAndroidManifest().injectFragment("manifest", `<uses-feature android:name="${feature}" />`);
|
|
148
|
+
}
|
|
149
|
+
return this;
|
|
150
|
+
}
|
|
151
|
+
#getFeaturesInAndroid() {
|
|
152
|
+
const androidManifest = this.project.android.getAndroidManifest();
|
|
153
|
+
const element = androidManifest.getDocumentElement();
|
|
154
|
+
if (!element) throw new Error("manifest not found");
|
|
155
|
+
const usesFeature = element.getElementsByTagName("uses-feature");
|
|
156
|
+
return Array.from(usesFeature).map((feature) => feature.getAttribute("android:name"));
|
|
157
|
+
}
|
|
158
|
+
#hasFeatureInAndroid(feature) {
|
|
159
|
+
return this.#getFeaturesInAndroid().includes(feature);
|
|
160
|
+
}
|
|
161
|
+
#setPermissionsInAndroid(permissions) {
|
|
162
|
+
for (const permission of permissions) {
|
|
163
|
+
if (this.#hasPermissionInAndroid(permission)) {
|
|
164
|
+
this.app.logger.info(`${permission} already exists in android`);
|
|
165
|
+
return this;
|
|
166
|
+
}
|
|
167
|
+
this.app.logger.info(`Adding ${permission} to android`);
|
|
168
|
+
this.project.android.getAndroidManifest().injectFragment("manifest", `<uses-permission android:name="android.permission.${permission}" />`);
|
|
169
|
+
}
|
|
170
|
+
return this;
|
|
171
|
+
}
|
|
172
|
+
#getPermissionsInAndroid() {
|
|
173
|
+
const androidManifest = this.project.android.getAndroidManifest();
|
|
174
|
+
const element = androidManifest.getDocumentElement();
|
|
175
|
+
if (!element) throw new Error("manifest not found");
|
|
176
|
+
const usesPermission = element.getElementsByTagName("uses-permission");
|
|
177
|
+
return Array.from(usesPermission).map((permission) => permission.getAttribute("android:name"));
|
|
178
|
+
}
|
|
179
|
+
#hasPermissionInAndroid(permission) {
|
|
180
|
+
return this.#getPermissionsInAndroid().includes(permission);
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
184
|
+
0 && (module.exports = {
|
|
185
|
+
CapacitorApp
|
|
186
|
+
});
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
declare const basePath: string;
|
|
2
|
+
declare const configPath: string;
|
|
3
|
+
declare const akanCloudHost: string;
|
|
4
|
+
declare const akanCloudBackendUrl: string;
|
|
5
|
+
declare const akanCloudClientUrl: string;
|
|
6
|
+
interface HostConfig {
|
|
7
|
+
auth?: {
|
|
8
|
+
token: string;
|
|
9
|
+
self: {
|
|
10
|
+
id: string;
|
|
11
|
+
nickname: string;
|
|
12
|
+
};
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
declare const defaultHostConfig: HostConfig;
|
|
16
|
+
interface AkanGlobalConfig {
|
|
17
|
+
[key: string]: HostConfig;
|
|
18
|
+
}
|
|
19
|
+
declare const defaultAkanGlobalConfig: AkanGlobalConfig;
|
|
20
|
+
|
|
21
|
+
export { type AkanGlobalConfig, type HostConfig, akanCloudBackendUrl, akanCloudClientUrl, akanCloudHost, basePath, configPath, defaultAkanGlobalConfig, defaultHostConfig };
|
package/src/constants.js
ADDED
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __export = (target, all) => {
|
|
6
|
+
for (var name in all)
|
|
7
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
+
};
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
14
|
+
}
|
|
15
|
+
return to;
|
|
16
|
+
};
|
|
17
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
|
+
var constants_exports = {};
|
|
19
|
+
__export(constants_exports, {
|
|
20
|
+
akanCloudBackendUrl: () => akanCloudBackendUrl,
|
|
21
|
+
akanCloudClientUrl: () => akanCloudClientUrl,
|
|
22
|
+
akanCloudHost: () => akanCloudHost,
|
|
23
|
+
basePath: () => basePath,
|
|
24
|
+
configPath: () => configPath,
|
|
25
|
+
defaultAkanGlobalConfig: () => defaultAkanGlobalConfig,
|
|
26
|
+
defaultHostConfig: () => defaultHostConfig
|
|
27
|
+
});
|
|
28
|
+
module.exports = __toCommonJS(constants_exports);
|
|
29
|
+
var import_os = require("os");
|
|
30
|
+
const basePath = `${(0, import_os.homedir)()}/.akan`;
|
|
31
|
+
const configPath = `${basePath}/config.json`;
|
|
32
|
+
const akanCloudHost = process.env.NEXT_PUBLIC_OPERATION_MODE === "local" ? "http://localhost" : "https://akasys-debug.akamir.com";
|
|
33
|
+
//! Temp
|
|
34
|
+
const akanCloudBackendUrl = `${akanCloudHost}${process.env.NEXT_PUBLIC_OPERATION_MODE === "local" ? ":8080" : ""}/backend`;
|
|
35
|
+
const akanCloudClientUrl = `${akanCloudHost}${process.env.NEXT_PUBLIC_OPERATION_MODE === "local" ? ":4200" : ""}`;
|
|
36
|
+
const defaultHostConfig = {};
|
|
37
|
+
const defaultAkanGlobalConfig = {};
|
|
38
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
39
|
+
0 && (module.exports = {
|
|
40
|
+
akanCloudBackendUrl,
|
|
41
|
+
akanCloudClientUrl,
|
|
42
|
+
akanCloudHost,
|
|
43
|
+
basePath,
|
|
44
|
+
configPath,
|
|
45
|
+
defaultAkanGlobalConfig,
|
|
46
|
+
defaultHostConfig
|
|
47
|
+
});
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var createTunnel_exports = {};
|
|
20
|
+
__export(createTunnel_exports, {
|
|
21
|
+
createTunnel: () => createTunnel
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(createTunnel_exports);
|
|
24
|
+
var import_tunnel_ssh = require("tunnel-ssh");
|
|
25
|
+
var import_baseDevEnv = require("./baseDevEnv");
|
|
26
|
+
const createTunnel = /* @__PURE__ */ __name(async ({ appName, environment, port = 27017 }) => {
|
|
27
|
+
const tunnelOptions = {
|
|
28
|
+
autoClose: true,
|
|
29
|
+
reconnectOnError: true
|
|
30
|
+
};
|
|
31
|
+
const sshOptions = (0, import_baseDevEnv.getSshTunnelOptions)(appName, environment);
|
|
32
|
+
const serverOptions = {
|
|
33
|
+
port
|
|
34
|
+
};
|
|
35
|
+
const forwardOptions = {
|
|
36
|
+
srcAddr: "0.0.0.0",
|
|
37
|
+
srcPort: port,
|
|
38
|
+
dstAddr: `mongo-0.mongo-svc.${appName}-${environment}`,
|
|
39
|
+
dstPort: 27017
|
|
40
|
+
};
|
|
41
|
+
const [server, client] = await (0, import_tunnel_ssh.createTunnel)(tunnelOptions, serverOptions, sshOptions, forwardOptions);
|
|
42
|
+
return `localhost:${port}`;
|
|
43
|
+
}, "createTunnel");
|
|
44
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
45
|
+
0 && (module.exports = {
|
|
46
|
+
createTunnel
|
|
47
|
+
});
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
#!/usr/bin/env ts-node
|
|
2
|
+
declare class TypeScriptDependencyScanner {
|
|
3
|
+
#private;
|
|
4
|
+
readonly directory: string;
|
|
5
|
+
constructor(directory: string);
|
|
6
|
+
getImportSets(depSets: Set<string>[]): Promise<Set<string>[]>;
|
|
7
|
+
getDependencies(): Promise<Map<string, string[]>>;
|
|
8
|
+
generateDependencyGraph(): string;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export { TypeScriptDependencyScanner };
|