zdk 0.7.14 → 0.7.16
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/dist/esm/index.js +4 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/index.d.mts +265 -0
- package/dist/index.d.ts +265 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var d=(r=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(r,{get:(t,e)=>(typeof require<"u"?require:t)[e]}):r)(function(r){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+r+'" is not supported')});var g=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports);var P=g((ae,M)=>{M.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 A=g((ie,u)=>{var D=d("fs"),b=d("path"),q=d("os"),F=d("crypto"),G=P(),O=G.version,j=/(?:^|^)\s*(?:export\s+)?([\w.-]+)(?:\s*=\s*?|:\s+?)(\s*'(?:\\'|[^'])*'|\s*"(?:\\"|[^"])*"|\s*`(?:\\`|[^`])*`|[^#\r\n]+)?\s*(?:#.*)?(?:$|$)/mg;function K(r){let t={},e=r.toString();e=e.replace(/\r\n?/mg,`
|
|
2
|
+
`);let o;for(;(o=j.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")),t[s]=n}return t}function Y(r){let t=L(r),e=p.configDotenv({path:t});if(!e.parsed){let a=new Error(`MISSING_DATA: Cannot parse ${t} for an unknown reason`);throw a.code="MISSING_DATA",a}let o=$(r).split(","),s=o.length,n;for(let a=0;a<s;a++)try{let i=o[a].trim(),c=B(e,i);n=p.decrypt(c.ciphertext,c.key);break}catch(i){if(a+1>=s)throw i}return p.parse(n)}function z(r){console.log(`[dotenv@${O}][INFO] ${r}`)}function Z(r){console.log(`[dotenv@${O}][WARN] ${r}`)}function y(r){console.log(`[dotenv@${O}][DEBUG] ${r}`)}function $(r){return r&&r.DOTENV_KEY&&r.DOTENV_KEY.length>0?r.DOTENV_KEY:process.env.DOTENV_KEY&&process.env.DOTENV_KEY.length>0?process.env.DOTENV_KEY:""}function B(r,t){let e;try{e=new URL(t)}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=r.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 L(r){let t=null;if(r&&r.path&&r.path.length>0)if(Array.isArray(r.path))for(let e of r.path)D.existsSync(e)&&(t=e.endsWith(".vault")?e:`${e}.vault`);else t=r.path.endsWith(".vault")?r.path:`${r.path}.vault`;else t=b.resolve(process.cwd(),".env.vault");return D.existsSync(t)?t:null}function V(r){return r[0]==="~"?b.join(q.homedir(),r.slice(1)):r}function Q(r){z("Loading env from encrypted .env.vault");let t=p._parseVault(r),e=process.env;return r&&r.processEnv!=null&&(e=r.processEnv),p.populate(e,t,r),{parsed:t}}function H(r){let t=b.resolve(process.cwd(),".env"),e="utf8",o=!!(r&&r.debug);r&&r.encoding?e=r.encoding:o&&y("No encoding is specified. UTF-8 is used by default");let s=[t];if(r&&r.path)if(!Array.isArray(r.path))s=[V(r.path)];else{s=[];for(let c of r.path)s.push(V(c))}let n,a={};for(let c of s)try{let l=p.parse(D.readFileSync(c,{encoding:e}));p.populate(a,l,r)}catch(l){o&&y(`Failed to load ${c} ${l.message}`),n=l}let i=process.env;return r&&r.processEnv!=null&&(i=r.processEnv),p.populate(i,a,r),n?{parsed:a,error:n}:{parsed:a}}function J(r){if($(r).length===0)return p.configDotenv(r);let t=L(r);return t?p._configVault(r):(Z(`You set DOTENV_KEY but you are missing a .env.vault file at ${t}. Did you forget to build it?`),p.configDotenv(r))}function W(r,t){let e=Buffer.from(t.slice(-64),"hex"),o=Buffer.from(r,"base64"),s=o.subarray(0,12),n=o.subarray(-16);o=o.subarray(12,-16);try{let a=F.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 f=new Error("INVALID_DOTENV_KEY: It must be 64 characters long (or more)");throw f.code="INVALID_DOTENV_KEY",f}else if(l){let f=new Error("DECRYPTION_FAILED: Please check your DOTENV_KEY");throw f.code="DECRYPTION_FAILED",f}else throw a}}function X(r,t,e={}){let o=!!(e&&e.debug),s=!!(e&&e.override);if(typeof t!="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(t))Object.prototype.hasOwnProperty.call(r,n)?(s===!0&&(r[n]=t[n]),o&&y(s===!0?`"${n}" is already defined and WAS overwritten`:`"${n}" is already defined and was NOT overwritten`)):r[n]=t[n]}var p={configDotenv:H,_configVault:Q,_parseVault:Y,config:J,decrypt:W,parse:K,populate:X};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((ce,R)=>{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);R.exports=m});var S=g((pe,C)=>{var ee=/^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/;C.exports=function(t){return t.reduce(function(e,o){let s=o.match(ee);return s&&(e[s[1]]=s[2]),e},{})}});(function(){A().config(Object.assign({},x(),S()(process.argv)))})();import re,{AxiosError as te}from"axios";var I=class{_rootUrl;_token;constructor(t,e){this._rootUrl=t||process.env?.ZAPPY_URL,this._token=e||process.env?.ZAPPY_TOKEN}async makeRequest(t,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:t,headers:{"Content-Type":"application/json",Authorization:`Bearer ${this._token}`,...s},data:o};return await(await re(a)).data}catch(n){throw n instanceof te&&"error"in n.response.data?new Error(n?.response?.data?.error):new Error("No request possible")}}};var E=class{constructor(t){this.api=t}async list(){try{return await this.api.makeRequest("GET","/api/connections")}catch(t){return console.error(t),{error:"Unable to list connections"}}}async get(t){try{let o=(await this.api.makeRequest("GET","/api/connections"))?.connections;if(!o||o.length===0)return{error:"No connections available"};let s=o.find(a=>a.id===t),n=a=>a.status==="CONNECTED"||a.status==="WHATSAPP_AUTH";if(!s||!n(s)){let a=o?.find(i=>n(i));return a||{error:"Connection not found"}}return s}catch(e){return console.error(e),{error:"Unable to get connection"}}}};var h=class{constructor(t){this.api=t}async list(t){try{let{page:e=1,pageSize:o=20}=t||{},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(t){try{let e=await this.api.makeRequest("GET",`/api/contacts/${t}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"No contact details could be obtained"}}}async update(t,e){try{let o=await this.api.makeRequest("PUT",`/api/contacts/${t}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Unable to update contact"}}}};import oe from"form-data";function se(r){try{return JSON.stringify(r,null,2)}catch{try{return String(r)}catch{return"[unserializable]"}}}function w(r){if(r==null||typeof r!="object")return r;if(Array.isArray(r))return r.map(w);let t=["media","file","buffer"],e={};for(let o of Object.keys(r))try{if(t.includes(o))e[o]="<redacted>";else if(/(token|password|auth|authorization)/i.test(o))e[o]="<redacted>";else{let s=r[o];e[o]=typeof s=="object"?w(s):s}}catch{e[o]="<unserializable>"}return e}var T=class{constructor(t){this.api=t}async list(t){try{let{page:e=1,pageSize:o=20,ticketId:s="",contactId:n="",dateFrom:a="",dateTo:i=""}=t||{},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(t){try{let e=await this.api.makeRequest("GET",`/api/messages/${t}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to message"}}}async send(t,e,o){try{if(!o||o==="text"){let s=await this.api.makeRequest("POST",`/api/send/${t}`,e);return s?.error?{error:s?.error}:s}else{let{caption:s,connectionFrom:n,media:a}=e,i=new oe;i.append("media",a),i.append("caption",s||""),i.append("connectionFrom",n);let c=await this.api.makeRequest("POST",`/api/send/${o}/${t}`,i,{...i.getHeaders()});return c?.error?{error:c?.error}:c}}catch(s){let n={timestamp:new Date().toISOString(),component:"Message",method:"send",to:t,type:o||"text",data:w(e),error:{message:s?.message?JSON.stringify(s,null,4):JSON.stringify(s),stack:s?.stack,full:JSON.stringify(s,null,4)}};return console.error("ZDK_ERROR",se(n)),{error:"Cannot send message"}}}};var v=class{constructor(t){this.api=t}async list(t){try{let{page:e=1,pageSize:o=20}=t||{},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(t){try{let e=await this.api.makeRequest("GET",`/api/queues/${t}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to queue"}}}};var _=class{constructor(t){this.api=t}async list(t){try{let{page:e=1,pageSize:o=20}=t||{},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(t){try{let e=await this.api.makeRequest("GET",`/api/tags/${t}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to tag"}}}};var k=class{constructor(t){this.api=t}async list(t){try{let{page:e=1,pageSize:o=20}=t||{},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(t){try{let e=await this.api.makeRequest("GET",`/api/tickets/${t}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to ticket"}}}async transfer(t,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${t}/transfer`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot transfer ticket"}}}async resolve(t,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${t}/resolve`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot resolve ticket"}}}async update(t,e){try{let o=await this.api.makeRequest("PUT",`/api/tickets/${t}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot update ticket"}}}};var N=class{constructor(t){this.api=t}async list(t){try{let{page:e=1,pageSize:o=20}=t||{},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(t){try{let e=await this.api.makeRequest("GET",`/api/users/${t}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to user"}}}};var U=class extends I{tickets=new k(this);connections=new E(this);contacts=new h(this);messages=new T(this);queues=new v(this);tags=new _(this);users=new N(this)};export{I as ZappyApi,U as Zdk};
|
|
4
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../node_modules/dotenv/package.json","../../node_modules/dotenv/lib/main.js","../../node_modules/dotenv/lib/env-options.js","../../node_modules/dotenv/lib/cli-options.js","../../node_modules/dotenv/config.js","../../src/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 if (!connections || connections.length === 0) {\n return { error: \"No connections available\" };\n }\n\n const connectionExists = connections.find(\n (connection: IConnection) => connection.id === id\n );\n\n const isValidConnection = (conn: IConnection) => conn.status === \"CONNECTED\" || conn.status === \"WHATSAPP_AUTH\";\n if (!connectionExists || !isValidConnection(connectionExists)) {\n const validConnection = connections?.find(\n (connection: IConnection) => isValidConnection(connection)\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 get connection\" };\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\nfunction safeStringify(obj: any) {\n try {\n return JSON.stringify(obj, null, 2);\n } catch {\n try {\n return String(obj);\n } catch {\n return \"[unserializable]\";\n }\n }\n}\n\nfunction sanitizeData(value: any): any {\n if (value == null) return value;\n if (typeof value !== \"object\") return value;\n\n if (Array.isArray(value)) return value.map(sanitizeData);\n\n const redacted = [\"media\", \"file\", \"buffer\"];\n const out: Record<string, any> = {};\n\n for (const key of Object.keys(value)) {\n try {\n if (redacted.includes(key)) {\n out[key] = \"<redacted>\";\n } else if (/(token|password|auth|authorization)/i.test(key)) {\n out[key] = \"<redacted>\";\n } else {\n const v = value[key];\n out[key] = typeof v === \"object\" ? sanitizeData(v) : v;\n }\n } catch {\n out[key] = \"<unserializable>\";\n }\n }\n\n return out;\n}\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: IMessage } | IError>;\n\n async send(\n to: string,\n data: ISendMediaMessage,\n type: Exclude<MediaType, \"text\">\n ): Promise<{ message: IMessage } | IError>;\n\n async send(\n to: string,\n data: ISendMessage | ISendMediaMessage,\n /**\n * @default \"text\"\n */\n type?: MediaType\n ): Promise<{ message: IMessage } | 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 const log = {\n timestamp: new Date().toISOString(),\n component: \"Message\",\n method: \"send\",\n to,\n type: type || \"text\",\n data: sanitizeData(data),\n error: {\n message: error?.message ? JSON.stringify(error, null, 4) : JSON.stringify(error),\n stack: (error as any)?.stack,\n full: JSON.stringify(error, null, 4),\n },\n };\n\n console.error(\"ZDK_ERROR\", safeStringify(log));\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","isValidConnection","conn","validConnection","Contact","api","params","page","pageSize","response","error","id","data","FormData","safeStringify","obj","sanitizeData","value","redacted","out","key","v","Message","api","params","page","pageSize","ticketId","contactId","dateFrom","dateTo","response","error","id","to","data","type","caption","connectionFrom","media","form","log","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
ADDED
|
@@ -0,0 +1,265 @@
|
|
|
1
|
+
interface IError {
|
|
2
|
+
error: Record<string, unknown> | string;
|
|
3
|
+
}
|
|
4
|
+
type HttpMethod = "GET" | "POST" | "PUT" | "PATCH" | "DELETE";
|
|
5
|
+
type ConnectionStatus = "CONNECTED" | "DISCONNECTED" | "TIMEOUT" | "WHATSAPP_AUTH";
|
|
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<{
|
|
217
|
+
message: IMessage;
|
|
218
|
+
} | IError>;
|
|
219
|
+
send(to: string, data: ISendMediaMessage, type: Exclude<MediaType, "text">): Promise<{
|
|
220
|
+
message: IMessage;
|
|
221
|
+
} | IError>;
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
declare class Queue {
|
|
225
|
+
protected api: ZappyApi;
|
|
226
|
+
constructor(api: ZappyApi);
|
|
227
|
+
list(params?: IParamsList): Promise<IQueueList | IError>;
|
|
228
|
+
get(id: number): Promise<IQueue | IError>;
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
declare class Tag {
|
|
232
|
+
protected api: ZappyApi;
|
|
233
|
+
constructor(api: ZappyApi);
|
|
234
|
+
list(params?: IParamsList): Promise<ITagList | IError>;
|
|
235
|
+
get(id: number): Promise<ITag | IError>;
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
declare class Ticket {
|
|
239
|
+
protected api: ZappyApi;
|
|
240
|
+
constructor(api: ZappyApi);
|
|
241
|
+
list(params?: IParamsList): Promise<ITicketList | IError>;
|
|
242
|
+
get(id: number): Promise<ITicket | IError>;
|
|
243
|
+
transfer(id: number, data: ITicketTransferForm): Promise<ITicket | IError>;
|
|
244
|
+
resolve(id: number, data: ITicketResolveForm): Promise<ITicket | IError>;
|
|
245
|
+
update(id: number, data: ITicketUpdateForm): Promise<ITicket | IError>;
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
declare class User {
|
|
249
|
+
protected api: ZappyApi;
|
|
250
|
+
constructor(api: ZappyApi);
|
|
251
|
+
list(params?: IParamsList): Promise<IUserList | IError>;
|
|
252
|
+
get(id: number): Promise<IUser | IError>;
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
declare class Zdk extends ZappyApi {
|
|
256
|
+
readonly tickets: Ticket;
|
|
257
|
+
readonly connections: Connection;
|
|
258
|
+
readonly contacts: Contact;
|
|
259
|
+
readonly messages: Message;
|
|
260
|
+
readonly queues: Queue;
|
|
261
|
+
readonly tags: Tag;
|
|
262
|
+
readonly users: User;
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
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
ADDED
|
@@ -0,0 +1,265 @@
|
|
|
1
|
+
interface IError {
|
|
2
|
+
error: Record<string, unknown> | string;
|
|
3
|
+
}
|
|
4
|
+
type HttpMethod = "GET" | "POST" | "PUT" | "PATCH" | "DELETE";
|
|
5
|
+
type ConnectionStatus = "CONNECTED" | "DISCONNECTED" | "TIMEOUT" | "WHATSAPP_AUTH";
|
|
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<{
|
|
217
|
+
message: IMessage;
|
|
218
|
+
} | IError>;
|
|
219
|
+
send(to: string, data: ISendMediaMessage, type: Exclude<MediaType, "text">): Promise<{
|
|
220
|
+
message: IMessage;
|
|
221
|
+
} | IError>;
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
declare class Queue {
|
|
225
|
+
protected api: ZappyApi;
|
|
226
|
+
constructor(api: ZappyApi);
|
|
227
|
+
list(params?: IParamsList): Promise<IQueueList | IError>;
|
|
228
|
+
get(id: number): Promise<IQueue | IError>;
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
declare class Tag {
|
|
232
|
+
protected api: ZappyApi;
|
|
233
|
+
constructor(api: ZappyApi);
|
|
234
|
+
list(params?: IParamsList): Promise<ITagList | IError>;
|
|
235
|
+
get(id: number): Promise<ITag | IError>;
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
declare class Ticket {
|
|
239
|
+
protected api: ZappyApi;
|
|
240
|
+
constructor(api: ZappyApi);
|
|
241
|
+
list(params?: IParamsList): Promise<ITicketList | IError>;
|
|
242
|
+
get(id: number): Promise<ITicket | IError>;
|
|
243
|
+
transfer(id: number, data: ITicketTransferForm): Promise<ITicket | IError>;
|
|
244
|
+
resolve(id: number, data: ITicketResolveForm): Promise<ITicket | IError>;
|
|
245
|
+
update(id: number, data: ITicketUpdateForm): Promise<ITicket | IError>;
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
declare class User {
|
|
249
|
+
protected api: ZappyApi;
|
|
250
|
+
constructor(api: ZappyApi);
|
|
251
|
+
list(params?: IParamsList): Promise<IUserList | IError>;
|
|
252
|
+
get(id: number): Promise<IUser | IError>;
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
declare class Zdk extends ZappyApi {
|
|
256
|
+
readonly tickets: Ticket;
|
|
257
|
+
readonly connections: Connection;
|
|
258
|
+
readonly contacts: Contact;
|
|
259
|
+
readonly messages: Message;
|
|
260
|
+
readonly queues: Queue;
|
|
261
|
+
readonly tags: Tag;
|
|
262
|
+
readonly users: User;
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
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
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var j=Object.create;var g=Object.defineProperty;var K=Object.getOwnPropertyDescriptor;var Y=Object.getOwnPropertyNames;var z=Object.getPrototypeOf,Z=Object.prototype.hasOwnProperty;var y=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),B=(r,t)=>{for(var e in t)g(r,e,{get:t[e],enumerable:!0})},$=(r,t,e,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Y(t))!Z.call(r,s)&&s!==e&&g(r,s,{get:()=>t[s],enumerable:!(o=K(t,s))||o.enumerable});return r};var L=(r,t,e)=>(e=r!=null?j(z(r)):{},$(t||!r||!r.__esModule?g(e,"default",{value:r,enumerable:!0}):e,r)),Q=r=>$(g({},"__esModule",{value:!0}),r);var A=y((ge,H)=>{H.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 S=y((ye,u)=>{var b=require("fs"),O=require("path"),J=require("os"),W=require("crypto"),X=A(),w=X.version,ee=/(?:^|^)\s*(?:export\s+)?([\w.-]+)(?:\s*=\s*?|:\s+?)(\s*'(?:\\'|[^'])*'|\s*"(?:\\"|[^"])*"|\s*`(?:\\`|[^`])*`|[^#\r\n]+)?\s*(?:#.*)?(?:$|$)/mg;function re(r){let t={},e=r.toString();e=e.replace(/\r\n?/mg,`
|
|
2
|
+
`);let o;for(;(o=ee.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")),t[s]=n}return t}function te(r){let t=C(r),e=p.configDotenv({path:t});if(!e.parsed){let a=new Error(`MISSING_DATA: Cannot parse ${t} for an unknown reason`);throw a.code="MISSING_DATA",a}let o=x(r).split(","),s=o.length,n;for(let a=0;a<s;a++)try{let i=o[a].trim(),c=ne(e,i);n=p.decrypt(c.ciphertext,c.key);break}catch(i){if(a+1>=s)throw i}return p.parse(n)}function oe(r){console.log(`[dotenv@${w}][INFO] ${r}`)}function se(r){console.log(`[dotenv@${w}][WARN] ${r}`)}function I(r){console.log(`[dotenv@${w}][DEBUG] ${r}`)}function x(r){return r&&r.DOTENV_KEY&&r.DOTENV_KEY.length>0?r.DOTENV_KEY:process.env.DOTENV_KEY&&process.env.DOTENV_KEY.length>0?process.env.DOTENV_KEY:""}function ne(r,t){let e;try{e=new URL(t)}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=r.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 C(r){let t=null;if(r&&r.path&&r.path.length>0)if(Array.isArray(r.path))for(let e of r.path)b.existsSync(e)&&(t=e.endsWith(".vault")?e:`${e}.vault`);else t=r.path.endsWith(".vault")?r.path:`${r.path}.vault`;else t=O.resolve(process.cwd(),".env.vault");return b.existsSync(t)?t:null}function R(r){return r[0]==="~"?O.join(J.homedir(),r.slice(1)):r}function ae(r){oe("Loading env from encrypted .env.vault");let t=p._parseVault(r),e=process.env;return r&&r.processEnv!=null&&(e=r.processEnv),p.populate(e,t,r),{parsed:t}}function ie(r){let t=O.resolve(process.cwd(),".env"),e="utf8",o=!!(r&&r.debug);r&&r.encoding?e=r.encoding:o&&I("No encoding is specified. UTF-8 is used by default");let s=[t];if(r&&r.path)if(!Array.isArray(r.path))s=[R(r.path)];else{s=[];for(let c of r.path)s.push(R(c))}let n,a={};for(let c of s)try{let l=p.parse(b.readFileSync(c,{encoding:e}));p.populate(a,l,r)}catch(l){o&&I(`Failed to load ${c} ${l.message}`),n=l}let i=process.env;return r&&r.processEnv!=null&&(i=r.processEnv),p.populate(i,a,r),n?{parsed:a,error:n}:{parsed:a}}function ce(r){if(x(r).length===0)return p.configDotenv(r);let t=C(r);return t?p._configVault(r):(se(`You set DOTENV_KEY but you are missing a .env.vault file at ${t}. Did you forget to build it?`),p.configDotenv(r))}function pe(r,t){let e=Buffer.from(t.slice(-64),"hex"),o=Buffer.from(r,"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 f=new Error("INVALID_DOTENV_KEY: It must be 64 characters long (or more)");throw f.code="INVALID_DOTENV_KEY",f}else if(l){let f=new Error("DECRYPTION_FAILED: Please check your DOTENV_KEY");throw f.code="DECRYPTION_FAILED",f}else throw a}}function ue(r,t,e={}){let o=!!(e&&e.debug),s=!!(e&&e.override);if(typeof t!="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(t))Object.prototype.hasOwnProperty.call(r,n)?(s===!0&&(r[n]=t[n]),o&&I(s===!0?`"${n}" is already defined and WAS overwritten`:`"${n}" is already defined and was NOT overwritten`)):r[n]=t[n]}var p={configDotenv:ie,_configVault:ae,_parseVault:te,config:ce,decrypt:pe,parse:re,populate:ue};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 M=y((Ie,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 F=y((Ee,q)=>{var le=/^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/;q.exports=function(t){return t.reduce(function(e,o){let s=o.match(le);return s&&(e[s[1]]=s[2]),e},{})}});var fe={};B(fe,{ZappyApi:()=>d,Zdk:()=>V});module.exports=Q(fe);(function(){S().config(Object.assign({},M(),F()(process.argv)))})();var E=L(require("axios")),d=class{_rootUrl;_token;constructor(t,e){this._rootUrl=t||process.env?.ZAPPY_URL,this._token=e||process.env?.ZAPPY_TOKEN}async makeRequest(t,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:t,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(t){this.api=t}async list(){try{return await this.api.makeRequest("GET","/api/connections")}catch(t){return console.error(t),{error:"Unable to list connections"}}}async get(t){try{let o=(await this.api.makeRequest("GET","/api/connections"))?.connections;if(!o||o.length===0)return{error:"No connections available"};let s=o.find(a=>a.id===t),n=a=>a.status==="CONNECTED"||a.status==="WHATSAPP_AUTH";if(!s||!n(s)){let a=o?.find(i=>n(i));return a||{error:"Connection not found"}}return s}catch(e){return console.error(e),{error:"Unable to get connection"}}}};var T=class{constructor(t){this.api=t}async list(t){try{let{page:e=1,pageSize:o=20}=t||{},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(t){try{let e=await this.api.makeRequest("GET",`/api/contacts/${t}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"No contact details could be obtained"}}}async update(t,e){try{let o=await this.api.makeRequest("PUT",`/api/contacts/${t}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Unable to update contact"}}}};var G=L(require("form-data"));function me(r){try{return JSON.stringify(r,null,2)}catch{try{return String(r)}catch{return"[unserializable]"}}}function P(r){if(r==null||typeof r!="object")return r;if(Array.isArray(r))return r.map(P);let t=["media","file","buffer"],e={};for(let o of Object.keys(r))try{if(t.includes(o))e[o]="<redacted>";else if(/(token|password|auth|authorization)/i.test(o))e[o]="<redacted>";else{let s=r[o];e[o]=typeof s=="object"?P(s):s}}catch{e[o]="<unserializable>"}return e}var v=class{constructor(t){this.api=t}async list(t){try{let{page:e=1,pageSize:o=20,ticketId:s="",contactId:n="",dateFrom:a="",dateTo:i=""}=t||{},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(t){try{let e=await this.api.makeRequest("GET",`/api/messages/${t}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to message"}}}async send(t,e,o){try{if(!o||o==="text"){let s=await this.api.makeRequest("POST",`/api/send/${t}`,e);return s?.error?{error:s?.error}:s}else{let{caption:s,connectionFrom:n,media:a}=e,i=new G.default;i.append("media",a),i.append("caption",s||""),i.append("connectionFrom",n);let c=await this.api.makeRequest("POST",`/api/send/${o}/${t}`,i,{...i.getHeaders()});return c?.error?{error:c?.error}:c}}catch(s){let n={timestamp:new Date().toISOString(),component:"Message",method:"send",to:t,type:o||"text",data:P(e),error:{message:s?.message?JSON.stringify(s,null,4):JSON.stringify(s),stack:s?.stack,full:JSON.stringify(s,null,4)}};return console.error("ZDK_ERROR",me(n)),{error:"Cannot send message"}}}};var _=class{constructor(t){this.api=t}async list(t){try{let{page:e=1,pageSize:o=20}=t||{},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(t){try{let e=await this.api.makeRequest("GET",`/api/queues/${t}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to queue"}}}};var k=class{constructor(t){this.api=t}async list(t){try{let{page:e=1,pageSize:o=20}=t||{},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(t){try{let e=await this.api.makeRequest("GET",`/api/tags/${t}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to tag"}}}};var N=class{constructor(t){this.api=t}async list(t){try{let{page:e=1,pageSize:o=20}=t||{},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(t){try{let e=await this.api.makeRequest("GET",`/api/tickets/${t}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to ticket"}}}async transfer(t,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${t}/transfer`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot transfer ticket"}}}async resolve(t,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${t}/resolve`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot resolve ticket"}}}async update(t,e){try{let o=await this.api.makeRequest("PUT",`/api/tickets/${t}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot update ticket"}}}};var D=class{constructor(t){this.api=t}async list(t){try{let{page:e=1,pageSize:o=20}=t||{},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(t){try{let e=await this.api.makeRequest("GET",`/api/users/${t}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to user"}}}};var V=class extends d{tickets=new N(this);connections=new h(this);contacts=new T(this);messages=new v(this);queues=new _(this);tags=new k(this);users=new D(this)};0&&(module.exports={ZappyApi,Zdk});
|
|
4
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../node_modules/dotenv/package.json","../node_modules/dotenv/lib/main.js","../node_modules/dotenv/lib/env-options.js","../node_modules/dotenv/lib/cli-options.js","../src/index.ts","../node_modules/dotenv/config.js","../src/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 if (!connections || connections.length === 0) {\n return { error: \"No connections available\" };\n }\n\n const connectionExists = connections.find(\n (connection: IConnection) => connection.id === id\n );\n\n const isValidConnection = (conn: IConnection) => conn.status === \"CONNECTED\" || conn.status === \"WHATSAPP_AUTH\";\n if (!connectionExists || !isValidConnection(connectionExists)) {\n const validConnection = connections?.find(\n (connection: IConnection) => isValidConnection(connection)\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 get connection\" };\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\nfunction safeStringify(obj: any) {\n try {\n return JSON.stringify(obj, null, 2);\n } catch {\n try {\n return String(obj);\n } catch {\n return \"[unserializable]\";\n }\n }\n}\n\nfunction sanitizeData(value: any): any {\n if (value == null) return value;\n if (typeof value !== \"object\") return value;\n\n if (Array.isArray(value)) return value.map(sanitizeData);\n\n const redacted = [\"media\", \"file\", \"buffer\"];\n const out: Record<string, any> = {};\n\n for (const key of Object.keys(value)) {\n try {\n if (redacted.includes(key)) {\n out[key] = \"<redacted>\";\n } else if (/(token|password|auth|authorization)/i.test(key)) {\n out[key] = \"<redacted>\";\n } else {\n const v = value[key];\n out[key] = typeof v === \"object\" ? sanitizeData(v) : v;\n }\n } catch {\n out[key] = \"<unserializable>\";\n }\n }\n\n return out;\n}\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: IMessage } | IError>;\n\n async send(\n to: string,\n data: ISendMediaMessage,\n type: Exclude<MediaType, \"text\">\n ): Promise<{ message: IMessage } | IError>;\n\n async send(\n to: string,\n data: ISendMessage | ISendMediaMessage,\n /**\n * @default \"text\"\n */\n type?: MediaType\n ): Promise<{ message: IMessage } | 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 const log = {\n timestamp: new Date().toISOString(),\n component: \"Message\",\n method: \"send\",\n to,\n type: type || \"text\",\n data: sanitizeData(data),\n error: {\n message: error?.message ? JSON.stringify(error, null, 4) : JSON.stringify(error),\n stack: (error as any)?.stack,\n full: JSON.stringify(error, null, 4),\n },\n };\n\n console.error(\"ZDK_ERROR\", safeStringify(log));\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","isValidConnection","conn","validConnection","Contact","api","params","page","pageSize","response","error","id","data","import_form_data","safeStringify","obj","sanitizeData","value","redacted","out","key","v","Message","api","params","page","pageSize","ticketId","contactId","dateFrom","dateTo","response","error","id","to","data","type","caption","connectionFrom","media","form","FormData","log","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"]}
|