New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

ryuu.js

Package Overview
Dependencies
Maintainers
5
Versions
54
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ryuu.js - npm Package Compare versions

Comparing version 4.3.1 to 4.4.0

LICENSE

19

changelog.md

@@ -0,1 +1,20 @@

# Changelog
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
## [4.4.0](https://github.com/DomoApps/domo.js/compare/v2.5.8...v4.4.0) (2023-06-26)
### Features
* **onDataUpdate:** verify origin of data recieved ([#10](https://github.com/DomoApps/domo.js/issues/10)) ([d5b8594](https://github.com/DomoApps/domo.js/commit/d5b8594f8baf8a220db1b3aaab449e819b081757))
* **onFiltersUpdate:** DOMO-275255 ([868be22](https://github.com/DomoApps/domo.js/commit/868be22147b4cb64b191986e07bc6cb318da05d1))
### Bug Fixes
* add checking to onDataUpdate event listener ([#9](https://github.com/DomoApps/domo.js/issues/9)) ([d4e07cd](https://github.com/DomoApps/domo.js/commit/d4e07cd4a801ee68f3df115f6adaee9fba98eca9))
* changed to only append SID if it doesn't exist ([95fdbe2](https://github.com/DomoApps/domo.js/commit/95fdbe2fb36a76e8c2428a2cfcbe24beb422fda5))
* **onFiltersUpdate:** call each callback on event ([0aba05f](https://github.com/DomoApps/domo.js/commit/0aba05f0f0de23d2cccdf6be928a294bbc0c57c5))
# v3.0.0

@@ -2,0 +21,0 @@ Converted to TypeScript

4

dist/domo.js
/*! For license information please see domo.js.LICENSE.txt */
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.domo=t():e.domo=t()}(self,(function(){return(()=>{"use strict";var e={727:(e,t,r)=>{var o=r(554),n=r(206),a=function(){function e(){}return e.post=function(e,t,r){return i(o.RequestMethods.POST,e,r,!0,t)},e.put=function(e,t,r){return i(o.RequestMethods.PUT,e,r,!0,t)},e.get=function(e,t){return i(o.RequestMethods.GET,e,t)},e.delete=function(e,t){return i(o.RequestMethods.DELETE,e,t)},e.getAll=function(t,r){return Promise.all(t.map((function(t){return e.get(t,r)})))},e.onDataUpdate=function(e){function t(t){if(c(t.origin)&&"string"==typeof t.data&&t.data.length>0)try{var r=JSON.parse(t.data);if(!r.hasOwnProperty("alias"))return;var o=r.alias,n=JSON.stringify({event:"ack",alias:o});t.source instanceof MessagePort||t.source instanceof ServiceWorker||t.source.postMessage(n,t.origin),e(o)}catch(e){console.warn("There was an error in onDataUpdate! It may be that our event listener caught a message from another source and tried to parse it, so your update still may have worked. If you would like more info, here is the error: \n",e)}}return window.addEventListener("message",t),function(){return window.removeEventListener("message",t)}},e.navigate=function(e,t){var r=JSON.stringify({event:"navigate",url:e,isNewWindow:t});window.parent.postMessage(r,"*")},e.filterContainer=function(e){var t=window.navigator.userAgent.toLowerCase(),r=/safari/.test(t),o=/iphone|ipod|ipad/.test(t),n=JSON.stringify({event:"filter",filter:e&&e.map((function(e){return{columnName:e.column,operator:e.operator||e.operand,values:e.values,dataType:e.dataType}}))});o&&!r?window.webkit.messageHandlers.domofilter.postMessage(e&&e.map((function(e){return{column:e.column,operand:e.operator||e.operand,values:e.values,dataType:e.dataType}}))):window.parent.postMessage(n,"*")},e.connected=!1,e.listeners={onFiltersUpdate:[]},e.connect=function(){e.connected||(e.connected=!0,e.channel=new MessageChannel,window.parent.postMessage(JSON.stringify({event:"subscribe"}),"*",[e.channel.port2]))},e.onFiltersUpdate=function(t){e.connect();var r=e.listeners.onFiltersUpdate.push(t)-1;return e.channel.port1.onmessage=function(t){var r=t.ports[0];void 0!==r&&"filtersUpdated"===t.data.event&&e.listeners.onFiltersUpdate.length>0&&(r.postMessage({}),e.listeners.onFiltersUpdate.forEach((function(e){return e(t.data.filters)})))},function(){e.listeners.onFiltersUpdate.splice(r,1)}},e.env=d(),e.__util={isVerifiedOrigin:c,getQueryParams:d,setFormatHeaders:p,isSuccess:u},e}(),s=window.__RYUU_SID__;function i(e,t,r,n,a){return r=r||{},new Promise((function(i,c){var d=new XMLHttpRequest;if(n?d.open(e,t,n):d.open(e,t),p(d,t,r),function(e,t){t.contentType?"multipart"!==t.contentType&&e.setRequestHeader("Content-Type",t.contentType):e.setRequestHeader("Content-Type",o.DataFormats.JSON)}(d,r),function(e){s&&e.setRequestHeader("X-DOMO-Ryuu-Session",s)}(d),function(e,t){void 0!==t.responseType&&(e.responseType=t.responseType)}(d,r),d.onload=function(){var e;if(u(d.status)){!["csv","excel"].includes(r.format)&&d.response||i(d.response),"blob"===r.responseType&&i(new Blob([d.response],{type:d.getResponseHeader("content-type")}));var t=d.response;try{e=JSON.parse(t)}catch(e){return void c(Error("Invalid JSON response"))}i(e)}else c(Error(d.statusText))},d.onerror=function(){c(Error("Network Error"))},a)if(r.contentType&&r.contentType!==o.DataFormats.JSON)d.send(a);else{var f=JSON.stringify(a);d.send(f)}else d.send()}))}function u(e){return e>=200&&e<300}function c(e){var t=e.match("^https?://([^/]+[.])?(domo|domotech|domorig).(com|io)?(/.*)?$"),r=e.match("(.*).(domoapps).(.*)");return!!t&&!r}function d(){var e=location.search.substr(1),t={};return e.split("&").forEach((function(e){var r=e.split("=");t[r[0]]=decodeURIComponent(r[1])})),t}function p(e,t,r){if(-1!==t.indexOf("data/v")){var a=void 0!==r.format?(0,n.domoFormatToRequestFormat)(r.format):o.DataFormats.DEFAULT;e.setRequestHeader("Accept",a)}}function f(e){if(e===document.body||e===document.head)return l(e);var t=e.dataset&&e.dataset.domoHref||e.getAttribute("href"),r=e.dataset&&e.dataset.domoSrc||e.getAttribute("src"),o=t?"href":"src",n=t||r;if(n&&s&&!n.includes(s)){var a=new URL(n,document.location.origin);a.origin===document.location.origin&&(a.searchParams.append("ryuu-sid",s),e.setAttribute(o,a.href))}}function l(e){for(var t=0;t<e.children.length;t++)f(e.children[t])}var m=new MutationObserver((function(e){for(var t=0,r=e;t<r.length;t++)l(r[t].target)}));m.observe(document.body,{childList:!0,subtree:!0}),m.observe(document.head,{childList:!0,subtree:!0}),e.exports=a},548:(e,t)=>{var r;Object.defineProperty(t,"__esModule",{value:!0}),t.DataFormats=void 0,(r=t.DataFormats||(t.DataFormats={})).DEFAULT="application/array-of-objects",r.ARRAY_OF_OBJECTS="application/array-of-objects",r.JSON="application/json",r.CSV="text/csv",r.EXCEL="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",r.PLAIN="text/plain"},64:(e,t)=>{var r;Object.defineProperty(t,"__esModule",{value:!0}),t.RequestMethods=void 0,(r=t.RequestMethods||(t.RequestMethods={})).get="GET",r.GET="GET",r.post="POST",r.POST="POST",r.put="PUT",r.PUT="PUT",r.delete="DELETE",r.DELETE="DELETE"},554:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.FilterDataTypes=t.DataFormats=t.RequestMethods=void 0;var o=r(64);Object.defineProperty(t,"RequestMethods",{enumerable:!0,get:function(){return o.RequestMethods}});var n=r(548);Object.defineProperty(t,"DataFormats",{enumerable:!0,get:function(){return n.DataFormats}});var a=r(616);Object.defineProperty(t,"FilterDataTypes",{enumerable:!0,get:function(){return a.FilterDataTypes}})},616:(e,t)=>{var r;Object.defineProperty(t,"__esModule",{value:!0}),t.FilterDataTypes=void 0,(r=t.FilterDataTypes||(t.FilterDataTypes={})).NUMERIC="NUMERIC",r.DATE="DATE",r.DATETIME="DATETIME",r.STRING="STRING"},206:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.domoFormatToRequestFormat=void 0;var o=r(554);t.domoFormatToRequestFormat=function(e){switch(e){case"array-of-objects":return o.DataFormats.ARRAY_OF_OBJECTS;case"array-of-arrays":return o.DataFormats.JSON;case"excel":return o.DataFormats.EXCEL;case"csv":return o.DataFormats.CSV;default:return o.DataFormats.DEFAULT}}}},t={};return function r(o){var n=t[o];if(void 0!==n)return n.exports;var a=t[o]={exports:{}};return e[o](a,a.exports,r),a.exports}(727)})()}));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"domo.js","mappings":"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","sources":["webpack://domo/webpack/universalModuleDefinition","webpack://domo/./src/domo.ts","webpack://domo/./src/models/enums/data-formats.ts","webpack://domo/./src/models/enums/request-methods.ts","webpack://domo/./src/models/index.ts","webpack://domo/./src/models/interfaces/filter-data-types.ts","webpack://domo/./src/utils/data-helpers.ts","webpack://domo/webpack/bootstrap","webpack://domo/webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"domo\"] = factory();\n\telse\n\t\troot[\"domo\"] = factory();\n})(self, function() {\nreturn ","import {\n  RequestMethods,\n  RequestOptions,\n  ObjectRequestOptions,\n  ArrayRequestOptions,\n  DataFormats,\n  QueryParams,\n  Filter,\n  RequestBody,\n  ResponseBody,\n  ObjectResponseBody,\n  ArrayResponseBody,\n} from \"./models\";\nimport { domoFormatToRequestFormat } from \"./utils/data-helpers\";\n\nexport = domo;\n\nclass domo {\n  static post(\n    url: string,\n    body?: RequestBody,\n    options?: RequestOptions\n  ): Promise<ResponseBody>;\n  static post<T>(\n    url: string,\n    body?: RequestBody,\n    options?: RequestOptions\n  ): Promise<T>;\n  static post<T>(\n    url: string,\n    body?: RequestBody,\n    options?: RequestOptions\n  ): Promise<T> {\n    return domoHttp<T>(RequestMethods.POST, url, options, true, body);\n  }\n\n  static put(\n    url: string,\n    body?: RequestBody,\n    options?: RequestOptions\n  ): Promise<ResponseBody>;\n  static put<T>(\n    url: string,\n    body?: RequestBody,\n    options?: RequestOptions\n  ): Promise<T>;\n  static put<T>(\n    url: string,\n    body?: RequestBody,\n    options?: RequestOptions\n  ): Promise<T> {\n    return domoHttp<T>(RequestMethods.PUT, url, options, true, body);\n  }\n\n  static get(\n    url: string,\n    options: ObjectRequestOptions\n  ): Promise<ObjectResponseBody[]>;\n  static get(\n    url: string,\n    options: ArrayRequestOptions\n  ): Promise<ArrayResponseBody>;\n  static get(url: string, options?: RequestOptions): Promise<ResponseBody>;\n  static get<T>(url: string, options?: RequestOptions): Promise<T>;\n  static get<T>(url: string, options?: RequestOptions): Promise<T> {\n    return domoHttp<T>(RequestMethods.GET, url, options);\n  }\n\n  static delete(url: string, options?: RequestOptions): Promise<ResponseBody>;\n  static delete<T>(url: string, options?: RequestOptions): Promise<T>;\n  static delete<T>(url: string, options?: RequestOptions): Promise<T> {\n    return domoHttp<T>(RequestMethods.DELETE, url, options);\n  }\n\n  static getAll(\n    urls: string[],\n    options: ObjectRequestOptions\n  ): Promise<ObjectResponseBody[][]>;\n  static getAll(\n    urls: string[],\n    options: ArrayRequestOptions\n  ): Promise<ArrayResponseBody[]>;\n  static getAll(\n    urls: string[],\n    options?: RequestOptions\n  ): Promise<ResponseBody[]>;\n  static getAll<T>(urls: string[], options?: RequestOptions): Promise<T[]>;\n  static getAll<T>(urls: string[], options?: RequestOptions): Promise<T[]> {\n    return Promise.all(\n      urls.map(function (url) {\n        return domo.get<T>(url, options);\n      })\n    );\n  }\n\n  /**\n   * Let the domoapp optionally handle its own data updates.\n   */\n  static onDataUpdate(cb: (alias: string) => void) {\n    function innerCallback(event: MessageEvent) {\n      if (!isVerifiedOrigin(event.origin)) return;\n\n      if (typeof event.data === \"string\" && event.data.length > 0) {\n        try {\n          const message = JSON.parse(event.data);\n          if (!message.hasOwnProperty(\"alias\")) {\n            return;\n          }\n\n          const alias = message.alias;\n\n          // send acknowledgement to prevent autorefresh\n          const ack = JSON.stringify({\n            event: \"ack\",\n            alias: alias,\n          });\n\n          // Only WindowProxy | Window have the postMessage method and the type of event.source varies between browsers\n          if (\n            !(event.source instanceof MessagePort) &&\n            !(event.source instanceof ServiceWorker)\n          ) {\n            event.source.postMessage(ack, event.origin);\n          }\n\n          // inform domo app which alias has been updated\n          cb(alias);\n        } catch (err) {\n          const info =\n            \"There was an error in onDataUpdate! It may be that our event listener caught \" +\n            \"a message from another source and tried to parse it, so your update still may have worked. \" +\n            \"If you would like more info, here is the error: \\n\";\n          console.warn(info, err);\n        }\n      }\n    }\n    window.addEventListener(\"message\", innerCallback);\n    return () => window.removeEventListener(\"message\", innerCallback);\n  }\n\n  /**\n   * Let the domoapp optionally handle other events\n   */\n  static channel?: MessageChannel;\n  static connected = false;\n  static listeners: { [index: string]: Function[] } = {\n    onFiltersUpdate: [],\n  };\n\n  static connect = () => {\n    if (domo.connected) return;\n    domo.connected = true;\n    domo.channel = new MessageChannel();\n    window.parent.postMessage(JSON.stringify({ event: \"subscribe\" }), \"*\", [\n      domo.channel.port2,\n    ]);\n  };\n\n  /**\n   * Let the domoapp handle its own filter updates\n   */\n  static onFiltersUpdate = (callback: Function) => {\n    domo.connect();\n    const index = domo.listeners.onFiltersUpdate.push(callback) - 1;\n\n    domo.channel.port1.onmessage = (e: MessageEvent) => {\n      const [responsePort] = e.ports;\n      if (responsePort === undefined) return;\n\n      if (\n        e.data.event === \"filtersUpdated\" &&\n        domo.listeners.onFiltersUpdate.length > 0\n      ) {\n        responsePort.postMessage({}); // Prevents the app from reloading. Says we've handled it\n        domo.listeners.onFiltersUpdate.forEach((cb) => cb(e.data.filters)); // <- split out onFiltersUpdate so that you can handle each message differently here\n      }\n    };\n\n    // unregister\n    return () => {\n      domo.listeners.onFiltersUpdate.splice(index, 1);\n    };\n  };\n\n  /**\n   * Request a navigation change\n   */\n  static navigate(url: string, isNewWindow: boolean) {\n    const message = JSON.stringify({\n      event: \"navigate\",\n      url: url,\n      isNewWindow: isNewWindow,\n    });\n    window.parent.postMessage(message, \"*\");\n  }\n\n  static filterContainer(filters: Filter[] | null): void {\n    const userAgent = window.navigator.userAgent.toLowerCase(),\n      safari = /safari/.test(userAgent),\n      ios = /iphone|ipod|ipad/.test(userAgent);\n\n    const message = JSON.stringify({\n      event: \"filter\",\n      filter:\n        filters &&\n        filters.map((filter) => ({\n          columnName: filter.column,\n          operator: filter.operator || (filter as any).operand, // Most filter code (including Phoenix) still uses \"operand\" instead of \"operator\"\n          values: filter.values,\n          dataType: filter.dataType,\n        })),\n    });\n\n    if (ios && !safari) {\n      (window as any).webkit.messageHandlers.domofilter.postMessage(\n        filters &&\n          filters.map((filter) => ({\n            column: filter.column,\n            operand: filter.operator || (filter as any).operand,\n            values: filter.values,\n            dataType: filter.dataType,\n          }))\n      );\n    } else {\n      window.parent.postMessage(message, \"*\");\n    }\n  }\n\n  static env = getQueryParams();\n\n  static __util = {\n    isVerifiedOrigin,\n    getQueryParams,\n    setFormatHeaders,\n    isSuccess,\n  };\n}\n\nconst token = (window as any).__RYUU_SID__;\n\nfunction domoHttp(\n  method: RequestMethods,\n  url: string,\n  options: ObjectRequestOptions,\n  async?: boolean,\n  body?: RequestBody\n): Promise<ObjectResponseBody[]>;\nfunction domoHttp(\n  method: RequestMethods,\n  url: string,\n  options: ArrayRequestOptions,\n  async?: boolean,\n  body?: RequestBody\n): Promise<ArrayResponseBody>;\nfunction domoHttp(\n  method: RequestMethods,\n  url: string,\n  options: RequestOptions,\n  async?: boolean,\n  body?: RequestBody\n): Promise<ResponseBody>;\nfunction domoHttp<T>(\n  method: RequestMethods,\n  url: string,\n  options: RequestOptions,\n  async?: boolean,\n  body?: RequestBody\n): Promise<T>;\nfunction domoHttp(\n  method: RequestMethods,\n  url: string,\n  options: RequestOptions,\n  async?: boolean,\n  body?: RequestBody\n): Promise<ResponseBody> {\n  options = options || {};\n  return new Promise(function (\n    resolve: (value?: ResponseBody) => void,\n    reject: (reason?: Error) => void\n  ) {\n    // Do the usual XHR stuff\n    let req: XMLHttpRequest = new XMLHttpRequest();\n    if (async) {\n      req.open(method, url, async);\n    } else {\n      req.open(method, url);\n    }\n    setFormatHeaders(req, url, options);\n    setContentHeaders(req, options);\n    setAuthTokenHeader(req);\n    setResponseType(req, options);\n\n    req.onload = function () {\n      let data;\n      // This is called even on 404 etc so check the status\n      if (isSuccess(req.status)) {\n        if ([\"csv\", \"excel\"].includes(options.format) || !req.response) {\n          resolve(req.response);\n        }\n        if (options.responseType === \"blob\") {\n          resolve(\n            new Blob([req.response], {\n              type: req.getResponseHeader(\"content-type\"),\n            })\n          );\n        }\n\n        let responseStr = req.response;\n        try {\n          // if(!responseStr) {\n          //   responseStr = \"{}\";\n          // }\n          data = JSON.parse(responseStr);\n        } catch (ex) {\n          reject(Error(\"Invalid JSON response\"));\n          return;\n        }\n        // Resolve the promise with the response text\n        resolve(data);\n      } else {\n        // Otherwise reject with the status text\n        // which will hopefully be a meaningful error\n        reject(Error(req.statusText));\n      }\n    };\n\n    // Handle network errors\n    req.onerror = function () {\n      reject(Error(\"Network Error\"));\n    };\n\n    // Make the request\n    if (body) {\n      if (!options.contentType || options.contentType === DataFormats.JSON) {\n        const json = JSON.stringify(body);\n        // Make the request\n        req.send(json);\n      } else {\n        // body can no longer be JSON\n        req.send(body as Document | XMLHttpRequestBodyInit);\n      }\n    } else {\n      req.send();\n    }\n  });\n}\n\nfunction isSuccess(status: number) {\n  return status >= 200 && status < 300;\n}\n\nfunction isVerifiedOrigin(origin: string) {\n  const whitelisted = origin.match(\n    \"^https?://([^/]+[.])?(domo|domotech|domorig).(com|io)?(/.*)?$\"\n  );\n  const blacklisted = origin.match(\"(.*).(domoapps).(.*)\");\n  return !!whitelisted && !blacklisted;\n}\n\nfunction getQueryParams(): QueryParams {\n  const query = location.search.substr(1);\n  let result: { [index: string]: string } = {};\n  query.split(\"&\").forEach(function (part) {\n    const item = part.split(\"=\");\n    result[item[0]] = decodeURIComponent(item[1]);\n  });\n  return result;\n}\n\nfunction setFormatHeaders(\n  req: XMLHttpRequest,\n  url: string,\n  options?: RequestOptions\n) {\n  if (url.indexOf(\"data/v\") === -1) {\n    return;\n  }\n  // set format\n  const requestFormat: DataFormats =\n    options.format !== undefined\n      ? domoFormatToRequestFormat(options.format)\n      : DataFormats.DEFAULT;\n\n  req.setRequestHeader(\"Accept\", requestFormat);\n}\n\nfunction setContentHeaders(req: XMLHttpRequest, options?: RequestOptions) {\n  if (options.contentType) {\n    // set content type if user passed option\n    if (options.contentType !== \"multipart\") {\n      req.setRequestHeader(\"Content-Type\", options.contentType);\n    }\n  } else {\n    req.setRequestHeader(\"Content-Type\", DataFormats.JSON);\n  }\n}\n\nfunction setAuthTokenHeader(req: XMLHttpRequest) {\n  if (token) {\n    req.setRequestHeader(\"X-DOMO-Ryuu-Session\", token);\n  }\n}\n\nfunction setResponseType(req: XMLHttpRequest, options?: RequestOptions) {\n  //set response type if user passed option\n  if (options.responseType !== undefined) {\n    req.responseType = options.responseType;\n  }\n}\n\nfunction handleNode(node: HTMLElement) {\n  if (node === document.body || node === document.head)\n    return processBody(node);\n\n  const hrefAttribute =\n    (node.dataset && node.dataset.domoHref) || node.getAttribute(\"href\");\n  const srcAttribute =\n    (node.dataset && node.dataset.domoSrc) || node.getAttribute(\"src\");\n  const attr = hrefAttribute ? \"href\" : \"src\";\n  const url = hrefAttribute || srcAttribute;\n\n  if (!url || !token || url.includes(token)) return;\n\n  const newUrl = new URL(url, document.location.origin);\n  const isRelativeUrl = newUrl.origin === document.location.origin;\n  if (isRelativeUrl) {\n    newUrl.searchParams.append(\"ryuu-sid\", token);\n    node.setAttribute(attr, newUrl.href);\n  }\n}\n\nfunction processBody(node: any) {\n  for (let i = 0; i < node.children.length; i++) {\n    handleNode(<HTMLElement>node.children[i]);\n  }\n}\n\nconst ob = new MutationObserver((mutations) => {\n  for (const record of mutations) {\n    processBody(record.target);\n  }\n});\n\nob.observe(document.body, { childList: true, subtree: true });\nob.observe(document.head, { childList: true, subtree: true });\n","/**\n * Supported `accept` headers for controlling the format\n * of the data returned from Domo.\n *\n * See [developer.domo.com](https://developer.domo.com/docs/dev-studio-references/data-api#Data%20Formats)\n * for more details.\n */\nexport enum DataFormats {\n  DEFAULT = 'application/array-of-objects',\n  ARRAY_OF_OBJECTS = 'application/array-of-objects',\n  JSON = 'application/json',\n  CSV = 'text/csv',\n  EXCEL = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\n  PLAIN = 'text/plain'\n}","export enum RequestMethods {\n  get = 'GET',\n  GET = 'GET',\n  post = 'POST',\n  POST = 'POST',\n  put = 'PUT',\n  PUT = 'PUT',\n  delete = 'DELETE',\n  DELETE = 'DELETE',\n}\n","export { RequestMethods } from './enums/request-methods';\nexport { DomoDataFormats } from './interfaces/domo-data-formats';\nexport { DataFormats } from './enums/data-formats';\nexport { FilterDataTypes } from './interfaces/filter-data-types';\nexport { Filter } from './interfaces/filter';\n\nexport { RequestOptions, ObjectRequestOptions, ArrayRequestOptions } from './interfaces/request-options';\nexport { QueryParams } from './interfaces/query-params';\nexport { RequestBody } from './interfaces/request-body';\nexport { ResponseBody, ObjectResponseBody, ArrayResponseBody } from './interfaces/response-body';\nexport { Json } from './interfaces/json';\n","export enum FilterDataTypes{\n  NUMERIC = \"NUMERIC\",\n  DATE = \"DATE\",\n  DATETIME = \"DATETIME\",\n  STRING = \"STRING\",\n}\n","import { DomoDataFormats, DataFormats } from '../models';\n\nexport function domoFormatToRequestFormat(format: DomoDataFormats): DataFormats {\n  switch (format) {\n    case 'array-of-objects': {\n      return DataFormats.ARRAY_OF_OBJECTS;\n    }\n    case 'array-of-arrays': {\n      return DataFormats.JSON;\n    }\n    case 'excel': {\n      return DataFormats.EXCEL;\n    }\n    case 'csv': {\n      return DataFormats.CSV;\n    }\n    default: {\n      return DataFormats.DEFAULT;\n    }\n  }\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(727);\n"],"names":["root","factory","exports","module","define","amd","self","post","url","body","options","domoHttp","RequestMethods","POST","put","PUT","get","GET","delete","DELETE","getAll","urls","Promise","all","map","domo","onDataUpdate","cb","innerCallback","event","isVerifiedOrigin","origin","data","length","message","JSON","parse","hasOwnProperty","alias","ack","stringify","source","MessagePort","ServiceWorker","postMessage","err","console","warn","window","addEventListener","removeEventListener","navigate","isNewWindow","parent","filterContainer","filters","userAgent","navigator","toLowerCase","safari","test","ios","filter","columnName","column","operator","operand","values","dataType","webkit","messageHandlers","domofilter","connected","listeners","onFiltersUpdate","connect","channel","MessageChannel","port2","callback","index","push","port1","onmessage","e","responsePort","ports","undefined","forEach","splice","env","getQueryParams","__util","setFormatHeaders","isSuccess","token","__RYUU_SID__","method","async","resolve","reject","req","XMLHttpRequest","open","contentType","setRequestHeader","DataFormats","setContentHeaders","setAuthTokenHeader","responseType","setResponseType","onload","status","includes","format","response","Blob","type","getResponseHeader","responseStr","ex","Error","statusText","onerror","send","json","whitelisted","match","blacklisted","query","location","search","substr","result","split","part","item","decodeURIComponent","indexOf","requestFormat","domoFormatToRequestFormat","DEFAULT","handleNode","node","document","head","processBody","hrefAttribute","dataset","domoHref","getAttribute","srcAttribute","domoSrc","attr","newUrl","URL","searchParams","append","setAttribute","href","i","children","ob","MutationObserver","mutations","target","observe","childList","subtree","FilterDataTypes","ARRAY_OF_OBJECTS","EXCEL","CSV","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__"],"sourceRoot":""}
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.domo=t():e.domo=t()}(self,(()=>(()=>{"use strict";var e={727:(e,t,r)=>{var o=r(554),n=r(206),a=function(){function e(){}return e.post=function(e,t,r){return i(o.RequestMethods.POST,e,r,!0,t)},e.put=function(e,t,r){return i(o.RequestMethods.PUT,e,r,!0,t)},e.get=function(e,t){return i(o.RequestMethods.GET,e,t)},e.delete=function(e,t){return i(o.RequestMethods.DELETE,e,t)},e.getAll=function(t,r){return Promise.all(t.map((function(t){return e.get(t,r)})))},e.onDataUpdate=function(e){function t(t){if(c(t.origin)&&"string"==typeof t.data&&t.data.length>0)try{var r=JSON.parse(t.data);if(!r.hasOwnProperty("alias"))return;var o=r.alias,n=JSON.stringify({event:"ack",alias:o});t.source instanceof MessagePort||t.source instanceof ServiceWorker||t.source.postMessage(n,t.origin),e(o)}catch(e){console.warn("There was an error in onDataUpdate! It may be that our event listener caught a message from another source and tried to parse it, so your update still may have worked. If you would like more info, here is the error: \n",e)}}return window.addEventListener("message",t),function(){return window.removeEventListener("message",t)}},e.navigate=function(e,t){var r=JSON.stringify({event:"navigate",url:e,isNewWindow:t});window.parent.postMessage(r,"*")},e.filterContainer=function(e){var t=window.navigator.userAgent.toLowerCase(),r=/safari/.test(t),o=/iphone|ipod|ipad/.test(t),n=JSON.stringify({event:"filter",filter:e&&e.map((function(e){return{columnName:e.column,operator:e.operator||e.operand,values:e.values,dataType:e.dataType}}))});o&&!r?window.webkit.messageHandlers.domofilter.postMessage(e&&e.map((function(e){return{column:e.column,operand:e.operator||e.operand,values:e.values,dataType:e.dataType}}))):window.parent.postMessage(n,"*")},e.connected=!1,e.listeners={onFiltersUpdate:[]},e.connect=function(){e.connected||(e.connected=!0,e.channel=new MessageChannel,window.parent.postMessage(JSON.stringify({event:"subscribe"}),"*",[e.channel.port2]))},e.onFiltersUpdate=function(t){e.connect();var r=e.listeners.onFiltersUpdate.push(t)-1;return e.channel.port1.onmessage=function(t){var r=t.ports[0];void 0!==r&&"filtersUpdated"===t.data.event&&e.listeners.onFiltersUpdate.length>0&&(r.postMessage({}),e.listeners.onFiltersUpdate.forEach((function(e){return e(t.data.filters)})))},function(){e.listeners.onFiltersUpdate.splice(r,1)}},e.env=d(),e.__util={isVerifiedOrigin:c,getQueryParams:d,setFormatHeaders:p,isSuccess:u},e}(),s=window.__RYUU_SID__;function i(e,t,r,n,a){return r=r||{},new Promise((function(i,c){var d=new XMLHttpRequest;if(n?d.open(e,t,n):d.open(e,t),p(d,t,r),function(e,t){t.contentType?"multipart"!==t.contentType&&e.setRequestHeader("Content-Type",t.contentType):e.setRequestHeader("Content-Type",o.DataFormats.JSON)}(d,r),function(e){s&&e.setRequestHeader("X-DOMO-Ryuu-Session",s)}(d),function(e,t){void 0!==t.responseType&&(e.responseType=t.responseType)}(d,r),d.onload=function(){var e;if(u(d.status)){!["csv","excel"].includes(r.format)&&d.response||i(d.response),"blob"===r.responseType&&i(new Blob([d.response],{type:d.getResponseHeader("content-type")}));var t=d.response;try{e=JSON.parse(t)}catch(e){return void c(Error("Invalid JSON response"))}i(e)}else c(Error(d.statusText))},d.onerror=function(){c(Error("Network Error"))},a)if(r.contentType&&r.contentType!==o.DataFormats.JSON)d.send(a);else{var f=JSON.stringify(a);d.send(f)}else d.send()}))}function u(e){return e>=200&&e<300}function c(e){var t=e.match("^https?://([^/]+[.])?(domo|domotech|domorig).(com|io)?(/.*)?$"),r=e.match("(.*).(domoapps).(.*)");return!!t&&!r}function d(){var e=location.search.substr(1),t={};return e.split("&").forEach((function(e){var r=e.split("=");t[r[0]]=decodeURIComponent(r[1])})),t}function p(e,t,r){if(-1!==t.indexOf("data/v")){var a=void 0!==r.format?(0,n.domoFormatToRequestFormat)(r.format):o.DataFormats.DEFAULT;e.setRequestHeader("Accept",a)}}function f(e){if(e===document.body||e===document.head)return l(e);var t=e.dataset&&e.dataset.domoHref||e.getAttribute("href"),r=e.dataset&&e.dataset.domoSrc||e.getAttribute("src"),o=t?"href":"src",n=t||r;if(n&&s&&!n.includes(s)){var a=new URL(n,document.location.origin);a.origin===document.location.origin&&(a.searchParams.append("ryuu-sid",s),e.setAttribute(o,a.href))}}function l(e){for(var t=0;t<e.children.length;t++)f(e.children[t])}var m=new MutationObserver((function(e){for(var t=0,r=e;t<r.length;t++)l(r[t].target)}));m.observe(document.body,{childList:!0,subtree:!0}),m.observe(document.head,{childList:!0,subtree:!0}),e.exports=a},548:(e,t)=>{var r;Object.defineProperty(t,"__esModule",{value:!0}),t.DataFormats=void 0,(r=t.DataFormats||(t.DataFormats={})).DEFAULT="application/array-of-objects",r.ARRAY_OF_OBJECTS="application/array-of-objects",r.JSON="application/json",r.CSV="text/csv",r.EXCEL="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",r.PLAIN="text/plain"},64:(e,t)=>{var r;Object.defineProperty(t,"__esModule",{value:!0}),t.RequestMethods=void 0,(r=t.RequestMethods||(t.RequestMethods={})).get="GET",r.GET="GET",r.post="POST",r.POST="POST",r.put="PUT",r.PUT="PUT",r.delete="DELETE",r.DELETE="DELETE"},554:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.FilterDataTypes=t.DataFormats=t.RequestMethods=void 0;var o=r(64);Object.defineProperty(t,"RequestMethods",{enumerable:!0,get:function(){return o.RequestMethods}});var n=r(548);Object.defineProperty(t,"DataFormats",{enumerable:!0,get:function(){return n.DataFormats}});var a=r(616);Object.defineProperty(t,"FilterDataTypes",{enumerable:!0,get:function(){return a.FilterDataTypes}})},616:(e,t)=>{var r;Object.defineProperty(t,"__esModule",{value:!0}),t.FilterDataTypes=void 0,(r=t.FilterDataTypes||(t.FilterDataTypes={})).NUMERIC="NUMERIC",r.DATE="DATE",r.DATETIME="DATETIME",r.STRING="STRING"},206:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.domoFormatToRequestFormat=void 0;var o=r(554);t.domoFormatToRequestFormat=function(e){switch(e){case"array-of-objects":return o.DataFormats.ARRAY_OF_OBJECTS;case"array-of-arrays":return o.DataFormats.JSON;case"excel":return o.DataFormats.EXCEL;case"csv":return o.DataFormats.CSV;default:return o.DataFormats.DEFAULT}}}},t={};return function r(o){var n=t[o];if(void 0!==n)return n.exports;var a=t[o]={exports:{}};return e[o](a,a.exports,r),a.exports}(727)})()));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"domo.js","mappings":"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","sources":["webpack://domo/webpack/universalModuleDefinition","webpack://domo/./src/domo.ts","webpack://domo/./src/models/enums/data-formats.ts","webpack://domo/./src/models/enums/request-methods.ts","webpack://domo/./src/models/index.ts","webpack://domo/./src/models/interfaces/filter-data-types.ts","webpack://domo/./src/utils/data-helpers.ts","webpack://domo/webpack/bootstrap","webpack://domo/webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"domo\"] = factory();\n\telse\n\t\troot[\"domo\"] = factory();\n})(self, () => {\nreturn ","import {\n  RequestMethods,\n  RequestOptions,\n  ObjectRequestOptions,\n  ArrayRequestOptions,\n  DataFormats,\n  QueryParams,\n  Filter,\n  RequestBody,\n  ResponseBody,\n  ObjectResponseBody,\n  ArrayResponseBody,\n} from \"./models\";\nimport { domoFormatToRequestFormat } from \"./utils/data-helpers\";\n\nexport = domo;\n\nclass domo {\n  static post(\n    url: string,\n    body?: RequestBody,\n    options?: RequestOptions\n  ): Promise<ResponseBody>;\n  static post<T>(\n    url: string,\n    body?: RequestBody,\n    options?: RequestOptions\n  ): Promise<T>;\n  static post<T>(\n    url: string,\n    body?: RequestBody,\n    options?: RequestOptions\n  ): Promise<T> {\n    return domoHttp<T>(RequestMethods.POST, url, options, true, body);\n  }\n\n  static put(\n    url: string,\n    body?: RequestBody,\n    options?: RequestOptions\n  ): Promise<ResponseBody>;\n  static put<T>(\n    url: string,\n    body?: RequestBody,\n    options?: RequestOptions\n  ): Promise<T>;\n  static put<T>(\n    url: string,\n    body?: RequestBody,\n    options?: RequestOptions\n  ): Promise<T> {\n    return domoHttp<T>(RequestMethods.PUT, url, options, true, body);\n  }\n\n  static get(\n    url: string,\n    options: ObjectRequestOptions\n  ): Promise<ObjectResponseBody[]>;\n  static get(\n    url: string,\n    options: ArrayRequestOptions\n  ): Promise<ArrayResponseBody>;\n  static get(url: string, options?: RequestOptions): Promise<ResponseBody>;\n  static get<T>(url: string, options?: RequestOptions): Promise<T>;\n  static get<T>(url: string, options?: RequestOptions): Promise<T> {\n    return domoHttp<T>(RequestMethods.GET, url, options);\n  }\n\n  static delete(url: string, options?: RequestOptions): Promise<ResponseBody>;\n  static delete<T>(url: string, options?: RequestOptions): Promise<T>;\n  static delete<T>(url: string, options?: RequestOptions): Promise<T> {\n    return domoHttp<T>(RequestMethods.DELETE, url, options);\n  }\n\n  static getAll(\n    urls: string[],\n    options: ObjectRequestOptions\n  ): Promise<ObjectResponseBody[][]>;\n  static getAll(\n    urls: string[],\n    options: ArrayRequestOptions\n  ): Promise<ArrayResponseBody[]>;\n  static getAll(\n    urls: string[],\n    options?: RequestOptions\n  ): Promise<ResponseBody[]>;\n  static getAll<T>(urls: string[], options?: RequestOptions): Promise<T[]>;\n  static getAll<T>(urls: string[], options?: RequestOptions): Promise<T[]> {\n    return Promise.all(\n      urls.map(function (url) {\n        return domo.get<T>(url, options);\n      })\n    );\n  }\n\n  /**\n   * Let the domoapp optionally handle its own data updates.\n   */\n  static onDataUpdate(cb: (alias: string) => void) {\n    function innerCallback(event: MessageEvent) {\n      if (!isVerifiedOrigin(event.origin)) return;\n\n      if (typeof event.data === \"string\" && event.data.length > 0) {\n        try {\n          const message = JSON.parse(event.data);\n          if (!message.hasOwnProperty(\"alias\")) {\n            return;\n          }\n\n          const alias = message.alias;\n\n          // send acknowledgement to prevent autorefresh\n          const ack = JSON.stringify({\n            event: \"ack\",\n            alias: alias,\n          });\n\n          // Only WindowProxy | Window have the postMessage method and the type of event.source varies between browsers\n          if (\n            !(event.source instanceof MessagePort) &&\n            !(event.source instanceof ServiceWorker)\n          ) {\n            event.source.postMessage(ack, event.origin);\n          }\n\n          // inform domo app which alias has been updated\n          cb(alias);\n        } catch (err) {\n          const info =\n            \"There was an error in onDataUpdate! It may be that our event listener caught \" +\n            \"a message from another source and tried to parse it, so your update still may have worked. \" +\n            \"If you would like more info, here is the error: \\n\";\n          console.warn(info, err);\n        }\n      }\n    }\n    window.addEventListener(\"message\", innerCallback);\n    return () => window.removeEventListener(\"message\", innerCallback);\n  }\n\n  /**\n   * Let the domoapp optionally handle other events\n   */\n  static channel?: MessageChannel;\n  static connected = false;\n  static listeners: { [index: string]: Function[] } = {\n    onFiltersUpdate: [],\n  };\n\n  static connect = () => {\n    if (domo.connected) return;\n    domo.connected = true;\n    domo.channel = new MessageChannel();\n    window.parent.postMessage(JSON.stringify({ event: \"subscribe\" }), \"*\", [\n      domo.channel.port2,\n    ]);\n  };\n\n  /**\n   * Let the domoapp handle its own filter updates\n   */\n  static onFiltersUpdate = (callback: Function) => {\n    domo.connect();\n    const index = domo.listeners.onFiltersUpdate.push(callback) - 1;\n\n    domo.channel.port1.onmessage = (e: MessageEvent) => {\n      const [responsePort] = e.ports;\n      if (responsePort === undefined) return;\n\n      if (\n        e.data.event === \"filtersUpdated\" &&\n        domo.listeners.onFiltersUpdate.length > 0\n      ) {\n        responsePort.postMessage({}); // Prevents the app from reloading. Says we've handled it\n        domo.listeners.onFiltersUpdate.forEach((cb) => cb(e.data.filters)); // <- split out onFiltersUpdate so that you can handle each message differently here\n      }\n    };\n\n    // unregister\n    return () => {\n      domo.listeners.onFiltersUpdate.splice(index, 1);\n    };\n  };\n\n  /**\n   * Request a navigation change\n   */\n  static navigate(url: string, isNewWindow: boolean) {\n    const message = JSON.stringify({\n      event: \"navigate\",\n      url: url,\n      isNewWindow: isNewWindow,\n    });\n    window.parent.postMessage(message, \"*\");\n  }\n\n  static filterContainer(filters: Filter[] | null): void {\n    const userAgent = window.navigator.userAgent.toLowerCase(),\n      safari = /safari/.test(userAgent),\n      ios = /iphone|ipod|ipad/.test(userAgent);\n\n    const message = JSON.stringify({\n      event: \"filter\",\n      filter:\n        filters &&\n        filters.map((filter) => ({\n          columnName: filter.column,\n          operator: filter.operator || (filter as any).operand, // Most filter code (including Phoenix) still uses \"operand\" instead of \"operator\"\n          values: filter.values,\n          dataType: filter.dataType,\n        })),\n    });\n\n    if (ios && !safari) {\n      (window as any).webkit.messageHandlers.domofilter.postMessage(\n        filters &&\n          filters.map((filter) => ({\n            column: filter.column,\n            operand: filter.operator || (filter as any).operand,\n            values: filter.values,\n            dataType: filter.dataType,\n          }))\n      );\n    } else {\n      window.parent.postMessage(message, \"*\");\n    }\n  }\n\n  static env = getQueryParams();\n\n  static __util = {\n    isVerifiedOrigin,\n    getQueryParams,\n    setFormatHeaders,\n    isSuccess,\n  };\n}\n\nconst token = (window as any).__RYUU_SID__;\n\nfunction domoHttp(\n  method: RequestMethods,\n  url: string,\n  options: ObjectRequestOptions,\n  async?: boolean,\n  body?: RequestBody\n): Promise<ObjectResponseBody[]>;\nfunction domoHttp(\n  method: RequestMethods,\n  url: string,\n  options: ArrayRequestOptions,\n  async?: boolean,\n  body?: RequestBody\n): Promise<ArrayResponseBody>;\nfunction domoHttp(\n  method: RequestMethods,\n  url: string,\n  options: RequestOptions,\n  async?: boolean,\n  body?: RequestBody\n): Promise<ResponseBody>;\nfunction domoHttp<T>(\n  method: RequestMethods,\n  url: string,\n  options: RequestOptions,\n  async?: boolean,\n  body?: RequestBody\n): Promise<T>;\nfunction domoHttp(\n  method: RequestMethods,\n  url: string,\n  options: RequestOptions,\n  async?: boolean,\n  body?: RequestBody\n): Promise<ResponseBody> {\n  options = options || {};\n  return new Promise(function (\n    resolve: (value?: ResponseBody) => void,\n    reject: (reason?: Error) => void\n  ) {\n    // Do the usual XHR stuff\n    let req: XMLHttpRequest = new XMLHttpRequest();\n    if (async) {\n      req.open(method, url, async);\n    } else {\n      req.open(method, url);\n    }\n    setFormatHeaders(req, url, options);\n    setContentHeaders(req, options);\n    setAuthTokenHeader(req);\n    setResponseType(req, options);\n\n    req.onload = function () {\n      let data;\n      // This is called even on 404 etc so check the status\n      if (isSuccess(req.status)) {\n        if ([\"csv\", \"excel\"].includes(options.format) || !req.response) {\n          resolve(req.response);\n        }\n        if (options.responseType === \"blob\") {\n          resolve(\n            new Blob([req.response], {\n              type: req.getResponseHeader(\"content-type\"),\n            })\n          );\n        }\n\n        let responseStr = req.response;\n        try {\n          // if(!responseStr) {\n          //   responseStr = \"{}\";\n          // }\n          data = JSON.parse(responseStr);\n        } catch (ex) {\n          reject(Error(\"Invalid JSON response\"));\n          return;\n        }\n        // Resolve the promise with the response text\n        resolve(data);\n      } else {\n        // Otherwise reject with the status text\n        // which will hopefully be a meaningful error\n        reject(Error(req.statusText));\n      }\n    };\n\n    // Handle network errors\n    req.onerror = function () {\n      reject(Error(\"Network Error\"));\n    };\n\n    // Make the request\n    if (body) {\n      if (!options.contentType || options.contentType === DataFormats.JSON) {\n        const json = JSON.stringify(body);\n        // Make the request\n        req.send(json);\n      } else {\n        // body can no longer be JSON\n        req.send(body as Document | XMLHttpRequestBodyInit);\n      }\n    } else {\n      req.send();\n    }\n  });\n}\n\nfunction isSuccess(status: number) {\n  return status >= 200 && status < 300;\n}\n\nfunction isVerifiedOrigin(origin: string) {\n  const whitelisted = origin.match(\n    \"^https?://([^/]+[.])?(domo|domotech|domorig).(com|io)?(/.*)?$\"\n  );\n  const blacklisted = origin.match(\"(.*).(domoapps).(.*)\");\n  return !!whitelisted && !blacklisted;\n}\n\nfunction getQueryParams(): QueryParams {\n  const query = location.search.substr(1);\n  let result: { [index: string]: string } = {};\n  query.split(\"&\").forEach(function (part) {\n    const item = part.split(\"=\");\n    result[item[0]] = decodeURIComponent(item[1]);\n  });\n  return result;\n}\n\nfunction setFormatHeaders(\n  req: XMLHttpRequest,\n  url: string,\n  options?: RequestOptions\n) {\n  if (url.indexOf(\"data/v\") === -1) {\n    return;\n  }\n  // set format\n  const requestFormat: DataFormats =\n    options.format !== undefined\n      ? domoFormatToRequestFormat(options.format)\n      : DataFormats.DEFAULT;\n\n  req.setRequestHeader(\"Accept\", requestFormat);\n}\n\nfunction setContentHeaders(req: XMLHttpRequest, options?: RequestOptions) {\n  if (options.contentType) {\n    // set content type if user passed option\n    if (options.contentType !== \"multipart\") {\n      req.setRequestHeader(\"Content-Type\", options.contentType);\n    }\n  } else {\n    req.setRequestHeader(\"Content-Type\", DataFormats.JSON);\n  }\n}\n\nfunction setAuthTokenHeader(req: XMLHttpRequest) {\n  if (token) {\n    req.setRequestHeader(\"X-DOMO-Ryuu-Session\", token);\n  }\n}\n\nfunction setResponseType(req: XMLHttpRequest, options?: RequestOptions) {\n  //set response type if user passed option\n  if (options.responseType !== undefined) {\n    req.responseType = options.responseType;\n  }\n}\n\nfunction handleNode(node: HTMLElement) {\n  if (node === document.body || node === document.head)\n    return processBody(node);\n\n  const hrefAttribute =\n    (node.dataset && node.dataset.domoHref) || node.getAttribute(\"href\");\n  const srcAttribute =\n    (node.dataset && node.dataset.domoSrc) || node.getAttribute(\"src\");\n  const attr = hrefAttribute ? \"href\" : \"src\";\n  const url = hrefAttribute || srcAttribute;\n\n  if (!url || !token || url.includes(token)) return;\n\n  const newUrl = new URL(url, document.location.origin);\n  const isRelativeUrl = newUrl.origin === document.location.origin;\n  if (isRelativeUrl) {\n    newUrl.searchParams.append(\"ryuu-sid\", token);\n    node.setAttribute(attr, newUrl.href);\n  }\n}\n\nfunction processBody(node: any) {\n  for (let i = 0; i < node.children.length; i++) {\n    handleNode(<HTMLElement>node.children[i]);\n  }\n}\n\nconst ob = new MutationObserver((mutations) => {\n  for (const record of mutations) {\n    processBody(record.target);\n  }\n});\n\nob.observe(document.body, { childList: true, subtree: true });\nob.observe(document.head, { childList: true, subtree: true });\n","/**\n * Supported `accept` headers for controlling the format\n * of the data returned from Domo.\n *\n * See [developer.domo.com](https://developer.domo.com/docs/dev-studio-references/data-api#Data%20Formats)\n * for more details.\n */\nexport enum DataFormats {\n  DEFAULT = 'application/array-of-objects',\n  ARRAY_OF_OBJECTS = 'application/array-of-objects',\n  JSON = 'application/json',\n  CSV = 'text/csv',\n  EXCEL = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\n  PLAIN = 'text/plain'\n}","export enum RequestMethods {\n  get = 'GET',\n  GET = 'GET',\n  post = 'POST',\n  POST = 'POST',\n  put = 'PUT',\n  PUT = 'PUT',\n  delete = 'DELETE',\n  DELETE = 'DELETE',\n}\n","export { RequestMethods } from './enums/request-methods';\nexport { DomoDataFormats } from './interfaces/domo-data-formats';\nexport { DataFormats } from './enums/data-formats';\nexport { FilterDataTypes } from './interfaces/filter-data-types';\nexport { Filter } from './interfaces/filter';\n\nexport { RequestOptions, ObjectRequestOptions, ArrayRequestOptions } from './interfaces/request-options';\nexport { QueryParams } from './interfaces/query-params';\nexport { RequestBody } from './interfaces/request-body';\nexport { ResponseBody, ObjectResponseBody, ArrayResponseBody } from './interfaces/response-body';\nexport { Json } from './interfaces/json';\n","export enum FilterDataTypes{\n  NUMERIC = \"NUMERIC\",\n  DATE = \"DATE\",\n  DATETIME = \"DATETIME\",\n  STRING = \"STRING\",\n}\n","import { DomoDataFormats, DataFormats } from '../models';\n\nexport function domoFormatToRequestFormat(format: DomoDataFormats): DataFormats {\n  switch (format) {\n    case 'array-of-objects': {\n      return DataFormats.ARRAY_OF_OBJECTS;\n    }\n    case 'array-of-arrays': {\n      return DataFormats.JSON;\n    }\n    case 'excel': {\n      return DataFormats.EXCEL;\n    }\n    case 'csv': {\n      return DataFormats.CSV;\n    }\n    default: {\n      return DataFormats.DEFAULT;\n    }\n  }\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(727);\n"],"names":["root","factory","exports","module","define","amd","self","post","url","body","options","domoHttp","RequestMethods","POST","put","PUT","get","GET","delete","DELETE","getAll","urls","Promise","all","map","domo","onDataUpdate","cb","innerCallback","event","isVerifiedOrigin","origin","data","length","message","JSON","parse","hasOwnProperty","alias","ack","stringify","source","MessagePort","ServiceWorker","postMessage","err","console","warn","window","addEventListener","removeEventListener","navigate","isNewWindow","parent","filterContainer","filters","userAgent","navigator","toLowerCase","safari","test","ios","filter","columnName","column","operator","operand","values","dataType","webkit","messageHandlers","domofilter","connected","listeners","onFiltersUpdate","connect","channel","MessageChannel","port2","callback","index","push","port1","onmessage","e","responsePort","ports","undefined","forEach","splice","env","getQueryParams","__util","setFormatHeaders","isSuccess","token","__RYUU_SID__","method","async","resolve","reject","req","XMLHttpRequest","open","contentType","setRequestHeader","DataFormats","setContentHeaders","setAuthTokenHeader","responseType","setResponseType","onload","status","includes","format","response","Blob","type","getResponseHeader","responseStr","ex","Error","statusText","onerror","send","json","whitelisted","match","blacklisted","query","location","search","substr","result","split","part","item","decodeURIComponent","indexOf","requestFormat","domoFormatToRequestFormat","DEFAULT","handleNode","node","document","head","processBody","hrefAttribute","dataset","domoHref","getAttribute","srcAttribute","domoSrc","attr","newUrl","URL","searchParams","append","setAttribute","href","i","children","ob","MutationObserver","mutations","target","observe","childList","subtree","FilterDataTypes","ARRAY_OF_OBJECTS","EXCEL","CSV","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__"],"sourceRoot":""}
/*!
* domo.js v4.3.1
* domo.js v4.4.0
* Optional utility library for Custom Apps
*/
{
"name": "ryuu.js",
"version": "4.3.1",
"version": "4.4.0",
"description": "Ryuu JavaScript Utility Library",
"main": "dist/domo.js",
"license": "SEE LICENSE IN LICENSE",
"dependencies": {},
"devDependencies": {
"http-server": "^14.0.0",
"standard-version": "^9.5.0",
"ts-loader": "^9.2.6",
"typescript": "^4.4.4",
"webpack": "^5.60.0",
"webpack": "^5.88.0",
"webpack-cli": "^4.9.1"

@@ -20,5 +22,8 @@ },

"releaseAlpha": "npm run build && npm publish --tag alpha",
"releaseBeta": "npm run build && npm publish --tag beta"
"releaseBeta": "npm run build && npm publish --tag beta",
"bumpAlpha": "npm run build && npm run bump -- --prerelease alpha",
"bumpBeta": "npm run build && npm run bump -- --prerelease beta",
"bump": "standard-version"
},
"author": "Domo"
}
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc