@prosopo/cli 2.1.4 → 2.1.6
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/RateLimiter.d.ts +63 -0
- package/dist/RateLimiter.d.ts.map +1 -0
- package/dist/RateLimiter.js +66 -0
- package/dist/RateLimiter.js.map +1 -0
- package/dist/argv.d.ts +22 -0
- package/dist/argv.d.ts.map +1 -0
- package/dist/argv.js +21 -0
- package/dist/argv.js.map +1 -0
- package/dist/cjs/RateLimiter.cjs +68 -0
- package/dist/cjs/argv.cjs +19 -0
- package/dist/cjs/cli.cjs +53 -0
- package/dist/cjs/commands/index.cjs +10 -0
- package/dist/cjs/commands/providerSetDataset.cjs +51 -0
- package/dist/cjs/commands/siteKeyRegister.cjs +31 -0
- package/dist/cjs/commands/storeCaptchasExternally.cjs +25 -0
- package/dist/cjs/commands/validators.cjs +41 -0
- package/dist/cjs/commands/version.cjs +14 -0
- package/dist/cjs/files.cjs +39 -0
- package/dist/cjs/index.cjs +21 -0
- package/dist/cjs/process.env.cjs +45 -0
- package/dist/cjs/prosopo.config.cjs +68 -0
- package/dist/cjs/reloader.cjs +59 -0
- package/dist/cjs/start.cjs +69 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +56 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/batchCommit.d.ts +21 -0
- package/dist/commands/batchCommit.d.ts.map +1 -0
- package/dist/commands/batchCommit.js +37 -0
- package/dist/commands/batchCommit.js.map +1 -0
- package/dist/commands/dappAccounts.d.ts +15 -0
- package/dist/commands/dappAccounts.d.ts.map +1 -0
- package/dist/commands/dappAccounts.js +25 -0
- package/dist/commands/dappAccounts.js.map +1 -0
- package/dist/commands/dappDetails.d.ts +19 -0
- package/dist/commands/dappDetails.d.ts.map +1 -0
- package/dist/commands/dappDetails.js +32 -0
- package/dist/commands/dappDetails.js.map +1 -0
- package/dist/commands/dappRegister.d.ts +23 -0
- package/dist/commands/dappRegister.d.ts.map +1 -0
- package/dist/commands/dappRegister.js +48 -0
- package/dist/commands/dappRegister.js.map +1 -0
- package/dist/commands/dappUpdate.d.ts +23 -0
- package/dist/commands/dappUpdate.d.ts.map +1 -0
- package/dist/commands/dappUpdate.js +50 -0
- package/dist/commands/dappUpdate.js.map +1 -0
- package/dist/commands/index.d.ts +5 -0
- package/dist/commands/index.d.ts.map +1 -0
- package/dist/commands/index.js +5 -0
- package/dist/commands/index.js.map +1 -0
- package/dist/commands/providerAccounts.d.ts +9 -0
- package/dist/commands/providerAccounts.d.ts.map +1 -0
- package/dist/commands/providerAccounts.js +24 -0
- package/dist/commands/providerAccounts.js.map +1 -0
- package/dist/commands/providerDataset.d.ts +18 -0
- package/dist/commands/providerDataset.d.ts.map +1 -0
- package/dist/commands/providerDataset.js +46 -0
- package/dist/commands/providerDataset.js.map +1 -0
- package/dist/commands/providerDeregister.d.ts +19 -0
- package/dist/commands/providerDeregister.d.ts.map +1 -0
- package/dist/commands/providerDeregister.js +30 -0
- package/dist/commands/providerDeregister.js.map +1 -0
- package/dist/commands/providerDetails.d.ts +19 -0
- package/dist/commands/providerDetails.d.ts.map +1 -0
- package/dist/commands/providerDetails.js +33 -0
- package/dist/commands/providerDetails.js.map +1 -0
- package/dist/commands/providerRegister.d.ts +9 -0
- package/dist/commands/providerRegister.d.ts.map +1 -0
- package/dist/commands/providerRegister.js +60 -0
- package/dist/commands/providerRegister.js.map +1 -0
- package/dist/commands/providerSetDataset.d.ts +17 -0
- package/dist/commands/providerSetDataset.d.ts.map +1 -0
- package/dist/commands/providerSetDataset.js +35 -0
- package/dist/commands/providerSetDataset.js.map +1 -0
- package/dist/commands/providerUpdate.d.ts +27 -0
- package/dist/commands/providerUpdate.d.ts.map +1 -0
- package/dist/commands/providerUpdate.js +63 -0
- package/dist/commands/providerUpdate.js.map +1 -0
- package/dist/commands/siteKeyRegister.d.ts +19 -0
- package/dist/commands/siteKeyRegister.d.ts.map +1 -0
- package/dist/commands/siteKeyRegister.js +31 -0
- package/dist/commands/siteKeyRegister.js.map +1 -0
- package/dist/commands/storeCaptchasExternally.d.ts +13 -0
- package/dist/commands/storeCaptchasExternally.d.ts.map +1 -0
- package/dist/commands/storeCaptchasExternally.js +27 -0
- package/dist/commands/storeCaptchasExternally.js.map +1 -0
- package/dist/commands/validators.d.ts +18 -0
- package/dist/commands/validators.d.ts.map +1 -0
- package/dist/commands/validators.js +36 -0
- package/dist/commands/validators.js.map +1 -0
- package/dist/commands/version.d.ts +12 -0
- package/dist/commands/version.d.ts.map +1 -0
- package/dist/commands/version.js +13 -0
- package/dist/commands/version.js.map +1 -0
- package/dist/env.d.ts +4 -0
- package/dist/env.d.ts.map +1 -0
- package/dist/env.js +25 -0
- package/dist/env.js.map +1 -0
- package/dist/files.d.ts +4 -0
- package/dist/files.d.ts.map +1 -0
- package/dist/files.js +37 -0
- package/dist/files.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js.map +1 -0
- package/dist/process.env.d.ts +8 -0
- package/dist/process.env.d.ts.map +1 -0
- package/dist/process.env.js +44 -0
- package/dist/process.env.js.map +1 -0
- package/dist/prosopo.config.d.ts +3 -0
- package/dist/prosopo.config.d.ts.map +1 -0
- package/dist/prosopo.config.js +73 -0
- package/dist/prosopo.config.js.map +1 -0
- package/dist/reloader.d.ts +21 -0
- package/dist/reloader.d.ts.map +1 -0
- package/dist/reloader.js +58 -0
- package/dist/reloader.js.map +1 -0
- package/dist/start.d.ts +5 -0
- package/dist/start.d.ts.map +1 -0
- package/dist/start.js +65 -0
- package/dist/start.js.map +1 -0
- package/dist/tests/bundle/bundle.test.d.ts +2 -0
- package/dist/tests/bundle/bundle.test.d.ts.map +1 -0
- package/dist/tests/bundle/bundle.test.js +14 -0
- package/dist/tests/bundle/bundle.test.js.map +1 -0
- package/dist/tests/bundle/bundle.unit.test.d.ts +2 -0
- package/dist/tests/bundle/bundle.unit.test.d.ts.map +1 -0
- package/dist/tests/bundle/bundle.unit.test.js +14 -0
- package/dist/tests/bundle/bundle.unit.test.js.map +1 -0
- package/dist/tests/reloader.test.d.ts +2 -0
- package/dist/tests/reloader.test.d.ts.map +1 -0
- package/dist/tests/reloader.test.js +73 -0
- package/dist/tests/reloader.test.js.map +1 -0
- package/package.json +12 -12
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { ProsopoEnvError } from "@prosopo/common";
|
|
2
|
+
import { encodeStringAddress } from "@prosopo/provider";
|
|
3
|
+
import parser from "cron-parser";
|
|
4
|
+
export const validateAddress = (argv) => {
|
|
5
|
+
const address = encodeStringAddress(argv.address);
|
|
6
|
+
return { address };
|
|
7
|
+
};
|
|
8
|
+
export const validateSiteKey = (argv) => {
|
|
9
|
+
const sitekey = encodeStringAddress(argv.sitekey);
|
|
10
|
+
return { sitekey };
|
|
11
|
+
};
|
|
12
|
+
export const validateValue = (argv) => {
|
|
13
|
+
if (typeof argv.value !== "number") {
|
|
14
|
+
throw new ProsopoEnvError("CLI.PARAMETER_ERROR", {
|
|
15
|
+
context: { value: [argv.value] },
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
const value = argv.value;
|
|
19
|
+
return { value };
|
|
20
|
+
};
|
|
21
|
+
export const validateScheduleExpression = (argv) => {
|
|
22
|
+
if (typeof argv.schedule === "string") {
|
|
23
|
+
const result = parser.parseString(argv.schedule);
|
|
24
|
+
if (argv.schedule in result.errors) {
|
|
25
|
+
throw new ProsopoEnvError("CLI.PARAMETER_ERROR", {
|
|
26
|
+
context: {
|
|
27
|
+
payee: [argv.shedule],
|
|
28
|
+
failedFuncName: validateScheduleExpression.name,
|
|
29
|
+
},
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
return { schedule: argv.schedule };
|
|
33
|
+
}
|
|
34
|
+
return { schedule: null };
|
|
35
|
+
};
|
|
36
|
+
//# sourceMappingURL=validators.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../src/commands/validators.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,MAAM,MAAM,aAAa,CAAC;AAIjC,MAAM,CAAC,MAAM,eAAe,GAAG,CAC9B,IAAwB,EACF,EAAE;IACxB,MAAM,OAAO,GAAG,mBAAmB,CAAC,IAAI,CAAC,OAAiB,CAAC,CAAC;IAE5D,OAAO,EAAE,OAAO,EAAE,CAAC;AACpB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAC9B,IAAwB,EACF,EAAE;IACxB,MAAM,OAAO,GAAG,mBAAmB,CAAC,IAAI,CAAC,OAAiB,CAAC,CAAC;IAE5D,OAAO,EAAE,OAAO,EAAE,CAAC;AACpB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,IAAwB,EAAE,EAAE;IACzD,IAAI,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ,EAAE,CAAC;QACpC,MAAM,IAAI,eAAe,CAAC,qBAAqB,EAAE;YAChD,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;SAChC,CAAC,CAAC;IACJ,CAAC;IACD,MAAM,KAAK,GAAkB,IAAI,CAAC,KAAiC,CAAC;IACpE,OAAO,EAAE,KAAK,EAAE,CAAC;AAClB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAAC,IAAwB,EAAE,EAAE;IACtE,IAAI,OAAO,IAAI,CAAC,QAAQ,KAAK,QAAQ,EAAE,CAAC;QACvC,MAAM,MAAM,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,QAAkB,CAAC,CAAC;QAE3D,IAAI,IAAI,CAAC,QAAQ,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;YACpC,MAAM,IAAI,eAAe,CAAC,qBAAqB,EAAE;gBAChD,OAAO,EAAE;oBACR,KAAK,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC;oBACrB,cAAc,EAAE,0BAA0B,CAAC,IAAI;iBAC/C;aACD,CAAC,CAAC;QACJ,CAAC;QAED,OAAO,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAkB,EAAE,CAAC;IAC9C,CAAC;IACD,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;AAC3B,CAAC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { KeyringPair } from "@polkadot/keyring/types";
|
|
2
|
+
import { type Logger } from "@prosopo/common";
|
|
3
|
+
import type { ProsopoConfigOutput } from "@prosopo/types";
|
|
4
|
+
declare const _default: (pair: KeyringPair, config: ProsopoConfigOutput, cmdArgs?: {
|
|
5
|
+
logger?: Logger;
|
|
6
|
+
}) => {
|
|
7
|
+
command: string;
|
|
8
|
+
describe: string;
|
|
9
|
+
handler: () => Promise<void>;
|
|
10
|
+
};
|
|
11
|
+
export default _default;
|
|
12
|
+
//# sourceMappingURL=version.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../src/commands/version.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAY,KAAK,MAAM,EAAa,MAAM,iBAAiB,CAAC;AACnE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;+BAInD,WAAW,UACT,mBAAmB,YACjB;IAAE,MAAM,CAAC,EAAE,MAAM,CAAA;CAAE;;;;;AAH9B,wBAeE"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { LogLevel, getLogger } from "@prosopo/common";
|
|
2
|
+
import { version } from "@prosopo/util";
|
|
3
|
+
export default (pair, config, cmdArgs) => {
|
|
4
|
+
const logger = cmdArgs?.logger || getLogger(LogLevel.enum.info, "cli.version");
|
|
5
|
+
return {
|
|
6
|
+
command: "version",
|
|
7
|
+
describe: "Return the version of the software",
|
|
8
|
+
handler: async () => {
|
|
9
|
+
logger.info(`Version: ${JSON.stringify(version)}`);
|
|
10
|
+
},
|
|
11
|
+
};
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=version.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"version.js","sourceRoot":"","sources":["../../src/commands/version.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,QAAQ,EAAe,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAEnE,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAExC,eAAe,CACd,IAAiB,EACjB,MAA2B,EAC3B,OAA6B,EAC5B,EAAE;IACH,MAAM,MAAM,GACX,OAAO,EAAE,MAAM,IAAI,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,aAAa,CAAC,CAAC;IAEjE,OAAO;QACN,OAAO,EAAE,SAAS;QAClB,QAAQ,EAAE,oCAAoC;QAC9C,OAAO,EAAE,KAAK,IAAI,EAAE;YACnB,MAAM,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACpD,CAAC;KACD,CAAC;AACH,CAAC,CAAC"}
|
package/dist/env.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export declare function getEnv(): string;
|
|
2
|
+
export declare function loadEnv(rootDir?: string, filename?: string, filePath?: string): string;
|
|
3
|
+
export declare function getEnvFile(rootDir?: string, filename?: string, filepath?: string): string;
|
|
4
|
+
//# sourceMappingURL=env.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"env.d.ts","sourceRoot":"","sources":["../src/env.ts"],"names":[],"mappings":"AAsBA,wBAAgB,MAAM,WAKrB;AAED,wBAAgB,OAAO,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAMtF;AAED,wBAAgB,UAAU,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,QAAQ,SAAS,EAAE,QAAQ,SAAgC,UAGvG"}
|
package/dist/env.js
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { LogLevel, getLogger } from '@prosopo/common';
|
|
2
|
+
import { fileURLToPath } from 'url';
|
|
3
|
+
import dotenv from 'dotenv';
|
|
4
|
+
import path from 'path';
|
|
5
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
6
|
+
const __dirname = path.dirname(__filename);
|
|
7
|
+
const logger = getLogger(process.env.PROSOPO_LOG_LEVEL || LogLevel.enum.info, 'env');
|
|
8
|
+
export function getEnv() {
|
|
9
|
+
if (process.env.NODE_ENV) {
|
|
10
|
+
return process.env.NODE_ENV.replace(/\W/g, '');
|
|
11
|
+
}
|
|
12
|
+
return 'development';
|
|
13
|
+
}
|
|
14
|
+
export function loadEnv(rootDir, filename, filePath) {
|
|
15
|
+
const envPath = getEnvFile(path.resolve(rootDir || '.'), filename, filePath);
|
|
16
|
+
const args = { path: envPath };
|
|
17
|
+
logger.info(`Loading env from ${envPath}`);
|
|
18
|
+
dotenv.config(args);
|
|
19
|
+
return envPath;
|
|
20
|
+
}
|
|
21
|
+
export function getEnvFile(rootDir, filename = '.env', filepath = path.join(__dirname, '../..')) {
|
|
22
|
+
const env = getEnv();
|
|
23
|
+
return path.join(rootDir || filepath, `${filename}.${env}`);
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=env.js.map
|
package/dist/env.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"env.js","sourceRoot":"","sources":["../src/env.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,KAAK,CAAA;AACnC,OAAO,MAAM,MAAM,QAAQ,CAAA;AAC3B,OAAO,IAAI,MAAM,MAAM,CAAA;AAEvB,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;AACjD,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAA;AAC1C,MAAM,MAAM,GAAG,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;AAEpF,MAAM,UAAU,MAAM;IAClB,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE;QACtB,OAAO,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;KACjD;IACD,OAAO,aAAa,CAAA;AACxB,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,OAAgB,EAAE,QAAiB,EAAE,QAAiB;IAC1E,MAAM,OAAO,GAAG,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,GAAG,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAA;IAC5E,MAAM,IAAI,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,CAAA;IAC9B,MAAM,CAAC,IAAI,CAAC,oBAAoB,OAAO,EAAE,CAAC,CAAA;IAC1C,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;IACnB,OAAO,OAAO,CAAA;AAClB,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,OAAgB,EAAE,QAAQ,GAAG,MAAM,EAAE,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC;IACpG,MAAM,GAAG,GAAG,MAAM,EAAE,CAAA;IACpB,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,QAAQ,EAAE,GAAG,QAAQ,IAAI,GAAG,EAAE,CAAC,CAAA;AAC/D,CAAC"}
|
package/dist/files.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export declare function loadJSONFile(filePath: string): any;
|
|
2
|
+
export declare function writeJSONFile(filePath: string, jsonData: Record<string, any>): Promise<unknown>;
|
|
3
|
+
export declare function readFile(filePath: string): Promise<Buffer>;
|
|
4
|
+
//# sourceMappingURL=files.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"files.d.ts","sourceRoot":"","sources":["../src/files.ts"],"names":[],"mappings":"AAiBA,wBAAgB,YAAY,CAAC,QAAQ,EAAE,MAAM,OAQ5C;AAGD,wBAAgB,aAAa,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,oBAmB5E;AAED,wBAAsB,QAAQ,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAOhE"}
|
package/dist/files.js
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import fs, { createWriteStream } from "node:fs";
|
|
2
|
+
import { Readable } from "node:stream";
|
|
3
|
+
import { ProsopoCliError } from "@prosopo/common";
|
|
4
|
+
export function loadJSONFile(filePath) {
|
|
5
|
+
try {
|
|
6
|
+
return JSON.parse(fs.readFileSync(filePath, "utf8"));
|
|
7
|
+
}
|
|
8
|
+
catch (error) {
|
|
9
|
+
throw new ProsopoCliError("GENERAL.JSON_LOAD_FAILED", {
|
|
10
|
+
context: { error, filePath },
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export function writeJSONFile(filePath, jsonData) {
|
|
15
|
+
return new Promise((resolve, reject) => {
|
|
16
|
+
const writeStream = createWriteStream(filePath);
|
|
17
|
+
writeStream.setDefaultEncoding("utf-8");
|
|
18
|
+
writeStream.on("finish", () => {
|
|
19
|
+
resolve(true);
|
|
20
|
+
});
|
|
21
|
+
writeStream.on("error", (err) => {
|
|
22
|
+
reject(err);
|
|
23
|
+
});
|
|
24
|
+
const readable = Readable.from(JSON.stringify(jsonData));
|
|
25
|
+
readable.pipe(writeStream);
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
export async function readFile(filePath) {
|
|
29
|
+
return new Promise((resolve, reject) => {
|
|
30
|
+
fs.readFile(filePath, (err, data) => {
|
|
31
|
+
if (err)
|
|
32
|
+
reject(err);
|
|
33
|
+
resolve(data);
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=files.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"files.js","sourceRoot":"","sources":["../src/files.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAoB,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAClE,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAcvC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAElD,MAAM,UAAU,YAAY,CAAC,QAAgB;IAC5C,IAAI,CAAC;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAC;IACtD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QAChB,MAAM,IAAI,eAAe,CAAC,0BAA0B,EAAE;YACrD,OAAO,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE;SAC5B,CAAC,CAAC;IACJ,CAAC;AACF,CAAC;AAGD,MAAM,UAAU,aAAa,CAAC,QAAgB,EAAE,QAA6B;IAC5E,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACtC,MAAM,WAAW,GAAgB,iBAAiB,CAAC,QAAQ,CAAC,CAAC;QAE7D,WAAW,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;QAExC,WAAW,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;YAC7B,OAAO,CAAC,IAAI,CAAC,CAAC;QACf,CAAC,CAAC,CAAC;QAEH,WAAW,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;YAC/B,MAAM,CAAC,GAAG,CAAC,CAAC;QACb,CAAC,CAAC,CAAC;QAGH,MAAM,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;QAEzD,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,QAAQ,CAAC,QAAgB;IAC9C,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACtC,EAAE,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;YACnC,IAAI,GAAG;gBAAE,MAAM,CAAC,GAAG,CAAC,CAAC;YACrB,OAAO,CAAC,IAAc,CAAC,CAAC;QACzB,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;AACJ,CAAC"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAaA,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,kBAAkB,CAAC;AACjC,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,qBAAqB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAaA,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,kBAAkB,CAAC;AACjC,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { KeypairType } from "@polkadot/util-crypto/types";
|
|
2
|
+
export declare function getSs58Format(): number;
|
|
3
|
+
export declare function getPairType(): KeypairType;
|
|
4
|
+
export declare function getAddress(who?: string): string | undefined;
|
|
5
|
+
export declare function getPassword(who?: string): string | undefined;
|
|
6
|
+
export declare function getSecret(who?: string): string | undefined;
|
|
7
|
+
export declare function getDB(): string;
|
|
8
|
+
//# sourceMappingURL=process.env.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"process.env.d.ts","sourceRoot":"","sources":["../src/process.env.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAG/D,wBAAgB,aAAa,IAAI,MAAM,CAEtC;AAED,wBAAgB,WAAW,IAAI,WAAW,CAIzC;AAED,wBAAgB,UAAU,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAO3D;AAED,wBAAgB,WAAW,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAO5D;AAED,wBAAgB,SAAS,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAY1D;AAED,wBAAgB,KAAK,IAAI,MAAM,CAK9B"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { ProsopoEnvError } from "@prosopo/common";
|
|
2
|
+
export function getSs58Format() {
|
|
3
|
+
return Number.parseInt(process.env.SS58_FORMAT || "") || 42;
|
|
4
|
+
}
|
|
5
|
+
export function getPairType() {
|
|
6
|
+
return (process.env.PROSOPO_PAIR_TYPE || "sr25519");
|
|
7
|
+
}
|
|
8
|
+
export function getAddress(who) {
|
|
9
|
+
if (!who) {
|
|
10
|
+
who = "PROVIDER";
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
who = who.toUpperCase();
|
|
14
|
+
}
|
|
15
|
+
return process.env[`PROSOPO_${who}_ADDRESS`];
|
|
16
|
+
}
|
|
17
|
+
export function getPassword(who) {
|
|
18
|
+
if (!who) {
|
|
19
|
+
who = "PROVIDER";
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
who = who.toUpperCase();
|
|
23
|
+
}
|
|
24
|
+
return process.env[`PROSOPO_${who}_ACCOUNT_PASSWORD`];
|
|
25
|
+
}
|
|
26
|
+
export function getSecret(who) {
|
|
27
|
+
if (!who) {
|
|
28
|
+
who = "PROVIDER";
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
who = who.toUpperCase();
|
|
32
|
+
}
|
|
33
|
+
return (process.env[`PROSOPO_${who}_MNEMONIC`] ||
|
|
34
|
+
process.env[`PROSOPO_${who}_SEED`] ||
|
|
35
|
+
process.env[`PROSOPO_${who}_URI`] ||
|
|
36
|
+
process.env[`PROSOPO_${who}_JSON`]);
|
|
37
|
+
}
|
|
38
|
+
export function getDB() {
|
|
39
|
+
if (!process.env.PROSOPO_DATABASE_HOST) {
|
|
40
|
+
throw new ProsopoEnvError("DATABASE.DATABASE_HOST_UNDEFINED");
|
|
41
|
+
}
|
|
42
|
+
return process.env.PROSOPO_DATABASE_HOST;
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=process.env.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"process.env.js","sourceRoot":"","sources":["../src/process.env.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAElD,MAAM,UAAU,aAAa;IAC5B,OAAO,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,WAAW,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC;AAC7D,CAAC;AAED,MAAM,UAAU,WAAW;IAC1B,OAAO,CACL,OAAO,CAAC,GAAG,CAAC,iBAAiC,IAAK,SAAyB,CAC5E,CAAC;AACH,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,GAAY;IACtC,IAAI,CAAC,GAAG,EAAE,CAAC;QACV,GAAG,GAAG,UAAU,CAAC;IAClB,CAAC;SAAM,CAAC;QACP,GAAG,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC;IACzB,CAAC;IACD,OAAO,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,UAAU,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,GAAY;IACvC,IAAI,CAAC,GAAG,EAAE,CAAC;QACV,GAAG,GAAG,UAAU,CAAC;IAClB,CAAC;SAAM,CAAC;QACP,GAAG,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC;IACzB,CAAC;IACD,OAAO,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,mBAAmB,CAAC,CAAC;AACvD,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,GAAY;IACrC,IAAI,CAAC,GAAG,EAAE,CAAC;QACV,GAAG,GAAG,UAAU,CAAC;IAClB,CAAC;SAAM,CAAC;QACP,GAAG,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC;IACzB,CAAC;IACD,OAAO,CACN,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,WAAW,CAAC;QACtC,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,OAAO,CAAC;QAClC,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,MAAM,CAAC;QACjC,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,OAAO,CAAC,CAClC,CAAC;AACH,CAAC;AAED,MAAM,UAAU,KAAK;IACpB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,qBAAqB,EAAE,CAAC;QACxC,MAAM,IAAI,eAAe,CAAC,kCAAkC,CAAC,CAAC;IAC/D,CAAC;IACD,OAAO,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC;AAC1C,CAAC"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { type ProsopoCaptchaCountConfigSchemaInput, type ProsopoCaptchaSolutionConfigSchema, type ProsopoConfigOutput } from "@prosopo/types";
|
|
2
|
+
export default function getConfig(captchaSolutionsConfig?: typeof ProsopoCaptchaSolutionConfigSchema, captchaServeConfig?: ProsopoCaptchaCountConfigSchemaInput, who?: string): ProsopoConfigOutput;
|
|
3
|
+
//# sourceMappingURL=prosopo.config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prosopo.config.d.ts","sourceRoot":"","sources":["../src/prosopo.config.ts"],"names":[],"mappings":"AAeA,OAAO,EAGN,KAAK,oCAAoC,EACzC,KAAK,kCAAkC,EAEvC,KAAK,mBAAmB,EAExB,MAAM,gBAAgB,CAAC;AAgBxB,MAAM,CAAC,OAAO,UAAU,SAAS,CAChC,sBAAsB,CAAC,EAAE,OAAO,kCAAkC,EAClE,kBAAkB,CAAC,EAAE,oCAAoC,EACzD,GAAG,SAAa,GACd,mBAAmB,CAwDrB"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { getLogLevel } from "@prosopo/common";
|
|
2
|
+
import { DatabaseTypes, EnvironmentTypesSchema, ProsopoConfigSchema, } from "@prosopo/types";
|
|
3
|
+
import { getRateLimitConfig } from "./RateLimiter.js";
|
|
4
|
+
import { getAddress, getPassword, getSecret } from "./process.env.js";
|
|
5
|
+
function getMongoURI() {
|
|
6
|
+
const protocol = process.env.PROSOPO_DATABASE_PROTOCOL || "mongodb";
|
|
7
|
+
const mongoSrv = protocol === "mongodb+srv";
|
|
8
|
+
const password = process.env.PROSOPO_DATABASE_PASSWORD || "root";
|
|
9
|
+
const username = process.env.PROSOPO_DATABASE_USERNAME || "root";
|
|
10
|
+
const host = process.env.PROSOPO_DATABASE_HOST || "localhost";
|
|
11
|
+
const port = mongoSrv ? "" : `:${process.env.PROSOPO_DATABASE_PORT || 27017}`;
|
|
12
|
+
const retries = mongoSrv ? "?retryWrites=true&w=majority" : "";
|
|
13
|
+
const mongoURI = `${protocol}://${username}:${password}@${host}${port}/${retries}`;
|
|
14
|
+
return mongoURI;
|
|
15
|
+
}
|
|
16
|
+
export default function getConfig(captchaSolutionsConfig, captchaServeConfig, who = "PROVIDER") {
|
|
17
|
+
return ProsopoConfigSchema.parse({
|
|
18
|
+
logLevel: getLogLevel(),
|
|
19
|
+
defaultEnvironment: process.env.PROSOPO_DEFAULT_ENVIRONMENT
|
|
20
|
+
? EnvironmentTypesSchema.parse(process.env.PROSOPO_DEFAULT_ENVIRONMENT)
|
|
21
|
+
: EnvironmentTypesSchema.enum.development,
|
|
22
|
+
account: {
|
|
23
|
+
address: getAddress(who),
|
|
24
|
+
password: getPassword(who),
|
|
25
|
+
secret: getSecret(who),
|
|
26
|
+
},
|
|
27
|
+
database: {
|
|
28
|
+
development: {
|
|
29
|
+
type: DatabaseTypes.enum.provider,
|
|
30
|
+
endpoint: getMongoURI(),
|
|
31
|
+
dbname: process.env.PROSOPO_DATABASE_NAME,
|
|
32
|
+
authSource: process.env.PROSOPO_DATABASE_AUTH_SOURCE,
|
|
33
|
+
},
|
|
34
|
+
staging: {
|
|
35
|
+
type: DatabaseTypes.enum.provider,
|
|
36
|
+
endpoint: getMongoURI(),
|
|
37
|
+
dbname: process.env.PROSOPO_DATABASE_NAME,
|
|
38
|
+
authSource: process.env.PROSOPO_DATABASE_AUTH_SOURCE,
|
|
39
|
+
},
|
|
40
|
+
production: {
|
|
41
|
+
type: DatabaseTypes.enum.provider,
|
|
42
|
+
endpoint: getMongoURI(),
|
|
43
|
+
dbname: process.env.PROSOPO_DATABASE_NAME,
|
|
44
|
+
authSource: process.env.PROSOPO_DATABASE_AUTH_SOURCE,
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
server: {
|
|
48
|
+
baseURL: process.env.PROSOPO_API_BASE_URL || "http://localhost",
|
|
49
|
+
port: process.env.PROSOPO_API_PORT
|
|
50
|
+
? Number.parseInt(process.env.PROSOPO_API_PORT)
|
|
51
|
+
: 9229,
|
|
52
|
+
},
|
|
53
|
+
captchaSolutions: captchaSolutionsConfig,
|
|
54
|
+
captchas: captchaServeConfig,
|
|
55
|
+
devOnlyWatchEvents: process.env._DEV_ONLY_WATCH_EVENTS === "true",
|
|
56
|
+
mongoEventsUri: process.env.PROSOPO_MONGO_EVENTS_URI || "",
|
|
57
|
+
mongoCaptchaUri: process.env.PROSOPO_MONGO_CAPTCHA_URI || "",
|
|
58
|
+
mongoClientUri: process.env.PROSOPO_MONGO_CLIENT_URI || "",
|
|
59
|
+
rateLimits: getRateLimitConfig(),
|
|
60
|
+
proxyCount: process.env.PROSOPO_PROXY_COUNT
|
|
61
|
+
? Number.parseInt(process.env.PROSOPO_PROXY_COUNT)
|
|
62
|
+
: 0,
|
|
63
|
+
scheduledTasks: {
|
|
64
|
+
captchaScheduler: {
|
|
65
|
+
schedule: process.env.CAPTCHA_STORAGE_SCHEDULE,
|
|
66
|
+
},
|
|
67
|
+
clientListScheduler: {
|
|
68
|
+
schedule: process.env.CLIENT_LIST_SCHEDULE,
|
|
69
|
+
},
|
|
70
|
+
},
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=prosopo.config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prosopo.config.js","sourceRoot":"","sources":["../src/prosopo.config.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { KeyringPair } from "@polkadot/keyring/types";
|
|
2
|
+
import { ProviderEnvironment } from "@prosopo/env";
|
|
3
|
+
import type { ProsopoConfigOutput } from "@prosopo/types";
|
|
4
|
+
import type { AwaitedProcessedArgs } from "./argv.js";
|
|
5
|
+
export default class ReloadingAPI {
|
|
6
|
+
private _envWatcher;
|
|
7
|
+
private _envPath;
|
|
8
|
+
private _config;
|
|
9
|
+
private _pair;
|
|
10
|
+
private _processedArgs;
|
|
11
|
+
private api;
|
|
12
|
+
private _restarting;
|
|
13
|
+
private _env;
|
|
14
|
+
constructor(envPath: string, config: ProsopoConfigOutput, pair: KeyringPair, processedArgs: AwaitedProcessedArgs);
|
|
15
|
+
get env(): ProviderEnvironment | undefined;
|
|
16
|
+
start(reloadEnv?: boolean): Promise<void>;
|
|
17
|
+
startDev(): Promise<void>;
|
|
18
|
+
stop(): Promise<unknown>;
|
|
19
|
+
private _watchEnv;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=reloader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reloader.d.ts","sourceRoot":"","sources":["../src/reloader.ts"],"names":[],"mappings":"AAeA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAG3D,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC1D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AAKtD,MAAM,CAAC,OAAO,OAAO,YAAY;IAEhC,OAAO,CAAC,WAAW,CAAM;IACzB,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,OAAO,CAAsB;IACrC,OAAO,CAAC,KAAK,CAAc;IAC3B,OAAO,CAAC,cAAc,CAAuB;IAC7C,OAAO,CAAC,GAAG,CAAqB;IAChC,OAAO,CAAC,WAAW,CAAU;IAC7B,OAAO,CAAC,IAAI,CAAkC;gBAG7C,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,mBAAmB,EAC3B,IAAI,EAAE,WAAW,EACjB,aAAa,EAAE,oBAAoB;IASpC,IAAI,GAAG,oCAEN;IAEY,KAAK,CAAC,SAAS,UAAQ;IAYvB,QAAQ;IASR,IAAI;YASH,SAAS;CAYvB"}
|
package/dist/reloader.js
ADDED
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import fs from "node:fs";
|
|
2
|
+
import { LogLevel, getLogger } from "@prosopo/common";
|
|
3
|
+
import { loadEnv } from "@prosopo/dotenv";
|
|
4
|
+
import { ProviderEnvironment } from "@prosopo/env";
|
|
5
|
+
import { start, startDev } from "./start.js";
|
|
6
|
+
const log = getLogger(LogLevel.enum.info, "CLI");
|
|
7
|
+
export default class ReloadingAPI {
|
|
8
|
+
constructor(envPath, config, pair, processedArgs) {
|
|
9
|
+
this._envPath = envPath;
|
|
10
|
+
this._config = config;
|
|
11
|
+
this._pair = pair;
|
|
12
|
+
this._processedArgs = processedArgs;
|
|
13
|
+
this._restarting = false;
|
|
14
|
+
}
|
|
15
|
+
get env() {
|
|
16
|
+
return this._env;
|
|
17
|
+
}
|
|
18
|
+
async start(reloadEnv = false) {
|
|
19
|
+
log.info("Starting API");
|
|
20
|
+
this._envWatcher = await this._watchEnv();
|
|
21
|
+
loadEnv();
|
|
22
|
+
if (!this._env && reloadEnv) {
|
|
23
|
+
const env = new ProviderEnvironment(this._config, this._pair);
|
|
24
|
+
await env.isReady();
|
|
25
|
+
this._env = env;
|
|
26
|
+
}
|
|
27
|
+
this.api = await start(this.env, !!this._processedArgs.adminApi);
|
|
28
|
+
}
|
|
29
|
+
async startDev() {
|
|
30
|
+
log.info("Starting API");
|
|
31
|
+
this._envWatcher = await this._watchEnv();
|
|
32
|
+
loadEnv();
|
|
33
|
+
const env = new ProviderEnvironment(this._config, this._pair);
|
|
34
|
+
await env.isReady();
|
|
35
|
+
this.api = await startDev(env, !!this._processedArgs.adminApi);
|
|
36
|
+
}
|
|
37
|
+
async stop() {
|
|
38
|
+
log.info("Stopping API");
|
|
39
|
+
return new Promise((resolve) => {
|
|
40
|
+
if (this.api) {
|
|
41
|
+
this.api.close(resolve);
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
async _watchEnv() {
|
|
46
|
+
return fs.watchFile(this._envPath, async () => {
|
|
47
|
+
log.info(`env file change detected. Restarting: ${this._restarting}`);
|
|
48
|
+
if (!this._restarting) {
|
|
49
|
+
this._restarting = true;
|
|
50
|
+
await this.stop();
|
|
51
|
+
loadEnv();
|
|
52
|
+
await this.start(true);
|
|
53
|
+
this._restarting = false;
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=reloader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reloader.js","sourceRoot":"","sources":["../src/reloader.ts"],"names":[],"mappings":"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"}
|
package/dist/start.d.ts
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { Server } from "node:net";
|
|
2
|
+
import { ProviderEnvironment } from "@prosopo/env";
|
|
3
|
+
export declare function start(env?: ProviderEnvironment, admin?: boolean, port?: number): Promise<Server>;
|
|
4
|
+
export declare function startDev(env?: ProviderEnvironment, admin?: boolean): Promise<Server>;
|
|
5
|
+
//# sourceMappingURL=start.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"start.d.ts","sourceRoot":"","sources":["../src/start.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAGvC,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAqDnD,wBAAsB,KAAK,CAC1B,GAAG,CAAC,EAAE,mBAAmB,EACzB,KAAK,CAAC,EAAE,OAAO,EACf,IAAI,CAAC,EAAE,MAAM,mBAiCb;AAED,wBAAsB,QAAQ,CAAC,GAAG,CAAC,EAAE,mBAAmB,EAAE,KAAK,CAAC,EAAE,OAAO,mBAGxE"}
|
package/dist/start.js
ADDED
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { getPairAsync } from "@prosopo/contract";
|
|
2
|
+
import { loadEnv } from "@prosopo/dotenv";
|
|
3
|
+
import { ProviderEnvironment } from "@prosopo/env";
|
|
4
|
+
import { i18nMiddleware } from "@prosopo/locale";
|
|
5
|
+
import { getClientList, prosopoAdminRouter, prosopoRouter, prosopoVerifyRouter, storeCaptchasExternally, } from "@prosopo/provider";
|
|
6
|
+
import { authMiddleware } from "@prosopo/provider";
|
|
7
|
+
import cors from "cors";
|
|
8
|
+
import express from "express";
|
|
9
|
+
import rateLimit from "express-rate-limit";
|
|
10
|
+
import { getDB, getSecret } from "./process.env.js";
|
|
11
|
+
import getConfig from "./prosopo.config.js";
|
|
12
|
+
function startApi(env, admin = false, port) {
|
|
13
|
+
env.logger.info("Starting Prosopo API");
|
|
14
|
+
const apiApp = express();
|
|
15
|
+
const apiPort = port || env.config.server.port;
|
|
16
|
+
apiApp.set("trust proxy", env.config.proxyCount);
|
|
17
|
+
apiApp.use(cors());
|
|
18
|
+
apiApp.use(express.json({ limit: "50mb" }));
|
|
19
|
+
apiApp.use(i18nMiddleware({}));
|
|
20
|
+
apiApp.use(prosopoRouter(env));
|
|
21
|
+
apiApp.use(prosopoVerifyRouter(env));
|
|
22
|
+
if (admin) {
|
|
23
|
+
apiApp.use(authMiddleware(env));
|
|
24
|
+
apiApp.use(prosopoAdminRouter(env));
|
|
25
|
+
}
|
|
26
|
+
const rateLimits = env.config.rateLimits;
|
|
27
|
+
for (const [path, limit] of Object.entries(rateLimits)) {
|
|
28
|
+
const enumPath = path;
|
|
29
|
+
apiApp.use(enumPath, rateLimit(limit));
|
|
30
|
+
}
|
|
31
|
+
return apiApp.listen(apiPort, () => {
|
|
32
|
+
env.logger.info(`Prosopo app listening at http://localhost:${apiPort}`);
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
export async function start(env, admin, port) {
|
|
36
|
+
if (!env) {
|
|
37
|
+
loadEnv();
|
|
38
|
+
getDB();
|
|
39
|
+
const secret = getSecret();
|
|
40
|
+
const config = getConfig(undefined, {
|
|
41
|
+
solved: { count: 2 },
|
|
42
|
+
unsolved: { count: 0 },
|
|
43
|
+
});
|
|
44
|
+
const pair = await getPairAsync(secret);
|
|
45
|
+
env = new ProviderEnvironment(config, pair);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
env.logger.debug("Env already defined");
|
|
49
|
+
}
|
|
50
|
+
await env.isReady();
|
|
51
|
+
if (env.pair) {
|
|
52
|
+
storeCaptchasExternally(env.pair, env.config).catch((err) => {
|
|
53
|
+
console.error("Failed to start scheduler:", err);
|
|
54
|
+
});
|
|
55
|
+
getClientList(env.pair, env.config).catch((err) => {
|
|
56
|
+
console.error("Failed to get client list:", err);
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
return startApi(env, admin, port);
|
|
60
|
+
}
|
|
61
|
+
export async function startDev(env, admin) {
|
|
62
|
+
start(env, admin, 9238);
|
|
63
|
+
return await start(env, admin);
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=start.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"start.js","sourceRoot":"","sources":["../src/start.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bundle.test.d.ts","sourceRoot":"","sources":["../../../src/tests/bundle/bundle.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { assert, describe, test } from 'vitest';
|
|
2
|
+
import { exec } from 'child_process';
|
|
3
|
+
import { getCliPkgDir } from '@prosopo/config';
|
|
4
|
+
import { promisify } from 'util';
|
|
5
|
+
const execPromise = promisify(exec);
|
|
6
|
+
describe('provider bundle', () => {
|
|
7
|
+
test('bundle runs after bundling', async () => {
|
|
8
|
+
const rootDir = getCliPkgDir();
|
|
9
|
+
await execPromise(`cd ${rootDir} && NODE_ENV=production npm run bundle`);
|
|
10
|
+
const { stdout: runOut, stderr: runErr } = await execPromise(`cd ${rootDir} && node dist/bundle/provider.cli.bundle.js version`);
|
|
11
|
+
assert(runOut.includes('Version:'));
|
|
12
|
+
}, 120000);
|
|
13
|
+
});
|
|
14
|
+
//# sourceMappingURL=bundle.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bundle.test.js","sourceRoot":"","sources":["../../../src/tests/bundle/bundle.test.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAA;AAC/C,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAA;AACpC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAA;AAChC,MAAM,WAAW,GAAG,SAAS,CAAC,IAAI,CAAC,CAAA;AAEnC,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC7B,IAAI,CAAC,4BAA4B,EAAE,KAAK,IAAI,EAAE;QAE1C,MAAM,OAAO,GAAG,YAAY,EAAE,CAAA;QAG9B,MAAM,WAAW,CAAC,MAAM,OAAO,wCAAwC,CAAC,CAAA;QAGxE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,WAAW,CACxD,MAAM,OAAO,qDAAqD,CACrE,CAAA;QACD,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAA;IACvC,CAAC,EAAE,MAAM,CAAC,CAAA;AACd,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bundle.unit.test.d.ts","sourceRoot":"","sources":["../../../src/tests/bundle/bundle.unit.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { exec } from "node:child_process";
|
|
2
|
+
import { promisify } from "node:util";
|
|
3
|
+
import { getCliPkgDir } from "@prosopo/config";
|
|
4
|
+
import { assert, describe, test } from "vitest";
|
|
5
|
+
const execPromise = promisify(exec);
|
|
6
|
+
describe("provider bundle", () => {
|
|
7
|
+
test("bundle runs after bundling", async () => {
|
|
8
|
+
const rootDir = getCliPkgDir();
|
|
9
|
+
await execPromise(`cd ${rootDir} && NODE_ENV=production npm run bundle`);
|
|
10
|
+
const { stdout: runOut, stderr: runErr } = await execPromise(`cd ${rootDir} && node dist/bundle/provider.cli.bundle.js version`);
|
|
11
|
+
assert(runOut.includes("Version:"));
|
|
12
|
+
}, 120000);
|
|
13
|
+
});
|
|
14
|
+
//# sourceMappingURL=bundle.unit.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bundle.unit.test.js","sourceRoot":"","sources":["../../../src/tests/bundle/bundle.unit.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAc/C,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAChD,MAAM,WAAW,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;AAEpC,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAChC,IAAI,CAAC,4BAA4B,EAAE,KAAK,IAAI,EAAE;QAE7C,MAAM,OAAO,GAAG,YAAY,EAAE,CAAC;QAG/B,MAAM,WAAW,CAAC,MAAM,OAAO,wCAAwC,CAAC,CAAC;QAGzE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,WAAW,CAC3D,MAAM,OAAO,qDAAqD,CAClE,CAAC;QACF,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC;IACrC,CAAC,EAAE,MAAM,CAAC,CAAC;AACZ,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reloader.test.d.ts","sourceRoot":"","sources":["../../src/tests/reloader.test.ts"],"names":[],"mappings":""}
|