UNPKG

18.4 kBJavaScriptView Raw
1var __extends = (this && this.__extends) || (function () {
2 var extendStatics = function (d, b) {
3 extendStatics = Object.setPrototypeOf ||
4 ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
5 function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
6 return extendStatics(d, b);
7 };
8 return function (d, b) {
9 extendStatics(d, b);
10 function __() { this.constructor = d; }
11 d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
12 };
13})();
14import { IonicNativePlugin, cordova } from '@ionic-native/core';
15var IntelSecurityOriginal = /** @class */ (function (_super) {
16 __extends(IntelSecurityOriginal, _super);
17 function IntelSecurityOriginal() {
18 var _this = _super !== null && _super.apply(this, arguments) || this;
19 /**
20 * returns an IntelSecurityStorage object
21 * @type {IntelSecurityStorage}
22 */
23 _this.storage = new IntelSecurityStorage();
24 /**
25 * Returns an IntelSecurityData object
26 * @type {IntelSecurityData}
27 */
28 _this.data = new IntelSecurityData();
29 return _this;
30 }
31 IntelSecurityOriginal.pluginName = "IntelSecurity";
32 IntelSecurityOriginal.plugin = "com-intel-security-cordova-plugin";
33 IntelSecurityOriginal.pluginRef = "intel.security";
34 IntelSecurityOriginal.repo = "https://github.com/AppSecurityApi/com-intel-security-cordova-plugin";
35 IntelSecurityOriginal.platforms = ["Android", "iOS", "Windows", "Windows Phone 8"];
36 return IntelSecurityOriginal;
37}(IonicNativePlugin));
38var IntelSecurity = new IntelSecurityOriginal();
39export { IntelSecurity };
40var IntelSecurityData = /** @class */ (function () {
41 function IntelSecurityData() {
42 }
43 IntelSecurityData.prototype.createFromData = function (options) { return cordova(this, "createFromData", { "otherPromise": true }, arguments); };
44 IntelSecurityData.prototype.createFromSealedData = function (options) { return cordova(this, "createFromSealedData", { "otherPromise": true }, arguments); };
45 IntelSecurityData.prototype.getData = function (instanceID) { return cordova(this, "getData", { "otherPromise": true }, arguments); };
46 IntelSecurityData.prototype.getSealedData = function (instanceID) { return cordova(this, "getSealedData", { "otherPromise": true }, arguments); };
47 IntelSecurityData.prototype.getTag = function (instanceID) { return cordova(this, "getTag", { "otherPromise": true }, arguments); };
48 IntelSecurityData.prototype.getPolicy = function (instanceID) { return cordova(this, "getPolicy", { "otherPromise": true }, arguments); };
49 IntelSecurityData.prototype.getOwners = function (instanceID) { return cordova(this, "getOwners", { "otherPromise": true }, arguments); };
50 IntelSecurityData.prototype.getCreator = function (instanceID) { return cordova(this, "getCreator", { "otherPromise": true }, arguments); };
51 IntelSecurityData.prototype.getWebOwners = function (instanceID) { return cordova(this, "getWebOwners", { "otherPromise": true }, arguments); };
52 IntelSecurityData.prototype.changeExtraKey = function (options) { return cordova(this, "changeExtraKey", { "otherPromise": true }, arguments); };
53 IntelSecurityData.prototype.destroy = function (instanceID) { return cordova(this, "destroy", { "otherPromise": true }, arguments); };
54 IntelSecurityData.pluginName = "IntelSecurity";
55 IntelSecurityData.plugin = "com-intel-security-cordova-plugin";
56 IntelSecurityData.pluginRef = "intel.security.secureData";
57 return IntelSecurityData;
58}());
59export { IntelSecurityData };
60var IntelSecurityStorage = /** @class */ (function () {
61 function IntelSecurityStorage() {
62 }
63 IntelSecurityStorage.prototype.delete = function (options) { return cordova(this, "delete", { "otherPromise": true }, arguments); };
64 IntelSecurityStorage.prototype.read = function (options) { return cordova(this, "read", { "otherPromise": true }, arguments); };
65 IntelSecurityStorage.prototype.write = function (options) { return cordova(this, "write", { "otherPromise": true }, arguments); };
66 IntelSecurityStorage.pluginName = "IntelSecurity";
67 IntelSecurityStorage.plugin = "com-intel-security-cordova-plugin";
68 IntelSecurityStorage.pluginRef = "intel.security.secureStorage";
69 return IntelSecurityStorage;
70}());
71export { IntelSecurityStorage };
72//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/@ionic-native/plugins/intel-security/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,OAAO,8BAAsC,MAAM,oBAAoB,CAAC;;IA6ErC,iCAAiB;;;QAClD;;;WAGG;QACH,aAAO,GAAyB,IAAI,oBAAoB,EAAE,CAAC;QAE3D;;;WAGG;QACH,UAAI,GAAsB,IAAI,iBAAiB,EAAE,CAAC;;;;;;;;wBAxFpD;EA6EmC,iBAAiB;SAAvC,aAAa;;;;IA6BxB,0CAAc,aAAC,OAAiC;IAWhD,gDAAoB,aAAC,OAA+B;IAUpD,mCAAO,aAAC,UAAkB;IAU1B,yCAAa,aAAC,UAAe;IAU7B,kCAAM,aAAC,UAAe;IAUtB,qCAAS,aAAC,UAAe;IAUzB,qCAAS,aAAC,UAAe;IAUzB,sCAAU,aAAC,UAAe;IAU1B,wCAAY,aAAC,UAAe;IAY5B,0CAAc,aAAC,OAAY;IAU3B,mCAAO,aAAC,UAAe;;;;4BAjNzB;;SAmGa,iBAAiB;;;;IAoI5B,qCAAM,aAAC,OAA6C;IAapD,mCAAI,aAAC,OAIJ;IAaD,oCAAK,aAAC,OAIL;;;;+BAzQH;;SA8Na,oBAAoB","sourcesContent":["import { Cordova, IonicNativePlugin, Plugin } from '@ionic-native/core';\nimport { Injectable } from '@angular/core';\n\ndeclare const window: any;\n\nexport interface IntelSecurityDataOptions {\n  /* Non-empty string. **/\n  data: String;\n  /** Tag text.  */\n  tag?: String;\n  /** Valid secure data instance ID. */\n  extraKey?: Number;\n  /** Application access control policy. */\n  appAccessControl?: Number;\n  /** Device locality policy. */\n  deviceLocality?: Number;\n  /** Sensitivity level policy. */\n  sensitivityLevel?: Number;\n  /** Disallow sealed blob access. */\n  noStore?: Boolean;\n  /** Disallow plain-text data access. */\n  noRead?: Boolean;\n  /** Creator unique ID. */\n  creator?: Number;\n  /** Array of owners unique IDs. */\n  owners?: Number[];\n  /** List of trusted web domains. */\n  webOwners?: String[];\n}\n\n/**\n * @name Intel Security\n * @description\n * The App Security API enables the use of security properties and capabilities on the platform, using a new set of API defined for application developers. You are not required to be a security expert to make good use of the API. Key elements, such as encryption of data and establishments of capabilities, is abstracted and done by the API implementation, for you.\n *\n * For example:\n * - Use the API to store (E.g. cache) data locally, using the device non-volatile storage. Data protection/encryption will be done for you by the API implementation\n * - Establish a connection with remote server (E.g. XHR) using a protected channel. SSL/TLS establishment and usage will be done for you by the API implementation\n *\n * For more information please visit the [API documentation](https://software.intel.com/en-us/app-security-api/api).\n *\n * @usage\n * ```typescript\n * import { IntelSecurity } from '@ionic-native/intel-security/ngx';\n * ...\n * constructor(private intelSecurity: IntelSecurity) { }\n * ...\n *\n * let storageID = 'id';\n *\n * this.intelSecurity.data.createFromData({ data: 'Sample Data' })\n *   .then((instanceID: Number) => this.intelSecurity.storage.write({ id: storageId, instanceID: instanceID }))\n *   .catch((error: any) => console.log(error));\n *\n * this.intelSecurity.storage.read({id: storageID })\n *   .then((instanceID: number) => this.intelSecurity.data.getData(instanceID))\n *   .then((data: string) => console.log(data)) // Resolves to 'Sample Data'\n *   .catch((error: any) => console.log(error));\n *\n * this.intelSecurity.storage.delete({ id: storageID })\n *   .then(() => console.log('Deleted Successfully'))\n *   .catch((error: any) => console.log(error));\n * ```\n * @classes\n * IntelSecurityData\n * IntelSecurityStorage\n * @interfaces\n * IntelSecurityDataOptions\n */\n@Plugin({\n  pluginName: 'IntelSecurity',\n  plugin: 'com-intel-security-cordova-plugin',\n  pluginRef: 'intel.security',\n  repo: 'https://github.com/AppSecurityApi/com-intel-security-cordova-plugin',\n  platforms: ['Android', 'iOS', 'Windows', 'Windows Phone 8']\n})\n@Injectable()\nexport class IntelSecurity extends IonicNativePlugin {\n  /**\n   * returns an IntelSecurityStorage object\n   * @type {IntelSecurityStorage}\n   */\n  storage: IntelSecurityStorage = new IntelSecurityStorage();\n\n  /**\n   * Returns an IntelSecurityData object\n   * @type {IntelSecurityData}\n   */\n  data: IntelSecurityData = new IntelSecurityData();\n}\n\n/**\n * @hidden\n */\n@Plugin({\n  pluginName: 'IntelSecurity',\n  plugin: 'com-intel-security-cordova-plugin',\n  pluginRef: 'intel.security.secureData'\n})\nexport class IntelSecurityData {\n  /**\n   * This creates a new instance of secure data using plain-text data.\n   * @param options {IntelSecurityDataOptions}\n   * @returns {Promise<any>} Returns a Promise that resolves with the instanceID of the created data instance, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  createFromData(options: IntelSecurityDataOptions): Promise<Number> {\n    return;\n  }\n\n  /**\n   * This creates a new instance of secure data (using sealed data)\n   * @param options {Object}\n   * @param options.sealedData {string} Sealed data in string format.\n   * @returns {Promise<any>} Returns a Promise that resolves with the instanceID of the created data instance, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  createFromSealedData(options: { sealedData: string }): Promise<Number> {\n    return;\n  }\n\n  /**\n   * This returns the plain-text data of the secure data instance.\n   * @param instanceID {Number} Secure data instance ID.\n   * @returns {Promise<string>} Returns a Promise that resolves to the data as plain-text, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  getData(instanceID: Number): Promise<string> {\n    return;\n  }\n\n  /**\n   * This returns the sealed chunk of a secure data instance.\n   * @param instanceID {any} Secure data instance ID.\n   * @returns {Promise<any>} Returns a Promise that resolves to the sealed data, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  getSealedData(instanceID: any): Promise<any> {\n    return;\n  }\n\n  /**\n   * This returns the tag of the secure data instance.\n   * @param instanceID {any} Secure data instance ID.\n   * @returns {Promise<string>} Returns a Promise that resolves to the tag, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  getTag(instanceID: any): Promise<string> {\n    return;\n  }\n\n  /**\n   * This returns the data policy of the secure data instance.\n   * @param instanceID {any} Secure data instance ID.\n   * @returns {Promise<any>} Returns a promise that resolves to the policy object, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  getPolicy(instanceID: any): Promise<any> {\n    return;\n  }\n\n  /**\n   * This returns an array of the data owners unique IDs.\n   * @param instanceID {any} Secure data instance ID.\n   * @returns {Promise<Array>} Returns a promise that resolves to an array of owners' unique IDs, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  getOwners(instanceID: any): Promise<any[]> {\n    return;\n  }\n\n  /**\n   * This returns the data creator unique ID.\n   * @param instanceID {any} Secure data instance ID.\n   * @returns {Promise<Number>} Returns a promsie that resolves to the creator's unique ID, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  getCreator(instanceID: any): Promise<Number> {\n    return;\n  }\n\n  /**\n   * This returns an array of the trusted web domains of the secure data instance.\n   * @param instanceID {any} Secure data instance ID.\n   * @returns {Promise<Array>} Returns a promise that resolves to a list of web owners, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  getWebOwners(instanceID: any): Promise<any[]> {\n    return;\n  }\n\n  /**\n   * This changes the extra key of a secure data instance. To successfully replace the extra key, the calling application must have sufficient access to the plain-text data.\n   * @param options {Object}\n   * @param options.instanceID {any} Secure data instance ID.\n   * @param options.extraKey {Number} Extra sealing secret for secure data instance.\n   * @returns {Promise<any>} Returns a promise that resolves with no parameters, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  changeExtraKey(options: any): Promise<any> {\n    return;\n  }\n\n  /**\n   * This releases a secure data instance.\n   * @param instanceID {any} Secure data instance ID.\n   * @returns {Promise<any>} Returns a promise that resovles with no parameters, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  destroy(instanceID: any): Promise<any> {\n    return;\n  }\n}\n\n/**\n * @hidden\n */\n@Plugin({\n  pluginName: 'IntelSecurity',\n  plugin: 'com-intel-security-cordova-plugin',\n  pluginRef: 'intel.security.secureStorage'\n})\nexport class IntelSecurityStorage {\n  /**\n   * This deletes a secure storage resource (indicated by id).\n   * @param options {Object}\n   * @param options.id {String} Storage resource identifier.\n   * @param [options.storageType] {Number} Storage type.\n   * @returns {Promise<any>} Returns a Promise that resolves with no parameters, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  delete(options: { id: string; storageType?: Number }): Promise<any> {\n    return;\n  }\n\n  /**\n   * This reads the data from secure storage (indicated by id) and creates a new secure data instance.\n   * @param options {Object}\n   * @param options.id {String} Storage resource identifier.\n   * @param [options.storageType] {Number} Storage type.\n   * @param [options.extraKey] {Number} Valid secure data instance ID.\n   * @returns {Promise<Number>} Returns a Promise that resolves with the instance ID of the created secure data instance, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  read(options: {\n    id: string;\n    storageType?: Number;\n    extraKey?: Number;\n  }): Promise<Number> {\n    return;\n  }\n\n  /**\n   * This writes the data contained in a secure data instance into secure storage.\n   * @param options {Object}\n   * @param options.id {String} Storage resource identifier.\n   * @param options.instanceID {Number} Valid secure data instance ID\n   * @param [options.storageType] {Number} Storage type.\n   * @returns {Promise<any>} Returns a Promise that resolves with no parameters, or rejects with an error.\n   */\n  @Cordova({ otherPromise: true })\n  write(options: {\n    id: String;\n    instanceID: Number;\n    storageType?: Number;\n  }): Promise<any> {\n    return;\n  }\n}\n"]}
\No newline at end of file