@stackone/core 1.14.3 → 1.15.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/dist/index.es.mjs CHANGED
@@ -1 +1 @@
1
- import{HttpClient as e}from"@stackone/transport";import t from"jsonpath";import*as r from"date-fns";const s=(e,t="")=>{if("object"===e.type&&e.properties){const r=""===t||t.endsWith(".")?t:`${t}.`;return Object.entries(e.properties).flatMap((([e,t])=>s(t,`${r}${e}`)))}return"array"===e.type&&e.items?s(e.items,`${t}[].`):[{name:t.endsWith(".")?t.slice(0,-1):t,type:e.type,description:e.description}]};class n{constructor({version:t="1",key:r,name:n,services:o={},httpOperations:i={},auth:a,proxy:u,httpClient:c=new e}){this.listOperations=()=>Object.keys(this.httpOperations||{}),this.getOperation=e=>{const t=this.httpOperations?.[e];if(!t)throw new Error(`Operation ${e} not found`);return t},this.getOperationResponseFieldsMetadata=e=>{const t=this.getOperation(e).responses;if(!t)return null;const r=(e=>{const t=Object.entries(e).find((([e])=>e.startsWith("2")));return t?t[1]:null})(t);return r?.content["application/json"]?.schema?s(r.content["application/json"]?.schema):null},this.callOperation=async({operationId:e,params:t,credentials:r})=>{const s=this.httpOperations?.[e];if(!s)throw new Error(`Operation ${e} not found`);const n=(({params:e,httpOperation:t})=>{const{url:r,method:s}=t;let n=r;const o=[],i=[],a={};let u;Object.entries(e||{}).forEach((([e,r])=>{const s=t.parameters?.[e];if(s)switch(s.in){case"path":n=n.replace(`{${e}}`,r).replace(`:${e}`,r);break;case"query":o.push(`${e}=${r}`);break;case"header":a[e]=r;break;case"cookie":i.push(`${e}=${r}; `);break;case"body":u=r}}));const c=o.length>0?`?${o.join("&")}`:"";return i.length>0&&(a.cookie=i.join("")),{url:`${n}${c}`,method:s,headers:Object.keys(a).length>0?a:void 0,body:u||void 0}})({params:t,httpOperation:s}),{method:o,url:i,headers:a,body:u}=n,{apiKey:c}=r;return{connector:this,input:{operationId:e,params:t},response:await this.httpClient.request({method:o,url:i,headers:{...a,authorization:c},payload:u}),credentials:r}},this.version=t,this.key=r,this.name=n,this.services=o,this.httpOperations=i,this.auth=a,this.proxy=u,this.httpClient=c}}const o="request_body";var i;!function(e){e.MAP="map",e.TYPECAST="typecast",e.MAP_FIELDS="map_fields"}(i||(i={}));const a=async({blockSteps:e,block:t})=>e.reduce((async(e,t)=>t({block:await e})),Promise.resolve(t)),u=async({block:e})=>{const t=e?.fieldConfigs,r=[];if(!t||"disabled"===e?.debug?.custom_mappings)return e;let s;const n=e.providerData,o=e.context.childResource??e.context.subResource??e.context.resource;if(Array.isArray(e.result))s=e.result.map((e=>{const s=n?.[o]?.items;if(!s)return e;const i=c(e.id,e.remote_id,n),a=l(e,t,i);return r.push(...a.errors||[]),a.record}));else{const o=l(e.result,t,n);s=o.record,r.push(...o.errors||[])}return{...e,result:s,customMappingErrors:Object.keys(r).length>0?r:void 0}},c=(e,t,r)=>r?Object.keys(r).reduce(((s,n)=>{const o=r[n];if(!o.items)return s;const i=o.items.find((r=>r.id===e||r.id===t));return i?{...s,[n]:i}:s}),{}):{},l=(e,t,r)=>{if(!e||!r)return{record:e};const s={unified:{...e},..."object"==typeof r?r:{}},n={},o=[],i={...e};for(const r of t){const{error:t,value:a}=d(s,e.id,r);t?o.push(t):r.isUnified?i[r.targetFieldKey]=a:n[r.targetFieldKey]=a}return{record:{...i,unified_custom_fields:Object.keys(n).length>0?n:void 0},errors:o.length>0?o:void 0}},d=(e,r,s)=>{const{expression:n,targetFieldKey:o}=s;if(!n)return{error:{message:"Expression is empty",id:r,targetField:o}};try{t.parse(n)}catch(e){return{error:{message:"Invalid JSON path expression",id:r,targetField:o}}}const i=n&&t.query(e,n)[0];return i?{value:i}:{error:{message:"Expression returned no value",id:r,targetField:o}}},p=e=>null!=e,y=e=>null==e||""===e,f=e=>"string"==typeof e,h=e=>e instanceof Date,m="yyyy-MM-dd",g=["yyyy-MM-dd","yyyy/MM/dd","dd/MM/yyyy","dd-MM-yyyy","yyyy-dd-MM","yyyy/dd/MM","MM/dd/yyyy","MM-dd-yyyy"],b=({value:e})=>{const t=r.parseISO(e);if(r.isValid(t))return t;const s=new Date;for(const t of g){const n=r.parse(e,t,s);if(r.isValid(n))return n.setUTCHours(0,0,0,0),n}return null},v=({value:e,format:t=m})=>{const s=(({value:e,format:t=m})=>{if(h(e))return e;if(!f(e))return null;try{const s=r.parse(e,t,new Date);return r.isValid(s)?s:b({value:e})}catch(e){return null}})({value:e,format:t});return s?s.toISOString():null};var O;!function(e){e.String="string",e.Number="number",e.Boolean="boolean",e.DateTimeString="datetime_string"}(O||(O={}));const M=({value:e,type:t,format:r})=>{if(y(e))return null;switch(t){case O.String:return(({value:e})=>f(e)?e:h(e)?e.toISOString():(e=>"object"==typeof e&&null!==e)(e)?JSON.stringify(e):String(e))({value:e});case O.Number:return(({value:e})=>{if((e=>"number"==typeof e)(e))return e;if(h(e))return null;const t=Number(e);return isNaN(t)?null:t})({value:e});case O.Boolean:return(({value:e})=>(e=>"boolean"==typeof e)(e)?e:"false"!==e&&"0"!==e&&0!==e&&Boolean(e))({value:e});case O.DateTimeString:return v({value:e,format:r});default:return e}},k=async({block:e})=>{const t=e?.fieldConfigs;if(!t||"disabled"===e?.debug?.custom_mappings)return e;let r;return r=Array.isArray(e.result)?e.result.map((e=>j(e,t))):j(e.result,t),{...e,result:r}},j=(e,t)=>{const r={...e};return t.forEach((t=>{const{targetFieldKey:s,type:n}=t;(e=>Object.values(O).includes(e))(n)&&(t.isUnified&&p(r[s])?r[s]=M({value:e[s],type:n}):r.unified_custom_fields&&p(r.unified_custom_fields?.[s])&&(r.unified_custom_fields[s]=M({value:e.unified_custom_fields?.[s],type:n})))})),{...r}},_=async({block:e})=>{const t=e?.fieldConfigs,r=[],s=e.steps;if(!t||"disabled"===e?.debug?.custom_mappings||!s)return e;let n;if(Array.isArray(e.result)){const o=e.result.length;n=e.result.map(((e,n)=>{const i=S(s,o,n),a=A(e,t,i);return r.push(...a.errors||[]),a.record}))}else{const o=A(e.result,t,s);n=o.record,r.push(...o.errors||[])}return{...e,result:n,customMappingErrors:Object.keys(r).length>0?r:void 0}},S=(e,t,r)=>Object.entries(e).reduce(((e,[s,n])=>{const o=n.output.data;return Array.isArray(o)&&o.length===t?e[s]={output:{data:o[r]}}:e[s]=n,e}),{}),A=(e,t,r)=>{if(!e||!r)return{record:e};const s={unified:{...e},..."object"==typeof r?r:{}},n={},o=[],i={...e};for(const r of t){const{error:t,value:a}=E(s,e.id,r);t?o.push(t):r.isUnified?i[r.targetFieldKey]=a:n[r.targetFieldKey]=a}return{record:{...i,unified_custom_fields:Object.keys(n).length>0?n:void 0},errors:o.length>0?o:void 0}},E=(e,r,s)=>{const{expression:n,targetFieldKey:o}=s;if(!n)return{error:{message:"Expression is empty",id:r,targetField:o}};try{t.parse(n)}catch(e){return{error:{message:"Invalid JSON path expression",id:r,targetField:o}}}const i=n&&t.query(e,n)[0];return y(i)?{error:{message:"Expression returned no value",id:r,targetField:o}}:{value:i}},F={build({type:e}){switch(e){case i.MAP:return u;case i.TYPECAST:return k;case i.MAP_FIELDS:return _;default:throw new Error(`Unknown block step: ${e}`)}}},$=({fieldConfigs:e})=>{const t=[];return e&&t.push(F.build({type:i.MAP}),F.build({type:i.TYPECAST})),t};export{n as BaseConnector,i as BlockStepType,F as BlockStepsFactory,o as REQUEST_BODY_PARAM,a as blockPipe,$ as getBlockPipeStepsFromConfigs};
1
+ import{HttpClient as e}from"@stackone/transport";import t from"jsonpath";import*as r from"date-fns";const s=(e,t="")=>{if("object"===e.type&&e.properties){const r=""===t||t.endsWith(".")?t:`${t}.`;return Object.entries(e.properties).flatMap((([e,t])=>s(t,`${r}${e}`)))}return"array"===e.type&&e.items?s(e.items,`${t}[].`):[{name:t.endsWith(".")?t.slice(0,-1):t,type:e.type,description:e.description}]};class n{constructor({version:t="1",key:r,name:n,services:i={},httpOperations:o={},auth:a,proxy:u,httpClient:c=new e}){this.listOperations=()=>Object.keys(this.httpOperations||{}),this.getOperation=e=>{const t=this.httpOperations?.[e];if(!t)throw new Error(`Operation ${e} not found`);return t},this.getOperationResponseFieldsMetadata=e=>{const t=this.getOperation(e).responses;if(!t)return null;const r=(e=>{const t=Object.entries(e).find((([e])=>e.startsWith("2")));return t?t[1]:null})(t);return r?.content["application/json"]?.schema?s(r.content["application/json"]?.schema):null},this.getOperationRequestFieldsMetadata=e=>this.getOperation(e).parameters,this.callOperation=async({operationId:e,params:t,credentials:r})=>{const s=this.httpOperations?.[e];if(!s)throw new Error(`Operation ${e} not found`);const n=(({params:e,httpOperation:t})=>{const{url:r,method:s}=t;let n=r;const i=[],o=[],a={};let u;Object.entries(e||{}).forEach((([e,r])=>{const s=t.parameters?.[e];if(s)switch(s.in){case"path":n=n.replace(`{${e}}`,r).replace(`:${e}`,r);break;case"query":i.push(`${e}=${r}`);break;case"header":a[e]=r;break;case"cookie":o.push(`${e}=${r}; `);break;case"body":u=r}}));const c=i.length>0?`?${i.join("&")}`:"";return o.length>0&&(a.cookie=o.join("")),{url:`${n}${c}`,method:s,headers:Object.keys(a).length>0?a:void 0,body:u||void 0}})({params:t,httpOperation:s}),{method:i,url:o,headers:a,body:u}=n,{apiKey:c}=r;return{connector:this,input:{operationId:e,params:t},response:await this.httpClient.request({method:i,url:o,headers:{...a,authorization:c},payload:u}),credentials:r}},this.version=t,this.key=r,this.name=n,this.services=i,this.httpOperations=o,this.auth=a,this.proxy=u,this.httpClient=c}}const i="request_body";var o;!function(e){e.MAP="map",e.TYPECAST="typecast",e.MAP_FIELDS="map_fields"}(o||(o={}));const a=async({blockSteps:e,block:t})=>e.reduce((async(e,t)=>t({block:await e})),Promise.resolve(t)),u=async({block:e})=>{const t=e?.fieldConfigs,r=[];if(!t||"disabled"===e?.debug?.custom_mappings)return e;let s;const n=e.providerData,i=e.context.childResource??e.context.subResource??e.context.resource;if(Array.isArray(e.result))s=e.result.map((e=>{const s=n?.[i]?.items;if(!s)return e;const o=c(e.id,e.remote_id,n),a=l(e,t,o);return r.push(...a.errors||[]),a.record}));else{const i=l(e.result,t,n);s=i.record,r.push(...i.errors||[])}return{...e,result:s,customMappingErrors:Object.keys(r).length>0?r:void 0}},c=(e,t,r)=>r?Object.keys(r).reduce(((s,n)=>{const i=r[n];if(!i.items)return s;const o=i.items.find((r=>r.id===e||r.id===t));return o?{...s,[n]:o}:s}),{}):{},l=(e,t,r)=>{if(!e||!r)return{record:e};const s={unified:{...e},..."object"==typeof r?r:{}},n={},i=[],o={...e};for(const r of t){const{error:t,value:a}=d(s,e.id,r);t?i.push(t):r.isUnified?o[r.targetFieldKey]=a:n[r.targetFieldKey]=a}return{record:{...o,unified_custom_fields:Object.keys(n).length>0?n:void 0},errors:i.length>0?i:void 0}},d=(e,r,s)=>{const{expression:n,targetFieldKey:i}=s;if(!n)return{error:{message:"Expression is empty",id:r,targetField:i}};try{t.parse(n)}catch(e){return{error:{message:"Invalid JSON path expression",id:r,targetField:i}}}const o=n&&t.query(e,n)[0];return o?{value:o}:{error:{message:"Expression returned no value",id:r,targetField:i}}},p=e=>null!=e,y=e=>"string"==typeof e,f=e=>e instanceof Date,h="yyyy-MM-dd",m=["yyyy-MM-dd","yyyy/MM/dd","dd/MM/yyyy","dd-MM-yyyy","yyyy-dd-MM","yyyy/dd/MM","MM/dd/yyyy","MM-dd-yyyy"],g=({value:e})=>{const t=r.parseISO(e);if(r.isValid(t))return t;const s=new Date;for(const t of m){const n=r.parse(e,t,s);if(r.isValid(n))return n.setUTCHours(0,0,0,0),n}return null},b=({value:e,format:t=h})=>{const s=(({value:e,format:t=h})=>{if(f(e))return e;if(!y(e))return null;try{const s=r.parse(e,t,new Date);return r.isValid(s)?s:g({value:e})}catch(e){return null}})({value:e,format:t});return s?s.toISOString():null};var v;!function(e){e.String="string",e.Number="number",e.Boolean="boolean",e.DateTimeString="datetime_string"}(v||(v={}));const O=({value:e,type:t,format:r})=>{if((e=>null==e||""===e)(e))return null;switch(t){case v.String:return(({value:e})=>y(e)?e:f(e)?e.toISOString():(e=>"object"==typeof e&&null!==e)(e)?JSON.stringify(e):String(e))({value:e});case v.Number:return(({value:e})=>{if((e=>"number"==typeof e)(e))return e;if(f(e))return null;const t=Number(e);return isNaN(t)?null:t})({value:e});case v.Boolean:return(({value:e})=>(e=>"boolean"==typeof e)(e)?e:"false"!==e&&"0"!==e&&0!==e&&Boolean(e))({value:e});case v.DateTimeString:return b({value:e,format:r});default:return e}},M=async({block:e})=>{const t=e?.fieldConfigs;if(!t||"disabled"===e?.debug?.custom_mappings)return e;let r;return r=Array.isArray(e.result)?e.result.map((e=>k(e,t))):k(e.result,t),{...e,result:r}},k=(e,t)=>{const r={...e};return t.forEach((t=>{const{targetFieldKey:s,type:n}=t;(e=>Object.values(v).includes(e))(n)&&(t.isUnified&&p(r[s])?r[s]=O({value:e[s],type:n}):r.unified_custom_fields&&p(r.unified_custom_fields?.[s])&&(r.unified_custom_fields[s]=O({value:e.unified_custom_fields?.[s],type:n})))})),{...r}},j=async({block:e})=>{const t=e?.fieldConfigs,r=[],s=e.steps;if(!t||"disabled"===e?.debug?.custom_mappings||!s)return e;let n;if(Array.isArray(e.result)){const i=e.result.length;n=e.result.map(((e,n)=>{const o=_(s,i,n),a=S(e,t,o);return r.push(...a.errors||[]),a.record}))}else{const i=S(e.result,t,s);n=i.record,r.push(...i.errors||[])}return{...e,result:n,customMappingErrors:Object.keys(r).length>0?r:void 0}},_=(e,t,r)=>Object.entries(e).reduce(((e,[s,n])=>{const i=n.output.data;return Array.isArray(i)&&i.length===t?e[s]={output:{data:i[r]}}:e[s]=n,e}),{}),S=(e,t,r)=>{if(!e||!r)return{record:e};const s={unified:{...e},..."object"==typeof r?r:{}},n={},i=[],o={...e};for(const r of t){const{error:t,value:a}=F(s,e.id,r);t?i.push(t):r.isUnified?o[r.targetFieldKey]=a:n[r.targetFieldKey]=a}return{record:{...o,unified_custom_fields:Object.keys(n).length>0?n:void 0},errors:i.length>0?i:void 0}},F=(e,r,s)=>{const{expression:n,targetFieldKey:i}=s;if(!n)return{error:{message:"Expression is empty",id:r,targetField:i}};try{t.parse(n)}catch(e){return{error:{message:"Invalid JSON path expression",id:r,targetField:i}}}const o=n&&t.query(e,n)[0];return void 0===o?{error:{message:"Expression returned no value",id:r,targetField:i}}:{value:o}},A={build({type:e}){switch(e){case o.MAP:return u;case o.TYPECAST:return M;case o.MAP_FIELDS:return j;default:throw new Error(`Unknown block step: ${e}`)}}},E=({fieldConfigs:e})=>{const t=[];return e&&t.push(A.build({type:o.MAP}),A.build({type:o.TYPECAST})),t};export{n as BaseConnector,o as BlockStepType,A as BlockStepsFactory,i as REQUEST_BODY_PARAM,a as blockPipe,E as getBlockPipeStepsFromConfigs};
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- "use strict";var e=require("@stackone/transport"),t=require("jsonpath");function r(e){var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var s=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,s.get?s:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var s=r(require("date-fns"));const n=(e,t="")=>{if("object"===e.type&&e.properties){const r=""===t||t.endsWith(".")?t:`${t}.`;return Object.entries(e.properties).flatMap((([e,t])=>n(t,`${r}${e}`)))}return"array"===e.type&&e.items?n(e.items,`${t}[].`):[{name:t.endsWith(".")?t.slice(0,-1):t,type:e.type,description:e.description}]};var o;exports.BlockStepType=void 0,(o=exports.BlockStepType||(exports.BlockStepType={})).MAP="map",o.TYPECAST="typecast",o.MAP_FIELDS="map_fields";const i=async({block:e})=>{const t=e?.fieldConfigs,r=[];if(!t||"disabled"===e?.debug?.custom_mappings)return e;let s;const n=e.providerData,o=e.context.childResource??e.context.subResource??e.context.resource;if(Array.isArray(e.result))s=e.result.map((e=>{const s=n?.[o]?.items;if(!s)return e;const i=a(e.id,e.remote_id,n),c=u(e,t,i);return r.push(...c.errors||[]),c.record}));else{const o=u(e.result,t,n);s=o.record,r.push(...o.errors||[])}return{...e,result:s,customMappingErrors:Object.keys(r).length>0?r:void 0}},a=(e,t,r)=>r?Object.keys(r).reduce(((s,n)=>{const o=r[n];if(!o.items)return s;const i=o.items.find((r=>r.id===e||r.id===t));return i?{...s,[n]:i}:s}),{}):{},u=(e,t,r)=>{if(!e||!r)return{record:e};const s={unified:{...e},..."object"==typeof r?r:{}},n={},o=[],i={...e};for(const r of t){const{error:t,value:a}=c(s,e.id,r);t?o.push(t):r.isUnified?i[r.targetFieldKey]=a:n[r.targetFieldKey]=a}return{record:{...i,unified_custom_fields:Object.keys(n).length>0?n:void 0},errors:o.length>0?o:void 0}},c=(e,r,s)=>{const{expression:n,targetFieldKey:o}=s;if(!n)return{error:{message:"Expression is empty",id:r,targetField:o}};try{t.parse(n)}catch(e){return{error:{message:"Invalid JSON path expression",id:r,targetField:o}}}const i=n&&t.query(e,n)[0];return i?{value:i}:{error:{message:"Expression returned no value",id:r,targetField:o}}},l=e=>null!=e,p=e=>null==e||""===e,d=e=>"string"==typeof e,y=e=>e instanceof Date,f="yyyy-MM-dd",h=["yyyy-MM-dd","yyyy/MM/dd","dd/MM/yyyy","dd-MM-yyyy","yyyy-dd-MM","yyyy/dd/MM","MM/dd/yyyy","MM-dd-yyyy"],m=({value:e})=>{const t=s.parseISO(e);if(s.isValid(t))return t;const r=new Date;for(const t of h){const n=s.parse(e,t,r);if(s.isValid(n))return n.setUTCHours(0,0,0,0),n}return null},g=({value:e,format:t=f})=>{const r=(({value:e,format:t=f})=>{if(y(e))return e;if(!d(e))return null;try{const r=s.parse(e,t,new Date);return s.isValid(r)?r:m({value:e})}catch(e){return null}})({value:e,format:t});return r?r.toISOString():null};var b;!function(e){e.String="string",e.Number="number",e.Boolean="boolean",e.DateTimeString="datetime_string"}(b||(b={}));const v=({value:e,type:t,format:r})=>{if(p(e))return null;switch(t){case b.String:return(({value:e})=>d(e)?e:y(e)?e.toISOString():(e=>"object"==typeof e&&null!==e)(e)?JSON.stringify(e):String(e))({value:e});case b.Number:return(({value:e})=>{if((e=>"number"==typeof e)(e))return e;if(y(e))return null;const t=Number(e);return isNaN(t)?null:t})({value:e});case b.Boolean:return(({value:e})=>(e=>"boolean"==typeof e)(e)?e:"false"!==e&&"0"!==e&&0!==e&&Boolean(e))({value:e});case b.DateTimeString:return g({value:e,format:r});default:return e}},O=async({block:e})=>{const t=e?.fieldConfigs;if(!t||"disabled"===e?.debug?.custom_mappings)return e;let r;return r=Array.isArray(e.result)?e.result.map((e=>k(e,t))):k(e.result,t),{...e,result:r}},k=(e,t)=>{const r={...e};return t.forEach((t=>{const{targetFieldKey:s,type:n}=t;(e=>Object.values(b).includes(e))(n)&&(t.isUnified&&l(r[s])?r[s]=v({value:e[s],type:n}):r.unified_custom_fields&&l(r.unified_custom_fields?.[s])&&(r.unified_custom_fields[s]=v({value:e.unified_custom_fields?.[s],type:n})))})),{...r}},S=async({block:e})=>{const t=e?.fieldConfigs,r=[],s=e.steps;if(!t||"disabled"===e?.debug?.custom_mappings||!s)return e;let n;if(Array.isArray(e.result)){const o=e.result.length;n=e.result.map(((e,n)=>{const i=M(s,o,n),a=j(e,t,i);return r.push(...a.errors||[]),a.record}))}else{const o=j(e.result,t,s);n=o.record,r.push(...o.errors||[])}return{...e,result:n,customMappingErrors:Object.keys(r).length>0?r:void 0}},M=(e,t,r)=>Object.entries(e).reduce(((e,[s,n])=>{const o=n.output.data;return Array.isArray(o)&&o.length===t?e[s]={output:{data:o[r]}}:e[s]=n,e}),{}),j=(e,t,r)=>{if(!e||!r)return{record:e};const s={unified:{...e},..."object"==typeof r?r:{}},n={},o=[],i={...e};for(const r of t){const{error:t,value:a}=x(s,e.id,r);t?o.push(t):r.isUnified?i[r.targetFieldKey]=a:n[r.targetFieldKey]=a}return{record:{...i,unified_custom_fields:Object.keys(n).length>0?n:void 0},errors:o.length>0?o:void 0}},x=(e,r,s)=>{const{expression:n,targetFieldKey:o}=s;if(!n)return{error:{message:"Expression is empty",id:r,targetField:o}};try{t.parse(n)}catch(e){return{error:{message:"Invalid JSON path expression",id:r,targetField:o}}}const i=n&&t.query(e,n)[0];return p(i)?{error:{message:"Expression returned no value",id:r,targetField:o}}:{value:i}},_={build({type:e}){switch(e){case exports.BlockStepType.MAP:return i;case exports.BlockStepType.TYPECAST:return O;case exports.BlockStepType.MAP_FIELDS:return S;default:throw new Error(`Unknown block step: ${e}`)}}};exports.BaseConnector=class{constructor({version:t="1",key:r,name:s,services:o={},httpOperations:i={},auth:a,proxy:u,httpClient:c=new e.HttpClient}){this.listOperations=()=>Object.keys(this.httpOperations||{}),this.getOperation=e=>{const t=this.httpOperations?.[e];if(!t)throw new Error(`Operation ${e} not found`);return t},this.getOperationResponseFieldsMetadata=e=>{const t=this.getOperation(e).responses;if(!t)return null;const r=(e=>{const t=Object.entries(e).find((([e])=>e.startsWith("2")));return t?t[1]:null})(t);return r?.content["application/json"]?.schema?n(r.content["application/json"]?.schema):null},this.callOperation=async({operationId:e,params:t,credentials:r})=>{const s=this.httpOperations?.[e];if(!s)throw new Error(`Operation ${e} not found`);const n=(({params:e,httpOperation:t})=>{const{url:r,method:s}=t;let n=r;const o=[],i=[],a={};let u;Object.entries(e||{}).forEach((([e,r])=>{const s=t.parameters?.[e];if(s)switch(s.in){case"path":n=n.replace(`{${e}}`,r).replace(`:${e}`,r);break;case"query":o.push(`${e}=${r}`);break;case"header":a[e]=r;break;case"cookie":i.push(`${e}=${r}; `);break;case"body":u=r}}));const c=o.length>0?`?${o.join("&")}`:"";return i.length>0&&(a.cookie=i.join("")),{url:`${n}${c}`,method:s,headers:Object.keys(a).length>0?a:void 0,body:u||void 0}})({params:t,httpOperation:s}),{method:o,url:i,headers:a,body:u}=n,{apiKey:c}=r;return{connector:this,input:{operationId:e,params:t},response:await this.httpClient.request({method:o,url:i,headers:{...a,authorization:c},payload:u}),credentials:r}},this.version=t,this.key=r,this.name=s,this.services=o,this.httpOperations=i,this.auth=a,this.proxy=u,this.httpClient=c}},exports.BlockStepsFactory=_,exports.REQUEST_BODY_PARAM="request_body",exports.blockPipe=async({blockSteps:e,block:t})=>e.reduce((async(e,t)=>t({block:await e})),Promise.resolve(t)),exports.getBlockPipeStepsFromConfigs=({fieldConfigs:e})=>{const t=[];return e&&t.push(_.build({type:exports.BlockStepType.MAP}),_.build({type:exports.BlockStepType.TYPECAST})),t};
1
+ "use strict";var e=require("@stackone/transport"),t=require("jsonpath");function r(e){var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var s=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,s.get?s:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var s=r(require("date-fns"));const n=(e,t="")=>{if("object"===e.type&&e.properties){const r=""===t||t.endsWith(".")?t:`${t}.`;return Object.entries(e.properties).flatMap((([e,t])=>n(t,`${r}${e}`)))}return"array"===e.type&&e.items?n(e.items,`${t}[].`):[{name:t.endsWith(".")?t.slice(0,-1):t,type:e.type,description:e.description}]};var o;exports.BlockStepType=void 0,(o=exports.BlockStepType||(exports.BlockStepType={})).MAP="map",o.TYPECAST="typecast",o.MAP_FIELDS="map_fields";const i=async({block:e})=>{const t=e?.fieldConfigs,r=[];if(!t||"disabled"===e?.debug?.custom_mappings)return e;let s;const n=e.providerData,o=e.context.childResource??e.context.subResource??e.context.resource;if(Array.isArray(e.result))s=e.result.map((e=>{const s=n?.[o]?.items;if(!s)return e;const i=a(e.id,e.remote_id,n),c=u(e,t,i);return r.push(...c.errors||[]),c.record}));else{const o=u(e.result,t,n);s=o.record,r.push(...o.errors||[])}return{...e,result:s,customMappingErrors:Object.keys(r).length>0?r:void 0}},a=(e,t,r)=>r?Object.keys(r).reduce(((s,n)=>{const o=r[n];if(!o.items)return s;const i=o.items.find((r=>r.id===e||r.id===t));return i?{...s,[n]:i}:s}),{}):{},u=(e,t,r)=>{if(!e||!r)return{record:e};const s={unified:{...e},..."object"==typeof r?r:{}},n={},o=[],i={...e};for(const r of t){const{error:t,value:a}=c(s,e.id,r);t?o.push(t):r.isUnified?i[r.targetFieldKey]=a:n[r.targetFieldKey]=a}return{record:{...i,unified_custom_fields:Object.keys(n).length>0?n:void 0},errors:o.length>0?o:void 0}},c=(e,r,s)=>{const{expression:n,targetFieldKey:o}=s;if(!n)return{error:{message:"Expression is empty",id:r,targetField:o}};try{t.parse(n)}catch(e){return{error:{message:"Invalid JSON path expression",id:r,targetField:o}}}const i=n&&t.query(e,n)[0];return i?{value:i}:{error:{message:"Expression returned no value",id:r,targetField:o}}},l=e=>null!=e,p=e=>"string"==typeof e,d=e=>e instanceof Date,y="yyyy-MM-dd",f=["yyyy-MM-dd","yyyy/MM/dd","dd/MM/yyyy","dd-MM-yyyy","yyyy-dd-MM","yyyy/dd/MM","MM/dd/yyyy","MM-dd-yyyy"],h=({value:e})=>{const t=s.parseISO(e);if(s.isValid(t))return t;const r=new Date;for(const t of f){const n=s.parse(e,t,r);if(s.isValid(n))return n.setUTCHours(0,0,0,0),n}return null},m=({value:e,format:t=y})=>{const r=(({value:e,format:t=y})=>{if(d(e))return e;if(!p(e))return null;try{const r=s.parse(e,t,new Date);return s.isValid(r)?r:h({value:e})}catch(e){return null}})({value:e,format:t});return r?r.toISOString():null};var g;!function(e){e.String="string",e.Number="number",e.Boolean="boolean",e.DateTimeString="datetime_string"}(g||(g={}));const b=({value:e,type:t,format:r})=>{if((e=>null==e||""===e)(e))return null;switch(t){case g.String:return(({value:e})=>p(e)?e:d(e)?e.toISOString():(e=>"object"==typeof e&&null!==e)(e)?JSON.stringify(e):String(e))({value:e});case g.Number:return(({value:e})=>{if((e=>"number"==typeof e)(e))return e;if(d(e))return null;const t=Number(e);return isNaN(t)?null:t})({value:e});case g.Boolean:return(({value:e})=>(e=>"boolean"==typeof e)(e)?e:"false"!==e&&"0"!==e&&0!==e&&Boolean(e))({value:e});case g.DateTimeString:return m({value:e,format:r});default:return e}},v=async({block:e})=>{const t=e?.fieldConfigs;if(!t||"disabled"===e?.debug?.custom_mappings)return e;let r;return r=Array.isArray(e.result)?e.result.map((e=>O(e,t))):O(e.result,t),{...e,result:r}},O=(e,t)=>{const r={...e};return t.forEach((t=>{const{targetFieldKey:s,type:n}=t;(e=>Object.values(g).includes(e))(n)&&(t.isUnified&&l(r[s])?r[s]=b({value:e[s],type:n}):r.unified_custom_fields&&l(r.unified_custom_fields?.[s])&&(r.unified_custom_fields[s]=b({value:e.unified_custom_fields?.[s],type:n})))})),{...r}},k=async({block:e})=>{const t=e?.fieldConfigs,r=[],s=e.steps;if(!t||"disabled"===e?.debug?.custom_mappings||!s)return e;let n;if(Array.isArray(e.result)){const o=e.result.length;n=e.result.map(((e,n)=>{const i=S(s,o,n),a=M(e,t,i);return r.push(...a.errors||[]),a.record}))}else{const o=M(e.result,t,s);n=o.record,r.push(...o.errors||[])}return{...e,result:n,customMappingErrors:Object.keys(r).length>0?r:void 0}},S=(e,t,r)=>Object.entries(e).reduce(((e,[s,n])=>{const o=n.output.data;return Array.isArray(o)&&o.length===t?e[s]={output:{data:o[r]}}:e[s]=n,e}),{}),M=(e,t,r)=>{if(!e||!r)return{record:e};const s={unified:{...e},..."object"==typeof r?r:{}},n={},o=[],i={...e};for(const r of t){const{error:t,value:a}=j(s,e.id,r);t?o.push(t):r.isUnified?i[r.targetFieldKey]=a:n[r.targetFieldKey]=a}return{record:{...i,unified_custom_fields:Object.keys(n).length>0?n:void 0},errors:o.length>0?o:void 0}},j=(e,r,s)=>{const{expression:n,targetFieldKey:o}=s;if(!n)return{error:{message:"Expression is empty",id:r,targetField:o}};try{t.parse(n)}catch(e){return{error:{message:"Invalid JSON path expression",id:r,targetField:o}}}const i=n&&t.query(e,n)[0];return void 0===i?{error:{message:"Expression returned no value",id:r,targetField:o}}:{value:i}},x={build({type:e}){switch(e){case exports.BlockStepType.MAP:return i;case exports.BlockStepType.TYPECAST:return v;case exports.BlockStepType.MAP_FIELDS:return k;default:throw new Error(`Unknown block step: ${e}`)}}};exports.BaseConnector=class{constructor({version:t="1",key:r,name:s,services:o={},httpOperations:i={},auth:a,proxy:u,httpClient:c=new e.HttpClient}){this.listOperations=()=>Object.keys(this.httpOperations||{}),this.getOperation=e=>{const t=this.httpOperations?.[e];if(!t)throw new Error(`Operation ${e} not found`);return t},this.getOperationResponseFieldsMetadata=e=>{const t=this.getOperation(e).responses;if(!t)return null;const r=(e=>{const t=Object.entries(e).find((([e])=>e.startsWith("2")));return t?t[1]:null})(t);return r?.content["application/json"]?.schema?n(r.content["application/json"]?.schema):null},this.getOperationRequestFieldsMetadata=e=>this.getOperation(e).parameters,this.callOperation=async({operationId:e,params:t,credentials:r})=>{const s=this.httpOperations?.[e];if(!s)throw new Error(`Operation ${e} not found`);const n=(({params:e,httpOperation:t})=>{const{url:r,method:s}=t;let n=r;const o=[],i=[],a={};let u;Object.entries(e||{}).forEach((([e,r])=>{const s=t.parameters?.[e];if(s)switch(s.in){case"path":n=n.replace(`{${e}}`,r).replace(`:${e}`,r);break;case"query":o.push(`${e}=${r}`);break;case"header":a[e]=r;break;case"cookie":i.push(`${e}=${r}; `);break;case"body":u=r}}));const c=o.length>0?`?${o.join("&")}`:"";return i.length>0&&(a.cookie=i.join("")),{url:`${n}${c}`,method:s,headers:Object.keys(a).length>0?a:void 0,body:u||void 0}})({params:t,httpOperation:s}),{method:o,url:i,headers:a,body:u}=n,{apiKey:c}=r;return{connector:this,input:{operationId:e,params:t},response:await this.httpClient.request({method:o,url:i,headers:{...a,authorization:c},payload:u}),credentials:r}},this.version=t,this.key=r,this.name=s,this.services=o,this.httpOperations=i,this.auth=a,this.proxy=u,this.httpClient=c}},exports.BlockStepsFactory=x,exports.REQUEST_BODY_PARAM="request_body",exports.blockPipe=async({blockSteps:e,block:t})=>e.reduce((async(e,t)=>t({block:await e})),Promise.resolve(t)),exports.getBlockPipeStepsFromConfigs=({fieldConfigs:e})=>{const t=[];return e&&t.push(x.build({type:exports.BlockStepType.MAP}),x.build({type:exports.BlockStepType.TYPECAST})),t};
@@ -1,5 +1,5 @@
1
1
  import { IHttpClient } from '@stackone/transport';
2
- import { Bundle, HttpOperation, HttpOperations, IConnector, Operation, ResponseFieldMetaData, Service } from './types';
2
+ import { Bundle, HttpOperation, HttpOperations, HttpParameter, IConnector, Operation, ResponseFieldMetaData, Service } from './types';
3
3
  export declare abstract class BaseConnector implements IConnector {
4
4
  protected httpClient: IHttpClient;
5
5
  version: string;
@@ -32,6 +32,9 @@ export declare abstract class BaseConnector implements IConnector {
32
32
  listOperations: () => string[];
33
33
  getOperation: (operationId: string) => HttpOperation;
34
34
  getOperationResponseFieldsMetadata: (operationId: string) => ResponseFieldMetaData[] | null;
35
+ getOperationRequestFieldsMetadata: (operationId: string) => {
36
+ [key: string]: HttpParameter;
37
+ } | undefined;
35
38
  callOperation: ({ operationId, params, credentials, }: {
36
39
  operationId: string;
37
40
  params?: Record<string, unknown> | undefined;
@@ -37,6 +37,7 @@ export interface HttpParameter {
37
37
  in: HttpParameterLocation;
38
38
  type: HttpParameterType;
39
39
  isArray?: boolean;
40
+ required?: boolean;
40
41
  }
41
42
  export type HttpResponses = {
42
43
  [key: string]: HttpSchemaResponse;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@stackone/core",
3
- "version": "1.14.3",
3
+ "version": "1.15.0",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.es.js",