@mainsail/crypto-worker 0.0.1-alpha.2 → 0.0.1-alpha.20
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/README.md +19 -0
- package/distribution/defaults.js +6 -9
- package/distribution/defaults.js.map +1 -1
- package/distribution/index.d.ts +1 -1
- package/distribution/index.d.ts.map +1 -1
- package/distribution/index.js +1 -17
- package/distribution/index.js.map +1 -1
- package/distribution/service-provider.d.ts.map +1 -1
- package/distribution/service-provider.js +20 -26
- package/distribution/service-provider.js.map +1 -1
- package/distribution/worker-handler.d.ts +7 -8
- package/distribution/worker-handler.d.ts.map +1 -1
- package/distribution/worker-handler.js +15 -20
- package/distribution/worker-handler.js.map +1 -1
- package/distribution/worker-pool.d.ts +4 -5
- package/distribution/worker-pool.d.ts.map +1 -1
- package/distribution/worker-pool.js +16 -18
- package/distribution/worker-pool.js.map +1 -1
- package/distribution/worker-script.js +3 -11
- package/distribution/worker-script.js.map +1 -1
- package/distribution/worker.d.ts +8 -10
- package/distribution/worker.d.ts.map +1 -1
- package/distribution/worker.js +10 -13
- package/distribution/worker.js.map +1 -1
- package/package.json +10 -9
package/README.md
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
# Mainsail - Crypto worker
|
|
2
|
+
|
|
3
|
+

