zdk 0.7.2 → 0.7.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/dist/esm/index.js +0 -4
- package/dist/esm/index.js.map +0 -1
- package/dist/index.d.mts +0 -261
- package/dist/index.d.ts +0 -261
- package/dist/index.js +0 -4
- package/dist/index.js.map +0 -1
package/package.json
CHANGED
package/dist/esm/index.js
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
var f=(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 O=g((se,q)=>{q.exports={name:"dotenv",version:"16.4.5",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","test:coverage":"tap --coverage-report=lcov",prerelease:"npm test",release:"standard-version"},repository:{type:"git",url:"git://github.com/motdotla/dotenv.git"},funding:"https://dotenvx.com",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 L=g((ne,u)=>{var D=f("fs"),w=f("path"),M=f("os"),S=f("crypto"),F=O(),b=F.version,G=/(?:^|^)\s*(?:export\s+)?([\w.-]+)(?:\s*=\s*?|:\s+?)(\s*'(?:\\'|[^'])*'|\s*"(?:\\"|[^"])*"|\s*`(?:\\`|[^`])*`|[^#\r\n]+)?\s*(?:#.*)?(?:$|$)/mg;function Y(t){let r={},e=t.toString();e=e.replace(/\r\n?/mg,`
|
|
2
|
-
`);let o;for(;(o=G.exec(e))!=null;){let s=o[1],n=o[2]||"";n=n.trim();let a=n[0];n=n.replace(/^(['"`])([\s\S]*)\1$/mg,"$2"),a==='"'&&(n=n.replace(/\\n/g,`
|
|
3
|
-
`),n=n.replace(/\\r/g,"\r")),r[s]=n}return r}function j(t){let r=$(t),e=p.configDotenv({path:r});if(!e.parsed){let a=new Error(`MISSING_DATA: Cannot parse ${r} for an unknown reason`);throw a.code="MISSING_DATA",a}let o=V(t).split(","),s=o.length,n;for(let a=0;a<s;a++)try{let i=o[a].trim(),c=Z(e,i);n=p.decrypt(c.ciphertext,c.key);break}catch(i){if(a+1>=s)throw i}return p.parse(n)}function K(t){console.log(`[dotenv@${b}][INFO] ${t}`)}function z(t){console.log(`[dotenv@${b}][WARN] ${t}`)}function I(t){console.log(`[dotenv@${b}][DEBUG] ${t}`)}function V(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 Z(t,r){let e;try{e=new URL(r)}catch(i){if(i.code==="ERR_INVALID_URL"){let c=new Error("INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenvx.com/vault/.env.vault?environment=development");throw c.code="INVALID_DOTENV_KEY",c}throw i}let o=e.password;if(!o){let i=new Error("INVALID_DOTENV_KEY: Missing key part");throw i.code="INVALID_DOTENV_KEY",i}let s=e.searchParams.get("environment");if(!s){let i=new Error("INVALID_DOTENV_KEY: Missing environment part");throw i.code="INVALID_DOTENV_KEY",i}let n=`DOTENV_VAULT_${s.toUpperCase()}`,a=t.parsed[n];if(!a){let i=new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${n} in your .env.vault file.`);throw i.code="NOT_FOUND_DOTENV_ENVIRONMENT",i}return{ciphertext:a,key:o}}function $(t){let r=null;if(t&&t.path&&t.path.length>0)if(Array.isArray(t.path))for(let e of t.path)D.existsSync(e)&&(r=e.endsWith(".vault")?e:`${e}.vault`);else r=t.path.endsWith(".vault")?t.path:`${t.path}.vault`;else r=w.resolve(process.cwd(),".env.vault");return D.existsSync(r)?r:null}function P(t){return t[0]==="~"?w.join(M.homedir(),t.slice(1)):t}function B(t){K("Loading env from encrypted .env.vault");let r=p._parseVault(t),e=process.env;return t&&t.processEnv!=null&&(e=t.processEnv),p.populate(e,r,t),{parsed:r}}function Q(t){let r=w.resolve(process.cwd(),".env"),e="utf8",o=!!(t&&t.debug);t&&t.encoding?e=t.encoding:o&&I("No encoding is specified. UTF-8 is used by default");let s=[r];if(t&&t.path)if(!Array.isArray(t.path))s=[P(t.path)];else{s=[];for(let c of t.path)s.push(P(c))}let n,a={};for(let c of s)try{let l=p.parse(D.readFileSync(c,{encoding:e}));p.populate(a,l,t)}catch(l){o&&I(`Failed to load ${c} ${l.message}`),n=l}let i=process.env;return t&&t.processEnv!=null&&(i=t.processEnv),p.populate(i,a,t),n?{parsed:a,error:n}:{parsed:a}}function H(t){if(V(t).length===0)return p.configDotenv(t);let r=$(t);return r?p._configVault(t):(z(`You set DOTENV_KEY but you are missing a .env.vault file at ${r}. Did you forget to build it?`),p.configDotenv(t))}function W(t,r){let e=Buffer.from(r.slice(-64),"hex"),o=Buffer.from(t,"base64"),s=o.subarray(0,12),n=o.subarray(-16);o=o.subarray(12,-16);try{let a=S.createDecipheriv("aes-256-gcm",e,s);return a.setAuthTag(n),`${a.update(o)}${a.final()}`}catch(a){let i=a instanceof RangeError,c=a.message==="Invalid key length",l=a.message==="Unsupported state or unable to authenticate data";if(i||c){let d=new Error("INVALID_DOTENV_KEY: It must be 64 characters long (or more)");throw d.code="INVALID_DOTENV_KEY",d}else if(l){let d=new Error("DECRYPTION_FAILED: Please check your DOTENV_KEY");throw d.code="DECRYPTION_FAILED",d}else throw a}}function J(t,r,e={}){let o=!!(e&&e.debug),s=!!(e&&e.override);if(typeof r!="object"){let n=new Error("OBJECT_REQUIRED: Please check the processEnv argument being passed to populate");throw n.code="OBJECT_REQUIRED",n}for(let n of Object.keys(r))Object.prototype.hasOwnProperty.call(t,n)?(s===!0&&(t[n]=r[n]),o&&I(s===!0?`"${n}" is already defined and WAS overwritten`:`"${n}" is already defined and was NOT overwritten`)):t[n]=r[n]}var p={configDotenv:Q,_configVault:B,_parseVault:j,config:H,decrypt:W,parse:Y,populate:J};u.exports.configDotenv=p.configDotenv;u.exports._configVault=p._configVault;u.exports._parseVault=p._parseVault;u.exports.config=p.config;u.exports.decrypt=p.decrypt;u.exports.parse=p.parse;u.exports.populate=p.populate;u.exports=p});var x=g((ae,C)=>{var m={};process.env.DOTENV_CONFIG_ENCODING!=null&&(m.encoding=process.env.DOTENV_CONFIG_ENCODING);process.env.DOTENV_CONFIG_PATH!=null&&(m.path=process.env.DOTENV_CONFIG_PATH);process.env.DOTENV_CONFIG_DEBUG!=null&&(m.debug=process.env.DOTENV_CONFIG_DEBUG);process.env.DOTENV_CONFIG_OVERRIDE!=null&&(m.override=process.env.DOTENV_CONFIG_OVERRIDE);process.env.DOTENV_CONFIG_DOTENV_KEY!=null&&(m.DOTENV_KEY=process.env.DOTENV_CONFIG_DOTENV_KEY);C.exports=m});var R=g((ie,A)=>{var X=/^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/;A.exports=function(r){return r.reduce(function(e,o){let s=o.match(X);return s&&(e[s[1]]=s[2]),e},{})}});(function(){L().config(Object.assign({},x(),R()(process.argv)))})();import ee,{AxiosError as re}from"axios";var y=class{_rootUrl;_token;constructor(r,e){this._rootUrl=r||process.env?.ZAPPY_URL,this._token=e||process.env?.ZAPPY_TOKEN}async makeRequest(r,e,o,s){if(!this._rootUrl||!this._token)throw new Error("Missing base url or API token");try{let a={url:this._rootUrl+e,method:r,headers:{"Content-Type":"application/json",Authorization:`Bearer ${this._token}`,...s},data:o};return await(await ee(a)).data}catch(n){throw n instanceof re&&"error"in n.response.data?new Error(n?.response?.data?.error):new Error("No request possible")}}};var E=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 o=(await this.api.makeRequest("GET","/api/connections"))?.connections,s=o.find(n=>n.id===r);if(!s||s?.status!=="CONNECTED"){let n=o?.find(a=>a?.status==="CONNECTED");return n||{error:"Connection not found"}}return s}catch(e){return console.error(e),{error:"Unable to connection"}}}};var h=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/contacts?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}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:"No contact details could be obtained"}}}async update(r,e){try{let o=await this.api.makeRequest("PUT",`/api/contacts/${r}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Unable to update contact"}}}};import te from"form-data";var v=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20,ticketId:s="",contactId:n="",dateFrom:a="",dateTo:i=""}=r||{},c=await this.api.makeRequest("GET",`/api/messages?page=${e}&pageSize=${o}&ticketId=${s}&contactId=${n}&dateFrom=${a}&dateToo=${i}`);return c?.error?{error:c?.error}:c}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,o){try{if(!o||o==="text"){let s=await this.api.makeRequest("POST",`/api/send/${r}`,e);return s?.error?{error:s?.error}:s}else{let{caption:s,connectionFrom:n,media:a}=e,i=new te;i.append("media",a),i.append("caption",s||""),i.append("connectionFrom",n);let c=await this.api.makeRequest("POST",`/api/send/${o}/${r}`,i,{...i.getHeaders()});return c?.error?{error:c?.error}:c}}catch(s){return console.error(s),{error:"Cannot send message"}}}};var T=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/queues?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}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 _=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/tags?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}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 k=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/tickets?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}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"}}}async transfer(r,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${r}/transfer`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot transfer ticket"}}}async resolve(r,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${r}/resolve`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot resolve ticket"}}}async update(r,e){try{let o=await this.api.makeRequest("PUT",`/api/tickets/${r}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot update ticket"}}}};var N=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/users?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}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 U=class extends y{tickets=new k(this);connections=new E(this);contacts=new h(this);messages=new v(this);queues=new T(this);tags=new _(this);users=new N(this)};export{y as ZappyApi,U as Zdk};
|
|
4
|
-
//# sourceMappingURL=index.js.map
|
package/dist/esm/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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/zappy-api.ts","../../src/lib/connection.ts","../../src/lib/contact.ts","../../src/lib/message.ts","../../src/lib/queue.ts","../../src/lib/tag.ts","../../src/lib/ticket.ts","../../src/lib/user.ts","../../src/zdk.ts"],"sourcesContent":["{\n \"name\": \"dotenv\",\n \"version\": \"16.4.5\",\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 \"test:coverage\": \"tap --coverage-report=lcov\",\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://dotenvx.com\",\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 const err = new Error(`MISSING_DATA: Cannot parse ${vaultPath} for an unknown reason`)\n err.code = 'MISSING_DATA'\n throw err\n }\n\n // handle scenario for comma separated keys - for use with key rotation\n // example: DOTENV_KEY=\"dotenv://:key_1234@dotenvx.com/vault/.env.vault?environment=prod,dotenv://:key_7890@dotenvx.com/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 const err = new Error('INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenvx.com/vault/.env.vault?environment=development')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n }\n\n throw error\n }\n\n // Get decrypt key\n const key = uri.password\n if (!key) {\n const err = new Error('INVALID_DOTENV_KEY: Missing key part')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n }\n\n // Get environment\n const environment = uri.searchParams.get('environment')\n if (!environment) {\n const err = new Error('INVALID_DOTENV_KEY: Missing environment part')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\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 const err = new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${environmentKey} in your .env.vault file.`)\n err.code = 'NOT_FOUND_DOTENV_ENVIRONMENT'\n throw err\n }\n\n return { ciphertext, key }\n}\n\nfunction _vaultPath (options) {\n let possibleVaultPath = null\n\n if (options && options.path && options.path.length > 0) {\n if (Array.isArray(options.path)) {\n for (const filepath of options.path) {\n if (fs.existsSync(filepath)) {\n possibleVaultPath = filepath.endsWith('.vault') ? filepath : `${filepath}.vault`\n }\n }\n } else {\n possibleVaultPath = options.path.endsWith('.vault') ? options.path : `${options.path}.vault`\n }\n } else {\n possibleVaultPath = path.resolve(process.cwd(), '.env.vault')\n }\n\n if (fs.existsSync(possibleVaultPath)) {\n return possibleVaultPath\n }\n\n return null\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 const dotenvPath = path.resolve(process.cwd(), '.env')\n let encoding = 'utf8'\n const debug = Boolean(options && options.debug)\n\n if (options && options.encoding) {\n encoding = options.encoding\n } else {\n if (debug) {\n _debug('No encoding is specified. UTF-8 is used by default')\n }\n }\n\n let optionPaths = [dotenvPath] // default, look for .env\n if (options && options.path) {\n if (!Array.isArray(options.path)) {\n optionPaths = [_resolveHome(options.path)]\n } else {\n optionPaths = [] // reset default\n for (const filepath of options.path) {\n optionPaths.push(_resolveHome(filepath))\n }\n }\n }\n\n // Build the parsed data in a temporary object (because we need to return it). Once we have the final\n // parsed data, we will combine it with process.env (or options.processEnv if provided).\n let lastError\n const parsedAll = {}\n for (const path of optionPaths) {\n try {\n // Specifying an encoding returns a string instead of a buffer\n const parsed = DotenvModule.parse(fs.readFileSync(path, { encoding }))\n\n DotenvModule.populate(parsedAll, parsed, options)\n } catch (e) {\n if (debug) {\n _debug(`Failed to load ${path} ${e.message}`)\n }\n lastError = e\n }\n }\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsedAll, options)\n\n if (lastError) {\n return { parsed: parsedAll, error: lastError }\n } else {\n return { parsed: parsedAll }\n }\n}\n\n// Populates process.env from .env file\nfunction config (options) {\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 const vaultPath = _vaultPath(options)\n\n // dotenvKey exists but .env.vault file does not exist\n if (!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.subarray(0, 12)\n const authTag = ciphertext.subarray(-16)\n ciphertext = ciphertext.subarray(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 err = new Error('INVALID_DOTENV_KEY: It must be 64 characters long (or more)')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n } else if (decryptionFailed) {\n const err = new Error('DECRYPTION_FAILED: Please check your DOTENV_KEY')\n err.code = 'DECRYPTION_FAILED'\n throw err\n } else {\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 const err = new Error('OBJECT_REQUIRED: Please check the processEnv argument being passed to populate')\n err.code = 'OBJECT_REQUIRED'\n throw err\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\";\nimport axios, { AxiosError } from \"axios\";\n\nexport class ZappyApi {\n private _rootUrl: string;\n private _token: string;\n\n constructor(rootUrl?: string, token?: string) {\n this._rootUrl = rootUrl || process.env?.ZAPPY_URL;\n this._token = token || process.env?.ZAPPY_TOKEN;\n }\n\n async makeRequest(\n method: HttpMethod,\n endpoint: string,\n data?: unknown,\n customHeaders?: Record<string, string>\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): Promise<any> {\n if (!this._rootUrl || !this._token) {\n throw new Error(\"Missing base url or API token\");\n }\n\n try {\n const url: string = this._rootUrl + endpoint;\n const options = {\n url,\n method,\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${this._token}`,\n ...customHeaders,\n },\n data,\n };\n const request = await axios(options);\n const response = await request.data;\n return response;\n } catch (error: unknown) {\n if (error instanceof AxiosError && \"error\" in error.response.data) {\n throw new Error(error?.response?.data?.error);\n }\n\n throw new Error(\"No request possible\");\n }\n }\n}\n","import { ZappyApi } from \"../zappy-api\";\nimport type { IConnection, IConnectionList, IError } from \"../types\";\n\nexport class Connection {\n constructor(protected api: ZappyApi) {}\n\n 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 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\n return connectionExists;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to connection\" };\n }\n }\n}\n","import type {\n IContact,\n IContactList,\n IContactPostData,\n IError,\n IParamsList,\n} from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Contact {\n constructor(protected api: ZappyApi) {}\n\n 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 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: \"No contact details could be obtained\" };\n }\n }\n\n async update(id: number, data: IContactPostData): Promise<IContact | IError> {\n try {\n const response = await this.api.makeRequest(\n \"PUT\",\n `/api/contacts/${id}`,\n data\n );\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 update contact\" };\n }\n }\n}\n","import type {\n IError,\n IMessage,\n IMessageList,\n IParamsMessageList,\n ISendMediaMessage,\n ISendMessage,\n MediaType,\n} from \"../types\";\n\nimport type { ZappyApi } from \"../zappy-api\";\nimport FormData from \"form-data\";\n\nexport class Message {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsMessageList): 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 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 async send(to: string, data: ISendMessage): Promise<Message | IError>;\n\n async send(\n to: string,\n data: ISendMediaMessage,\n type: Exclude<MediaType, \"text\">\n ): Promise<Message | IError>;\n\n async send(\n to: string,\n data: ISendMessage | ISendMediaMessage,\n /**\n * @default \"text\"\n */\n type?: MediaType\n ): Promise<Message | IError> {\n try {\n if (!type || type === \"text\") {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/send/${to}`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response;\n } else {\n const { caption, connectionFrom, media } = data as ISendMediaMessage;\n const form = new FormData();\n form.append(\"media\", media);\n form.append(\"caption\", caption || \"\");\n form.append(\"connectionFrom\", connectionFrom);\n\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/send/${type}/${to}`,\n form,\n {\n ...form.getHeaders(),\n }\n );\n\n if (response?.error) return { error: response?.error };\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 { ZappyApi } from \"../zappy-api\";\n\nexport class Queue {\n constructor(protected api: ZappyApi) {}\n\n 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 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 { ZappyApi } from \"../zappy-api\";\n\nexport class Tag {\n constructor(protected api: ZappyApi) {}\n\n 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 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 {\n IError,\n IParamsList,\n ITicket,\n ITicketList,\n ITicketResolveForm,\n ITicketTransferForm,\n ITicketUpdateForm,\n} from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Ticket {\n constructor(protected api: ZappyApi) {}\n\n 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 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 async transfer(\n id: number,\n data: ITicketTransferForm\n ): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/tickets/${id}/transfer`,\n data\n );\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: \"Cannot transfer ticket\" };\n }\n }\n\n async resolve(\n id: number,\n data: ITicketResolveForm\n ): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/tickets/${id}/resolve`,\n data\n );\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: \"Cannot resolve ticket\" };\n }\n }\n\n async update(id: number, data: ITicketUpdateForm): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"PUT\",\n `/api/tickets/${id}`,\n data\n );\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: \"Cannot update ticket\" };\n }\n }\n}\n","import type { IError, IParamsList, IUser, IUserList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class User {\n constructor(protected api: ZappyApi) {}\n\n 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 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 \"dotenv/config\";\n\nimport { ZappyApi } from \"./zappy-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 ZappyApi {\n readonly tickets = new Ticket(this);\n\n readonly connections = new Connection(this);\n\n readonly contacts = new Contact(this);\n\n readonly messages = new Message(this);\n\n readonly queues = new Queue(this);\n\n readonly tags = new Tag(this);\n\n readonly users = new User(this);\n}\n\nexport default Zdk;\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","err","keys","_dotenvKey","length","decrypted","i","attrs","_instructions","error","_log","message","_warn","_debug","dotenvKey","uri","environment","environmentKey","ciphertext","possibleVaultPath","filepath","_resolveHome","envPath","_configVault","parsed","processEnv","configDotenv","dotenvPath","encoding","debug","optionPaths","lastError","parsedAll","e","config","decrypt","encrypted","keyStr","nonce","authTag","aesgcm","isRange","invalidKeyLength","decryptionFailed","populate","override","require_env_options","__commonJSMin","exports","module","options","require_cli_options","__commonJSMin","exports","module","re","args","acc","cur","matches","axios","AxiosError","ZappyApi","rootUrl","token","method","endpoint","data","customHeaders","options","error","Connection","api","error","id","connections","connectionExists","connection","validConnection","Contact","api","params","page","pageSize","response","error","id","data","FormData","Message","api","params","page","pageSize","ticketId","contactId","dateFrom","dateTo","response","error","id","to","data","type","caption","connectionFrom","media","form","Queue","api","params","page","pageSize","response","error","id","Tag","api","params","page","pageSize","response","error","id","Ticket","api","params","page","pageSize","response","error","id","data","User","api","params","page","pageSize","response","error","id","Zdk","ZappyApi","Ticket","Connection","Contact","Message","Queue","Tag","User"]}
|
package/dist/index.d.mts
DELETED
|
@@ -1,261 +0,0 @@
|
|
|
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" | "reuseOrClose";
|
|
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: unknown;
|
|
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
|
-
extraInfo: IContactExtraInfo[];
|
|
81
|
-
}
|
|
82
|
-
interface IContactExtraInfo {
|
|
83
|
-
name: string;
|
|
84
|
-
value: string;
|
|
85
|
-
}
|
|
86
|
-
interface IContactPostData {
|
|
87
|
-
name: string;
|
|
88
|
-
number: string;
|
|
89
|
-
email: string;
|
|
90
|
-
profilePicUrl: string;
|
|
91
|
-
isGroup: boolean;
|
|
92
|
-
blocked: boolean;
|
|
93
|
-
userId: number;
|
|
94
|
-
queueId: number;
|
|
95
|
-
createdAt: string;
|
|
96
|
-
updatedAt: string;
|
|
97
|
-
tagsIds: number[];
|
|
98
|
-
extraInfo: IContactExtraInfo[];
|
|
99
|
-
noCheckNumber: boolean;
|
|
100
|
-
}
|
|
101
|
-
interface ITag {
|
|
102
|
-
id: string;
|
|
103
|
-
name: string;
|
|
104
|
-
color: string;
|
|
105
|
-
}
|
|
106
|
-
interface ITicket {
|
|
107
|
-
id: string;
|
|
108
|
-
status: string;
|
|
109
|
-
userId: string;
|
|
110
|
-
contactId: string;
|
|
111
|
-
whatsappId: string;
|
|
112
|
-
queueId: string;
|
|
113
|
-
unreadMessages: number;
|
|
114
|
-
lastMessage: string;
|
|
115
|
-
isGroup: boolean;
|
|
116
|
-
createdAt: string;
|
|
117
|
-
updatedAt: string;
|
|
118
|
-
}
|
|
119
|
-
interface IUser {
|
|
120
|
-
id: string;
|
|
121
|
-
name: string;
|
|
122
|
-
email: string;
|
|
123
|
-
status: string;
|
|
124
|
-
profile: string;
|
|
125
|
-
enabled: boolean;
|
|
126
|
-
createdAt: string;
|
|
127
|
-
updatedAt: string;
|
|
128
|
-
}
|
|
129
|
-
interface IQueue {
|
|
130
|
-
id: string;
|
|
131
|
-
name: string;
|
|
132
|
-
color: string;
|
|
133
|
-
}
|
|
134
|
-
interface IMessageObject {
|
|
135
|
-
id: string;
|
|
136
|
-
createdAt: string;
|
|
137
|
-
updatedAt: string;
|
|
138
|
-
body: string;
|
|
139
|
-
mediaUrl: string;
|
|
140
|
-
mediaType: string;
|
|
141
|
-
isDeleted: boolean;
|
|
142
|
-
quotedMsgId: string;
|
|
143
|
-
ticketId: string;
|
|
144
|
-
contactId: string;
|
|
145
|
-
fromMe: boolean;
|
|
146
|
-
ack: string;
|
|
147
|
-
read: boolean;
|
|
148
|
-
locationLatitude: string;
|
|
149
|
-
locationLongitude: string;
|
|
150
|
-
editedFromId: string;
|
|
151
|
-
editedToId: string;
|
|
152
|
-
error: string;
|
|
153
|
-
}
|
|
154
|
-
interface IContactList extends IPagination {
|
|
155
|
-
contacts: IContact[];
|
|
156
|
-
}
|
|
157
|
-
interface IQueueList extends IPagination {
|
|
158
|
-
queues: IQueue[];
|
|
159
|
-
}
|
|
160
|
-
interface ITicketList extends IPagination {
|
|
161
|
-
tickets: ITicket[];
|
|
162
|
-
}
|
|
163
|
-
interface ITagList extends IPagination {
|
|
164
|
-
tags: ITag[];
|
|
165
|
-
}
|
|
166
|
-
interface IMessageList extends IPagination {
|
|
167
|
-
messages: IMessageObject[];
|
|
168
|
-
}
|
|
169
|
-
interface IUserList extends IPagination {
|
|
170
|
-
users: IUser[];
|
|
171
|
-
}
|
|
172
|
-
interface IConnectionList {
|
|
173
|
-
connections: IConnection[];
|
|
174
|
-
}
|
|
175
|
-
interface ITicketUpdateForm {
|
|
176
|
-
status?: TicketStatus;
|
|
177
|
-
userId?: number;
|
|
178
|
-
queueId?: number;
|
|
179
|
-
}
|
|
180
|
-
interface ITicketTransferForm {
|
|
181
|
-
queueId?: number;
|
|
182
|
-
userId?: number;
|
|
183
|
-
connectionId?: number;
|
|
184
|
-
}
|
|
185
|
-
interface ITicketResolveForm {
|
|
186
|
-
feedbackOption: FeedbackOption;
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
declare class ZappyApi {
|
|
190
|
-
private _rootUrl;
|
|
191
|
-
private _token;
|
|
192
|
-
constructor(rootUrl?: string, token?: string);
|
|
193
|
-
makeRequest(method: HttpMethod, endpoint: string, data?: unknown, customHeaders?: Record<string, string>): Promise<any>;
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
declare class Connection {
|
|
197
|
-
protected api: ZappyApi;
|
|
198
|
-
constructor(api: ZappyApi);
|
|
199
|
-
list(): Promise<IConnectionList | IError>;
|
|
200
|
-
get(id?: number): Promise<IConnection | IError>;
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
declare class Contact {
|
|
204
|
-
protected api: ZappyApi;
|
|
205
|
-
constructor(api: ZappyApi);
|
|
206
|
-
list(params?: IParamsList): Promise<IContactList | IError>;
|
|
207
|
-
get(id: number): Promise<IContact | IError>;
|
|
208
|
-
update(id: number, data: IContactPostData): Promise<IContact | IError>;
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
declare class Message {
|
|
212
|
-
protected api: ZappyApi;
|
|
213
|
-
constructor(api: ZappyApi);
|
|
214
|
-
list(params?: IParamsMessageList): Promise<IMessageList | IError>;
|
|
215
|
-
get(id: string): Promise<IMessage | IError>;
|
|
216
|
-
send(to: string, data: ISendMessage): Promise<Message | IError>;
|
|
217
|
-
send(to: string, data: ISendMediaMessage, type: Exclude<MediaType, "text">): Promise<Message | IError>;
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
declare class Queue {
|
|
221
|
-
protected api: ZappyApi;
|
|
222
|
-
constructor(api: ZappyApi);
|
|
223
|
-
list(params?: IParamsList): Promise<IQueueList | IError>;
|
|
224
|
-
get(id: number): Promise<IQueue | IError>;
|
|
225
|
-
}
|
|
226
|
-
|
|
227
|
-
declare class Tag {
|
|
228
|
-
protected api: ZappyApi;
|
|
229
|
-
constructor(api: ZappyApi);
|
|
230
|
-
list(params?: IParamsList): Promise<ITagList | IError>;
|
|
231
|
-
get(id: number): Promise<ITag | IError>;
|
|
232
|
-
}
|
|
233
|
-
|
|
234
|
-
declare class Ticket {
|
|
235
|
-
protected api: ZappyApi;
|
|
236
|
-
constructor(api: ZappyApi);
|
|
237
|
-
list(params?: IParamsList): Promise<ITicketList | IError>;
|
|
238
|
-
get(id: number): Promise<ITicket | IError>;
|
|
239
|
-
transfer(id: number, data: ITicketTransferForm): Promise<ITicket | IError>;
|
|
240
|
-
resolve(id: number, data: ITicketResolveForm): Promise<ITicket | IError>;
|
|
241
|
-
update(id: number, data: ITicketUpdateForm): Promise<ITicket | IError>;
|
|
242
|
-
}
|
|
243
|
-
|
|
244
|
-
declare class User {
|
|
245
|
-
protected api: ZappyApi;
|
|
246
|
-
constructor(api: ZappyApi);
|
|
247
|
-
list(params?: IParamsList): Promise<IUserList | IError>;
|
|
248
|
-
get(id: number): Promise<IUser | IError>;
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
declare class Zdk extends ZappyApi {
|
|
252
|
-
readonly tickets: Ticket;
|
|
253
|
-
readonly connections: Connection;
|
|
254
|
-
readonly contacts: Contact;
|
|
255
|
-
readonly messages: Message;
|
|
256
|
-
readonly queues: Queue;
|
|
257
|
-
readonly tags: Tag;
|
|
258
|
-
readonly users: User;
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
export { type ConnectionStatus, type FeedbackOption, type HttpMethod, type IConnection, type IConnectionList, type IContact, type IContactExtraInfo, type IContactList, type IContactPostData, 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, ZappyApi, Zdk };
|
package/dist/index.d.ts
DELETED
|
@@ -1,261 +0,0 @@
|
|
|
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" | "reuseOrClose";
|
|
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: unknown;
|
|
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
|
-
extraInfo: IContactExtraInfo[];
|
|
81
|
-
}
|
|
82
|
-
interface IContactExtraInfo {
|
|
83
|
-
name: string;
|
|
84
|
-
value: string;
|
|
85
|
-
}
|
|
86
|
-
interface IContactPostData {
|
|
87
|
-
name: string;
|
|
88
|
-
number: string;
|
|
89
|
-
email: string;
|
|
90
|
-
profilePicUrl: string;
|
|
91
|
-
isGroup: boolean;
|
|
92
|
-
blocked: boolean;
|
|
93
|
-
userId: number;
|
|
94
|
-
queueId: number;
|
|
95
|
-
createdAt: string;
|
|
96
|
-
updatedAt: string;
|
|
97
|
-
tagsIds: number[];
|
|
98
|
-
extraInfo: IContactExtraInfo[];
|
|
99
|
-
noCheckNumber: boolean;
|
|
100
|
-
}
|
|
101
|
-
interface ITag {
|
|
102
|
-
id: string;
|
|
103
|
-
name: string;
|
|
104
|
-
color: string;
|
|
105
|
-
}
|
|
106
|
-
interface ITicket {
|
|
107
|
-
id: string;
|
|
108
|
-
status: string;
|
|
109
|
-
userId: string;
|
|
110
|
-
contactId: string;
|
|
111
|
-
whatsappId: string;
|
|
112
|
-
queueId: string;
|
|
113
|
-
unreadMessages: number;
|
|
114
|
-
lastMessage: string;
|
|
115
|
-
isGroup: boolean;
|
|
116
|
-
createdAt: string;
|
|
117
|
-
updatedAt: string;
|
|
118
|
-
}
|
|
119
|
-
interface IUser {
|
|
120
|
-
id: string;
|
|
121
|
-
name: string;
|
|
122
|
-
email: string;
|
|
123
|
-
status: string;
|
|
124
|
-
profile: string;
|
|
125
|
-
enabled: boolean;
|
|
126
|
-
createdAt: string;
|
|
127
|
-
updatedAt: string;
|
|
128
|
-
}
|
|
129
|
-
interface IQueue {
|
|
130
|
-
id: string;
|
|
131
|
-
name: string;
|
|
132
|
-
color: string;
|
|
133
|
-
}
|
|
134
|
-
interface IMessageObject {
|
|
135
|
-
id: string;
|
|
136
|
-
createdAt: string;
|
|
137
|
-
updatedAt: string;
|
|
138
|
-
body: string;
|
|
139
|
-
mediaUrl: string;
|
|
140
|
-
mediaType: string;
|
|
141
|
-
isDeleted: boolean;
|
|
142
|
-
quotedMsgId: string;
|
|
143
|
-
ticketId: string;
|
|
144
|
-
contactId: string;
|
|
145
|
-
fromMe: boolean;
|
|
146
|
-
ack: string;
|
|
147
|
-
read: boolean;
|
|
148
|
-
locationLatitude: string;
|
|
149
|
-
locationLongitude: string;
|
|
150
|
-
editedFromId: string;
|
|
151
|
-
editedToId: string;
|
|
152
|
-
error: string;
|
|
153
|
-
}
|
|
154
|
-
interface IContactList extends IPagination {
|
|
155
|
-
contacts: IContact[];
|
|
156
|
-
}
|
|
157
|
-
interface IQueueList extends IPagination {
|
|
158
|
-
queues: IQueue[];
|
|
159
|
-
}
|
|
160
|
-
interface ITicketList extends IPagination {
|
|
161
|
-
tickets: ITicket[];
|
|
162
|
-
}
|
|
163
|
-
interface ITagList extends IPagination {
|
|
164
|
-
tags: ITag[];
|
|
165
|
-
}
|
|
166
|
-
interface IMessageList extends IPagination {
|
|
167
|
-
messages: IMessageObject[];
|
|
168
|
-
}
|
|
169
|
-
interface IUserList extends IPagination {
|
|
170
|
-
users: IUser[];
|
|
171
|
-
}
|
|
172
|
-
interface IConnectionList {
|
|
173
|
-
connections: IConnection[];
|
|
174
|
-
}
|
|
175
|
-
interface ITicketUpdateForm {
|
|
176
|
-
status?: TicketStatus;
|
|
177
|
-
userId?: number;
|
|
178
|
-
queueId?: number;
|
|
179
|
-
}
|
|
180
|
-
interface ITicketTransferForm {
|
|
181
|
-
queueId?: number;
|
|
182
|
-
userId?: number;
|
|
183
|
-
connectionId?: number;
|
|
184
|
-
}
|
|
185
|
-
interface ITicketResolveForm {
|
|
186
|
-
feedbackOption: FeedbackOption;
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
declare class ZappyApi {
|
|
190
|
-
private _rootUrl;
|
|
191
|
-
private _token;
|
|
192
|
-
constructor(rootUrl?: string, token?: string);
|
|
193
|
-
makeRequest(method: HttpMethod, endpoint: string, data?: unknown, customHeaders?: Record<string, string>): Promise<any>;
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
declare class Connection {
|
|
197
|
-
protected api: ZappyApi;
|
|
198
|
-
constructor(api: ZappyApi);
|
|
199
|
-
list(): Promise<IConnectionList | IError>;
|
|
200
|
-
get(id?: number): Promise<IConnection | IError>;
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
declare class Contact {
|
|
204
|
-
protected api: ZappyApi;
|
|
205
|
-
constructor(api: ZappyApi);
|
|
206
|
-
list(params?: IParamsList): Promise<IContactList | IError>;
|
|
207
|
-
get(id: number): Promise<IContact | IError>;
|
|
208
|
-
update(id: number, data: IContactPostData): Promise<IContact | IError>;
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
declare class Message {
|
|
212
|
-
protected api: ZappyApi;
|
|
213
|
-
constructor(api: ZappyApi);
|
|
214
|
-
list(params?: IParamsMessageList): Promise<IMessageList | IError>;
|
|
215
|
-
get(id: string): Promise<IMessage | IError>;
|
|
216
|
-
send(to: string, data: ISendMessage): Promise<Message | IError>;
|
|
217
|
-
send(to: string, data: ISendMediaMessage, type: Exclude<MediaType, "text">): Promise<Message | IError>;
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
declare class Queue {
|
|
221
|
-
protected api: ZappyApi;
|
|
222
|
-
constructor(api: ZappyApi);
|
|
223
|
-
list(params?: IParamsList): Promise<IQueueList | IError>;
|
|
224
|
-
get(id: number): Promise<IQueue | IError>;
|
|
225
|
-
}
|
|
226
|
-
|
|
227
|
-
declare class Tag {
|
|
228
|
-
protected api: ZappyApi;
|
|
229
|
-
constructor(api: ZappyApi);
|
|
230
|
-
list(params?: IParamsList): Promise<ITagList | IError>;
|
|
231
|
-
get(id: number): Promise<ITag | IError>;
|
|
232
|
-
}
|
|
233
|
-
|
|
234
|
-
declare class Ticket {
|
|
235
|
-
protected api: ZappyApi;
|
|
236
|
-
constructor(api: ZappyApi);
|
|
237
|
-
list(params?: IParamsList): Promise<ITicketList | IError>;
|
|
238
|
-
get(id: number): Promise<ITicket | IError>;
|
|
239
|
-
transfer(id: number, data: ITicketTransferForm): Promise<ITicket | IError>;
|
|
240
|
-
resolve(id: number, data: ITicketResolveForm): Promise<ITicket | IError>;
|
|
241
|
-
update(id: number, data: ITicketUpdateForm): Promise<ITicket | IError>;
|
|
242
|
-
}
|
|
243
|
-
|
|
244
|
-
declare class User {
|
|
245
|
-
protected api: ZappyApi;
|
|
246
|
-
constructor(api: ZappyApi);
|
|
247
|
-
list(params?: IParamsList): Promise<IUserList | IError>;
|
|
248
|
-
get(id: number): Promise<IUser | IError>;
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
declare class Zdk extends ZappyApi {
|
|
252
|
-
readonly tickets: Ticket;
|
|
253
|
-
readonly connections: Connection;
|
|
254
|
-
readonly contacts: Contact;
|
|
255
|
-
readonly messages: Message;
|
|
256
|
-
readonly queues: Queue;
|
|
257
|
-
readonly tags: Tag;
|
|
258
|
-
readonly users: User;
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
export { type ConnectionStatus, type FeedbackOption, type HttpMethod, type IConnection, type IConnectionList, type IContact, type IContactExtraInfo, type IContactList, type IContactPostData, 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, ZappyApi, Zdk };
|
package/dist/index.js
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
var G=Object.create;var g=Object.defineProperty;var Y=Object.getOwnPropertyDescriptor;var j=Object.getOwnPropertyNames;var K=Object.getPrototypeOf,z=Object.prototype.hasOwnProperty;var I=(t,r)=>()=>(r||t((r={exports:{}}).exports,r),r.exports),Z=(t,r)=>{for(var e in r)g(t,e,{get:r[e],enumerable:!0})},V=(t,r,e,o)=>{if(r&&typeof r=="object"||typeof r=="function")for(let s of j(r))!z.call(t,s)&&s!==e&&g(t,s,{get:()=>r[s],enumerable:!(o=Y(r,s))||o.enumerable});return t};var $=(t,r,e)=>(e=t!=null?G(K(t)):{},V(r||!t||!t.__esModule?g(e,"default",{value:t,enumerable:!0}):e,t)),B=t=>V(g({},"__esModule",{value:!0}),t);var L=I((de,Q)=>{Q.exports={name:"dotenv",version:"16.4.5",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","test:coverage":"tap --coverage-report=lcov",prerelease:"npm test",release:"standard-version"},repository:{type:"git",url:"git://github.com/motdotla/dotenv.git"},funding:"https://dotenvx.com",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 R=I((fe,u)=>{var w=require("fs"),b=require("path"),H=require("os"),W=require("crypto"),J=L(),O=J.version,X=/(?:^|^)\s*(?:export\s+)?([\w.-]+)(?:\s*=\s*?|:\s+?)(\s*'(?:\\'|[^'])*'|\s*"(?:\\"|[^"])*"|\s*`(?:\\`|[^`])*`|[^#\r\n]+)?\s*(?:#.*)?(?:$|$)/mg;function ee(t){let r={},e=t.toString();e=e.replace(/\r\n?/mg,`
|
|
2
|
-
`);let o;for(;(o=X.exec(e))!=null;){let s=o[1],n=o[2]||"";n=n.trim();let a=n[0];n=n.replace(/^(['"`])([\s\S]*)\1$/mg,"$2"),a==='"'&&(n=n.replace(/\\n/g,`
|
|
3
|
-
`),n=n.replace(/\\r/g,"\r")),r[s]=n}return r}function re(t){let r=A(t),e=p.configDotenv({path:r});if(!e.parsed){let a=new Error(`MISSING_DATA: Cannot parse ${r} for an unknown reason`);throw a.code="MISSING_DATA",a}let o=x(t).split(","),s=o.length,n;for(let a=0;a<s;a++)try{let i=o[a].trim(),c=se(e,i);n=p.decrypt(c.ciphertext,c.key);break}catch(i){if(a+1>=s)throw i}return p.parse(n)}function te(t){console.log(`[dotenv@${O}][INFO] ${t}`)}function oe(t){console.log(`[dotenv@${O}][WARN] ${t}`)}function y(t){console.log(`[dotenv@${O}][DEBUG] ${t}`)}function x(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 se(t,r){let e;try{e=new URL(r)}catch(i){if(i.code==="ERR_INVALID_URL"){let c=new Error("INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenvx.com/vault/.env.vault?environment=development");throw c.code="INVALID_DOTENV_KEY",c}throw i}let o=e.password;if(!o){let i=new Error("INVALID_DOTENV_KEY: Missing key part");throw i.code="INVALID_DOTENV_KEY",i}let s=e.searchParams.get("environment");if(!s){let i=new Error("INVALID_DOTENV_KEY: Missing environment part");throw i.code="INVALID_DOTENV_KEY",i}let n=`DOTENV_VAULT_${s.toUpperCase()}`,a=t.parsed[n];if(!a){let i=new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${n} in your .env.vault file.`);throw i.code="NOT_FOUND_DOTENV_ENVIRONMENT",i}return{ciphertext:a,key:o}}function A(t){let r=null;if(t&&t.path&&t.path.length>0)if(Array.isArray(t.path))for(let e of t.path)w.existsSync(e)&&(r=e.endsWith(".vault")?e:`${e}.vault`);else r=t.path.endsWith(".vault")?t.path:`${t.path}.vault`;else r=b.resolve(process.cwd(),".env.vault");return w.existsSync(r)?r:null}function C(t){return t[0]==="~"?b.join(H.homedir(),t.slice(1)):t}function ne(t){te("Loading env from encrypted .env.vault");let r=p._parseVault(t),e=process.env;return t&&t.processEnv!=null&&(e=t.processEnv),p.populate(e,r,t),{parsed:r}}function ae(t){let r=b.resolve(process.cwd(),".env"),e="utf8",o=!!(t&&t.debug);t&&t.encoding?e=t.encoding:o&&y("No encoding is specified. UTF-8 is used by default");let s=[r];if(t&&t.path)if(!Array.isArray(t.path))s=[C(t.path)];else{s=[];for(let c of t.path)s.push(C(c))}let n,a={};for(let c of s)try{let l=p.parse(w.readFileSync(c,{encoding:e}));p.populate(a,l,t)}catch(l){o&&y(`Failed to load ${c} ${l.message}`),n=l}let i=process.env;return t&&t.processEnv!=null&&(i=t.processEnv),p.populate(i,a,t),n?{parsed:a,error:n}:{parsed:a}}function ie(t){if(x(t).length===0)return p.configDotenv(t);let r=A(t);return r?p._configVault(t):(oe(`You set DOTENV_KEY but you are missing a .env.vault file at ${r}. Did you forget to build it?`),p.configDotenv(t))}function ce(t,r){let e=Buffer.from(r.slice(-64),"hex"),o=Buffer.from(t,"base64"),s=o.subarray(0,12),n=o.subarray(-16);o=o.subarray(12,-16);try{let a=W.createDecipheriv("aes-256-gcm",e,s);return a.setAuthTag(n),`${a.update(o)}${a.final()}`}catch(a){let i=a instanceof RangeError,c=a.message==="Invalid key length",l=a.message==="Unsupported state or unable to authenticate data";if(i||c){let d=new Error("INVALID_DOTENV_KEY: It must be 64 characters long (or more)");throw d.code="INVALID_DOTENV_KEY",d}else if(l){let d=new Error("DECRYPTION_FAILED: Please check your DOTENV_KEY");throw d.code="DECRYPTION_FAILED",d}else throw a}}function pe(t,r,e={}){let o=!!(e&&e.debug),s=!!(e&&e.override);if(typeof r!="object"){let n=new Error("OBJECT_REQUIRED: Please check the processEnv argument being passed to populate");throw n.code="OBJECT_REQUIRED",n}for(let n of Object.keys(r))Object.prototype.hasOwnProperty.call(t,n)?(s===!0&&(t[n]=r[n]),o&&y(s===!0?`"${n}" is already defined and WAS overwritten`:`"${n}" is already defined and was NOT overwritten`)):t[n]=r[n]}var p={configDotenv:ae,_configVault:ne,_parseVault:re,config:ie,decrypt:ce,parse:ee,populate:pe};u.exports.configDotenv=p.configDotenv;u.exports._configVault=p._configVault;u.exports._parseVault=p._parseVault;u.exports.config=p.config;u.exports.decrypt=p.decrypt;u.exports.parse=p.parse;u.exports.populate=p.populate;u.exports=p});var q=I((ge,U)=>{var m={};process.env.DOTENV_CONFIG_ENCODING!=null&&(m.encoding=process.env.DOTENV_CONFIG_ENCODING);process.env.DOTENV_CONFIG_PATH!=null&&(m.path=process.env.DOTENV_CONFIG_PATH);process.env.DOTENV_CONFIG_DEBUG!=null&&(m.debug=process.env.DOTENV_CONFIG_DEBUG);process.env.DOTENV_CONFIG_OVERRIDE!=null&&(m.override=process.env.DOTENV_CONFIG_OVERRIDE);process.env.DOTENV_CONFIG_DOTENV_KEY!=null&&(m.DOTENV_KEY=process.env.DOTENV_CONFIG_DOTENV_KEY);U.exports=m});var S=I((Ie,M)=>{var ue=/^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/;M.exports=function(r){return r.reduce(function(e,o){let s=o.match(ue);return s&&(e[s[1]]=s[2]),e},{})}});var le={};Z(le,{ZappyApi:()=>f,Zdk:()=>P});module.exports=B(le);(function(){R().config(Object.assign({},q(),S()(process.argv)))})();var E=$(require("axios")),f=class{_rootUrl;_token;constructor(r,e){this._rootUrl=r||process.env?.ZAPPY_URL,this._token=e||process.env?.ZAPPY_TOKEN}async makeRequest(r,e,o,s){if(!this._rootUrl||!this._token)throw new Error("Missing base url or API token");try{let a={url:this._rootUrl+e,method:r,headers:{"Content-Type":"application/json",Authorization:`Bearer ${this._token}`,...s},data:o};return await(await(0,E.default)(a)).data}catch(n){throw n instanceof E.AxiosError&&"error"in n.response.data?new Error(n?.response?.data?.error):new Error("No request possible")}}};var h=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 o=(await this.api.makeRequest("GET","/api/connections"))?.connections,s=o.find(n=>n.id===r);if(!s||s?.status!=="CONNECTED"){let n=o?.find(a=>a?.status==="CONNECTED");return n||{error:"Connection not found"}}return s}catch(e){return console.error(e),{error:"Unable to connection"}}}};var v=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/contacts?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}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:"No contact details could be obtained"}}}async update(r,e){try{let o=await this.api.makeRequest("PUT",`/api/contacts/${r}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Unable to update contact"}}}};var F=$(require("form-data")),T=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20,ticketId:s="",contactId:n="",dateFrom:a="",dateTo:i=""}=r||{},c=await this.api.makeRequest("GET",`/api/messages?page=${e}&pageSize=${o}&ticketId=${s}&contactId=${n}&dateFrom=${a}&dateToo=${i}`);return c?.error?{error:c?.error}:c}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,o){try{if(!o||o==="text"){let s=await this.api.makeRequest("POST",`/api/send/${r}`,e);return s?.error?{error:s?.error}:s}else{let{caption:s,connectionFrom:n,media:a}=e,i=new F.default;i.append("media",a),i.append("caption",s||""),i.append("connectionFrom",n);let c=await this.api.makeRequest("POST",`/api/send/${o}/${r}`,i,{...i.getHeaders()});return c?.error?{error:c?.error}:c}}catch(s){return console.error(s),{error:"Cannot send message"}}}};var _=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/queues?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}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 k=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/tags?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}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 N=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/tickets?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}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"}}}async transfer(r,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${r}/transfer`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot transfer ticket"}}}async resolve(r,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${r}/resolve`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot resolve ticket"}}}async update(r,e){try{let o=await this.api.makeRequest("PUT",`/api/tickets/${r}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot update ticket"}}}};var D=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/users?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}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 P=class extends f{tickets=new N(this);connections=new h(this);contacts=new v(this);messages=new T(this);queues=new _(this);tags=new k(this);users=new D(this)};0&&(module.exports={ZappyApi,Zdk});
|
|
4
|
-
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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/zappy-api.ts","../src/lib/connection.ts","../src/lib/contact.ts","../src/lib/message.ts","../src/lib/queue.ts","../src/lib/tag.ts","../src/lib/ticket.ts","../src/lib/user.ts","../src/zdk.ts"],"sourcesContent":["{\n \"name\": \"dotenv\",\n \"version\": \"16.4.5\",\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 \"test:coverage\": \"tap --coverage-report=lcov\",\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://dotenvx.com\",\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 const err = new Error(`MISSING_DATA: Cannot parse ${vaultPath} for an unknown reason`)\n err.code = 'MISSING_DATA'\n throw err\n }\n\n // handle scenario for comma separated keys - for use with key rotation\n // example: DOTENV_KEY=\"dotenv://:key_1234@dotenvx.com/vault/.env.vault?environment=prod,dotenv://:key_7890@dotenvx.com/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 const err = new Error('INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenvx.com/vault/.env.vault?environment=development')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n }\n\n throw error\n }\n\n // Get decrypt key\n const key = uri.password\n if (!key) {\n const err = new Error('INVALID_DOTENV_KEY: Missing key part')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n }\n\n // Get environment\n const environment = uri.searchParams.get('environment')\n if (!environment) {\n const err = new Error('INVALID_DOTENV_KEY: Missing environment part')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\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 const err = new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${environmentKey} in your .env.vault file.`)\n err.code = 'NOT_FOUND_DOTENV_ENVIRONMENT'\n throw err\n }\n\n return { ciphertext, key }\n}\n\nfunction _vaultPath (options) {\n let possibleVaultPath = null\n\n if (options && options.path && options.path.length > 0) {\n if (Array.isArray(options.path)) {\n for (const filepath of options.path) {\n if (fs.existsSync(filepath)) {\n possibleVaultPath = filepath.endsWith('.vault') ? filepath : `${filepath}.vault`\n }\n }\n } else {\n possibleVaultPath = options.path.endsWith('.vault') ? options.path : `${options.path}.vault`\n }\n } else {\n possibleVaultPath = path.resolve(process.cwd(), '.env.vault')\n }\n\n if (fs.existsSync(possibleVaultPath)) {\n return possibleVaultPath\n }\n\n return null\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 const dotenvPath = path.resolve(process.cwd(), '.env')\n let encoding = 'utf8'\n const debug = Boolean(options && options.debug)\n\n if (options && options.encoding) {\n encoding = options.encoding\n } else {\n if (debug) {\n _debug('No encoding is specified. UTF-8 is used by default')\n }\n }\n\n let optionPaths = [dotenvPath] // default, look for .env\n if (options && options.path) {\n if (!Array.isArray(options.path)) {\n optionPaths = [_resolveHome(options.path)]\n } else {\n optionPaths = [] // reset default\n for (const filepath of options.path) {\n optionPaths.push(_resolveHome(filepath))\n }\n }\n }\n\n // Build the parsed data in a temporary object (because we need to return it). Once we have the final\n // parsed data, we will combine it with process.env (or options.processEnv if provided).\n let lastError\n const parsedAll = {}\n for (const path of optionPaths) {\n try {\n // Specifying an encoding returns a string instead of a buffer\n const parsed = DotenvModule.parse(fs.readFileSync(path, { encoding }))\n\n DotenvModule.populate(parsedAll, parsed, options)\n } catch (e) {\n if (debug) {\n _debug(`Failed to load ${path} ${e.message}`)\n }\n lastError = e\n }\n }\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsedAll, options)\n\n if (lastError) {\n return { parsed: parsedAll, error: lastError }\n } else {\n return { parsed: parsedAll }\n }\n}\n\n// Populates process.env from .env file\nfunction config (options) {\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 const vaultPath = _vaultPath(options)\n\n // dotenvKey exists but .env.vault file does not exist\n if (!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.subarray(0, 12)\n const authTag = ciphertext.subarray(-16)\n ciphertext = ciphertext.subarray(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 err = new Error('INVALID_DOTENV_KEY: It must be 64 characters long (or more)')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n } else if (decryptionFailed) {\n const err = new Error('DECRYPTION_FAILED: Please check your DOTENV_KEY')\n err.code = 'DECRYPTION_FAILED'\n throw err\n } else {\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 const err = new Error('OBJECT_REQUIRED: Please check the processEnv argument being passed to populate')\n err.code = 'OBJECT_REQUIRED'\n throw err\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\";\nexport * from \"./zappy-api\";\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\";\nimport axios, { AxiosError } from \"axios\";\n\nexport class ZappyApi {\n private _rootUrl: string;\n private _token: string;\n\n constructor(rootUrl?: string, token?: string) {\n this._rootUrl = rootUrl || process.env?.ZAPPY_URL;\n this._token = token || process.env?.ZAPPY_TOKEN;\n }\n\n async makeRequest(\n method: HttpMethod,\n endpoint: string,\n data?: unknown,\n customHeaders?: Record<string, string>\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): Promise<any> {\n if (!this._rootUrl || !this._token) {\n throw new Error(\"Missing base url or API token\");\n }\n\n try {\n const url: string = this._rootUrl + endpoint;\n const options = {\n url,\n method,\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${this._token}`,\n ...customHeaders,\n },\n data,\n };\n const request = await axios(options);\n const response = await request.data;\n return response;\n } catch (error: unknown) {\n if (error instanceof AxiosError && \"error\" in error.response.data) {\n throw new Error(error?.response?.data?.error);\n }\n\n throw new Error(\"No request possible\");\n }\n }\n}\n","import { ZappyApi } from \"../zappy-api\";\nimport type { IConnection, IConnectionList, IError } from \"../types\";\n\nexport class Connection {\n constructor(protected api: ZappyApi) {}\n\n 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 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\n return connectionExists;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to connection\" };\n }\n }\n}\n","import type {\n IContact,\n IContactList,\n IContactPostData,\n IError,\n IParamsList,\n} from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Contact {\n constructor(protected api: ZappyApi) {}\n\n 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 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: \"No contact details could be obtained\" };\n }\n }\n\n async update(id: number, data: IContactPostData): Promise<IContact | IError> {\n try {\n const response = await this.api.makeRequest(\n \"PUT\",\n `/api/contacts/${id}`,\n data\n );\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 update contact\" };\n }\n }\n}\n","import type {\n IError,\n IMessage,\n IMessageList,\n IParamsMessageList,\n ISendMediaMessage,\n ISendMessage,\n MediaType,\n} from \"../types\";\n\nimport type { ZappyApi } from \"../zappy-api\";\nimport FormData from \"form-data\";\n\nexport class Message {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsMessageList): 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 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 async send(to: string, data: ISendMessage): Promise<Message | IError>;\n\n async send(\n to: string,\n data: ISendMediaMessage,\n type: Exclude<MediaType, \"text\">\n ): Promise<Message | IError>;\n\n async send(\n to: string,\n data: ISendMessage | ISendMediaMessage,\n /**\n * @default \"text\"\n */\n type?: MediaType\n ): Promise<Message | IError> {\n try {\n if (!type || type === \"text\") {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/send/${to}`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response;\n } else {\n const { caption, connectionFrom, media } = data as ISendMediaMessage;\n const form = new FormData();\n form.append(\"media\", media);\n form.append(\"caption\", caption || \"\");\n form.append(\"connectionFrom\", connectionFrom);\n\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/send/${type}/${to}`,\n form,\n {\n ...form.getHeaders(),\n }\n );\n\n if (response?.error) return { error: response?.error };\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 { ZappyApi } from \"../zappy-api\";\n\nexport class Queue {\n constructor(protected api: ZappyApi) {}\n\n 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 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 { ZappyApi } from \"../zappy-api\";\n\nexport class Tag {\n constructor(protected api: ZappyApi) {}\n\n 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 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 {\n IError,\n IParamsList,\n ITicket,\n ITicketList,\n ITicketResolveForm,\n ITicketTransferForm,\n ITicketUpdateForm,\n} from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Ticket {\n constructor(protected api: ZappyApi) {}\n\n 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 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 async transfer(\n id: number,\n data: ITicketTransferForm\n ): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/tickets/${id}/transfer`,\n data\n );\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: \"Cannot transfer ticket\" };\n }\n }\n\n async resolve(\n id: number,\n data: ITicketResolveForm\n ): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/tickets/${id}/resolve`,\n data\n );\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: \"Cannot resolve ticket\" };\n }\n }\n\n async update(id: number, data: ITicketUpdateForm): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"PUT\",\n `/api/tickets/${id}`,\n data\n );\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: \"Cannot update ticket\" };\n }\n }\n}\n","import type { IError, IParamsList, IUser, IUserList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class User {\n constructor(protected api: ZappyApi) {}\n\n 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 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 \"dotenv/config\";\n\nimport { ZappyApi } from \"./zappy-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 ZappyApi {\n readonly tickets = new Ticket(this);\n\n readonly connections = new Connection(this);\n\n readonly contacts = new Contact(this);\n\n readonly messages = new Message(this);\n\n readonly queues = new Queue(this);\n\n readonly tags = new Tag(this);\n\n readonly users = new User(this);\n}\n\nexport default Zdk;\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","err","keys","_dotenvKey","length","decrypted","i","attrs","_instructions","error","_log","message","_warn","_debug","dotenvKey","uri","environment","environmentKey","ciphertext","possibleVaultPath","filepath","_resolveHome","envPath","_configVault","parsed","processEnv","configDotenv","dotenvPath","encoding","debug","optionPaths","lastError","parsedAll","e","config","decrypt","encrypted","keyStr","nonce","authTag","aesgcm","isRange","invalidKeyLength","decryptionFailed","populate","override","require_env_options","__commonJSMin","exports","module","options","require_cli_options","__commonJSMin","exports","module","re","args","acc","cur","matches","index_exports","__export","ZappyApi","Zdk","__toCommonJS","import_axios","ZappyApi","rootUrl","token","method","endpoint","data","customHeaders","options","axios","error","Connection","api","error","id","connections","connectionExists","connection","validConnection","Contact","api","params","page","pageSize","response","error","id","data","import_form_data","Message","api","params","page","pageSize","ticketId","contactId","dateFrom","dateTo","response","error","id","to","data","type","caption","connectionFrom","media","form","FormData","Queue","api","params","page","pageSize","response","error","id","Tag","api","params","page","pageSize","response","error","id","Ticket","api","params","page","pageSize","response","error","id","data","User","api","params","page","pageSize","response","error","id","Zdk","ZappyApi","Ticket","Connection","Contact","Message","Queue","Tag","User"]}
|