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
3
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.0.0 to 4.0.1

10

dist/domo.d.ts

@@ -1,2 +0,2 @@

import { RequestOptions, ObjectRequestOptions, ArrayRequestOptions, QueryParams, FilterDataTypes, FilterOperators, RequestBody, ResponseBody, ObjectResponseBody, ArrayResponseBody } from './models';
import { RequestOptions, ObjectRequestOptions, ArrayRequestOptions, QueryParams, FilterDataTypes, FilterOperators, RequestBody, ResponseBody, ObjectResponseBody, ArrayResponseBody } from "./models";
export = domo;

@@ -21,3 +21,3 @@ declare class domo {

*/
static onDataUpdate(cb: (alias: string) => void): void;
static onDataUpdate(cb: (alias: string) => void): () => void;
/**

@@ -49,3 +49,3 @@ * Let the domoapp optionally handle other events

values: Date[];
dataType: 'DATE' | 'DATETIME';
dataType: "DATE" | "DATETIME";
} | {

@@ -55,3 +55,3 @@ column: string;

values: number[];
dataType: 'NUMERIC';
dataType: "NUMERIC";
} | {

@@ -61,3 +61,3 @@ column: string;

values: string[];
dataType: 'STRING';
dataType: "STRING";
})[]): void;

@@ -64,0 +64,0 @@ static env: QueryParams;

/*!
* domo.js v4.0.0
* domo.js v4.0.1
* Optional utility library for Custom Apps
*/
!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()}(window,(function(){return function(e){var t={};function n(o){if(t[o])return t[o].exports;var r=t[o]={i:o,l:!1,exports:{}};return e[o].call(r.exports,r,r.exports,n),r.l=!0,r.exports}return n.m=e,n.c=t,n.d=function(e,t,o){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:o})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var o=Object.create(null);if(n.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var r in e)n.d(o,r,function(t){return e[t]}.bind(null,r));return o},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="",n(n.s=1)}([function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var o=n(2);t.RequestMethods=o.RequestMethods;var r=n(3);t.DataFormats=r.DataFormats},function(e,t,n){"use strict";var o=n(0),r=n(4),a=function(){function e(){}return e.post=function(e,t,n){return s(o.RequestMethods.POST,e,n,!0,t)},e.put=function(e,t,n){return s(o.RequestMethods.PUT,e,n,!0,t)},e.get=function(e,t){return s(o.RequestMethods.GET,e,t)},e.delete=function(e,t){return s(o.RequestMethods.DELETE,e,t)},e.getAll=function(t,n){return Promise.all(t.map((function(t){return e.get(t,n)})))},e.onDataUpdate=function(e){window.addEventListener("message",(function(t){if(u(t.origin)&&"string"==typeof t.data&&t.data.length>0)try{var n=JSON.parse(t.data);if(!n.hasOwnProperty("alias"))return;var o=n.alias,r=JSON.stringify({event:"ack",alias:o});t.source instanceof Window&&t.source.postMessage(r,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)}}))},e.navigate=function(e,t){var n=JSON.stringify({event:"navigate",url:e,isNewWindow:t});window.parent.postMessage(n,"*")},e.filterContainer=function(e){var t=window.navigator.userAgent.toLowerCase(),n=/safari/.test(t),o=/iphone|ipod|ipad/.test(t),r=JSON.stringify({event:"filter",filter:e.map((function(e){return{columnName:e.column,operator:e.operator,values:e.values,dataType:e.dataType}}))});o&&!n?window.webkit.messageHandlers.domofilter.postMessage(e.map((function(e){return{column:e.column,operand:e.operator,values:e.values,dataType:e.dataType}}))):window.parent.postMessage(r,"*")},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 n=e.listeners.onFiltersUpdate.push(t)-1;return e.channel.port1.onmessage=function(t){var n=t.ports[0];void 0!==n&&"filtersUpdated"===t.data.event&&e.listeners.onFiltersUpdate.length>0&&(n.postMessage({}),e.listeners.onFiltersUpdate.forEach((function(e){return e(t.data.filters)})))},function(){e.listeners.onFiltersUpdate.splice(n,1)}},e.env=c(),e.__util={isVerifiedOrigin:u,getQueryParams:c,setFormatHeaders:p,isSuccess:i},e}();function s(e,t,n,r,a){return n=n||{},new Promise((function(s,u){var c=new XMLHttpRequest;if(r?c.open(e,t,r):c.open(e,t),p(c,t,n),function(e,t){t.contentType?"multipart"!==t.contentType&&e.setRequestHeader("Content-Type",t.contentType):e.setRequestHeader("Content-Type",o.DataFormats.JSON)}(c,n),function(e,t){void 0!==t.responseType&&(e.responseType=t.responseType)}(c,n),c.onload=function(){var e;if(i(c.status)){!["csv","excel"].includes(n.format)&&c.response||s(c.response),"blob"===n.responseType&&s(new Blob([c.response],{type:c.getResponseHeader("content-type")}));var t=c.response;try{e=JSON.parse(t)}catch(e){return void u(Error("Invalid JSON response"))}s(e)}else u(Error(c.statusText))},c.onerror=function(){u(Error("Network Error"))},a)if(n.contentType&&n.contentType!==o.DataFormats.JSON)c.send(a);else{var d=JSON.stringify(a);c.send(d)}else c.send()}))}function i(e){return e>=200&&e<300}function u(e){var t=e.match("^https?://([^/]+[.])?(domo|domotech|domorig).(com|io)?(/.*)?$"),n=e.match("(.*).(domoapps).(.*)");return!!t&&!n}function c(){var e=location.search.substr(1),t={};return e.split("&").forEach((function(e){var n=e.split("=");t[n[0]]=decodeURIComponent(n[1])})),t}function p(e,t,n){if(-1!==t.indexOf("data/v1")){var a=void 0!==n.format?r.domoFormatToRequestFormat(n.format):o.DataFormats.DEFAULT;e.setRequestHeader("Accept",a)}}e.exports=a},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),function(e){e.get="GET",e.GET="GET",e.post="POST",e.POST="POST",e.put="PUT",e.PUT="PUT",e.delete="DELETE",e.DELETE="DELETE"}(t.RequestMethods||(t.RequestMethods={}))},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),function(e){e.DEFAULT="application/array-of-objects",e.ARRAY_OF_OBJECTS="application/array-of-objects",e.JSON="application/json",e.CSV="text/csv",e.EXCEL="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",e.PLAIN="text/plain"}(t.DataFormats||(t.DataFormats={}))},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var o=n(0);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}}}])}));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://domo/webpack/universalModuleDefinition","webpack://domo/webpack/bootstrap","webpack://domo/./src/models/index.ts","webpack://domo/./src/domo.ts","webpack://domo/./src/models/enums/request-methods.ts","webpack://domo/./src/models/enums/data-formats.ts","webpack://domo/./src/utils/data-helpers.ts"],"names":["root","factory","exports","module","define","amd","window","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","RequestMethods","DataFormats","post","url","body","options","domoHttp","POST","put","PUT","GET","delete","DELETE","getAll","urls","Promise","all","map","domo","onDataUpdate","cb","addEventListener","event","isVerifiedOrigin","origin","data","length","message","JSON","parse","alias","ack","stringify","source","Window","postMessage","err","console","warn","navigate","isNewWindow","parent","filterContainer","filters","userAgent","navigator","toLowerCase","safari","test","ios","filter","columnName","column","operator","values","dataType","webkit","messageHandlers","domofilter","operand","connected","listeners","onFiltersUpdate","connect","channel","MessageChannel","port2","callback","index","push","port1","onmessage","e","responsePort","undefined","forEach","splice","env","getQueryParams","__util","setFormatHeaders","isSuccess","method","async","resolve","reject","req","XMLHttpRequest","open","contentType","setRequestHeader","setContentHeaders","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","ARRAY_OF_OBJECTS","EXCEL","CSV","DEFAULT"],"mappings":"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","file":"domo.js","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})(window, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 1);\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 { FilterOperators } from './interfaces/filter-operators';\n\nexport { RequestOptions, ObjectRequestOptions, ArrayRequestOptions } from './interfaces/request-options';\nexport { QueryParams } from './interfaces/query-params';\nexport { RequestBody, XMLHttpRequestBody } from './interfaces/request-body';\nexport { ResponseBody, ObjectResponseBody, ArrayResponseBody } from './interfaces/response-body';\nexport { Json } from './interfaces/json';\n","import {\n  RequestMethods,\n  RequestOptions,\n  ObjectRequestOptions,\n  ArrayRequestOptions,\n  DataFormats,\n  QueryParams,\n  FilterDataTypes,\n  FilterOperators,\n  RequestBody,\n  XMLHttpRequestBody,\n  ResponseBody,\n  ObjectResponseBody,\n  ArrayResponseBody,\n} from './models';\nimport { domoFormatToRequestFormat } from './utils/data-helpers';\n\nexport = domo;\n\nclass domo {\n  static post(url: string, body?: RequestBody, options?: RequestOptions): Promise<ResponseBody>;\n  static post<T>(url: string, body?: RequestBody, options?: RequestOptions): Promise<T>;\n  static post<T>(url: string, body?: RequestBody, options?: RequestOptions): Promise<T> {\n    return domoHttp<T>(RequestMethods.POST, url, options, true, body);\n  }\n\n  static put(url: string, body?: RequestBody, options?: RequestOptions): Promise<ResponseBody>;\n  static put<T>(url: string, body?: RequestBody, options?: RequestOptions): Promise<T>;\n  static put<T>(url: string, body?: RequestBody, options?: RequestOptions): Promise<T> {\n    return domoHttp<T>(RequestMethods.PUT, url, options, true, body);\n  }\n\n  static get(url: string, options: ObjectRequestOptions): Promise<ObjectResponseBody[]>;\n  static get(url: string, options: ArrayRequestOptions): 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(urls: string[], options: ObjectRequestOptions): Promise<ObjectResponseBody[][]>;\n  static getAll(urls: string[], options: ArrayRequestOptions): Promise<ArrayResponseBody[]>;\n  static getAll(urls: string[], options?: RequestOptions): 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(urls.map(function (url) {\n      return domo.get<T>(url, options);\n    }));\n  };\n\n  /**\n   * Let the domoapp optionally handle its own data updates.\n   */\n  static onDataUpdate(cb: (alias: string) => void) {\n    window.addEventListener('message', function (event: MessageEvent) {\n      if (!isVerifiedOrigin(event.origin))\n        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          if (event.source instanceof Window) {\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 = '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  };\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 (e.data.event === 'filtersUpdated' && domo.listeners.onFiltersUpdate.length > 0) {\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:\n    ({ column: string, operator: FilterOperators, values: (string | number | Date)[], dataType: FilterDataTypes }\n      | { column: string, operator: FilterOperators, values: Date[], dataType: 'DATE' | 'DATETIME' }\n      | { column: string, operator: FilterOperators, values: number[], dataType: 'NUMERIC' }\n      | { column: string, operator: FilterOperators, values: string[], dataType: 'STRING' })[]\n  ): 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: filters.map(filter => ({\n        columnName: filter.column,\n        operator: filter.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.map(filter =>\n          ({ column: filter.column, operand: filter.operator, values: filter.values, 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};\n\nfunction domoHttp(method: RequestMethods, url: string, options: ObjectRequestOptions, async?: boolean, body?: RequestBody): Promise<ObjectResponseBody[]>;\nfunction domoHttp(method: RequestMethods, url: string, options: ArrayRequestOptions, async?: boolean, body?: RequestBody): Promise<ArrayResponseBody>;\nfunction domoHttp(method: RequestMethods, url: string, options: RequestOptions, async?: boolean, body?: RequestBody): Promise<ResponseBody>;\nfunction domoHttp<T>(method: RequestMethods, url: string, options: RequestOptions, async?: boolean, body?: RequestBody): Promise<T>;\nfunction domoHttp(method: RequestMethods, url: string, options: RequestOptions, async?: boolean, body?: RequestBody): Promise<ResponseBody> {\n  options = options || {};\n  return new Promise(function (resolve: (value?: ResponseBody) => void, reject: (reason?: Error) => void) {\n    // Do the usual XHR stuff\n    let req: XMLHttpRequest = new XMLHttpRequest();\n    if (async) {\n      req.open(method, url, async);\n    }\n    else {\n      req.open(method, url);\n    }\n    setFormatHeaders(req, url, options);\n    setContentHeaders(req, options);\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\n        if (['csv', 'excel'].includes(options.format) || !req.response) {\n          resolve(req.response);\n        }\n        if (options.responseType === 'blob') {\n          resolve(new Blob([req.response], { type: req.getResponseHeader('content-type') }));\n        }\n\n        let responseStr = req.response;\n        try {\n          // if(!responseStr) {\n          //   responseStr = \"{}\";\n          // }\n          data = JSON.parse(responseStr);\n        }\n        catch (ex) {\n          reject(Error('Invalid JSON response'));\n          return;\n        }\n        // Resolve the promise with the response text\n        resolve(data);\n      }\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 XMLHttpRequestBody);\n      }\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('^https?://([^/]+[.])?(domo|domotech|domorig)\\.(com|io)?(/.*)?$');\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(req: XMLHttpRequest, url: string, options?: RequestOptions) {\n  if (url.indexOf('data/v1') === -1) { return; }\n  // set format\n  const requestFormat: DataFormats = (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  }\n  else {\n    req.setRequestHeader('Content-Type', DataFormats.JSON);\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}","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","/**\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}","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"],"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()}(window,(function(){return function(e){var t={};function n(r){if(t[r])return t[r].exports;var o=t[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,n),o.l=!0,o.exports}return n.m=e,n.c=t,n.d=function(e,t,r){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var o in e)n.d(r,o,function(t){return e[t]}.bind(null,o));return r},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="",n(n.s=1)}([function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=n(2);t.RequestMethods=r.RequestMethods;var o=n(3);t.DataFormats=o.DataFormats},function(e,t,n){"use strict";var r=n(0),o=n(4),a=function(){function e(){}return e.post=function(e,t,n){return i(r.RequestMethods.POST,e,n,!0,t)},e.put=function(e,t,n){return i(r.RequestMethods.PUT,e,n,!0,t)},e.get=function(e,t){return i(r.RequestMethods.GET,e,t)},e.delete=function(e,t){return i(r.RequestMethods.DELETE,e,t)},e.getAll=function(t,n){return Promise.all(t.map((function(t){return e.get(t,n)})))},e.onDataUpdate=function(e){function t(t){if(c(t.origin)&&"string"==typeof t.data&&t.data.length>0)try{var n=JSON.parse(t.data);if(!n.hasOwnProperty("alias"))return;var r=n.alias,o=JSON.stringify({event:"ack",alias:r});t.source instanceof Window&&t.source.postMessage(o,t.origin),e(r)}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 n=JSON.stringify({event:"navigate",url:e,isNewWindow:t});window.parent.postMessage(n,"*")},e.filterContainer=function(e){var t=window.navigator.userAgent.toLowerCase(),n=/safari/.test(t),r=/iphone|ipod|ipad/.test(t),o=JSON.stringify({event:"filter",filter:e.map((function(e){return{columnName:e.column,operator:e.operator,values:e.values,dataType:e.dataType}}))});r&&!n?window.webkit.messageHandlers.domofilter.postMessage(e.map((function(e){return{column:e.column,operand:e.operator,values:e.values,dataType:e.dataType}}))):window.parent.postMessage(o,"*")},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 n=e.listeners.onFiltersUpdate.push(t)-1;return e.channel.port1.onmessage=function(t){var n=t.ports[0];void 0!==n&&"filtersUpdated"===t.data.event&&e.listeners.onFiltersUpdate.length>0&&(n.postMessage({}),e.listeners.onFiltersUpdate.forEach((function(e){return e(t.data.filters)})))},function(){e.listeners.onFiltersUpdate.splice(n,1)}},e.env=d(),e.__util={isVerifiedOrigin:c,getQueryParams:d,setFormatHeaders:f,isSuccess:u},e}(),s=window.__RYUU_AUTHENTICATION_TOKEN__;function i(e,t,n,o,a){return n=n||{},new Promise((function(i,c){var d=new XMLHttpRequest;if(o?d.open(e,t,o):d.open(e,t),f(d,t,n),function(e,t){t.contentType?"multipart"!==t.contentType&&e.setRequestHeader("Content-Type",t.contentType):e.setRequestHeader("Content-Type",r.DataFormats.JSON)}(d,n),function(e){s&&e.setRequestHeader("X-DOMO-Ryuu-Token",s)}(d),function(e,t){void 0!==t.responseType&&(e.responseType=t.responseType)}(d,n),d.onload=function(){var e;if(u(d.status)){!["csv","excel"].includes(n.format)&&d.response||i(d.response),"blob"===n.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(n.contentType&&n.contentType!==r.DataFormats.JSON)d.send(a);else{var p=JSON.stringify(a);d.send(p)}else d.send()}))}function u(e){return e>=200&&e<300}function c(e){var t=e.match("^https?://([^/]+[.])?(domo|domotech|domorig).(com|io)?(/.*)?$"),n=e.match("(.*).(domoapps).(.*)");return!!t&&!n}function d(){var e=location.search.substr(1),t={};return e.split("&").forEach((function(e){var n=e.split("=");t[n[0]]=decodeURIComponent(n[1])})),t}function f(e,t,n){if(-1!==t.indexOf("data/v1")){var a=void 0!==n.format?o.domoFormatToRequestFormat(n.format):r.DataFormats.DEFAULT;e.setRequestHeader("Accept",a)}}function p(e){if(e===document.body)return function(e){for(var t=0;t<e.children.length;t++)p(e.children[t])}(e);var t,n;if(e.dataset&&e.dataset.domoHref?(t="href",n=e.dataset.domoHref):e.dataset&&e.dataset.domoSrc?(t="src",n=e.dataset.domoSrc):e.hasAttribute&&e.hasAttribute("href")?(t="href",n=e.getAttribute("href")):e.hasAttribute&&e.hasAttribute("src")&&(t="src",n=e.getAttribute("src")),n&&s){var r=new URL(n,document.location.origin);r.origin===document.location.origin&&(r.searchParams.append("rpt",s),e.setAttribute(t,r.href))}}var l=new MutationObserver((function(e){for(var t=0,n=e;t<n.length;t++){n[t].addedNodes.forEach(p)}}));l.observe(document.documentElement,{childList:!0}),l.observe(document.head,{childList:!0}),e.exports=a},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),function(e){e.get="GET",e.GET="GET",e.post="POST",e.POST="POST",e.put="PUT",e.PUT="PUT",e.delete="DELETE",e.DELETE="DELETE"}(t.RequestMethods||(t.RequestMethods={}))},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),function(e){e.DEFAULT="application/array-of-objects",e.ARRAY_OF_OBJECTS="application/array-of-objects",e.JSON="application/json",e.CSV="text/csv",e.EXCEL="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",e.PLAIN="text/plain"}(t.DataFormats||(t.DataFormats={}))},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=n(0);t.domoFormatToRequestFormat=function(e){switch(e){case"array-of-objects":return r.DataFormats.ARRAY_OF_OBJECTS;case"array-of-arrays":return r.DataFormats.JSON;case"excel":return r.DataFormats.EXCEL;case"csv":return r.DataFormats.CSV;default:return r.DataFormats.DEFAULT}}}])}));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://domo/webpack/universalModuleDefinition","webpack://domo/webpack/bootstrap","webpack://domo/./src/models/index.ts","webpack://domo/./src/domo.ts","webpack://domo/./src/models/enums/request-methods.ts","webpack://domo/./src/models/enums/data-formats.ts","webpack://domo/./src/utils/data-helpers.ts"],"names":["root","factory","exports","module","define","amd","window","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","RequestMethods","DataFormats","post","url","body","options","domoHttp","POST","put","PUT","GET","delete","DELETE","getAll","urls","Promise","all","map","domo","onDataUpdate","cb","innerCallback","event","isVerifiedOrigin","origin","data","length","message","JSON","parse","alias","ack","stringify","source","Window","postMessage","err","console","warn","addEventListener","removeEventListener","navigate","isNewWindow","parent","filterContainer","filters","userAgent","navigator","toLowerCase","safari","test","ios","filter","columnName","column","operator","values","dataType","webkit","messageHandlers","domofilter","operand","connected","listeners","onFiltersUpdate","connect","channel","MessageChannel","port2","callback","index","push","port1","onmessage","e","responsePort","undefined","forEach","splice","env","getQueryParams","__util","setFormatHeaders","isSuccess","token","__RYUU_AUTHENTICATION_TOKEN__","method","async","resolve","reject","req","XMLHttpRequest","open","contentType","setRequestHeader","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","children","processBody","attr","dataset","domoHref","domoSrc","hasAttribute","getAttribute","newUrl","URL","searchParams","append","setAttribute","href","ob","MutationObserver","mutations","addedNodes","observe","documentElement","childList","head","ARRAY_OF_OBJECTS","EXCEL","CSV"],"mappings":"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","file":"domo.js","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})(window, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 1);\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 { FilterOperators } from './interfaces/filter-operators';\n\nexport { RequestOptions, ObjectRequestOptions, ArrayRequestOptions } from './interfaces/request-options';\nexport { QueryParams } from './interfaces/query-params';\nexport { RequestBody, XMLHttpRequestBody } from './interfaces/request-body';\nexport { ResponseBody, ObjectResponseBody, ArrayResponseBody } from './interfaces/response-body';\nexport { Json } from './interfaces/json';\n","import {\n  RequestMethods,\n  RequestOptions,\n  ObjectRequestOptions,\n  ArrayRequestOptions,\n  DataFormats,\n  QueryParams,\n  FilterDataTypes,\n  FilterOperators,\n  RequestBody,\n  XMLHttpRequestBody,\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          if (event.source instanceof Window) {\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(\n    filters: (\n      | {\n          column: string;\n          operator: FilterOperators;\n          values: (string | number | Date)[];\n          dataType: FilterDataTypes;\n        }\n      | {\n          column: string;\n          operator: FilterOperators;\n          values: Date[];\n          dataType: \"DATE\" | \"DATETIME\";\n        }\n      | {\n          column: string;\n          operator: FilterOperators;\n          values: number[];\n          dataType: \"NUMERIC\";\n        }\n      | {\n          column: string;\n          operator: FilterOperators;\n          values: string[];\n          dataType: \"STRING\";\n        }\n    )[]\n  ): 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: filters.map((filter) => ({\n        columnName: filter.column,\n        operator: filter.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.map((filter) => ({\n          column: filter.column,\n          operand: filter.operator,\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_AUTHENTICATION_TOKEN__;\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 XMLHttpRequestBody);\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/v1\") === -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-Token', token);\n  }\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) {\n    return processBody(node);\n  }\n  let attr;\n  let url;\n  if (node.dataset && node.dataset.domoHref) {\n    attr = 'href';\n    url = node.dataset.domoHref;\n  } else if (node.dataset && node.dataset.domoSrc) {\n    attr = 'src';\n    url = node.dataset.domoSrc;\n  } else if (node.hasAttribute && node.hasAttribute('href')) {\n    attr = 'href';\n    url = node.getAttribute('href');\n  } else if (node.hasAttribute && node.hasAttribute('src')) {\n    attr = 'src';\n    url = node.getAttribute('src');\n  }\n\n  if (url && token) {\n    const newUrl = new URL(url, document.location.origin);\n    const isRelativeUrl = (newUrl).origin === document.location.origin;\n    if (isRelativeUrl) {\n      newUrl.searchParams.append('rpt', token);\n      node.setAttribute(attr, newUrl.href);\n    }\n  }\n};\n\nfunction processBody(node: Element) {\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    record.addedNodes.forEach(handleNode);\n  }\n});\nob.observe(document.documentElement, { childList: true });\nob.observe(document.head, { childList: true });\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","/**\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}","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"],"sourceRoot":""}
{
"name": "ryuu.js",
"version": "4.0.0",
"version": "4.0.1",
"description": "Ryuu JavaScript Utility Library",

@@ -20,2 +20,2 @@ "main": "dist/domo.js",

"author": "Domo"
}
}

