zdk 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,4 @@
1
+ var m=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(r,e)=>(typeof require<"u"?require:r)[e]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var g=(t,r)=>()=>(r||t((r={exports:{}}).exports,r),r.exports);var D=g((re,q)=>{q.exports={name:"dotenv",version:"16.3.1",description:"Loads environment variables from .env file",main:"lib/main.js",types:"lib/main.d.ts",exports:{".":{types:"./lib/main.d.ts",require:"./lib/main.js",default:"./lib/main.js"},"./config":"./config.js","./config.js":"./config.js","./lib/env-options":"./lib/env-options.js","./lib/env-options.js":"./lib/env-options.js","./lib/cli-options":"./lib/cli-options.js","./lib/cli-options.js":"./lib/cli-options.js","./package.json":"./package.json"},scripts:{"dts-check":"tsc --project tests/types/tsconfig.json",lint:"standard","lint-readme":"standard-markdown",pretest:"npm run lint && npm run dts-check",test:"tap tests/*.js --100 -Rspec",prerelease:"npm test",release:"standard-version"},repository:{type:"git",url:"git://github.com/motdotla/dotenv.git"},funding:"https://github.com/motdotla/dotenv?sponsor=1",keywords:["dotenv","env",".env","environment","variables","config","settings"],readmeFilename:"README.md",license:"BSD-2-Clause",devDependencies:{"@definitelytyped/dtslint":"^0.0.133","@types/node":"^18.11.3",decache:"^4.6.1",sinon:"^14.0.1",standard:"^17.0.0","standard-markdown":"^7.1.0","standard-version":"^9.5.0",tap:"^16.3.0",tar:"^6.1.11",typescript:"^4.8.4"},engines:{node:">=12"},browser:{fs:!1}}});var $=g((te,u)=>{var O=m("fs"),N=m("path"),A=m("os"),G=m("crypto"),j=D(),w=j.version,S=/(?:^|^)\s*(?:export\s+)?([\w.-]+)(?:\s*=\s*?|:\s+?)(\s*'(?:\\'|[^'])*'|\s*"(?:\\"|[^"])*"|\s*`(?:\\`|[^`])*`|[^#\r\n]+)?\s*(?:#.*)?(?:$|$)/mg;function M(t){let r={},e=t.toString();e=e.replace(/\r\n?/mg,`
2
+ `);let s;for(;(s=S.exec(e))!=null;){let o=s[1],n=s[2]||"";n=n.trim();let i=n[0];n=n.replace(/^(['"`])([\s\S]*)\1$/mg,"$2"),i==='"'&&(n=n.replace(/\\n/g,`
3
+ `),n=n.replace(/\\r/g,"\r")),r[o]=n}return r}function z(t){let r=L(t),e=a.configDotenv({path:r});if(!e.parsed)throw new Error(`MISSING_DATA: Cannot parse ${r} for an unknown reason`);let s=k(t).split(","),o=s.length,n;for(let i=0;i<o;i++)try{let c=s[i].trim(),p=Y(e,c);n=a.decrypt(p.ciphertext,p.key);break}catch(c){if(i+1>=o)throw c}return a.parse(n)}function F(t){console.log(`[dotenv@${w}][INFO] ${t}`)}function K(t){console.log(`[dotenv@${w}][WARN] ${t}`)}function T(t){console.log(`[dotenv@${w}][DEBUG] ${t}`)}function k(t){return t&&t.DOTENV_KEY&&t.DOTENV_KEY.length>0?t.DOTENV_KEY:process.env.DOTENV_KEY&&process.env.DOTENV_KEY.length>0?process.env.DOTENV_KEY:""}function Y(t,r){let e;try{e=new URL(r)}catch(c){throw c.code==="ERR_INVALID_URL"?new Error("INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenv.org/vault/.env.vault?environment=development"):c}let s=e.password;if(!s)throw new Error("INVALID_DOTENV_KEY: Missing key part");let o=e.searchParams.get("environment");if(!o)throw new Error("INVALID_DOTENV_KEY: Missing environment part");let n=`DOTENV_VAULT_${o.toUpperCase()}`,i=t.parsed[n];if(!i)throw new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${n} in your .env.vault file.`);return{ciphertext:i,key:s}}function L(t){let r=N.resolve(process.cwd(),".env");return t&&t.path&&t.path.length>0&&(r=t.path),r.endsWith(".vault")?r:`${r}.vault`}function Z(t){return t[0]==="~"?N.join(A.homedir(),t.slice(1)):t}function B(t){F("Loading env from encrypted .env.vault");let r=a._parseVault(t),e=process.env;return t&&t.processEnv!=null&&(e=t.processEnv),a.populate(e,r,t),{parsed:r}}function Q(t){let r=N.resolve(process.cwd(),".env"),e="utf8",s=!!(t&&t.debug);t&&(t.path!=null&&(r=Z(t.path)),t.encoding!=null&&(e=t.encoding));try{let o=a.parse(O.readFileSync(r,{encoding:e})),n=process.env;return t&&t.processEnv!=null&&(n=t.processEnv),a.populate(n,o,t),{parsed:o}}catch(o){return s&&T(`Failed to load ${r} ${o.message}`),{error:o}}}function H(t){let r=L(t);return k(t).length===0?a.configDotenv(t):O.existsSync(r)?a._configVault(t):(K(`You set DOTENV_KEY but you are missing a .env.vault file at ${r}. Did you forget to build it?`),a.configDotenv(t))}function W(t,r){let e=Buffer.from(r.slice(-64),"hex"),s=Buffer.from(t,"base64"),o=s.slice(0,12),n=s.slice(-16);s=s.slice(12,-16);try{let i=G.createDecipheriv("aes-256-gcm",e,o);return i.setAuthTag(n),`${i.update(s)}${i.final()}`}catch(i){let c=i instanceof RangeError,p=i.message==="Invalid key length",U=i.message==="Unsupported state or unable to authenticate data";if(c||p){let _="INVALID_DOTENV_KEY: It must be 64 characters long (or more)";throw new Error(_)}else if(U){let _="DECRYPTION_FAILED: Please check your DOTENV_KEY";throw new Error(_)}else throw console.error("Error: ",i.code),console.error("Error: ",i.message),i}}function J(t,r,e={}){let s=!!(e&&e.debug),o=!!(e&&e.override);if(typeof r!="object")throw new Error("OBJECT_REQUIRED: Please check the processEnv argument being passed to populate");for(let n of Object.keys(r))Object.prototype.hasOwnProperty.call(t,n)?(o===!0&&(t[n]=r[n]),s&&T(o===!0?`"${n}" is already defined and WAS overwritten`:`"${n}" is already defined and was NOT overwritten`)):t[n]=r[n]}var a={configDotenv:Q,_configVault:B,_parseVault:z,config:H,decrypt:W,parse:M,populate:J};u.exports.configDotenv=a.configDotenv;u.exports._configVault=a._configVault;u.exports._parseVault=a._parseVault;u.exports.config=a.config;u.exports.decrypt=a.decrypt;u.exports.parse=a.parse;u.exports.populate=a.populate;u.exports=a});var C=g((oe,V)=>{var l={};process.env.DOTENV_CONFIG_ENCODING!=null&&(l.encoding=process.env.DOTENV_CONFIG_ENCODING);process.env.DOTENV_CONFIG_PATH!=null&&(l.path=process.env.DOTENV_CONFIG_PATH);process.env.DOTENV_CONFIG_DEBUG!=null&&(l.debug=process.env.DOTENV_CONFIG_DEBUG);process.env.DOTENV_CONFIG_OVERRIDE!=null&&(l.override=process.env.DOTENV_CONFIG_OVERRIDE);process.env.DOTENV_CONFIG_DOTENV_KEY!=null&&(l.DOTENV_KEY=process.env.DOTENV_CONFIG_DOTENV_KEY);V.exports=l});var x=g((se,P)=>{var X=/^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/;P.exports=function(r){return r.reduce(function(e,s){let o=s.match(X);return o&&(e[o[1]]=o[2]),e},{})}});(function(){$().config(Object.assign({},C(),x()(process.argv)))})();var f=class{_rootUrl;_token;constructor(r,e){this._rootUrl=r,this._token=e}async makeRequest(r,e,s,o){let n=this._rootUrl+e,i={method:r,headers:{Authorization:`Bearer ${this._token}`,"Content-Type":o??"application/json"},body:s?typeof s=="string"?s:JSON.stringify(s):void 0};return await(await fetch(n,i)).json()}};var d=class{constructor(r){this.api=r}async list(){try{return await this.api.makeRequest("GET","/api/connections")}catch(r){return console.error(r),{error:"Unable to list connections"}}}async get(r){try{let s=(await this.api.makeRequest("GET","/api/connections"))?.connections,o=s.find(n=>n.id===r);if(!o||o?.status!=="CONNECTED"){let n=s?.find(i=>i?.status==="CONNECTED");return n||{error:"Connection not found"}}}catch(e){return console.error(e),{error:"Unable to connection"}}}};var E=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:s=20}=r||{},o=await this.api.makeRequest("GET",`/api/contacts?page=${e}&pageSize=${s}`);return o?.error?{error:o?.error}:o}catch(e){return console.error(e),{error:"Unable to list contacts"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/contacts/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to contact"}}}};var I=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:s=20,ticketId:o="",contactId:n="",dateFrom:i="",dateTo:c=""}=r||{},p=await this.api.makeRequest("GET",`/api/messages?page=${e}&pageSize=${s}&ticketId=${o}&contactId=${n}&dateFrom=${i}&dateToo=${c}`);return p?.error?{error:p?.error}:p}catch(e){return console.error(e),{error:"Unable to list message"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/messages/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to message"}}}async send(r,e,s){try{if(!s||s==="text")return await this.api.makeRequest("POST",`/api/messages/${r}`,e)}catch(o){return console.error(o),{error:"Cannot send message"}}}};var y=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:s=20}=r||{},o=await this.api.makeRequest("GET",`/api/queues?page=${e}&pageSize=${s}`);return o?.error?{error:o?.error}:o}catch(e){return console.error(e),{error:"Unable to list queues"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/queues/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to queue"}}}};var h=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:s=20}=r||{},o=await this.api.makeRequest("GET",`/api/tags?page=${e}&pageSize=${s}`);return o?.error?{error:o?.error}:o}catch(e){return console.error(e),{error:"Unable to list tags"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/tags/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to tag"}}}};var v=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:s=20}=r||{},o=await this.api.makeRequest("GET",`/api/users?page=${e}&pageSize=${s}`);return o?.error?{error:o?.error}:o}catch(e){return console.error(e),{error:"Unable to list users"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/users/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to user"}}}};var b=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:s=20}=r||{},o=await this.api.makeRequest("GET",`/api/tickets?page=${e}&pageSize=${s}`);return o?.error?{error:o?.error}:o}catch(e){return console.error(e),{error:"Unable to list tickets"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/tickets/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to ticket"}}}};var R=class extends f{tickets=new b(this);connections=new d(this);contacts=new E(this);messages=new I(this);queues=new y(this);tags=new h(this);users=new v(this)};export{R as Zdk};
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../node_modules/dotenv/package.json","../../node_modules/dotenv/lib/main.js","../../node_modules/dotenv/lib/env-options.js","../../node_modules/dotenv/lib/cli-options.js","../../node_modules/dotenv/config.js","../../src/zap-api.ts","../../src/lib/connection.ts","../../src/lib/contact.ts","../../src/lib/message.ts","../../src/lib/queue.ts","../../src/lib/tag.ts","../../src/lib/user.ts","../../src/lib/ticket.ts","../../src/zdk.ts"],"sourcesContent":["{\n \"name\": \"dotenv\",\n \"version\": \"16.3.1\",\n \"description\": \"Loads environment variables from .env file\",\n \"main\": \"lib/main.js\",\n \"types\": \"lib/main.d.ts\",\n \"exports\": {\n \".\": {\n \"types\": \"./lib/main.d.ts\",\n \"require\": \"./lib/main.js\",\n \"default\": \"./lib/main.js\"\n },\n \"./config\": \"./config.js\",\n \"./config.js\": \"./config.js\",\n \"./lib/env-options\": \"./lib/env-options.js\",\n \"./lib/env-options.js\": \"./lib/env-options.js\",\n \"./lib/cli-options\": \"./lib/cli-options.js\",\n \"./lib/cli-options.js\": \"./lib/cli-options.js\",\n \"./package.json\": \"./package.json\"\n },\n \"scripts\": {\n \"dts-check\": \"tsc --project tests/types/tsconfig.json\",\n \"lint\": \"standard\",\n \"lint-readme\": \"standard-markdown\",\n \"pretest\": \"npm run lint && npm run dts-check\",\n \"test\": \"tap tests/*.js --100 -Rspec\",\n \"prerelease\": \"npm test\",\n \"release\": \"standard-version\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git://github.com/motdotla/dotenv.git\"\n },\n \"funding\": \"https://github.com/motdotla/dotenv?sponsor=1\",\n \"keywords\": [\n \"dotenv\",\n \"env\",\n \".env\",\n \"environment\",\n \"variables\",\n \"config\",\n \"settings\"\n ],\n \"readmeFilename\": \"README.md\",\n \"license\": \"BSD-2-Clause\",\n \"devDependencies\": {\n \"@definitelytyped/dtslint\": \"^0.0.133\",\n \"@types/node\": \"^18.11.3\",\n \"decache\": \"^4.6.1\",\n \"sinon\": \"^14.0.1\",\n \"standard\": \"^17.0.0\",\n \"standard-markdown\": \"^7.1.0\",\n \"standard-version\": \"^9.5.0\",\n \"tap\": \"^16.3.0\",\n \"tar\": \"^6.1.11\",\n \"typescript\": \"^4.8.4\"\n },\n \"engines\": {\n \"node\": \">=12\"\n },\n \"browser\": {\n \"fs\": false\n }\n}\n","const fs = require('fs')\nconst path = require('path')\nconst os = require('os')\nconst crypto = require('crypto')\nconst packageJson = require('../package.json')\n\nconst version = packageJson.version\n\nconst LINE = /(?:^|^)\\s*(?:export\\s+)?([\\w.-]+)(?:\\s*=\\s*?|:\\s+?)(\\s*'(?:\\\\'|[^'])*'|\\s*\"(?:\\\\\"|[^\"])*\"|\\s*`(?:\\\\`|[^`])*`|[^#\\r\\n]+)?\\s*(?:#.*)?(?:$|$)/mg\n\n// Parse src into an Object\nfunction parse (src) {\n const obj = {}\n\n // Convert buffer to string\n let lines = src.toString()\n\n // Convert line breaks to same format\n lines = lines.replace(/\\r\\n?/mg, '\\n')\n\n let match\n while ((match = LINE.exec(lines)) != null) {\n const key = match[1]\n\n // Default undefined or null to empty string\n let value = (match[2] || '')\n\n // Remove whitespace\n value = value.trim()\n\n // Check if double quoted\n const maybeQuote = value[0]\n\n // Remove surrounding quotes\n value = value.replace(/^(['\"`])([\\s\\S]*)\\1$/mg, '$2')\n\n // Expand newlines if double quoted\n if (maybeQuote === '\"') {\n value = value.replace(/\\\\n/g, '\\n')\n value = value.replace(/\\\\r/g, '\\r')\n }\n\n // Add to object\n obj[key] = value\n }\n\n return obj\n}\n\nfunction _parseVault (options) {\n const vaultPath = _vaultPath(options)\n\n // Parse .env.vault\n const result = DotenvModule.configDotenv({ path: vaultPath })\n if (!result.parsed) {\n throw new Error(`MISSING_DATA: Cannot parse ${vaultPath} for an unknown reason`)\n }\n\n // handle scenario for comma separated keys - for use with key rotation\n // example: DOTENV_KEY=\"dotenv://:key_1234@dotenv.org/vault/.env.vault?environment=prod,dotenv://:key_7890@dotenv.org/vault/.env.vault?environment=prod\"\n const keys = _dotenvKey(options).split(',')\n const length = keys.length\n\n let decrypted\n for (let i = 0; i < length; i++) {\n try {\n // Get full key\n const key = keys[i].trim()\n\n // Get instructions for decrypt\n const attrs = _instructions(result, key)\n\n // Decrypt\n decrypted = DotenvModule.decrypt(attrs.ciphertext, attrs.key)\n\n break\n } catch (error) {\n // last key\n if (i + 1 >= length) {\n throw error\n }\n // try next key\n }\n }\n\n // Parse decrypted .env string\n return DotenvModule.parse(decrypted)\n}\n\nfunction _log (message) {\n console.log(`[dotenv@${version}][INFO] ${message}`)\n}\n\nfunction _warn (message) {\n console.log(`[dotenv@${version}][WARN] ${message}`)\n}\n\nfunction _debug (message) {\n console.log(`[dotenv@${version}][DEBUG] ${message}`)\n}\n\nfunction _dotenvKey (options) {\n // prioritize developer directly setting options.DOTENV_KEY\n if (options && options.DOTENV_KEY && options.DOTENV_KEY.length > 0) {\n return options.DOTENV_KEY\n }\n\n // secondary infra already contains a DOTENV_KEY environment variable\n if (process.env.DOTENV_KEY && process.env.DOTENV_KEY.length > 0) {\n return process.env.DOTENV_KEY\n }\n\n // fallback to empty string\n return ''\n}\n\nfunction _instructions (result, dotenvKey) {\n // Parse DOTENV_KEY. Format is a URI\n let uri\n try {\n uri = new URL(dotenvKey)\n } catch (error) {\n if (error.code === 'ERR_INVALID_URL') {\n throw new Error('INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenv.org/vault/.env.vault?environment=development')\n }\n\n throw error\n }\n\n // Get decrypt key\n const key = uri.password\n if (!key) {\n throw new Error('INVALID_DOTENV_KEY: Missing key part')\n }\n\n // Get environment\n const environment = uri.searchParams.get('environment')\n if (!environment) {\n throw new Error('INVALID_DOTENV_KEY: Missing environment part')\n }\n\n // Get ciphertext payload\n const environmentKey = `DOTENV_VAULT_${environment.toUpperCase()}`\n const ciphertext = result.parsed[environmentKey] // DOTENV_VAULT_PRODUCTION\n if (!ciphertext) {\n throw new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${environmentKey} in your .env.vault file.`)\n }\n\n return { ciphertext, key }\n}\n\nfunction _vaultPath (options) {\n let dotenvPath = path.resolve(process.cwd(), '.env')\n\n if (options && options.path && options.path.length > 0) {\n dotenvPath = options.path\n }\n\n // Locate .env.vault\n return dotenvPath.endsWith('.vault') ? dotenvPath : `${dotenvPath}.vault`\n}\n\nfunction _resolveHome (envPath) {\n return envPath[0] === '~' ? path.join(os.homedir(), envPath.slice(1)) : envPath\n}\n\nfunction _configVault (options) {\n _log('Loading env from encrypted .env.vault')\n\n const parsed = DotenvModule._parseVault(options)\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsed, options)\n\n return { parsed }\n}\n\nfunction configDotenv (options) {\n let dotenvPath = path.resolve(process.cwd(), '.env')\n let encoding = 'utf8'\n const debug = Boolean(options && options.debug)\n\n if (options) {\n if (options.path != null) {\n dotenvPath = _resolveHome(options.path)\n }\n if (options.encoding != null) {\n encoding = options.encoding\n }\n }\n\n try {\n // Specifying an encoding returns a string instead of a buffer\n const parsed = DotenvModule.parse(fs.readFileSync(dotenvPath, { encoding }))\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsed, options)\n\n return { parsed }\n } catch (e) {\n if (debug) {\n _debug(`Failed to load ${dotenvPath} ${e.message}`)\n }\n\n return { error: e }\n }\n}\n\n// Populates process.env from .env file\nfunction config (options) {\n const vaultPath = _vaultPath(options)\n\n // fallback to original dotenv if DOTENV_KEY is not set\n if (_dotenvKey(options).length === 0) {\n return DotenvModule.configDotenv(options)\n }\n\n // dotenvKey exists but .env.vault file does not exist\n if (!fs.existsSync(vaultPath)) {\n _warn(`You set DOTENV_KEY but you are missing a .env.vault file at ${vaultPath}. Did you forget to build it?`)\n\n return DotenvModule.configDotenv(options)\n }\n\n return DotenvModule._configVault(options)\n}\n\nfunction decrypt (encrypted, keyStr) {\n const key = Buffer.from(keyStr.slice(-64), 'hex')\n let ciphertext = Buffer.from(encrypted, 'base64')\n\n const nonce = ciphertext.slice(0, 12)\n const authTag = ciphertext.slice(-16)\n ciphertext = ciphertext.slice(12, -16)\n\n try {\n const aesgcm = crypto.createDecipheriv('aes-256-gcm', key, nonce)\n aesgcm.setAuthTag(authTag)\n return `${aesgcm.update(ciphertext)}${aesgcm.final()}`\n } catch (error) {\n const isRange = error instanceof RangeError\n const invalidKeyLength = error.message === 'Invalid key length'\n const decryptionFailed = error.message === 'Unsupported state or unable to authenticate data'\n\n if (isRange || invalidKeyLength) {\n const msg = 'INVALID_DOTENV_KEY: It must be 64 characters long (or more)'\n throw new Error(msg)\n } else if (decryptionFailed) {\n const msg = 'DECRYPTION_FAILED: Please check your DOTENV_KEY'\n throw new Error(msg)\n } else {\n console.error('Error: ', error.code)\n console.error('Error: ', error.message)\n throw error\n }\n }\n}\n\n// Populate process.env with parsed values\nfunction populate (processEnv, parsed, options = {}) {\n const debug = Boolean(options && options.debug)\n const override = Boolean(options && options.override)\n\n if (typeof parsed !== 'object') {\n throw new Error('OBJECT_REQUIRED: Please check the processEnv argument being passed to populate')\n }\n\n // Set process.env\n for (const key of Object.keys(parsed)) {\n if (Object.prototype.hasOwnProperty.call(processEnv, key)) {\n if (override === true) {\n processEnv[key] = parsed[key]\n }\n\n if (debug) {\n if (override === true) {\n _debug(`\"${key}\" is already defined and WAS overwritten`)\n } else {\n _debug(`\"${key}\" is already defined and was NOT overwritten`)\n }\n }\n } else {\n processEnv[key] = parsed[key]\n }\n }\n}\n\nconst DotenvModule = {\n configDotenv,\n _configVault,\n _parseVault,\n config,\n decrypt,\n parse,\n populate\n}\n\nmodule.exports.configDotenv = DotenvModule.configDotenv\nmodule.exports._configVault = DotenvModule._configVault\nmodule.exports._parseVault = DotenvModule._parseVault\nmodule.exports.config = DotenvModule.config\nmodule.exports.decrypt = DotenvModule.decrypt\nmodule.exports.parse = DotenvModule.parse\nmodule.exports.populate = DotenvModule.populate\n\nmodule.exports = DotenvModule\n","// ../config.js accepts options via environment variables\nconst options = {}\n\nif (process.env.DOTENV_CONFIG_ENCODING != null) {\n options.encoding = process.env.DOTENV_CONFIG_ENCODING\n}\n\nif (process.env.DOTENV_CONFIG_PATH != null) {\n options.path = process.env.DOTENV_CONFIG_PATH\n}\n\nif (process.env.DOTENV_CONFIG_DEBUG != null) {\n options.debug = process.env.DOTENV_CONFIG_DEBUG\n}\n\nif (process.env.DOTENV_CONFIG_OVERRIDE != null) {\n options.override = process.env.DOTENV_CONFIG_OVERRIDE\n}\n\nif (process.env.DOTENV_CONFIG_DOTENV_KEY != null) {\n options.DOTENV_KEY = process.env.DOTENV_CONFIG_DOTENV_KEY\n}\n\nmodule.exports = options\n","const re = /^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/\n\nmodule.exports = function optionMatcher (args) {\n return args.reduce(function (acc, cur) {\n const matches = cur.match(re)\n if (matches) {\n acc[matches[1]] = matches[2]\n }\n return acc\n }, {})\n}\n","(function () {\n require('./lib/main').config(\n Object.assign(\n {},\n require('./lib/env-options'),\n require('./lib/cli-options')(process.argv)\n )\n )\n})()\n","import type { HttpMethod } from \"./types\";\n\nexport class ZapApi {\n private _rootUrl: string;\n private _token: string;\n\n public constructor(rootUrl: string, token: string) {\n this._rootUrl = rootUrl;\n this._token = token;\n }\n\n public async makeRequest(\n method: HttpMethod,\n endpoint: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n body?: any,\n contentType?: string\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): Promise<any> {\n const fullUrl: string = this._rootUrl + endpoint;\n const options: RequestInit = {\n method,\n headers: {\n Authorization: `Bearer ${this._token}`,\n \"Content-Type\": contentType ?? \"application/json\",\n },\n body: body\n ? typeof body === \"string\"\n ? body\n : JSON.stringify(body)\n : undefined,\n };\n\n const request = await fetch(fullUrl, options);\n const response = await request.json();\n\n return response;\n }\n}\n","import type { IConnection, IConnectionList, IError } from \"../types\";\nimport { ZapApi } from \"../zap-api\";\n\nexport class Connection {\n constructor(protected api: ZapApi) {}\n\n public async list(): Promise<IConnectionList | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", \"/api/connections\");\n\n return response as IConnectionList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list connections\" };\n }\n }\n\n public async get(id?: number): Promise<IConnection | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", \"/api/connections\");\n\n const connections = response?.connections as IConnection[];\n\n const connectionExists = connections.find(\n (connection: IConnection) => connection.id === id\n );\n\n if (!connectionExists || connectionExists?.status !== \"CONNECTED\") {\n const validConnection = connections?.find(\n (connection: IConnection) => connection?.status === \"CONNECTED\"\n );\n\n if (!validConnection) return { error: \"Connection not found\" };\n\n return validConnection;\n }\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to connection\" };\n }\n }\n}\n","import type { IContact, IContactList, IError, IParamsList } from \"../types\";\nimport type { ZapApi } from \"../zap-api\";\n\nexport class Contact {\n constructor(protected api: ZapApi) {}\n\n public async list(params?: IParamsList): Promise<IContactList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/contacts?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IContactList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list contacts\" };\n }\n }\n\n public async get(id: number): Promise<IContact | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/contacts/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IContact;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to contact\" };\n }\n }\n}\n","import type {\n IError,\n IMessage,\n IMessageList,\n IParamsMessageList,\n ISendMessage,\n MediaType,\n} from \"../types\";\n\nimport type { ZapApi } from \"../zap-api\";\n\nexport class Message {\n constructor(protected api: ZapApi) {}\n\n public async list(\n params?: IParamsMessageList\n ): Promise<IMessageList | IError> {\n try {\n const {\n page = 1,\n pageSize = 20,\n ticketId = \"\",\n contactId = \"\",\n dateFrom = \"\",\n dateTo = \"\",\n } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/messages?page=${page}&pageSize=${pageSize}&ticketId=${ticketId}&contactId=${contactId}&dateFrom=${dateFrom}&dateToo=${dateTo}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IMessageList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list message\" };\n }\n }\n\n public async get(id: string): Promise<IMessage | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/messages/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IMessage;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to message\" };\n }\n }\n\n public async send(to: string, data: ISendMessage, type?: MediaType) {\n try {\n if (!type || type === \"text\") {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/messages/${to}`,\n data\n );\n\n return response;\n }\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot send message\" };\n }\n }\n}\n","import type { IError, IParamsList, IQueue, IQueueList } from \"../types\";\nimport type { ZapApi } from \"../zap-api\";\n\nexport class Queue {\n constructor(protected api: ZapApi) {}\n\n public async list(params?: IParamsList): Promise<IQueueList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/queues?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IQueueList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list queues\" };\n }\n }\n\n public async get(id: number): Promise<IQueue | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/queues/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IQueue;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to queue\" };\n }\n }\n}\n","import type { IError, IParamsList, ITag, ITagList } from \"../types\";\nimport type { ZapApi } from \"../zap-api\";\n\nexport class Tag {\n constructor(protected api: ZapApi) {}\n\n public async list(params?: IParamsList): Promise<ITagList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/tags?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITagList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list tags\" };\n }\n }\n\n public async get(id: number): Promise<ITag | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/tags/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as ITag;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to tag\" };\n }\n }\n}\n","import type { IError, IParamsList, IUser, IUserList } from \"../types\";\nimport type { ZapApi } from \"../zap-api\";\n\nexport class User {\n constructor(protected api: ZapApi) {}\n\n public async list(params?: IParamsList): Promise<IUserList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/users?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IUserList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list users\" };\n }\n }\n\n public async get(id: number): Promise<IUser | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/users/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IUser;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to user\" };\n }\n }\n}\n","import type { IError, IParamsList, ITicket, ITicketList } from \"../types\";\nimport type { ZapApi } from \"../zap-api\";\n\nexport class Ticket {\n constructor(protected api: ZapApi) {}\n\n public async list(params?: IParamsList): Promise<ITicketList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/tickets?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicketList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list tickets\" };\n }\n }\n\n public async get(id: number): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/tickets/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to ticket\" };\n }\n }\n}\n","import \"dotenv/config\";\nimport { ZapApi } from \"./zap-api\";\nimport { Connection } from \"./lib\";\nimport { Contact } from \"./lib/contact\";\nimport { Message } from \"./lib/message\";\nimport { Queue } from \"./lib/queue\";\nimport { Tag } from \"./lib/tag\";\nimport { User } from \"./lib/user\";\nimport { Ticket } from \"./lib/ticket\";\n\nexport class Zdk extends ZapApi {\n public readonly tickets = new Ticket(this);\n\n public readonly connections = new Connection(this);\n\n public readonly contacts = new Contact(this);\n\n public readonly messages = new Message(this);\n\n public readonly queues = new Queue(this);\n\n public readonly tags = new Tag(this);\n\n public readonly users = new User(this);\n}\n"],"mappings":"uTAAA,IAAAA,EAAAC,EAAA,CAAAC,GAAAC,IAAA,CAAAA,EAAA,SACE,KAAQ,SACR,QAAW,SACX,YAAe,6CACf,KAAQ,cACR,MAAS,gBACT,QAAW,CACT,IAAK,CACH,MAAS,kBACT,QAAW,gBACX,QAAW,eACb,EACA,WAAY,cACZ,cAAe,cACf,oBAAqB,uBACrB,uBAAwB,uBACxB,oBAAqB,uBACrB,uBAAwB,uBACxB,iBAAkB,gBACpB,EACA,QAAW,CACT,YAAa,0CACb,KAAQ,WACR,cAAe,oBACf,QAAW,oCACX,KAAQ,8BACR,WAAc,WACd,QAAW,kBACb,EACA,WAAc,CACZ,KAAQ,MACR,IAAO,sCACT,EACA,QAAW,+CACX,SAAY,CACV,SACA,MACA,OACA,cACA,YACA,SACA,UACF,EACA,eAAkB,YAClB,QAAW,eACX,gBAAmB,CACjB,2BAA4B,WAC5B,cAAe,WACf,QAAW,SACX,MAAS,UACT,SAAY,UACZ,oBAAqB,SACrB,mBAAoB,SACpB,IAAO,UACP,IAAO,UACP,WAAc,QAChB,EACA,QAAW,CACT,KAAQ,MACV,EACA,QAAW,CACT,GAAM,EACR,CACF,IC/DA,IAAAC,EAAAC,EAAA,CAAAC,GAAAC,IAAA,KAAMC,EAAK,EAAQ,IAAI,EACjBC,EAAO,EAAQ,MAAM,EACrBC,EAAK,EAAQ,IAAI,EACjBC,EAAS,EAAQ,QAAQ,EACzBC,EAAc,IAEdC,EAAUD,EAAY,QAEtBE,EAAO,+IAGb,SAASC,EAAOC,EAAK,CACnB,IAAMC,EAAM,CAAC,EAGTC,EAAQF,EAAI,SAAS,EAGzBE,EAAQA,EAAM,QAAQ,UAAW;AAAA,CAAI,EAErC,IAAIC,EACJ,MAAQA,EAAQL,EAAK,KAAKI,CAAK,IAAM,MAAM,CACzC,IAAME,EAAMD,EAAM,CAAC,EAGfE,EAASF,EAAM,CAAC,GAAK,GAGzBE,EAAQA,EAAM,KAAK,EAGnB,IAAMC,EAAaD,EAAM,CAAC,EAG1BA,EAAQA,EAAM,QAAQ,yBAA0B,IAAI,EAGhDC,IAAe,MACjBD,EAAQA,EAAM,QAAQ,OAAQ;AAAA,CAAI,EAClCA,EAAQA,EAAM,QAAQ,OAAQ,IAAI,GAIpCJ,EAAIG,CAAG,EAAIC,CACb,CAEA,OAAOJ,CACT,CAEA,SAASM,EAAaC,EAAS,CAC7B,IAAMC,EAAYC,EAAWF,CAAO,EAG9BG,EAASC,EAAa,aAAa,CAAE,KAAMH,CAAU,CAAC,EAC5D,GAAI,CAACE,EAAO,OACV,MAAM,IAAI,MAAM,8BAA8BF,CAAS,wBAAwB,EAKjF,IAAMI,EAAOC,EAAWN,CAAO,EAAE,MAAM,GAAG,EACpCO,EAASF,EAAK,OAEhBG,EACJ,QAAS,EAAI,EAAG,EAAID,EAAQ,IAC1B,GAAI,CAEF,IAAMX,EAAMS,EAAK,CAAC,EAAE,KAAK,EAGnBI,EAAQC,EAAcP,EAAQP,CAAG,EAGvCY,EAAYJ,EAAa,QAAQK,EAAM,WAAYA,EAAM,GAAG,EAE5D,KACF,OAASE,EAAO,CAEd,GAAI,EAAI,GAAKJ,EACX,MAAMI,CAGV,CAIF,OAAOP,EAAa,MAAMI,CAAS,CACrC,CAEA,SAASI,EAAMC,EAAS,CACtB,QAAQ,IAAI,WAAWxB,CAAO,WAAWwB,CAAO,EAAE,CACpD,CAEA,SAASC,EAAOD,EAAS,CACvB,QAAQ,IAAI,WAAWxB,CAAO,WAAWwB,CAAO,EAAE,CACpD,CAEA,SAASE,EAAQF,EAAS,CACxB,QAAQ,IAAI,WAAWxB,CAAO,YAAYwB,CAAO,EAAE,CACrD,CAEA,SAASP,EAAYN,EAAS,CAE5B,OAAIA,GAAWA,EAAQ,YAAcA,EAAQ,WAAW,OAAS,EACxDA,EAAQ,WAIb,QAAQ,IAAI,YAAc,QAAQ,IAAI,WAAW,OAAS,EACrD,QAAQ,IAAI,WAId,EACT,CAEA,SAASU,EAAeP,EAAQa,EAAW,CAEzC,IAAIC,EACJ,GAAI,CACFA,EAAM,IAAI,IAAID,CAAS,CACzB,OAASL,EAAO,CACd,MAAIA,EAAM,OAAS,kBACX,IAAI,MAAM,2IAA2I,EAGvJA,CACR,CAGA,IAAMf,EAAMqB,EAAI,SAChB,GAAI,CAACrB,EACH,MAAM,IAAI,MAAM,sCAAsC,EAIxD,IAAMsB,EAAcD,EAAI,aAAa,IAAI,aAAa,EACtD,GAAI,CAACC,EACH,MAAM,IAAI,MAAM,8CAA8C,EAIhE,IAAMC,EAAiB,gBAAgBD,EAAY,YAAY,CAAC,GAC1DE,EAAajB,EAAO,OAAOgB,CAAc,EAC/C,GAAI,CAACC,EACH,MAAM,IAAI,MAAM,2DAA2DD,CAAc,2BAA2B,EAGtH,MAAO,CAAE,WAAAC,EAAY,IAAAxB,CAAI,CAC3B,CAEA,SAASM,EAAYF,EAAS,CAC5B,IAAIqB,EAAapC,EAAK,QAAQ,QAAQ,IAAI,EAAG,MAAM,EAEnD,OAAIe,GAAWA,EAAQ,MAAQA,EAAQ,KAAK,OAAS,IACnDqB,EAAarB,EAAQ,MAIhBqB,EAAW,SAAS,QAAQ,EAAIA,EAAa,GAAGA,CAAU,QACnE,CAEA,SAASC,EAAcC,EAAS,CAC9B,OAAOA,EAAQ,CAAC,IAAM,IAAMtC,EAAK,KAAKC,EAAG,QAAQ,EAAGqC,EAAQ,MAAM,CAAC,CAAC,EAAIA,CAC1E,CAEA,SAASC,EAAcxB,EAAS,CAC9BY,EAAK,uCAAuC,EAE5C,IAAMa,EAASrB,EAAa,YAAYJ,CAAO,EAE3C0B,EAAa,QAAQ,IACzB,OAAI1B,GAAWA,EAAQ,YAAc,OACnC0B,EAAa1B,EAAQ,YAGvBI,EAAa,SAASsB,EAAYD,EAAQzB,CAAO,EAE1C,CAAE,OAAAyB,CAAO,CAClB,CAEA,SAASE,EAAc3B,EAAS,CAC9B,IAAIqB,EAAapC,EAAK,QAAQ,QAAQ,IAAI,EAAG,MAAM,EAC/C2C,EAAW,OACTC,EAAQ,GAAQ7B,GAAWA,EAAQ,OAErCA,IACEA,EAAQ,MAAQ,OAClBqB,EAAaC,EAAatB,EAAQ,IAAI,GAEpCA,EAAQ,UAAY,OACtB4B,EAAW5B,EAAQ,WAIvB,GAAI,CAEF,IAAMyB,EAASrB,EAAa,MAAMpB,EAAG,aAAaqC,EAAY,CAAE,SAAAO,CAAS,CAAC,CAAC,EAEvEF,EAAa,QAAQ,IACzB,OAAI1B,GAAWA,EAAQ,YAAc,OACnC0B,EAAa1B,EAAQ,YAGvBI,EAAa,SAASsB,EAAYD,EAAQzB,CAAO,EAE1C,CAAE,OAAAyB,CAAO,CAClB,OAASK,EAAG,CACV,OAAID,GACFd,EAAO,kBAAkBM,CAAU,IAAIS,EAAE,OAAO,EAAE,EAG7C,CAAE,MAAOA,CAAE,CACpB,CACF,CAGA,SAASC,EAAQ/B,EAAS,CACxB,IAAMC,EAAYC,EAAWF,CAAO,EAGpC,OAAIM,EAAWN,CAAO,EAAE,SAAW,EAC1BI,EAAa,aAAaJ,CAAO,EAIrChB,EAAG,WAAWiB,CAAS,EAMrBG,EAAa,aAAaJ,CAAO,GALtCc,EAAM,+DAA+Db,CAAS,+BAA+B,EAEtGG,EAAa,aAAaJ,CAAO,EAI5C,CAEA,SAASgC,EAASC,EAAWC,EAAQ,CACnC,IAAMtC,EAAM,OAAO,KAAKsC,EAAO,MAAM,GAAG,EAAG,KAAK,EAC5Cd,EAAa,OAAO,KAAKa,EAAW,QAAQ,EAE1CE,EAAQf,EAAW,MAAM,EAAG,EAAE,EAC9BgB,EAAUhB,EAAW,MAAM,GAAG,EACpCA,EAAaA,EAAW,MAAM,GAAI,GAAG,EAErC,GAAI,CACF,IAAMiB,EAASlD,EAAO,iBAAiB,cAAeS,EAAKuC,CAAK,EAChE,OAAAE,EAAO,WAAWD,CAAO,EAClB,GAAGC,EAAO,OAAOjB,CAAU,CAAC,GAAGiB,EAAO,MAAM,CAAC,EACtD,OAAS1B,EAAO,CACd,IAAM2B,EAAU3B,aAAiB,WAC3B4B,EAAmB5B,EAAM,UAAY,qBACrC6B,EAAmB7B,EAAM,UAAY,mDAE3C,GAAI2B,GAAWC,EAAkB,CAC/B,IAAME,EAAM,8DACZ,MAAM,IAAI,MAAMA,CAAG,CACrB,SAAWD,EAAkB,CAC3B,IAAMC,EAAM,kDACZ,MAAM,IAAI,MAAMA,CAAG,CACrB,KACE,eAAQ,MAAM,UAAW9B,EAAM,IAAI,EACnC,QAAQ,MAAM,UAAWA,EAAM,OAAO,EAChCA,CAEV,CACF,CAGA,SAAS+B,EAAUhB,EAAYD,EAAQzB,EAAU,CAAC,EAAG,CACnD,IAAM6B,EAAQ,GAAQ7B,GAAWA,EAAQ,OACnC2C,EAAW,GAAQ3C,GAAWA,EAAQ,UAE5C,GAAI,OAAOyB,GAAW,SACpB,MAAM,IAAI,MAAM,gFAAgF,EAIlG,QAAW7B,KAAO,OAAO,KAAK6B,CAAM,EAC9B,OAAO,UAAU,eAAe,KAAKC,EAAY9B,CAAG,GAClD+C,IAAa,KACfjB,EAAW9B,CAAG,EAAI6B,EAAO7B,CAAG,GAG1BiC,GAEAd,EADE4B,IAAa,GACR,IAAI/C,CAAG,2CAEP,IAAIA,CAAG,8CAF0C,GAM5D8B,EAAW9B,CAAG,EAAI6B,EAAO7B,CAAG,CAGlC,CAEA,IAAMQ,EAAe,CACnB,aAAAuB,EACA,aAAAH,EACA,YAAAzB,EACA,OAAAgC,EACA,QAAAC,EACA,MAAAzC,EACA,SAAAmD,CACF,EAEA3D,EAAO,QAAQ,aAAeqB,EAAa,aAC3CrB,EAAO,QAAQ,aAAeqB,EAAa,aAC3CrB,EAAO,QAAQ,YAAcqB,EAAa,YAC1CrB,EAAO,QAAQ,OAASqB,EAAa,OACrCrB,EAAO,QAAQ,QAAUqB,EAAa,QACtCrB,EAAO,QAAQ,MAAQqB,EAAa,MACpCrB,EAAO,QAAQ,SAAWqB,EAAa,SAEvCrB,EAAO,QAAUqB,ICzTjB,IAAAwC,EAAAC,EAAA,CAAAC,GAAAC,IAAA,CACA,IAAMC,EAAU,CAAC,EAEb,QAAQ,IAAI,wBAA0B,OACxCA,EAAQ,SAAW,QAAQ,IAAI,wBAG7B,QAAQ,IAAI,oBAAsB,OACpCA,EAAQ,KAAO,QAAQ,IAAI,oBAGzB,QAAQ,IAAI,qBAAuB,OACrCA,EAAQ,MAAQ,QAAQ,IAAI,qBAG1B,QAAQ,IAAI,wBAA0B,OACxCA,EAAQ,SAAW,QAAQ,IAAI,wBAG7B,QAAQ,IAAI,0BAA4B,OAC1CA,EAAQ,WAAa,QAAQ,IAAI,0BAGnCD,EAAO,QAAUC,ICvBjB,IAAAC,EAAAC,EAAA,CAAAC,GAAAC,IAAA,KAAMC,EAAK,iEAEXD,EAAO,QAAU,SAAwBE,EAAM,CAC7C,OAAOA,EAAK,OAAO,SAAUC,EAAKC,EAAK,CACrC,IAAMC,EAAUD,EAAI,MAAMH,CAAE,EAC5B,OAAII,IACFF,EAAIE,EAAQ,CAAC,CAAC,EAAIA,EAAQ,CAAC,GAEtBF,CACT,EAAG,CAAC,CAAC,CACP,KCVC,UAAY,CACX,IAAsB,OACpB,OAAO,OACL,CAAC,EACD,IACA,IAA6B,QAAQ,IAAI,CAC3C,CACF,CACF,GAAG,ECNI,IAAMG,EAAN,KAAa,CACV,SACA,OAED,YAAYC,EAAiBC,EAAe,CACjD,KAAK,SAAWD,EAChB,KAAK,OAASC,CAChB,CAEA,MAAa,YACXC,EACAC,EAEAC,EACAC,EAEc,CACd,IAAMC,EAAkB,KAAK,SAAWH,EAClCI,EAAuB,CAC3B,OAAAL,EACA,QAAS,CACP,cAAe,UAAU,KAAK,MAAM,GACpC,eAAgBG,GAAe,kBACjC,EACA,KAAMD,EACF,OAAOA,GAAS,SACdA,EACA,KAAK,UAAUA,CAAI,EACrB,MACN,EAKA,OAFiB,MADD,MAAM,MAAME,EAASC,CAAO,GACb,KAAK,CAGtC,CACF,ECnCO,IAAMC,EAAN,KAAiB,CACtB,YAAsBC,EAAa,CAAb,SAAAA,CAAc,CAEpC,MAAa,MAA0C,CACrD,GAAI,CAGF,OAFiB,MAAM,KAAK,IAAI,YAAY,MAAO,kBAAkB,CAGvE,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,4BAA6B,CAC/C,CACF,CAEA,MAAa,IAAIC,EAA4C,CAC3D,GAAI,CAGF,IAAMC,GAFW,MAAM,KAAK,IAAI,YAAY,MAAO,kBAAkB,IAEvC,YAExBC,EAAmBD,EAAY,KAClCE,GAA4BA,EAAW,KAAOH,CACjD,EAEA,GAAI,CAACE,GAAoBA,GAAkB,SAAW,YAAa,CACjE,IAAME,EAAkBH,GAAa,KAClCE,GAA4BA,GAAY,SAAW,WACtD,EAEA,OAAKC,GAAwB,CAAE,MAAO,sBAAuB,CAG/D,CACF,OAASL,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,sBAAuB,CACzC,CACF,CACF,ECxCO,IAAMM,EAAN,KAAc,CACnB,YAAsBC,EAAa,CAAb,SAAAA,CAAc,CAEpC,MAAa,KAAKC,EAAsD,CACtE,GAAI,CACF,GAAM,CAAE,KAAAC,EAAO,EAAG,SAAAC,EAAW,EAAG,EAAIF,GAAU,CAAC,EAEzCG,EAAW,MAAM,KAAK,IAAI,YAC9B,MACA,sBAAsBF,CAAI,aAAaC,CAAQ,EACjD,EAEA,OAAIC,GAAU,MAAc,CAAE,MAAOA,GAAU,KAAM,EAE9CA,CACT,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,yBAA0B,CAC5C,CACF,CAEA,MAAa,IAAIC,EAAwC,CACvD,GAAI,CACF,IAAMF,EAAW,MAAM,KAAK,IAAI,YAAY,MAAO,iBAAiBE,CAAE,EAAE,EAExE,OAAIF,GAAU,MAAc,CAAE,MAAOA,GAAU,KAAM,EAE9CA,CACT,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,mBAAoB,CACtC,CACF,CACF,EC3BO,IAAME,EAAN,KAAc,CACnB,YAAsBC,EAAa,CAAb,SAAAA,CAAc,CAEpC,MAAa,KACXC,EACgC,CAChC,GAAI,CACF,GAAM,CACJ,KAAAC,EAAO,EACP,SAAAC,EAAW,GACX,SAAAC,EAAW,GACX,UAAAC,EAAY,GACZ,SAAAC,EAAW,GACX,OAAAC,EAAS,EACX,EAAIN,GAAU,CAAC,EAETO,EAAW,MAAM,KAAK,IAAI,YAC9B,MACA,sBAAsBN,CAAI,aAAaC,CAAQ,aAAaC,CAAQ,cAAcC,CAAS,aAAaC,CAAQ,YAAYC,CAAM,EACpI,EAEA,OAAIC,GAAU,MAAc,CAAE,MAAOA,GAAU,KAAM,EAE9CA,CACT,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,wBAAyB,CAC3C,CACF,CAEA,MAAa,IAAIC,EAAwC,CACvD,GAAI,CACF,IAAMF,EAAW,MAAM,KAAK,IAAI,YAAY,MAAO,iBAAiBE,CAAE,EAAE,EAExE,OAAIF,GAAU,MAAc,CAAE,MAAOA,GAAU,KAAM,EAE9CA,CACT,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,mBAAoB,CACtC,CACF,CAEA,MAAa,KAAKE,EAAYC,EAAoBC,EAAkB,CAClE,GAAI,CACF,GAAI,CAACA,GAAQA,IAAS,OAOpB,OANiB,MAAM,KAAK,IAAI,YAC9B,OACA,iBAAiBF,CAAE,GACnBC,CACF,CAIJ,OAASH,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,qBAAsB,CACxC,CACF,CACF,ECtEO,IAAMK,EAAN,KAAY,CACjB,YAAsBC,EAAa,CAAb,SAAAA,CAAc,CAEpC,MAAa,KAAKC,EAAoD,CACpE,GAAI,CACF,GAAM,CAAE,KAAAC,EAAO,EAAG,SAAAC,EAAW,EAAG,EAAIF,GAAU,CAAC,EAEzCG,EAAW,MAAM,KAAK,IAAI,YAC9B,MACA,oBAAoBF,CAAI,aAAaC,CAAQ,EAC/C,EAEA,OAAIC,GAAU,MAAc,CAAE,MAAOA,GAAU,KAAM,EAE9CA,CACT,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,uBAAwB,CAC1C,CACF,CAEA,MAAa,IAAIC,EAAsC,CACrD,GAAI,CACF,IAAMF,EAAW,MAAM,KAAK,IAAI,YAAY,MAAO,eAAeE,CAAE,EAAE,EAEtE,OAAIF,GAAU,MAAc,CAAE,MAAOA,GAAU,KAAM,EAE9CA,CACT,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,iBAAkB,CACpC,CACF,CACF,ECnCO,IAAME,EAAN,KAAU,CACf,YAAsBC,EAAa,CAAb,SAAAA,CAAc,CAEpC,MAAa,KAAKC,EAAkD,CAClE,GAAI,CACF,GAAM,CAAE,KAAAC,EAAO,EAAG,SAAAC,EAAW,EAAG,EAAIF,GAAU,CAAC,EAEzCG,EAAW,MAAM,KAAK,IAAI,YAC9B,MACA,kBAAkBF,CAAI,aAAaC,CAAQ,EAC7C,EAEA,OAAIC,GAAU,MAAc,CAAE,MAAOA,GAAU,KAAM,EAE9CA,CACT,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,qBAAsB,CACxC,CACF,CAEA,MAAa,IAAIC,EAAoC,CACnD,GAAI,CACF,IAAMF,EAAW,MAAM,KAAK,IAAI,YAAY,MAAO,aAAaE,CAAE,EAAE,EAEpE,OAAIF,GAAU,MAAc,CAAE,MAAOA,GAAU,KAAM,EAE9CA,CACT,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,eAAgB,CAClC,CACF,CACF,ECnCO,IAAME,EAAN,KAAW,CAChB,YAAsBC,EAAa,CAAb,SAAAA,CAAc,CAEpC,MAAa,KAAKC,EAAmD,CACnE,GAAI,CACF,GAAM,CAAE,KAAAC,EAAO,EAAG,SAAAC,EAAW,EAAG,EAAIF,GAAU,CAAC,EAEzCG,EAAW,MAAM,KAAK,IAAI,YAC9B,MACA,mBAAmBF,CAAI,aAAaC,CAAQ,EAC9C,EAEA,OAAIC,GAAU,MAAc,CAAE,MAAOA,GAAU,KAAM,EAE9CA,CACT,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,sBAAuB,CACzC,CACF,CAEA,MAAa,IAAIC,EAAqC,CACpD,GAAI,CACF,IAAMF,EAAW,MAAM,KAAK,IAAI,YAAY,MAAO,cAAcE,CAAE,EAAE,EAErE,OAAIF,GAAU,MAAc,CAAE,MAAOA,GAAU,KAAM,EAE9CA,CACT,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,gBAAiB,CACnC,CACF,CACF,ECnCO,IAAME,EAAN,KAAa,CAClB,YAAsBC,EAAa,CAAb,SAAAA,CAAc,CAEpC,MAAa,KAAKC,EAAqD,CACrE,GAAI,CACF,GAAM,CAAE,KAAAC,EAAO,EAAG,SAAAC,EAAW,EAAG,EAAIF,GAAU,CAAC,EAEzCG,EAAW,MAAM,KAAK,IAAI,YAC9B,MACA,qBAAqBF,CAAI,aAAaC,CAAQ,EAChD,EAEA,OAAIC,GAAU,MAAc,CAAE,MAAOA,GAAU,KAAM,EAE9CA,CACT,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,wBAAyB,CAC3C,CACF,CAEA,MAAa,IAAIC,EAAuC,CACtD,GAAI,CACF,IAAMF,EAAW,MAAM,KAAK,IAAI,YAAY,MAAO,gBAAgBE,CAAE,EAAE,EAEvE,OAAIF,GAAU,MAAc,CAAE,MAAOA,GAAU,KAAM,EAE9CA,CACT,OAASC,EAAO,CACd,eAAQ,MAAMA,CAAK,EAEZ,CAAE,MAAO,kBAAmB,CACrC,CACF,CACF,EC5BO,IAAME,EAAN,cAAkBC,CAAO,CACd,QAAU,IAAIC,EAAO,IAAI,EAEzB,YAAc,IAAIC,EAAW,IAAI,EAEjC,SAAW,IAAIC,EAAQ,IAAI,EAE3B,SAAW,IAAIC,EAAQ,IAAI,EAE3B,OAAS,IAAIC,EAAM,IAAI,EAEvB,KAAO,IAAIC,EAAI,IAAI,EAEnB,MAAQ,IAAIC,EAAK,IAAI,CACvC","names":["require_package","__commonJSMin","exports","module","require_main","__commonJSMin","exports","module","fs","path","os","crypto","packageJson","version","LINE","parse","src","obj","lines","match","key","value","maybeQuote","_parseVault","options","vaultPath","_vaultPath","result","DotenvModule","keys","_dotenvKey","length","decrypted","attrs","_instructions","error","_log","message","_warn","_debug","dotenvKey","uri","environment","environmentKey","ciphertext","dotenvPath","_resolveHome","envPath","_configVault","parsed","processEnv","configDotenv","encoding","debug","e","config","decrypt","encrypted","keyStr","nonce","authTag","aesgcm","isRange","invalidKeyLength","decryptionFailed","msg","populate","override","require_env_options","__commonJSMin","exports","module","options","require_cli_options","__commonJSMin","exports","module","re","args","acc","cur","matches","ZapApi","rootUrl","token","method","endpoint","body","contentType","fullUrl","options","Connection","api","error","id","connections","connectionExists","connection","validConnection","Contact","api","params","page","pageSize","response","error","id","Message","api","params","page","pageSize","ticketId","contactId","dateFrom","dateTo","response","error","id","to","data","type","Queue","api","params","page","pageSize","response","error","id","Tag","api","params","page","pageSize","response","error","id","User","api","params","page","pageSize","response","error","id","Ticket","api","params","page","pageSize","response","error","id","Zdk","ZapApi","Ticket","Connection","Contact","Message","Queue","Tag","User"]}
@@ -0,0 +1,236 @@
1
+ interface IError {
2
+ error: Record<string, unknown> | string;
3
+ }
4
+ type HttpMethod = "GET" | "POST" | "PUT" | "PATCH" | "DELETE";
5
+ type ConnectionStatus = "CONNECTED" | "DISCONNECTED" | "TIMEOUT";
6
+ type TicketStrategy = "create" | "nocreate" | "close";
7
+ type TicketStatus = "pending" | "open" | "closed";
8
+ type FeedbackOption = "none" | "feedback" | "send-end-message";
9
+ type MediaType = "text" | "image" | "video" | "audio" | "voice" | "document";
10
+ interface IPagination {
11
+ count: number;
12
+ page: number;
13
+ pageSize: number;
14
+ pageCount: number;
15
+ }
16
+ interface IParamsList extends Pick<IPagination, "page" | "pageSize"> {
17
+ }
18
+ interface IParamsMessageList extends IParamsList {
19
+ ticketId?: string;
20
+ contactId?: string;
21
+ dateFrom?: string;
22
+ dateTo?: string;
23
+ }
24
+ interface IConnection {
25
+ id: number;
26
+ status: ConnectionStatus;
27
+ createdAt: string;
28
+ updatedAt: string;
29
+ isDefault: boolean;
30
+ name: string;
31
+ platform: string;
32
+ number: string;
33
+ greetingMessage: string;
34
+ endMessage: string;
35
+ feedbackMessage: string;
36
+ }
37
+ interface IZdkOptions {
38
+ rootUrl: string;
39
+ token: string;
40
+ }
41
+ interface ISendMessage {
42
+ body: string;
43
+ connectionFrom: number;
44
+ ticketStrategy: TicketStrategy;
45
+ }
46
+ interface ISendMediaMessage {
47
+ media: string;
48
+ caption: string;
49
+ connectionFrom: number;
50
+ }
51
+ interface SendMediaMessageJson {
52
+ url: string;
53
+ caption: string;
54
+ connectionFrom: string;
55
+ }
56
+ interface IMessage {
57
+ id: number;
58
+ body: string;
59
+ type: string;
60
+ subtype: string;
61
+ isMedia: string;
62
+ myContact: string;
63
+ from: string;
64
+ contactId: number;
65
+ ticketId: number;
66
+ }
67
+ interface IContact {
68
+ id: number;
69
+ name: string;
70
+ number: string;
71
+ email: string;
72
+ profilePicUrl: string;
73
+ isGroup: boolean;
74
+ createdAt: string;
75
+ updatedAt: string;
76
+ blocked: boolean;
77
+ userId: number;
78
+ queueId: number;
79
+ tags: ITag[];
80
+ }
81
+ interface ITag {
82
+ id: string;
83
+ name: string;
84
+ color: string;
85
+ }
86
+ interface ITicket {
87
+ id: string;
88
+ status: string;
89
+ userId: string;
90
+ contactId: string;
91
+ whatsappId: string;
92
+ queueId: string;
93
+ unreadMessages: number;
94
+ lastMessage: string;
95
+ isGroup: boolean;
96
+ createdAt: string;
97
+ updatedAt: string;
98
+ }
99
+ interface IUser {
100
+ id: string;
101
+ name: string;
102
+ email: string;
103
+ status: string;
104
+ profile: string;
105
+ enabled: boolean;
106
+ createdAt: string;
107
+ updatedAt: string;
108
+ }
109
+ interface IQueue {
110
+ id: string;
111
+ name: string;
112
+ color: string;
113
+ }
114
+ interface IMessageObject {
115
+ id: string;
116
+ createdAt: string;
117
+ updatedAt: string;
118
+ body: string;
119
+ mediaUrl: string;
120
+ mediaType: string;
121
+ isDeleted: boolean;
122
+ quotedMsgId: string;
123
+ ticketId: string;
124
+ contactId: string;
125
+ fromMe: boolean;
126
+ ack: string;
127
+ read: boolean;
128
+ locationLatitude: string;
129
+ locationLongitude: string;
130
+ editedFromId: string;
131
+ editedToId: string;
132
+ error: string;
133
+ }
134
+ interface IContactList extends IPagination {
135
+ contacts: IContact[];
136
+ }
137
+ interface IQueueList extends IPagination {
138
+ queues: IQueue[];
139
+ }
140
+ interface ITicketList extends IPagination {
141
+ tickets: ITicket[];
142
+ }
143
+ interface ITagList extends IPagination {
144
+ tags: ITag[];
145
+ }
146
+ interface IMessageList extends IPagination {
147
+ messages: IMessageObject[];
148
+ }
149
+ interface IUserList extends IPagination {
150
+ users: IUser[];
151
+ }
152
+ interface IConnectionList {
153
+ connections: IConnection[];
154
+ }
155
+ interface ITicketUpdateForm {
156
+ status: TicketStatus;
157
+ userId: number;
158
+ queueId: number;
159
+ }
160
+ interface ITicketTransferForm {
161
+ queueId: number;
162
+ userId: number;
163
+ connectionId: number;
164
+ }
165
+ interface ITicketResolveForm {
166
+ feedbackOption: FeedbackOption;
167
+ }
168
+
169
+ declare class ZapApi {
170
+ private _rootUrl;
171
+ private _token;
172
+ constructor(rootUrl: string, token: string);
173
+ makeRequest(method: HttpMethod, endpoint: string, body?: any, contentType?: string): Promise<any>;
174
+ }
175
+
176
+ declare class Connection {
177
+ protected api: ZapApi;
178
+ constructor(api: ZapApi);
179
+ list(): Promise<IConnectionList | IError>;
180
+ get(id?: number): Promise<IConnection | IError>;
181
+ }
182
+
183
+ declare class Contact {
184
+ protected api: ZapApi;
185
+ constructor(api: ZapApi);
186
+ list(params?: IParamsList): Promise<IContactList | IError>;
187
+ get(id: number): Promise<IContact | IError>;
188
+ }
189
+
190
+ declare class Message {
191
+ protected api: ZapApi;
192
+ constructor(api: ZapApi);
193
+ list(params?: IParamsMessageList): Promise<IMessageList | IError>;
194
+ get(id: string): Promise<IMessage | IError>;
195
+ send(to: string, data: ISendMessage, type?: MediaType): Promise<any>;
196
+ }
197
+
198
+ declare class Queue {
199
+ protected api: ZapApi;
200
+ constructor(api: ZapApi);
201
+ list(params?: IParamsList): Promise<IQueueList | IError>;
202
+ get(id: number): Promise<IQueue | IError>;
203
+ }
204
+
205
+ declare class Tag {
206
+ protected api: ZapApi;
207
+ constructor(api: ZapApi);
208
+ list(params?: IParamsList): Promise<ITagList | IError>;
209
+ get(id: number): Promise<ITag | IError>;
210
+ }
211
+
212
+ declare class User {
213
+ protected api: ZapApi;
214
+ constructor(api: ZapApi);
215
+ list(params?: IParamsList): Promise<IUserList | IError>;
216
+ get(id: number): Promise<IUser | IError>;
217
+ }
218
+
219
+ declare class Ticket {
220
+ protected api: ZapApi;
221
+ constructor(api: ZapApi);
222
+ list(params?: IParamsList): Promise<ITicketList | IError>;
223
+ get(id: number): Promise<ITicket | IError>;
224
+ }
225
+
226
+ declare class Zdk extends ZapApi {
227
+ readonly tickets: Ticket;
228
+ readonly connections: Connection;
229
+ readonly contacts: Contact;
230
+ readonly messages: Message;
231
+ readonly queues: Queue;
232
+ readonly tags: Tag;
233
+ readonly users: User;
234
+ }
235
+
236
+ export { type ConnectionStatus, type FeedbackOption, type HttpMethod, type IConnection, type IConnectionList, type IContact, type IContactList, type IError, type IMessage, type IMessageList, type IMessageObject, type IPagination, type IParamsList, type IParamsMessageList, type IQueue, type IQueueList, type ISendMediaMessage, type ISendMessage, type ITag, type ITagList, type ITicket, type ITicketList, type ITicketResolveForm, type ITicketTransferForm, type ITicketUpdateForm, type IUser, type IUserList, type IZdkOptions, type MediaType, type SendMediaMessageJson, type TicketStatus, type TicketStrategy, Zdk };
@@ -0,0 +1,236 @@
1
+ interface IError {
2
+ error: Record<string, unknown> | string;
3
+ }
4
+ type HttpMethod = "GET" | "POST" | "PUT" | "PATCH" | "DELETE";
5
+ type ConnectionStatus = "CONNECTED" | "DISCONNECTED" | "TIMEOUT";
6
+ type TicketStrategy = "create" | "nocreate" | "close";
7
+ type TicketStatus = "pending" | "open" | "closed";
8
+ type FeedbackOption = "none" | "feedback" | "send-end-message";
9
+ type MediaType = "text" | "image" | "video" | "audio" | "voice" | "document";
10
+ interface IPagination {
11
+ count: number;
12
+ page: number;
13
+ pageSize: number;
14
+ pageCount: number;
15
+ }
16
+ interface IParamsList extends Pick<IPagination, "page" | "pageSize"> {
17
+ }
18
+ interface IParamsMessageList extends IParamsList {
19
+ ticketId?: string;
20
+ contactId?: string;
21
+ dateFrom?: string;
22
+ dateTo?: string;
23
+ }
24
+ interface IConnection {
25
+ id: number;
26
+ status: ConnectionStatus;
27
+ createdAt: string;
28
+ updatedAt: string;
29
+ isDefault: boolean;
30
+ name: string;
31
+ platform: string;
32
+ number: string;
33
+ greetingMessage: string;
34
+ endMessage: string;
35
+ feedbackMessage: string;
36
+ }
37
+ interface IZdkOptions {
38
+ rootUrl: string;
39
+ token: string;
40
+ }
41
+ interface ISendMessage {
42
+ body: string;
43
+ connectionFrom: number;
44
+ ticketStrategy: TicketStrategy;
45
+ }
46
+ interface ISendMediaMessage {
47
+ media: string;
48
+ caption: string;
49
+ connectionFrom: number;
50
+ }
51
+ interface SendMediaMessageJson {
52
+ url: string;
53
+ caption: string;
54
+ connectionFrom: string;
55
+ }
56
+ interface IMessage {
57
+ id: number;
58
+ body: string;
59
+ type: string;
60
+ subtype: string;
61
+ isMedia: string;
62
+ myContact: string;
63
+ from: string;
64
+ contactId: number;
65
+ ticketId: number;
66
+ }
67
+ interface IContact {
68
+ id: number;
69
+ name: string;
70
+ number: string;
71
+ email: string;
72
+ profilePicUrl: string;
73
+ isGroup: boolean;
74
+ createdAt: string;
75
+ updatedAt: string;
76
+ blocked: boolean;
77
+ userId: number;
78
+ queueId: number;
79
+ tags: ITag[];
80
+ }
81
+ interface ITag {
82
+ id: string;
83
+ name: string;
84
+ color: string;
85
+ }
86
+ interface ITicket {
87
+ id: string;
88
+ status: string;
89
+ userId: string;
90
+ contactId: string;
91
+ whatsappId: string;
92
+ queueId: string;
93
+ unreadMessages: number;
94
+ lastMessage: string;
95
+ isGroup: boolean;
96
+ createdAt: string;
97
+ updatedAt: string;
98
+ }
99
+ interface IUser {
100
+ id: string;
101
+ name: string;
102
+ email: string;
103
+ status: string;
104
+ profile: string;
105
+ enabled: boolean;
106
+ createdAt: string;
107
+ updatedAt: string;
108
+ }
109
+ interface IQueue {
110
+ id: string;
111
+ name: string;
112
+ color: string;
113
+ }
114
+ interface IMessageObject {
115
+ id: string;
116
+ createdAt: string;
117
+ updatedAt: string;
118
+ body: string;
119
+ mediaUrl: string;
120
+ mediaType: string;
121
+ isDeleted: boolean;
122
+ quotedMsgId: string;
123
+ ticketId: string;
124
+ contactId: string;
125
+ fromMe: boolean;
126
+ ack: string;
127
+ read: boolean;
128
+ locationLatitude: string;
129
+ locationLongitude: string;
130
+ editedFromId: string;
131
+ editedToId: string;
132
+ error: string;
133
+ }
134
+ interface IContactList extends IPagination {
135
+ contacts: IContact[];
136
+ }
137
+ interface IQueueList extends IPagination {
138
+ queues: IQueue[];
139
+ }
140
+ interface ITicketList extends IPagination {
141
+ tickets: ITicket[];
142
+ }
143
+ interface ITagList extends IPagination {
144
+ tags: ITag[];
145
+ }
146
+ interface IMessageList extends IPagination {
147
+ messages: IMessageObject[];
148
+ }
149
+ interface IUserList extends IPagination {
150
+ users: IUser[];
151
+ }
152
+ interface IConnectionList {
153
+ connections: IConnection[];
154
+ }
155
+ interface ITicketUpdateForm {
156
+ status: TicketStatus;
157
+ userId: number;
158
+ queueId: number;
159
+ }
160
+ interface ITicketTransferForm {
161
+ queueId: number;
162
+ userId: number;
163
+ connectionId: number;
164
+ }
165
+ interface ITicketResolveForm {
166
+ feedbackOption: FeedbackOption;
167
+ }
168
+
169
+ declare class ZapApi {
170
+ private _rootUrl;
171
+ private _token;
172
+ constructor(rootUrl: string, token: string);
173
+ makeRequest(method: HttpMethod, endpoint: string, body?: any, contentType?: string): Promise<any>;
174
+ }
175
+
176
+ declare class Connection {
177
+ protected api: ZapApi;
178
+ constructor(api: ZapApi);
179
+ list(): Promise<IConnectionList | IError>;
180
+ get(id?: number): Promise<IConnection | IError>;
181
+ }
182
+
183
+ declare class Contact {
184
+ protected api: ZapApi;
185
+ constructor(api: ZapApi);
186
+ list(params?: IParamsList): Promise<IContactList | IError>;
187
+ get(id: number): Promise<IContact | IError>;
188
+ }
189
+
190
+ declare class Message {
191
+ protected api: ZapApi;
192
+ constructor(api: ZapApi);
193
+ list(params?: IParamsMessageList): Promise<IMessageList | IError>;
194
+ get(id: string): Promise<IMessage | IError>;
195
+ send(to: string, data: ISendMessage, type?: MediaType): Promise<any>;
196
+ }
197
+
198
+ declare class Queue {
199
+ protected api: ZapApi;
200
+ constructor(api: ZapApi);
201
+ list(params?: IParamsList): Promise<IQueueList | IError>;
202
+ get(id: number): Promise<IQueue | IError>;
203
+ }
204
+
205
+ declare class Tag {
206
+ protected api: ZapApi;
207
+ constructor(api: ZapApi);
208
+ list(params?: IParamsList): Promise<ITagList | IError>;
209
+ get(id: number): Promise<ITag | IError>;
210
+ }
211
+
212
+ declare class User {
213
+ protected api: ZapApi;
214
+ constructor(api: ZapApi);
215
+ list(params?: IParamsList): Promise<IUserList | IError>;
216
+ get(id: number): Promise<IUser | IError>;
217
+ }
218
+
219
+ declare class Ticket {
220
+ protected api: ZapApi;
221
+ constructor(api: ZapApi);
222
+ list(params?: IParamsList): Promise<ITicketList | IError>;
223
+ get(id: number): Promise<ITicket | IError>;
224
+ }
225
+
226
+ declare class Zdk extends ZapApi {
227
+ readonly tickets: Ticket;
228
+ readonly connections: Connection;
229
+ readonly contacts: Contact;
230
+ readonly messages: Message;
231
+ readonly queues: Queue;
232
+ readonly tags: Tag;
233
+ readonly users: User;
234
+ }
235
+
236
+ export { type ConnectionStatus, type FeedbackOption, type HttpMethod, type IConnection, type IConnectionList, type IContact, type IContactList, type IError, type IMessage, type IMessageList, type IMessageObject, type IPagination, type IParamsList, type IParamsMessageList, type IQueue, type IQueueList, type ISendMediaMessage, type ISendMessage, type ITag, type ITagList, type ITicket, type ITicketList, type ITicketResolveForm, type ITicketTransferForm, type ITicketUpdateForm, type IUser, type IUserList, type IZdkOptions, type MediaType, type SendMediaMessageJson, type TicketStatus, type TicketStrategy, Zdk };
package/dist/index.js ADDED
@@ -0,0 +1,4 @@
1
+ var _=Object.defineProperty;var q=Object.getOwnPropertyDescriptor;var A=Object.getOwnPropertyNames;var G=Object.prototype.hasOwnProperty;var m=(t,r)=>()=>(r||t((r={exports:{}}).exports,r),r.exports),j=(t,r)=>{for(var e in r)_(t,e,{get:r[e],enumerable:!0})},S=(t,r,e,s)=>{if(r&&typeof r=="object"||typeof r=="function")for(let o of A(r))!G.call(t,o)&&o!==e&&_(t,o,{get:()=>r[o],enumerable:!(s=q(r,o))||s.enumerable});return t};var M=t=>S(_({},"__esModule",{value:!0}),t);var O=m((ce,z)=>{z.exports={name:"dotenv",version:"16.3.1",description:"Loads environment variables from .env file",main:"lib/main.js",types:"lib/main.d.ts",exports:{".":{types:"./lib/main.d.ts",require:"./lib/main.js",default:"./lib/main.js"},"./config":"./config.js","./config.js":"./config.js","./lib/env-options":"./lib/env-options.js","./lib/env-options.js":"./lib/env-options.js","./lib/cli-options":"./lib/cli-options.js","./lib/cli-options.js":"./lib/cli-options.js","./package.json":"./package.json"},scripts:{"dts-check":"tsc --project tests/types/tsconfig.json",lint:"standard","lint-readme":"standard-markdown",pretest:"npm run lint && npm run dts-check",test:"tap tests/*.js --100 -Rspec",prerelease:"npm test",release:"standard-version"},repository:{type:"git",url:"git://github.com/motdotla/dotenv.git"},funding:"https://github.com/motdotla/dotenv?sponsor=1",keywords:["dotenv","env",".env","environment","variables","config","settings"],readmeFilename:"README.md",license:"BSD-2-Clause",devDependencies:{"@definitelytyped/dtslint":"^0.0.133","@types/node":"^18.11.3",decache:"^4.6.1",sinon:"^14.0.1",standard:"^17.0.0","standard-markdown":"^7.1.0","standard-version":"^9.5.0",tap:"^16.3.0",tar:"^6.1.11",typescript:"^4.8.4"},engines:{node:">=12"},browser:{fs:!1}}});var V=m((pe,u)=>{var k=require("fs"),N=require("path"),F=require("os"),K=require("crypto"),Y=O(),w=Y.version,Z=/(?:^|^)\s*(?:export\s+)?([\w.-]+)(?:\s*=\s*?|:\s+?)(\s*'(?:\\'|[^'])*'|\s*"(?:\\"|[^"])*"|\s*`(?:\\`|[^`])*`|[^#\r\n]+)?\s*(?:#.*)?(?:$|$)/mg;function B(t){let r={},e=t.toString();e=e.replace(/\r\n?/mg,`
2
+ `);let s;for(;(s=Z.exec(e))!=null;){let o=s[1],n=s[2]||"";n=n.trim();let i=n[0];n=n.replace(/^(['"`])([\s\S]*)\1$/mg,"$2"),i==='"'&&(n=n.replace(/\\n/g,`
3
+ `),n=n.replace(/\\r/g,"\r")),r[o]=n}return r}function Q(t){let r=$(t),e=a.configDotenv({path:r});if(!e.parsed)throw new Error(`MISSING_DATA: Cannot parse ${r} for an unknown reason`);let s=L(t).split(","),o=s.length,n;for(let i=0;i<o;i++)try{let c=s[i].trim(),p=J(e,c);n=a.decrypt(p.ciphertext,p.key);break}catch(c){if(i+1>=o)throw c}return a.parse(n)}function H(t){console.log(`[dotenv@${w}][INFO] ${t}`)}function W(t){console.log(`[dotenv@${w}][WARN] ${t}`)}function T(t){console.log(`[dotenv@${w}][DEBUG] ${t}`)}function L(t){return t&&t.DOTENV_KEY&&t.DOTENV_KEY.length>0?t.DOTENV_KEY:process.env.DOTENV_KEY&&process.env.DOTENV_KEY.length>0?process.env.DOTENV_KEY:""}function J(t,r){let e;try{e=new URL(r)}catch(c){throw c.code==="ERR_INVALID_URL"?new Error("INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenv.org/vault/.env.vault?environment=development"):c}let s=e.password;if(!s)throw new Error("INVALID_DOTENV_KEY: Missing key part");let o=e.searchParams.get("environment");if(!o)throw new Error("INVALID_DOTENV_KEY: Missing environment part");let n=`DOTENV_VAULT_${o.toUpperCase()}`,i=t.parsed[n];if(!i)throw new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${n} in your .env.vault file.`);return{ciphertext:i,key:s}}function $(t){let r=N.resolve(process.cwd(),".env");return t&&t.path&&t.path.length>0&&(r=t.path),r.endsWith(".vault")?r:`${r}.vault`}function X(t){return t[0]==="~"?N.join(F.homedir(),t.slice(1)):t}function ee(t){H("Loading env from encrypted .env.vault");let r=a._parseVault(t),e=process.env;return t&&t.processEnv!=null&&(e=t.processEnv),a.populate(e,r,t),{parsed:r}}function re(t){let r=N.resolve(process.cwd(),".env"),e="utf8",s=!!(t&&t.debug);t&&(t.path!=null&&(r=X(t.path)),t.encoding!=null&&(e=t.encoding));try{let o=a.parse(k.readFileSync(r,{encoding:e})),n=process.env;return t&&t.processEnv!=null&&(n=t.processEnv),a.populate(n,o,t),{parsed:o}}catch(o){return s&&T(`Failed to load ${r} ${o.message}`),{error:o}}}function te(t){let r=$(t);return L(t).length===0?a.configDotenv(t):k.existsSync(r)?a._configVault(t):(W(`You set DOTENV_KEY but you are missing a .env.vault file at ${r}. Did you forget to build it?`),a.configDotenv(t))}function oe(t,r){let e=Buffer.from(r.slice(-64),"hex"),s=Buffer.from(t,"base64"),o=s.slice(0,12),n=s.slice(-16);s=s.slice(12,-16);try{let i=K.createDecipheriv("aes-256-gcm",e,o);return i.setAuthTag(n),`${i.update(s)}${i.final()}`}catch(i){let c=i instanceof RangeError,p=i.message==="Invalid key length",U=i.message==="Unsupported state or unable to authenticate data";if(c||p){let b="INVALID_DOTENV_KEY: It must be 64 characters long (or more)";throw new Error(b)}else if(U){let b="DECRYPTION_FAILED: Please check your DOTENV_KEY";throw new Error(b)}else throw console.error("Error: ",i.code),console.error("Error: ",i.message),i}}function se(t,r,e={}){let s=!!(e&&e.debug),o=!!(e&&e.override);if(typeof r!="object")throw new Error("OBJECT_REQUIRED: Please check the processEnv argument being passed to populate");for(let n of Object.keys(r))Object.prototype.hasOwnProperty.call(t,n)?(o===!0&&(t[n]=r[n]),s&&T(o===!0?`"${n}" is already defined and WAS overwritten`:`"${n}" is already defined and was NOT overwritten`)):t[n]=r[n]}var a={configDotenv:re,_configVault:ee,_parseVault:Q,config:te,decrypt:oe,parse:B,populate:se};u.exports.configDotenv=a.configDotenv;u.exports._configVault=a._configVault;u.exports._parseVault=a._parseVault;u.exports.config=a.config;u.exports.decrypt=a.decrypt;u.exports.parse=a.parse;u.exports.populate=a.populate;u.exports=a});var P=m((ue,C)=>{var l={};process.env.DOTENV_CONFIG_ENCODING!=null&&(l.encoding=process.env.DOTENV_CONFIG_ENCODING);process.env.DOTENV_CONFIG_PATH!=null&&(l.path=process.env.DOTENV_CONFIG_PATH);process.env.DOTENV_CONFIG_DEBUG!=null&&(l.debug=process.env.DOTENV_CONFIG_DEBUG);process.env.DOTENV_CONFIG_OVERRIDE!=null&&(l.override=process.env.DOTENV_CONFIG_OVERRIDE);process.env.DOTENV_CONFIG_DOTENV_KEY!=null&&(l.DOTENV_KEY=process.env.DOTENV_CONFIG_DOTENV_KEY);C.exports=l});var R=m((le,x)=>{var ne=/^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/;x.exports=function(r){return r.reduce(function(e,s){let o=s.match(ne);return o&&(e[o[1]]=o[2]),e},{})}});var ie={};j(ie,{Zdk:()=>D});module.exports=M(ie);(function(){V().config(Object.assign({},P(),R()(process.argv)))})();var g=class{_rootUrl;_token;constructor(r,e){this._rootUrl=r,this._token=e}async makeRequest(r,e,s,o){let n=this._rootUrl+e,i={method:r,headers:{Authorization:`Bearer ${this._token}`,"Content-Type":o??"application/json"},body:s?typeof s=="string"?s:JSON.stringify(s):void 0};return await(await fetch(n,i)).json()}};var f=class{constructor(r){this.api=r}async list(){try{return await this.api.makeRequest("GET","/api/connections")}catch(r){return console.error(r),{error:"Unable to list connections"}}}async get(r){try{let s=(await this.api.makeRequest("GET","/api/connections"))?.connections,o=s.find(n=>n.id===r);if(!o||o?.status!=="CONNECTED"){let n=s?.find(i=>i?.status==="CONNECTED");return n||{error:"Connection not found"}}}catch(e){return console.error(e),{error:"Unable to connection"}}}};var d=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:s=20}=r||{},o=await this.api.makeRequest("GET",`/api/contacts?page=${e}&pageSize=${s}`);return o?.error?{error:o?.error}:o}catch(e){return console.error(e),{error:"Unable to list contacts"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/contacts/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to contact"}}}};var E=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:s=20,ticketId:o="",contactId:n="",dateFrom:i="",dateTo:c=""}=r||{},p=await this.api.makeRequest("GET",`/api/messages?page=${e}&pageSize=${s}&ticketId=${o}&contactId=${n}&dateFrom=${i}&dateToo=${c}`);return p?.error?{error:p?.error}:p}catch(e){return console.error(e),{error:"Unable to list message"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/messages/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to message"}}}async send(r,e,s){try{if(!s||s==="text")return await this.api.makeRequest("POST",`/api/messages/${r}`,e)}catch(o){return console.error(o),{error:"Cannot send message"}}}};var I=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:s=20}=r||{},o=await this.api.makeRequest("GET",`/api/queues?page=${e}&pageSize=${s}`);return o?.error?{error:o?.error}:o}catch(e){return console.error(e),{error:"Unable to list queues"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/queues/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to queue"}}}};var y=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:s=20}=r||{},o=await this.api.makeRequest("GET",`/api/tags?page=${e}&pageSize=${s}`);return o?.error?{error:o?.error}:o}catch(e){return console.error(e),{error:"Unable to list tags"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/tags/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to tag"}}}};var h=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:s=20}=r||{},o=await this.api.makeRequest("GET",`/api/users?page=${e}&pageSize=${s}`);return o?.error?{error:o?.error}:o}catch(e){return console.error(e),{error:"Unable to list users"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/users/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to user"}}}};var v=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:s=20}=r||{},o=await this.api.makeRequest("GET",`/api/tickets?page=${e}&pageSize=${s}`);return o?.error?{error:o?.error}:o}catch(e){return console.error(e),{error:"Unable to list tickets"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/tickets/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to ticket"}}}};var D=class extends g{tickets=new v(this);connections=new f(this);contacts=new d(this);messages=new E(this);queues=new I(this);tags=new y(this);users=new h(this)};0&&(module.exports={Zdk});
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../node_modules/dotenv/package.json","../node_modules/dotenv/lib/main.js","../node_modules/dotenv/lib/env-options.js","../node_modules/dotenv/lib/cli-options.js","../src/index.ts","../node_modules/dotenv/config.js","../src/zap-api.ts","../src/lib/connection.ts","../src/lib/contact.ts","../src/lib/message.ts","../src/lib/queue.ts","../src/lib/tag.ts","../src/lib/user.ts","../src/lib/ticket.ts","../src/zdk.ts"],"sourcesContent":["{\n \"name\": \"dotenv\",\n \"version\": \"16.3.1\",\n \"description\": \"Loads environment variables from .env file\",\n \"main\": \"lib/main.js\",\n \"types\": \"lib/main.d.ts\",\n \"exports\": {\n \".\": {\n \"types\": \"./lib/main.d.ts\",\n \"require\": \"./lib/main.js\",\n \"default\": \"./lib/main.js\"\n },\n \"./config\": \"./config.js\",\n \"./config.js\": \"./config.js\",\n \"./lib/env-options\": \"./lib/env-options.js\",\n \"./lib/env-options.js\": \"./lib/env-options.js\",\n \"./lib/cli-options\": \"./lib/cli-options.js\",\n \"./lib/cli-options.js\": \"./lib/cli-options.js\",\n \"./package.json\": \"./package.json\"\n },\n \"scripts\": {\n \"dts-check\": \"tsc --project tests/types/tsconfig.json\",\n \"lint\": \"standard\",\n \"lint-readme\": \"standard-markdown\",\n \"pretest\": \"npm run lint && npm run dts-check\",\n \"test\": \"tap tests/*.js --100 -Rspec\",\n \"prerelease\": \"npm test\",\n \"release\": \"standard-version\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git://github.com/motdotla/dotenv.git\"\n },\n \"funding\": \"https://github.com/motdotla/dotenv?sponsor=1\",\n \"keywords\": [\n \"dotenv\",\n \"env\",\n \".env\",\n \"environment\",\n \"variables\",\n \"config\",\n \"settings\"\n ],\n \"readmeFilename\": \"README.md\",\n \"license\": \"BSD-2-Clause\",\n \"devDependencies\": {\n \"@definitelytyped/dtslint\": \"^0.0.133\",\n \"@types/node\": \"^18.11.3\",\n \"decache\": \"^4.6.1\",\n \"sinon\": \"^14.0.1\",\n \"standard\": \"^17.0.0\",\n \"standard-markdown\": \"^7.1.0\",\n \"standard-version\": \"^9.5.0\",\n \"tap\": \"^16.3.0\",\n \"tar\": \"^6.1.11\",\n \"typescript\": \"^4.8.4\"\n },\n \"engines\": {\n \"node\": \">=12\"\n },\n \"browser\": {\n \"fs\": false\n }\n}\n","const fs = require('fs')\nconst path = require('path')\nconst os = require('os')\nconst crypto = require('crypto')\nconst packageJson = require('../package.json')\n\nconst version = packageJson.version\n\nconst LINE = /(?:^|^)\\s*(?:export\\s+)?([\\w.-]+)(?:\\s*=\\s*?|:\\s+?)(\\s*'(?:\\\\'|[^'])*'|\\s*\"(?:\\\\\"|[^\"])*\"|\\s*`(?:\\\\`|[^`])*`|[^#\\r\\n]+)?\\s*(?:#.*)?(?:$|$)/mg\n\n// Parse src into an Object\nfunction parse (src) {\n const obj = {}\n\n // Convert buffer to string\n let lines = src.toString()\n\n // Convert line breaks to same format\n lines = lines.replace(/\\r\\n?/mg, '\\n')\n\n let match\n while ((match = LINE.exec(lines)) != null) {\n const key = match[1]\n\n // Default undefined or null to empty string\n let value = (match[2] || '')\n\n // Remove whitespace\n value = value.trim()\n\n // Check if double quoted\n const maybeQuote = value[0]\n\n // Remove surrounding quotes\n value = value.replace(/^(['\"`])([\\s\\S]*)\\1$/mg, '$2')\n\n // Expand newlines if double quoted\n if (maybeQuote === '\"') {\n value = value.replace(/\\\\n/g, '\\n')\n value = value.replace(/\\\\r/g, '\\r')\n }\n\n // Add to object\n obj[key] = value\n }\n\n return obj\n}\n\nfunction _parseVault (options) {\n const vaultPath = _vaultPath(options)\n\n // Parse .env.vault\n const result = DotenvModule.configDotenv({ path: vaultPath })\n if (!result.parsed) {\n throw new Error(`MISSING_DATA: Cannot parse ${vaultPath} for an unknown reason`)\n }\n\n // handle scenario for comma separated keys - for use with key rotation\n // example: DOTENV_KEY=\"dotenv://:key_1234@dotenv.org/vault/.env.vault?environment=prod,dotenv://:key_7890@dotenv.org/vault/.env.vault?environment=prod\"\n const keys = _dotenvKey(options).split(',')\n const length = keys.length\n\n let decrypted\n for (let i = 0; i < length; i++) {\n try {\n // Get full key\n const key = keys[i].trim()\n\n // Get instructions for decrypt\n const attrs = _instructions(result, key)\n\n // Decrypt\n decrypted = DotenvModule.decrypt(attrs.ciphertext, attrs.key)\n\n break\n } catch (error) {\n // last key\n if (i + 1 >= length) {\n throw error\n }\n // try next key\n }\n }\n\n // Parse decrypted .env string\n return DotenvModule.parse(decrypted)\n}\n\nfunction _log (message) {\n console.log(`[dotenv@${version}][INFO] ${message}`)\n}\n\nfunction _warn (message) {\n console.log(`[dotenv@${version}][WARN] ${message}`)\n}\n\nfunction _debug (message) {\n console.log(`[dotenv@${version}][DEBUG] ${message}`)\n}\n\nfunction _dotenvKey (options) {\n // prioritize developer directly setting options.DOTENV_KEY\n if (options && options.DOTENV_KEY && options.DOTENV_KEY.length > 0) {\n return options.DOTENV_KEY\n }\n\n // secondary infra already contains a DOTENV_KEY environment variable\n if (process.env.DOTENV_KEY && process.env.DOTENV_KEY.length > 0) {\n return process.env.DOTENV_KEY\n }\n\n // fallback to empty string\n return ''\n}\n\nfunction _instructions (result, dotenvKey) {\n // Parse DOTENV_KEY. Format is a URI\n let uri\n try {\n uri = new URL(dotenvKey)\n } catch (error) {\n if (error.code === 'ERR_INVALID_URL') {\n throw new Error('INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenv.org/vault/.env.vault?environment=development')\n }\n\n throw error\n }\n\n // Get decrypt key\n const key = uri.password\n if (!key) {\n throw new Error('INVALID_DOTENV_KEY: Missing key part')\n }\n\n // Get environment\n const environment = uri.searchParams.get('environment')\n if (!environment) {\n throw new Error('INVALID_DOTENV_KEY: Missing environment part')\n }\n\n // Get ciphertext payload\n const environmentKey = `DOTENV_VAULT_${environment.toUpperCase()}`\n const ciphertext = result.parsed[environmentKey] // DOTENV_VAULT_PRODUCTION\n if (!ciphertext) {\n throw new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${environmentKey} in your .env.vault file.`)\n }\n\n return { ciphertext, key }\n}\n\nfunction _vaultPath (options) {\n let dotenvPath = path.resolve(process.cwd(), '.env')\n\n if (options && options.path && options.path.length > 0) {\n dotenvPath = options.path\n }\n\n // Locate .env.vault\n return dotenvPath.endsWith('.vault') ? dotenvPath : `${dotenvPath}.vault`\n}\n\nfunction _resolveHome (envPath) {\n return envPath[0] === '~' ? path.join(os.homedir(), envPath.slice(1)) : envPath\n}\n\nfunction _configVault (options) {\n _log('Loading env from encrypted .env.vault')\n\n const parsed = DotenvModule._parseVault(options)\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsed, options)\n\n return { parsed }\n}\n\nfunction configDotenv (options) {\n let dotenvPath = path.resolve(process.cwd(), '.env')\n let encoding = 'utf8'\n const debug = Boolean(options && options.debug)\n\n if (options) {\n if (options.path != null) {\n dotenvPath = _resolveHome(options.path)\n }\n if (options.encoding != null) {\n encoding = options.encoding\n }\n }\n\n try {\n // Specifying an encoding returns a string instead of a buffer\n const parsed = DotenvModule.parse(fs.readFileSync(dotenvPath, { encoding }))\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsed, options)\n\n return { parsed }\n } catch (e) {\n if (debug) {\n _debug(`Failed to load ${dotenvPath} ${e.message}`)\n }\n\n return { error: e }\n }\n}\n\n// Populates process.env from .env file\nfunction config (options) {\n const vaultPath = _vaultPath(options)\n\n // fallback to original dotenv if DOTENV_KEY is not set\n if (_dotenvKey(options).length === 0) {\n return DotenvModule.configDotenv(options)\n }\n\n // dotenvKey exists but .env.vault file does not exist\n if (!fs.existsSync(vaultPath)) {\n _warn(`You set DOTENV_KEY but you are missing a .env.vault file at ${vaultPath}. Did you forget to build it?`)\n\n return DotenvModule.configDotenv(options)\n }\n\n return DotenvModule._configVault(options)\n}\n\nfunction decrypt (encrypted, keyStr) {\n const key = Buffer.from(keyStr.slice(-64), 'hex')\n let ciphertext = Buffer.from(encrypted, 'base64')\n\n const nonce = ciphertext.slice(0, 12)\n const authTag = ciphertext.slice(-16)\n ciphertext = ciphertext.slice(12, -16)\n\n try {\n const aesgcm = crypto.createDecipheriv('aes-256-gcm', key, nonce)\n aesgcm.setAuthTag(authTag)\n return `${aesgcm.update(ciphertext)}${aesgcm.final()}`\n } catch (error) {\n const isRange = error instanceof RangeError\n const invalidKeyLength = error.message === 'Invalid key length'\n const decryptionFailed = error.message === 'Unsupported state or unable to authenticate data'\n\n if (isRange || invalidKeyLength) {\n const msg = 'INVALID_DOTENV_KEY: It must be 64 characters long (or more)'\n throw new Error(msg)\n } else if (decryptionFailed) {\n const msg = 'DECRYPTION_FAILED: Please check your DOTENV_KEY'\n throw new Error(msg)\n } else {\n console.error('Error: ', error.code)\n console.error('Error: ', error.message)\n throw error\n }\n }\n}\n\n// Populate process.env with parsed values\nfunction populate (processEnv, parsed, options = {}) {\n const debug = Boolean(options && options.debug)\n const override = Boolean(options && options.override)\n\n if (typeof parsed !== 'object') {\n throw new Error('OBJECT_REQUIRED: Please check the processEnv argument being passed to populate')\n }\n\n // Set process.env\n for (const key of Object.keys(parsed)) {\n if (Object.prototype.hasOwnProperty.call(processEnv, key)) {\n if (override === true) {\n processEnv[key] = parsed[key]\n }\n\n if (debug) {\n if (override === true) {\n _debug(`\"${key}\" is already defined and WAS overwritten`)\n } else {\n _debug(`\"${key}\" is already defined and was NOT overwritten`)\n }\n }\n } else {\n processEnv[key] = parsed[key]\n }\n }\n}\n\nconst DotenvModule = {\n configDotenv,\n _configVault,\n _parseVault,\n config,\n decrypt,\n parse,\n populate\n}\n\nmodule.exports.configDotenv = DotenvModule.configDotenv\nmodule.exports._configVault = DotenvModule._configVault\nmodule.exports._parseVault = DotenvModule._parseVault\nmodule.exports.config = DotenvModule.config\nmodule.exports.decrypt = DotenvModule.decrypt\nmodule.exports.parse = DotenvModule.parse\nmodule.exports.populate = DotenvModule.populate\n\nmodule.exports = DotenvModule\n","// ../config.js accepts options via environment variables\nconst options = {}\n\nif (process.env.DOTENV_CONFIG_ENCODING != null) {\n options.encoding = process.env.DOTENV_CONFIG_ENCODING\n}\n\nif (process.env.DOTENV_CONFIG_PATH != null) {\n options.path = process.env.DOTENV_CONFIG_PATH\n}\n\nif (process.env.DOTENV_CONFIG_DEBUG != null) {\n options.debug = process.env.DOTENV_CONFIG_DEBUG\n}\n\nif (process.env.DOTENV_CONFIG_OVERRIDE != null) {\n options.override = process.env.DOTENV_CONFIG_OVERRIDE\n}\n\nif (process.env.DOTENV_CONFIG_DOTENV_KEY != null) {\n options.DOTENV_KEY = process.env.DOTENV_CONFIG_DOTENV_KEY\n}\n\nmodule.exports = options\n","const re = /^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/\n\nmodule.exports = function optionMatcher (args) {\n return args.reduce(function (acc, cur) {\n const matches = cur.match(re)\n if (matches) {\n acc[matches[1]] = matches[2]\n }\n return acc\n }, {})\n}\n","export * from \"./zdk\";\nexport * from \"./types\";\n","(function () {\n require('./lib/main').config(\n Object.assign(\n {},\n require('./lib/env-options'),\n require('./lib/cli-options')(process.argv)\n )\n )\n})()\n","import type { HttpMethod } from \"./types\";\n\nexport class ZapApi {\n private _rootUrl: string;\n private _token: string;\n\n public constructor(rootUrl: string, token: string) {\n this._rootUrl = rootUrl;\n this._token = token;\n }\n\n public async makeRequest(\n method: HttpMethod,\n endpoint: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n body?: any,\n contentType?: string\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): Promise<any> {\n const fullUrl: string = this._rootUrl + endpoint;\n const options: RequestInit = {\n method,\n headers: {\n Authorization: `Bearer ${this._token}`,\n \"Content-Type\": contentType ?? \"application/json\",\n },\n body: body\n ? typeof body === \"string\"\n ? body\n : JSON.stringify(body)\n : undefined,\n };\n\n const request = await fetch(fullUrl, options);\n const response = await request.json();\n\n return response;\n }\n}\n","import type { IConnection, IConnectionList, IError } from \"../types\";\nimport { ZapApi } from \"../zap-api\";\n\nexport class Connection {\n constructor(protected api: ZapApi) {}\n\n public async list(): Promise<IConnectionList | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", \"/api/connections\");\n\n return response as IConnectionList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list connections\" };\n }\n }\n\n public async get(id?: number): Promise<IConnection | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", \"/api/connections\");\n\n const connections = response?.connections as IConnection[];\n\n const connectionExists = connections.find(\n (connection: IConnection) => connection.id === id\n );\n\n if (!connectionExists || connectionExists?.status !== \"CONNECTED\") {\n const validConnection = connections?.find(\n (connection: IConnection) => connection?.status === \"CONNECTED\"\n );\n\n if (!validConnection) return { error: \"Connection not found\" };\n\n return validConnection;\n }\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to connection\" };\n }\n }\n}\n","import type { IContact, IContactList, IError, IParamsList } from \"../types\";\nimport type { ZapApi } from \"../zap-api\";\n\nexport class Contact {\n constructor(protected api: ZapApi) {}\n\n public async list(params?: IParamsList): Promise<IContactList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/contacts?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IContactList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list contacts\" };\n }\n }\n\n public async get(id: number): Promise<IContact | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/contacts/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IContact;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to contact\" };\n }\n }\n}\n","import type {\n IError,\n IMessage,\n IMessageList,\n IParamsMessageList,\n ISendMessage,\n MediaType,\n} from \"../types\";\n\nimport type { ZapApi } from \"../zap-api\";\n\nexport class Message {\n constructor(protected api: ZapApi) {}\n\n public async list(\n params?: IParamsMessageList\n ): Promise<IMessageList | IError> {\n try {\n const {\n page = 1,\n pageSize = 20,\n ticketId = \"\",\n contactId = \"\",\n dateFrom = \"\",\n dateTo = \"\",\n } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/messages?page=${page}&pageSize=${pageSize}&ticketId=${ticketId}&contactId=${contactId}&dateFrom=${dateFrom}&dateToo=${dateTo}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IMessageList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list message\" };\n }\n }\n\n public async get(id: string): Promise<IMessage | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/messages/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IMessage;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to message\" };\n }\n }\n\n public async send(to: string, data: ISendMessage, type?: MediaType) {\n try {\n if (!type || type === \"text\") {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/messages/${to}`,\n data\n );\n\n return response;\n }\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot send message\" };\n }\n }\n}\n","import type { IError, IParamsList, IQueue, IQueueList } from \"../types\";\nimport type { ZapApi } from \"../zap-api\";\n\nexport class Queue {\n constructor(protected api: ZapApi) {}\n\n public async list(params?: IParamsList): Promise<IQueueList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/queues?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IQueueList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list queues\" };\n }\n }\n\n public async get(id: number): Promise<IQueue | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/queues/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IQueue;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to queue\" };\n }\n }\n}\n","import type { IError, IParamsList, ITag, ITagList } from \"../types\";\nimport type { ZapApi } from \"../zap-api\";\n\nexport class Tag {\n constructor(protected api: ZapApi) {}\n\n public async list(params?: IParamsList): Promise<ITagList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/tags?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITagList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list tags\" };\n }\n }\n\n public async get(id: number): Promise<ITag | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/tags/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as ITag;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to tag\" };\n }\n }\n}\n","import type { IError, IParamsList, IUser, IUserList } from \"../types\";\nimport type { ZapApi } from \"../zap-api\";\n\nexport class User {\n constructor(protected api: ZapApi) {}\n\n public async list(params?: IParamsList): Promise<IUserList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/users?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IUserList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list users\" };\n }\n }\n\n public async get(id: number): Promise<IUser | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/users/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IUser;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to user\" };\n }\n }\n}\n","import type { IError, IParamsList, ITicket, ITicketList } from \"../types\";\nimport type { ZapApi } from \"../zap-api\";\n\nexport class Ticket {\n constructor(protected api: ZapApi) {}\n\n public async list(params?: IParamsList): Promise<ITicketList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/tickets?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicketList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list tickets\" };\n }\n }\n\n public async get(id: number): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/tickets/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to ticket\" };\n }\n }\n}\n","import \"dotenv/config\";\nimport { ZapApi } from \"./zap-api\";\nimport { Connection } from \"./lib\";\nimport { Contact } from \"./lib/contact\";\nimport { Message } from \"./lib/message\";\nimport { Queue } from \"./lib/queue\";\nimport { Tag } from \"./lib/tag\";\nimport { User } from \"./lib/user\";\nimport { Ticket } from \"./lib/ticket\";\n\nexport class Zdk extends ZapApi {\n public readonly tickets = new Ticket(this);\n\n public readonly connections = new Connection(this);\n\n public readonly contacts = new Contact(this);\n\n public readonly messages = new Message(this);\n\n public readonly queues = new Queue(this);\n\n public readonly tags = new Tag(this);\n\n public readonly users = new User(this);\n}\n"],"mappings":"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","names":["require_package","__commonJSMin","exports","module","require_main","__commonJSMin","exports","module","fs","path","os","crypto","packageJson","version","LINE","parse","src","obj","lines","match","key","value","maybeQuote","_parseVault","options","vaultPath","_vaultPath","result","DotenvModule","keys","_dotenvKey","length","decrypted","attrs","_instructions","error","_log","message","_warn","_debug","dotenvKey","uri","environment","environmentKey","ciphertext","dotenvPath","_resolveHome","envPath","_configVault","parsed","processEnv","configDotenv","encoding","debug","e","config","decrypt","encrypted","keyStr","nonce","authTag","aesgcm","isRange","invalidKeyLength","decryptionFailed","msg","populate","override","require_env_options","__commonJSMin","exports","module","options","require_cli_options","__commonJSMin","exports","module","re","args","acc","cur","matches","src_exports","__export","Zdk","__toCommonJS","ZapApi","rootUrl","token","method","endpoint","body","contentType","fullUrl","options","Connection","api","error","id","connections","connectionExists","connection","validConnection","Contact","api","params","page","pageSize","response","error","id","Message","api","params","page","pageSize","ticketId","contactId","dateFrom","dateTo","response","error","id","to","data","type","Queue","api","params","page","pageSize","response","error","id","Tag","api","params","page","pageSize","response","error","id","User","api","params","page","pageSize","response","error","id","Ticket","api","params","page","pageSize","response","error","id","Zdk","ZapApi","Ticket","Connection","Contact","Message","Queue","Tag","User"]}
package/package.json ADDED
@@ -0,0 +1,53 @@
1
+ {
2
+ "name": "zdk",
3
+ "version": "0.1.0",
4
+ "description": "Kit de desenvolvimento da Zap",
5
+ "main": "index.js",
6
+ "scripts": {
7
+ "dev": "tsup --watch",
8
+ "build": "rm -rf ./dist && tsup",
9
+ "lint": "eslint .",
10
+ "lint:fix": "eslint --fix .",
11
+ "format": "prettier --write .",
12
+ "docs:generate": "typedoc"
13
+ },
14
+ "repository": {
15
+ "type": "git",
16
+ "url": "git+https://github.com/innovtech-developers/zdk.git"
17
+ },
18
+ "keywords": [
19
+ "zap",
20
+ "kit",
21
+ "sdk",
22
+ "zap-contabil",
23
+ "zap-plataforma",
24
+ "whatsapp",
25
+ "sistema-de-atendimento"
26
+ ],
27
+ "author": "Lucas Bogos <@lucas-bogos>",
28
+ "license": "ISC",
29
+ "bugs": {
30
+ "url": "https://github.com/innovtech-developers/zdk/issues"
31
+ },
32
+ "homepage": "https://github.com/innovtech-developers/zdk#readme",
33
+ "files": [
34
+ "./dist",
35
+ "!/dist/.tsbuildinfo",
36
+ "/LICENSE"
37
+ ],
38
+ "devDependencies": {
39
+ "@types/node": "^20.10.0",
40
+ "@typescript-eslint/eslint-plugin": "^6.12.0",
41
+ "@typescript-eslint/parser": "^6.12.0",
42
+ "dotenv": "^16.3.1",
43
+ "eslint": "^8.54.0",
44
+ "prettier": "^3.1.0",
45
+ "tsup": "^8.0.1",
46
+ "typedoc": "^0.25.3",
47
+ "typedoc-plugin-markdown": "^3.17.1",
48
+ "typescript": "^5.2.*"
49
+ },
50
+ "dependencies": {
51
+ "axios": "^1.6.2"
52
+ }
53
+ }