PHP WebShell

Текущая директория: /usr/lib/node_modules/bitgo/node_modules/@bitgo/abstract-utxo/dist/src/descriptor

Просмотр файла: validatePolicy.js

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.DescriptorPolicyValidationError = exports.policyAllowAll = void 0;
exports.getValidatorDescriptorTemplate = getValidatorDescriptorTemplate;
exports.getValidatorEvery = getValidatorEvery;
exports.getValidatorSome = getValidatorSome;
exports.getValidatorOneOfTemplates = getValidatorOneOfTemplates;
exports.getValidatorSignedByUserKey = getValidatorSignedByUserKey;
exports.assertDescriptorPolicy = assertDescriptorPolicy;
exports.toDescriptorMapValidate = toDescriptorMapValidate;
exports.getPolicyForEnv = getPolicyForEnv;
const descriptor_1 = require("@bitgo/utxo-core/descriptor");
const builder_1 = require("./builder");
const NamedDescriptor_1 = require("./NamedDescriptor");
exports.policyAllowAll = {
    name: 'allowAll',
    validate: () => true,
};
function getValidatorDescriptorTemplate(name) {
    return {
        name: 'descriptorTemplate(' + name + ')',
        validate(arr, walletKeys) {
            return arr.every((d) => {
                const parsed = (0, builder_1.parseDescriptor)(d.value);
                return (parsed.name === name &&
                    parsed.keys.length === walletKeys.length &&
                    parsed.keys.every((k, i) => k.toBase58() === walletKeys[i].neutered().toBase58()));
            });
        },
    };
}
function getValidatorEvery(validators) {
    return {
        name: 'every(' + validators.map((v) => v.name).join(',') + ')',
        validate(arr, walletKeys) {
            return validators.every((v) => v.validate(arr, walletKeys));
        },
    };
}
function getValidatorSome(validators) {
    return {
        name: 'some(' + validators.map((v) => v.name).join(',') + ')',
        validate(arr, walletKeys) {
            return validators.some((v) => v.validate(arr, walletKeys));
        },
    };
}
function getValidatorOneOfTemplates(names) {
    return getValidatorSome(names.map(getValidatorDescriptorTemplate));
}
function getValidatorSignedByUserKey() {
    return {
        name: 'signedByUser',
        validate(arr, walletKeys) {
            // the first key is the user key, by convention
            return arr.every((d) => (0, NamedDescriptor_1.hasValidSignature)(d.value, walletKeys[0], d.signatures ?? []));
        },
    };
}
class DescriptorPolicyValidationError extends Error {
    constructor(ds, policy) {
        super(`Descriptors ${ds.map((d) => d.value.toString())} does not match policy ${policy.name}`);
    }
}
exports.DescriptorPolicyValidationError = DescriptorPolicyValidationError;
function assertDescriptorPolicy(descriptors, policy, walletKeys) {
    if (!policy.validate(descriptors, walletKeys)) {
        throw new DescriptorPolicyValidationError(descriptors, policy);
    }
}
function toDescriptorMapValidate(descriptors, walletKeys, policy) {
    const namedDescriptorsNative = descriptors.map((v) => (0, NamedDescriptor_1.toNamedDescriptorNative)(v, 'derivable'));
    assertDescriptorPolicy(namedDescriptorsNative, policy, walletKeys);
    return (0, descriptor_1.toDescriptorMap)(namedDescriptorsNative);
}
function getPolicyForEnv(env) {
    switch (env) {
        case 'adminProd':
        case 'prod':
            return getValidatorSome([
                // allow 2-of-3-ish descriptor groups where the keys match the wallet keys
                getValidatorDescriptorTemplate('Wsh2Of3'),
                // allow descriptor groups where all keys match the wallet keys plus OP_DROP (coredao staking)
                getValidatorDescriptorTemplate('Wsh2Of3CltvDrop'),
                // allow all descriptors signed by the user key
                getValidatorSignedByUserKey(),
            ]);
        default:
            return exports.policyAllowAll;
    }
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validatePolicy.js","sourceRoot":"","sources":["../../../src/descriptor/validatePolicy.ts"],"names":[],"mappings":"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","sourcesContent":["import { EnvironmentName, Triple } from '@bitgo/sdk-core';\nimport * as utxolib from '@bitgo/utxo-lib';\nimport { DescriptorMap, toDescriptorMap } from '@bitgo/utxo-core/descriptor';\n\nimport { parseDescriptor } from './builder';\nimport { hasValidSignature, NamedDescriptor, NamedDescriptorNative, toNamedDescriptorNative } from './NamedDescriptor';\n\nexport type KeyTriple = Triple<utxolib.BIP32Interface>;\n\nexport interface DescriptorValidationPolicy {\n  name: string;\n\n  validate(arr: NamedDescriptorNative[], walletKeys: KeyTriple): boolean;\n}\n\nexport const policyAllowAll: DescriptorValidationPolicy = {\n  name: 'allowAll',\n  validate: () => true,\n};\n\nexport function getValidatorDescriptorTemplate(name: string): DescriptorValidationPolicy {\n  return {\n    name: 'descriptorTemplate(' + name + ')',\n    validate(arr: NamedDescriptorNative[], walletKeys: KeyTriple): boolean {\n      return arr.every((d) => {\n        const parsed = parseDescriptor(d.value);\n        return (\n          parsed.name === name &&\n          parsed.keys.length === walletKeys.length &&\n          parsed.keys.every((k, i) => k.toBase58() === walletKeys[i].neutered().toBase58())\n        );\n      });\n    },\n  };\n}\n\nexport function getValidatorEvery(validators: DescriptorValidationPolicy[]): DescriptorValidationPolicy {\n  return {\n    name: 'every(' + validators.map((v) => v.name).join(',') + ')',\n    validate(arr: NamedDescriptorNative[], walletKeys: KeyTriple): boolean {\n      return validators.every((v) => v.validate(arr, walletKeys));\n    },\n  };\n}\n\nexport function getValidatorSome(validators: DescriptorValidationPolicy[]): DescriptorValidationPolicy {\n  return {\n    name: 'some(' + validators.map((v) => v.name).join(',') + ')',\n    validate(arr: NamedDescriptorNative[], walletKeys: KeyTriple): boolean {\n      return validators.some((v) => v.validate(arr, walletKeys));\n    },\n  };\n}\n\nexport function getValidatorOneOfTemplates(names: string[]): DescriptorValidationPolicy {\n  return getValidatorSome(names.map(getValidatorDescriptorTemplate));\n}\n\nexport function getValidatorSignedByUserKey(): DescriptorValidationPolicy {\n  return {\n    name: 'signedByUser',\n    validate(arr: NamedDescriptorNative[], walletKeys: KeyTriple): boolean {\n      // the first key is the user key, by convention\n      return arr.every((d) => hasValidSignature(d.value, walletKeys[0], d.signatures ?? []));\n    },\n  };\n}\n\nexport class DescriptorPolicyValidationError extends Error {\n  constructor(ds: NamedDescriptorNative[], policy: DescriptorValidationPolicy) {\n    super(`Descriptors ${ds.map((d) => d.value.toString())} does not match policy ${policy.name}`);\n  }\n}\n\nexport function assertDescriptorPolicy(\n  descriptors: NamedDescriptorNative[],\n  policy: DescriptorValidationPolicy,\n  walletKeys: KeyTriple\n): void {\n  if (!policy.validate(descriptors, walletKeys)) {\n    throw new DescriptorPolicyValidationError(descriptors, policy);\n  }\n}\n\nexport function toDescriptorMapValidate(\n  descriptors: NamedDescriptor[],\n  walletKeys: KeyTriple,\n  policy: DescriptorValidationPolicy\n): DescriptorMap {\n  const namedDescriptorsNative: NamedDescriptorNative[] = descriptors.map((v) =>\n    toNamedDescriptorNative(v, 'derivable')\n  );\n  assertDescriptorPolicy(namedDescriptorsNative, policy, walletKeys);\n  return toDescriptorMap(namedDescriptorsNative);\n}\n\nexport function getPolicyForEnv(env: EnvironmentName): DescriptorValidationPolicy {\n  switch (env) {\n    case 'adminProd':\n    case 'prod':\n      return getValidatorSome([\n        // allow 2-of-3-ish descriptor groups where the keys match the wallet keys\n        getValidatorDescriptorTemplate('Wsh2Of3'),\n        // allow descriptor groups where all keys match the wallet keys plus OP_DROP (coredao staking)\n        getValidatorDescriptorTemplate('Wsh2Of3CltvDrop'),\n        // allow all descriptors signed by the user key\n        getValidatorSignedByUserKey(),\n      ]);\n    default:\n      return policyAllowAll;\n  }\n}\n"]}

Выполнить команду


Для локальной разработки. Не используйте в интернете!