@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.
@@ -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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"}
@@ -3,64 +3,45 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.NodeSettingsIniFile = exports.NodeSettings = exports.readIniConfig = exports.readEnvConfig = exports.ApiConfigSection = exports.ApiConfig = exports.getenv = void 0;
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 ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
19
-
20
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
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
@@ -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":"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"}
@@ -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 ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
23
-
24
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
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