|
|
4
|
+
|
|
5
|
+
## Documentation
|
|
6
|
+
|
|
7
|
+
You can find installation instructions and detailed instructions on how to use this package at the [dedicated documentation site](https://ark.dev/docs/mainsail).
|
|
8
|
+
|
|
9
|
+
## Security
|
|
10
|
+
|
|
11
|
+
If you discover a security vulnerability within this package, please send an e-mail to [security@ark.io](mailto:security@ark.io). All security vulnerabilities will be promptly addressed.
|
|
12
|
+
|
|
13
|
+
## Credits
|
|
14
|
+
|
|
15
|
+
This project exists thanks to all the people who [contribute](https://github.com/ArkEcosystem/mainsail/graphs/contributors).
|
|
16
|
+
|
|
17
|
+
## License
|
|
18
|
+
|
|
19
|
+
[GPL-3.0-only](https://github.com/ArkEcosystem/mainsail/blob/main/LICENSE) © [ARK Ecosystem](https://ark.io)
|
package/distribution/defaults.js
CHANGED
|
@@ -1,11 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
exports.defaults = {
|
|
8
|
-
workerCount: kernel_1.Environment.get(contracts_1.Constants.Flags.CORE_CRYPTO_WORKER_COUNT, (0, os_1.cpus)().length),
|
|
9
|
-
workerLoggingEnabled: kernel_1.Environment.isTrue(contracts_1.Constants.Flags.CORE_CRYPTO_WORKER_LOGGING_ENABLED),
|
|
1
|
+
import { Constants } from "@mainsail/contracts";
|
|
2
|
+
import { Environment } from "@mainsail/kernel";
|
|
3
|
+
import { cpus } from "os";
|
|
4
|
+
export const defaults = {
|
|
5
|
+
workerCount: Environment.get(Constants.EnvironmentVariables.CORE_CRYPTO_WORKER_COUNT, cpus().length),
|
|
6
|
+
workerLoggingEnabled: Environment.isTrue(Constants.EnvironmentVariables.CORE_CRYPTO_WORKER_LOGGING_ENABLED),
|
|
10
7
|
};
|
|
11
8
|
//# sourceMappingURL=defaults.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"defaults.js","sourceRoot":"","sources":["../source/defaults.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"defaults.js","sourceRoot":"","sources":["../source/defaults.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAE1B,MAAM,CAAC,MAAM,QAAQ,GAAG;IACvB,WAAW,EAAE,WAAW,CAAC,GAAG,CAAC,SAAS,CAAC,oBAAoB,CAAC,wBAAwB,EAAE,IAAI,EAAE,CAAC,MAAM,CAAC;IACpG,oBAAoB,EAAE,WAAW,CAAC,MAAM,CAAC,SAAS,CAAC,oBAAoB,CAAC,kCAAkC,CAAC;CAC3G,CAAC"}
|
package/distribution/index.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from "./service-provider";
|
|
1
|
+
export * from "./service-provider.js";
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC"}
|
package/distribution/index.js
CHANGED
|
@@ -1,18 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./service-provider"), exports);
|
|
1
|
+
export * from "./service-provider.js";
|
|
18
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../source/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"service-provider.d.ts","sourceRoot":"","sources":["../source/service-provider.ts"],"names":[],"mappings":"AACA,OAAO,
|
|
1
|
+
{"version":3,"file":"service-provider.d.ts","sourceRoot":"","sources":["../source/service-provider.ts"],"names":[],"mappings":"AACA,OAAO,EAAO,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,GAAG,MAAM,KAAK,CAAC;AAQtB,qBAAa,eAAgB,SAAQ,SAAS,CAAC,eAAe;IAChD,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAYzB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAIrB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAIxB,QAAQ,IAAI,OAAO,CAAC,OAAO,CAAC;IAIlC,YAAY,IAAI,GAAG,CAAC,SAAS;CAMpC"}
|
|
@@ -1,41 +1,35 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
const joi_1 = __importDefault(require("joi"));
|
|
11
|
-
const os_1 = require("os");
|
|
12
|
-
const worker_1 = require("./worker");
|
|
13
|
-
const worker_pool_1 = require("./worker-pool");
|
|
14
|
-
class ServiceProvider extends kernel_1.Providers.ServiceProvider {
|
|
1
|
+
import { Identifiers } from "@mainsail/contracts";
|
|
2
|
+
import { Ipc, Providers } from "@mainsail/kernel";
|
|
3
|
+
import Joi from "joi";
|
|
4
|
+
import { cpus } from "os";
|
|
5
|
+
import { URL } from "url";
|
|
6
|
+
import { Worker } from "worker_threads";
|
|
7
|
+
import { Worker as WorkerInstance } from "./worker.js";
|
|
8
|
+
import { WorkerPool } from "./worker-pool.js";
|
|
9
|
+
export class ServiceProvider extends Providers.ServiceProvider {
|
|
15
10
|
async register() {
|
|
16
|
-
this.app.bind(
|
|
17
|
-
this.app.bind(
|
|
18
|
-
this.app.bind(
|
|
19
|
-
|
|
20
|
-
|
|
11
|
+
this.app.bind(Identifiers.CryptoWorker.Worker.Instance).to(WorkerInstance);
|
|
12
|
+
this.app.bind(Identifiers.CryptoWorker.Worker.Factory).toAutoFactory(Identifiers.CryptoWorker.Worker.Instance);
|
|
13
|
+
this.app.bind(Identifiers.CryptoWorker.WorkerPool).to(WorkerPool).inSingletonScope();
|
|
14
|
+
this.app.bind(Identifiers.CryptoWorker.WorkerSubprocess.Factory).toFactory(() => () => {
|
|
15
|
+
const subprocess = new Worker(`${new URL(".", import.meta.url).pathname}/worker-script.js`, {});
|
|
16
|
+
return new Ipc.Subprocess(subprocess);
|
|
21
17
|
});
|
|
22
|
-
this.app.bind(contracts_1.Identifiers.CryptoWorker.Worker.Factory).toAutoFactory(contracts_1.Identifiers.CryptoWorker.Worker.Instance);
|
|
23
18
|
}
|
|
24
19
|
async boot() {
|
|
25
|
-
await this.app.get(
|
|
20
|
+
await this.app.get(Identifiers.CryptoWorker.WorkerPool).boot();
|
|
26
21
|
}
|
|
27
22
|
async dispose() {
|
|
28
|
-
await this.app.get(
|
|
23
|
+
await this.app.get(Identifiers.CryptoWorker.WorkerPool).shutdown();
|
|
29
24
|
}
|
|
30
25
|
async required() {
|
|
31
26
|
return true;
|
|
32
27
|
}
|
|
33
28
|
configSchema() {
|
|
34
|
-
return
|
|
35
|
-
workerCount:
|
|
36
|
-
workerLoggingEnabled:
|
|
29
|
+
return Joi.object({
|
|
30
|
+
workerCount: Joi.number().integer().min(1).max(cpus().length).required(),
|
|
31
|
+
workerLoggingEnabled: Joi.bool().required(),
|
|
37
32
|
}).unknown(true);
|
|
38
33
|
}
|
|
39
34
|
}
|
|
40
|
-
exports.ServiceProvider = ServiceProvider;
|
|
41
35
|
//# sourceMappingURL=service-provider.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"service-provider.js","sourceRoot":"","sources":["../source/service-provider.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"service-provider.js","sourceRoot":"","sources":["../source/service-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAC1B,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAExC,OAAO,EAAE,MAAM,IAAI,cAAc,EAAE,MAAM,aAAa,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C,MAAM,OAAO,eAAgB,SAAQ,SAAS,CAAC,eAAe;IACtD,KAAK,CAAC,QAAQ;QACpB,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC;QAC3E,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,aAAa,CAAC,WAAW,CAAC,YAAY,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAE/G,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,gBAAgB,EAAE,CAAC;QAErF,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE;YACrF,MAAM,UAAU,GAAG,IAAI,MAAM,CAAC,GAAG,IAAI,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,mBAAmB,EAAE,EAAE,CAAC,CAAC;YAChG,OAAO,IAAI,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,IAAI;QAChB,MAAM,IAAI,CAAC,GAAG,CAAC,GAAG,CAA8B,WAAW,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAAC;IAC7F,CAAC;IAEM,KAAK,CAAC,OAAO;QACnB,MAAM,IAAI,CAAC,GAAG,CAAC,GAAG,CAA8B,WAAW,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,QAAQ,EAAE,CAAC;IACjG,CAAC;IAEM,KAAK,CAAC,QAAQ;QACpB,OAAO,IAAI,CAAC;IACb,CAAC;IAEM,YAAY;QAClB,OAAO,GAAG,CAAC,MAAM,CAAC;YACjB,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE;YACxE,oBAAoB,EAAE,GAAG,CAAC,IAAI,EAAE,CAAC,QAAQ,EAAE;SAC3C,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC;CACD"}
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
import { Contracts } from "@mainsail/contracts";
|
|
2
|
-
|
|
3
|
-
export declare class WorkerScriptHandler implements IpcWorker.WorkerScriptHandler {
|
|
2
|
+
export declare class WorkerScriptHandler implements Contracts.Crypto.WorkerScriptHandler {
|
|
4
3
|
#private;
|
|
5
|
-
boot(flags:
|
|
6
|
-
consensusSignature<K extends
|
|
7
|
-
walletSignature<K extends
|
|
8
|
-
blockFactory<K extends
|
|
9
|
-
transactionFactory<K extends
|
|
10
|
-
publicKeyFactory<K extends
|
|
4
|
+
boot(flags: Contracts.Crypto.WorkerFlags): Promise<void>;
|
|
5
|
+
consensusSignature<K extends Contracts.Kernel.IPC.Requests<Contracts.Crypto.Signature>>(method: K, ...arguments_: Parameters<Contracts.Crypto.Signature[K]>): Promise<ReturnType<Contracts.Crypto.Signature[K]>>;
|
|
6
|
+
walletSignature<K extends Contracts.Kernel.IPC.Requests<Contracts.Crypto.Signature>>(method: K, ...arguments_: Parameters<Contracts.Crypto.Signature[K]>): Promise<ReturnType<Contracts.Crypto.Signature[K]>>;
|
|
7
|
+
blockFactory<K extends Contracts.Kernel.IPC.Requests<Contracts.Crypto.BlockFactory>>(method: K, ...arguments_: Parameters<Contracts.Crypto.BlockFactory[K]>): Promise<ReturnType<Contracts.Crypto.BlockFactory[K]>>;
|
|
8
|
+
transactionFactory<K extends Contracts.Kernel.IPC.Requests<Contracts.Crypto.TransactionFactory>>(method: K, ...arguments_: Parameters<Contracts.Crypto.TransactionFactory[K]>): Promise<ReturnType<Contracts.Crypto.TransactionFactory[K]>>;
|
|
9
|
+
publicKeyFactory<K extends Contracts.Kernel.IPC.Requests<Contracts.Crypto.PublicKeyFactory>>(method: K, ...arguments_: Parameters<Contracts.Crypto.PublicKeyFactory[K]>): Promise<ReturnType<Contracts.Crypto.PublicKeyFactory[K]>>;
|
|
11
10
|
}
|
|
12
11
|
//# sourceMappingURL=worker-handler.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker-handler.d.ts","sourceRoot":"","sources":["../source/worker-handler.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAe,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"worker-handler.d.ts","sourceRoot":"","sources":["../source/worker-handler.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAe,MAAM,qBAAqB,CAAC;AAgF7D,qBAAa,mBAAoB,YAAW,SAAS,CAAC,MAAM,CAAC,mBAAmB;;IAOlE,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,MAAM,CAAC,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAmBxD,kBAAkB,CAAC,CAAC,SAAS,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,EAClG,MAAM,EAAE,CAAC,EACT,GAAG,UAAU,EAAE,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,GACtD,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IAKxC,eAAe,CAAC,CAAC,SAAS,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,EAC/F,MAAM,EAAE,CAAC,EACT,GAAG,UAAU,EAAE,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,GACtD,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IAKxC,YAAY,CAAC,CAAC,SAAS,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,EAC/F,MAAM,EAAE,CAAC,EACT,GAAG,UAAU,EAAE,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,GACzD,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;IAK3C,kBAAkB,CAAC,CAAC,SAAS,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,kBAAkB,CAAC,EAC3G,MAAM,EAAE,CAAC,EACT,GAAG,UAAU,EAAE,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,GAC/D,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC;IAKjD,gBAAgB,CAAC,CAAC,SAAS,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,EACvG,MAAM,EAAE,CAAC,EACT,GAAG,UAAU,EAAE,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,GAC7D,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC;CAI5D"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
1
|
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
2
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
3
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
@@ -20,11 +19,9 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
|
|
|
20
19
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
21
20
|
};
|
|
22
21
|
var _WorkerImpl_instances, _WorkerImpl_call, _WorkerScriptHandler_app, _WorkerScriptHandler_impl;
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
const contracts_1 = require("@mainsail/contracts");
|
|
27
|
-
const kernel_1 = require("@mainsail/kernel");
|
|
22
|
+
import { Container, inject, injectable, tagged } from "@mainsail/container";
|
|
23
|
+
import { Contracts, Identifiers } from "@mainsail/contracts";
|
|
24
|
+
import { Application, Services } from "@mainsail/kernel";
|
|
28
25
|
let WorkerImpl = class WorkerImpl {
|
|
29
26
|
constructor() {
|
|
30
27
|
_WorkerImpl_instances.add(this);
|
|
@@ -60,32 +57,32 @@ _WorkerImpl_call = async function _WorkerImpl_call(object, method, arguments_) {
|
|
|
60
57
|
return object[method](...arguments_);
|
|
61
58
|
};
|
|
62
59
|
__decorate([
|
|
63
|
-
|
|
60
|
+
inject(Identifiers.Cryptography.Block.Factory),
|
|
64
61
|
__metadata("design:type", Object)
|
|
65
62
|
], WorkerImpl.prototype, "blockFactory", void 0);
|
|
66
63
|
__decorate([
|
|
67
|
-
|
|
64
|
+
inject(Identifiers.Cryptography.Transaction.Factory),
|
|
68
65
|
__metadata("design:type", Object)
|
|
69
66
|
], WorkerImpl.prototype, "transactionFactory", void 0);
|
|
70
67
|
__decorate([
|
|
71
|
-
|
|
72
|
-
|
|
68
|
+
inject(Identifiers.Cryptography.Signature.Instance),
|
|
69
|
+
tagged("type", "consensus"),
|
|
73
70
|
__metadata("design:type", Object)
|
|
74
71
|
], WorkerImpl.prototype, "consensusSignature", void 0);
|
|
75
72
|
__decorate([
|
|
76
|
-
|
|
77
|
-
|
|
73
|
+
inject(Identifiers.Cryptography.Identity.PublicKey.Factory),
|
|
74
|
+
tagged("type", "consensus"),
|
|
78
75
|
__metadata("design:type", Object)
|
|
79
76
|
], WorkerImpl.prototype, "publicKeyFactory", void 0);
|
|
80
77
|
__decorate([
|
|
81
|
-
|
|
82
|
-
|
|
78
|
+
inject(Identifiers.Cryptography.Signature.Instance),
|
|
79
|
+
tagged("type", "wallet"),
|
|
83
80
|
__metadata("design:type", Object)
|
|
84
81
|
], WorkerImpl.prototype, "walletSignature", void 0);
|
|
85
82
|
WorkerImpl = __decorate([
|
|
86
|
-
|
|
83
|
+
injectable()
|
|
87
84
|
], WorkerImpl);
|
|
88
|
-
class WorkerScriptHandler {
|
|
85
|
+
export class WorkerScriptHandler {
|
|
89
86
|
constructor() {
|
|
90
87
|
// @ts-ignore
|
|
91
88
|
_WorkerScriptHandler_app.set(this, void 0);
|
|
@@ -93,13 +90,12 @@ class WorkerScriptHandler {
|
|
|
93
90
|
_WorkerScriptHandler_impl.set(this, void 0);
|
|
94
91
|
}
|
|
95
92
|
async boot(flags) {
|
|
96
|
-
const app = new
|
|
97
|
-
app.config("worker", true);
|
|
93
|
+
const app = new Application(new Container());
|
|
98
94
|
await app.bootstrap({
|
|
99
95
|
flags,
|
|
100
96
|
});
|
|
101
97
|
if (!flags.workerLoggingEnabled) {
|
|
102
|
-
app.rebind(
|
|
98
|
+
app.rebind(Identifiers.Services.Log.Service).to(Services.Log.NullLogger);
|
|
103
99
|
}
|
|
104
100
|
// eslint-disable-next-line @typescript-eslint/await-thenable
|
|
105
101
|
await app.boot();
|
|
@@ -127,6 +123,5 @@ class WorkerScriptHandler {
|
|
|
127
123
|
return __classPrivateFieldGet(this, _WorkerScriptHandler_impl, "f").callPublicKeyFactory(method, arguments_[0]);
|
|
128
124
|
}
|
|
129
125
|
}
|
|
130
|
-
exports.WorkerScriptHandler = WorkerScriptHandler;
|
|
131
126
|
_WorkerScriptHandler_app = new WeakMap(), _WorkerScriptHandler_impl = new WeakMap();
|
|
132
127
|
//# sourceMappingURL=worker-handler.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker-handler.js","sourceRoot":"","sources":["../source/worker-handler.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"worker-handler.js","sourceRoot":"","sources":["../source/worker-handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
export declare class WorkerPool implements IpcWorker.WorkerPool {
|
|
1
|
+
import { Contracts } from "@mainsail/contracts";
|
|
2
|
+
export declare class WorkerPool implements Contracts.Crypto.WorkerPool {
|
|
4
3
|
#private;
|
|
5
4
|
private readonly configuration;
|
|
6
5
|
private readonly logger;
|
|
@@ -8,7 +7,7 @@ export declare class WorkerPool implements IpcWorker.WorkerPool {
|
|
|
8
7
|
private workers;
|
|
9
8
|
private readonly flags;
|
|
10
9
|
boot(): Promise<void>;
|
|
11
|
-
shutdown(
|
|
12
|
-
getWorker(): Promise<
|
|
10
|
+
shutdown(): Promise<void>;
|
|
11
|
+
getWorker(): Promise<Contracts.Crypto.Worker>;
|
|
13
12
|
}
|
|
14
13
|
//# sourceMappingURL=worker-pool.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker-pool.d.ts","sourceRoot":"","sources":["../source/worker-pool.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"worker-pool.d.ts","sourceRoot":"","sources":["../source/worker-pool.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAe,MAAM,qBAAqB,CAAC;AAG7D,qBACa,UAAW,YAAW,SAAS,CAAC,MAAM,CAAC,UAAU;;IAG7D,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAiC;IAG/D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA2B;IAGlD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAkC;IAE/D,OAAO,CAAC,OAAO,CAAiC;IAGhD,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAsB;IAI/B,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAqBrB,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAIzB,SAAS,IAAI,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC;CAM1D"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
1
|
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
2
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
3
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
@@ -20,11 +19,9 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
|
|
|
20
19
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
21
20
|
};
|
|
22
21
|
var _WorkerPool_currentWorkerIndex;
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
const contracts_1 = require("@mainsail/contracts");
|
|
27
|
-
const kernel_1 = require("@mainsail/kernel");
|
|
22
|
+
import { inject, injectable, tagged } from "@mainsail/container";
|
|
23
|
+
import { Contracts, Identifiers } from "@mainsail/contracts";
|
|
24
|
+
import { Providers, Types } from "@mainsail/kernel";
|
|
28
25
|
let WorkerPool = class WorkerPool {
|
|
29
26
|
constructor() {
|
|
30
27
|
this.workers = [];
|
|
@@ -36,14 +33,15 @@ let WorkerPool = class WorkerPool {
|
|
|
36
33
|
const worker = this.createWorker();
|
|
37
34
|
this.workers.push(worker);
|
|
38
35
|
}
|
|
39
|
-
this.logger.info(`Booting up ${this.workers.length} workers`);
|
|
36
|
+
this.logger.info(`Booting up ${this.workers.length} crypto workers`);
|
|
40
37
|
await Promise.all(this.workers.map((worker) => worker.boot({
|
|
41
38
|
...this.flags,
|
|
39
|
+
thread: "crypto-worker",
|
|
42
40
|
workerLoggingEnabled: this.configuration.getRequired("workerLoggingEnabled"),
|
|
43
41
|
})));
|
|
44
42
|
}
|
|
45
|
-
async shutdown(
|
|
46
|
-
await Promise.all(this.workers.map((worker) => worker.kill(
|
|
43
|
+
async shutdown() {
|
|
44
|
+
await Promise.all(this.workers.map(async (worker) => await worker.kill()));
|
|
47
45
|
}
|
|
48
46
|
async getWorker() {
|
|
49
47
|
const worker = this.workers[__classPrivateFieldGet(this, _WorkerPool_currentWorkerIndex, "f")];
|
|
@@ -51,26 +49,26 @@ let WorkerPool = class WorkerPool {
|
|
|
51
49
|
return worker;
|
|
52
50
|
}
|
|
53
51
|
};
|
|
54
|
-
exports.WorkerPool = WorkerPool;
|
|
55
52
|
_WorkerPool_currentWorkerIndex = new WeakMap();
|
|
56
53
|
__decorate([
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
__metadata("design:type",
|
|
54
|
+
inject(Identifiers.ServiceProvider.Configuration),
|
|
55
|
+
tagged("plugin", "crypto-worker"),
|
|
56
|
+
__metadata("design:type", Providers.PluginConfiguration)
|
|
60
57
|
], WorkerPool.prototype, "configuration", void 0);
|
|
61
58
|
__decorate([
|
|
62
|
-
|
|
59
|
+
inject(Identifiers.Services.Log.Service),
|
|
63
60
|
__metadata("design:type", Object)
|
|
64
61
|
], WorkerPool.prototype, "logger", void 0);
|
|
65
62
|
__decorate([
|
|
66
|
-
|
|
63
|
+
inject(Identifiers.CryptoWorker.Worker.Factory),
|
|
67
64
|
__metadata("design:type", Function)
|
|
68
65
|
], WorkerPool.prototype, "createWorker", void 0);
|
|
69
66
|
__decorate([
|
|
70
|
-
|
|
67
|
+
inject(Identifiers.Config.Flags),
|
|
71
68
|
__metadata("design:type", Object)
|
|
72
69
|
], WorkerPool.prototype, "flags", void 0);
|
|
73
|
-
|
|
74
|
-
|
|
70
|
+
WorkerPool = __decorate([
|
|
71
|
+
injectable()
|
|
75
72
|
], WorkerPool);
|
|
73
|
+
export { WorkerPool };
|
|
76
74
|
//# sourceMappingURL=worker-pool.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker-pool.js","sourceRoot":"","sources":["../source/worker-pool.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"worker-pool.js","sourceRoot":"","sources":["../source/worker-pool.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AACjE,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAG7C,IAAM,UAAU,GAAhB,MAAM,UAAU;IAAhB;QAWE,YAAO,GAA8B,EAAE,CAAC;QAKhD,yCAAsB,CAAC,EAAC;IAiCzB,CAAC;IA/BO,KAAK,CAAC,IAAI;QAChB,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAS,aAAa,CAAC,CAAC;QAE1E,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,WAAW,EAAE,KAAK,EAAE,EAAE,CAAC;YAClD,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YACnC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC3B,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,OAAO,CAAC,MAAM,iBAAiB,CAAC,CAAC;QAErE,MAAM,OAAO,CAAC,GAAG,CAChB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAC3B,MAAM,CAAC,IAAI,CAAC;YACX,GAAG,IAAI,CAAC,KAAK;YACb,MAAM,EAAE,eAAe;YACvB,oBAAoB,EAAE,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,sBAAsB,CAAC;SAC5E,CAAC,CACF,CACD,CAAC;IACH,CAAC;IAEM,KAAK,CAAC,QAAQ;QACpB,MAAM,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC,MAAM,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAC5E,CAAC;IAEM,KAAK,CAAC,SAAS;QACrB,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,uBAAA,IAAI,sCAAoB,CAAC,CAAC;QACtD,uBAAA,IAAI,kCAAuB,CAAC,uBAAA,IAAI,sCAAoB,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,MAAA,CAAC;QAEhF,OAAO,MAAM,CAAC;IACf,CAAC;CACD,CAAA;;AA9CiB;IAFhB,MAAM,CAAC,WAAW,CAAC,eAAe,CAAC,aAAa,CAAC;IACjD,MAAM,CAAC,QAAQ,EAAE,eAAe,CAAC;8BACD,SAAS,CAAC,mBAAmB;iDAAC;AAG9C;IADhB,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC;;0CACS;AAGjC;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC;;gDACe;AAK9C;IADhB,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC;;yCACW;AAdhC,UAAU;IADtB,UAAU,EAAE;GACA,UAAU,CAiDtB"}
|
|
@@ -1,12 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const worker_handler_1 = require("./worker-handler");
|
|
5
|
-
const ipcHandler = new kernel_1.Ipc.Handler(new worker_handler_1.WorkerScriptHandler());
|
|
6
|
-
ipcHandler.handleRequest("boot");
|
|
7
|
-
ipcHandler.handleRequest("walletSignature");
|
|
8
|
-
ipcHandler.handleRequest("consensusSignature");
|
|
9
|
-
ipcHandler.handleRequest("blockFactory");
|
|
10
|
-
ipcHandler.handleRequest("transactionFactory");
|
|
11
|
-
ipcHandler.handleRequest("publicKeyFactory");
|
|
1
|
+
import { Ipc } from "@mainsail/kernel";
|
|
2
|
+
import { WorkerScriptHandler } from "./worker-handler.js";
|
|
3
|
+
new Ipc.Handler(new WorkerScriptHandler());
|
|
12
4
|
//# sourceMappingURL=worker-script.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker-script.js","sourceRoot":"","sources":["../source/worker-script.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"worker-script.js","sourceRoot":"","sources":["../source/worker-script.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AAEvC,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAE1D,IAAI,GAAG,CAAC,OAAO,CAAC,IAAI,mBAAmB,EAAE,CAAC,CAAC"}
|
package/distribution/worker.d.ts
CHANGED
|
@@ -1,17 +1,15 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
1
|
import { Contracts } from "@mainsail/contracts";
|
|
3
|
-
|
|
4
|
-
export declare class Worker implements IpcWorker.Worker {
|
|
2
|
+
export declare class Worker implements Contracts.Crypto.Worker {
|
|
5
3
|
#private;
|
|
6
4
|
private readonly createWorkerSubprocess;
|
|
7
5
|
private ipcSubprocess;
|
|
8
|
-
boot(flags:
|
|
9
|
-
kill(
|
|
6
|
+
boot(flags: Contracts.Crypto.WorkerFlags): Promise<void>;
|
|
7
|
+
kill(): Promise<number>;
|
|
10
8
|
getQueueSize(): number;
|
|
11
|
-
consensusSignature<K extends
|
|
12
|
-
walletSignature<K extends
|
|
13
|
-
blockFactory<K extends
|
|
14
|
-
transactionFactory<K extends
|
|
15
|
-
publicKeyFactory<K extends
|
|
9
|
+
consensusSignature<K extends Contracts.Kernel.IPC.Requests<Contracts.Crypto.Signature>>(method: K, ...arguments_: Parameters<Contracts.Crypto.Signature[K]>): Promise<ReturnType<Contracts.Crypto.Signature[K]>>;
|
|
10
|
+
walletSignature<K extends Contracts.Kernel.IPC.Requests<Contracts.Crypto.Signature>>(method: K, ...arguments_: Parameters<Contracts.Crypto.Signature[K]>): Promise<ReturnType<Contracts.Crypto.Signature[K]>>;
|
|
11
|
+
blockFactory<K extends Contracts.Kernel.IPC.Requests<Contracts.Crypto.BlockFactory>>(method: K, ...arguments_: Parameters<Contracts.Crypto.BlockFactory[K]>): Promise<ReturnType<Contracts.Crypto.BlockFactory[K]>>;
|
|
12
|
+
transactionFactory<K extends Contracts.Kernel.IPC.Requests<Contracts.Crypto.TransactionFactory>>(method: K, ...arguments_: Parameters<Contracts.Crypto.TransactionFactory[K]>): Promise<ReturnType<Contracts.Crypto.TransactionFactory[K]>>;
|
|
13
|
+
publicKeyFactory<K extends Contracts.Kernel.IPC.Requests<Contracts.Crypto.PublicKeyFactory>>(method: K, ...arguments_: Parameters<Contracts.Crypto.PublicKeyFactory[K]>): Promise<ReturnType<Contracts.Crypto.PublicKeyFactory[K]>>;
|
|
16
14
|
}
|
|
17
15
|
//# sourceMappingURL=worker.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker.d.ts","sourceRoot":"","sources":["../source/worker.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"worker.d.ts","sourceRoot":"","sources":["../source/worker.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAe,MAAM,qBAAqB,CAAC;AAG7D,qBACa,MAAO,YAAW,SAAS,CAAC,MAAM,CAAC,MAAM;;IAErD,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAA4C;IAEnF,OAAO,CAAC,aAAa,CAAqC;IAK7C,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,MAAM,CAAC,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAmBxD,IAAI,IAAI,OAAO,CAAC,MAAM,CAAC;IAI7B,YAAY,IAAI,MAAM;IAIhB,kBAAkB,CAAC,CAAC,SAAS,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,EAClG,MAAM,EAAE,CAAC,EACT,GAAG,UAAU,EAAE,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,GACtD,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IAIxC,eAAe,CAAC,CAAC,SAAS,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,EAC/F,MAAM,EAAE,CAAC,EACT,GAAG,UAAU,EAAE,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,GACtD,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IAIxC,YAAY,CAAC,CAAC,SAAS,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,EAC/F,MAAM,EAAE,CAAC,EACT,GAAG,UAAU,EAAE,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,GACzD,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;IAI3C,kBAAkB,CAAC,CAAC,SAAS,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,kBAAkB,CAAC,EAC3G,MAAM,EAAE,CAAC,EACT,GAAG,UAAU,EAAE,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,GAC/D,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC;IAIjD,gBAAgB,CAAC,CAAC,SAAS,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,EACvG,MAAM,EAAE,CAAC,EACT,GAAG,UAAU,EAAE,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,GAC7D,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC;CAG5D"}
|
package/distribution/worker.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
1
|
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
2
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
3
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
@@ -20,11 +19,9 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
|
|
|
20
19
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
21
20
|
};
|
|
22
21
|
var _Worker_booted, _Worker_booting;
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
const contracts_1 = require("@mainsail/contracts");
|
|
27
|
-
const kernel_1 = require("@mainsail/kernel");
|
|
22
|
+
import { inject, injectable } from "@mainsail/container";
|
|
23
|
+
import { Contracts, Identifiers } from "@mainsail/contracts";
|
|
24
|
+
import { Utils } from "@mainsail/kernel";
|
|
28
25
|
let Worker = class Worker {
|
|
29
26
|
constructor() {
|
|
30
27
|
_Worker_booted.set(this, false);
|
|
@@ -33,7 +30,7 @@ let Worker = class Worker {
|
|
|
33
30
|
async boot(flags) {
|
|
34
31
|
this.ipcSubprocess = this.createWorkerSubprocess();
|
|
35
32
|
while (__classPrivateFieldGet(this, _Worker_booting, "f")) {
|
|
36
|
-
await
|
|
33
|
+
await Utils.sleep(50);
|
|
37
34
|
}
|
|
38
35
|
if (__classPrivateFieldGet(this, _Worker_booted, "f")) {
|
|
39
36
|
return;
|
|
@@ -43,8 +40,8 @@ let Worker = class Worker {
|
|
|
43
40
|
__classPrivateFieldSet(this, _Worker_booting, false, "f");
|
|
44
41
|
__classPrivateFieldSet(this, _Worker_booted, true, "f");
|
|
45
42
|
}
|
|
46
|
-
async kill(
|
|
47
|
-
return this.ipcSubprocess.kill(
|
|
43
|
+
async kill() {
|
|
44
|
+
return this.ipcSubprocess.kill();
|
|
48
45
|
}
|
|
49
46
|
getQueueSize() {
|
|
50
47
|
return this.ipcSubprocess.getQueueSize();
|
|
@@ -65,14 +62,14 @@ let Worker = class Worker {
|
|
|
65
62
|
return this.ipcSubprocess.sendRequest("publicKeyFactory", method, arguments_);
|
|
66
63
|
}
|
|
67
64
|
};
|
|
68
|
-
exports.Worker = Worker;
|
|
69
65
|
_Worker_booted = new WeakMap();
|
|
70
66
|
_Worker_booting = new WeakMap();
|
|
71
67
|
__decorate([
|
|
72
|
-
|
|
68
|
+
inject(Identifiers.CryptoWorker.WorkerSubprocess.Factory),
|
|
73
69
|
__metadata("design:type", Function)
|
|
74
70
|
], Worker.prototype, "createWorkerSubprocess", void 0);
|
|
75
|
-
|
|
76
|
-
|
|
71
|
+
Worker = __decorate([
|
|
72
|
+
injectable()
|
|
77
73
|
], Worker);
|
|
74
|
+
export { Worker };
|
|
78
75
|
//# sourceMappingURL=worker.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker.js","sourceRoot":"","sources":["../source/worker.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"worker.js","sourceRoot":"","sources":["../source/worker.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAGlC,IAAM,MAAM,GAAZ,MAAM,MAAM;IAAZ;QAMN,yBAAU,KAAK,EAAC;QAChB,0BAAW,KAAK,EAAC;IA+DlB,CAAC;IA7DO,KAAK,CAAC,IAAI,CAAC,KAAmC;QACpD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAEnD,OAAO,uBAAA,IAAI,uBAAS,EAAE,CAAC;YACtB,MAAM,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACvB,CAAC;QAED,IAAI,uBAAA,IAAI,sBAAQ,EAAE,CAAC;YAClB,OAAO;QACR,CAAC;QAED,uBAAA,IAAI,mBAAY,IAAI,MAAA,CAAC;QAErB,MAAM,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAEpD,uBAAA,IAAI,mBAAY,KAAK,MAAA,CAAC;QACtB,uBAAA,IAAI,kBAAW,IAAI,MAAA,CAAC;IACrB,CAAC;IAEM,KAAK,CAAC,IAAI;QAChB,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IAClC,CAAC;IAEM,YAAY;QAClB,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;IAC1C,CAAC;IAEM,KAAK,CAAC,kBAAkB,CAC9B,MAAS,EACT,GAAG,UAAqD;QAExD,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,oBAAoB,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;IACjF,CAAC;IAEM,KAAK,CAAC,eAAe,CAC3B,MAAS,EACT,GAAG,UAAqD;QAExD,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,iBAAiB,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;IAC9E,CAAC;IAEM,KAAK,CAAC,YAAY,CACxB,MAAS,EACT,GAAG,UAAwD;QAE3D,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,cAAc,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;IAC3E,CAAC;IAEM,KAAK,CAAC,kBAAkB,CAC9B,MAAS,EACT,GAAG,UAA8D;QAEjE,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,oBAAoB,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;IACjF,CAAC;IAEM,KAAK,CAAC,gBAAgB,CAC5B,MAAS,EACT,GAAG,UAA4D;QAE/D,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,kBAAkB,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;IAC/E,CAAC;CACD,CAAA;;;AApEiB;IADhB,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC;;sDACyB;AAFvE,MAAM;IADlB,UAAU,EAAE;GACA,MAAM,CAsElB"}
|
package/package.json
CHANGED
|
@@ -1,26 +1,26 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mainsail/crypto-worker",
|
|
3
|
-
"version": "0.0.1-alpha.
|
|
3
|
+
"version": "0.0.1-alpha.20",
|
|
4
4
|
"description": "Crypto worker based on node child processes for Mainsail blockchain",
|
|
5
5
|
"license": "GPL-3.0-only",
|
|
6
6
|
"contributors": [],
|
|
7
|
+
"type": "module",
|
|
7
8
|
"main": "distribution/index.js",
|
|
8
9
|
"files": [
|
|
9
10
|
"/distribution"
|
|
10
11
|
],
|
|
11
12
|
"dependencies": {
|
|
12
|
-
"
|
|
13
|
-
"@mainsail/
|
|
14
|
-
"@mainsail/
|
|
13
|
+
"joi": "17.12.2",
|
|
14
|
+
"@mainsail/container": "0.0.1-alpha.20",
|
|
15
|
+
"@mainsail/contracts": "0.0.1-alpha.20",
|
|
16
|
+
"@mainsail/kernel": "0.0.1-alpha.20"
|
|
15
17
|
},
|
|
16
18
|
"devDependencies": {
|
|
17
19
|
"@types/chance": "1.1.6",
|
|
18
20
|
"@types/fs-extra": "11.0.4",
|
|
19
|
-
"@types/got": "9.6.12",
|
|
20
21
|
"@types/lodash.clonedeep": "4.5.9",
|
|
21
|
-
"@types/sinon": "^17.0.
|
|
22
|
+
"@types/sinon": "^17.0.3",
|
|
22
23
|
"@types/tmp": "0.2.6",
|
|
23
|
-
"joi": "17.11.0",
|
|
24
24
|
"uvu": "^0.5.6"
|
|
25
25
|
},
|
|
26
26
|
"engines": {
|
|
@@ -31,9 +31,10 @@
|
|
|
31
31
|
"build:watch": "pnpm run clean && tsc -w",
|
|
32
32
|
"clean": "del distribution",
|
|
33
33
|
"release": "pnpm publish --access public",
|
|
34
|
-
"test": "
|
|
34
|
+
"test": "pnpm run uvu source .test.ts",
|
|
35
35
|
"test:coverage": "c8 pnpm run test",
|
|
36
36
|
"test:coverage:html": "c8 -r html --all pnpm run test",
|
|
37
|
-
"test:file": "
|
|
37
|
+
"test:file": "pnpm run uvu source",
|
|
38
|
+
"uvu": "tsx --tsconfig ../../tsconfig.test.json ./node_modules/uvu/bin.js"
|
|
38
39
|
}
|
|
39
40
|
}
|