@@ -15,4 +15,4 @@ import {

ArrayResponseBody,
} from './models';
import { domoFormatToRequestFormat } from './utils/data-helpers';
} from "./models";
import { domoFormatToRequestFormat } from "./utils/data-helpers";

@@ -22,16 +22,46 @@ export = domo;

class domo {
static post(url: string, body?: RequestBody, options?: RequestOptions): Promise<ResponseBody>;
static post<T>(url: string, body?: RequestBody, options?: RequestOptions): Promise<T>;
static post<T>(url: string, body?: RequestBody, options?: RequestOptions): Promise<T> {
static post(
url: string,
body?: RequestBody,
options?: RequestOptions
): Promise<ResponseBody>;
static post<T>(
url: string,
body?: RequestBody,
options?: RequestOptions
): Promise<T>;
static post<T>(
url: string,
body?: RequestBody,
options?: RequestOptions
): Promise<T> {
return domoHttp<T>(RequestMethods.POST, url, options, true, body);
}
static put(url: string, body?: RequestBody, options?: RequestOptions): Promise<ResponseBody>;
static put<T>(url: string, body?: RequestBody, options?: RequestOptions): Promise<T>;
static put<T>(url: string, body?: RequestBody, options?: RequestOptions): Promise<T> {
static put(
url: string,
body?: RequestBody,
options?: RequestOptions
): Promise<ResponseBody>;
static put<T>(
url: string,
body?: RequestBody,
options?: RequestOptions
): Promise<T>;
static put<T>(
url: string,
body?: RequestBody,
options?: RequestOptions
): Promise<T> {
return domoHttp<T>(RequestMethods.PUT, url, options, true, body);
}
static get(url: string, options: ObjectRequestOptions): Promise<ObjectResponseBody[]>;
static get(url: string, options: ArrayRequestOptions): Promise<ArrayResponseBody>;
static get(
url: string,
options: ObjectRequestOptions
): Promise<ObjectResponseBody[]>;
static get(
url: string,
options: ArrayRequestOptions
): Promise<ArrayResponseBody>;
static get(url: string, options?: RequestOptions): Promise<ResponseBody>;

@@ -49,11 +79,22 @@ static get<T>(url: string, options?: RequestOptions): Promise<T>;

static getAll(urls: string[], options: ObjectRequestOptions): Promise<ObjectResponseBody[][]>;
static getAll(urls: string[], options: ArrayRequestOptions): Promise<ArrayResponseBody[]>;
static getAll(urls: string[], options?: RequestOptions): Promise<ResponseBody[]>;
static getAll(
urls: string[],
options: ObjectRequestOptions
): Promise<ObjectResponseBody[][]>;
static getAll(
urls: string[],
options: ArrayRequestOptions
): Promise<ArrayResponseBody[]>;
static getAll(
urls: string[],
options?: RequestOptions
): Promise<ResponseBody[]>;
static getAll<T>(urls: string[], options?: RequestOptions): Promise<T[]>;
static getAll<T>(urls: string[], options?: RequestOptions): Promise<T[]> {
return Promise.all(urls.map(function (url) {
return domo.get<T>(url, options);
}));
};
return Promise.all(
urls.map(function (url) {
return domo.get<T>(url, options);
})
);
}

@@ -64,10 +105,9 @@ /**

static onDataUpdate(cb: (alias: string) => void) {
window.addEventListener('message', function (event: MessageEvent) {
if (!isVerifiedOrigin(event.origin))
return;
function innerCallback(event: MessageEvent) {
if (!isVerifiedOrigin(event.origin)) return;
if (typeof event.data === 'string' && event.data.length > 0) {
if (typeof event.data === "string" && event.data.length > 0) {
try {
const message = JSON.parse(event.data);
if (!message.hasOwnProperty('alias')) {
if (!message.hasOwnProperty("alias")) {
return;

@@ -80,3 +120,3 @@ }

const ack = JSON.stringify({
event: 'ack',
event: "ack",
alias: alias,

@@ -91,10 +131,13 @@ });

} catch (err) {
const info = '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'
const info =
"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";
console.warn(info, err);
}
}
});
};
}
window.addEventListener("message", innerCallback);
return () => window.removeEventListener("message", innerCallback);
}

@@ -114,3 +157,3 @@ /**

domo.channel = new MessageChannel();
window.parent.postMessage(JSON.stringify({ event: 'subscribe' }), '*', [
window.parent.postMessage(JSON.stringify({ event: "subscribe" }), "*", [
domo.channel.port2,

@@ -131,3 +174,6 @@ ]);

if (e.data.event === 'filtersUpdated' && domo.listeners.onFiltersUpdate.length > 0) {
if (
e.data.event === "filtersUpdated" &&
domo.listeners.onFiltersUpdate.length > 0
) {
responsePort.postMessage({}); // Prevents the app from reloading. Says we've handled it

@@ -149,5 +195,5 @@ domo.listeners.onFiltersUpdate.forEach((cb) => cb(e.data.filters)); // <- split out onFiltersUpdate so that you can handle each message differently here

const message = JSON.stringify({
event: 'navigate',
event: "navigate",
url: url,
isNewWindow: isNewWindow
isNewWindow: isNewWindow,
});

@@ -157,7 +203,29 @@ window.parent.postMessage(message, "*");

static filterContainer(filters:
({ column: string, operator: FilterOperators, values: (string | number | Date)[], dataType: FilterDataTypes }
| { column: string, operator: FilterOperators, values: Date[], dataType: 'DATE' | 'DATETIME' }
| { column: string, operator: FilterOperators, values: number[], dataType: 'NUMERIC' }
| { column: string, operator: FilterOperators, values: string[], dataType: 'STRING' })[]
static filterContainer(
filters: (
| {
column: string;
operator: FilterOperators;
values: (string | number | Date)[];
dataType: FilterDataTypes;
}
| {
column: string;
operator: FilterOperators;
values: Date[];
dataType: "DATE" | "DATETIME";
}
| {
column: string;
operator: FilterOperators;
values: number[];
dataType: "NUMERIC";
}
| {
column: string;
operator: FilterOperators;
values: string[];
dataType: "STRING";
}
)[]
): void {

@@ -169,9 +237,9 @@ const userAgent = window.navigator.userAgent.toLowerCase(),

const message = JSON.stringify({
event: 'filter',
filter: filters.map(filter => ({
event: "filter",
filter: filters.map((filter) => ({
columnName: filter.column,
operator: filter.operator,
values: filter.values,
dataType: filter.dataType
}))
dataType: filter.dataType,
})),
});

@@ -181,7 +249,10 @@

(window as any).webkit.messageHandlers.domofilter.postMessage(
filters.map(filter =>
({ column: filter.column, operand: filter.operator, values: filter.values, dataType: filter.dataType }))
filters.map((filter) => ({
column: filter.column,
operand: filter.operator,
values: filter.values,
dataType: filter.dataType,
}))
);
}
else {
} else {
window.parent.postMessage(message, "*");

@@ -197,14 +268,48 @@ }

setFormatHeaders,
isSuccess
}
isSuccess,
};
}
};
const token = (window as any).__RYUU_AUTHENTICATION_TOKEN__;
function domoHttp(method: RequestMethods, url: string, options: ObjectRequestOptions, async?: boolean, body?: RequestBody): Promise<ObjectResponseBody[]>;
function domoHttp(method: RequestMethods, url: string, options: ArrayRequestOptions, async?: boolean, body?: RequestBody): Promise<ArrayResponseBody>;
function domoHttp(method: RequestMethods, url: string, options: RequestOptions, async?: boolean, body?: RequestBody): Promise<ResponseBody>;
function domoHttp<T>(method: RequestMethods, url: string, options: RequestOptions, async?: boolean, body?: RequestBody): Promise<T>;
function domoHttp(method: RequestMethods, url: string, options: RequestOptions, async?: boolean, body?: RequestBody): Promise<ResponseBody> {
function domoHttp(
method: RequestMethods,
url: string,
options: ObjectRequestOptions,
async?: boolean,
body?: RequestBody
): Promise<ObjectResponseBody[]>;
function domoHttp(
method: RequestMethods,
url: string,
options: ArrayRequestOptions,
async?: boolean,
body?: RequestBody
): Promise<ArrayResponseBody>;
function domoHttp(
method: RequestMethods,
url: string,
options: RequestOptions,
async?: boolean,
body?: RequestBody
): Promise<ResponseBody>;
function domoHttp<T>(
method: RequestMethods,
url: string,
options: RequestOptions,
async?: boolean,
body?: RequestBody
): Promise<T>;
function domoHttp(
method: RequestMethods,
url: string,
options: RequestOptions,
async?: boolean,
body?: RequestBody
): Promise<ResponseBody> {
options = options || {};
return new Promise(function (resolve: (value?: ResponseBody) => void, reject: (reason?: Error) => void) {
return new Promise(function (
resolve: (value?: ResponseBody) => void,
reject: (reason?: Error) => void
) {
// Do the usual XHR stuff

@@ -214,4 +319,3 @@ let req: XMLHttpRequest = new XMLHttpRequest();

req.open(method, url, async);
}
else {
} else {
req.open(method, url);

@@ -221,2 +325,3 @@ }

setContentHeaders(req, options);
setAuthTokenHeader(req);
setResponseType(req, options);

@@ -228,8 +333,11 @@

if (isSuccess(req.status)) {
if (['csv', 'excel'].includes(options.format) || !req.response) {
if (["csv", "excel"].includes(options.format) || !req.response) {
resolve(req.response);
}
if (options.responseType === 'blob') {
resolve(new Blob([req.response], { type: req.getResponseHeader('content-type') }));
if (options.responseType === "blob") {
resolve(
new Blob([req.response], {
type: req.getResponseHeader("content-type"),
})
);
}

@@ -243,5 +351,4 @@

data = JSON.parse(responseStr);
}
catch (ex) {
reject(Error('Invalid JSON response'));
} catch (ex) {
reject(Error("Invalid JSON response"));
return;

@@ -251,4 +358,3 @@ }

resolve(data);
}
else {
} else {
// Otherwise reject with the status text

@@ -275,4 +381,3 @@ // which will hopefully be a meaningful error

}
}
else {
} else {
req.send();

@@ -288,4 +393,6 @@ }

function isVerifiedOrigin(origin: string) {
const whitelisted = origin.match('^https?://([^/]+[.])?(domo|domotech|domorig)\.(com|io)?(/.*)?$');
const blacklisted = origin.match('(.*)\.(domoapps)\.(.*)');
const whitelisted = origin.match(
"^https?://([^/]+[.])?(domo|domotech|domorig).(com|io)?(/.*)?$"
);
const blacklisted = origin.match("(.*).(domoapps).(.*)");
return !!whitelisted && !blacklisted;

@@ -304,10 +411,17 @@ }

function setFormatHeaders(req: XMLHttpRequest, url: string, options?: RequestOptions) {
if (url.indexOf('data/v1') === -1) { return; }
function setFormatHeaders(
req: XMLHttpRequest,
url: string,
options?: RequestOptions
) {
if (url.indexOf("data/v1") === -1) {
return;
}
// set format
const requestFormat: DataFormats = (options.format !== undefined)
? (domoFormatToRequestFormat(options.format))
: (DataFormats.DEFAULT);
const requestFormat: DataFormats =
options.format !== undefined
? domoFormatToRequestFormat(options.format)
: DataFormats.DEFAULT;
req.setRequestHeader('Accept', requestFormat);
req.setRequestHeader("Accept", requestFormat);
}

@@ -318,11 +432,17 @@

// set content type if user passed option
if (options.contentType !== 'multipart') {
req.setRequestHeader('Content-Type', options.contentType);
if (options.contentType !== "multipart") {
req.setRequestHeader("Content-Type", options.contentType);
}
} else {
req.setRequestHeader("Content-Type", DataFormats.JSON);
}
else {
req.setRequestHeader('Content-Type', DataFormats.JSON);
}
function setAuthTokenHeader(req: XMLHttpRequest) {
if (token) {
req.setRequestHeader('X-DOMO-Ryuu-Token', token);
}
}
function setResponseType(req: XMLHttpRequest, options?: RequestOptions) {

@@ -333,2 +453,46 @@ //set response type if user passed option

}
}
}
function handleNode(node: HTMLElement){
if (node === document.body) {
return processBody(node);
}
let attr;
let url;
if (node.dataset && node.dataset.domoHref) {
attr = 'href';
url = node.dataset.domoHref;
} else if (node.dataset && node.dataset.domoSrc) {
attr = 'src';
url = node.dataset.domoSrc;
} else if (node.hasAttribute && node.hasAttribute('href')) {
attr = 'href';
url = node.getAttribute('href');
} else if (node.hasAttribute && node.hasAttribute('src')) {
attr = 'src';
url = node.getAttribute('src');
}
if (url && token) {
const newUrl = new URL(url, document.location.origin);
const isRelativeUrl = (newUrl).origin === document.location.origin;
if (isRelativeUrl) {
newUrl.searchParams.append('rpt', token);
node.setAttribute(attr, newUrl.href);
}
}
};
function processBody(node: Element) {
for (let i = 0; i < node.children.length; i++) {
handleNode(<HTMLElement>node.children[i]);
}
}
const ob = new MutationObserver((mutations) => {
for (const record of mutations) {
record.addedNodes.forEach(handleNode);
}
});
ob.observe(document.documentElement, { childList: true });
ob.observe(document.head, { childList: true });
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