myrtex-mf-signer 1.1.53 → 1.1.55
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/esm2020/lib/providers/crypto.provider.mjs +1 -1
- package/esm2020/lib/services/cryptopro/crypto.pro.async.service.mjs +1 -1
- package/esm2020/lib/services/cryptopro/crypto.pro.base.service.mjs +24 -22
- package/esm2020/lib/services/cryptopro/crypto.pro.ts.service.mjs +1 -1
- package/fesm2015/myrtex-mf-signer.mjs +23 -21
- package/fesm2015/myrtex-mf-signer.mjs.map +1 -1
- package/fesm2020/myrtex-mf-signer.mjs +23 -21
- package/fesm2020/myrtex-mf-signer.mjs.map +1 -1
- package/lib/providers/crypto.provider.d.ts +7 -0
- package/lib/services/cryptopro/crypto.pro.base.service.d.ts +1 -0
- package/lib/services/cryptopro/crypto.pro.ts.service.d.ts +7 -0
- package/package.json +1 -1
|
@@ -125,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
|
|
|
125
125
|
providedIn: 'root'
|
|
126
126
|
}]
|
|
127
127
|
}], ctorParameters: function () { return [{ type: i1.SimpleModalService }, { type: i2.CryptoService }, { type: i3.CryptoApiService }]; } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crypto.provider.js","sourceRoot":"","sources":["../../../../../projects/myrtex-mf-signer/src/lib/providers/crypto.provider.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Base64 } from 'js-base64';\nimport { SimpleModalService } from 'ngx-simple-modal';\nimport { ISignProvider, SignOptions } from './interfaces/isign.provider';\nimport { CryptoService } from '../services/crypto.service';\nimport { CryptoProAsyncService } from '../services/cryptopro/crypto.pro.async.service';\nimport { CertificateSelectComponent } from '../components/certificate-select/certificate-select.component';\nimport { CryptoApiService } from '../services/crypto.api.service';\nimport { SignedResultModel } from '../models';\nimport { strippingCharacters } from '../helpers/strippingCharacters';\n\ndeclare const window: any;\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class CryptoProvider implements ISignProvider {\n\n  constructor(private simpleModalService: SimpleModalService,\n              private cryptoService: CryptoService,\n              private cryptoApiService: CryptoApiService) {\n  }\n\n  public async sign(data: string, options?: SignOptions): Promise<SignedResultModel> {\n    const withLog = options?.withLog;\n    await this.cryptoService.startUp(withLog);\n\n    const service = await this.cryptoService.getService<CryptoProAsyncService>(CryptoProAsyncService.key);\n    const list = await service.getCertificates({\n      certificateCheck: options?.certificateCheck\n    });\n\n    if (list.length === 0) {\n      return Promise.reject('Отсутствует подходящий сертификат');\n    }\n\n    const modalResult = await this.simpleModalService\n      .addModal(CertificateSelectComponent, {certificates: list}).toPromise();\n\n    if (!modalResult.selected) {\n      if (withLog) {\n        console.log('Сертификат не выбран, отмена');\n      }\n      return Promise.reject();\n    }\n\n    let certificateFail = 0;\n    if (window.CRYPTO_SKIP_CHECK !== true) {\n      if (options?.certificateCheck?.fio &&\n        modalResult.selected.fio.toLowerCase() !== options?.certificateCheck?.fio.toLowerCase()) {\n        certificateFail = 1;\n      }\n\n      if (options?.certificateCheck?.fullName || options?.certificateCheck?.shortName) {\n        let organization = modalResult.selected.organization;\n\n        if (!organization) {\n          organization = modalResult.selected.cn;\n        }\n\n        if (organization) {\n          const orgIsValid = (options?.certificateCheck?.fullName &&\n              strippingCharacters(organization) == strippingCharacters(options?.certificateCheck?.fullName))\n            || (options?.certificateCheck?.shortName &&\n              strippingCharacters(organization) == strippingCharacters(options?.certificateCheck?.shortName));\n          if (!orgIsValid) {\n            certificateFail = 2;\n          }\n        } else {\n          certificateFail = 2;\n        }\n      }\n\n      /** @deprecated */\n      if (options?.checkFio &&\n        modalResult.selected.fio.toLowerCase() !== options?.checkFio.toLowerCase()) {\n        certificateFail = 1;\n      }\n\n      if (options?.checkOrganizationFullName || options?.checkOrganizationShortName) {\n        let organization = modalResult.selected.organization;\n\n        if (!organization) {\n          organization = modalResult.selected.cn;\n        }\n\n        if (organization) {\n          const orgIsValid = (options?.checkOrganizationFullName &&\n              strippingCharacters(organization) == strippingCharacters(options?.checkOrganizationFullName))\n            || (options?.checkOrganizationShortName &&\n              strippingCharacters(organization) == strippingCharacters(options?.checkOrganizationShortName));\n          if (!orgIsValid) {\n            certificateFail = 2;\n          }\n        } else {\n          certificateFail = 2;\n        }\n      }\n    }\n\n    if (certificateFail > 0) {\n      return Promise.reject(\n        certificateFail == 1 ?\n          'Данные лица, подписывающего заявку не совпадают с данными усиленной квалифицированной подписи.' :\n          certificateFail === 3 ? 'Отсутствует активный КриптоПровайдер (не установлен либо недоступен плагин). ' +\n            'Чтобы подписать, установите плагин КриптоПро и проверьте наличие сертификата' :\n            'Данные организации не совпадают с данными усиленной квалифицированной подписи. ' +\n            'Убедитесь, что вы используете сертификат, выданные от организации.',\n      );\n    }\n\n    if (withLog) {\n      console.log('Подписываемые данные', data);\n    }\n\n    const signedData = await service.signBase64(modalResult.selected.certificate, data, true);\n\n    if (withLog) {\n      console.log('Подписанные данные', signedData);\n    }\n\n    if (!options?.skipServerCheck) {\n      const verifyResult = await this.cryptoApiService.verify({\n        data: data,\n        signature: Base64.encode(signedData),\n        detached: true\n      }).toPromise();\n\n      return {\n        data,\n        success: verifyResult.success,\n        signed: signedData,\n        certificate: modalResult.selected,\n      };\n    } else {\n      return {\n        data,\n        success: true,\n        signed: signedData,\n        certificate: modalResult.selected,\n      };\n    }\n  }\n}\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crypto.provider.js","sourceRoot":"","sources":["../../../../../projects/myrtex-mf-signer/src/lib/providers/crypto.provider.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Base64 } from 'js-base64';\nimport { SimpleModalService } from 'ngx-simple-modal';\nimport { ISignProvider, SignOptions } from './interfaces/isign.provider';\nimport { CryptoService } from '../services/crypto.service';\nimport { CryptoProAsyncService } from '../services/cryptopro/crypto.pro.async.service';\nimport { CertificateSelectComponent } from '../components/certificate-select/certificate-select.component';\nimport { CryptoApiService } from '../services/crypto.api.service';\nimport { SignedResultModel } from '../models';\nimport { strippingCharacters } from '../helpers/strippingCharacters';\nimport { Async } from 'cadesplugin-types';\n\ndeclare global {\n  interface Window {\n    cadesplugin: Async.IWebClassFactory;\n    CRYPTO_SKIP_CHECK?: boolean;\n  }\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class CryptoProvider implements ISignProvider {\n\n  constructor(private simpleModalService: SimpleModalService,\n              private cryptoService: CryptoService,\n              private cryptoApiService: CryptoApiService) {\n  }\n\n  public async sign(data: string, options?: SignOptions): Promise<SignedResultModel> {\n    const withLog = options?.withLog;\n    await this.cryptoService.startUp(withLog);\n\n    const service = await this.cryptoService.getService<CryptoProAsyncService>(CryptoProAsyncService.key);\n    const list = await service.getCertificates({\n      certificateCheck: options?.certificateCheck\n    });\n\n    if (list.length === 0) {\n      return Promise.reject('Отсутствует подходящий сертификат');\n    }\n\n    const modalResult = await this.simpleModalService\n      .addModal(CertificateSelectComponent, {certificates: list}).toPromise();\n\n    if (!modalResult.selected) {\n      if (withLog) {\n        console.log('Сертификат не выбран, отмена');\n      }\n      return Promise.reject();\n    }\n\n    let certificateFail = 0;\n    if (window.CRYPTO_SKIP_CHECK !== true) {\n      if (options?.certificateCheck?.fio &&\n        modalResult.selected.fio.toLowerCase() !== options?.certificateCheck?.fio.toLowerCase()) {\n        certificateFail = 1;\n      }\n\n      if (options?.certificateCheck?.fullName || options?.certificateCheck?.shortName) {\n        let organization = modalResult.selected.organization;\n\n        if (!organization) {\n          organization = modalResult.selected.cn;\n        }\n\n        if (organization) {\n          const orgIsValid = (options?.certificateCheck?.fullName &&\n              strippingCharacters(organization) == strippingCharacters(options?.certificateCheck?.fullName))\n            || (options?.certificateCheck?.shortName &&\n              strippingCharacters(organization) == strippingCharacters(options?.certificateCheck?.shortName));\n          if (!orgIsValid) {\n            certificateFail = 2;\n          }\n        } else {\n          certificateFail = 2;\n        }\n      }\n\n      /** @deprecated */\n      if (options?.checkFio &&\n        modalResult.selected.fio.toLowerCase() !== options?.checkFio.toLowerCase()) {\n        certificateFail = 1;\n      }\n\n      if (options?.checkOrganizationFullName || options?.checkOrganizationShortName) {\n        let organization = modalResult.selected.organization;\n\n        if (!organization) {\n          organization = modalResult.selected.cn;\n        }\n\n        if (organization) {\n          const orgIsValid = (options?.checkOrganizationFullName &&\n              strippingCharacters(organization) == strippingCharacters(options?.checkOrganizationFullName))\n            || (options?.checkOrganizationShortName &&\n              strippingCharacters(organization) == strippingCharacters(options?.checkOrganizationShortName));\n          if (!orgIsValid) {\n            certificateFail = 2;\n          }\n        } else {\n          certificateFail = 2;\n        }\n      }\n    }\n\n    if (certificateFail > 0) {\n      return Promise.reject(\n        certificateFail == 1 ?\n          'Данные лица, подписывающего заявку не совпадают с данными усиленной квалифицированной подписи.' :\n          certificateFail === 3 ? 'Отсутствует активный КриптоПровайдер (не установлен либо недоступен плагин). ' +\n            'Чтобы подписать, установите плагин КриптоПро и проверьте наличие сертификата' :\n            'Данные организации не совпадают с данными усиленной квалифицированной подписи. ' +\n            'Убедитесь, что вы используете сертификат, выданные от организации.',\n      );\n    }\n\n    if (withLog) {\n      console.log('Подписываемые данные', data);\n    }\n\n    const signedData = await service.signBase64(modalResult.selected.certificate, data, true);\n\n    if (withLog) {\n      console.log('Подписанные данные', signedData);\n    }\n\n    if (!options?.skipServerCheck) {\n      const verifyResult = await this.cryptoApiService.verify({\n        data: data,\n        signature: Base64.encode(signedData),\n        detached: true\n      }).toPromise();\n\n      return {\n        data,\n        success: verifyResult.success,\n        signed: signedData,\n        certificate: modalResult.selected,\n      };\n    } else {\n      return {\n        data,\n        success: true,\n        signed: signedData,\n        certificate: modalResult.selected,\n      };\n    }\n  }\n}\n"]}
|
|
@@ -27,4 +27,4 @@ export class CryptoProAsyncService extends CryptoProBaseService {
|
|
|
27
27
|
}
|
|
28
28
|
}
|
|
29
29
|
CryptoProAsyncService.key = 'cryptoproasync';
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3J5cHRvLnByby5hc3luYy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGV4LW1mLXNpZ25lci9zcmMvbGliL3NlcnZpY2VzL2NyeXB0b3Byby9jcnlwdG8ucHJvLmFzeW5jLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0EsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFakUsTUFBTSxPQUFPLHFCQUFzQixTQUFRLG9CQUFvQjtJQUk3RDtRQUNFLEtBQUssRUFBRSxDQUFDO0lBQ1YsQ0FBQztJQUVNLEtBQUssQ0FBQyxPQUFPLENBQUMsV0FBZ0IsRUFBRSxJQUFZO1FBQ2pELElBQUksTUFBTSxHQUFxQixNQUFNLE1BQU0sQ0FBQyxXQUFXLENBQUMsaUJBQWlCLG9DQUFrQixDQUFDO1FBQzVGLE1BQU0sTUFBTSxDQUFDLG1CQUFtQixDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRTlDLElBQUkscUJBQXFCLEdBQUcsd0NBQXdDLENBQUM7UUFDckUsTUFBTSxNQUFNLENBQUMsa0JBQWtCLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQUV2RCxJQUFJLE1BQU0sR0FBcUIsTUFBTSxNQUFNLENBQUMsV0FBVyxDQUFDLGlCQUFpQixzQ0FBbUIsQ0FBQztRQUU3RixJQUFJLFVBQVUsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMxRCxNQUFNLE1BQU0sQ0FBQyxlQUFlLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFekMsSUFBSSxrQ0FBa0MsR0FBRyxFQUFFLENBQUM7UUFDNUMsTUFBTSxNQUFNLENBQUMscUJBQXFCLENBQUMsa0NBQWtDLENBQUMsQ0FBQztRQUV2RSxNQUFNLFVBQVUsR0FBRyxNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFN0MsT0FBTyxVQUFVLENBQUM7SUFDcEIsQ0FBQztJQUVNLEtBQUssQ0FBQyxVQUFVLENBQUMsV0FBZ0IsRUFBRSxJQUFZLEVBQUUsV0FBb0IsS0FBSztRQUMvRSxJQUFJLE1BQU0sR0FBcUIsTUFBTSxNQUFNLENBQUMsV0FBVyxDQUFDLGlCQUFpQixvQ0FBa0IsQ0FBQztRQUM1RixNQUFNLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUU5QyxJQUFJLE1BQU0sR0FBeUIsTUFBTSxNQUFNLENBQUMsV0FBVyxDQUFDLGlCQUFpQixrREFBeUIsQ0FBQztRQUV2RyxNQUFNLE1BQU0sQ0FBQyx1QkFBdUIsbUNBQTBELENBQUM7UUFDL0YsTUFBTSxNQUFNLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRW5DLE1BQU0sVUFBVSxHQUFHLE1BQU0sTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNLDhCQUEwQyxRQUFRLENBQUMsQ0FBQztRQUVwRyxPQUFPLFVBQVUsQ0FBQztJQUNwQixDQUFDOztBQXRDc0IseUJBQUcsR0FBRyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFzeW5jLFxuICBDQURFU0NPTV9DQURFU19UWVBFLFxuICBDQURFU0NPTV9DT05URU5UX0VOQ09ESU5HX1RZUEUsXG4gIENBREVTQ09NX1NUT1JFX0xPQ0FUSU9OLCBDQVBJQ09NX1NUT1JFX05BTUVTLCBDQVBJQ09NX1NUT1JFX09QRU5fTU9ERSxcbiAgUHJvZ0lkc1xufSBmcm9tICdjYWRlc3BsdWdpbi10eXBlcyc7XG5pbXBvcnQgeyBDcnlwdG9Qcm9CYXNlU2VydmljZSB9IGZyb20gJy4vY3J5cHRvLnByby5iYXNlLnNlcnZpY2UnO1xuXG5leHBvcnQgY2xhc3MgQ3J5cHRvUHJvQXN5bmNTZXJ2aWNlIGV4dGVuZHMgQ3J5cHRvUHJvQmFzZVNlcnZpY2Uge1xuXG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkga2V5ID0gJ2NyeXB0b3Byb2FzeW5jJztcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIHNpZ25YbWwoY2VydGlmaWNhdGU6IGFueSwgZGF0YTogc3RyaW5nKTogUHJvbWlzZTxzdHJpbmc+
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3J5cHRvLnByby5hc3luYy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGV4LW1mLXNpZ25lci9zcmMvbGliL3NlcnZpY2VzL2NyeXB0b3Byby9jcnlwdG8ucHJvLmFzeW5jLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0EsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFakUsTUFBTSxPQUFPLHFCQUFzQixTQUFRLG9CQUFvQjtJQUk3RDtRQUNFLEtBQUssRUFBRSxDQUFDO0lBQ1YsQ0FBQztJQUVNLEtBQUssQ0FBQyxPQUFPLENBQUMsV0FBZ0IsRUFBRSxJQUFZO1FBQ2pELElBQUksTUFBTSxHQUFxQixNQUFNLE1BQU0sQ0FBQyxXQUFXLENBQUMsaUJBQWlCLG9DQUFrQixDQUFDO1FBQzVGLE1BQU0sTUFBTSxDQUFDLG1CQUFtQixDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRTlDLElBQUkscUJBQXFCLEdBQUcsd0NBQXdDLENBQUM7UUFDckUsTUFBTSxNQUFNLENBQUMsa0JBQWtCLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQUV2RCxJQUFJLE1BQU0sR0FBcUIsTUFBTSxNQUFNLENBQUMsV0FBVyxDQUFDLGlCQUFpQixzQ0FBbUIsQ0FBQztRQUU3RixJQUFJLFVBQVUsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMxRCxNQUFNLE1BQU0sQ0FBQyxlQUFlLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFekMsSUFBSSxrQ0FBa0MsR0FBRyxFQUFFLENBQUM7UUFDNUMsTUFBTSxNQUFNLENBQUMscUJBQXFCLENBQUMsa0NBQWtDLENBQUMsQ0FBQztRQUV2RSxNQUFNLFVBQVUsR0FBRyxNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFN0MsT0FBTyxVQUFVLENBQUM7SUFDcEIsQ0FBQztJQUVNLEtBQUssQ0FBQyxVQUFVLENBQUMsV0FBZ0IsRUFBRSxJQUFZLEVBQUUsV0FBb0IsS0FBSztRQUMvRSxJQUFJLE1BQU0sR0FBcUIsTUFBTSxNQUFNLENBQUMsV0FBVyxDQUFDLGlCQUFpQixvQ0FBa0IsQ0FBQztRQUM1RixNQUFNLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUU5QyxJQUFJLE1BQU0sR0FBeUIsTUFBTSxNQUFNLENBQUMsV0FBVyxDQUFDLGlCQUFpQixrREFBeUIsQ0FBQztRQUV2RyxNQUFNLE1BQU0sQ0FBQyx1QkFBdUIsbUNBQTBELENBQUM7UUFDL0YsTUFBTSxNQUFNLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRW5DLE1BQU0sVUFBVSxHQUFHLE1BQU0sTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNLDhCQUEwQyxRQUFRLENBQUMsQ0FBQztRQUVwRyxPQUFPLFVBQVUsQ0FBQztJQUNwQixDQUFDOztBQXRDc0IseUJBQUcsR0FBRyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFzeW5jLFxuICBDQURFU0NPTV9DQURFU19UWVBFLFxuICBDQURFU0NPTV9DT05URU5UX0VOQ09ESU5HX1RZUEUsXG4gIENBREVTQ09NX1NUT1JFX0xPQ0FUSU9OLCBDQVBJQ09NX1NUT1JFX05BTUVTLCBDQVBJQ09NX1NUT1JFX09QRU5fTU9ERSxcbiAgUHJvZ0lkc1xufSBmcm9tICdjYWRlc3BsdWdpbi10eXBlcyc7XG5pbXBvcnQgeyBDcnlwdG9Qcm9CYXNlU2VydmljZSB9IGZyb20gJy4vY3J5cHRvLnByby5iYXNlLnNlcnZpY2UnO1xuXG5leHBvcnQgY2xhc3MgQ3J5cHRvUHJvQXN5bmNTZXJ2aWNlIGV4dGVuZHMgQ3J5cHRvUHJvQmFzZVNlcnZpY2Uge1xuXG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkga2V5ID0gJ2NyeXB0b3Byb2FzeW5jJztcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIHNpZ25YbWwoY2VydGlmaWNhdGU6IGFueSwgZGF0YTogc3RyaW5nKTogUHJvbWlzZTxzdHJpbmc+IHtcbiAgICBsZXQgc2lnbmVyOiBBc3luYy5JQ1BTaWduZXI2ID0gYXdhaXQgd2luZG93LmNhZGVzcGx1Z2luLkNyZWF0ZU9iamVjdEFzeW5jKFByb2dJZHMuQ1BTaWduZXIpO1xuICAgIGF3YWl0IHNpZ25lci5wcm9wc2V0X0NlcnRpZmljYXRlKGNlcnRpZmljYXRlKTtcblxuICAgIGxldCB0aW1lc3RhbXBfc2VydmljZV91cmwgPSAnaHR0cDovL3Rlc3RjYS5jcnlwdG9wcm8ucnUvdHNwL3RzcC5zcmYnO1xuICAgIGF3YWl0IHNpZ25lci5wcm9wc2V0X1RTQUFkZHJlc3ModGltZXN0YW1wX3NlcnZpY2VfdXJsKTtcblxuICAgIGxldCBzaWduZWQ6IEFzeW5jLklTaWduZWRYTUwgPSBhd2FpdCB3aW5kb3cuY2FkZXNwbHVnaW4uQ3JlYXRlT2JqZWN0QXN5bmMoUHJvZ0lkcy5TaWduZWRYTUwpO1xuXG4gICAgbGV0IGVuY29kZWRYbWwgPSBidG9hKHVuZXNjYXBlKGVuY29kZVVSSUNvbXBvbmVudChkYXRhKSkpO1xuICAgIGF3YWl0IHNpZ25lZC5wcm9wc2V0X0NvbnRlbnQoZW5jb2RlZFhtbCk7XG5cbiAgICBsZXQgY2FkZXNfeG1sX3NpZ25hdHVyZV90eXBlX2VudmVsb3BlZCA9IDgwO1xuICAgIGF3YWl0IHNpZ25lZC5wcm9wc2V0X1NpZ25hdHVyZVR5cGUoY2FkZXNfeG1sX3NpZ25hdHVyZV90eXBlX2VudmVsb3BlZCk7XG5cbiAgICBjb25zdCBzaWduZWREYXRhID0gYXdhaXQgc2lnbmVkLlNpZ24oc2lnbmVyKTtcblxuICAgIHJldHVybiBzaWduZWREYXRhO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIHNpZ25CYXNlNjQoY2VydGlmaWNhdGU6IGFueSwgZGF0YTogc3RyaW5nLCBkZXRhY2hlZDogYm9vbGVhbiA9IGZhbHNlKTogUHJvbWlzZTxzdHJpbmc+IHtcbiAgICBsZXQgc2lnbmVyOiBBc3luYy5JQ1BTaWduZXI2ID0gYXdhaXQgd2luZG93LmNhZGVzcGx1Z2luLkNyZWF0ZU9iamVjdEFzeW5jKFByb2dJZHMuQ1BTaWduZXIpO1xuICAgIGF3YWl0IHNpZ25lci5wcm9wc2V0X0NlcnRpZmljYXRlKGNlcnRpZmljYXRlKTtcblxuICAgIGxldCBzaWduZWQ6IEFzeW5jLklDUFNpZ25lZERhdGE1ID0gYXdhaXQgd2luZG93LmNhZGVzcGx1Z2luLkNyZWF0ZU9iamVjdEFzeW5jKFByb2dJZHMuQ2FkZXNTaWduZWREYXRhKTtcblxuICAgIGF3YWl0IHNpZ25lZC5wcm9wc2V0X0NvbnRlbnRFbmNvZGluZyhDQURFU0NPTV9DT05URU5UX0VOQ09ESU5HX1RZUEUuQ0FERVNDT01fQkFTRTY0X1RPX0JJTkFSWSk7XG4gICAgYXdhaXQgc2lnbmVkLnByb3BzZXRfQ29udGVudChkYXRhKTtcblxuICAgIGNvbnN0IHNpZ25lZERhdGEgPSBhd2FpdCBzaWduZWQuU2lnbkNhZGVzKHNpZ25lciwgQ0FERVNDT01fQ0FERVNfVFlQRS5DQURFU0NPTV9DQURFU19CRVMsIGRldGFjaGVkKTtcblxuICAgIHJldHVybiBzaWduZWREYXRhO1xuICB9XG59XG4iXX0=
|
|
@@ -43,34 +43,36 @@ export class CryptoProBaseService extends CryptoBaseService {
|
|
|
43
43
|
isExpired: validToDate < new Date()
|
|
44
44
|
};
|
|
45
45
|
let filterOk = true;
|
|
46
|
-
if (
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
46
|
+
if (window.CRYPTO_SKIP_CHECK !== true) {
|
|
47
|
+
if (filter?.certificateCheck?.signerType === SignerTypeEnum.FL) {
|
|
48
|
+
filterOk = !certificate.ogrn;
|
|
49
|
+
}
|
|
50
|
+
else if ([SignerTypeEnum.UL, SignerTypeEnum.IP]
|
|
51
|
+
.indexOf(filter?.certificateCheck?.signerType || SignerTypeEnum.Unknown) > -1) {
|
|
52
|
+
filterOk = certificate.ogrn ? true : false;
|
|
53
|
+
if (filterOk) {
|
|
54
|
+
const organization = certificate.organization || certificate.cn;
|
|
55
|
+
if (organization) {
|
|
56
|
+
const orgIsValid = (filter?.certificateCheck?.fullName &&
|
|
57
|
+
strippingCharacters(organization) == strippingCharacters(filter?.certificateCheck?.fullName))
|
|
58
|
+
|| (filter?.certificateCheck?.shortName &&
|
|
59
|
+
strippingCharacters(organization) == strippingCharacters(filter?.certificateCheck?.shortName));
|
|
60
|
+
if (!orgIsValid) {
|
|
61
|
+
filterOk = false;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
60
65
|
filterOk = false;
|
|
61
66
|
}
|
|
62
67
|
}
|
|
63
|
-
|
|
68
|
+
}
|
|
69
|
+
if (filterOk && filter?.certificateCheck?.signerType) {
|
|
70
|
+
const fio = certificate.fio.toLowerCase();
|
|
71
|
+
if (filter?.certificateCheck?.fio?.toLocaleLowerCase() !== fio) {
|
|
64
72
|
filterOk = false;
|
|
65
73
|
}
|
|
66
74
|
}
|
|
67
75
|
}
|
|
68
|
-
if (filterOk && filter?.certificateCheck?.signerType) {
|
|
69
|
-
const fio = certificate.fio.toLowerCase();
|
|
70
|
-
if (filter?.certificateCheck?.fio?.toLocaleLowerCase() !== fio) {
|
|
71
|
-
filterOk = false;
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
76
|
if (filterOk) {
|
|
75
77
|
certificates.push(certificate);
|
|
76
78
|
}
|
|
@@ -79,4 +81,4 @@ export class CryptoProBaseService extends CryptoBaseService {
|
|
|
79
81
|
return certificates;
|
|
80
82
|
}
|
|
81
83
|
}
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crypto.pro.base.service.js","sourceRoot":"","sources":["../../../../../../projects/myrtex-mf-signer/src/lib/services/cryptopro/crypto.pro.base.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CADESCOM_STORE_LOCATION,\n  CAPICOM_STORE_NAMES,\n  CAPICOM_STORE_OPEN_MODE,\n  ProgIds,\n  Async\n} from 'cadesplugin-types';\nimport { CertificateCheck, CertificateModel } from '../../models';\n// @ts-ignore\nimport getCadesplugin from 'async-cadesplugin';\nimport { CryptoBaseService } from '../crypto.base.service';\nimport { CertificateAdjuster } from '../certificate.adjuster';\nimport { SignerTypeEnum } from '../../enums/signer-type.enum';\nimport { strippingCharacters } from '../../helpers/strippingCharacters';\n\ndeclare global {\n  interface Window {\n    cadesplugin: Async.IWebClassFactory;\n  }\n}\n\ninterface CertificateFilter {\n  certificateCheck?: CertificateCheck;\n}\n\ninterface Certificate {\n  id: number;\n  certificate: any;\n  subjectName: string;\n  name: string;\n  cn: string;\n  fio: string;\n  post: string;\n  ogrn: string;\n  organization: string;\n  inn: string;\n  validFromDate: string;\n  validToDate: string;\n  thumbprint: string;\n  issuerName: string;\n  serialNumber: string;\n  isExpired: boolean;\n}\n\nexport class CryptoProBaseService extends CryptoBaseService {\n\n  constructor() {\n    super();\n  }\n\n  public async init(): Promise<CryptoBaseService> {\n    await getCadesplugin();\n    return Promise.resolve(this);\n  };\n\n  public async getCertificates(filter?: CertificateFilter): Promise<CertificateModel[]> {\n    const store = await window.cadesplugin.CreateObjectAsync(ProgIds.Store);\n    await store.Open(CADESCOM_STORE_LOCATION.CAPICOM_CURRENT_USER_STORE, CAPICOM_STORE_NAMES.CAPICOM_MY_STORE,\n      CAPICOM_STORE_OPEN_MODE.CAPICOM_STORE_OPEN_MAXIMUM_ALLOWED);\n\n    let storeCerts = await store.Certificates;\n    let count = await storeCerts.Count;\n    let certificates: Array<CertificateModel> = [];\n\n    for (let i = 1; i <= count; i++) {\n      let cert = await storeCerts.Item(i);\n      let validFromDate = new Date(await cert.ValidFromDate);\n      let validToDate = new Date(await cert.ValidToDate);\n      const subjectName = await cert.SubjectName;\n\n      const certificate: Certificate = {\n        id: i,\n        certificate: cert,\n        subjectName: subjectName,\n        name: CertificateAdjuster.getCertInfoString(subjectName, validFromDate),\n        cn: CertificateAdjuster.getCertName(subjectName),\n        fio: CertificateAdjuster.getCertFio(subjectName),\n        post: CertificateAdjuster.getCertPost(subjectName),\n        ogrn: CertificateAdjuster.getCertOgrn(subjectName),\n        organization: CertificateAdjuster.getCertOrg(subjectName),\n        inn: CertificateAdjuster.getCertInn(subjectName),\n        validFromDate: validFromDate.toLocaleDateString('ru-RU'),\n        validToDate: validToDate.toLocaleDateString('ru-RU'),\n        thumbprint: await cert.Thumbprint,\n        issuerName: await cert.IssuerName,\n        serialNumber: await cert.SerialNumber,\n        isExpired: validToDate < new Date()\n      };\n\n      let filterOk = true;\n      if (filter?.certificateCheck?.signerType === SignerTypeEnum.FL) {\n        filterOk = !certificate.ogrn;\n      } else if ([SignerTypeEnum.UL, SignerTypeEnum.IP]\n        .indexOf(filter?.certificateCheck?.signerType || SignerTypeEnum.Unknown) > -1) {\n        filterOk = certificate.ogrn ? true : false;\n        if (filterOk) {\n          const organization = certificate.organization || certificate.cn;\n\n          if (organization) {\n            const orgIsValid = (filter?.certificateCheck?.fullName &&\n                strippingCharacters(organization) == strippingCharacters(filter?.certificateCheck?.fullName))\n              || (filter?.certificateCheck?.shortName &&\n                strippingCharacters(organization) == strippingCharacters(filter?.certificateCheck?.shortName));\n            if (!orgIsValid) {\n              filterOk = false;\n            }\n          } else {\n            filterOk = false;\n          }\n        }\n      }\n\n      if (filterOk && filter?.certificateCheck?.signerType) {\n        const fio = certificate.fio.toLowerCase();\n\n        if (filter?.certificateCheck?.fio?.toLocaleLowerCase() !== fio) {\n          filterOk = false;\n        }\n      }\n\n      if (filterOk) {\n        certificates.push(certificate);\n      }\n    }\n\n    await store.Close();\n    return certificates;\n  }\n}\n"]}
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crypto.pro.base.service.js","sourceRoot":"","sources":["../../../../../../projects/myrtex-mf-signer/src/lib/services/cryptopro/crypto.pro.base.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Async,\n  CADESCOM_STORE_LOCATION,\n  CAPICOM_STORE_NAMES,\n  CAPICOM_STORE_OPEN_MODE,\n  ProgIds\n} from 'cadesplugin-types';\nimport { CertificateCheck, CertificateModel } from '../../models';\n// @ts-ignore\nimport getCadesplugin from 'async-cadesplugin';\nimport { CryptoBaseService } from '../crypto.base.service';\nimport { CertificateAdjuster } from '../certificate.adjuster';\nimport { SignerTypeEnum } from '../../enums/signer-type.enum';\nimport { strippingCharacters } from '../../helpers/strippingCharacters';\n\ndeclare global {\n  interface Window {\n    cadesplugin: Async.IWebClassFactory;\n    CRYPTO_SKIP_CHECK?: boolean;\n  }\n}\n\ninterface CertificateFilter {\n  certificateCheck?: CertificateCheck;\n}\n\ninterface Certificate {\n  id: number;\n  certificate: any;\n  subjectName: string;\n  name: string;\n  cn: string;\n  fio: string;\n  post: string;\n  ogrn: string;\n  organization: string;\n  inn: string;\n  validFromDate: string;\n  validToDate: string;\n  thumbprint: string;\n  issuerName: string;\n  serialNumber: string;\n  isExpired: boolean;\n}\n\nexport class CryptoProBaseService extends CryptoBaseService {\n\n  constructor() {\n    super();\n  }\n\n  public async init(): Promise<CryptoBaseService> {\n    await getCadesplugin();\n    return Promise.resolve(this);\n  };\n\n  public async getCertificates(filter?: CertificateFilter): Promise<CertificateModel[]> {\n    const store = await window.cadesplugin.CreateObjectAsync(ProgIds.Store);\n    await store.Open(CADESCOM_STORE_LOCATION.CAPICOM_CURRENT_USER_STORE, CAPICOM_STORE_NAMES.CAPICOM_MY_STORE,\n      CAPICOM_STORE_OPEN_MODE.CAPICOM_STORE_OPEN_MAXIMUM_ALLOWED);\n\n    let storeCerts = await store.Certificates;\n    let count = await storeCerts.Count;\n    let certificates: Array<CertificateModel> = [];\n\n    for (let i = 1; i <= count; i++) {\n      let cert = await storeCerts.Item(i);\n      let validFromDate = new Date(await cert.ValidFromDate);\n      let validToDate = new Date(await cert.ValidToDate);\n      const subjectName = await cert.SubjectName;\n\n      const certificate: Certificate = {\n        id: i,\n        certificate: cert,\n        subjectName: subjectName,\n        name: CertificateAdjuster.getCertInfoString(subjectName, validFromDate),\n        cn: CertificateAdjuster.getCertName(subjectName),\n        fio: CertificateAdjuster.getCertFio(subjectName),\n        post: CertificateAdjuster.getCertPost(subjectName),\n        ogrn: CertificateAdjuster.getCertOgrn(subjectName),\n        organization: CertificateAdjuster.getCertOrg(subjectName),\n        inn: CertificateAdjuster.getCertInn(subjectName),\n        validFromDate: validFromDate.toLocaleDateString('ru-RU'),\n        validToDate: validToDate.toLocaleDateString('ru-RU'),\n        thumbprint: await cert.Thumbprint,\n        issuerName: await cert.IssuerName,\n        serialNumber: await cert.SerialNumber,\n        isExpired: validToDate < new Date()\n      };\n\n      let filterOk = true;\n      if (window.CRYPTO_SKIP_CHECK !== true) {\n        if (filter?.certificateCheck?.signerType === SignerTypeEnum.FL) {\n          filterOk = !certificate.ogrn;\n        } else if ([SignerTypeEnum.UL, SignerTypeEnum.IP]\n          .indexOf(filter?.certificateCheck?.signerType || SignerTypeEnum.Unknown) > -1) {\n          filterOk = certificate.ogrn ? true : false;\n          if (filterOk) {\n            const organization = certificate.organization || certificate.cn;\n\n            if (organization) {\n              const orgIsValid = (filter?.certificateCheck?.fullName &&\n                strippingCharacters(organization) == strippingCharacters(filter?.certificateCheck?.fullName))\n                || (filter?.certificateCheck?.shortName &&\n                  strippingCharacters(organization) == strippingCharacters(filter?.certificateCheck?.shortName));\n              if (!orgIsValid) {\n                filterOk = false;\n              }\n            } else {\n              filterOk = false;\n            }\n          }\n        }\n\n        if (filterOk && filter?.certificateCheck?.signerType) {\n          const fio = certificate.fio.toLowerCase();\n\n          if (filter?.certificateCheck?.fio?.toLocaleLowerCase() !== fio) {\n            filterOk = false;\n          }\n        }\n      }\n\n      if (filterOk) {\n        certificates.push(certificate);\n      }\n    }\n\n    await store.Close();\n    return certificates;\n  }\n}\n"]}
|
|
@@ -47,4 +47,4 @@ export class CryptoProTsService extends CryptoProBaseService {
|
|
|
47
47
|
}
|
|
48
48
|
}
|
|
49
49
|
CryptoProTsService.key = 'cryptoprots';
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3J5cHRvLnByby50cy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGV4LW1mLXNpZ25lci9zcmMvbGliL3NlcnZpY2VzL2NyeXB0b3Byby9jcnlwdG8ucHJvLnRzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0EsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFTakUsTUFBTSxPQUFPLGtCQUFtQixTQUFRLG9CQUFvQjtJQUkxRDtRQUNFLEtBQUssRUFBRSxDQUFDO0lBQ1YsQ0FBQztJQUVELElBQVkscUJBQXFCO1FBQy9CLE9BQU8sd0NBQXdDLENBQUM7SUFDbEQsQ0FBQztJQUVNLEtBQUssQ0FBQyxJQUFJLENBQUMsV0FBZ0IsRUFBRSxJQUFZO1FBQzlDLE1BQU0sS0FBSyxHQUFHLE1BQU0sTUFBTSxDQUFDLFdBQVcsQ0FBQyxpQkFBaUIsOEJBQWUsQ0FBQztRQUN4RSxNQUFNLEtBQUssQ0FBQyxJQUFJLDZHQUM2QyxDQUFDO1FBRTlELElBQUksTUFBTSxHQUFxQixNQUFNLE1BQU0sQ0FBQyxXQUFXLENBQUMsaUJBQWlCLG9DQUFrQixDQUFDO1FBQzVGLE1BQU0sTUFBTSxDQUFDLG1CQUFtQixDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRTlDLElBQUksU0FBUyxHQUFxQixNQUFNLE1BQU0sQ0FBQyxXQUFXLENBQUMsaUJBQWlCLHNDQUFtQixDQUFDO1FBRWhHLElBQUksU0FBUyxHQUFxQixNQUFNLFdBQVcsQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUNoRSxJQUFJLFNBQVMsR0FBZSxNQUFNLFNBQVMsQ0FBQyxTQUFTLENBQUM7UUFDdEQsSUFBSSxZQUFZLEdBQUcsTUFBTSxTQUFTLENBQUMsS0FBSyxDQUFDO1FBRXpDLElBQUksRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFlBQVksQ0FBQyxDQUFDO1FBRXhFLDRFQUE0RTtRQUU1RSxNQUFNLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQUU1RCxJQUFJLElBQUksRUFBRTtZQUNSLElBQUksVUFBVSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzFELE1BQU0sU0FBUyxDQUFDLGVBQWUsQ0FBQyxVQUFVLENBQUMsQ0FBQztTQUM3QztRQUVELE1BQU0sU0FBUyxDQUFDLHFCQUFxQiwrQ0FBbUUsQ0FBQztRQUN6RyxNQUFNLFNBQVMsQ0FBQyx1QkFBdUIsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUNwRCxNQUFNLFNBQVMsQ0FBQyxvQkFBb0IsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUVuRCxJQUFJLFNBQVMsR0FBRyxNQUFNLFNBQVMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFN0MsTUFBTSxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7UUFFcEIsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVPLGlCQUFpQixDQUFDLFlBQW9CO1FBQzVDLElBQUksVUFBVSxHQUFHLEVBQUUsRUFBRSxZQUFZLEdBQUcsRUFBRSxDQUFDO1FBRXZDLElBQUksWUFBWSxJQUFJLG1CQUFtQixFQUFFLEVBQUksc0RBQXNEO1lBQ2pHLFVBQVUsR0FBRyw0RUFBNEUsQ0FBQztZQUMxRixZQUFZLEdBQUcsOERBQThELENBQUM7U0FDL0U7YUFBTSxJQUFJLFlBQVksSUFBSSxtQkFBbUIsRUFBRSxFQUFJLHNEQUFzRDtZQUN4RyxVQUFVLEdBQUcsNEVBQTRFLENBQUM7WUFDMUYsWUFBWSxHQUFHLDhEQUE4RCxDQUFDO1NBQy9FO2FBQU0sSUFBSSxZQUFZLElBQUksZ0JBQWdCLEVBQUUsRUFBRyw2QkFBNkI7WUFDM0UsVUFBVSxHQUFHLG9FQUFvRSxDQUFDO1lBQ2xGLFlBQVksR0FBRyxzREFBc0QsQ0FBQztTQUN2RTtRQUVELE9BQU8sRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLENBQUM7SUFDdEMsQ0FBQzs7QUE3RHNCLHNCQUFHLEdBQUcsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQXN5bmMsXG4gIENBREVTQ09NX1NUT1JFX0xPQ0FUSU9OLCBDQURFU0NPTV9YTUxfU0lHTkFUVVJFX1RZUEUsXG4gIENBUElDT01fU1RPUkVfTkFNRVMsXG4gIENBUElDT01fU1RPUkVfT1BFTl9NT0RFLFxuICBQcm9nSWRzXG59IGZyb20gJ2NhZGVzcGx1Z2luLXR5cGVzJztcbmltcG9ydCB7IENyeXB0b1Byb0Jhc2VTZXJ2aWNlIH0gZnJvbSAnLi9jcnlwdG8ucHJvLmJhc2Uuc2VydmljZSc7XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIFdpbmRvdyB7XG4gICAgY2FkZXNwbHVnaW46IEFzeW5jLklXZWJDbGFzc0ZhY3Rvcnk7XG4gICAgQ1JZUFRPX1NLSVBfQ0hFQ0s/OiBib29sZWFuO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBDcnlwdG9Qcm9Uc1NlcnZpY2UgZXh0ZW5kcyBDcnlwdG9Qcm9CYXNlU2VydmljZSB7XG5cbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBrZXkgPSAnY3J5cHRvcHJvdHMnO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCk7XG4gIH1cblxuICBwcml2YXRlIGdldCBUSU1FU1RBTVBfU0VSVklDRV9VUkwoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gJ2h0dHA6Ly90ZXN0Y2EuY3J5cHRvcHJvLnJ1L3RzcC90c3Auc3JmJztcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBzaWduKGNlcnRpZmljYXRlOiBhbnksIGRhdGE6IHN0cmluZyk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgY29uc3Qgc3RvcmUgPSBhd2FpdCB3aW5kb3cuY2FkZXNwbHVnaW4uQ3JlYXRlT2JqZWN0QXN5bmMoUHJvZ0lkcy5TdG9yZSk7XG4gICAgYXdhaXQgc3RvcmUuT3BlbihDQURFU0NPTV9TVE9SRV9MT0NBVElPTi5DQVBJQ09NX0NVUlJFTlRfVVNFUl9TVE9SRSwgQ0FQSUNPTV9TVE9SRV9OQU1FUy5DQVBJQ09NX01ZX1NUT1JFLFxuICAgICAgQ0FQSUNPTV9TVE9SRV9PUEVOX01PREUuQ0FQSUNPTV9TVE9SRV9PUEVOX01BWElNVU1fQUxMT1dFRCk7XG5cbiAgICBsZXQgc2lnbmVyOiBBc3luYy5JQ1BTaWduZXI2ID0gYXdhaXQgd2luZG93LmNhZGVzcGx1Z2luLkNyZWF0ZU9iamVjdEFzeW5jKFByb2dJZHMuQ1BTaWduZXIpO1xuICAgIGF3YWl0IHNpZ25lci5wcm9wc2V0X0NlcnRpZmljYXRlKGNlcnRpZmljYXRlKTtcblxuICAgIGxldCBzaWduZWRYTUw6IEFzeW5jLklTaWduZWRYTUwgPSBhd2FpdCB3aW5kb3cuY2FkZXNwbHVnaW4uQ3JlYXRlT2JqZWN0QXN5bmMoUHJvZ0lkcy5TaWduZWRYTUwpO1xuXG4gICAgbGV0IHB1YmxpY0tleTogQXN5bmMuSVB1YmxpY0tleSA9IGF3YWl0IGNlcnRpZmljYXRlLlB1YmxpY0tleSgpO1xuICAgIGxldCBhbGdvcml0aG06IEFzeW5jLklPSUQgPSBhd2FpdCBwdWJsaWNLZXkuQWxnb3JpdGhtO1xuICAgIGxldCBhbGdvcml0aG1PaWQgPSBhd2FpdCBhbGdvcml0aG0uVmFsdWU7XG5cbiAgICBsZXQgeyBzaWduTWV0aG9kLCBkaWdlc3RNZXRob2QgfSA9IHRoaXMuZ2V0U2lnbmluZ01ldGhvZHMoYWxnb3JpdGhtT2lkKTtcblxuICAgIC8vYXdhaXQgc2lnbmVyLnByb3BzZXRfT3B0aW9ucyhhcGkuQ0FQSUNPTV9DRVJUSUZJQ0FURV9JTkNMVURFX1dIT0xFX0NIQUlOKTtcblxuICAgIGF3YWl0IHNpZ25lci5wcm9wc2V0X1RTQUFkZHJlc3ModGhpcy5USU1FU1RBTVBfU0VSVklDRV9VUkwpO1xuXG4gICAgaWYgKGRhdGEpIHtcbiAgICAgIGxldCBlbmNvZGVkWG1sID0gYnRvYSh1bmVzY2FwZShlbmNvZGVVUklDb21wb25lbnQoZGF0YSkpKTtcbiAgICAgIGF3YWl0IHNpZ25lZFhNTC5wcm9wc2V0X0NvbnRlbnQoZW5jb2RlZFhtbCk7XG4gICAgfVxuXG4gICAgYXdhaXQgc2lnbmVkWE1MLnByb3BzZXRfU2lnbmF0dXJlVHlwZShDQURFU0NPTV9YTUxfU0lHTkFUVVJFX1RZUEUuQ0FERVNDT01fWE1MX1NJR05BVFVSRV9UWVBFX0VOVkVMT1BFRCk7XG4gICAgYXdhaXQgc2lnbmVkWE1MLnByb3BzZXRfU2lnbmF0dXJlTWV0aG9kKHNpZ25NZXRob2QpO1xuICAgIGF3YWl0IHNpZ25lZFhNTC5wcm9wc2V0X0RpZ2VzdE1ldGhvZChkaWdlc3RNZXRob2QpO1xuXG4gICAgbGV0IHNpZ25hdHVyZSA9IGF3YWl0IHNpZ25lZFhNTC5TaWduKHNpZ25lcik7XG5cbiAgICBhd2FpdCBzdG9yZS5DbG9zZSgpO1xuXG4gICAgcmV0dXJuIHNpZ25hdHVyZTtcbiAgfVxuXG4gIHByaXZhdGUgZ2V0U2lnbmluZ01ldGhvZHMoYWxnb3JpdGhtT2lkOiBzdHJpbmcpOiB7IHNpZ25NZXRob2Q6IHN0cmluZywgZGlnZXN0TWV0aG9kOiBzdHJpbmcgfSB7XG4gICAgbGV0IHNpZ25NZXRob2QgPSAnJywgZGlnZXN0TWV0aG9kID0gJyc7XG5cbiAgICBpZiAoYWxnb3JpdGhtT2lkID09ICcxLjIuNjQzLjcuMS4xLjEuMScpIHsgICAvLyDQsNC70LPQvtGA0LjRgtC8INC/0L7QtNC/0LjRgdC4INCT0J7QodCiINCgIDM0LjEwLTIwMTIg0YEg0LrQu9GO0YfQvtC8IDI1NiDQsdC40YJcbiAgICAgIHNpZ25NZXRob2QgPSAndXJuOmlldGY6cGFyYW1zOnhtbDpuczpjcHhtbHNlYzphbGdvcml0aG1zOmdvc3RyMzQxMDIwMTItZ29zdHIzNDExMjAxMi0yNTYnO1xuICAgICAgZGlnZXN0TWV0aG9kID0gJ3VybjppZXRmOnBhcmFtczp4bWw6bnM6Y3B4bWxzZWM6YWxnb3JpdGhtczpnb3N0cjM0MTEyMDEyLTI1Nic7XG4gICAgfSBlbHNlIGlmIChhbGdvcml0aG1PaWQgPT0gJzEuMi42NDMuNy4xLjEuMS4yJykgeyAgIC8vINCw0LvQs9C+0YDQuNGC0Lwg0L/QvtC00L/QuNGB0Lgg0JPQntCh0KIg0KAgMzQuMTAtMjAxMiDRgSDQutC70Y7Rh9C+0LwgNTEyINCx0LjRglxuICAgICAgc2lnbk1ldGhvZCA9ICd1cm46aWV0ZjpwYXJhbXM6eG1sOm5zOmNweG1sc2VjOmFsZ29yaXRobXM6Z29zdHIzNDEwMjAxMi1nb3N0cjM0MTEyMDEyLTUxMic7XG4gICAgICBkaWdlc3RNZXRob2QgPSAndXJuOmlldGY6cGFyYW1zOnhtbDpuczpjcHhtbHNlYzphbGdvcml0aG1zOmdvc3RyMzQxMTIwMTItNTEyJztcbiAgICB9IGVsc2UgaWYgKGFsZ29yaXRobU9pZCA9PSAnMS4yLjY0My4yLjIuMTknKSB7ICAvLyDQsNC70LPQvtGA0LjRgtC8INCT0J7QodCiINCgIDM0LjEwLTIwMDFcbiAgICAgIHNpZ25NZXRob2QgPSAndXJuOmlldGY6cGFyYW1zOnhtbDpuczpjcHhtbHNlYzphbGdvcml0aG1zOmdvc3RyMzQxMDIwMDEtZ29zdHIzNDExJztcbiAgICAgIGRpZ2VzdE1ldGhvZCA9ICd1cm46aWV0ZjpwYXJhbXM6eG1sOm5zOmNweG1sc2VjOmFsZ29yaXRobXM6Z29zdHIzNDExJztcbiAgICB9XG5cbiAgICByZXR1cm4geyBzaWduTWV0aG9kLCBkaWdlc3RNZXRob2QgfTtcbiAgfVxufVxuIl19
|
|
@@ -156,34 +156,36 @@ class CryptoProBaseService extends CryptoBaseService {
|
|
|
156
156
|
isExpired: validToDate < new Date()
|
|
157
157
|
};
|
|
158
158
|
let filterOk = true;
|
|
159
|
-
if (
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
159
|
+
if (window.CRYPTO_SKIP_CHECK !== true) {
|
|
160
|
+
if (((_a = filter === null || filter === void 0 ? void 0 : filter.certificateCheck) === null || _a === void 0 ? void 0 : _a.signerType) === SignerTypeEnum.FL) {
|
|
161
|
+
filterOk = !certificate.ogrn;
|
|
162
|
+
}
|
|
163
|
+
else if ([SignerTypeEnum.UL, SignerTypeEnum.IP]
|
|
164
|
+
.indexOf(((_b = filter === null || filter === void 0 ? void 0 : filter.certificateCheck) === null || _b === void 0 ? void 0 : _b.signerType) || SignerTypeEnum.Unknown) > -1) {
|
|
165
|
+
filterOk = certificate.ogrn ? true : false;
|
|
166
|
+
if (filterOk) {
|
|
167
|
+
const organization = certificate.organization || certificate.cn;
|
|
168
|
+
if (organization) {
|
|
169
|
+
const orgIsValid = (((_c = filter === null || filter === void 0 ? void 0 : filter.certificateCheck) === null || _c === void 0 ? void 0 : _c.fullName) &&
|
|
170
|
+
strippingCharacters(organization) == strippingCharacters((_d = filter === null || filter === void 0 ? void 0 : filter.certificateCheck) === null || _d === void 0 ? void 0 : _d.fullName))
|
|
171
|
+
|| (((_e = filter === null || filter === void 0 ? void 0 : filter.certificateCheck) === null || _e === void 0 ? void 0 : _e.shortName) &&
|
|
172
|
+
strippingCharacters(organization) == strippingCharacters((_f = filter === null || filter === void 0 ? void 0 : filter.certificateCheck) === null || _f === void 0 ? void 0 : _f.shortName));
|
|
173
|
+
if (!orgIsValid) {
|
|
174
|
+
filterOk = false;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
else {
|
|
173
178
|
filterOk = false;
|
|
174
179
|
}
|
|
175
180
|
}
|
|
176
|
-
|
|
181
|
+
}
|
|
182
|
+
if (filterOk && ((_g = filter === null || filter === void 0 ? void 0 : filter.certificateCheck) === null || _g === void 0 ? void 0 : _g.signerType)) {
|
|
183
|
+
const fio = certificate.fio.toLowerCase();
|
|
184
|
+
if (((_j = (_h = filter === null || filter === void 0 ? void 0 : filter.certificateCheck) === null || _h === void 0 ? void 0 : _h.fio) === null || _j === void 0 ? void 0 : _j.toLocaleLowerCase()) !== fio) {
|
|
177
185
|
filterOk = false;
|
|
178
186
|
}
|
|
179
187
|
}
|
|
180
188
|
}
|
|
181
|
-
if (filterOk && ((_g = filter === null || filter === void 0 ? void 0 : filter.certificateCheck) === null || _g === void 0 ? void 0 : _g.signerType)) {
|
|
182
|
-
const fio = certificate.fio.toLowerCase();
|
|
183
|
-
if (((_j = (_h = filter === null || filter === void 0 ? void 0 : filter.certificateCheck) === null || _h === void 0 ? void 0 : _h.fio) === null || _j === void 0 ? void 0 : _j.toLocaleLowerCase()) !== fio) {
|
|
184
|
-
filterOk = false;
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
189
|
if (filterOk) {
|
|
188
190
|
certificates.push(certificate);
|
|
189
191
|
}
|