zdk 0.4.2 → 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -71,3 +71,5 @@ A classe `Zdk` estende `ZapApi` e inclui propriedades para gerenciar recursos pr
71
71
  | tags | Gerencia funcionalidade de tags para categorização. |
72
72
  | tickets | Gerencia tickets de atendimento. |
73
73
  | users | Acessa métodos relacionados a usuários do sistema. |
74
+
75
+ [Documentação completa](./docs/modules/index.md)
package/dist/esm/index.js CHANGED
@@ -1,4 +1,4 @@
1
- var m=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(r,e)=>(typeof require<"u"?require:r)[e]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var f=(t,r)=>()=>(r||t((r={exports:{}}).exports,r),r.exports);var b=f((re,q)=>{q.exports={name:"dotenv",version:"16.3.1",description:"Loads environment variables from .env file",main:"lib/main.js",types:"lib/main.d.ts",exports:{".":{types:"./lib/main.d.ts",require:"./lib/main.js",default:"./lib/main.js"},"./config":"./config.js","./config.js":"./config.js","./lib/env-options":"./lib/env-options.js","./lib/env-options.js":"./lib/env-options.js","./lib/cli-options":"./lib/cli-options.js","./lib/cli-options.js":"./lib/cli-options.js","./package.json":"./package.json"},scripts:{"dts-check":"tsc --project tests/types/tsconfig.json",lint:"standard","lint-readme":"standard-markdown",pretest:"npm run lint && npm run dts-check",test:"tap tests/*.js --100 -Rspec",prerelease:"npm test",release:"standard-version"},repository:{type:"git",url:"git://github.com/motdotla/dotenv.git"},funding:"https://github.com/motdotla/dotenv?sponsor=1",keywords:["dotenv","env",".env","environment","variables","config","settings"],readmeFilename:"README.md",license:"BSD-2-Clause",devDependencies:{"@definitelytyped/dtslint":"^0.0.133","@types/node":"^18.11.3",decache:"^4.6.1",sinon:"^14.0.1",standard:"^17.0.0","standard-markdown":"^7.1.0","standard-version":"^9.5.0",tap:"^16.3.0",tar:"^6.1.11",typescript:"^4.8.4"},engines:{node:">=12"},browser:{fs:!1}}});var $=f((te,u)=>{var O=m("fs"),w=m("path"),A=m("os"),G=m("crypto"),S=b(),N=S.version,j=/(?:^|^)\s*(?:export\s+)?([\w.-]+)(?:\s*=\s*?|:\s+?)(\s*'(?:\\'|[^'])*'|\s*"(?:\\"|[^"])*"|\s*`(?:\\`|[^`])*`|[^#\r\n]+)?\s*(?:#.*)?(?:$|$)/mg;function F(t){let r={},e=t.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")),r[s]=n}return r}function M(t){let r=P(t),e=i.configDotenv({path:r});if(!e.parsed)throw new Error(`MISSING_DATA: Cannot parse ${r} for an unknown reason`);let o=D(t).split(","),s=o.length,n;for(let a=0;a<s;a++)try{let c=o[a].trim(),p=z(e,c);n=i.decrypt(p.ciphertext,p.key);break}catch(c){if(a+1>=s)throw c}return i.parse(n)}function K(t){console.log(`[dotenv@${N}][INFO] ${t}`)}function Y(t){console.log(`[dotenv@${N}][WARN] ${t}`)}function _(t){console.log(`[dotenv@${N}][DEBUG] ${t}`)}function D(t){return t&&t.DOTENV_KEY&&t.DOTENV_KEY.length>0?t.DOTENV_KEY:process.env.DOTENV_KEY&&process.env.DOTENV_KEY.length>0?process.env.DOTENV_KEY:""}function z(t,r){let e;try{e=new URL(r)}catch(c){throw c.code==="ERR_INVALID_URL"?new Error("INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenv.org/vault/.env.vault?environment=development"):c}let o=e.password;if(!o)throw new Error("INVALID_DOTENV_KEY: Missing key part");let s=e.searchParams.get("environment");if(!s)throw new Error("INVALID_DOTENV_KEY: Missing environment part");let n=`DOTENV_VAULT_${s.toUpperCase()}`,a=t.parsed[n];if(!a)throw new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${n} in your .env.vault file.`);return{ciphertext:a,key:o}}function P(t){let r=w.resolve(process.cwd(),".env");return t&&t.path&&t.path.length>0&&(r=t.path),r.endsWith(".vault")?r:`${r}.vault`}function Z(t){return t[0]==="~"?w.join(A.homedir(),t.slice(1)):t}function B(t){K("Loading env from encrypted .env.vault");let r=i._parseVault(t),e=process.env;return t&&t.processEnv!=null&&(e=t.processEnv),i.populate(e,r,t),{parsed:r}}function Q(t){let r=w.resolve(process.cwd(),".env"),e="utf8",o=!!(t&&t.debug);t&&(t.path!=null&&(r=Z(t.path)),t.encoding!=null&&(e=t.encoding));try{let s=i.parse(O.readFileSync(r,{encoding:e})),n=process.env;return t&&t.processEnv!=null&&(n=t.processEnv),i.populate(n,s,t),{parsed:s}}catch(s){return o&&_(`Failed to load ${r} ${s.message}`),{error:s}}}function H(t){let r=P(t);return D(t).length===0?i.configDotenv(t):O.existsSync(r)?i._configVault(t):(Y(`You set DOTENV_KEY but you are missing a .env.vault file at ${r}. Did you forget to build it?`),i.configDotenv(t))}function W(t,r){let e=Buffer.from(r.slice(-64),"hex"),o=Buffer.from(t,"base64"),s=o.slice(0,12),n=o.slice(-16);o=o.slice(12,-16);try{let a=G.createDecipheriv("aes-256-gcm",e,s);return a.setAuthTag(n),`${a.update(o)}${a.final()}`}catch(a){let c=a instanceof RangeError,p=a.message==="Invalid key length",U=a.message==="Unsupported state or unable to authenticate data";if(c||p){let k="INVALID_DOTENV_KEY: It must be 64 characters long (or more)";throw new Error(k)}else if(U){let k="DECRYPTION_FAILED: Please check your DOTENV_KEY";throw new Error(k)}else throw console.error("Error: ",a.code),console.error("Error: ",a.message),a}}function J(t,r,e={}){let o=!!(e&&e.debug),s=!!(e&&e.override);if(typeof r!="object")throw new Error("OBJECT_REQUIRED: Please check the processEnv argument being passed to populate");for(let n of Object.keys(r))Object.prototype.hasOwnProperty.call(t,n)?(s===!0&&(t[n]=r[n]),o&&_(s===!0?`"${n}" is already defined and WAS overwritten`:`"${n}" is already defined and was NOT overwritten`)):t[n]=r[n]}var i={configDotenv:Q,_configVault:B,_parseVault:M,config:H,decrypt:W,parse:F,populate:J};u.exports.configDotenv=i.configDotenv;u.exports._configVault=i._configVault;u.exports._parseVault=i._parseVault;u.exports.config=i.config;u.exports.decrypt=i.decrypt;u.exports.parse=i.parse;u.exports.populate=i.populate;u.exports=i});var V=f((oe,L)=>{var l={};process.env.DOTENV_CONFIG_ENCODING!=null&&(l.encoding=process.env.DOTENV_CONFIG_ENCODING);process.env.DOTENV_CONFIG_PATH!=null&&(l.path=process.env.DOTENV_CONFIG_PATH);process.env.DOTENV_CONFIG_DEBUG!=null&&(l.debug=process.env.DOTENV_CONFIG_DEBUG);process.env.DOTENV_CONFIG_OVERRIDE!=null&&(l.override=process.env.DOTENV_CONFIG_OVERRIDE);process.env.DOTENV_CONFIG_DOTENV_KEY!=null&&(l.DOTENV_KEY=process.env.DOTENV_CONFIG_DOTENV_KEY);L.exports=l});var x=f((se,C)=>{var X=/^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/;C.exports=function(r){return r.reduce(function(e,o){let s=o.match(X);return s&&(e[s[1]]=s[2]),e},{})}});(function(){$().config(Object.assign({},V(),x()(process.argv)))})();var g=class{_rootUrl;_token;constructor(r,e){this._rootUrl=r||process.env?.ZAPPY_URL,this._token=e||process.env?.ZAPPY_TOKEN}async makeRequest(r,e,o,s){if(!this._rootUrl||!this._token)throw new Error("Missing base url or API token");let n=this._rootUrl+e,a={method:r,headers:{Authorization:`Bearer ${this._token}`,"Content-Type":s??"application/json"},body:o?typeof o=="string"?o:JSON.stringify(o):void 0};return await(await fetch(n,a)).json()}};var d=class{constructor(r){this.api=r}async list(){try{return await this.api.makeRequest("GET","/api/connections")}catch(r){return console.error(r),{error:"Unable to list connections"}}}async get(r){try{let o=(await this.api.makeRequest("GET","/api/connections"))?.connections,s=o.find(n=>n.id===r);if(!s||s?.status!=="CONNECTED"){let n=o?.find(a=>a?.status==="CONNECTED");return n||{error:"Connection not found"}}}catch(e){return console.error(e),{error:"Unable to connection"}}}};var y=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/contacts?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list contacts"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/contacts/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to contact"}}}};var I=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20,ticketId:s="",contactId:n="",dateFrom:a="",dateTo:c=""}=r||{},p=await this.api.makeRequest("GET",`/api/messages?page=${e}&pageSize=${o}&ticketId=${s}&contactId=${n}&dateFrom=${a}&dateToo=${c}`);return p?.error?{error:p?.error}:p}catch(e){return console.error(e),{error:"Unable to list message"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/messages/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to message"}}}async send(r,e,o){try{if(!o||o==="text")return await this.api.makeRequest("POST",`/api/send/${r}`,e)}catch(s){return console.error(s),{error:"Cannot send message"}}}};var E=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/queues?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list queues"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/queues/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to queue"}}}};var h=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/tags?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list tags"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/tags/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to tag"}}}};var v=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/tickets?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list tickets"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/tickets/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to ticket"}}}async transfer(r,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${r}/transfer`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot transfer ticket"}}}async resolve(r,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${r}/resolve`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot resolve ticket"}}}async update(r,e){try{let o=await this.api.makeRequest("PUT",`/api/tickets/${r}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot update ticket"}}}};var T=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/users?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list users"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/users/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to user"}}}};var R=class extends g{tickets=new v(this);connections=new d(this);contacts=new y(this);messages=new I(this);queues=new E(this);tags=new h(this);users=new T(this)};export{g as ZappyApi,R as Zdk};
1
+ var f=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(r,e)=>(typeof require<"u"?require:r)[e]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var g=(t,r)=>()=>(r||t((r={exports:{}}).exports,r),r.exports);var O=g((se,q)=>{q.exports={name:"dotenv",version:"16.4.5",description:"Loads environment variables from .env file",main:"lib/main.js",types:"lib/main.d.ts",exports:{".":{types:"./lib/main.d.ts",require:"./lib/main.js",default:"./lib/main.js"},"./config":"./config.js","./config.js":"./config.js","./lib/env-options":"./lib/env-options.js","./lib/env-options.js":"./lib/env-options.js","./lib/cli-options":"./lib/cli-options.js","./lib/cli-options.js":"./lib/cli-options.js","./package.json":"./package.json"},scripts:{"dts-check":"tsc --project tests/types/tsconfig.json",lint:"standard","lint-readme":"standard-markdown",pretest:"npm run lint && npm run dts-check",test:"tap tests/*.js --100 -Rspec","test:coverage":"tap --coverage-report=lcov",prerelease:"npm test",release:"standard-version"},repository:{type:"git",url:"git://github.com/motdotla/dotenv.git"},funding:"https://dotenvx.com",keywords:["dotenv","env",".env","environment","variables","config","settings"],readmeFilename:"README.md",license:"BSD-2-Clause",devDependencies:{"@definitelytyped/dtslint":"^0.0.133","@types/node":"^18.11.3",decache:"^4.6.1",sinon:"^14.0.1",standard:"^17.0.0","standard-markdown":"^7.1.0","standard-version":"^9.5.0",tap:"^16.3.0",tar:"^6.1.11",typescript:"^4.8.4"},engines:{node:">=12"},browser:{fs:!1}}});var L=g((ne,u)=>{var D=f("fs"),w=f("path"),M=f("os"),S=f("crypto"),F=O(),b=F.version,G=/(?:^|^)\s*(?:export\s+)?([\w.-]+)(?:\s*=\s*?|:\s+?)(\s*'(?:\\'|[^'])*'|\s*"(?:\\"|[^"])*"|\s*`(?:\\`|[^`])*`|[^#\r\n]+)?\s*(?:#.*)?(?:$|$)/mg;function Y(t){let r={},e=t.toString();e=e.replace(/\r\n?/mg,`
2
+ `);let o;for(;(o=G.exec(e))!=null;){let s=o[1],n=o[2]||"";n=n.trim();let a=n[0];n=n.replace(/^(['"`])([\s\S]*)\1$/mg,"$2"),a==='"'&&(n=n.replace(/\\n/g,`
3
+ `),n=n.replace(/\\r/g,"\r")),r[s]=n}return r}function j(t){let r=$(t),e=p.configDotenv({path:r});if(!e.parsed){let a=new Error(`MISSING_DATA: Cannot parse ${r} for an unknown reason`);throw a.code="MISSING_DATA",a}let o=V(t).split(","),s=o.length,n;for(let a=0;a<s;a++)try{let i=o[a].trim(),c=Z(e,i);n=p.decrypt(c.ciphertext,c.key);break}catch(i){if(a+1>=s)throw i}return p.parse(n)}function K(t){console.log(`[dotenv@${b}][INFO] ${t}`)}function z(t){console.log(`[dotenv@${b}][WARN] ${t}`)}function I(t){console.log(`[dotenv@${b}][DEBUG] ${t}`)}function V(t){return t&&t.DOTENV_KEY&&t.DOTENV_KEY.length>0?t.DOTENV_KEY:process.env.DOTENV_KEY&&process.env.DOTENV_KEY.length>0?process.env.DOTENV_KEY:""}function Z(t,r){let e;try{e=new URL(r)}catch(i){if(i.code==="ERR_INVALID_URL"){let c=new Error("INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenvx.com/vault/.env.vault?environment=development");throw c.code="INVALID_DOTENV_KEY",c}throw i}let o=e.password;if(!o){let i=new Error("INVALID_DOTENV_KEY: Missing key part");throw i.code="INVALID_DOTENV_KEY",i}let s=e.searchParams.get("environment");if(!s){let i=new Error("INVALID_DOTENV_KEY: Missing environment part");throw i.code="INVALID_DOTENV_KEY",i}let n=`DOTENV_VAULT_${s.toUpperCase()}`,a=t.parsed[n];if(!a){let i=new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${n} in your .env.vault file.`);throw i.code="NOT_FOUND_DOTENV_ENVIRONMENT",i}return{ciphertext:a,key:o}}function $(t){let r=null;if(t&&t.path&&t.path.length>0)if(Array.isArray(t.path))for(let e of t.path)D.existsSync(e)&&(r=e.endsWith(".vault")?e:`${e}.vault`);else r=t.path.endsWith(".vault")?t.path:`${t.path}.vault`;else r=w.resolve(process.cwd(),".env.vault");return D.existsSync(r)?r:null}function P(t){return t[0]==="~"?w.join(M.homedir(),t.slice(1)):t}function B(t){K("Loading env from encrypted .env.vault");let r=p._parseVault(t),e=process.env;return t&&t.processEnv!=null&&(e=t.processEnv),p.populate(e,r,t),{parsed:r}}function Q(t){let r=w.resolve(process.cwd(),".env"),e="utf8",o=!!(t&&t.debug);t&&t.encoding?e=t.encoding:o&&I("No encoding is specified. UTF-8 is used by default");let s=[r];if(t&&t.path)if(!Array.isArray(t.path))s=[P(t.path)];else{s=[];for(let c of t.path)s.push(P(c))}let n,a={};for(let c of s)try{let l=p.parse(D.readFileSync(c,{encoding:e}));p.populate(a,l,t)}catch(l){o&&I(`Failed to load ${c} ${l.message}`),n=l}let i=process.env;return t&&t.processEnv!=null&&(i=t.processEnv),p.populate(i,a,t),n?{parsed:a,error:n}:{parsed:a}}function H(t){if(V(t).length===0)return p.configDotenv(t);let r=$(t);return r?p._configVault(t):(z(`You set DOTENV_KEY but you are missing a .env.vault file at ${r}. Did you forget to build it?`),p.configDotenv(t))}function W(t,r){let e=Buffer.from(r.slice(-64),"hex"),o=Buffer.from(t,"base64"),s=o.subarray(0,12),n=o.subarray(-16);o=o.subarray(12,-16);try{let a=S.createDecipheriv("aes-256-gcm",e,s);return a.setAuthTag(n),`${a.update(o)}${a.final()}`}catch(a){let i=a instanceof RangeError,c=a.message==="Invalid key length",l=a.message==="Unsupported state or unable to authenticate data";if(i||c){let d=new Error("INVALID_DOTENV_KEY: It must be 64 characters long (or more)");throw d.code="INVALID_DOTENV_KEY",d}else if(l){let d=new Error("DECRYPTION_FAILED: Please check your DOTENV_KEY");throw d.code="DECRYPTION_FAILED",d}else throw a}}function J(t,r,e={}){let o=!!(e&&e.debug),s=!!(e&&e.override);if(typeof r!="object"){let n=new Error("OBJECT_REQUIRED: Please check the processEnv argument being passed to populate");throw n.code="OBJECT_REQUIRED",n}for(let n of Object.keys(r))Object.prototype.hasOwnProperty.call(t,n)?(s===!0&&(t[n]=r[n]),o&&I(s===!0?`"${n}" is already defined and WAS overwritten`:`"${n}" is already defined and was NOT overwritten`)):t[n]=r[n]}var p={configDotenv:Q,_configVault:B,_parseVault:j,config:H,decrypt:W,parse:Y,populate:J};u.exports.configDotenv=p.configDotenv;u.exports._configVault=p._configVault;u.exports._parseVault=p._parseVault;u.exports.config=p.config;u.exports.decrypt=p.decrypt;u.exports.parse=p.parse;u.exports.populate=p.populate;u.exports=p});var x=g((ae,C)=>{var m={};process.env.DOTENV_CONFIG_ENCODING!=null&&(m.encoding=process.env.DOTENV_CONFIG_ENCODING);process.env.DOTENV_CONFIG_PATH!=null&&(m.path=process.env.DOTENV_CONFIG_PATH);process.env.DOTENV_CONFIG_DEBUG!=null&&(m.debug=process.env.DOTENV_CONFIG_DEBUG);process.env.DOTENV_CONFIG_OVERRIDE!=null&&(m.override=process.env.DOTENV_CONFIG_OVERRIDE);process.env.DOTENV_CONFIG_DOTENV_KEY!=null&&(m.DOTENV_KEY=process.env.DOTENV_CONFIG_DOTENV_KEY);C.exports=m});var R=g((ie,A)=>{var X=/^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/;A.exports=function(r){return r.reduce(function(e,o){let s=o.match(X);return s&&(e[s[1]]=s[2]),e},{})}});(function(){L().config(Object.assign({},x(),R()(process.argv)))})();import ee,{AxiosError as re}from"axios";var y=class{_rootUrl;_token;constructor(r,e){this._rootUrl=r||process.env?.ZAPPY_URL,this._token=e||process.env?.ZAPPY_TOKEN}async makeRequest(r,e,o,s){if(!this._rootUrl||!this._token)throw new Error("Missing base url or API token");try{let a={url:this._rootUrl+e,method:r,headers:{"Content-Type":"application/json",Authorization:`Bearer ${this._token}`,...s},data:o};return await(await ee(a)).data}catch(n){throw n instanceof re&&"error"in n.response.data?new Error(n?.response?.data?.error):new Error("No request possible")}}};var E=class{constructor(r){this.api=r}async list(){try{return await this.api.makeRequest("GET","/api/connections")}catch(r){return console.error(r),{error:"Unable to list connections"}}}async get(r){try{let o=(await this.api.makeRequest("GET","/api/connections"))?.connections,s=o.find(n=>n.id===r);if(!s||s?.status!=="CONNECTED"){let n=o?.find(a=>a?.status==="CONNECTED");return n||{error:"Connection not found"}}}catch(e){return console.error(e),{error:"Unable to connection"}}}};var h=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/contacts?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list contacts"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/contacts/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"No contact details could be obtained"}}}async update(r,e){try{let o=await this.api.makeRequest("PUT",`/api/contacts/${r}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Unable to update contact"}}}};import te from"form-data";var v=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20,ticketId:s="",contactId:n="",dateFrom:a="",dateTo:i=""}=r||{},c=await this.api.makeRequest("GET",`/api/messages?page=${e}&pageSize=${o}&ticketId=${s}&contactId=${n}&dateFrom=${a}&dateToo=${i}`);return c?.error?{error:c?.error}:c}catch(e){return console.error(e),{error:"Unable to list message"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/messages/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to message"}}}async send(r,e,o){try{if(!o||o==="text"){let s=await this.api.makeRequest("POST",`/api/send/${r}`,e);return s?.error?{error:s?.error}:s}else{let{caption:s,connectionFrom:n,media:a}=e,i=new te;i.append("media",a),i.append("caption",s||""),i.append("connectionFrom",n);let c=await this.api.makeRequest("POST",`/api/send/${o}/${r}`,i,{...i.getHeaders()});return c?.error?{error:c?.error}:c}}catch(s){return console.error(s),{error:"Cannot send message"}}}};var T=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/queues?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list queues"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/queues/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to queue"}}}};var _=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/tags?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list tags"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/tags/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to tag"}}}};var k=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/tickets?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list tickets"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/tickets/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to ticket"}}}async transfer(r,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${r}/transfer`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot transfer ticket"}}}async resolve(r,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${r}/resolve`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot resolve ticket"}}}async update(r,e){try{let o=await this.api.makeRequest("PUT",`/api/tickets/${r}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot update ticket"}}}};var N=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/users?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list users"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/users/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to user"}}}};var U=class extends y{tickets=new k(this);connections=new E(this);contacts=new h(this);messages=new v(this);queues=new T(this);tags=new _(this);users=new N(this)};export{y as ZappyApi,U as Zdk};
4
4
  //# sourceMappingURL=index.js.map
