@clxmedia/credstore-client 1.0.18 → 1.0.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/dist/client.d.ts CHANGED
@@ -1,3 +1,5 @@
1
+ export declare const XperienceEntityKeyValidator: (entityId: string | number, entitySecret: string, availableEntityKeys: string[]) => boolean;
2
+ export declare const XperienceEntityKeyGenerator: (entityId: string | number, xperienceEntityKey: string) => string;
1
3
  export interface CredStoreConfig {
2
4
  api_server: string;
3
5
  api_key?: string;
package/dist/client.js CHANGED
@@ -9,9 +9,32 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
9
9
  });
10
10
  };
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.CredStoreClient = exports.CredentialProvider = void 0;
12
+ exports.CredStoreClient = exports.CredentialProvider = exports.XperienceEntityKeyGenerator = exports.XperienceEntityKeyValidator = void 0;
13
13
  const axios_1 = require("@nestjs/axios");
14
14
  const rxjs_1 = require("rxjs");
15
+ const luxon_1 = require("luxon");
16
+ const crypto_1 = require("crypto");
17
+ const XperienceEntityKeyValidator = (entityId, entitySecret, availableEntityKeys) => {
18
+ const now = luxon_1.DateTime.local().startOf('minute').toSeconds();
19
+ const timeRange = Array.from(Array(9).keys()).map((i) => now + (i - 4) * 60);
20
+ return timeRange.some((timeSalt) => {
21
+ return availableEntityKeys.some((entityKey) => {
22
+ return entitySecret === sha256Hash(`${entityId}:${entityKey}`, timeSalt.toString());
23
+ });
24
+ });
25
+ };
26
+ exports.XperienceEntityKeyValidator = XperienceEntityKeyValidator;
27
+ const XperienceEntityKeyGenerator = (entityId, xperienceEntityKey) => {
28
+ const timeSalt = luxon_1.DateTime.local().startOf('minute').toSeconds();
29
+ return sha256Hash(`${entityId}:${xperienceEntityKey}`, timeSalt.toString());
30
+ };
31
+ exports.XperienceEntityKeyGenerator = XperienceEntityKeyGenerator;
32
+ const sha256Hash = (input, salt) => {
33
+ return (0, crypto_1.createHash)("sha256")
34
+ .update(input)
35
+ .update((0, crypto_1.createHash)("sha256").update(salt, "utf8").digest("hex"))
36
+ .digest("hex");
37
+ };
15
38
  var CredentialProvider;
