PHP WebShell
Текущая директория: /usr/lib/node_modules/bitgo/node_modules/avalanche/dist/apis/keystore
Просмотр файла: api.js
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.KeystoreAPI = void 0;
const jrpcapi_1 = require("../../common/jrpcapi");
/**
* Class for interacting with a node API that is using the node's KeystoreAPI.
*
* **WARNING**: The KeystoreAPI is to be used by the node-owner as the data is stored locally on the node. Do not trust the root user. If you are not the node-owner, do not use this as your wallet.
*
* @category RPCAPIs
*
* @remarks This extends the [[JRPCAPI]] class. This class should not be directly called. Instead, use the [[Avalanche.addAPI]] function to register this interface with Avalanche.
*/
class KeystoreAPI extends jrpcapi_1.JRPCAPI {
/**
* This class should not be instantiated directly. Instead use the [[Avalanche.addAPI]] method.
*
* @param core A reference to the Avalanche class
* @param baseURL Defaults to the string "/ext/keystore" as the path to rpc's baseURL
*/
constructor(core, baseURL = "/ext/keystore") {
super(core, baseURL);
/**
* Creates a user in the node's database.
*
* @param username Name of the user to create
* @param password Password for the user
*
* @returns Promise for a boolean with true on success
*/
this.createUser = (username, password) => __awaiter(this, void 0, void 0, function* () {
const params = {
username,
password
};
const response = yield this.callMethod("keystore.createUser", params);
return response.data.result.success
? response.data.result.success
: response.data.result;
});
/**
* Exports a user. The user can be imported to another node with keystore.importUser .
*
* @param username The name of the user to export
* @param password The password of the user to export
*
* @returns Promise with a string importable using importUser
*/
this.exportUser = (username, password) => __awaiter(this, void 0, void 0, function* () {
const params = {
username,
password
};
const response = yield this.callMethod("keystore.exportUser", params);
return response.data.result.user
? response.data.result.user
: response.data.result;
});
/**
* Imports a user file into the node's user database and assigns it to a username.
*
* @param username The name the user file should be imported into
* @param user cb58 serialized string represetning a user"s data
* @param password The user"s password
*
* @returns A promise with a true-value on success.
*/
this.importUser = (username, user, password) => __awaiter(this, void 0, void 0, function* () {
const params = {
username,
user,
password
};
const response = yield this.callMethod("keystore.importUser", params);
return response.data.result.success
? response.data.result.success
: response.data.result;
});
/**
* Lists the names of all users on the node.
*
* @returns Promise of an array with all user names.
*/
this.listUsers = () => __awaiter(this, void 0, void 0, function* () {
const response = yield this.callMethod("keystore.listUsers");
return response.data.result.users;
});
/**
* Deletes a user in the node's database.
*
* @param username Name of the user to delete
* @param password Password for the user
*
* @returns Promise for a boolean with true on success
*/
this.deleteUser = (username, password) => __awaiter(this, void 0, void 0, function* () {
const params = {
username,
password
};
const response = yield this.callMethod("keystore.deleteUser", params);
return response.data.result.success
? response.data.result.success
: response.data.result;
});
}
}
exports.KeystoreAPI = KeystoreAPI;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../../src/apis/keystore/api.ts"],"names":[],"mappings":";;;;;;;;;;;;AAKA,kDAA8C;AAK9C;;;;;;;;GAQG;AACH,MAAa,WAAY,SAAQ,iBAAO;IA2GtC;;;;;OAKG;IACH,YAAY,IAAmB,EAAE,UAAkB,eAAe;QAChE,KAAK,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;QAjHtB;;;;;;;WAOG;QACH,eAAU,GAAG,CAAO,QAAgB,EAAE,QAAgB,EAAoB,EAAE;YAC1E,MAAM,MAAM,GAAmB;gBAC7B,QAAQ;gBACR,QAAQ;aACT,CAAA;YACD,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,qBAAqB,EACrB,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO;gBACjC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO;gBAC9B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC1B,CAAC,CAAA,CAAA;QAED;;;;;;;WAOG;QACH,eAAU,GAAG,CAAO,QAAgB,EAAE,QAAgB,EAAmB,EAAE;YACzE,MAAM,MAAM,GAAmB;gBAC7B,QAAQ;gBACR,QAAQ;aACT,CAAA;YACD,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,qBAAqB,EACrB,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC9B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC3B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC1B,CAAC,CAAA,CAAA;QAED;;;;;;;;WAQG;QACH,eAAU,GAAG,CACX,QAAgB,EAChB,IAAY,EACZ,QAAgB,EACE,EAAE;YACpB,MAAM,MAAM,GAAqB;gBAC/B,QAAQ;gBACR,IAAI;gBACJ,QAAQ;aACT,CAAA;YACD,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,qBAAqB,EACrB,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO;gBACjC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO;gBAC9B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC1B,CAAC,CAAA,CAAA;QAED;;;;WAIG;QACH,cAAS,GAAG,GAA4B,EAAE;YACxC,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,oBAAoB,CACrB,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAA;QACnC,CAAC,CAAA,CAAA;QAED;;;;;;;WAOG;QACH,eAAU,GAAG,CAAO,QAAgB,EAAE,QAAgB,EAAoB,EAAE;YAC1E,MAAM,MAAM,GAAmB;gBAC7B,QAAQ;gBACR,QAAQ;aACT,CAAA;YACD,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,qBAAqB,EACrB,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO;gBACjC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO;gBAC9B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC1B,CAAC,CAAA,CAAA;IAUD,CAAC;CACF;AApHD,kCAoHC","sourcesContent":["/**\n * @packageDocumentation\n * @module API-Keystore\n */\nimport AvalancheCore from \"../../avalanche\"\nimport { JRPCAPI } from \"../../common/jrpcapi\"\nimport { RequestResponseData } from \"../../common/apibase\"\nimport { ImportUserParams } from \"./interfaces\"\nimport { CredsInterface } from \"../../common/interfaces\"\n\n/**\n * Class for interacting with a node API that is using the node's KeystoreAPI.\n *\n * **WARNING**: The KeystoreAPI is to be used by the node-owner as the data is stored locally on the node. Do not trust the root user. If you are not the node-owner, do not use this as your wallet.\n *\n * @category RPCAPIs\n *\n * @remarks This extends the [[JRPCAPI]] class. This class should not be directly called. Instead, use the [[Avalanche.addAPI]] function to register this interface with Avalanche.\n */\nexport class KeystoreAPI extends JRPCAPI {\n  /**\n   * Creates a user in the node's database.\n   *\n   * @param username Name of the user to create\n   * @param password Password for the user\n   *\n   * @returns Promise for a boolean with true on success\n   */\n  createUser = async (username: string, password: string): Promise<boolean> => {\n    const params: CredsInterface = {\n      username,\n      password\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"keystore.createUser\",\n      params\n    )\n    return response.data.result.success\n      ? response.data.result.success\n      : response.data.result\n  }\n\n  /**\n   * Exports a user. The user can be imported to another node with keystore.importUser .\n   *\n   * @param username The name of the user to export\n   * @param password The password of the user to export\n   *\n   * @returns Promise with a string importable using importUser\n   */\n  exportUser = async (username: string, password: string): Promise<string> => {\n    const params: CredsInterface = {\n      username,\n      password\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"keystore.exportUser\",\n      params\n    )\n    return response.data.result.user\n      ? response.data.result.user\n      : response.data.result\n  }\n\n  /**\n   * Imports a user file into the node's user database and assigns it to a username.\n   *\n   * @param username The name the user file should be imported into\n   * @param user cb58 serialized string represetning a user\"s data\n   * @param password The user\"s password\n   *\n   * @returns A promise with a true-value on success.\n   */\n  importUser = async (\n    username: string,\n    user: string,\n    password: string\n  ): Promise<boolean> => {\n    const params: ImportUserParams = {\n      username,\n      user,\n      password\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"keystore.importUser\",\n      params\n    )\n    return response.data.result.success\n      ? response.data.result.success\n      : response.data.result\n  }\n\n  /**\n   * Lists the names of all users on the node.\n   *\n   * @returns Promise of an array with all user names.\n   */\n  listUsers = async (): Promise<string[]> => {\n    const response: RequestResponseData = await this.callMethod(\n      \"keystore.listUsers\"\n    )\n    return response.data.result.users\n  }\n\n  /**\n   * Deletes a user in the node's database.\n   *\n   * @param username Name of the user to delete\n   * @param password Password for the user\n   *\n   * @returns Promise for a boolean with true on success\n   */\n  deleteUser = async (username: string, password: string): Promise<boolean> => {\n    const params: CredsInterface = {\n      username,\n      password\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"keystore.deleteUser\",\n      params\n    )\n    return response.data.result.success\n      ? response.data.result.success\n      : response.data.result\n  }\n\n  /**\n   * This class should not be instantiated directly. Instead use the [[Avalanche.addAPI]] method.\n   *\n   * @param core A reference to the Avalanche class\n   * @param baseURL Defaults to the string \"/ext/keystore\" as the path to rpc's baseURL\n   */\n  constructor(core: AvalancheCore, baseURL: string = \"/ext/keystore\") {\n    super(core, baseURL)\n  }\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!