@@ -1 +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.3.1\",\n \"description\": \"Loads environment variables from .env file\",\n \"main\": \"lib/main.js\",\n \"types\": \"lib/main.d.ts\",\n \"exports\": {\n \".\": {\n \"types\": \"./lib/main.d.ts\",\n \"require\": \"./lib/main.js\",\n \"default\": \"./lib/main.js\"\n },\n \"./config\": \"./config.js\",\n \"./config.js\": \"./config.js\",\n \"./lib/env-options\": \"./lib/env-options.js\",\n \"./lib/env-options.js\": \"./lib/env-options.js\",\n \"./lib/cli-options\": \"./lib/cli-options.js\",\n \"./lib/cli-options.js\": \"./lib/cli-options.js\",\n \"./package.json\": \"./package.json\"\n },\n \"scripts\": {\n \"dts-check\": \"tsc --project tests/types/tsconfig.json\",\n \"lint\": \"standard\",\n \"lint-readme\": \"standard-markdown\",\n \"pretest\": \"npm run lint && npm run dts-check\",\n \"test\": \"tap tests/*.js --100 -Rspec\",\n \"prerelease\": \"npm test\",\n \"release\": \"standard-version\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git://github.com/motdotla/dotenv.git\"\n },\n \"funding\": \"https://github.com/motdotla/dotenv?sponsor=1\",\n \"keywords\": [\n \"dotenv\",\n \"env\",\n \".env\",\n \"environment\",\n \"variables\",\n \"config\",\n \"settings\"\n ],\n \"readmeFilename\": \"README.md\",\n \"license\": \"BSD-2-Clause\",\n \"devDependencies\": {\n \"@definitelytyped/dtslint\": \"^0.0.133\",\n \"@types/node\": \"^18.11.3\",\n \"decache\": \"^4.6.1\",\n \"sinon\": \"^14.0.1\",\n \"standard\": \"^17.0.0\",\n \"standard-markdown\": \"^7.1.0\",\n \"standard-version\": \"^9.5.0\",\n \"tap\": \"^16.3.0\",\n \"tar\": \"^6.1.11\",\n \"typescript\": \"^4.8.4\"\n },\n \"engines\": {\n \"node\": \">=12\"\n },\n \"browser\": {\n \"fs\": false\n }\n}\n","const fs = require('fs')\nconst path = require('path')\nconst os = require('os')\nconst crypto = require('crypto')\nconst packageJson = require('../package.json')\n\nconst version = packageJson.version\n\nconst LINE = /(?:^|^)\\s*(?:export\\s+)?([\\w.-]+)(?:\\s*=\\s*?|:\\s+?)(\\s*'(?:\\\\'|[^'])*'|\\s*\"(?:\\\\\"|[^\"])*\"|\\s*`(?:\\\\`|[^`])*`|[^#\\r\\n]+)?\\s*(?:#.*)?(?:$|$)/mg\n\n// Parse src into an Object\nfunction parse (src) {\n const obj = {}\n\n // Convert buffer to string\n let lines = src.toString()\n\n // Convert line breaks to same format\n lines = lines.replace(/\\r\\n?/mg, '\\n')\n\n let match\n while ((match = LINE.exec(lines)) != null) {\n const key = match[1]\n\n // Default undefined or null to empty string\n let value = (match[2] || '')\n\n // Remove whitespace\n value = value.trim()\n\n // Check if double quoted\n const maybeQuote = value[0]\n\n // Remove surrounding quotes\n value = value.replace(/^(['\"`])([\\s\\S]*)\\1$/mg, '$2')\n\n // Expand newlines if double quoted\n if (maybeQuote === '\"') {\n value = value.replace(/\\\\n/g, '\\n')\n value = value.replace(/\\\\r/g, '\\r')\n }\n\n // Add to object\n obj[key] = value\n }\n\n return obj\n}\n\nfunction _parseVault (options) {\n const vaultPath = _vaultPath(options)\n\n // Parse .env.vault\n const result = DotenvModule.configDotenv({ path: vaultPath })\n if (!result.parsed) {\n throw new Error(`MISSING_DATA: Cannot parse ${vaultPath} for an unknown reason`)\n }\n\n // handle scenario for comma separated keys - for use with key rotation\n // example: DOTENV_KEY=\"dotenv://:key_1234@dotenv.org/vault/.env.vault?environment=prod,dotenv://:key_7890@dotenv.org/vault/.env.vault?environment=prod\"\n const keys = _dotenvKey(options).split(',')\n const length = keys.length\n\n let decrypted\n for (let i = 0; i < length; i++) {\n try {\n // Get full key\n const key = keys[i].trim()\n\n // Get instructions for decrypt\n const attrs = _instructions(result, key)\n\n // Decrypt\n decrypted = DotenvModule.decrypt(attrs.ciphertext, attrs.key)\n\n break\n } catch (error) {\n // last key\n if (i + 1 >= length) {\n throw error\n }\n // try next key\n }\n }\n\n // Parse decrypted .env string\n return DotenvModule.parse(decrypted)\n}\n\nfunction _log (message) {\n console.log(`[dotenv@${version}][INFO] ${message}`)\n}\n\nfunction _warn (message) {\n console.log(`[dotenv@${version}][WARN] ${message}`)\n}\n\nfunction _debug (message) {\n console.log(`[dotenv@${version}][DEBUG] ${message}`)\n}\n\nfunction _dotenvKey (options) {\n // prioritize developer directly setting options.DOTENV_KEY\n if (options && options.DOTENV_KEY && options.DOTENV_KEY.length > 0) {\n return options.DOTENV_KEY\n }\n\n // secondary infra already contains a DOTENV_KEY environment variable\n if (process.env.DOTENV_KEY && process.env.DOTENV_KEY.length > 0) {\n return process.env.DOTENV_KEY\n }\n\n // fallback to empty string\n return ''\n}\n\nfunction _instructions (result, dotenvKey) {\n // Parse DOTENV_KEY. Format is a URI\n let uri\n try {\n uri = new URL(dotenvKey)\n } catch (error) {\n if (error.code === 'ERR_INVALID_URL') {\n throw new Error('INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenv.org/vault/.env.vault?environment=development')\n }\n\n throw error\n }\n\n // Get decrypt key\n const key = uri.password\n if (!key) {\n throw new Error('INVALID_DOTENV_KEY: Missing key part')\n }\n\n // Get environment\n const environment = uri.searchParams.get('environment')\n if (!environment) {\n throw new Error('INVALID_DOTENV_KEY: Missing environment part')\n }\n\n // Get ciphertext payload\n const environmentKey = `DOTENV_VAULT_${environment.toUpperCase()}`\n const ciphertext = result.parsed[environmentKey] // DOTENV_VAULT_PRODUCTION\n if (!ciphertext) {\n throw new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${environmentKey} in your .env.vault file.`)\n }\n\n return { ciphertext, key }\n}\n\nfunction _vaultPath (options) {\n let dotenvPath = path.resolve(process.cwd(), '.env')\n\n if (options && options.path && options.path.length > 0) {\n dotenvPath = options.path\n }\n\n // Locate .env.vault\n return dotenvPath.endsWith('.vault') ? dotenvPath : `${dotenvPath}.vault`\n}\n\nfunction _resolveHome (envPath) {\n return envPath[0] === '~' ? path.join(os.homedir(), envPath.slice(1)) : envPath\n}\n\nfunction _configVault (options) {\n _log('Loading env from encrypted .env.vault')\n\n const parsed = DotenvModule._parseVault(options)\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsed, options)\n\n return { parsed }\n}\n\nfunction configDotenv (options) {\n let dotenvPath = path.resolve(process.cwd(), '.env')\n let encoding = 'utf8'\n const debug = Boolean(options && options.debug)\n\n if (options) {\n if (options.path != null) {\n dotenvPath = _resolveHome(options.path)\n }\n if (options.encoding != null) {\n encoding = options.encoding\n }\n }\n\n try {\n // Specifying an encoding returns a string instead of a buffer\n const parsed = DotenvModule.parse(fs.readFileSync(dotenvPath, { encoding }))\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsed, options)\n\n return { parsed }\n } catch (e) {\n if (debug) {\n _debug(`Failed to load ${dotenvPath} ${e.message}`)\n }\n\n return { error: e }\n }\n}\n\n// Populates process.env from .env file\nfunction config (options) {\n const vaultPath = _vaultPath(options)\n\n // fallback to original dotenv if DOTENV_KEY is not set\n if (_dotenvKey(options).length === 0) {\n return DotenvModule.configDotenv(options)\n }\n\n // dotenvKey exists but .env.vault file does not exist\n if (!fs.existsSync(vaultPath)) {\n _warn(`You set DOTENV_KEY but you are missing a .env.vault file at ${vaultPath}. Did you forget to build it?`)\n\n return DotenvModule.configDotenv(options)\n }\n\n return DotenvModule._configVault(options)\n}\n\nfunction decrypt (encrypted, keyStr) {\n const key = Buffer.from(keyStr.slice(-64), 'hex')\n let ciphertext = Buffer.from(encrypted, 'base64')\n\n const nonce = ciphertext.slice(0, 12)\n const authTag = ciphertext.slice(-16)\n ciphertext = ciphertext.slice(12, -16)\n\n try {\n const aesgcm = crypto.createDecipheriv('aes-256-gcm', key, nonce)\n aesgcm.setAuthTag(authTag)\n return `${aesgcm.update(ciphertext)}${aesgcm.final()}`\n } catch (error) {\n const isRange = error instanceof RangeError\n const invalidKeyLength = error.message === 'Invalid key length'\n const decryptionFailed = error.message === 'Unsupported state or unable to authenticate data'\n\n if (isRange || invalidKeyLength) {\n const msg = 'INVALID_DOTENV_KEY: It must be 64 characters long (or more)'\n throw new Error(msg)\n } else if (decryptionFailed) {\n const msg = 'DECRYPTION_FAILED: Please check your DOTENV_KEY'\n throw new Error(msg)\n } else {\n console.error('Error: ', error.code)\n console.error('Error: ', error.message)\n throw error\n }\n }\n}\n\n// Populate process.env with parsed values\nfunction populate (processEnv, parsed, options = {}) {\n const debug = Boolean(options && options.debug)\n const override = Boolean(options && options.override)\n\n if (typeof parsed !== 'object') {\n throw new Error('OBJECT_REQUIRED: Please check the processEnv argument being passed to populate')\n }\n\n // Set process.env\n for (const key of Object.keys(parsed)) {\n if (Object.prototype.hasOwnProperty.call(processEnv, key)) {\n if (override === true) {\n processEnv[key] = parsed[key]\n }\n\n if (debug) {\n if (override === true) {\n _debug(`\"${key}\" is already defined and WAS overwritten`)\n } else {\n _debug(`\"${key}\" is already defined and was NOT overwritten`)\n }\n }\n } else {\n processEnv[key] = parsed[key]\n }\n }\n}\n\nconst DotenvModule = {\n configDotenv,\n _configVault,\n _parseVault,\n config,\n decrypt,\n parse,\n populate\n}\n\nmodule.exports.configDotenv = DotenvModule.configDotenv\nmodule.exports._configVault = DotenvModule._configVault\nmodule.exports._parseVault = DotenvModule._parseVault\nmodule.exports.config = DotenvModule.config\nmodule.exports.decrypt = DotenvModule.decrypt\nmodule.exports.parse = DotenvModule.parse\nmodule.exports.populate = DotenvModule.populate\n\nmodule.exports = DotenvModule\n","// ../config.js accepts options via environment variables\nconst options = {}\n\nif (process.env.DOTENV_CONFIG_ENCODING != null) {\n options.encoding = process.env.DOTENV_CONFIG_ENCODING\n}\n\nif (process.env.DOTENV_CONFIG_PATH != null) {\n options.path = process.env.DOTENV_CONFIG_PATH\n}\n\nif (process.env.DOTENV_CONFIG_DEBUG != null) {\n options.debug = process.env.DOTENV_CONFIG_DEBUG\n}\n\nif (process.env.DOTENV_CONFIG_OVERRIDE != null) {\n options.override = process.env.DOTENV_CONFIG_OVERRIDE\n}\n\nif (process.env.DOTENV_CONFIG_DOTENV_KEY != null) {\n options.DOTENV_KEY = process.env.DOTENV_CONFIG_DOTENV_KEY\n}\n\nmodule.exports = options\n","const re = /^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/\n\nmodule.exports = function optionMatcher (args) {\n return args.reduce(function (acc, cur) {\n const matches = cur.match(re)\n if (matches) {\n acc[matches[1]] = matches[2]\n }\n return acc\n }, {})\n}\n","(function () {\n require('./lib/main').config(\n Object.assign(\n {},\n require('./lib/env-options'),\n require('./lib/cli-options')(process.argv)\n )\n )\n})()\n","import type { HttpMethod } from \"./types\";\n\nexport class 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 // eslint-disable-next-line @typescript-eslint/no-explicit-any\n body?: any,\n contentType?: string\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): Promise<any> {\n if (!this._rootUrl || !this._token) {\n throw new Error(\"Missing base url or API token\");\n }\n\n const fullUrl: string = this._rootUrl + endpoint;\n const options: RequestInit = {\n method,\n headers: {\n Authorization: `Bearer ${this._token}`,\n \"Content-Type\": contentType ?? \"application/json\",\n },\n body: body\n ? typeof body === \"string\"\n ? body\n : JSON.stringify(body)\n : undefined,\n };\n\n const request = await fetch(fullUrl, options);\n\n const response = await request.json();\n\n return response;\n }\n}\n","import { ZappyApi } from \"../zappy-api\";\nimport type { IConnection, IConnectionList, IError } from \"../types\";\n\nexport class Connection {\n constructor(protected api: ZappyApi) {}\n\n async list(): Promise<IConnectionList | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", \"/api/connections\");\n\n return response as IConnectionList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list connections\" };\n }\n }\n\n async get(id?: number): Promise<IConnection | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", \"/api/connections\");\n\n const connections = response?.connections as IConnection[];\n\n const connectionExists = connections.find(\n (connection: IConnection) => connection.id === id\n );\n\n if (!connectionExists || connectionExists?.status !== \"CONNECTED\") {\n const validConnection = connections?.find(\n (connection: IConnection) => connection?.status === \"CONNECTED\"\n );\n\n if (!validConnection) return { error: \"Connection not found\" };\n\n return validConnection;\n }\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to connection\" };\n }\n }\n}\n","import type { IContact, IContactList, IError, IParamsList } from \"../types\";\nimport type { 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: \"Unable to contact\" };\n }\n }\n}\n","import type {\n IError,\n IMessage,\n IMessageList,\n IParamsMessageList,\n ISendMessage,\n MediaType,\n} from \"../types\";\n\nimport type { ZappyApi } from \"../zappy-api\";\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, type?: MediaType) {\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 return response;\n }\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot send message\" };\n }\n }\n}\n","import type { IError, IParamsList, IQueue, IQueueList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Queue {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<IQueueList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/queues?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IQueueList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list queues\" };\n }\n }\n\n async get(id: number): Promise<IQueue | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/queues/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IQueue;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to queue\" };\n }\n }\n}\n","import type { IError, IParamsList, ITag, ITagList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Tag {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<ITagList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/tags?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITagList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list tags\" };\n }\n }\n\n async get(id: number): Promise<ITag | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/tags/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as ITag;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to tag\" };\n }\n }\n}\n","import type {\n IError,\n IParamsList,\n ITicket,\n ITicketList,\n ITicketResolveForm,\n ITicketTransferForm,\n ITicketUpdateForm,\n} from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Ticket {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<ITicketList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/tickets?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicketList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list tickets\" };\n }\n }\n\n async get(id: number): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/tickets/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to ticket\" };\n }\n }\n\n async transfer(\n id: number,\n data: ITicketTransferForm\n ): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/tickets/${id}/transfer`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot transfer ticket\" };\n }\n }\n\n async resolve(\n id: number,\n data: ITicketResolveForm\n ): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/tickets/${id}/resolve`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot resolve ticket\" };\n }\n }\n\n async update(id: number, data: ITicketUpdateForm): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"PUT\",\n `/api/tickets/${id}`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot update ticket\" };\n }\n }\n}\n","import type { IError, IParamsList, IUser, IUserList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class User {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<IUserList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/users?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IUserList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list users\" };\n }\n }\n\n async get(id: number): Promise<IUser | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/users/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IUser;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to user\" };\n }\n }\n}\n","import \"dotenv/config\";\n\nimport { ZappyApi } from \"./zappy-api\";\nimport { Connection } from \"./lib\";\nimport { Contact } from \"./lib/contact\";\nimport { Message } from \"./lib/message\";\nimport { Queue } from \"./lib/queue\";\nimport { Tag } from \"./lib/tag\";\nimport { User } from \"./lib/user\";\nimport { Ticket } from \"./lib/ticket\";\n\nexport class Zdk extends ZappyApi {\n readonly tickets = new Ticket(this);\n\n readonly connections = new Connection(this);\n\n readonly contacts = new Contact(this);\n\n readonly messages = new Message(this);\n\n readonly queues = new Queue(this);\n\n readonly tags = new Tag(this);\n\n readonly users = new User(this);\n}\n\nexport default Zdk;\n"],"mappings":"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","names":["require_package","__commonJSMin","exports","module","require_main","__commonJSMin","exports","module","fs","path","os","crypto","packageJson","version","LINE","parse","src","obj","lines","match","key","value","maybeQuote","_parseVault","options","vaultPath","_vaultPath","result","DotenvModule","keys","_dotenvKey","length","decrypted","i","attrs","_instructions","error","_log","message","_warn","_debug","dotenvKey","uri","environment","environmentKey","ciphertext","dotenvPath","_resolveHome","envPath","_configVault","parsed","processEnv","configDotenv","encoding","debug","e","config","decrypt","encrypted","keyStr","nonce","authTag","aesgcm","isRange","invalidKeyLength","decryptionFailed","msg","populate","override","require_env_options","__commonJSMin","exports","module","options","require_cli_options","__commonJSMin","exports","module","re","args","acc","cur","matches","ZappyApi","rootUrl","token","method","endpoint","body","contentType","fullUrl","options","Connection","api","error","id","connections","connectionExists","connection","validConnection","Contact","api","params","page","pageSize","response","error","id","Message","api","params","page","pageSize","ticketId","contactId","dateFrom","dateTo","response","error","id","to","data","type","Queue","api","params","page","pageSize","response","error","id","Tag","api","params","page","pageSize","response","error","id","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"]}
1
+ {"version":3,"sources":["../../node_modules/dotenv/package.json","../../node_modules/dotenv/lib/main.js","../../node_modules/dotenv/lib/env-options.js","../../node_modules/dotenv/lib/cli-options.js","../../node_modules/dotenv/config.js","../../src/zappy-api.ts","../../src/lib/connection.ts","../../src/lib/contact.ts","../../src/lib/message.ts","../../src/lib/queue.ts","../../src/lib/tag.ts","../../src/lib/ticket.ts","../../src/lib/user.ts","../../src/zdk.ts"],"sourcesContent":["{\n \"name\": \"dotenv\",\n \"version\": \"16.4.5\",\n \"description\": \"Loads environment variables from .env file\",\n \"main\": \"lib/main.js\",\n \"types\": \"lib/main.d.ts\",\n \"exports\": {\n \".\": {\n \"types\": \"./lib/main.d.ts\",\n \"require\": \"./lib/main.js\",\n \"default\": \"./lib/main.js\"\n },\n \"./config\": \"./config.js\",\n \"./config.js\": \"./config.js\",\n \"./lib/env-options\": \"./lib/env-options.js\",\n \"./lib/env-options.js\": \"./lib/env-options.js\",\n \"./lib/cli-options\": \"./lib/cli-options.js\",\n \"./lib/cli-options.js\": \"./lib/cli-options.js\",\n \"./package.json\": \"./package.json\"\n },\n \"scripts\": {\n \"dts-check\": \"tsc --project tests/types/tsconfig.json\",\n \"lint\": \"standard\",\n \"lint-readme\": \"standard-markdown\",\n \"pretest\": \"npm run lint && npm run dts-check\",\n \"test\": \"tap tests/*.js --100 -Rspec\",\n \"test:coverage\": \"tap --coverage-report=lcov\",\n \"prerelease\": \"npm test\",\n \"release\": \"standard-version\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git://github.com/motdotla/dotenv.git\"\n },\n \"funding\": \"https://dotenvx.com\",\n \"keywords\": [\n \"dotenv\",\n \"env\",\n \".env\",\n \"environment\",\n \"variables\",\n \"config\",\n \"settings\"\n ],\n \"readmeFilename\": \"README.md\",\n \"license\": \"BSD-2-Clause\",\n \"devDependencies\": {\n \"@definitelytyped/dtslint\": \"^0.0.133\",\n \"@types/node\": \"^18.11.3\",\n \"decache\": \"^4.6.1\",\n \"sinon\": \"^14.0.1\",\n \"standard\": \"^17.0.0\",\n \"standard-markdown\": \"^7.1.0\",\n \"standard-version\": \"^9.5.0\",\n \"tap\": \"^16.3.0\",\n \"tar\": \"^6.1.11\",\n \"typescript\": \"^4.8.4\"\n },\n \"engines\": {\n \"node\": \">=12\"\n },\n \"browser\": {\n \"fs\": false\n }\n}\n","const fs = require('fs')\nconst path = require('path')\nconst os = require('os')\nconst crypto = require('crypto')\nconst packageJson = require('../package.json')\n\nconst version = packageJson.version\n\nconst LINE = /(?:^|^)\\s*(?:export\\s+)?([\\w.-]+)(?:\\s*=\\s*?|:\\s+?)(\\s*'(?:\\\\'|[^'])*'|\\s*\"(?:\\\\\"|[^\"])*\"|\\s*`(?:\\\\`|[^`])*`|[^#\\r\\n]+)?\\s*(?:#.*)?(?:$|$)/mg\n\n// Parse src into an Object\nfunction parse (src) {\n const obj = {}\n\n // Convert buffer to string\n let lines = src.toString()\n\n // Convert line breaks to same format\n lines = lines.replace(/\\r\\n?/mg, '\\n')\n\n let match\n while ((match = LINE.exec(lines)) != null) {\n const key = match[1]\n\n // Default undefined or null to empty string\n let value = (match[2] || '')\n\n // Remove whitespace\n value = value.trim()\n\n // Check if double quoted\n const maybeQuote = value[0]\n\n // Remove surrounding quotes\n value = value.replace(/^(['\"`])([\\s\\S]*)\\1$/mg, '$2')\n\n // Expand newlines if double quoted\n if (maybeQuote === '\"') {\n value = value.replace(/\\\\n/g, '\\n')\n value = value.replace(/\\\\r/g, '\\r')\n }\n\n // Add to object\n obj[key] = value\n }\n\n return obj\n}\n\nfunction _parseVault (options) {\n const vaultPath = _vaultPath(options)\n\n // Parse .env.vault\n const result = DotenvModule.configDotenv({ path: vaultPath })\n if (!result.parsed) {\n const err = new Error(`MISSING_DATA: Cannot parse ${vaultPath} for an unknown reason`)\n err.code = 'MISSING_DATA'\n throw err\n }\n\n // handle scenario for comma separated keys - for use with key rotation\n // example: DOTENV_KEY=\"dotenv://:key_1234@dotenvx.com/vault/.env.vault?environment=prod,dotenv://:key_7890@dotenvx.com/vault/.env.vault?environment=prod\"\n const keys = _dotenvKey(options).split(',')\n const length = keys.length\n\n let decrypted\n for (let i = 0; i < length; i++) {\n try {\n // Get full key\n const key = keys[i].trim()\n\n // Get instructions for decrypt\n const attrs = _instructions(result, key)\n\n // Decrypt\n decrypted = DotenvModule.decrypt(attrs.ciphertext, attrs.key)\n\n break\n } catch (error) {\n // last key\n if (i + 1 >= length) {\n throw error\n }\n // try next key\n }\n }\n\n // Parse decrypted .env string\n return DotenvModule.parse(decrypted)\n}\n\nfunction _log (message) {\n console.log(`[dotenv@${version}][INFO] ${message}`)\n}\n\nfunction _warn (message) {\n console.log(`[dotenv@${version}][WARN] ${message}`)\n}\n\nfunction _debug (message) {\n console.log(`[dotenv@${version}][DEBUG] ${message}`)\n}\n\nfunction _dotenvKey (options) {\n // prioritize developer directly setting options.DOTENV_KEY\n if (options && options.DOTENV_KEY && options.DOTENV_KEY.length > 0) {\n return options.DOTENV_KEY\n }\n\n // secondary infra already contains a DOTENV_KEY environment variable\n if (process.env.DOTENV_KEY && process.env.DOTENV_KEY.length > 0) {\n return process.env.DOTENV_KEY\n }\n\n // fallback to empty string\n return ''\n}\n\nfunction _instructions (result, dotenvKey) {\n // Parse DOTENV_KEY. Format is a URI\n let uri\n try {\n uri = new URL(dotenvKey)\n } catch (error) {\n if (error.code === 'ERR_INVALID_URL') {\n const err = new Error('INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenvx.com/vault/.env.vault?environment=development')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n }\n\n throw error\n }\n\n // Get decrypt key\n const key = uri.password\n if (!key) {\n const err = new Error('INVALID_DOTENV_KEY: Missing key part')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n }\n\n // Get environment\n const environment = uri.searchParams.get('environment')\n if (!environment) {\n const err = new Error('INVALID_DOTENV_KEY: Missing environment part')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n }\n\n // Get ciphertext payload\n const environmentKey = `DOTENV_VAULT_${environment.toUpperCase()}`\n const ciphertext = result.parsed[environmentKey] // DOTENV_VAULT_PRODUCTION\n if (!ciphertext) {\n const err = new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${environmentKey} in your .env.vault file.`)\n err.code = 'NOT_FOUND_DOTENV_ENVIRONMENT'\n throw err\n }\n\n return { ciphertext, key }\n}\n\nfunction _vaultPath (options) {\n let possibleVaultPath = null\n\n if (options && options.path && options.path.length > 0) {\n if (Array.isArray(options.path)) {\n for (const filepath of options.path) {\n if (fs.existsSync(filepath)) {\n possibleVaultPath = filepath.endsWith('.vault') ? filepath : `${filepath}.vault`\n }\n }\n } else {\n possibleVaultPath = options.path.endsWith('.vault') ? options.path : `${options.path}.vault`\n }\n } else {\n possibleVaultPath = path.resolve(process.cwd(), '.env.vault')\n }\n\n if (fs.existsSync(possibleVaultPath)) {\n return possibleVaultPath\n }\n\n return null\n}\n\nfunction _resolveHome (envPath) {\n return envPath[0] === '~' ? path.join(os.homedir(), envPath.slice(1)) : envPath\n}\n\nfunction _configVault (options) {\n _log('Loading env from encrypted .env.vault')\n\n const parsed = DotenvModule._parseVault(options)\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsed, options)\n\n return { parsed }\n}\n\nfunction configDotenv (options) {\n const dotenvPath = path.resolve(process.cwd(), '.env')\n let encoding = 'utf8'\n const debug = Boolean(options && options.debug)\n\n if (options && options.encoding) {\n encoding = options.encoding\n } else {\n if (debug) {\n _debug('No encoding is specified. UTF-8 is used by default')\n }\n }\n\n let optionPaths = [dotenvPath] // default, look for .env\n if (options && options.path) {\n if (!Array.isArray(options.path)) {\n optionPaths = [_resolveHome(options.path)]\n } else {\n optionPaths = [] // reset default\n for (const filepath of options.path) {\n optionPaths.push(_resolveHome(filepath))\n }\n }\n }\n\n // Build the parsed data in a temporary object (because we need to return it). Once we have the final\n // parsed data, we will combine it with process.env (or options.processEnv if provided).\n let lastError\n const parsedAll = {}\n for (const path of optionPaths) {\n try {\n // Specifying an encoding returns a string instead of a buffer\n const parsed = DotenvModule.parse(fs.readFileSync(path, { encoding }))\n\n DotenvModule.populate(parsedAll, parsed, options)\n } catch (e) {\n if (debug) {\n _debug(`Failed to load ${path} ${e.message}`)\n }\n lastError = e\n }\n }\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsedAll, options)\n\n if (lastError) {\n return { parsed: parsedAll, error: lastError }\n } else {\n return { parsed: parsedAll }\n }\n}\n\n// Populates process.env from .env file\nfunction config (options) {\n // fallback to original dotenv if DOTENV_KEY is not set\n if (_dotenvKey(options).length === 0) {\n return DotenvModule.configDotenv(options)\n }\n\n const vaultPath = _vaultPath(options)\n\n // dotenvKey exists but .env.vault file does not exist\n if (!vaultPath) {\n _warn(`You set DOTENV_KEY but you are missing a .env.vault file at ${vaultPath}. Did you forget to build it?`)\n\n return DotenvModule.configDotenv(options)\n }\n\n return DotenvModule._configVault(options)\n}\n\nfunction decrypt (encrypted, keyStr) {\n const key = Buffer.from(keyStr.slice(-64), 'hex')\n let ciphertext = Buffer.from(encrypted, 'base64')\n\n const nonce = ciphertext.subarray(0, 12)\n const authTag = ciphertext.subarray(-16)\n ciphertext = ciphertext.subarray(12, -16)\n\n try {\n const aesgcm = crypto.createDecipheriv('aes-256-gcm', key, nonce)\n aesgcm.setAuthTag(authTag)\n return `${aesgcm.update(ciphertext)}${aesgcm.final()}`\n } catch (error) {\n const isRange = error instanceof RangeError\n const invalidKeyLength = error.message === 'Invalid key length'\n const decryptionFailed = error.message === 'Unsupported state or unable to authenticate data'\n\n if (isRange || invalidKeyLength) {\n const err = new Error('INVALID_DOTENV_KEY: It must be 64 characters long (or more)')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n } else if (decryptionFailed) {\n const err = new Error('DECRYPTION_FAILED: Please check your DOTENV_KEY')\n err.code = 'DECRYPTION_FAILED'\n throw err\n } else {\n throw error\n }\n }\n}\n\n// Populate process.env with parsed values\nfunction populate (processEnv, parsed, options = {}) {\n const debug = Boolean(options && options.debug)\n const override = Boolean(options && options.override)\n\n if (typeof parsed !== 'object') {\n const err = new Error('OBJECT_REQUIRED: Please check the processEnv argument being passed to populate')\n err.code = 'OBJECT_REQUIRED'\n throw err\n }\n\n // Set process.env\n for (const key of Object.keys(parsed)) {\n if (Object.prototype.hasOwnProperty.call(processEnv, key)) {\n if (override === true) {\n processEnv[key] = parsed[key]\n }\n\n if (debug) {\n if (override === true) {\n _debug(`\"${key}\" is already defined and WAS overwritten`)\n } else {\n _debug(`\"${key}\" is already defined and was NOT overwritten`)\n }\n }\n } else {\n processEnv[key] = parsed[key]\n }\n }\n}\n\nconst DotenvModule = {\n configDotenv,\n _configVault,\n _parseVault,\n config,\n decrypt,\n parse,\n populate\n}\n\nmodule.exports.configDotenv = DotenvModule.configDotenv\nmodule.exports._configVault = DotenvModule._configVault\nmodule.exports._parseVault = DotenvModule._parseVault\nmodule.exports.config = DotenvModule.config\nmodule.exports.decrypt = DotenvModule.decrypt\nmodule.exports.parse = DotenvModule.parse\nmodule.exports.populate = DotenvModule.populate\n\nmodule.exports = DotenvModule\n","// ../config.js accepts options via environment variables\nconst options = {}\n\nif (process.env.DOTENV_CONFIG_ENCODING != null) {\n options.encoding = process.env.DOTENV_CONFIG_ENCODING\n}\n\nif (process.env.DOTENV_CONFIG_PATH != null) {\n options.path = process.env.DOTENV_CONFIG_PATH\n}\n\nif (process.env.DOTENV_CONFIG_DEBUG != null) {\n options.debug = process.env.DOTENV_CONFIG_DEBUG\n}\n\nif (process.env.DOTENV_CONFIG_OVERRIDE != null) {\n options.override = process.env.DOTENV_CONFIG_OVERRIDE\n}\n\nif (process.env.DOTENV_CONFIG_DOTENV_KEY != null) {\n options.DOTENV_KEY = process.env.DOTENV_CONFIG_DOTENV_KEY\n}\n\nmodule.exports = options\n","const re = /^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/\n\nmodule.exports = function optionMatcher (args) {\n return args.reduce(function (acc, cur) {\n const matches = cur.match(re)\n if (matches) {\n acc[matches[1]] = matches[2]\n }\n return acc\n }, {})\n}\n","(function () {\n require('./lib/main').config(\n Object.assign(\n {},\n require('./lib/env-options'),\n require('./lib/cli-options')(process.argv)\n )\n )\n})()\n","import type { HttpMethod } from \"./types\";\nimport axios, { AxiosError } from \"axios\";\n\nexport class ZappyApi {\n private _rootUrl: string;\n private _token: string;\n\n constructor(rootUrl?: string, token?: string) {\n this._rootUrl = rootUrl || process.env?.ZAPPY_URL;\n this._token = token || process.env?.ZAPPY_TOKEN;\n }\n\n async makeRequest(\n method: HttpMethod,\n endpoint: string,\n data?: unknown,\n customHeaders?: Record<string, string>\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): Promise<any> {\n if (!this._rootUrl || !this._token) {\n throw new Error(\"Missing base url or API token\");\n }\n\n try {\n const url: string = this._rootUrl + endpoint;\n const options = {\n url,\n method,\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${this._token}`,\n ...customHeaders,\n },\n data,\n };\n const request = await axios(options);\n const response = await request.data;\n return response;\n } catch (error: unknown) {\n if (error instanceof AxiosError && \"error\" in error.response.data) {\n throw new Error(error?.response?.data?.error);\n }\n\n throw new Error(\"No request possible\");\n }\n }\n}\n","import { ZappyApi } from \"../zappy-api\";\nimport type { IConnection, IConnectionList, IError } from \"../types\";\n\nexport class Connection {\n constructor(protected api: ZappyApi) {}\n\n async list(): Promise<IConnectionList | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", \"/api/connections\");\n\n return response as IConnectionList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list connections\" };\n }\n }\n\n async get(id?: number): Promise<IConnection | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", \"/api/connections\");\n\n const connections = response?.connections as IConnection[];\n\n const connectionExists = connections.find(\n (connection: IConnection) => connection.id === id\n );\n\n if (!connectionExists || connectionExists?.status !== \"CONNECTED\") {\n const validConnection = connections?.find(\n (connection: IConnection) => connection?.status === \"CONNECTED\"\n );\n\n if (!validConnection) return { error: \"Connection not found\" };\n\n return validConnection;\n }\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to connection\" };\n }\n }\n}\n","import type {\n IContact,\n IContactList,\n IContactPostData,\n IError,\n IParamsList,\n} from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Contact {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<IContactList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/contacts?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IContactList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list contacts\" };\n }\n }\n\n async get(id: number): Promise<IContact | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/contacts/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IContact;\n } catch (error) {\n console.error(error);\n\n return { error: \"No contact details could be obtained\" };\n }\n }\n\n async update(id: number, data: IContactPostData): Promise<IContact | IError> {\n try {\n const response = await this.api.makeRequest(\n \"PUT\",\n `/api/contacts/${id}`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IContact;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to update contact\" };\n }\n }\n}\n","import type {\n IError,\n IMessage,\n IMessageList,\n IParamsMessageList,\n ISendMediaMessage,\n ISendMessage,\n MediaType,\n} from \"../types\";\n\nimport type { ZappyApi } from \"../zappy-api\";\nimport FormData from \"form-data\";\n\nexport class Message {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsMessageList): Promise<IMessageList | IError> {\n try {\n const {\n page = 1,\n pageSize = 20,\n ticketId = \"\",\n contactId = \"\",\n dateFrom = \"\",\n dateTo = \"\",\n } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/messages?page=${page}&pageSize=${pageSize}&ticketId=${ticketId}&contactId=${contactId}&dateFrom=${dateFrom}&dateToo=${dateTo}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IMessageList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list message\" };\n }\n }\n\n async get(id: string): Promise<IMessage | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/messages/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IMessage;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to message\" };\n }\n }\n\n async send(to: string, data: ISendMessage): Promise<Message | IError>;\n\n async send(\n to: string,\n data: ISendMediaMessage,\n type: Exclude<MediaType, \"text\">\n ): Promise<Message | IError>;\n\n async send(\n to: string,\n data: ISendMessage | ISendMediaMessage,\n /**\n * @default \"text\"\n */\n type?: MediaType\n ): Promise<Message | IError> {\n try {\n if (!type || type === \"text\") {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/send/${to}`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response;\n } else {\n const { caption, connectionFrom, media } = data as ISendMediaMessage;\n const form = new FormData();\n form.append(\"media\", media);\n form.append(\"caption\", caption || \"\");\n form.append(\"connectionFrom\", connectionFrom);\n\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/send/${type}/${to}`,\n form,\n {\n ...form.getHeaders(),\n }\n );\n\n if (response?.error) return { error: response?.error };\n\n return response;\n }\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot send message\" };\n }\n }\n}\n","import type { IError, IParamsList, IQueue, IQueueList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Queue {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<IQueueList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/queues?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IQueueList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list queues\" };\n }\n }\n\n async get(id: number): Promise<IQueue | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/queues/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IQueue;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to queue\" };\n }\n }\n}\n","import type { IError, IParamsList, ITag, ITagList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Tag {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<ITagList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/tags?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITagList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list tags\" };\n }\n }\n\n async get(id: number): Promise<ITag | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/tags/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as ITag;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to tag\" };\n }\n }\n}\n","import type {\n IError,\n IParamsList,\n ITicket,\n ITicketList,\n ITicketResolveForm,\n ITicketTransferForm,\n ITicketUpdateForm,\n} from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Ticket {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<ITicketList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/tickets?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicketList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list tickets\" };\n }\n }\n\n async get(id: number): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/tickets/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to ticket\" };\n }\n }\n\n async transfer(\n id: number,\n data: ITicketTransferForm\n ): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/tickets/${id}/transfer`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot transfer ticket\" };\n }\n }\n\n async resolve(\n id: number,\n data: ITicketResolveForm\n ): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/tickets/${id}/resolve`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot resolve ticket\" };\n }\n }\n\n async update(id: number, data: ITicketUpdateForm): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"PUT\",\n `/api/tickets/${id}`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot update ticket\" };\n }\n }\n}\n","import type { IError, IParamsList, IUser, IUserList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class User {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<IUserList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/users?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IUserList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list users\" };\n }\n }\n\n async get(id: number): Promise<IUser | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/users/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IUser;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to user\" };\n }\n }\n}\n","import \"dotenv/config\";\n\nimport { ZappyApi } from \"./zappy-api\";\nimport { Connection } from \"./lib\";\nimport { Contact } from \"./lib/contact\";\nimport { Message } from \"./lib/message\";\nimport { Queue } from \"./lib/queue\";\nimport { Tag } from \"./lib/tag\";\nimport { User } from \"./lib/user\";\nimport { Ticket } from \"./lib/ticket\";\n\nexport class Zdk extends ZappyApi {\n readonly tickets = new Ticket(this);\n\n readonly connections = new Connection(this);\n\n readonly contacts = new Contact(this);\n\n readonly messages = new Message(this);\n\n readonly queues = new Queue(this);\n\n readonly tags = new Tag(this);\n\n readonly users = new User(this);\n}\n\nexport default Zdk;\n"],"mappings":"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","names":["require_package","__commonJSMin","exports","module","require_main","__commonJSMin","exports","module","fs","path","os","crypto","packageJson","version","LINE","parse","src","obj","lines","match","key","value","maybeQuote","_parseVault","options","vaultPath","_vaultPath","result","DotenvModule","err","keys","_dotenvKey","length","decrypted","i","attrs","_instructions","error","_log","message","_warn","_debug","dotenvKey","uri","environment","environmentKey","ciphertext","possibleVaultPath","filepath","_resolveHome","envPath","_configVault","parsed","processEnv","configDotenv","dotenvPath","encoding","debug","optionPaths","lastError","parsedAll","e","config","decrypt","encrypted","keyStr","nonce","authTag","aesgcm","isRange","invalidKeyLength","decryptionFailed","populate","override","require_env_options","__commonJSMin","exports","module","options","require_cli_options","__commonJSMin","exports","module","re","args","acc","cur","matches","axios","AxiosError","ZappyApi","rootUrl","token","method","endpoint","data","customHeaders","options","error","Connection","api","error","id","connections","connectionExists","connection","validConnection","Contact","api","params","page","pageSize","response","error","id","data","FormData","Message","api","params","page","pageSize","ticketId","contactId","dateFrom","dateTo","response","error","id","to","data","type","caption","connectionFrom","media","form","Queue","api","params","page","pageSize","response","error","id","Tag","api","params","page","pageSize","response","error","id","Ticket","api","params","page","pageSize","response","error","id","data","User","api","params","page","pageSize","response","error","id","Zdk","ZappyApi","Ticket","Connection","Contact","Message","Queue","Tag","User"]}
package/dist/index.d.mts CHANGED
@@ -44,13 +44,13 @@ interface ISendMessage {
44
44
  ticketStrategy: TicketStrategy;
45
45
  }