16
39
  (function (CredentialProvider) {
17
40
  CredentialProvider["generic"] = "generic";
@@ -42,14 +65,14 @@ class CredStoreClient {
42
65
  fetchCredential(guid, fetchOptions) {
43
66
  return __awaiter(this, void 0, void 0, function* () {
44
67
  const { guidSecret, skipCache } = fetchOptions;
45
- return yield (0, rxjs_1.lastValueFrom)(this.httpService.get(`${this.apiServer}/credentials/${guid}`, { headers: this.buildHeaders(guidSecret, skipCache) }).pipe((0, rxjs_1.map)((response) => {
68
+ return yield (0, rxjs_1.lastValueFrom)(this.httpService.get(`${this.apiServer}/credstore/credentials/${guid}`, { headers: this.buildHeaders(guidSecret, skipCache) }).pipe((0, rxjs_1.map)((response) => {
46
69
  return response.data;
47
70
  })));
48
71
  });
49
72
  }
50
73
  createCredential(provider, credData) {
51
74
  return __awaiter(this, void 0, void 0, function* () {
52
- return yield (0, rxjs_1.lastValueFrom)(this.httpService.post(`${this.apiServer}/credentials/${provider}`, credData, { headers: this.buildHeaders() }).pipe((0, rxjs_1.map)((response) => {
75
+ return yield (0, rxjs_1.lastValueFrom)(this.httpService.post(`${this.apiServer}/credstore/credentials/${provider}`, credData, { headers: this.buildHeaders() }).pipe((0, rxjs_1.map)((response) => {
53
76
  return response.data;
54
77
  })));
55
78
  });
@@ -57,7 +80,7 @@ class CredStoreClient {
57
80
  updateCredential(guid, data, updateOptions) {
58
81
  return __awaiter(this, void 0, void 0, function* () {
59
82
  const { guidSecret } = updateOptions;
60
- return yield (0, rxjs_1.lastValueFrom)(this.httpService.patch(`${this.apiServer}/credentials/${guid}`, data, { headers: this.buildHeaders(guidSecret) }).pipe((0, rxjs_1.map)((response) => {
83
+ return yield (0, rxjs_1.lastValueFrom)(this.httpService.patch(`${this.apiServer}/credstore/credentials/${guid}`, data, { headers: this.buildHeaders(guidSecret) }).pipe((0, rxjs_1.map)((response) => {
61
84
  return response.data;
62
85
  })));
63
86
  });
package/dist/index.d.ts CHANGED
@@ -1,2 +1 @@
1
- export { CredStoreClient, CredStoreConfig, CredentialAttribute, BaseCredential, EntrataCredential, RealPageCredential, YardiCredential, MailJetCredential, GenericCredential, CredStoreBundle, EntrataCredStoreBundle, RealPageCredStoreBundle, YardiCredStoreBundle, MailJetCredStoreBundle, CredentialProvider, FetchOptions, UpdateOptions, OptionsBase } from './client';
2
- export { XperienceEntityKeyValidator } from './helpers';
1
+ export { CredStoreClient, CredStoreConfig, CredentialAttribute, BaseCredential, EntrataCredential, RealPageCredential, YardiCredential, MailJetCredential, GenericCredential, CredStoreBundle, EntrataCredStoreBundle, RealPageCredStoreBundle, YardiCredStoreBundle, MailJetCredStoreBundle, CredentialProvider, FetchOptions, UpdateOptions, OptionsBase, XperienceEntityKeyValidator, XperienceEntityKeyGenerator } from './client';
package/dist/index.js CHANGED
@@ -1,8 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.XperienceEntityKeyValidator = exports.CredentialProvider = exports.CredStoreClient = void 0;
3
+ exports.XperienceEntityKeyGenerator = exports.XperienceEntityKeyValidator = exports.CredentialProvider = exports.CredStoreClient = void 0;
4
4
  var client_1 = require("./client");
5
5
  Object.defineProperty(exports, "CredStoreClient", { enumerable: true, get: function () { return client_1.CredStoreClient; } });
6
6
  Object.defineProperty(exports, "CredentialProvider", { enumerable: true, get: function () { return client_1.CredentialProvider; } });
7
- var helpers_1 = require("./helpers");
8
- Object.defineProperty(exports, "XperienceEntityKeyValidator", { enumerable: true, get: function () { return helpers_1.XperienceEntityKeyValidator; } });
7
+ Object.defineProperty(exports, "XperienceEntityKeyValidator", { enumerable: true, get: function () { return client_1.XperienceEntityKeyValidator; } });
8
+ Object.defineProperty(exports, "XperienceEntityKeyGenerator", { enumerable: true, get: function () { return client_1.XperienceEntityKeyGenerator; } });
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@clxmedia/credstore-client",
3
- "version": "1.0.18",
3
+ "version": "1.0.20",
4
4
  "description": "CLXperience CredStore Client",
5
5
  "author": "Brandon Thompson <brandont@clxmedia.com>",
6
6
  "license": "MIT",
7
7
  "readmeFilename": "README.md",
8
- "main": "dist/client.js, dist/helpers.js",
9
- "typings": "dist/client.d.ts, dist/helpers.d.ts",
8
+ "main": "dist/client.js",
9
+ "typings": "dist/client.d.ts",
10
10
  "files": [
11
11
  "dist/**/*",
12
12
  "*.md"