@prosopo/cli 2.1.8 → 2.1.10
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 +22 -0
- package/dist/argv.js.map +1 -0
- package/dist/bundle/provider.cli.bundle.js +244470 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +57 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/addBlockRules.d.ts +25 -0
- package/dist/commands/addBlockRules.d.ts.map +1 -0
- package/dist/commands/addBlockRules.js +58 -0
- package/dist/commands/addBlockRules.js.map +1 -0
- package/dist/commands/index.d.ts +6 -0
- package/dist/commands/index.d.ts.map +1 -0
- package/dist/commands/index.js +6 -0
- package/dist/commands/index.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/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/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/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.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/package.json +11 -11
|
@@ -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;AAuDnD,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, blockMiddleware } 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(blockMiddleware(env));
|
|
21
|
+
apiApp.use(prosopoRouter(env));
|
|
22
|
+
apiApp.use(prosopoVerifyRouter(env));
|
|
23
|
+
if (admin) {
|
|
24
|
+
apiApp.use(authMiddleware(env));
|
|
25
|
+
apiApp.use(prosopoAdminRouter(env));
|
|
26
|
+
}
|
|
27
|
+
const rateLimits = env.config.rateLimits;
|
|
28
|
+
for (const [path, limit] of Object.entries(rateLimits)) {
|
|
29
|
+
const enumPath = path;
|
|
30
|
+
apiApp.use(enumPath, rateLimit(limit));
|
|
31
|
+
}
|
|
32
|
+
return apiApp.listen(apiPort, () => {
|
|
33
|
+
env.logger.info(`Prosopo app listening at http://localhost:${apiPort}`);
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
export async function start(env, admin, port) {
|
|
37
|
+
if (!env) {
|
|
38
|
+
loadEnv();
|
|
39
|
+
getDB();
|
|
40
|
+
const secret = getSecret();
|
|
41
|
+
const config = getConfig(undefined, {
|
|
42
|
+
solved: { count: 2 },
|
|
43
|
+
unsolved: { count: 0 },
|
|
44
|
+
});
|
|
45
|
+
const pair = await getPairAsync(secret);
|
|
46
|
+
env = new ProviderEnvironment(config, pair);
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
env.logger.debug("Env already defined");
|
|
50
|
+
}
|
|
51
|
+
await env.isReady();
|
|
52
|
+
if (env.pair) {
|
|
53
|
+
storeCaptchasExternally(env.pair, env.config).catch((err) => {
|
|
54
|
+
console.error("Failed to start scheduler:", err);
|
|
55
|
+
});
|
|
56
|
+
getClientList(env.pair, env.config).catch((err) => {
|
|
57
|
+
console.error("Failed to get client list:", err);
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
return startApi(env, admin, port);
|
|
61
|
+
}
|
|
62
|
+
export async function startDev(env, admin) {
|
|
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.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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@prosopo/cli",
|
|
3
|
-
"version": "2.1.
|
|
3
|
+
"version": "2.1.10",
|
|
4
4
|
"description": "CLI for Prosopo Provider",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"type": "module",
|
|
@@ -29,15 +29,15 @@
|
|
|
29
29
|
"@polkadot/keyring": "12.6.2",
|
|
30
30
|
"@polkadot/types-codec": "10.13.1",
|
|
31
31
|
"@polkadot/util-crypto": "12.6.2",
|
|
32
|
-
"@prosopo/config": "2.1.
|
|
33
|
-
"@prosopo/common": "2.1.
|
|
34
|
-
"@prosopo/contract": "2.1.
|
|
35
|
-
"@prosopo/dotenv": "2.1.
|
|
36
|
-
"@prosopo/env": "2.1.
|
|
37
|
-
"@prosopo/locale": "2.1.
|
|
38
|
-
"@prosopo/provider": "2.1.
|
|
39
|
-
"@prosopo/types": "2.1.
|
|
40
|
-
"@prosopo/util": "2.1.
|
|
32
|
+
"@prosopo/config": "2.1.10",
|
|
33
|
+
"@prosopo/common": "2.1.10",
|
|
34
|
+
"@prosopo/contract": "2.1.10",
|
|
35
|
+
"@prosopo/dotenv": "2.1.10",
|
|
36
|
+
"@prosopo/env": "2.1.10",
|
|
37
|
+
"@prosopo/locale": "2.1.10",
|
|
38
|
+
"@prosopo/provider": "2.1.10",
|
|
39
|
+
"@prosopo/types": "2.1.10",
|
|
40
|
+
"@prosopo/util": "2.1.10",
|
|
41
41
|
"cors": "2.8.5",
|
|
42
42
|
"cron-parser": "4.9.0",
|
|
43
43
|
"dotenv": "16.4.5",
|
|
@@ -46,7 +46,7 @@
|
|
|
46
46
|
"zod": "3.23.8"
|
|
47
47
|
},
|
|
48
48
|
"devDependencies": {
|
|
49
|
-
"@prosopo/config": "2.1.
|
|
49
|
+
"@prosopo/config": "2.1.10",
|
|
50
50
|
"@types/cors": "2.8.17",
|
|
51
51
|
"@types/yargs": "17.0.33",
|
|
52
52
|
"@vitest/coverage-v8": "2.1.1",
|