46
46
  interface ISendMediaMessage {
47
- media: string;
48
- caption: string;
47
+ media: unknown;
48
+ caption?: string;
49
49
  connectionFrom: number;
50
50
  }
51
51
  interface SendMediaMessageJson {
52
52
  url: string;
53
- caption: string;
53
+ caption?: string;
54
54
  connectionFrom: string;
55
55
  }
56
56
  interface IMessage {
@@ -77,6 +77,26 @@ interface IContact {
77
77
  userId: number;
78
78
  queueId: number;
79
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;
80
100
  }
81
101
  interface ITag {
82
102
  id: string;
@@ -170,7 +190,7 @@ declare class ZappyApi {
170
190
  private _rootUrl;
171
191
  private _token;
172
192
  constructor(rootUrl?: string, token?: string);
173
- makeRequest(method: HttpMethod, endpoint: string, body?: any, contentType?: string): Promise<any>;
193
+ makeRequest(method: HttpMethod, endpoint: string, data?: unknown, customHeaders?: Record<string, string>): Promise<any>;
174
194
  }
175
195
 
176
196
  declare class Connection {
@@ -185,6 +205,7 @@ declare class Contact {
185
205
  constructor(api: ZappyApi);
186
206
  list(params?: IParamsList): Promise<IContactList | IError>;
187
207
  get(id: number): Promise<IContact | IError>;
208
+ update(id: number, data: IContactPostData): Promise<IContact | IError>;
188
209
  }
189
210
 
190
211
  declare class Message {
@@ -192,7 +213,8 @@ declare class Message {
192
213
  constructor(api: ZappyApi);
193
214
  list(params?: IParamsMessageList): Promise<IMessageList | IError>;
194
215
  get(id: string): Promise<IMessage | IError>;
195
- send(to: string, data: ISendMessage, type?: MediaType): Promise<any>;
216
+ send(to: string, data: ISendMessage): Promise<Message | IError>;
217
+ send(to: string, data: ISendMediaMessage, type: Exclude<MediaType, "text">): Promise<Message | IError>;
196
218
  }
197
219
 
198
220
  declare class Queue {
@@ -236,4 +258,4 @@ declare class Zdk extends ZappyApi {
236
258
  readonly users: User;
237
259
  }
238
260
 
239
- export { type ConnectionStatus, type FeedbackOption, type HttpMethod, type IConnection, type IConnectionList, type IContact, type IContactList, type IError, type IMessage, type IMessageList, type IMessageObject, type IPagination, type IParamsList, type IParamsMessageList, type IQueue, type IQueueList, type ISendMediaMessage, type ISendMessage, type ITag, type ITagList, type ITicket, type ITicketList, type ITicketResolveForm, type ITicketTransferForm, type ITicketUpdateForm, type IUser, type IUserList, type IZdkOptions, type MediaType, type SendMediaMessageJson, type TicketStatus, type TicketStrategy, ZappyApi, Zdk };
261
+ export { type ConnectionStatus, type FeedbackOption, type HttpMethod, type IConnection, type IConnectionList, type IContact, type IContactExtraInfo, type IContactList, type IContactPostData, type IError, type IMessage, type IMessageList, type IMessageObject, type IPagination, type IParamsList, type IParamsMessageList, type IQueue, type IQueueList, type ISendMediaMessage, type ISendMessage, type ITag, type ITagList, type ITicket, type ITicketList, type ITicketResolveForm, type ITicketTransferForm, type ITicketUpdateForm, type IUser, type IUserList, type IZdkOptions, type MediaType, type SendMediaMessageJson, type TicketStatus, type TicketStrategy, ZappyApi, Zdk };
package/dist/index.d.ts CHANGED
@@ -44,13 +44,13 @@ interface ISendMessage {
44
44
  ticketStrategy: TicketStrategy;
45
45
  }
46
46
  interface ISendMediaMessage {
47
- media: string;
48
- caption: string;
47
+ media: unknown;
48
+ caption?: string;
49
49
  connectionFrom: number;
50
50
  }
51
51
  interface SendMediaMessageJson {
52
52
  url: string;
53
- caption: string;
53
+ caption?: string;
54
54
  connectionFrom: string;
55
55
  }
56
56
  interface IMessage {
@@ -77,6 +77,26 @@ interface IContact {
77
77
  userId: number;
78
78
  queueId: number;
79
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;
80
100
  }
81
101
  interface ITag {
82
102
  id: string;
@@ -170,7 +190,7 @@ declare class ZappyApi {
170
190
  private _rootUrl;
171
191
  private _token;
172
192
  constructor(rootUrl?: string, token?: string);
173
- makeRequest(method: HttpMethod, endpoint: string, body?: any, contentType?: string): Promise<any>;
193
+ makeRequest(method: HttpMethod, endpoint: string, data?: unknown, customHeaders?: Record<string, string>): Promise<any>;
174
194
  }
175
195
 
176
196
  declare class Connection {
@@ -185,6 +205,7 @@ declare class Contact {
185
205
  constructor(api: ZappyApi);
186
206
  list(params?: IParamsList): Promise<IContactList | IError>;
187
207
  get(id: number): Promise<IContact | IError>;
208
+ update(id: number, data: IContactPostData): Promise<IContact | IError>;
188
209
  }
189
210
 
190
211
  declare class Message {
@@ -192,7 +213,8 @@ declare class Message {
192
213
  constructor(api: ZappyApi);
193
214
  list(params?: IParamsMessageList): Promise<IMessageList | IError>;
194
215
  get(id: string): Promise<IMessage | IError>;
195
- send(to: string, data: ISendMessage, type?: MediaType): Promise<any>;
216
+ send(to: string, data: ISendMessage): Promise<Message | IError>;
217
+ send(to: string, data: ISendMediaMessage, type: Exclude<MediaType, "text">): Promise<Message | IError>;
196
218
  }
197
219
 
198
220
  declare class Queue {
@@ -236,4 +258,4 @@ declare class Zdk extends ZappyApi {
236
258
  readonly users: User;
237
259
  }
238
260
 
239
- export { type ConnectionStatus, type FeedbackOption, type HttpMethod, type IConnection, type IConnectionList, type IContact, type IContactList, type IError, type IMessage, type IMessageList, type IMessageObject, type IPagination, type IParamsList, type IParamsMessageList, type IQueue, type IQueueList, type ISendMediaMessage, type ISendMessage, type ITag, type ITagList, type ITicket, type ITicketList, type ITicketResolveForm, type ITicketTransferForm, type ITicketUpdateForm, type IUser, type IUserList, type IZdkOptions, type MediaType, type SendMediaMessageJson, type TicketStatus, type TicketStrategy, ZappyApi, Zdk };
261
+ export { type ConnectionStatus, type FeedbackOption, type HttpMethod, type IConnection, type IConnectionList, type IContact, type IContactExtraInfo, type IContactList, type IContactPostData, type IError, type IMessage, type IMessageList, type IMessageObject, type IPagination, type IParamsList, type IParamsMessageList, type IQueue, type IQueueList, type ISendMediaMessage, type ISendMessage, type ITag, type ITagList, type ITicket, type ITicketList, type ITicketResolveForm, type ITicketTransferForm, type ITicketUpdateForm, type IUser, type IUserList, type IZdkOptions, type MediaType, type SendMediaMessageJson, type TicketStatus, type TicketStrategy, ZappyApi, Zdk };
package/dist/index.js CHANGED
@@ -1,4 +1,4 @@
1
- var k=Object.defineProperty;var q=Object.getOwnPropertyDescriptor;var A=Object.getOwnPropertyNames;var G=Object.prototype.hasOwnProperty;var f=(t,r)=>()=>(r||t((r={exports:{}}).exports,r),r.exports),S=(t,r)=>{for(var e in r)k(t,e,{get:r[e],enumerable:!0})},j=(t,r,e,o)=>{if(r&&typeof r=="object"||typeof r=="function")for(let s of A(r))!G.call(t,s)&&s!==e&&k(t,s,{get:()=>r[s],enumerable:!(o=q(r,s))||o.enumerable});return t};var F=t=>j(k({},"__esModule",{value:!0}),t);var O=f((ce,M)=>{M.exports={name:"dotenv",version:"16.3.1",description:"Loads environment variables from .env file",main:"lib/main.js",types:"lib/main.d.ts",exports:{".":{types:"./lib/main.d.ts",require:"./lib/main.js",default:"./lib/main.js"},"./config":"./config.js","./config.js":"./config.js","./lib/env-options":"./lib/env-options.js","./lib/env-options.js":"./lib/env-options.js","./lib/cli-options":"./lib/cli-options.js","./lib/cli-options.js":"./lib/cli-options.js","./package.json":"./package.json"},scripts:{"dts-check":"tsc --project tests/types/tsconfig.json",lint:"standard","lint-readme":"standard-markdown",pretest:"npm run lint && npm run dts-check",test:"tap tests/*.js --100 -Rspec",prerelease:"npm test",release:"standard-version"},repository:{type:"git",url:"git://github.com/motdotla/dotenv.git"},funding:"https://github.com/motdotla/dotenv?sponsor=1",keywords:["dotenv","env",".env","environment","variables","config","settings"],readmeFilename:"README.md",license:"BSD-2-Clause",devDependencies:{"@definitelytyped/dtslint":"^0.0.133","@types/node":"^18.11.3",decache:"^4.6.1",sinon:"^14.0.1",standard:"^17.0.0","standard-markdown":"^7.1.0","standard-version":"^9.5.0",tap:"^16.3.0",tar:"^6.1.11",typescript:"^4.8.4"},engines:{node:">=12"},browser:{fs:!1}}});var L=f((pe,u)=>{var D=require("fs"),w=require("path"),K=require("os"),Y=require("crypto"),z=O(),N=z.version,Z=/(?:^|^)\s*(?:export\s+)?([\w.-]+)(?:\s*=\s*?|:\s+?)(\s*'(?:\\'|[^'])*'|\s*"(?:\\"|[^"])*"|\s*`(?:\\`|[^`])*`|[^#\r\n]+)?\s*(?:#.*)?(?:$|$)/mg;function B(t){let r={},e=t.toString();e=e.replace(/\r\n?/mg,`
2
- `);let o;for(;(o=Z.exec(e))!=null;){let s=o[1],n=o[2]||"";n=n.trim();let a=n[0];n=n.replace(/^(['"`])([\s\S]*)\1$/mg,"$2"),a==='"'&&(n=n.replace(/\\n/g,`
3
- `),n=n.replace(/\\r/g,"\r")),r[s]=n}return r}function Q(t){let r=$(t),e=i.configDotenv({path:r});if(!e.parsed)throw new Error(`MISSING_DATA: Cannot parse ${r} for an unknown reason`);let o=P(t).split(","),s=o.length,n;for(let a=0;a<s;a++)try{let c=o[a].trim(),p=J(e,c);n=i.decrypt(p.ciphertext,p.key);break}catch(c){if(a+1>=s)throw c}return i.parse(n)}function H(t){console.log(`[dotenv@${N}][INFO] ${t}`)}function W(t){console.log(`[dotenv@${N}][WARN] ${t}`)}function _(t){console.log(`[dotenv@${N}][DEBUG] ${t}`)}function P(t){return t&&t.DOTENV_KEY&&t.DOTENV_KEY.length>0?t.DOTENV_KEY:process.env.DOTENV_KEY&&process.env.DOTENV_KEY.length>0?process.env.DOTENV_KEY:""}function J(t,r){let e;try{e=new URL(r)}catch(c){throw c.code==="ERR_INVALID_URL"?new Error("INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenv.org/vault/.env.vault?environment=development"):c}let o=e.password;if(!o)throw new Error("INVALID_DOTENV_KEY: Missing key part");let s=e.searchParams.get("environment");if(!s)throw new Error("INVALID_DOTENV_KEY: Missing environment part");let n=`DOTENV_VAULT_${s.toUpperCase()}`,a=t.parsed[n];if(!a)throw new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${n} in your .env.vault file.`);return{ciphertext:a,key:o}}function $(t){let r=w.resolve(process.cwd(),".env");return t&&t.path&&t.path.length>0&&(r=t.path),r.endsWith(".vault")?r:`${r}.vault`}function X(t){return t[0]==="~"?w.join(K.homedir(),t.slice(1)):t}function ee(t){H("Loading env from encrypted .env.vault");let r=i._parseVault(t),e=process.env;return t&&t.processEnv!=null&&(e=t.processEnv),i.populate(e,r,t),{parsed:r}}function re(t){let r=w.resolve(process.cwd(),".env"),e="utf8",o=!!(t&&t.debug);t&&(t.path!=null&&(r=X(t.path)),t.encoding!=null&&(e=t.encoding));try{let s=i.parse(D.readFileSync(r,{encoding:e})),n=process.env;return t&&t.processEnv!=null&&(n=t.processEnv),i.populate(n,s,t),{parsed:s}}catch(s){return o&&_(`Failed to load ${r} ${s.message}`),{error:s}}}function te(t){let r=$(t);return P(t).length===0?i.configDotenv(t):D.existsSync(r)?i._configVault(t):(W(`You set DOTENV_KEY but you are missing a .env.vault file at ${r}. Did you forget to build it?`),i.configDotenv(t))}function oe(t,r){let e=Buffer.from(r.slice(-64),"hex"),o=Buffer.from(t,"base64"),s=o.slice(0,12),n=o.slice(-16);o=o.slice(12,-16);try{let a=Y.createDecipheriv("aes-256-gcm",e,s);return a.setAuthTag(n),`${a.update(o)}${a.final()}`}catch(a){let c=a instanceof RangeError,p=a.message==="Invalid key length",U=a.message==="Unsupported state or unable to authenticate data";if(c||p){let T="INVALID_DOTENV_KEY: It must be 64 characters long (or more)";throw new Error(T)}else if(U){let T="DECRYPTION_FAILED: Please check your DOTENV_KEY";throw new Error(T)}else throw console.error("Error: ",a.code),console.error("Error: ",a.message),a}}function se(t,r,e={}){let o=!!(e&&e.debug),s=!!(e&&e.override);if(typeof r!="object")throw new Error("OBJECT_REQUIRED: Please check the processEnv argument being passed to populate");for(let n of Object.keys(r))Object.prototype.hasOwnProperty.call(t,n)?(s===!0&&(t[n]=r[n]),o&&_(s===!0?`"${n}" is already defined and WAS overwritten`:`"${n}" is already defined and was NOT overwritten`)):t[n]=r[n]}var i={configDotenv:re,_configVault:ee,_parseVault:Q,config:te,decrypt:oe,parse:B,populate:se};u.exports.configDotenv=i.configDotenv;u.exports._configVault=i._configVault;u.exports._parseVault=i._parseVault;u.exports.config=i.config;u.exports.decrypt=i.decrypt;u.exports.parse=i.parse;u.exports.populate=i.populate;u.exports=i});var C=f((ue,V)=>{var l={};process.env.DOTENV_CONFIG_ENCODING!=null&&(l.encoding=process.env.DOTENV_CONFIG_ENCODING);process.env.DOTENV_CONFIG_PATH!=null&&(l.path=process.env.DOTENV_CONFIG_PATH);process.env.DOTENV_CONFIG_DEBUG!=null&&(l.debug=process.env.DOTENV_CONFIG_DEBUG);process.env.DOTENV_CONFIG_OVERRIDE!=null&&(l.override=process.env.DOTENV_CONFIG_OVERRIDE);process.env.DOTENV_CONFIG_DOTENV_KEY!=null&&(l.DOTENV_KEY=process.env.DOTENV_CONFIG_DOTENV_KEY);V.exports=l});var R=f((le,x)=>{var ne=/^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/;x.exports=function(r){return r.reduce(function(e,o){let s=o.match(ne);return s&&(e[s[1]]=s[2]),e},{})}});var ae={};S(ae,{ZappyApi:()=>m,Zdk:()=>b});module.exports=F(ae);(function(){L().config(Object.assign({},C(),R()(process.argv)))})();var m=class{_rootUrl;_token;constructor(r,e){this._rootUrl=r||process.env?.ZAPPY_URL,this._token=e||process.env?.ZAPPY_TOKEN}async makeRequest(r,e,o,s){if(!this._rootUrl||!this._token)throw new Error("Missing base url or API token");let n=this._rootUrl+e,a={method:r,headers:{Authorization:`Bearer ${this._token}`,"Content-Type":s??"application/json"},body:o?typeof o=="string"?o:JSON.stringify(o):void 0};return await(await fetch(n,a)).json()}};var g=class{constructor(r){this.api=r}async list(){try{return await this.api.makeRequest("GET","/api/connections")}catch(r){return console.error(r),{error:"Unable to list connections"}}}async get(r){try{let o=(await this.api.makeRequest("GET","/api/connections"))?.connections,s=o.find(n=>n.id===r);if(!s||s?.status!=="CONNECTED"){let n=o?.find(a=>a?.status==="CONNECTED");return n||{error:"Connection not found"}}}catch(e){return console.error(e),{error:"Unable to connection"}}}};var d=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/contacts?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list contacts"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/contacts/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to contact"}}}};var y=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20,ticketId:s="",contactId:n="",dateFrom:a="",dateTo:c=""}=r||{},p=await this.api.makeRequest("GET",`/api/messages?page=${e}&pageSize=${o}&ticketId=${s}&contactId=${n}&dateFrom=${a}&dateToo=${c}`);return p?.error?{error:p?.error}:p}catch(e){return console.error(e),{error:"Unable to list message"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/messages/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to message"}}}async send(r,e,o){try{if(!o||o==="text")return await this.api.makeRequest("POST",`/api/send/${r}`,e)}catch(s){return console.error(s),{error:"Cannot send message"}}}};var I=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/queues?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list queues"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/queues/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to queue"}}}};var E=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/tags?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list tags"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/tags/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to tag"}}}};var h=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/tickets?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list tickets"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/tickets/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to ticket"}}}async transfer(r,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${r}/transfer`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot transfer ticket"}}}async resolve(r,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${r}/resolve`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot resolve ticket"}}}async update(r,e){try{let o=await this.api.makeRequest("PUT",`/api/tickets/${r}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot update ticket"}}}};var v=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/users?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list users"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/users/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to user"}}}};var b=class extends m{tickets=new h(this);connections=new g(this);contacts=new d(this);messages=new y(this);queues=new I(this);tags=new E(this);users=new v(this)};0&&(module.exports={ZappyApi,Zdk});
1
+ var G=Object.create;var g=Object.defineProperty;var Y=Object.getOwnPropertyDescriptor;var j=Object.getOwnPropertyNames;var K=Object.getPrototypeOf,z=Object.prototype.hasOwnProperty;var I=(t,r)=>()=>(r||t((r={exports:{}}).exports,r),r.exports),Z=(t,r)=>{for(var e in r)g(t,e,{get:r[e],enumerable:!0})},V=(t,r,e,o)=>{if(r&&typeof r=="object"||typeof r=="function")for(let s of j(r))!z.call(t,s)&&s!==e&&g(t,s,{get:()=>r[s],enumerable:!(o=Y(r,s))||o.enumerable});return t};var $=(t,r,e)=>(e=t!=null?G(K(t)):{},V(r||!t||!t.__esModule?g(e,"default",{value:t,enumerable:!0}):e,t)),B=t=>V(g({},"__esModule",{value:!0}),t);var L=I((de,Q)=>{Q.exports={name:"dotenv",version:"16.4.5",description:"Loads environment variables from .env file",main:"lib/main.js",types:"lib/main.d.ts",exports:{".":{types:"./lib/main.d.ts",require:"./lib/main.js",default:"./lib/main.js"},"./config":"./config.js","./config.js":"./config.js","./lib/env-options":"./lib/env-options.js","./lib/env-options.js":"./lib/env-options.js","./lib/cli-options":"./lib/cli-options.js","./lib/cli-options.js":"./lib/cli-options.js","./package.json":"./package.json"},scripts:{"dts-check":"tsc --project tests/types/tsconfig.json",lint:"standard","lint-readme":"standard-markdown",pretest:"npm run lint && npm run dts-check",test:"tap tests/*.js --100 -Rspec","test:coverage":"tap --coverage-report=lcov",prerelease:"npm test",release:"standard-version"},repository:{type:"git",url:"git://github.com/motdotla/dotenv.git"},funding:"https://dotenvx.com",keywords:["dotenv","env",".env","environment","variables","config","settings"],readmeFilename:"README.md",license:"BSD-2-Clause",devDependencies:{"@definitelytyped/dtslint":"^0.0.133","@types/node":"^18.11.3",decache:"^4.6.1",sinon:"^14.0.1",standard:"^17.0.0","standard-markdown":"^7.1.0","standard-version":"^9.5.0",tap:"^16.3.0",tar:"^6.1.11",typescript:"^4.8.4"},engines:{node:">=12"},browser:{fs:!1}}});var R=I((fe,u)=>{var w=require("fs"),b=require("path"),H=require("os"),W=require("crypto"),J=L(),O=J.version,X=/(?:^|^)\s*(?:export\s+)?([\w.-]+)(?:\s*=\s*?|:\s+?)(\s*'(?:\\'|[^'])*'|\s*"(?:\\"|[^"])*"|\s*`(?:\\`|[^`])*`|[^#\r\n]+)?\s*(?:#.*)?(?:$|$)/mg;function ee(t){let r={},e=t.toString();e=e.replace(/\r\n?/mg,`
2
+ `);let o;for(;(o=X.exec(e))!=null;){let s=o[1],n=o[2]||"";n=n.trim();let a=n[0];n=n.replace(/^(['"`])([\s\S]*)\1$/mg,"$2"),a==='"'&&(n=n.replace(/\\n/g,`
3
+ `),n=n.replace(/\\r/g,"\r")),r[s]=n}return r}function re(t){let r=A(t),e=p.configDotenv({path:r});if(!e.parsed){let a=new Error(`MISSING_DATA: Cannot parse ${r} for an unknown reason`);throw a.code="MISSING_DATA",a}let o=x(t).split(","),s=o.length,n;for(let a=0;a<s;a++)try{let i=o[a].trim(),c=se(e,i);n=p.decrypt(c.ciphertext,c.key);break}catch(i){if(a+1>=s)throw i}return p.parse(n)}function te(t){console.log(`[dotenv@${O}][INFO] ${t}`)}function oe(t){console.log(`[dotenv@${O}][WARN] ${t}`)}function y(t){console.log(`[dotenv@${O}][DEBUG] ${t}`)}function x(t){return t&&t.DOTENV_KEY&&t.DOTENV_KEY.length>0?t.DOTENV_KEY:process.env.DOTENV_KEY&&process.env.DOTENV_KEY.length>0?process.env.DOTENV_KEY:""}function se(t,r){let e;try{e=new URL(r)}catch(i){if(i.code==="ERR_INVALID_URL"){let c=new Error("INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenvx.com/vault/.env.vault?environment=development");throw c.code="INVALID_DOTENV_KEY",c}throw i}let o=e.password;if(!o){let i=new Error("INVALID_DOTENV_KEY: Missing key part");throw i.code="INVALID_DOTENV_KEY",i}let s=e.searchParams.get("environment");if(!s){let i=new Error("INVALID_DOTENV_KEY: Missing environment part");throw i.code="INVALID_DOTENV_KEY",i}let n=`DOTENV_VAULT_${s.toUpperCase()}`,a=t.parsed[n];if(!a){let i=new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${n} in your .env.vault file.`);throw i.code="NOT_FOUND_DOTENV_ENVIRONMENT",i}return{ciphertext:a,key:o}}function A(t){let r=null;if(t&&t.path&&t.path.length>0)if(Array.isArray(t.path))for(let e of t.path)w.existsSync(e)&&(r=e.endsWith(".vault")?e:`${e}.vault`);else r=t.path.endsWith(".vault")?t.path:`${t.path}.vault`;else r=b.resolve(process.cwd(),".env.vault");return w.existsSync(r)?r:null}function C(t){return t[0]==="~"?b.join(H.homedir(),t.slice(1)):t}function ne(t){te("Loading env from encrypted .env.vault");let r=p._parseVault(t),e=process.env;return t&&t.processEnv!=null&&(e=t.processEnv),p.populate(e,r,t),{parsed:r}}function ae(t){let r=b.resolve(process.cwd(),".env"),e="utf8",o=!!(t&&t.debug);t&&t.encoding?e=t.encoding:o&&y("No encoding is specified. UTF-8 is used by default");let s=[r];if(t&&t.path)if(!Array.isArray(t.path))s=[C(t.path)];else{s=[];for(let c of t.path)s.push(C(c))}let n,a={};for(let c of s)try{let l=p.parse(w.readFileSync(c,{encoding:e}));p.populate(a,l,t)}catch(l){o&&y(`Failed to load ${c} ${l.message}`),n=l}let i=process.env;return t&&t.processEnv!=null&&(i=t.processEnv),p.populate(i,a,t),n?{parsed:a,error:n}:{parsed:a}}function ie(t){if(x(t).length===0)return p.configDotenv(t);let r=A(t);return r?p._configVault(t):(oe(`You set DOTENV_KEY but you are missing a .env.vault file at ${r}. Did you forget to build it?`),p.configDotenv(t))}function ce(t,r){let e=Buffer.from(r.slice(-64),"hex"),o=Buffer.from(t,"base64"),s=o.subarray(0,12),n=o.subarray(-16);o=o.subarray(12,-16);try{let a=W.createDecipheriv("aes-256-gcm",e,s);return a.setAuthTag(n),`${a.update(o)}${a.final()}`}catch(a){let i=a instanceof RangeError,c=a.message==="Invalid key length",l=a.message==="Unsupported state or unable to authenticate data";if(i||c){let d=new Error("INVALID_DOTENV_KEY: It must be 64 characters long (or more)");throw d.code="INVALID_DOTENV_KEY",d}else if(l){let d=new Error("DECRYPTION_FAILED: Please check your DOTENV_KEY");throw d.code="DECRYPTION_FAILED",d}else throw a}}function pe(t,r,e={}){let o=!!(e&&e.debug),s=!!(e&&e.override);if(typeof r!="object"){let n=new Error("OBJECT_REQUIRED: Please check the processEnv argument being passed to populate");throw n.code="OBJECT_REQUIRED",n}for(let n of Object.keys(r))Object.prototype.hasOwnProperty.call(t,n)?(s===!0&&(t[n]=r[n]),o&&y(s===!0?`"${n}" is already defined and WAS overwritten`:`"${n}" is already defined and was NOT overwritten`)):t[n]=r[n]}var p={configDotenv:ae,_configVault:ne,_parseVault:re,config:ie,decrypt:ce,parse:ee,populate:pe};u.exports.configDotenv=p.configDotenv;u.exports._configVault=p._configVault;u.exports._parseVault=p._parseVault;u.exports.config=p.config;u.exports.decrypt=p.decrypt;u.exports.parse=p.parse;u.exports.populate=p.populate;u.exports=p});var q=I((ge,U)=>{var m={};process.env.DOTENV_CONFIG_ENCODING!=null&&(m.encoding=process.env.DOTENV_CONFIG_ENCODING);process.env.DOTENV_CONFIG_PATH!=null&&(m.path=process.env.DOTENV_CONFIG_PATH);process.env.DOTENV_CONFIG_DEBUG!=null&&(m.debug=process.env.DOTENV_CONFIG_DEBUG);process.env.DOTENV_CONFIG_OVERRIDE!=null&&(m.override=process.env.DOTENV_CONFIG_OVERRIDE);process.env.DOTENV_CONFIG_DOTENV_KEY!=null&&(m.DOTENV_KEY=process.env.DOTENV_CONFIG_DOTENV_KEY);U.exports=m});var S=I((Ie,M)=>{var ue=/^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/;M.exports=function(r){return r.reduce(function(e,o){let s=o.match(ue);return s&&(e[s[1]]=s[2]),e},{})}});var le={};Z(le,{ZappyApi:()=>f,Zdk:()=>P});module.exports=B(le);(function(){R().config(Object.assign({},q(),S()(process.argv)))})();var E=$(require("axios")),f=class{_rootUrl;_token;constructor(r,e){this._rootUrl=r||process.env?.ZAPPY_URL,this._token=e||process.env?.ZAPPY_TOKEN}async makeRequest(r,e,o,s){if(!this._rootUrl||!this._token)throw new Error("Missing base url or API token");try{let a={url:this._rootUrl+e,method:r,headers:{"Content-Type":"application/json",Authorization:`Bearer ${this._token}`,...s},data:o};return await(await(0,E.default)(a)).data}catch(n){throw n instanceof E.AxiosError&&"error"in n.response.data?new Error(n?.response?.data?.error):new Error("No request possible")}}};var h=class{constructor(r){this.api=r}async list(){try{return await this.api.makeRequest("GET","/api/connections")}catch(r){return console.error(r),{error:"Unable to list connections"}}}async get(r){try{let o=(await this.api.makeRequest("GET","/api/connections"))?.connections,s=o.find(n=>n.id===r);if(!s||s?.status!=="CONNECTED"){let n=o?.find(a=>a?.status==="CONNECTED");return n||{error:"Connection not found"}}}catch(e){return console.error(e),{error:"Unable to connection"}}}};var v=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/contacts?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list contacts"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/contacts/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"No contact details could be obtained"}}}async update(r,e){try{let o=await this.api.makeRequest("PUT",`/api/contacts/${r}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Unable to update contact"}}}};var F=$(require("form-data")),T=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20,ticketId:s="",contactId:n="",dateFrom:a="",dateTo:i=""}=r||{},c=await this.api.makeRequest("GET",`/api/messages?page=${e}&pageSize=${o}&ticketId=${s}&contactId=${n}&dateFrom=${a}&dateToo=${i}`);return c?.error?{error:c?.error}:c}catch(e){return console.error(e),{error:"Unable to list message"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/messages/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to message"}}}async send(r,e,o){try{if(!o||o==="text"){let s=await this.api.makeRequest("POST",`/api/send/${r}`,e);return s?.error?{error:s?.error}:s}else{let{caption:s,connectionFrom:n,media:a}=e,i=new F.default;i.append("media",a),i.append("caption",s||""),i.append("connectionFrom",n);let c=await this.api.makeRequest("POST",`/api/send/${o}/${r}`,i,{...i.getHeaders()});return c?.error?{error:c?.error}:c}}catch(s){return console.error(s),{error:"Cannot send message"}}}};var _=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/queues?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list queues"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/queues/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to queue"}}}};var k=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/tags?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list tags"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/tags/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to tag"}}}};var N=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/tickets?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list tickets"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/tickets/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to ticket"}}}async transfer(r,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${r}/transfer`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot transfer ticket"}}}async resolve(r,e){try{let o=await this.api.makeRequest("POST",`/api/tickets/${r}/resolve`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot resolve ticket"}}}async update(r,e){try{let o=await this.api.makeRequest("PUT",`/api/tickets/${r}`,e);return o?.error?{error:o?.error}:o}catch(o){return console.error(o),{error:"Cannot update ticket"}}}};var D=class{constructor(r){this.api=r}async list(r){try{let{page:e=1,pageSize:o=20}=r||{},s=await this.api.makeRequest("GET",`/api/users?page=${e}&pageSize=${o}`);return s?.error?{error:s?.error}:s}catch(e){return console.error(e),{error:"Unable to list users"}}}async get(r){try{let e=await this.api.makeRequest("GET",`/api/users/${r}`);return e?.error?{error:e?.error}:e}catch(e){return console.error(e),{error:"Unable to user"}}}};var P=class extends f{tickets=new N(this);connections=new h(this);contacts=new v(this);messages=new T(this);queues=new _(this);tags=new k(this);users=new D(this)};0&&(module.exports={ZappyApi,Zdk});
4
4
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +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.3.1\",\n \"description\": \"Loads environment variables from .env file\",\n \"main\": \"lib/main.js\",\n \"types\": \"lib/main.d.ts\",\n \"exports\": {\n \".\": {\n \"types\": \"./lib/main.d.ts\",\n \"require\": \"./lib/main.js\",\n \"default\": \"./lib/main.js\"\n },\n \"./config\": \"./config.js\",\n \"./config.js\": \"./config.js\",\n \"./lib/env-options\": \"./lib/env-options.js\",\n \"./lib/env-options.js\": \"./lib/env-options.js\",\n \"./lib/cli-options\": \"./lib/cli-options.js\",\n \"./lib/cli-options.js\": \"./lib/cli-options.js\",\n \"./package.json\": \"./package.json\"\n },\n \"scripts\": {\n \"dts-check\": \"tsc --project tests/types/tsconfig.json\",\n \"lint\": \"standard\",\n \"lint-readme\": \"standard-markdown\",\n \"pretest\": \"npm run lint && npm run dts-check\",\n \"test\": \"tap tests/*.js --100 -Rspec\",\n \"prerelease\": \"npm test\",\n \"release\": \"standard-version\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git://github.com/motdotla/dotenv.git\"\n },\n \"funding\": \"https://github.com/motdotla/dotenv?sponsor=1\",\n \"keywords\": [\n \"dotenv\",\n \"env\",\n \".env\",\n \"environment\",\n \"variables\",\n \"config\",\n \"settings\"\n ],\n \"readmeFilename\": \"README.md\",\n \"license\": \"BSD-2-Clause\",\n \"devDependencies\": {\n \"@definitelytyped/dtslint\": \"^0.0.133\",\n \"@types/node\": \"^18.11.3\",\n \"decache\": \"^4.6.1\",\n \"sinon\": \"^14.0.1\",\n \"standard\": \"^17.0.0\",\n \"standard-markdown\": \"^7.1.0\",\n \"standard-version\": \"^9.5.0\",\n \"tap\": \"^16.3.0\",\n \"tar\": \"^6.1.11\",\n \"typescript\": \"^4.8.4\"\n },\n \"engines\": {\n \"node\": \">=12\"\n },\n \"browser\": {\n \"fs\": false\n }\n}\n","const fs = require('fs')\nconst path = require('path')\nconst os = require('os')\nconst crypto = require('crypto')\nconst packageJson = require('../package.json')\n\nconst version = packageJson.version\n\nconst LINE = /(?:^|^)\\s*(?:export\\s+)?([\\w.-]+)(?:\\s*=\\s*?|:\\s+?)(\\s*'(?:\\\\'|[^'])*'|\\s*\"(?:\\\\\"|[^\"])*\"|\\s*`(?:\\\\`|[^`])*`|[^#\\r\\n]+)?\\s*(?:#.*)?(?:$|$)/mg\n\n// Parse src into an Object\nfunction parse (src) {\n const obj = {}\n\n // Convert buffer to string\n let lines = src.toString()\n\n // Convert line breaks to same format\n lines = lines.replace(/\\r\\n?/mg, '\\n')\n\n let match\n while ((match = LINE.exec(lines)) != null) {\n const key = match[1]\n\n // Default undefined or null to empty string\n let value = (match[2] || '')\n\n // Remove whitespace\n value = value.trim()\n\n // Check if double quoted\n const maybeQuote = value[0]\n\n // Remove surrounding quotes\n value = value.replace(/^(['\"`])([\\s\\S]*)\\1$/mg, '$2')\n\n // Expand newlines if double quoted\n if (maybeQuote === '\"') {\n value = value.replace(/\\\\n/g, '\\n')\n value = value.replace(/\\\\r/g, '\\r')\n }\n\n // Add to object\n obj[key] = value\n }\n\n return obj\n}\n\nfunction _parseVault (options) {\n const vaultPath = _vaultPath(options)\n\n // Parse .env.vault\n const result = DotenvModule.configDotenv({ path: vaultPath })\n if (!result.parsed) {\n throw new Error(`MISSING_DATA: Cannot parse ${vaultPath} for an unknown reason`)\n }\n\n // handle scenario for comma separated keys - for use with key rotation\n // example: DOTENV_KEY=\"dotenv://:key_1234@dotenv.org/vault/.env.vault?environment=prod,dotenv://:key_7890@dotenv.org/vault/.env.vault?environment=prod\"\n const keys = _dotenvKey(options).split(',')\n const length = keys.length\n\n let decrypted\n for (let i = 0; i < length; i++) {\n try {\n // Get full key\n const key = keys[i].trim()\n\n // Get instructions for decrypt\n const attrs = _instructions(result, key)\n\n // Decrypt\n decrypted = DotenvModule.decrypt(attrs.ciphertext, attrs.key)\n\n break\n } catch (error) {\n // last key\n if (i + 1 >= length) {\n throw error\n }\n // try next key\n }\n }\n\n // Parse decrypted .env string\n return DotenvModule.parse(decrypted)\n}\n\nfunction _log (message) {\n console.log(`[dotenv@${version}][INFO] ${message}`)\n}\n\nfunction _warn (message) {\n console.log(`[dotenv@${version}][WARN] ${message}`)\n}\n\nfunction _debug (message) {\n console.log(`[dotenv@${version}][DEBUG] ${message}`)\n}\n\nfunction _dotenvKey (options) {\n // prioritize developer directly setting options.DOTENV_KEY\n if (options && options.DOTENV_KEY && options.DOTENV_KEY.length > 0) {\n return options.DOTENV_KEY\n }\n\n // secondary infra already contains a DOTENV_KEY environment variable\n if (process.env.DOTENV_KEY && process.env.DOTENV_KEY.length > 0) {\n return process.env.DOTENV_KEY\n }\n\n // fallback to empty string\n return ''\n}\n\nfunction _instructions (result, dotenvKey) {\n // Parse DOTENV_KEY. Format is a URI\n let uri\n try {\n uri = new URL(dotenvKey)\n } catch (error) {\n if (error.code === 'ERR_INVALID_URL') {\n throw new Error('INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenv.org/vault/.env.vault?environment=development')\n }\n\n throw error\n }\n\n // Get decrypt key\n const key = uri.password\n if (!key) {\n throw new Error('INVALID_DOTENV_KEY: Missing key part')\n }\n\n // Get environment\n const environment = uri.searchParams.get('environment')\n if (!environment) {\n throw new Error('INVALID_DOTENV_KEY: Missing environment part')\n }\n\n // Get ciphertext payload\n const environmentKey = `DOTENV_VAULT_${environment.toUpperCase()}`\n const ciphertext = result.parsed[environmentKey] // DOTENV_VAULT_PRODUCTION\n if (!ciphertext) {\n throw new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${environmentKey} in your .env.vault file.`)\n }\n\n return { ciphertext, key }\n}\n\nfunction _vaultPath (options) {\n let dotenvPath = path.resolve(process.cwd(), '.env')\n\n if (options && options.path && options.path.length > 0) {\n dotenvPath = options.path\n }\n\n // Locate .env.vault\n return dotenvPath.endsWith('.vault') ? dotenvPath : `${dotenvPath}.vault`\n}\n\nfunction _resolveHome (envPath) {\n return envPath[0] === '~' ? path.join(os.homedir(), envPath.slice(1)) : envPath\n}\n\nfunction _configVault (options) {\n _log('Loading env from encrypted .env.vault')\n\n const parsed = DotenvModule._parseVault(options)\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsed, options)\n\n return { parsed }\n}\n\nfunction configDotenv (options) {\n let dotenvPath = path.resolve(process.cwd(), '.env')\n let encoding = 'utf8'\n const debug = Boolean(options && options.debug)\n\n if (options) {\n if (options.path != null) {\n dotenvPath = _resolveHome(options.path)\n }\n if (options.encoding != null) {\n encoding = options.encoding\n }\n }\n\n try {\n // Specifying an encoding returns a string instead of a buffer\n const parsed = DotenvModule.parse(fs.readFileSync(dotenvPath, { encoding }))\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsed, options)\n\n return { parsed }\n } catch (e) {\n if (debug) {\n _debug(`Failed to load ${dotenvPath} ${e.message}`)\n }\n\n return { error: e }\n }\n}\n\n// Populates process.env from .env file\nfunction config (options) {\n const vaultPath = _vaultPath(options)\n\n // fallback to original dotenv if DOTENV_KEY is not set\n if (_dotenvKey(options).length === 0) {\n return DotenvModule.configDotenv(options)\n }\n\n // dotenvKey exists but .env.vault file does not exist\n if (!fs.existsSync(vaultPath)) {\n _warn(`You set DOTENV_KEY but you are missing a .env.vault file at ${vaultPath}. Did you forget to build it?`)\n\n return DotenvModule.configDotenv(options)\n }\n\n return DotenvModule._configVault(options)\n}\n\nfunction decrypt (encrypted, keyStr) {\n const key = Buffer.from(keyStr.slice(-64), 'hex')\n let ciphertext = Buffer.from(encrypted, 'base64')\n\n const nonce = ciphertext.slice(0, 12)\n const authTag = ciphertext.slice(-16)\n ciphertext = ciphertext.slice(12, -16)\n\n try {\n const aesgcm = crypto.createDecipheriv('aes-256-gcm', key, nonce)\n aesgcm.setAuthTag(authTag)\n return `${aesgcm.update(ciphertext)}${aesgcm.final()}`\n } catch (error) {\n const isRange = error instanceof RangeError\n const invalidKeyLength = error.message === 'Invalid key length'\n const decryptionFailed = error.message === 'Unsupported state or unable to authenticate data'\n\n if (isRange || invalidKeyLength) {\n const msg = 'INVALID_DOTENV_KEY: It must be 64 characters long (or more)'\n throw new Error(msg)\n } else if (decryptionFailed) {\n const msg = 'DECRYPTION_FAILED: Please check your DOTENV_KEY'\n throw new Error(msg)\n } else {\n console.error('Error: ', error.code)\n console.error('Error: ', error.message)\n throw error\n }\n }\n}\n\n// Populate process.env with parsed values\nfunction populate (processEnv, parsed, options = {}) {\n const debug = Boolean(options && options.debug)\n const override = Boolean(options && options.override)\n\n if (typeof parsed !== 'object') {\n throw new Error('OBJECT_REQUIRED: Please check the processEnv argument being passed to populate')\n }\n\n // Set process.env\n for (const key of Object.keys(parsed)) {\n if (Object.prototype.hasOwnProperty.call(processEnv, key)) {\n if (override === true) {\n processEnv[key] = parsed[key]\n }\n\n if (debug) {\n if (override === true) {\n _debug(`\"${key}\" is already defined and WAS overwritten`)\n } else {\n _debug(`\"${key}\" is already defined and was NOT overwritten`)\n }\n }\n } else {\n processEnv[key] = parsed[key]\n }\n }\n}\n\nconst DotenvModule = {\n configDotenv,\n _configVault,\n _parseVault,\n config,\n decrypt,\n parse,\n populate\n}\n\nmodule.exports.configDotenv = DotenvModule.configDotenv\nmodule.exports._configVault = DotenvModule._configVault\nmodule.exports._parseVault = DotenvModule._parseVault\nmodule.exports.config = DotenvModule.config\nmodule.exports.decrypt = DotenvModule.decrypt\nmodule.exports.parse = DotenvModule.parse\nmodule.exports.populate = DotenvModule.populate\n\nmodule.exports = DotenvModule\n","// ../config.js accepts options via environment variables\nconst options = {}\n\nif (process.env.DOTENV_CONFIG_ENCODING != null) {\n options.encoding = process.env.DOTENV_CONFIG_ENCODING\n}\n\nif (process.env.DOTENV_CONFIG_PATH != null) {\n options.path = process.env.DOTENV_CONFIG_PATH\n}\n\nif (process.env.DOTENV_CONFIG_DEBUG != null) {\n options.debug = process.env.DOTENV_CONFIG_DEBUG\n}\n\nif (process.env.DOTENV_CONFIG_OVERRIDE != null) {\n options.override = process.env.DOTENV_CONFIG_OVERRIDE\n}\n\nif (process.env.DOTENV_CONFIG_DOTENV_KEY != null) {\n options.DOTENV_KEY = process.env.DOTENV_CONFIG_DOTENV_KEY\n}\n\nmodule.exports = options\n","const re = /^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/\n\nmodule.exports = function optionMatcher (args) {\n return args.reduce(function (acc, cur) {\n const matches = cur.match(re)\n if (matches) {\n acc[matches[1]] = matches[2]\n }\n return acc\n }, {})\n}\n","export * from \"./zdk\";\nexport * from \"./types\";\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\";\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 // eslint-disable-next-line @typescript-eslint/no-explicit-any\n body?: any,\n contentType?: string\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): Promise<any> {\n if (!this._rootUrl || !this._token) {\n throw new Error(\"Missing base url or API token\");\n }\n\n const fullUrl: string = this._rootUrl + endpoint;\n const options: RequestInit = {\n method,\n headers: {\n Authorization: `Bearer ${this._token}`,\n \"Content-Type\": contentType ?? \"application/json\",\n },\n body: body\n ? typeof body === \"string\"\n ? body\n : JSON.stringify(body)\n : undefined,\n };\n\n const request = await fetch(fullUrl, options);\n\n const response = await request.json();\n\n return response;\n }\n}\n","import { ZappyApi } from \"../zappy-api\";\nimport type { IConnection, IConnectionList, IError } from \"../types\";\n\nexport class Connection {\n constructor(protected api: ZappyApi) {}\n\n async list(): Promise<IConnectionList | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", \"/api/connections\");\n\n return response as IConnectionList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list connections\" };\n }\n }\n\n async get(id?: number): Promise<IConnection | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", \"/api/connections\");\n\n const connections = response?.connections as IConnection[];\n\n const connectionExists = connections.find(\n (connection: IConnection) => connection.id === id\n );\n\n if (!connectionExists || connectionExists?.status !== \"CONNECTED\") {\n const validConnection = connections?.find(\n (connection: IConnection) => connection?.status === \"CONNECTED\"\n );\n\n if (!validConnection) return { error: \"Connection not found\" };\n\n return validConnection;\n }\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to connection\" };\n }\n }\n}\n","import type { IContact, IContactList, IError, IParamsList } from \"../types\";\nimport type { 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: \"Unable to contact\" };\n }\n }\n}\n","import type {\n IError,\n IMessage,\n IMessageList,\n IParamsMessageList,\n ISendMessage,\n MediaType,\n} from \"../types\";\n\nimport type { ZappyApi } from \"../zappy-api\";\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, type?: MediaType) {\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 return response;\n }\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot send message\" };\n }\n }\n}\n","import type { IError, IParamsList, IQueue, IQueueList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Queue {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<IQueueList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/queues?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IQueueList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list queues\" };\n }\n }\n\n async get(id: number): Promise<IQueue | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/queues/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IQueue;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to queue\" };\n }\n }\n}\n","import type { IError, IParamsList, ITag, ITagList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Tag {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<ITagList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/tags?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITagList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list tags\" };\n }\n }\n\n async get(id: number): Promise<ITag | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/tags/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as ITag;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to tag\" };\n }\n }\n}\n","import type {\n IError,\n IParamsList,\n ITicket,\n ITicketList,\n ITicketResolveForm,\n ITicketTransferForm,\n ITicketUpdateForm,\n} from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Ticket {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<ITicketList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/tickets?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicketList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list tickets\" };\n }\n }\n\n async get(id: number): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/tickets/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to ticket\" };\n }\n }\n\n async transfer(\n id: number,\n data: ITicketTransferForm\n ): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/tickets/${id}/transfer`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot transfer ticket\" };\n }\n }\n\n async resolve(\n id: number,\n data: ITicketResolveForm\n ): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/tickets/${id}/resolve`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot resolve ticket\" };\n }\n }\n\n async update(id: number, data: ITicketUpdateForm): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"PUT\",\n `/api/tickets/${id}`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot update ticket\" };\n }\n }\n}\n","import type { IError, IParamsList, IUser, IUserList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class User {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<IUserList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/users?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IUserList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list users\" };\n }\n }\n\n async get(id: number): Promise<IUser | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/users/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IUser;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to user\" };\n }\n }\n}\n","import \"dotenv/config\";\n\nimport { ZappyApi } from \"./zappy-api\";\nimport { Connection } from \"./lib\";\nimport { Contact } from \"./lib/contact\";\nimport { Message } from \"./lib/message\";\nimport { Queue } from \"./lib/queue\";\nimport { Tag } from \"./lib/tag\";\nimport { User } from \"./lib/user\";\nimport { Ticket } from \"./lib/ticket\";\n\nexport class Zdk extends ZappyApi {\n readonly tickets = new Ticket(this);\n\n readonly connections = new Connection(this);\n\n readonly contacts = new Contact(this);\n\n readonly messages = new Message(this);\n\n readonly queues = new Queue(this);\n\n readonly tags = new Tag(this);\n\n readonly users = new User(this);\n}\n\nexport default Zdk;\n"],"mappings":"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","names":["require_package","__commonJSMin","exports","module","require_main","__commonJSMin","exports","module","fs","path","os","crypto","packageJson","version","LINE","parse","src","obj","lines","match","key","value","maybeQuote","_parseVault","options","vaultPath","_vaultPath","result","DotenvModule","keys","_dotenvKey","length","decrypted","i","attrs","_instructions","error","_log","message","_warn","_debug","dotenvKey","uri","environment","environmentKey","ciphertext","dotenvPath","_resolveHome","envPath","_configVault","parsed","processEnv","configDotenv","encoding","debug","e","config","decrypt","encrypted","keyStr","nonce","authTag","aesgcm","isRange","invalidKeyLength","decryptionFailed","msg","populate","override","require_env_options","__commonJSMin","exports","module","options","require_cli_options","__commonJSMin","exports","module","re","args","acc","cur","matches","src_exports","__export","ZappyApi","Zdk","__toCommonJS","ZappyApi","rootUrl","token","method","endpoint","body","contentType","fullUrl","options","Connection","api","error","id","connections","connectionExists","connection","validConnection","Contact","api","params","page","pageSize","response","error","id","Message","api","params","page","pageSize","ticketId","contactId","dateFrom","dateTo","response","error","id","to","data","type","Queue","api","params","page","pageSize","response","error","id","Tag","api","params","page","pageSize","response","error","id","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"]}
1
+ {"version":3,"sources":["../node_modules/dotenv/package.json","../node_modules/dotenv/lib/main.js","../node_modules/dotenv/lib/env-options.js","../node_modules/dotenv/lib/cli-options.js","../src/index.ts","../node_modules/dotenv/config.js","../src/zappy-api.ts","../src/lib/connection.ts","../src/lib/contact.ts","../src/lib/message.ts","../src/lib/queue.ts","../src/lib/tag.ts","../src/lib/ticket.ts","../src/lib/user.ts","../src/zdk.ts"],"sourcesContent":["{\n \"name\": \"dotenv\",\n \"version\": \"16.4.5\",\n \"description\": \"Loads environment variables from .env file\",\n \"main\": \"lib/main.js\",\n \"types\": \"lib/main.d.ts\",\n \"exports\": {\n \".\": {\n \"types\": \"./lib/main.d.ts\",\n \"require\": \"./lib/main.js\",\n \"default\": \"./lib/main.js\"\n },\n \"./config\": \"./config.js\",\n \"./config.js\": \"./config.js\",\n \"./lib/env-options\": \"./lib/env-options.js\",\n \"./lib/env-options.js\": \"./lib/env-options.js\",\n \"./lib/cli-options\": \"./lib/cli-options.js\",\n \"./lib/cli-options.js\": \"./lib/cli-options.js\",\n \"./package.json\": \"./package.json\"\n },\n \"scripts\": {\n \"dts-check\": \"tsc --project tests/types/tsconfig.json\",\n \"lint\": \"standard\",\n \"lint-readme\": \"standard-markdown\",\n \"pretest\": \"npm run lint && npm run dts-check\",\n \"test\": \"tap tests/*.js --100 -Rspec\",\n \"test:coverage\": \"tap --coverage-report=lcov\",\n \"prerelease\": \"npm test\",\n \"release\": \"standard-version\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git://github.com/motdotla/dotenv.git\"\n },\n \"funding\": \"https://dotenvx.com\",\n \"keywords\": [\n \"dotenv\",\n \"env\",\n \".env\",\n \"environment\",\n \"variables\",\n \"config\",\n \"settings\"\n ],\n \"readmeFilename\": \"README.md\",\n \"license\": \"BSD-2-Clause\",\n \"devDependencies\": {\n \"@definitelytyped/dtslint\": \"^0.0.133\",\n \"@types/node\": \"^18.11.3\",\n \"decache\": \"^4.6.1\",\n \"sinon\": \"^14.0.1\",\n \"standard\": \"^17.0.0\",\n \"standard-markdown\": \"^7.1.0\",\n \"standard-version\": \"^9.5.0\",\n \"tap\": \"^16.3.0\",\n \"tar\": \"^6.1.11\",\n \"typescript\": \"^4.8.4\"\n },\n \"engines\": {\n \"node\": \">=12\"\n },\n \"browser\": {\n \"fs\": false\n }\n}\n","const fs = require('fs')\nconst path = require('path')\nconst os = require('os')\nconst crypto = require('crypto')\nconst packageJson = require('../package.json')\n\nconst version = packageJson.version\n\nconst LINE = /(?:^|^)\\s*(?:export\\s+)?([\\w.-]+)(?:\\s*=\\s*?|:\\s+?)(\\s*'(?:\\\\'|[^'])*'|\\s*\"(?:\\\\\"|[^\"])*\"|\\s*`(?:\\\\`|[^`])*`|[^#\\r\\n]+)?\\s*(?:#.*)?(?:$|$)/mg\n\n// Parse src into an Object\nfunction parse (src) {\n const obj = {}\n\n // Convert buffer to string\n let lines = src.toString()\n\n // Convert line breaks to same format\n lines = lines.replace(/\\r\\n?/mg, '\\n')\n\n let match\n while ((match = LINE.exec(lines)) != null) {\n const key = match[1]\n\n // Default undefined or null to empty string\n let value = (match[2] || '')\n\n // Remove whitespace\n value = value.trim()\n\n // Check if double quoted\n const maybeQuote = value[0]\n\n // Remove surrounding quotes\n value = value.replace(/^(['\"`])([\\s\\S]*)\\1$/mg, '$2')\n\n // Expand newlines if double quoted\n if (maybeQuote === '\"') {\n value = value.replace(/\\\\n/g, '\\n')\n value = value.replace(/\\\\r/g, '\\r')\n }\n\n // Add to object\n obj[key] = value\n }\n\n return obj\n}\n\nfunction _parseVault (options) {\n const vaultPath = _vaultPath(options)\n\n // Parse .env.vault\n const result = DotenvModule.configDotenv({ path: vaultPath })\n if (!result.parsed) {\n const err = new Error(`MISSING_DATA: Cannot parse ${vaultPath} for an unknown reason`)\n err.code = 'MISSING_DATA'\n throw err\n }\n\n // handle scenario for comma separated keys - for use with key rotation\n // example: DOTENV_KEY=\"dotenv://:key_1234@dotenvx.com/vault/.env.vault?environment=prod,dotenv://:key_7890@dotenvx.com/vault/.env.vault?environment=prod\"\n const keys = _dotenvKey(options).split(',')\n const length = keys.length\n\n let decrypted\n for (let i = 0; i < length; i++) {\n try {\n // Get full key\n const key = keys[i].trim()\n\n // Get instructions for decrypt\n const attrs = _instructions(result, key)\n\n // Decrypt\n decrypted = DotenvModule.decrypt(attrs.ciphertext, attrs.key)\n\n break\n } catch (error) {\n // last key\n if (i + 1 >= length) {\n throw error\n }\n // try next key\n }\n }\n\n // Parse decrypted .env string\n return DotenvModule.parse(decrypted)\n}\n\nfunction _log (message) {\n console.log(`[dotenv@${version}][INFO] ${message}`)\n}\n\nfunction _warn (message) {\n console.log(`[dotenv@${version}][WARN] ${message}`)\n}\n\nfunction _debug (message) {\n console.log(`[dotenv@${version}][DEBUG] ${message}`)\n}\n\nfunction _dotenvKey (options) {\n // prioritize developer directly setting options.DOTENV_KEY\n if (options && options.DOTENV_KEY && options.DOTENV_KEY.length > 0) {\n return options.DOTENV_KEY\n }\n\n // secondary infra already contains a DOTENV_KEY environment variable\n if (process.env.DOTENV_KEY && process.env.DOTENV_KEY.length > 0) {\n return process.env.DOTENV_KEY\n }\n\n // fallback to empty string\n return ''\n}\n\nfunction _instructions (result, dotenvKey) {\n // Parse DOTENV_KEY. Format is a URI\n let uri\n try {\n uri = new URL(dotenvKey)\n } catch (error) {\n if (error.code === 'ERR_INVALID_URL') {\n const err = new Error('INVALID_DOTENV_KEY: Wrong format. Must be in valid uri format like dotenv://:key_1234@dotenvx.com/vault/.env.vault?environment=development')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n }\n\n throw error\n }\n\n // Get decrypt key\n const key = uri.password\n if (!key) {\n const err = new Error('INVALID_DOTENV_KEY: Missing key part')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n }\n\n // Get environment\n const environment = uri.searchParams.get('environment')\n if (!environment) {\n const err = new Error('INVALID_DOTENV_KEY: Missing environment part')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n }\n\n // Get ciphertext payload\n const environmentKey = `DOTENV_VAULT_${environment.toUpperCase()}`\n const ciphertext = result.parsed[environmentKey] // DOTENV_VAULT_PRODUCTION\n if (!ciphertext) {\n const err = new Error(`NOT_FOUND_DOTENV_ENVIRONMENT: Cannot locate environment ${environmentKey} in your .env.vault file.`)\n err.code = 'NOT_FOUND_DOTENV_ENVIRONMENT'\n throw err\n }\n\n return { ciphertext, key }\n}\n\nfunction _vaultPath (options) {\n let possibleVaultPath = null\n\n if (options && options.path && options.path.length > 0) {\n if (Array.isArray(options.path)) {\n for (const filepath of options.path) {\n if (fs.existsSync(filepath)) {\n possibleVaultPath = filepath.endsWith('.vault') ? filepath : `${filepath}.vault`\n }\n }\n } else {\n possibleVaultPath = options.path.endsWith('.vault') ? options.path : `${options.path}.vault`\n }\n } else {\n possibleVaultPath = path.resolve(process.cwd(), '.env.vault')\n }\n\n if (fs.existsSync(possibleVaultPath)) {\n return possibleVaultPath\n }\n\n return null\n}\n\nfunction _resolveHome (envPath) {\n return envPath[0] === '~' ? path.join(os.homedir(), envPath.slice(1)) : envPath\n}\n\nfunction _configVault (options) {\n _log('Loading env from encrypted .env.vault')\n\n const parsed = DotenvModule._parseVault(options)\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsed, options)\n\n return { parsed }\n}\n\nfunction configDotenv (options) {\n const dotenvPath = path.resolve(process.cwd(), '.env')\n let encoding = 'utf8'\n const debug = Boolean(options && options.debug)\n\n if (options && options.encoding) {\n encoding = options.encoding\n } else {\n if (debug) {\n _debug('No encoding is specified. UTF-8 is used by default')\n }\n }\n\n let optionPaths = [dotenvPath] // default, look for .env\n if (options && options.path) {\n if (!Array.isArray(options.path)) {\n optionPaths = [_resolveHome(options.path)]\n } else {\n optionPaths = [] // reset default\n for (const filepath of options.path) {\n optionPaths.push(_resolveHome(filepath))\n }\n }\n }\n\n // Build the parsed data in a temporary object (because we need to return it). Once we have the final\n // parsed data, we will combine it with process.env (or options.processEnv if provided).\n let lastError\n const parsedAll = {}\n for (const path of optionPaths) {\n try {\n // Specifying an encoding returns a string instead of a buffer\n const parsed = DotenvModule.parse(fs.readFileSync(path, { encoding }))\n\n DotenvModule.populate(parsedAll, parsed, options)\n } catch (e) {\n if (debug) {\n _debug(`Failed to load ${path} ${e.message}`)\n }\n lastError = e\n }\n }\n\n let processEnv = process.env\n if (options && options.processEnv != null) {\n processEnv = options.processEnv\n }\n\n DotenvModule.populate(processEnv, parsedAll, options)\n\n if (lastError) {\n return { parsed: parsedAll, error: lastError }\n } else {\n return { parsed: parsedAll }\n }\n}\n\n// Populates process.env from .env file\nfunction config (options) {\n // fallback to original dotenv if DOTENV_KEY is not set\n if (_dotenvKey(options).length === 0) {\n return DotenvModule.configDotenv(options)\n }\n\n const vaultPath = _vaultPath(options)\n\n // dotenvKey exists but .env.vault file does not exist\n if (!vaultPath) {\n _warn(`You set DOTENV_KEY but you are missing a .env.vault file at ${vaultPath}. Did you forget to build it?`)\n\n return DotenvModule.configDotenv(options)\n }\n\n return DotenvModule._configVault(options)\n}\n\nfunction decrypt (encrypted, keyStr) {\n const key = Buffer.from(keyStr.slice(-64), 'hex')\n let ciphertext = Buffer.from(encrypted, 'base64')\n\n const nonce = ciphertext.subarray(0, 12)\n const authTag = ciphertext.subarray(-16)\n ciphertext = ciphertext.subarray(12, -16)\n\n try {\n const aesgcm = crypto.createDecipheriv('aes-256-gcm', key, nonce)\n aesgcm.setAuthTag(authTag)\n return `${aesgcm.update(ciphertext)}${aesgcm.final()}`\n } catch (error) {\n const isRange = error instanceof RangeError\n const invalidKeyLength = error.message === 'Invalid key length'\n const decryptionFailed = error.message === 'Unsupported state or unable to authenticate data'\n\n if (isRange || invalidKeyLength) {\n const err = new Error('INVALID_DOTENV_KEY: It must be 64 characters long (or more)')\n err.code = 'INVALID_DOTENV_KEY'\n throw err\n } else if (decryptionFailed) {\n const err = new Error('DECRYPTION_FAILED: Please check your DOTENV_KEY')\n err.code = 'DECRYPTION_FAILED'\n throw err\n } else {\n throw error\n }\n }\n}\n\n// Populate process.env with parsed values\nfunction populate (processEnv, parsed, options = {}) {\n const debug = Boolean(options && options.debug)\n const override = Boolean(options && options.override)\n\n if (typeof parsed !== 'object') {\n const err = new Error('OBJECT_REQUIRED: Please check the processEnv argument being passed to populate')\n err.code = 'OBJECT_REQUIRED'\n throw err\n }\n\n // Set process.env\n for (const key of Object.keys(parsed)) {\n if (Object.prototype.hasOwnProperty.call(processEnv, key)) {\n if (override === true) {\n processEnv[key] = parsed[key]\n }\n\n if (debug) {\n if (override === true) {\n _debug(`\"${key}\" is already defined and WAS overwritten`)\n } else {\n _debug(`\"${key}\" is already defined and was NOT overwritten`)\n }\n }\n } else {\n processEnv[key] = parsed[key]\n }\n }\n}\n\nconst DotenvModule = {\n configDotenv,\n _configVault,\n _parseVault,\n config,\n decrypt,\n parse,\n populate\n}\n\nmodule.exports.configDotenv = DotenvModule.configDotenv\nmodule.exports._configVault = DotenvModule._configVault\nmodule.exports._parseVault = DotenvModule._parseVault\nmodule.exports.config = DotenvModule.config\nmodule.exports.decrypt = DotenvModule.decrypt\nmodule.exports.parse = DotenvModule.parse\nmodule.exports.populate = DotenvModule.populate\n\nmodule.exports = DotenvModule\n","// ../config.js accepts options via environment variables\nconst options = {}\n\nif (process.env.DOTENV_CONFIG_ENCODING != null) {\n options.encoding = process.env.DOTENV_CONFIG_ENCODING\n}\n\nif (process.env.DOTENV_CONFIG_PATH != null) {\n options.path = process.env.DOTENV_CONFIG_PATH\n}\n\nif (process.env.DOTENV_CONFIG_DEBUG != null) {\n options.debug = process.env.DOTENV_CONFIG_DEBUG\n}\n\nif (process.env.DOTENV_CONFIG_OVERRIDE != null) {\n options.override = process.env.DOTENV_CONFIG_OVERRIDE\n}\n\nif (process.env.DOTENV_CONFIG_DOTENV_KEY != null) {\n options.DOTENV_KEY = process.env.DOTENV_CONFIG_DOTENV_KEY\n}\n\nmodule.exports = options\n","const re = /^dotenv_config_(encoding|path|debug|override|DOTENV_KEY)=(.+)$/\n\nmodule.exports = function optionMatcher (args) {\n return args.reduce(function (acc, cur) {\n const matches = cur.match(re)\n if (matches) {\n acc[matches[1]] = matches[2]\n }\n return acc\n }, {})\n}\n","export * from \"./zdk\";\nexport * from \"./types\";\nexport * from \"./zappy-api\";\n","(function () {\n require('./lib/main').config(\n Object.assign(\n {},\n require('./lib/env-options'),\n require('./lib/cli-options')(process.argv)\n )\n )\n})()\n","import type { HttpMethod } from \"./types\";\nimport axios, { AxiosError } from \"axios\";\n\nexport class ZappyApi {\n private _rootUrl: string;\n private _token: string;\n\n constructor(rootUrl?: string, token?: string) {\n this._rootUrl = rootUrl || process.env?.ZAPPY_URL;\n this._token = token || process.env?.ZAPPY_TOKEN;\n }\n\n async makeRequest(\n method: HttpMethod,\n endpoint: string,\n data?: unknown,\n customHeaders?: Record<string, string>\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): Promise<any> {\n if (!this._rootUrl || !this._token) {\n throw new Error(\"Missing base url or API token\");\n }\n\n try {\n const url: string = this._rootUrl + endpoint;\n const options = {\n url,\n method,\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${this._token}`,\n ...customHeaders,\n },\n data,\n };\n const request = await axios(options);\n const response = await request.data;\n return response;\n } catch (error: unknown) {\n if (error instanceof AxiosError && \"error\" in error.response.data) {\n throw new Error(error?.response?.data?.error);\n }\n\n throw new Error(\"No request possible\");\n }\n }\n}\n","import { ZappyApi } from \"../zappy-api\";\nimport type { IConnection, IConnectionList, IError } from \"../types\";\n\nexport class Connection {\n constructor(protected api: ZappyApi) {}\n\n async list(): Promise<IConnectionList | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", \"/api/connections\");\n\n return response as IConnectionList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list connections\" };\n }\n }\n\n async get(id?: number): Promise<IConnection | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", \"/api/connections\");\n\n const connections = response?.connections as IConnection[];\n\n const connectionExists = connections.find(\n (connection: IConnection) => connection.id === id\n );\n\n if (!connectionExists || connectionExists?.status !== \"CONNECTED\") {\n const validConnection = connections?.find(\n (connection: IConnection) => connection?.status === \"CONNECTED\"\n );\n\n if (!validConnection) return { error: \"Connection not found\" };\n\n return validConnection;\n }\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to connection\" };\n }\n }\n}\n","import type {\n IContact,\n IContactList,\n IContactPostData,\n IError,\n IParamsList,\n} from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Contact {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<IContactList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/contacts?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IContactList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list contacts\" };\n }\n }\n\n async get(id: number): Promise<IContact | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/contacts/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IContact;\n } catch (error) {\n console.error(error);\n\n return { error: \"No contact details could be obtained\" };\n }\n }\n\n async update(id: number, data: IContactPostData): Promise<IContact | IError> {\n try {\n const response = await this.api.makeRequest(\n \"PUT\",\n `/api/contacts/${id}`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IContact;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to update contact\" };\n }\n }\n}\n","import type {\n IError,\n IMessage,\n IMessageList,\n IParamsMessageList,\n ISendMediaMessage,\n ISendMessage,\n MediaType,\n} from \"../types\";\n\nimport type { ZappyApi } from \"../zappy-api\";\nimport FormData from \"form-data\";\n\nexport class Message {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsMessageList): Promise<IMessageList | IError> {\n try {\n const {\n page = 1,\n pageSize = 20,\n ticketId = \"\",\n contactId = \"\",\n dateFrom = \"\",\n dateTo = \"\",\n } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/messages?page=${page}&pageSize=${pageSize}&ticketId=${ticketId}&contactId=${contactId}&dateFrom=${dateFrom}&dateToo=${dateTo}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IMessageList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list message\" };\n }\n }\n\n async get(id: string): Promise<IMessage | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/messages/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IMessage;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to message\" };\n }\n }\n\n async send(to: string, data: ISendMessage): Promise<Message | IError>;\n\n async send(\n to: string,\n data: ISendMediaMessage,\n type: Exclude<MediaType, \"text\">\n ): Promise<Message | IError>;\n\n async send(\n to: string,\n data: ISendMessage | ISendMediaMessage,\n /**\n * @default \"text\"\n */\n type?: MediaType\n ): Promise<Message | IError> {\n try {\n if (!type || type === \"text\") {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/send/${to}`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response;\n } else {\n const { caption, connectionFrom, media } = data as ISendMediaMessage;\n const form = new FormData();\n form.append(\"media\", media);\n form.append(\"caption\", caption || \"\");\n form.append(\"connectionFrom\", connectionFrom);\n\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/send/${type}/${to}`,\n form,\n {\n ...form.getHeaders(),\n }\n );\n\n if (response?.error) return { error: response?.error };\n\n return response;\n }\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot send message\" };\n }\n }\n}\n","import type { IError, IParamsList, IQueue, IQueueList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Queue {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<IQueueList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/queues?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IQueueList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list queues\" };\n }\n }\n\n async get(id: number): Promise<IQueue | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/queues/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IQueue;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to queue\" };\n }\n }\n}\n","import type { IError, IParamsList, ITag, ITagList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Tag {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<ITagList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/tags?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITagList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list tags\" };\n }\n }\n\n async get(id: number): Promise<ITag | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/tags/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as ITag;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to tag\" };\n }\n }\n}\n","import type {\n IError,\n IParamsList,\n ITicket,\n ITicketList,\n ITicketResolveForm,\n ITicketTransferForm,\n ITicketUpdateForm,\n} from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class Ticket {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<ITicketList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/tickets?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicketList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list tickets\" };\n }\n }\n\n async get(id: number): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/tickets/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to ticket\" };\n }\n }\n\n async transfer(\n id: number,\n data: ITicketTransferForm\n ): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/tickets/${id}/transfer`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot transfer ticket\" };\n }\n }\n\n async resolve(\n id: number,\n data: ITicketResolveForm\n ): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"POST\",\n `/api/tickets/${id}/resolve`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot resolve ticket\" };\n }\n }\n\n async update(id: number, data: ITicketUpdateForm): Promise<ITicket | IError> {\n try {\n const response = await this.api.makeRequest(\n \"PUT\",\n `/api/tickets/${id}`,\n data\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as ITicket;\n } catch (error) {\n console.error(error);\n\n return { error: \"Cannot update ticket\" };\n }\n }\n}\n","import type { IError, IParamsList, IUser, IUserList } from \"../types\";\nimport type { ZappyApi } from \"../zappy-api\";\n\nexport class User {\n constructor(protected api: ZappyApi) {}\n\n async list(params?: IParamsList): Promise<IUserList | IError> {\n try {\n const { page = 1, pageSize = 20 } = params || {};\n\n const response = await this.api.makeRequest(\n \"GET\",\n `/api/users?page=${page}&pageSize=${pageSize}`\n );\n\n if (response?.error) return { error: response?.error };\n\n return response as IUserList;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to list users\" };\n }\n }\n\n async get(id: number): Promise<IUser | IError> {\n try {\n const response = await this.api.makeRequest(\"GET\", `/api/users/${id}`);\n\n if (response?.error) return { error: response?.error };\n\n return response as IUser;\n } catch (error) {\n console.error(error);\n\n return { error: \"Unable to user\" };\n }\n }\n}\n","import \"dotenv/config\";\n\nimport { ZappyApi } from \"./zappy-api\";\nimport { Connection } from \"./lib\";\nimport { Contact } from \"./lib/contact\";\nimport { Message } from \"./lib/message\";\nimport { Queue } from \"./lib/queue\";\nimport { Tag } from \"./lib/tag\";\nimport { User } from \"./lib/user\";\nimport { Ticket } from \"./lib/ticket\";\n\nexport class Zdk extends ZappyApi {\n readonly tickets = new Ticket(this);\n\n readonly connections = new Connection(this);\n\n readonly contacts = new Contact(this);\n\n readonly messages = new Message(this);\n\n readonly queues = new Queue(this);\n\n readonly tags = new Tag(this);\n\n readonly users = new User(this);\n}\n\nexport default Zdk;\n"],"mappings":"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","names":["require_package","__commonJSMin","exports","module","require_main","__commonJSMin","exports","module","fs","path","os","crypto","packageJson","version","LINE","parse","src","obj","lines","match","key","value","maybeQuote","_parseVault","options","vaultPath","_vaultPath","result","DotenvModule","err","keys","_dotenvKey","length","decrypted","i","attrs","_instructions","error","_log","message","_warn","_debug","dotenvKey","uri","environment","environmentKey","ciphertext","possibleVaultPath","filepath","_resolveHome","envPath","_configVault","parsed","processEnv","configDotenv","dotenvPath","encoding","debug","optionPaths","lastError","parsedAll","e","config","decrypt","encrypted","keyStr","nonce","authTag","aesgcm","isRange","invalidKeyLength","decryptionFailed","populate","override","require_env_options","__commonJSMin","exports","module","options","require_cli_options","__commonJSMin","exports","module","re","args","acc","cur","matches","src_exports","__export","ZappyApi","Zdk","__toCommonJS","import_axios","ZappyApi","rootUrl","token","method","endpoint","data","customHeaders","options","axios","error","Connection","api","error","id","connections","connectionExists","connection","validConnection","Contact","api","params","page","pageSize","response","error","id","data","import_form_data","Message","api","params","page","pageSize","ticketId","contactId","dateFrom","dateTo","response","error","id","to","data","type","caption","connectionFrom","media","form","FormData","Queue","api","params","page","pageSize","response","error","id","Tag","api","params","page","pageSize","response","error","id","Ticket","api","params","page","pageSize","response","error","id","data","User","api","params","page","pageSize","response","error","id","Zdk","ZappyApi","Ticket","Connection","Contact","Message","Queue","Tag","User"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "zdk",
3
- "version": "0.4.2",
3
+ "version": "0.6.0",
4
4
  "description": "Kit de desenvolvimento Zappy",
5
5
  "main": "./dist/index.js",
6
6
  "module": "./dist/esm/index.js",
@@ -50,6 +50,7 @@
50
50
  "typescript": "^5.2.*"
51
51
  },
52
52
  "dependencies": {
53
- "axios": "^1.6.2"
53
+ "axios": "^1.7.9",
54
+ "form-data": "^4.0.1"
54
55
  }
55
- }
56
+ }