@looker/sdk-node 22.20.1 → 23.2.0
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/CHANGELOG.md +30 -1
- package/lib/esm/index.js +60 -5
- package/lib/esm/index.js.map +1 -1
- package/lib/esm/nodeSdk.js +18 -14
- package/lib/esm/nodeSdk.js.map +1 -1
- package/lib/esm/nodeServices.js +15 -12
- package/lib/esm/nodeServices.js.map +1 -1
- package/lib/esm/nodeSession.js +18 -66
- package/lib/esm/nodeSession.js.map +1 -1
- package/lib/esm/nodeSettings.js +36 -45
- package/lib/esm/nodeSettings.js.map +1 -1
- package/lib/esm/nodeTransport.js +51 -96
- package/lib/esm/nodeTransport.js.map +1 -1
- package/lib/esm/testUtils/index.js +17 -0
- package/lib/esm/testUtils/index.js.map +1 -0
- package/lib/esm/testUtils/testUtils.js +55 -0
- package/lib/esm/testUtils/testUtils.js.map +1 -0
- package/lib/index.js +0 -10
- package/lib/index.js.map +1 -1
- package/lib/nodeSdk.js +0 -7
- package/lib/nodeSdk.js.map +1 -1
- package/lib/nodeServices.js +3 -11
- package/lib/nodeServices.js.map +1 -1
- package/lib/nodeSession.js +3 -63
- package/lib/nodeSession.js.map +1 -1
- package/lib/nodeSettings.js +6 -49
- package/lib/nodeSettings.js.map +1 -1
- package/lib/nodeTransport.js +5 -71
- package/lib/nodeTransport.js.map +1 -1
- package/lib/testUtils/index.js +0 -2
- package/lib/testUtils/index.js.map +1 -1
- package/lib/testUtils/testUtils.js +1 -15
- package/lib/testUtils/testUtils.js.map +1 -1
- package/package.json +5 -5
package/lib/nodeSession.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/nodeSession.ts"],"names":["strPost","strDelete","NodeSession","AuthSession","constructor","settings","transport","NodeTransport","AuthToken","activeToken","_sudoToken","access_token","_authToken","isAuthenticated","token","isActive","authenticate","props","getToken","headers","Authorization","isSudo","sudoId","login","reset","_login","toString","logout","result","_logout","sudoLogout","newId","section","readConfig","clientId","client_id","clientSecret","client_secret","message","body","ok","request","apiPath","undefined","setToken","promise","encodeURI","init","accessToken"],"mappings":"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","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type {\n IRequestProps,\n ITransport,\n HttpMethod,\n IApiSettings,\n IAccessToken,\n IError,\n} from '@looker/sdk-rtl'\nimport { sdkError, encodeParams, AuthToken, AuthSession } from '@looker/sdk-rtl'\nimport { NodeTransport } from './nodeTransport'\n\nconst strPost: HttpMethod = 'POST'\nconst strDelete: HttpMethod = 'DELETE'\n\nexport class NodeSession extends AuthSession {\n private readonly apiPath: string = '/api/4.0'\n _authToken: AuthToken = new AuthToken()\n _sudoToken: AuthToken = new AuthToken()\n\n constructor(public settings: IApiSettings, transport?: ITransport) {\n super(settings, transport || new NodeTransport(settings))\n }\n\n /**\n * Abstraction of AuthToken retrieval to support sudo mode\n */\n get activeToken() {\n if (this._sudoToken.access_token) {\n return this._sudoToken\n }\n return this._authToken\n }\n\n /**\n * Is there an active authentication token?\n */\n isAuthenticated() {\n // TODO I think this can be simplified\n const token = this.activeToken\n if (!(token && token.access_token)) return false\n return token.isActive()\n }\n\n /**\n * Add authentication data to the pending API request\n * @param props initialized API request properties\n *\n * @returns the updated request properties\n */\n async authenticate(props: IRequestProps) {\n const token = await this.getToken()\n if (token && token.access_token) {\n props.headers.Authorization = `Bearer ${token.access_token}`\n }\n return props\n }\n\n isSudo() {\n return !!this.sudoId && this._sudoToken.isActive()\n }\n\n /**\n * retrieve the current authentication token. If there is no active token, performs default\n * login to retrieve the token\n */\n async getToken() {\n if (!this.isAuthenticated()) {\n await this.login()\n }\n return this.activeToken\n }\n\n /**\n * Reset the authentication session\n */\n reset() {\n this.sudoId = ''\n this._authToken.reset()\n this._sudoToken.reset()\n }\n\n /**\n * Activate the authentication token for the API3 or sudo user\n * @param sudoId {string | number}: optional. If provided, impersonates the user specified\n *\n */\n async login(sudoId?: string | number) {\n if (sudoId || sudoId !== this.sudoId || !this.isAuthenticated()) {\n if (sudoId) {\n await this._login(sudoId.toString())\n } else {\n await this._login()\n }\n }\n return this.activeToken\n }\n\n /**\n * Logout the active user. If the active user is sudo, the session reverts to the API3 user\n */\n async logout() {\n let result = false\n if (this.isAuthenticated()) {\n result = await this._logout()\n }\n return result\n }\n\n private async sudoLogout() {\n let result = false\n if (this.isSudo()) {\n result = await this.logout() // Logout the current sudo\n this._sudoToken.reset()\n }\n return result\n }\n\n // internal login method that manages default auth token and sudo workflow\n private async _login(newId?: string) {\n // for linty freshness, always logout sudo if set\n await this.sudoLogout()\n\n if (newId !== this.sudoId) {\n // Assign new requested sudo id\n this.sudoId = newId || ''\n }\n\n if (!this._authToken.isActive()) {\n this.reset()\n // only retain client API3 credentials for the lifetime of the login request\n const section = this.settings.readConfig()\n const clientId = section.client_id\n const clientSecret = section.client_secret\n if (!clientId || !clientSecret) {\n throw sdkError({\n message: 'API credentials client_id and/or client_secret are not set',\n })\n }\n const body = encodeParams({\n client_id: clientId,\n client_secret: clientSecret,\n })\n // authenticate client\n const token = await this.ok(\n this.transport.request<IAccessToken, IError>(\n strPost,\n `${this.apiPath}/login`,\n undefined,\n body\n )\n )\n this._authToken.setToken(token)\n }\n\n if (this.sudoId) {\n // Use the API user auth to sudo\n const token = this.activeToken\n const promise = this.transport.request<IAccessToken, IError>(\n strPost,\n encodeURI(`${this.apiPath}/login/${newId}`),\n null,\n null,\n // ensure the auth token is included in the sudo request\n (init: IRequestProps) => {\n if (token.access_token) {\n init.headers.Authorization = `Bearer ${token.access_token}`\n }\n return init\n },\n this.settings // TODO this may not be needed here\n )\n\n const accessToken = await this.ok(promise)\n\n this._sudoToken.setToken(accessToken)\n }\n\n return this.activeToken\n }\n\n private async _logout() {\n const token = this.activeToken\n const promise = this.transport.request<string, IError>(\n strDelete,\n `${this.apiPath}/logout`,\n null,\n null,\n // ensure the auth token is included in the logout promise\n (init: IRequestProps) => {\n if (token.access_token) {\n init.headers.Authorization = `Bearer ${token.access_token}`\n }\n return init\n },\n this.settings\n )\n\n await this.ok(promise)\n\n // If no error was thrown, logout was successful\n if (this.sudoId) {\n // User was logged out, so set auth back to default\n this.sudoId = ''\n this._sudoToken.reset()\n if (!this._authToken.isActive()) {\n await this.login()\n }\n } else {\n // completely logged out\n this.reset()\n }\n return true\n }\n}\n"],"file":"nodeSession.js"}
|
|
1
|
+
{"version":3,"file":"nodeSession.js","names":["strPost","strDelete","NodeSession","AuthSession","constructor","settings","transport","NodeTransport","AuthToken","activeToken","_sudoToken","access_token","_authToken","isAuthenticated","token","isActive","authenticate","props","getToken","headers","Authorization","isSudo","sudoId","login","reset","_login","toString","logout","result","_logout","sudoLogout","newId","section","readConfig","clientId","client_id","clientSecret","client_secret","sdkError","message","body","encodeParams","ok","request","apiPath","undefined","setToken","promise","encodeURI","init","accessToken"],"sources":["../src/nodeSession.ts"],"sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport type {\n IRequestProps,\n ITransport,\n HttpMethod,\n IApiSettings,\n IAccessToken,\n IError,\n} from '@looker/sdk-rtl'\nimport { sdkError, encodeParams, AuthToken, AuthSession } from '@looker/sdk-rtl'\nimport { NodeTransport } from './nodeTransport'\n\nconst strPost: HttpMethod = 'POST'\nconst strDelete: HttpMethod = 'DELETE'\n\nexport class NodeSession extends AuthSession {\n private readonly apiPath: string = '/api/4.0'\n _authToken: AuthToken = new AuthToken()\n _sudoToken: AuthToken = new AuthToken()\n\n constructor(public settings: IApiSettings, transport?: ITransport) {\n super(settings, transport || new NodeTransport(settings))\n }\n\n /**\n * Abstraction of AuthToken retrieval to support sudo mode\n */\n get activeToken() {\n if (this._sudoToken.access_token) {\n return this._sudoToken\n }\n return this._authToken\n }\n\n /**\n * Is there an active authentication token?\n */\n isAuthenticated() {\n // TODO I think this can be simplified\n const token = this.activeToken\n if (!(token && token.access_token)) return false\n return token.isActive()\n }\n\n /**\n * Add authentication data to the pending API request\n * @param props initialized API request properties\n *\n * @returns the updated request properties\n */\n async authenticate(props: IRequestProps) {\n const token = await this.getToken()\n if (token && token.access_token) {\n props.headers.Authorization = `Bearer ${token.access_token}`\n }\n return props\n }\n\n isSudo() {\n return !!this.sudoId && this._sudoToken.isActive()\n }\n\n /**\n * retrieve the current authentication token. If there is no active token, performs default\n * login to retrieve the token\n */\n async getToken() {\n if (!this.isAuthenticated()) {\n await this.login()\n }\n return this.activeToken\n }\n\n /**\n * Reset the authentication session\n */\n reset() {\n this.sudoId = ''\n this._authToken.reset()\n this._sudoToken.reset()\n }\n\n /**\n * Activate the authentication token for the API3 or sudo user\n * @param sudoId {string | number}: optional. If provided, impersonates the user specified\n *\n */\n async login(sudoId?: string | number) {\n if (sudoId || sudoId !== this.sudoId || !this.isAuthenticated()) {\n if (sudoId) {\n await this._login(sudoId.toString())\n } else {\n await this._login()\n }\n }\n return this.activeToken\n }\n\n /**\n * Logout the active user. If the active user is sudo, the session reverts to the API3 user\n */\n async logout() {\n let result = false\n if (this.isAuthenticated()) {\n result = await this._logout()\n }\n return result\n }\n\n private async sudoLogout() {\n let result = false\n if (this.isSudo()) {\n result = await this.logout() // Logout the current sudo\n this._sudoToken.reset()\n }\n return result\n }\n\n // internal login method that manages default auth token and sudo workflow\n private async _login(newId?: string) {\n // for linty freshness, always logout sudo if set\n await this.sudoLogout()\n\n if (newId !== this.sudoId) {\n // Assign new requested sudo id\n this.sudoId = newId || ''\n }\n\n if (!this._authToken.isActive()) {\n this.reset()\n // only retain client API3 credentials for the lifetime of the login request\n const section = this.settings.readConfig()\n const clientId = section.client_id\n const clientSecret = section.client_secret\n if (!clientId || !clientSecret) {\n throw sdkError({\n message: 'API credentials client_id and/or client_secret are not set',\n })\n }\n const body = encodeParams({\n client_id: clientId,\n client_secret: clientSecret,\n })\n // authenticate client\n const token = await this.ok(\n this.transport.request<IAccessToken, IError>(\n strPost,\n `${this.apiPath}/login`,\n undefined,\n body\n )\n )\n this._authToken.setToken(token)\n }\n\n if (this.sudoId) {\n // Use the API user auth to sudo\n const token = this.activeToken\n const promise = this.transport.request<IAccessToken, IError>(\n strPost,\n encodeURI(`${this.apiPath}/login/${newId}`),\n null,\n null,\n // ensure the auth token is included in the sudo request\n (init: IRequestProps) => {\n if (token.access_token) {\n init.headers.Authorization = `Bearer ${token.access_token}`\n }\n return init\n },\n this.settings // TODO this may not be needed here\n )\n\n const accessToken = await this.ok(promise)\n\n this._sudoToken.setToken(accessToken)\n }\n\n return this.activeToken\n }\n\n private async _logout() {\n const token = this.activeToken\n const promise = this.transport.request<string, IError>(\n strDelete,\n `${this.apiPath}/logout`,\n null,\n null,\n // ensure the auth token is included in the logout promise\n (init: IRequestProps) => {\n if (token.access_token) {\n init.headers.Authorization = `Bearer ${token.access_token}`\n }\n return init\n },\n this.settings\n )\n\n await this.ok(promise)\n\n // If no error was thrown, logout was successful\n if (this.sudoId) {\n // User was logged out, so set auth back to default\n this.sudoId = ''\n this._sudoToken.reset()\n if (!this._authToken.isActive()) {\n await this.login()\n }\n } else {\n // completely logged out\n this.reset()\n }\n return true\n }\n}\n"],"mappings":"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"}
|
package/lib/nodeSettings.js
CHANGED
|
@@ -3,64 +3,45 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.
|
|
7
|
-
|
|
6
|
+
exports.readIniConfig = exports.readEnvConfig = exports.getenv = exports.NodeSettingsIniFile = exports.NodeSettings = exports.ApiConfigSection = exports.ApiConfig = void 0;
|
|
8
7
|
var fs = _interopRequireWildcard(require("fs"));
|
|
9
|
-
|
|
10
8
|
var ini = _interopRequireWildcard(require("ini"));
|
|
11
|
-
|
|
12
9
|
var _sdkRtl = require("@looker/sdk-rtl");
|
|
13
|
-
|
|
14
10
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
15
|
-
|
|
16
11
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
17
|
-
|
|
18
|
-
function
|
|
19
|
-
|
|
20
|
-
function
|
|
21
|
-
|
|
22
|
-
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
23
|
-
|
|
12
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
13
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
14
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
15
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
|
16
|
+
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
24
17
|
var getenv = function getenv(name) {
|
|
25
18
|
var defaultValue = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined;
|
|
26
19
|
var val = process.env[name];
|
|
27
20
|
return val === undefined ? defaultValue : val;
|
|
28
21
|
};
|
|
29
|
-
|
|
30
22
|
exports.getenv = getenv;
|
|
31
|
-
|
|
32
23
|
var ApiConfig = contents => ini.parse(contents);
|
|
33
|
-
|
|
34
24
|
exports.ApiConfig = ApiConfig;
|
|
35
|
-
|
|
36
25
|
var ApiConfigSection = (contents, section) => {
|
|
37
26
|
var config = ApiConfig(contents);
|
|
38
|
-
|
|
39
27
|
if (!section) {
|
|
40
28
|
section = Object.keys(config)[0];
|
|
41
29
|
}
|
|
42
|
-
|
|
43
30
|
var settings = config[section];
|
|
44
|
-
|
|
45
31
|
if (!settings) {
|
|
46
32
|
throw new Error("No section named \"".concat(section, "\" was found"));
|
|
47
33
|
}
|
|
48
|
-
|
|
49
34
|
if (settings.api_version) {
|
|
50
35
|
console.warn('api_version is no longer read from a configuration file by the SDK');
|
|
51
36
|
}
|
|
52
|
-
|
|
53
37
|
return settings;
|
|
54
38
|
};
|
|
55
|
-
|
|
56
39
|
exports.ApiConfigSection = ApiConfigSection;
|
|
57
|
-
|
|
58
40
|
var readEnvConfig = envPrefix => {
|
|
59
41
|
var values = {};
|
|
60
42
|
var configMap = (0, _sdkRtl.ApiConfigMap)(envPrefix);
|
|
61
43
|
Object.keys(configMap).forEach(key => {
|
|
62
44
|
var envKey = configMap[key];
|
|
63
|
-
|
|
64
45
|
if (process.env[envKey] !== undefined) {
|
|
65
46
|
var val = (0, _sdkRtl.unquote)(process.env[envKey]);
|
|
66
47
|
values[key] = val;
|
|
@@ -68,89 +49,65 @@ var readEnvConfig = envPrefix => {
|
|
|
68
49
|
});
|
|
69
50
|
return values;
|
|
70
51
|
};
|
|
71
|
-
|
|
72
52
|
exports.readEnvConfig = readEnvConfig;
|
|
73
|
-
|
|
74
53
|
var readIniConfig = (fileName, envPrefix, section) => {
|
|
75
54
|
var config = readEnvConfig(envPrefix);
|
|
76
|
-
|
|
77
55
|
if (fileName && fs.existsSync(fileName)) {
|
|
78
56
|
config = _objectSpread(_objectSpread({}, ApiConfigSection(fs.readFileSync(fileName, 'utf8'), section)), config);
|
|
79
57
|
}
|
|
80
|
-
|
|
81
58
|
Object.keys(config).forEach(key => {
|
|
82
59
|
var val = config[key];
|
|
83
|
-
|
|
84
60
|
if (typeof val === 'string') {
|
|
85
61
|
config[key] = (0, _sdkRtl.unquote)(val);
|
|
86
62
|
}
|
|
87
63
|
});
|
|
88
64
|
return config;
|
|
89
65
|
};
|
|
90
|
-
|
|
91
66
|
exports.readIniConfig = readIniConfig;
|
|
92
|
-
|
|
93
67
|
class NodeSettings extends _sdkRtl.ApiSettings {
|
|
94
68
|
constructor(envPrefix, contents, section) {
|
|
95
69
|
var settings;
|
|
96
|
-
|
|
97
70
|
if (contents) {
|
|
98
71
|
if (typeof contents === 'string') {
|
|
99
72
|
settings = ApiConfigSection(contents, section);
|
|
100
73
|
} else {
|
|
101
74
|
settings = contents;
|
|
102
75
|
}
|
|
103
|
-
|
|
104
76
|
settings = _objectSpread(_objectSpread({}, readEnvConfig(envPrefix)), settings);
|
|
105
77
|
} else {
|
|
106
78
|
settings = readEnvConfig(envPrefix);
|
|
107
79
|
}
|
|
108
|
-
|
|
109
80
|
super(_objectSpread(_objectSpread({}, (0, _sdkRtl.DefaultSettings)()), settings));
|
|
110
|
-
|
|
111
81
|
_defineProperty(this, "envPrefix", void 0);
|
|
112
|
-
|
|
113
82
|
_defineProperty(this, "section", void 0);
|
|
114
|
-
|
|
115
83
|
this.section = section !== null && section !== void 0 ? section : '';
|
|
116
84
|
this.envPrefix = envPrefix;
|
|
117
85
|
}
|
|
118
|
-
|
|
119
86
|
readConfig(_section) {
|
|
120
87
|
return readEnvConfig(this.envPrefix);
|
|
121
88
|
}
|
|
122
|
-
|
|
123
89
|
}
|
|
124
|
-
|
|
125
90
|
exports.NodeSettings = NodeSettings;
|
|
126
|
-
|
|
127
91
|
class NodeSettingsIniFile extends NodeSettings {
|
|
128
92
|
constructor(envPrefix) {
|
|
129
93
|
var fileName = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
|
|
130
94
|
var section = arguments.length > 2 ? arguments[2] : undefined;
|
|
131
|
-
|
|
132
95
|
if (fileName && !fs.existsSync(fileName)) {
|
|
133
96
|
throw (0, _sdkRtl.sdkError)({
|
|
134
97
|
message: "File ".concat(fileName, " was not found")
|
|
135
98
|
});
|
|
136
99
|
}
|
|
137
|
-
|
|
138
100
|
fileName = fileName || './looker.ini';
|
|
139
101
|
var config = readIniConfig(fileName, envPrefix, section);
|
|
140
102
|
var settings = (0, _sdkRtl.ValueSettings)(config, envPrefix);
|
|
141
103
|
super(envPrefix, settings, section);
|
|
142
|
-
|
|
143
104
|
_defineProperty(this, "fileName", void 0);
|
|
144
|
-
|
|
145
105
|
this.fileName = fileName;
|
|
146
106
|
}
|
|
147
|
-
|
|
148
107
|
readConfig(section) {
|
|
149
108
|
section = section || this.section;
|
|
150
109
|
return readIniConfig(this.fileName, this.envPrefix, section);
|
|
151
110
|
}
|
|
152
|
-
|
|
153
111
|
}
|
|
154
|
-
|
|
155
112
|
exports.NodeSettingsIniFile = NodeSettingsIniFile;
|
|
156
113
|
//# sourceMappingURL=nodeSettings.js.map
|
package/lib/nodeSettings.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/nodeSettings.ts"],"names":["getenv","name","defaultValue","undefined","val","process","env","ApiConfig","contents","ini","parse","ApiConfigSection","section","config","Object","keys","settings","Error","api_version","console","warn","readEnvConfig","envPrefix","values","configMap","forEach","key","envKey","readIniConfig","fileName","fs","existsSync","readFileSync","NodeSettings","ApiSettings","constructor","readConfig","_section","NodeSettingsIniFile","message"],"mappings":"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","sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport * as fs from 'fs'\nimport * as ini from 'ini'\nimport type { IApiSettings, IApiSection } from '@looker/sdk-rtl'\nimport {\n ApiConfigMap,\n ApiSettings,\n DefaultSettings,\n ValueSettings,\n sdkError,\n unquote,\n} from '@looker/sdk-rtl'\n\n/**\n * Read an environment key. Use defaultValue if it doesn't exist\n * @param {string} name Environment variable name\n * @param {string | undefined} defaultValue\n * @returns {string | undefined} The value of the environment variable if it exists, or defaultValue\n */\nexport const getenv = (\n name: string,\n defaultValue: string | undefined = undefined\n) => {\n const val = process.env[name]\n return val === undefined ? defaultValue : val\n}\n\n/**\n * Complete .INI file parse results\n */\nexport interface IApiConfig {\n [key: string]: any\n}\n\n/**\n * Parses `.ini` formatted content\n * @param contents formatted as an `.ini` file\n * @constructor\n */\nexport const ApiConfig = (contents: string): IApiConfig => ini.parse(contents)\n\n/**\n * Extract named or (default) first section from INI file\n * @param contents {string} Parameters formatted as an INI file\n * @param section {[key: string]: any;} Contents of INI section\n * @constructor\n */\nexport const ApiConfigSection = (\n contents: string,\n section?: string\n): IApiSection => {\n const config = ApiConfig(contents)\n if (!section) {\n // default to the first section if not specified\n section = Object.keys(config)[0]\n }\n const settings = config[section]\n if (!settings) {\n throw new Error(`No section named \"${section}\" was found`)\n }\n if (settings.api_version) {\n console.warn(\n 'api_version is no longer read from a configuration file by the SDK'\n )\n }\n return settings\n}\n\n/**\n * A utility function that loads environment variables and maps them to the standard configuration values\n *\n * @returns the populated `IApiSection`, which may be empty\n */\nexport const readEnvConfig = (envPrefix: string) => {\n const values: IApiSection = {}\n const configMap = ApiConfigMap(envPrefix)\n Object.keys(configMap).forEach((key) => {\n const envKey = configMap[key]\n if (process.env[envKey] !== undefined) {\n // Value exists. Map environment variable keys to config variable keys\n const val = unquote(process.env[envKey])\n values[key] = val\n }\n })\n return values\n}\n\n/**\n * A utility function that loads the configuration values from the specified file name and overrides them\n * with environment variable values, if the environment variables exist\n *\n * @param {string} fileName Name of configuration file to read\n * @param envPrefix environment variable prefix. Pass an empty string to skip environment reading.\n * @param {string} section Optional. Name of section of configuration file to read\n * @returns {IApiSection} containing the configuration values\n */\nexport const readIniConfig = (\n fileName: string,\n envPrefix: string,\n section?: string\n) => {\n // get environment variables\n let config = readEnvConfig(envPrefix)\n if (fileName && fs.existsSync(fileName)) {\n // override any config file settings with environment values if the environment value is set\n config = {\n ...ApiConfigSection(fs.readFileSync(fileName, 'utf8'), section),\n ...config,\n }\n }\n // Unquote any quoted configuration values\n Object.keys(config).forEach((key) => {\n const val = config[key]\n if (typeof val === 'string') {\n config[key] = unquote(val)\n }\n })\n return config\n}\n\n/**\n * Read configuration settings from Node environment variables\n *\n * This class initializes SDK settings **only** from the values passed in to its constructor and\n * (potentially) configured environment variables, and does not read a configuration file at all\n *\n * Any environment variables that **are** set, will override the values passed in to the constructor\n * with the same key\n *\n */\nexport class NodeSettings extends ApiSettings {\n protected readonly envPrefix!: string\n public section: string\n\n /**\n * Initialize config settings for the node SDK runtime\n * @param envPrefix Environment variable name prefix. Use empty string to not read the environment\n * @param contents contents of the read config\n * @param section name of ini section to process\n */\n constructor(\n envPrefix: string,\n contents?: string | IApiSettings,\n section?: string\n ) {\n let settings: IApiSettings\n if (contents) {\n if (typeof contents === 'string') {\n settings = ApiConfigSection(contents, section) as IApiSettings\n } else {\n settings = contents\n }\n settings = { ...readEnvConfig(envPrefix), ...settings }\n } else {\n settings = readEnvConfig(envPrefix) as IApiSettings\n }\n super({ ...DefaultSettings(), ...settings })\n this.section = section ?? ''\n this.envPrefix = envPrefix\n }\n\n /**\n * **NOTE**: If `envPrefix` is defined in the constructor, environment variables will be read in this call.\n *\n * @param _section section name is ignored here.\n */\n readConfig(_section?: string): IApiSection {\n return readEnvConfig(this.envPrefix)\n }\n}\n\n/**\n * Example class that reads a configuration from a file in node\n *\n * If `fileName` is not specified in the constructor, the default file name is `./looker.ini`\n *\n * **Warning**: `.ini` files storing credentials should be secured in the run-time environment, and\n * ignored by version control systems so credentials never get checked in to source code repositories.\n * A recommended pattern is using Node environment variables to specify confidential API credentials\n * while using an `.ini` file for values like `base_url`.\n *\n * **Note**: If the configuration file is specified but does **not** exist, an error will be thrown.\n * No error is thrown if the fileName defaulted to `./looker.ini` inside the constructor and that\n * file does not exist. In that case, configuration from environment variables will be required.\n *\n */\nexport class NodeSettingsIniFile extends NodeSettings {\n private readonly fileName!: string\n\n constructor(envPrefix: string, fileName = '', section?: string) {\n if (fileName && !fs.existsSync(fileName)) {\n throw sdkError({ message: `File ${fileName} was not found` })\n }\n // default fileName to looker.ini\n fileName = fileName || './looker.ini'\n const config = readIniConfig(fileName, envPrefix, section)\n const settings = ValueSettings(config, envPrefix)\n super(envPrefix, settings, section)\n this.fileName = fileName\n }\n\n /**\n * Read a configuration section and return it as a generic keyed collection\n * If the configuration file doesn't exist, environment variables will be used for the values\n * Environment variables, if set, also override the configuration file values\n *\n * **NOTE**: If `envPrefix` is defined in the constructor, environment variables will be read in this call.\n *\n * @param section {string} Name of Ini section to read. Optional. Defaults to first section.\n *\n */\n readConfig(section?: string): IApiSection {\n section = section || this.section\n return readIniConfig(this.fileName, this.envPrefix, section)\n }\n}\n"],"file":"nodeSettings.js"}
|
|
1
|
+
{"version":3,"file":"nodeSettings.js","names":["getenv","name","defaultValue","undefined","val","process","env","ApiConfig","contents","ini","parse","ApiConfigSection","section","config","Object","keys","settings","Error","api_version","console","warn","readEnvConfig","envPrefix","values","configMap","ApiConfigMap","forEach","key","envKey","unquote","readIniConfig","fileName","fs","existsSync","readFileSync","NodeSettings","ApiSettings","constructor","DefaultSettings","readConfig","_section","NodeSettingsIniFile","sdkError","message","ValueSettings"],"sources":["../src/nodeSettings.ts"],"sourcesContent":["/*\n\n MIT License\n\n Copyright (c) 2021 Looker Data Sciences, Inc.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n\n */\n\nimport * as fs from 'fs'\nimport * as ini from 'ini'\nimport type { IApiSettings, IApiSection } from '@looker/sdk-rtl'\nimport {\n ApiConfigMap,\n ApiSettings,\n DefaultSettings,\n ValueSettings,\n sdkError,\n unquote,\n} from '@looker/sdk-rtl'\n\n/**\n * Read an environment key. Use defaultValue if it doesn't exist\n * @param {string} name Environment variable name\n * @param {string | undefined} defaultValue\n * @returns {string | undefined} The value of the environment variable if it exists, or defaultValue\n */\nexport const getenv = (\n name: string,\n defaultValue: string | undefined = undefined\n) => {\n const val = process.env[name]\n return val === undefined ? defaultValue : val\n}\n\n/**\n * Complete .INI file parse results\n */\nexport interface IApiConfig {\n [key: string]: any\n}\n\n/**\n * Parses `.ini` formatted content\n * @param contents formatted as an `.ini` file\n * @constructor\n */\nexport const ApiConfig = (contents: string): IApiConfig => ini.parse(contents)\n\n/**\n * Extract named or (default) first section from INI file\n * @param contents {string} Parameters formatted as an INI file\n * @param section {[key: string]: any;} Contents of INI section\n * @constructor\n */\nexport const ApiConfigSection = (\n contents: string,\n section?: string\n): IApiSection => {\n const config = ApiConfig(contents)\n if (!section) {\n // default to the first section if not specified\n section = Object.keys(config)[0]\n }\n const settings = config[section]\n if (!settings) {\n throw new Error(`No section named \"${section}\" was found`)\n }\n if (settings.api_version) {\n console.warn(\n 'api_version is no longer read from a configuration file by the SDK'\n )\n }\n return settings\n}\n\n/**\n * A utility function that loads environment variables and maps them to the standard configuration values\n *\n * @returns the populated `IApiSection`, which may be empty\n */\nexport const readEnvConfig = (envPrefix: string) => {\n const values: IApiSection = {}\n const configMap = ApiConfigMap(envPrefix)\n Object.keys(configMap).forEach((key) => {\n const envKey = configMap[key]\n if (process.env[envKey] !== undefined) {\n // Value exists. Map environment variable keys to config variable keys\n const val = unquote(process.env[envKey])\n values[key] = val\n }\n })\n return values\n}\n\n/**\n * A utility function that loads the configuration values from the specified file name and overrides them\n * with environment variable values, if the environment variables exist\n *\n * @param {string} fileName Name of configuration file to read\n * @param envPrefix environment variable prefix. Pass an empty string to skip environment reading.\n * @param {string} section Optional. Name of section of configuration file to read\n * @returns {IApiSection} containing the configuration values\n */\nexport const readIniConfig = (\n fileName: string,\n envPrefix: string,\n section?: string\n) => {\n // get environment variables\n let config = readEnvConfig(envPrefix)\n if (fileName && fs.existsSync(fileName)) {\n // override any config file settings with environment values if the environment value is set\n config = {\n ...ApiConfigSection(fs.readFileSync(fileName, 'utf8'), section),\n ...config,\n }\n }\n // Unquote any quoted configuration values\n Object.keys(config).forEach((key) => {\n const val = config[key]\n if (typeof val === 'string') {\n config[key] = unquote(val)\n }\n })\n return config\n}\n\n/**\n * Read configuration settings from Node environment variables\n *\n * This class initializes SDK settings **only** from the values passed in to its constructor and\n * (potentially) configured environment variables, and does not read a configuration file at all\n *\n * Any environment variables that **are** set, will override the values passed in to the constructor\n * with the same key\n *\n */\nexport class NodeSettings extends ApiSettings {\n protected readonly envPrefix!: string\n public section: string\n\n /**\n * Initialize config settings for the node SDK runtime\n * @param envPrefix Environment variable name prefix. Use empty string to not read the environment\n * @param contents contents of the read config\n * @param section name of ini section to process\n */\n constructor(\n envPrefix: string,\n contents?: string | IApiSettings,\n section?: string\n ) {\n let settings: IApiSettings\n if (contents) {\n if (typeof contents === 'string') {\n settings = ApiConfigSection(contents, section) as IApiSettings\n } else {\n settings = contents\n }\n settings = { ...readEnvConfig(envPrefix), ...settings }\n } else {\n settings = readEnvConfig(envPrefix) as IApiSettings\n }\n super({ ...DefaultSettings(), ...settings })\n this.section = section ?? ''\n this.envPrefix = envPrefix\n }\n\n /**\n * **NOTE**: If `envPrefix` is defined in the constructor, environment variables will be read in this call.\n *\n * @param _section section name is ignored here.\n */\n readConfig(_section?: string): IApiSection {\n return readEnvConfig(this.envPrefix)\n }\n}\n\n/**\n * Example class that reads a configuration from a file in node\n *\n * If `fileName` is not specified in the constructor, the default file name is `./looker.ini`\n *\n * **Warning**: `.ini` files storing credentials should be secured in the run-time environment, and\n * ignored by version control systems so credentials never get checked in to source code repositories.\n * A recommended pattern is using Node environment variables to specify confidential API credentials\n * while using an `.ini` file for values like `base_url`.\n *\n * **Note**: If the configuration file is specified but does **not** exist, an error will be thrown.\n * No error is thrown if the fileName defaulted to `./looker.ini` inside the constructor and that\n * file does not exist. In that case, configuration from environment variables will be required.\n *\n */\nexport class NodeSettingsIniFile extends NodeSettings {\n private readonly fileName!: string\n\n constructor(envPrefix: string, fileName = '', section?: string) {\n if (fileName && !fs.existsSync(fileName)) {\n throw sdkError({ message: `File ${fileName} was not found` })\n }\n // default fileName to looker.ini\n fileName = fileName || './looker.ini'\n const config = readIniConfig(fileName, envPrefix, section)\n const settings = ValueSettings(config, envPrefix)\n super(envPrefix, settings, section)\n this.fileName = fileName\n }\n\n /**\n * Read a configuration section and return it as a generic keyed collection\n * If the configuration file doesn't exist, environment variables will be used for the values\n * Environment variables, if set, also override the configuration file values\n *\n * **NOTE**: If `envPrefix` is defined in the constructor, environment variables will be read in this call.\n *\n * @param section {string} Name of Ini section to read. Optional. Defaults to first section.\n *\n */\n readConfig(section?: string): IApiSection {\n section = section || this.section\n return readIniConfig(this.fileName, this.envPrefix, section)\n }\n}\n"],"mappings":";;;;;;AA0BA;AACA;AAEA;AAOwB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAQjB,IAAMA,MAAM,GAAG,SAATA,MAAM,CACjBC,IAAY,EAET;EAAA,IADHC,YAAgC,uEAAGC,SAAS;EAE5C,IAAMC,GAAG,GAAGC,OAAO,CAACC,GAAG,CAACL,IAAI,CAAC;EAC7B,OAAOG,GAAG,KAAKD,SAAS,GAAGD,YAAY,GAAGE,GAAG;AAC/C,CAAC;AAAA;AAcM,IAAMG,SAAS,GAAIC,QAAgB,IAAiBC,GAAG,CAACC,KAAK,CAACF,QAAQ,CAAC;AAAA;AAQvE,IAAMG,gBAAgB,GAAG,CAC9BH,QAAgB,EAChBI,OAAgB,KACA;EAChB,IAAMC,MAAM,GAAGN,SAAS,CAACC,QAAQ,CAAC;EAClC,IAAI,CAACI,OAAO,EAAE;IAEZA,OAAO,GAAGE,MAAM,CAACC,IAAI,CAACF,MAAM,CAAC,CAAC,CAAC,CAAC;EAClC;EACA,IAAMG,QAAQ,GAAGH,MAAM,CAACD,OAAO,CAAC;EAChC,IAAI,CAACI,QAAQ,EAAE;IACb,MAAM,IAAIC,KAAK,8BAAsBL,OAAO,kBAAc;EAC5D;EACA,IAAII,QAAQ,CAACE,WAAW,EAAE;IACxBC,OAAO,CAACC,IAAI,CACV,oEAAoE,CACrE;EACH;EACA,OAAOJ,QAAQ;AACjB,CAAC;AAAA;AAOM,IAAMK,aAAa,GAAIC,SAAiB,IAAK;EAClD,IAAMC,MAAmB,GAAG,CAAC,CAAC;EAC9B,IAAMC,SAAS,GAAG,IAAAC,oBAAY,EAACH,SAAS,CAAC;EACzCR,MAAM,CAACC,IAAI,CAACS,SAAS,CAAC,CAACE,OAAO,CAAEC,GAAG,IAAK;IACtC,IAAMC,MAAM,GAAGJ,SAAS,CAACG,GAAG,CAAC;IAC7B,IAAItB,OAAO,CAACC,GAAG,CAACsB,MAAM,CAAC,KAAKzB,SAAS,EAAE;MAErC,IAAMC,GAAG,GAAG,IAAAyB,eAAO,EAACxB,OAAO,CAACC,GAAG,CAACsB,MAAM,CAAC,CAAC;MACxCL,MAAM,CAACI,GAAG,CAAC,GAAGvB,GAAG;IACnB;EACF,CAAC,CAAC;EACF,OAAOmB,MAAM;AACf,CAAC;AAAA;AAWM,IAAMO,aAAa,GAAG,CAC3BC,QAAgB,EAChBT,SAAiB,EACjBV,OAAgB,KACb;EAEH,IAAIC,MAAM,GAAGQ,aAAa,CAACC,SAAS,CAAC;EACrC,IAAIS,QAAQ,IAAIC,EAAE,CAACC,UAAU,CAACF,QAAQ,CAAC,EAAE;IAEvClB,MAAM,mCACDF,gBAAgB,CAACqB,EAAE,CAACE,YAAY,CAACH,QAAQ,EAAE,MAAM,CAAC,EAAEnB,OAAO,CAAC,GAC5DC,MAAM,CACV;EACH;EAEAC,MAAM,CAACC,IAAI,CAACF,MAAM,CAAC,CAACa,OAAO,CAAEC,GAAG,IAAK;IACnC,IAAMvB,GAAG,GAAGS,MAAM,CAACc,GAAG,CAAC;IACvB,IAAI,OAAOvB,GAAG,KAAK,QAAQ,EAAE;MAC3BS,MAAM,CAACc,GAAG,CAAC,GAAG,IAAAE,eAAO,EAACzB,GAAG,CAAC;IAC5B;EACF,CAAC,CAAC;EACF,OAAOS,MAAM;AACf,CAAC;AAAA;AAYM,MAAMsB,YAAY,SAASC,mBAAW,CAAC;EAU5CC,WAAW,CACTf,SAAiB,EACjBd,QAAgC,EAChCI,OAAgB,EAChB;IACA,IAAII,QAAsB;IAC1B,IAAIR,QAAQ,EAAE;MACZ,IAAI,OAAOA,QAAQ,KAAK,QAAQ,EAAE;QAChCQ,QAAQ,GAAGL,gBAAgB,CAACH,QAAQ,EAAEI,OAAO,CAAiB;MAChE,CAAC,MAAM;QACLI,QAAQ,GAAGR,QAAQ;MACrB;MACAQ,QAAQ,mCAAQK,aAAa,CAACC,SAAS,CAAC,GAAKN,QAAQ,CAAE;IACzD,CAAC,MAAM;MACLA,QAAQ,GAAGK,aAAa,CAACC,SAAS,CAAiB;IACrD;IACA,KAAK,iCAAM,IAAAgB,uBAAe,GAAE,GAAKtB,QAAQ,EAAG;IAAA;IAAA;IAC5C,IAAI,CAACJ,OAAO,GAAGA,OAAO,aAAPA,OAAO,cAAPA,OAAO,GAAI,EAAE;IAC5B,IAAI,CAACU,SAAS,GAAGA,SAAS;EAC5B;EAOAiB,UAAU,CAACC,QAAiB,EAAe;IACzC,OAAOnB,aAAa,CAAC,IAAI,CAACC,SAAS,CAAC;EACtC;AACF;AAAC;AAiBM,MAAMmB,mBAAmB,SAASN,YAAY,CAAC;EAGpDE,WAAW,CAACf,SAAiB,EAAmC;IAAA,IAAjCS,QAAQ,uEAAG,EAAE;IAAA,IAAEnB,OAAgB;IAC5D,IAAImB,QAAQ,IAAI,CAACC,EAAE,CAACC,UAAU,CAACF,QAAQ,CAAC,EAAE;MACxC,MAAM,IAAAW,gBAAQ,EAAC;QAAEC,OAAO,iBAAUZ,QAAQ;MAAiB,CAAC,CAAC;IAC/D;IAEAA,QAAQ,GAAGA,QAAQ,IAAI,cAAc;IACrC,IAAMlB,MAAM,GAAGiB,aAAa,CAACC,QAAQ,EAAET,SAAS,EAAEV,OAAO,CAAC;IAC1D,IAAMI,QAAQ,GAAG,IAAA4B,qBAAa,EAAC/B,MAAM,EAAES,SAAS,CAAC;IACjD,KAAK,CAACA,SAAS,EAAEN,QAAQ,EAAEJ,OAAO,CAAC;IAAA;IACnC,IAAI,CAACmB,QAAQ,GAAGA,QAAQ;EAC1B;EAYAQ,UAAU,CAAC3B,OAAgB,EAAe;IACxCA,OAAO,GAAGA,OAAO,IAAI,IAAI,CAACA,OAAO;IACjC,OAAOkB,aAAa,CAAC,IAAI,CAACC,QAAQ,EAAE,IAAI,CAACT,SAAS,EAAEV,OAAO,CAAC;EAC9D;AACF;AAAC"}
|
package/lib/nodeTransport.js
CHANGED
|
@@ -4,79 +4,56 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.NodeTransport = exports.NodeCryptoHash = void 0;
|
|
7
|
-
|
|
8
7
|
var _crypto = _interopRequireDefault(require("crypto"));
|
|
9
|
-
|
|
10
8
|
var _request = _interopRequireDefault(require("request"));
|
|
11
|
-
|
|
12
9
|
var _requestPromiseNative = _interopRequireDefault(require("request-promise-native"));
|
|
13
|
-
|
|
14
10
|
var _readableStream = require("readable-stream");
|
|
15
|
-
|
|
16
11
|
var _errors = require("request-promise-native/errors");
|
|
17
|
-
|
|
18
12
|
var _sdkRtl = require("@looker/sdk-rtl");
|
|
19
|
-
|
|
20
13
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
21
|
-
|
|
22
|
-
function
|
|
23
|
-
|
|
24
|
-
function
|
|
25
|
-
|
|
26
|
-
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
27
|
-
|
|
14
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
15
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
16
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
17
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
|
18
|
+
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
28
19
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
|
|
29
|
-
|
|
30
20
|
function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
|
|
31
|
-
|
|
32
21
|
var utf8 = 'utf8';
|
|
33
|
-
|
|
34
22
|
var asString = value => {
|
|
35
23
|
if (value instanceof Buffer) {
|
|
36
24
|
return Buffer.from(value).toString(utf8);
|
|
37
25
|
}
|
|
38
|
-
|
|
39
26
|
if (value instanceof Object) {
|
|
40
27
|
return JSON.stringify(value);
|
|
41
28
|
}
|
|
42
|
-
|
|
43
29
|
return value.toString();
|
|
44
30
|
};
|
|
45
|
-
|
|
46
31
|
class NodeCryptoHash {
|
|
47
32
|
secureRandom(byteCount) {
|
|
48
33
|
return _crypto.default.randomBytes(byteCount).toString('hex');
|
|
49
34
|
}
|
|
50
|
-
|
|
51
35
|
sha256Hash(message) {
|
|
52
36
|
return _asyncToGenerator(function* () {
|
|
53
37
|
var hash = _crypto.default.createHash('sha256');
|
|
54
|
-
|
|
55
38
|
hash.update(message);
|
|
56
39
|
return (0, _sdkRtl.safeBase64)(new Uint8Array(hash.digest()));
|
|
57
40
|
})();
|
|
58
41
|
}
|
|
59
|
-
|
|
60
42
|
}
|
|
61
|
-
|
|
62
43
|
exports.NodeCryptoHash = NodeCryptoHash;
|
|
63
|
-
|
|
64
44
|
class NodeTransport extends _sdkRtl.BaseTransport {
|
|
65
45
|
constructor(options) {
|
|
66
46
|
super(options);
|
|
67
47
|
this.options = options;
|
|
68
48
|
}
|
|
69
|
-
|
|
70
49
|
rawRequest(method, path, queryParams, body, authenticator, options) {
|
|
71
50
|
var _this = this;
|
|
72
|
-
|
|
73
51
|
return _asyncToGenerator(function* () {
|
|
74
52
|
var init = yield _this.initRequest(method, path, queryParams, body, authenticator, options);
|
|
75
53
|
var req = (0, _requestPromiseNative.default)(init).promise();
|
|
76
54
|
var rawResponse;
|
|
77
55
|
var requestStarted = Date.now();
|
|
78
56
|
var responseCompleted;
|
|
79
|
-
|
|
80
57
|
try {
|
|
81
58
|
var res = yield req;
|
|
82
59
|
responseCompleted = Date.now();
|
|
@@ -98,14 +75,10 @@ class NodeTransport extends _sdkRtl.BaseTransport {
|
|
|
98
75
|
var statusMessage = "".concat(method, " ").concat(path);
|
|
99
76
|
var statusCode = 404;
|
|
100
77
|
var contentType = 'text';
|
|
101
|
-
|
|
102
78
|
var _body;
|
|
103
|
-
|
|
104
79
|
responseCompleted = Date.now();
|
|
105
|
-
|
|
106
80
|
if (e instanceof _errors.StatusCodeError) {
|
|
107
81
|
statusCode = e.statusCode;
|
|
108
|
-
|
|
109
82
|
if (e.error instanceof Buffer) {
|
|
110
83
|
_body = asString(e.error);
|
|
111
84
|
statusMessage += ": ".concat(statusCode);
|
|
@@ -121,7 +94,6 @@ class NodeTransport extends _sdkRtl.BaseTransport {
|
|
|
121
94
|
_body = JSON.stringify(e);
|
|
122
95
|
contentType = 'application/json';
|
|
123
96
|
}
|
|
124
|
-
|
|
125
97
|
rawResponse = {
|
|
126
98
|
method,
|
|
127
99
|
url: init.url.toString(),
|
|
@@ -135,20 +107,16 @@ class NodeTransport extends _sdkRtl.BaseTransport {
|
|
|
135
107
|
responseCompleted
|
|
136
108
|
};
|
|
137
109
|
}
|
|
138
|
-
|
|
139
110
|
return _this.observer ? _this.observer(rawResponse) : rawResponse;
|
|
140
111
|
})();
|
|
141
112
|
}
|
|
142
|
-
|
|
143
113
|
parseResponse(res) {
|
|
144
114
|
return _asyncToGenerator(function* () {
|
|
145
115
|
var mode = (0, _sdkRtl.responseMode)(res.contentType);
|
|
146
116
|
var response;
|
|
147
117
|
var error;
|
|
148
|
-
|
|
149
118
|
if (!res.ok) {
|
|
150
119
|
error = res.body;
|
|
151
|
-
|
|
152
120
|
if (typeof error === 'string') {
|
|
153
121
|
try {
|
|
154
122
|
error = JSON.parse(error);
|
|
@@ -158,23 +126,19 @@ class NodeTransport extends _sdkRtl.BaseTransport {
|
|
|
158
126
|
};
|
|
159
127
|
}
|
|
160
128
|
}
|
|
161
|
-
|
|
162
129
|
response = {
|
|
163
130
|
ok: false,
|
|
164
131
|
error
|
|
165
132
|
};
|
|
166
133
|
return response;
|
|
167
134
|
}
|
|
168
|
-
|
|
169
135
|
var result = yield res.body;
|
|
170
|
-
|
|
171
136
|
if (mode === _sdkRtl.ResponseMode.string) {
|
|
172
137
|
if (res.contentType.match(/^application\/.*\bjson\b/g)) {
|
|
173
138
|
try {
|
|
174
139
|
if (result instanceof Buffer) {
|
|
175
140
|
result = Buffer.from(result).toString(utf8);
|
|
176
141
|
}
|
|
177
|
-
|
|
178
142
|
if (!(result instanceof Object)) {
|
|
179
143
|
result = JSON.parse(result.toString());
|
|
180
144
|
}
|
|
@@ -187,13 +151,11 @@ class NodeTransport extends _sdkRtl.BaseTransport {
|
|
|
187
151
|
} else {
|
|
188
152
|
try {
|
|
189
153
|
var _result;
|
|
190
|
-
|
|
191
154
|
result = Buffer.from((_result = result) !== null && _result !== void 0 ? _result : '').toString('binary');
|
|
192
155
|
} catch (err) {
|
|
193
156
|
error = err;
|
|
194
157
|
}
|
|
195
158
|
}
|
|
196
|
-
|
|
197
159
|
if (!error) {
|
|
198
160
|
response = {
|
|
199
161
|
ok: true,
|
|
@@ -205,14 +167,11 @@ class NodeTransport extends _sdkRtl.BaseTransport {
|
|
|
205
167
|
error: error
|
|
206
168
|
};
|
|
207
169
|
}
|
|
208
|
-
|
|
209
170
|
return response;
|
|
210
171
|
})();
|
|
211
172
|
}
|
|
212
|
-
|
|
213
173
|
request(method, path, queryParams, body, authenticator, options) {
|
|
214
174
|
var _this2 = this;
|
|
215
|
-
|
|
216
175
|
return _asyncToGenerator(function* () {
|
|
217
176
|
try {
|
|
218
177
|
var res = yield _this2.rawRequest(method, path, queryParams, body, authenticator, options);
|
|
@@ -229,39 +188,28 @@ class NodeTransport extends _sdkRtl.BaseTransport {
|
|
|
229
188
|
}
|
|
230
189
|
})();
|
|
231
190
|
}
|
|
232
|
-
|
|
233
191
|
requestor(props) {
|
|
234
192
|
var _props$method;
|
|
235
|
-
|
|
236
193
|
var method = (_props$method = props.method) === null || _props$method === void 0 ? void 0 : _props$method.toString().toUpperCase();
|
|
237
|
-
|
|
238
194
|
switch (method) {
|
|
239
195
|
case 'GET':
|
|
240
196
|
return _request.default.get(props);
|
|
241
|
-
|
|
242
197
|
case 'PUT':
|
|
243
198
|
return _request.default.put(props);
|
|
244
|
-
|
|
245
199
|
case 'POST':
|
|
246
200
|
return _request.default.post(props);
|
|
247
|
-
|
|
248
201
|
case 'PATCH':
|
|
249
202
|
return _request.default.patch(props);
|
|
250
|
-
|
|
251
203
|
case 'DELETE':
|
|
252
204
|
return _request.default.put(props);
|
|
253
|
-
|
|
254
205
|
case 'HEAD':
|
|
255
206
|
return _request.default.head(props);
|
|
256
|
-
|
|
257
207
|
default:
|
|
258
208
|
return _request.default.get(props);
|
|
259
209
|
}
|
|
260
210
|
}
|
|
261
|
-
|
|
262
211
|
stream(callback, method, path, queryParams, body, authenticator, options) {
|
|
263
212
|
var _this3 = this;
|
|
264
|
-
|
|
265
213
|
return _asyncToGenerator(function* () {
|
|
266
214
|
var stream = new _readableStream.PassThrough();
|
|
267
215
|
var returnPromise = callback(stream);
|
|
@@ -269,9 +217,7 @@ class NodeTransport extends _sdkRtl.BaseTransport {
|
|
|
269
217
|
var streamPromise = new Promise((resolve, reject) => {
|
|
270
218
|
(0, _sdkRtl.trace)("[stream] beginning stream via download url", init);
|
|
271
219
|
var hasResolved = false;
|
|
272
|
-
|
|
273
220
|
var req = _this3.requestor(init);
|
|
274
|
-
|
|
275
221
|
req.on('error', err => {
|
|
276
222
|
if (hasResolved && err.code === 'ECONNRESET') {
|
|
277
223
|
(0, _sdkRtl.trace)('ignoring ECONNRESET that occurred after streaming finished', init);
|
|
@@ -305,34 +251,26 @@ class NodeTransport extends _sdkRtl.BaseTransport {
|
|
|
305
251
|
return results[0];
|
|
306
252
|
})();
|
|
307
253
|
}
|
|
308
|
-
|
|
309
254
|
verifySsl(options) {
|
|
310
255
|
if (!options) options = this.options;
|
|
311
256
|
return 'verify_ssl' in options ? options.verify_ssl : true;
|
|
312
257
|
}
|
|
313
|
-
|
|
314
258
|
timeout(options) {
|
|
315
259
|
if (!options) options = this.options;
|
|
316
260
|
if ('timeout' in options && options.timeout) return options.timeout;
|
|
317
261
|
return _sdkRtl.defaultTimeout;
|
|
318
262
|
}
|
|
319
|
-
|
|
320
263
|
initRequest(method, path, queryParams, body, authenticator, options) {
|
|
321
264
|
var _this4 = this;
|
|
322
|
-
|
|
323
265
|
return _asyncToGenerator(function* () {
|
|
324
266
|
options = options ? _objectSpread(_objectSpread({}, _this4.options), options) : _this4.options;
|
|
325
|
-
|
|
326
267
|
if (!options.agentTag) {
|
|
327
268
|
options.agentTag = _sdkRtl.agentPrefix;
|
|
328
269
|
}
|
|
329
|
-
|
|
330
270
|
var headers = _objectSpread({
|
|
331
271
|
[_sdkRtl.LookerAppId]: options.agentTag
|
|
332
272
|
}, options.headers);
|
|
333
|
-
|
|
334
273
|
var requestPath = _this4.makeUrl(path, options, queryParams);
|
|
335
|
-
|
|
336
274
|
var init = {
|
|
337
275
|
body: body || undefined,
|
|
338
276
|
encoding: null,
|
|
@@ -345,16 +283,12 @@ class NodeTransport extends _sdkRtl.BaseTransport {
|
|
|
345
283
|
url: requestPath
|
|
346
284
|
};
|
|
347
285
|
if ('encoding' in options) init.encoding = options.encoding;
|
|
348
|
-
|
|
349
286
|
if (authenticator) {
|
|
350
287
|
init = yield authenticator(init);
|
|
351
288
|
}
|
|
352
|
-
|
|
353
289
|
return init;
|
|
354
290
|
})();
|
|
355
291
|
}
|
|
356
|
-
|
|
357
292
|
}
|
|
358
|
-
|
|
359
293
|
exports.NodeTransport = NodeTransport;
|
|
360
294
|
//# sourceMappingURL=nodeTransport.js.map
|