aves-sdk 1.2.8 → 1.2.14
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 +2 -2
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/package.json +3 -3
package/README.md
CHANGED
|
@@ -29,8 +29,8 @@ import { AvesClient } from 'aves-sdk';
|
|
|
29
29
|
|
|
30
30
|
const client = new AvesClient(
|
|
31
31
|
'https://api.example.com', // Base URL
|
|
32
|
-
'
|
|
33
|
-
'
|
|
32
|
+
'hostid', // 6-digit HostID
|
|
33
|
+
'TOKEN', // Xtoken
|
|
34
34
|
'02' // Optional: 2-digit language code (01=Italian, 02=English)
|
|
35
35
|
);
|
|
36
36
|
|
package/dist/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var G=Object.create;var E=Object.defineProperty;var Q=Object.getOwnPropertyDescriptor;var Z=Object.getOwnPropertyNames;var J=Object.getPrototypeOf,Y=Object.prototype.hasOwnProperty;var ee=(a,n)=>{for(var i in n)E(a,i,{get:n[i],enumerable:!0})},O=(a,n,i,o)=>{if(n&&typeof n=="object"||typeof n=="function")for(let c of Z(n))!Y.call(a,c)&&c!==i&&E(a,c,{get:()=>n[c],enumerable:!(o=Q(n,c))||o.enumerable});return a};var f=(a,n,i)=>(i=a!=null?G(J(a)):{},O(n||!a||!a.__esModule?E(i,"default",{value:a,enumerable:!0}):i,a)),te=a=>O(E({},"__esModule",{value:!0}),a);var Ae={};ee(Ae,{AvesClient:()=>N,AvesError:()=>v});module.exports=te(Ae);var W=require("undici"),h=require("valibot");var D=require("fast-xml-parser"),re={ignoreAttributes:!1,attributeNamePrefix:"@",parseAttributeValue:!0,parseTrueNumberOnly:!1,trimValues:!0,ignoreNameSpace:!0,removeNSPrefix:!0,parseTagValue:!0},ae={ignoreAttributes:!1,attributeNamePrefix:"@",suppressEmptyNode:!1},ne=new D.XMLParser(re),oe=new D.XMLBuilder(ae);function w(a){return oe.build(a)}function $(a){return ne.parse(a)}var e=f(require("valibot"),1);var s=f(require("valibot"),1),A=s.object({"@HostID":s.pipe(s.string(),s.minLength(6),s.maxLength(6)),"@Xtoken":s.string(),"@Interface":s.literal("WEB"),"@UserName":s.literal("WEB"),"@LanguageCode":s.optional(s.pipe(s.string(),s.minLength(2),s.maxLength(2)))}),ie=s.optional(s.pipe(s.string(),s.transform(a=>a.split(",")))),M=s.object({"@Status":s.union([s.literal("OK"),s.literal("ERROR"),s.literal("WARNING"),s.literal("TIMEOUT")]),ErrorCode:s.optional(s.string()),ErrorDescription:s.optional(s.string()),Warnings:ie});var t=f(require("valibot"),1);var g=f(require("valibot"),1);function se(a){return a.charAt(0).toUpperCase()+a.slice(1)}function _(a){return a.charAt(0).toLowerCase()+a.slice(1)}var ce=new Set(["recordCode","insertCriteria","currencyCode","creditLimit","c_PaymentType","c_SpecPaymentTypeCode","s_PaymentType","s_SpecPaymentTypeCode","key","value","minDate","maxDate","hostID","xtoken","interface","userName","status"]);function y(a){if(!a||typeof a!="object")return a;if(Array.isArray(a))return a.map(i=>y(i));if(a instanceof Date||a instanceof RegExp||a instanceof Map||a instanceof Set||a instanceof Error)return a;let n={};for(let[i,o]of Object.entries(a)){let c=ce.has(i),l=se(i),u=c?`@${l}`:l;o&&typeof o=="object"&&!Array.isArray(o)?o instanceof Date||o instanceof RegExp||o instanceof Map||o instanceof Set||o instanceof Error?n[u]=o:n[u]=y(o):Array.isArray(o)?n[u]=o.map(p=>typeof p=="object"&&p&&!Array.isArray(p)?y(p):p):n[u]=o}return n}function C(a){if(!a||typeof a!="object")return a;if(Array.isArray(a))return a.map(i=>C(i));if(a instanceof Date||a instanceof RegExp||a instanceof Map||a instanceof Set||a instanceof Error)return a;let n={};for(let[i,o]of Object.entries(a))if(i.startsWith("@")){let c=i.slice(1),l=_(c);n[l]=o}else{let c=_(i);o&&typeof o=="object"&&!Array.isArray(o)?o instanceof Date||o instanceof RegExp||o instanceof Map||o instanceof Set||o instanceof Error?n[c]=o:n[c]=C(o):Array.isArray(o)?n[c]=o.map(l=>typeof l=="object"&&l&&!Array.isArray(l)?C(l):l):n[c]=o}return n}function R(a){return g.pipe(a,g.transform(n=>y(n)))}function S(a){return g.pipe(a,g.transform(n=>C(n)))}var U=t.object({currencyCode:t.string(),creditLimit:t.optional(t.string()),c_PaymentType:t.optional(t.union([t.literal("CASH"),t.literal("BANK"),t.literal("RID"),t.literal("RIBA"),t.literal("SPECIFIC_CODE")])),c_SpecPaymentTypeCode:t.optional(t.string()),s_PaymentType:t.optional(t.union([t.literal("CASH"),t.literal("BANK"),t.literal("RID"),t.literal("RIBA"),t.literal("SPECIFIC_CODE")])),s_SpecPaymentTypeCode:t.optional(t.string())}),x=R(U),B=t.object({key:t.string(),value:t.string()}),L=R(B),le=t.object({recordCode:t.optional(t.pipe(t.string(),t.minLength(6),t.maxLength(6))),insertCriteria:t.optional(t.union([t.literal("S"),t.literal("N"),t.literal("T"),t.literal("M")])),createdDate:t.optional(t.string()),recordType:t.optional(t.union([t.literal("CUSTOMER"),t.literal("SUPPLIER")],"CUSTOMER")),recordStatus:t.optional(t.union([t.literal("ENABLED"),t.literal("DISABLED"),t.literal("WARNING"),t.literal("BLACKLISTED")],"ENABLED")),moniker:t.optional(t.string()),name:t.optional(t.string()),extraInfo:t.optional(t.string()),languageCode:t.pipe(t.string(),t.minLength(2),t.maxLength(2)),address:t.optional(t.string()),zipCode:t.optional(t.string()),cityName:t.optional(t.string()),countyCode:t.optional(t.string()),stateCode:t.optional(t.string()),categoryCode:t.optional(t.string()),firstPhoneNumber:t.optional(t.string()),mobilePhoneNumber:t.optional(t.string()),email:t.optional(t.string()),gender:t.optional(t.string()),birthDate:t.optional(t.string()),fiscalCode:t.optional(t.string()),vatCode:t.optional(t.string()),financialDetail:t.optional(U),dynamicFields:t.optional(t.array(B))}),I=R(le),Oe=S(I);var ve=e.object({minDate:e.string(),maxDate:e.string()}),m=e.optional(e.pipe(e.string(),e.minLength(2),e.maxLength(2))),pe=e.object({searchType:e.literal("CODE"),recordCode:e.pipe(e.string(),e.minLength(6),e.maxLength(6)),languageCode:m}),me=e.object({searchType:e.literal("NAME"),name:e.string(),city:e.optional(e.string()),languageCode:m}),de=e.object({searchType:e.literal("VATCODE"),vatCode:e.string(),phoneNumber:e.optional(e.string()),languageCode:m}),ue=e.object({searchType:e.literal("ZONE"),zipCode:e.string(),countyCode:e.string(),city:e.optional(e.string()),languageCode:m}),ge=e.object({searchType:e.literal("CATEGORY"),categoryCode:e.string(),languageCode:m}),Re=e.object({searchType:e.literal("EMAIL"),email:e.string(),languageCode:m}),Se=e.object({searchType:e.literal("LASTMODDATE"),lastModificationDate:ve,languageCode:m}),he=e.object({searchType:e.literal("SEARCH_FIELD"),searchFieldValue:e.string(),languageCode:m}),fe=e.object({searchType:e.literal("EXTERNAL_REF_CODE"),searchFieldValue:e.string(),languageCode:m}),ye=e.union([pe,me,de,ue,ge,Re,Se,he,fe]),Ce=R(ye),H=e.object({RqHeader:A,SearchMasterRecord:Ce}),k=e.object({"@RecordCode":e.optional(e.pipe(e.union([e.string(),e.number()]),e.transform(a=>String(a)),e.minLength(6),e.maxLength(6))),"@InsertCriteria":e.optional(e.union([e.literal("S"),e.literal("N"),e.literal("T"),e.literal("M")])),CreatedDate:e.optional(e.string()),RecordType:e.optional(e.union([e.literal("CUSTOMER"),e.literal("SUPPLIER")])),RecordStatus:e.optional(e.union([e.literal("ENABLED"),e.literal("DISABLED"),e.literal("WARNING"),e.literal("BLACKLISTED")],"ENABLED")),Moniker:e.optional(e.string()),Name:e.optional(e.string()),LanguageCode:e.optional(e.pipe(e.string(),e.minLength(2),e.maxLength(2))),Address:e.optional(e.string()),ZipCode:e.optional(e.string()),CityName:e.optional(e.string()),CountyCode:e.optional(e.string()),StateCode:e.optional(e.string()),CategoryCode:e.optional(e.string()),FirstPhoneNumber:e.optional(e.string()),MobilePhoneNumber:e.optional(e.string()),Email:e.optional(e.string()),Gender:e.optional(e.string()),BirthDate:e.optional(e.string()),FiscalCode:e.optional(e.string()),NewsletterDisabled:e.optional(e.union([e.literal("true"),e.literal("false"),e.boolean()])),FinancialDetail:e.optional(x),DynamicFields:e.optional(e.array(L))}),Te=e.object({MasterRecordDetail:e.optional(e.pipe(e.union([e.array(k),k]),e.transform(a=>{if(a)return Array.isArray(a)?a:[a]})))}),z=S(e.object({RsStatus:M,MasterRecordList:e.optional(Te)}));var r=f(require("valibot"),1);var Ee=r.object({CustomerRecordCode:r.pipe(r.union([r.string(),r.number()]),r.transform(a=>String(a)),r.minLength(6),r.maxLength(6))}),De=r.object({"@RecordCode":r.optional(r.pipe(r.string(),r.minLength(6),r.maxLength(6))),"@InsertCriteria":r.optional(r.union([r.literal("S"),r.literal("N"),r.literal("T"),r.literal("M")])),CreatedDate:r.optional(r.string()),RecordType:r.optional(r.union([r.literal("CUSTOMER"),r.literal("SUPPLIER")])),RecordStatus:r.optional(r.union([r.literal("ENABLED"),r.literal("DISABLED"),r.literal("WARNING"),r.literal("BLACKLISTED")],"ENABLED")),Moniker:r.optional(r.string()),Name:r.optional(r.string()),LanguageCode:r.optional(r.pipe(r.string(),r.minLength(2),r.maxLength(2))),Address:r.optional(r.string()),ZipCode:r.optional(r.string()),CityName:r.optional(r.string()),CountyCode:r.optional(r.string()),StateCode:r.optional(r.string()),CategoryCode:r.optional(r.string()),FirstPhoneNumber:r.optional(r.string()),MobilePhoneNumber:r.optional(r.string()),Email:r.optional(r.string()),Gender:r.optional(r.string()),BirthDate:r.optional(r.string()),FiscalCode:r.optional(r.string()),NewsletterDisabled:r.optional(r.union([r.literal("true"),r.literal("false"),r.boolean()])),FinancialDetail:r.optional(x),DynamicFields:r.optional(r.array(L))}),q=r.object({RqHeader:A,MasterRecordDetail:r.intersect([De,r.object({"@InsertCriteria":r.union([r.literal("S"),r.literal("N"),r.literal("T"),r.literal("M")])})])}),K=S(r.object({RsStatus:M,CustomerRecordRS:r.optional(Ee)}));function j(a){return{success:!0,data:a}}function d(a){return{success:!1,error:a}}function V(a,n){return{[a]:n}}var P={SEARCH_REQUEST:"SearchMasterRecordRQ",SEARCH_RESPONSE:"SearchMasterRecordRS",UPSERT_REQUEST:"ManageMasterRecordRQ",UPSERT_RESPONSE:"ManageMasterRecordRS"},v=class extends Error{constructor(i,o,c,l){super(i);this.status=o;this.errorCode=c;this.errorDescription=l;this.name="AvesError"}},N=class{constructor(n,i,o,c){this.baseURL=n;this.hostID=i;this.xtoken=o;this.languageCode=c;this.baseURL=n.replace(/\/$/,"")}createRqHeader(){return{"@HostID":this.hostID,"@Xtoken":this.xtoken,"@Interface":"WEB","@UserName":"WEB",...this.languageCode&&{"@LanguageCode":this.languageCode}}}createUrl(n){return`${this.baseURL}${n}`}get endpoints(){return{search:"/interop/masterRecords/v2/rest/Search",upsert:"/interop/masterRecords/v2/rest/InsertOrUpdate"}}handleApiStatus(n,i){let o=i?.status;if(o==="ERROR"||o==="TIMEOUT")return d(new v(i.errorDescription||`API Error: ${o}`,o,i.errorCode,i.errorDescription));if(o==="WARNING"){let c=i.warnings?.join(", ");console.warn("AVES API Warning:",c)}return j(n)}toAvesError(n,i){return n instanceof v?n:n instanceof Error?new v(n.message):new v(i)}async request(n,i,o,c){try{let l=this.createUrl(n),u=w(i),p=await(0,W.request)(l,{method:"POST",headers:{"Content-Type":"application/xml"},body:u}),b=await p.body.text();if(p.statusCode!==200)return d(new v(b,p.statusCode.toString()));let F=$(b)[o];if(!F)return d(new v(`Invalid response structure: missing root element '${o}'`,void 0,"VALIDATION_ERROR"));let T=(0,h.safeParse)(c,F);return T.success?this.handleApiStatus(T.output,T.output.rsStatus):d(new v(`Invalid response format: ${T.issues.map(X=>X.message).join(", ")}`,"400","VALIDATION_ERROR"))}catch(l){return d(this.toAvesError(l,"Unknown error occurred"))}}async search(n){try{let i=(0,h.parse)(H,{RqHeader:this.createRqHeader(),SearchMasterRecord:n}),o=V(P.SEARCH_REQUEST,i);return await this.request(this.endpoints.search,o,P.SEARCH_RESPONSE,z)}catch(i){return d(this.toAvesError(i,"Validation error occurred during search"))}}async upsertRecord(n){try{let o={"@InsertCriteria":"T",...(0,h.parse)(I,n)},c=(0,h.parse)(q,{RqHeader:this.createRqHeader(),MasterRecordDetail:o}),l=V(P.UPSERT_REQUEST,c);return await this.request(this.endpoints.upsert,l,P.UPSERT_RESPONSE,K)}catch(i){return d(this.toAvesError(i,"Validation error occurred during upsert"))}}};0&&(module.exports={AvesClient,AvesError});
|
|
1
|
+
"use strict";var ve=Object.create;var C=Object.defineProperty;var me=Object.getOwnPropertyDescriptor;var de=Object.getOwnPropertyNames;var ue=Object.getPrototypeOf,ge=Object.prototype.hasOwnProperty;var Re=(t,r)=>{for(var a in r)C(t,a,{get:r[a],enumerable:!0})},V=(t,r,a,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let s of de(r))!ge.call(t,s)&&s!==a&&C(t,s,{get:()=>r[s],enumerable:!(n=me(r,s))||n.enumerable});return t};var f=(t,r,a)=>(a=t!=null?ve(ue(t)):{},V(r||!t||!t.__esModule?C(a,"default",{value:t,enumerable:!0}):a,t)),Se=t=>V(C({},"__esModule",{value:!0}),t);var ze={};Re(ze,{AvesClient:()=>N,AvesError:()=>l});module.exports=Se(ze);var ce=require("undici"),u=require("valibot");var M=require("fast-xml-parser");var U={VALIDATION:"validation",API:"api",UNKNOWN:"unknown"},l=class extends Error{constructor(a,n,s,c){super(n);this.kind=a;this.message=n;this.status=s;this.code=c;this.name="AvesError",this.status=s?.toLowerCase(),this.code=this.parseCode(c)}parseCode(a){return typeof a=="string"?Number.parseInt(a):a??0}};function A(t){return new l(U.VALIDATION,t)}function x(t,r,a){return new l(U.API,t,r,a)}function k(t){return new l(U.UNKNOWN,t)}function $(t){return t.map(r=>{let a=r.path&&r.path.length>0?r.path.map(s=>typeof s=="string"||typeof s=="number"?String(s):"key"in s?String(s.key):"").filter(Boolean).join("."):void 0,n=r.message??"Invalid value";return a?`${a}: ${n}`:n}).join("; ")}function X(t){return t instanceof Error&&t.name==="AbortError"}var he={ignoreAttributes:!1,attributeNamePrefix:"@",parseAttributeValue:!1,trimValues:!0,ignoreNameSpace:!0,removeNSPrefix:!0,parseTagValue:!1},fe={ignoreAttributes:!1,attributeNamePrefix:"@",suppressEmptyNode:!0},ye=new M.XMLParser(he),Ee=new M.XMLBuilder(fe);function W(t){try{return Ee.build(t)}catch(r){throw new l("validation",`Failed to convert JSON to XML: ${r instanceof Error?r.message:"Unknown error"}`)}}function G(t){try{return ye.parse(t)}catch(r){throw new l("validation",`Failed to convert XML to JSON: ${r instanceof Error?r.message:"Unknown error"}`)}}var o=f(require("valibot"),1);var i=f(require("valibot"),1),D=i.object({"@HostID":i.pipe(i.string(),i.minLength(6),i.maxLength(6)),"@Xtoken":i.string(),"@Interface":i.literal("WEB"),"@UserName":i.literal("WEB"),"@LanguageCode":i.optional(i.pipe(i.string(),i.minLength(2),i.maxLength(2)))}),Te=i.optional(i.pipe(i.string(),i.transform(t=>t.split(",")))),b=i.pipe(i.object({"@Status":i.union([i.literal("OK"),i.literal("ERROR"),i.literal("WARNING"),i.literal("TIMEOUT")]),ErrorCode:i.optional(i.pipe(i.union([i.string(),i.number()]),i.transform(t=>Number(t)))),ErrorDescription:i.optional(i.string()),Warnings:Te}),i.transform(t=>({status:t["@Status"],errorCode:t.ErrorCode,errorDescription:t.ErrorDescription,warnings:t.Warnings})));var e=f(require("valibot"),1);var d=f(require("valibot"),1);function Ce(t){return t.charAt(0).toUpperCase()+t.slice(1)}function Q(t){return t.charAt(0).toLowerCase()+t.slice(1)}function P(t){return t instanceof Date||t instanceof RegExp||t instanceof Map||t instanceof Set||t instanceof Error}var F=new Set(["recordCode","insertCriteria","currencyCode","creditLimit","c_PaymentType","c_SpecPaymentTypeCode","s_PaymentType","s_SpecPaymentTypeCode","enableElectronicInvoicing","electronicInvoicingType","key","value","minDate","maxDate","hostID","xtoken","interface","userName","status","acceptProfilingPolicies","acceptPrivacyPolicies","acceptNewsletterPolicies"]);function y(t){if(!t||typeof t!="object")return t;if(Array.isArray(t))return t.map(a=>y(a));if(P(t))return t;let r={};for(let[a,n]of Object.entries(t)){let s=F.has(a),c=Ce(a),R=s?`@${c}`:c;n&&typeof n=="object"&&!Array.isArray(n)?P(n)?r[R]=n:r[R]=y(n):Array.isArray(n)?r[R]=n.map(p=>typeof p=="object"&&p&&!Array.isArray(p)?y(p):p):r[R]=n}return r}function E(t){if(!t||typeof t!="object")return t;if(Array.isArray(t))return t.map(a=>E(a));if(P(t))return t;let r={};for(let[a,n]of Object.entries(t))if(a.startsWith("@")){let s=a.slice(1),c=Q(s);r[c]=n}else{let s=Q(a);n&&typeof n=="object"&&!Array.isArray(n)?P(n)?r[s]=n:r[s]=E(n):Array.isArray(n)?r[s]=n.map(c=>typeof c=="object"&&c&&!Array.isArray(c)?E(c):c):r[s]=n}return r}function g(t){return d.pipe(t,d.transform(r=>y(r)))}function S(t){return d.pipe(t,d.transform(r=>E(r)))}function L(t){let r={};for(let a in t.entries){let n=F.has(a),s=a.charAt(0).toUpperCase()+a.slice(1),c=n?`@${s}`:s;r[c]=t.entries[a]}return d.object(r)}var J=e.union([e.literal("CASH"),e.literal("BANK"),e.literal("RID"),e.literal("RIBA"),e.literal("SPECIFIC_CODE")]),K=e.object({currencyCode:e.optional(e.string()),creditLimit:e.optional(e.string()),c_PaymentType:e.optional(J),c_SpecPaymentTypeCode:e.optional(e.string()),s_PaymentType:e.optional(J),s_SpecPaymentTypeCode:e.optional(e.string()),enableElectronicInvoicing:e.optional(e.union([e.literal("true"),e.literal("false"),e.boolean()])),electronicInvoicingType:e.optional(e.string())}),tt=g(K),Ae=L(K),j=e.object({key:e.string(),value:e.string()}),rt=g(j),xe=L(j),_=e.union([e.literal(0),e.literal(1)]),Z=e.union([e.literal("ENABLED"),e.literal("DISABLED"),e.literal("WARNING"),e.literal("BLACKLISTED")]),Me=e.union([e.literal("CUSTOMER"),e.literal("SUPPLIER"),e.literal("GENERAL")]),Y=e.union([e.literal("S"),e.literal("N"),e.literal("T"),e.literal("M")]),B=e.object({acceptProfilingPolicies:e.optional(_),acceptPrivacyPolicies:e.optional(_),acceptNewsletterPolicies:e.optional(_)}),ot=g(B),De=L(B),be=e.object({recordCode:e.optional(e.pipe(e.string(),e.minLength(6),e.maxLength(6))),insertCriteria:e.optional(Y),createdDate:e.optional(e.string()),recordType:e.optional(e.union([Me],"CUSTOMER")),recordStatus:e.optional(e.union([Z],"ENABLED")),moniker:e.optional(e.string()),name:e.optional(e.string()),extraInfo:e.optional(e.string()),languageCode:e.pipe(e.string(),e.minLength(2),e.maxLength(2)),address:e.optional(e.string()),zipCode:e.optional(e.string()),cityName:e.optional(e.string()),countyCode:e.optional(e.string()),stateCode:e.optional(e.string()),categoryCode:e.optional(e.string()),firstPhoneNumber:e.optional(e.string()),mobilePhoneNumber:e.optional(e.string()),email:e.optional(e.string()),gender:e.optional(e.string()),birthDate:e.optional(e.string()),fiscalCode:e.optional(e.string()),vatCode:e.optional(e.string()),accountPolicies:e.optional(B),financialDetail:e.optional(K),dynamicFields:e.optional(j)}),H=g(be),at=S(H),h=e.object({"@RecordCode":e.optional(e.pipe(e.string(),e.minLength(5),e.maxLength(6))),"@InsertCriteria":e.optional(Y),CreatedDate:e.optional(e.string()),ModifiedDate:e.optional(e.string()),RecordType:e.optional(e.union([e.literal("CUSTOMER"),e.literal("SUPPLIER"),e.literal("GENERAL")])),LoginType:e.optional(e.string()),RecordStatus:e.optional(Z),Moniker:e.optional(e.string()),Name:e.optional(e.string()),ExtraInfo:e.optional(e.string()),LanguageCode:e.optional(e.pipe(e.string(),e.minLength(1),e.maxLength(2))),Address:e.optional(e.string()),ZipCode:e.optional(e.string()),CityName:e.optional(e.string()),CountyCode:e.optional(e.string()),StateCode:e.optional(e.string()),CategoryCode:e.optional(e.string()),PromoterCode:e.optional(e.string()),FirstPhoneNumber:e.optional(e.string()),MobilePhoneNumber:e.optional(e.string()),Email:e.optional(e.string()),Gender:e.optional(e.string()),BirthDate:e.optional(e.string()),EncryptedPassword:e.optional(e.union([e.literal("true"),e.literal("false"),e.boolean()])),FiscalCode:e.optional(e.string()),VatCode:e.optional(e.string()),NewsletterDisabled:e.optional(e.union([e.literal("true"),e.literal("false"),e.boolean()])),SupplierRefMasterRecords:e.optional(e.any()),AccountPolicies:e.optional(De),FinancialDetail:e.optional(Ae),DynamicFields:e.optional(e.array(xe))});var Pe=o.object({minDate:o.string(),maxDate:o.string()}),v=o.optional(o.pipe(o.string(),o.minLength(2),o.maxLength(2))),Le=o.object({searchType:o.literal("CODE"),recordCode:o.pipe(o.string(),o.minLength(5),o.maxLength(6)),languageCode:v}),Ie=o.object({searchType:o.literal("NAME"),name:o.string(),city:o.optional(o.string()),languageCode:v}),Ne=o.object({searchType:o.literal("VATCODE"),vatCode:o.string(),phoneNumber:o.optional(o.string()),languageCode:v}),we=o.object({searchType:o.literal("ZONE"),zipCode:o.string(),countyCode:o.string(),city:o.optional(o.string()),languageCode:v}),Oe=o.object({searchType:o.literal("CATEGORY"),categoryCode:o.string(),languageCode:v}),Ue=o.object({searchType:o.literal("EMAIL"),email:o.string(),languageCode:v}),ke=o.object({searchType:o.literal("LASTMODDATE"),lastModificationDate:Pe,languageCode:v}),$e=o.object({searchType:o.literal("SEARCH_FIELD"),searchFieldValue:o.string(),languageCode:v}),Fe=o.object({searchType:o.literal("EXTERNAL_REF_CODE"),searchFieldValue:o.string(),languageCode:v}),_e=o.union([Le,Ie,Ne,we,Oe,Ue,ke,$e,Fe]),Ke=t=>{if(!("@RecordCode"in t))return t;let r=t["@RecordCode"];if(!r)return t;let{["@RecordCode"]:a,...n}=t;return{...n,RecordCode:r}},je=o.pipe(g(_e),o.transform(t=>Ke(t))),ee=o.pipe(o.object({RqHeader:D,SearchMasterRecord:je}),o.transform(t=>{let{SearchMasterRecord:r,RqHeader:a,...n}=t;return{RqHeader:a,...r,...n}})),Be=o.object({MasterRecordDetail:o.optional(o.pipe(o.union([o.array(h),h]),o.transform(t=>{if(t)return Array.isArray(t)?t:[t]})))}),te=S(o.object({RsStatus:b,MasterRecordList:o.optional(Be)}));var T=f(require("valibot"),1);var re=T.object({RqHeader:D,MasterRecordDetail:h}),oe=S(T.object({RsStatus:b,MasterRecordDetail:T.optional(h)}));function ae(t){return{success:!0,data:t}}function m(t){return{success:!1,error:t}}function He(t,r){try{let a=new URL(t),s=(a.pathname.endsWith("/")?a.pathname.slice(0,-1):a.pathname)+r;return new URL(s,a)}catch(a){throw new l("validation",`Invalid baseURL: ${a instanceof Error?a.message:"Invalid URL format"}`)}}function ne(t,r){if(!r.startsWith("/"))throw new l("validation",`Invalid endpoint: endpoint must start with '/' but got '${r}'`);let a=t.replace(/\/$/,""),n=He(a,r);if(n.protocol!=="http:"&&n.protocol!=="https:")throw new l("validation",`Invalid protocol: baseURL must use http:// or https:// but got '${n.protocol}'`);return n.toString()}function ie(t){let r=new AbortController;if(!t||t<=0)return{signal:r.signal};let a=setTimeout(()=>r.abort(),t);return{signal:r.signal,clear:()=>clearTimeout(a)}}function se(t,r){return{[t]:r}}var I={SEARCH_REQUEST:"SearchMasterRecordRQ",SEARCH_RESPONSE:"SearchMasterRecordRS",UPSERT_REQUEST:"ManageMasterRecordRQ",UPSERT_RESPONSE:"ManageMasterRecordRS"},N=class{constructor(r){this.options=r}createRqHeader(){return{"@HostID":this.options.hostID,"@Xtoken":this.options.xtoken,"@Interface":"WEB","@UserName":"WEB",...this.options.languageCode&&{"@LanguageCode":this.options.languageCode}}}createUrl(r){return ne(this.options.baseURL,r)}get endpoints(){return{search:"/interop/masterRecords/v2/rest/Search",upsert:"/interop/masterRecords/v2/rest/InsertOrUpdate"}}handleApiStatus(r){let a=r.rsStatus,n=a?.status;return n!=="OK"?m(x(a.errorDescription,n,a.errorCode)):ae(r)}toAvesError(r,a){if(r instanceof l)return r;if(r instanceof u.ValiError){let n=$(r.issues);return A(`Validation error: ${n}`)}return r instanceof Error?k(r.message):k(a)}async request(r,a,n,s){let{signal:c,clear:R}=ie(this.options.timeoutMs??3e4);try{let p=this.createUrl(r),le=W(a),w=await(0,ce.request)(p,{method:"POST",headers:{"Content-Type":"application/xml"},body:le,signal:c}),z=await w.body.text();if(w.statusCode!==200)return m(x(z,"ERROR",w.statusCode));let q=G(z)[n];if(!q)return m(A(`Invalid response structure: missing root element '${n}'`));let O=(0,u.safeParse)(s,q);if(!O.success){let pe=$(O.issues);return m(A(`Invalid response format: ${pe}`))}return this.handleApiStatus(O.output)}catch(p){return X(p)?m(x("Request timed out","TIMEOUT")):m(this.toAvesError(p,"Unknown error occurred"))}finally{R?.()}}async search(r){try{let a=(0,u.parse)(ee,{RqHeader:this.createRqHeader(),SearchMasterRecord:r}),n=se(I.SEARCH_REQUEST,a);return this.request(this.endpoints.search,n,I.SEARCH_RESPONSE,te)}catch(a){return m(this.toAvesError(a,"Validation error occurred during search"))}}async upsertRecord(r){try{let a=(0,u.parse)(H,r),n=(0,u.parse)(re,{RqHeader:this.createRqHeader(),MasterRecordDetail:a}),s=se(I.UPSERT_REQUEST,n);return this.request(this.endpoints.upsert,s,I.UPSERT_RESPONSE,oe)}catch(a){return m(this.toAvesError(a,"Validation error occurred during upsert"))}}};0&&(module.exports={AvesClient,AvesError});
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/client.ts","../src/xml-client.ts","../src/schemas/search.ts","../src/schemas/common.ts","../src/schemas/master-record.ts","../src/utils/schema-transform.ts","../src/utils/case-transform.ts","../src/schemas/upsert.ts","../src/utils/result.ts"],"sourcesContent":["// Main client\nexport { AvesClient, AvesError } from './client.js';\n\n// Types\nexport type {\n RqHeader,\n RsStatus,\n FinancialDetail,\n MasterRecordDetail,\n MasterRecordDetailResponse,\n SearchMasterRecord,\n SearchMasterRecordRS,\n ManageMasterRecordRequest,\n ManageMasterRecordRS,\n} from './types.js';\n","import { request as r } from 'undici';\nimport { parse, safeParse } from 'valibot';\nimport { jsonToXml, xmlToJson } from './xml-client.js';\nimport {\n SearchMasterRecordRequestSchema,\n SearchMasterRecordResponseSchema,\n} from './schemas/search.js';\nimport {\n ManageMasterRecordRequestSchema,\n ManageMasterRecordResponseSchema,\n} from './schemas/upsert.js';\nimport type {\n ManageMasterRecordRS,\n MasterRecordDetail,\n SearchMasterRecord,\n SearchMasterRecordRS,\n} from './types.js';\nimport { MasterRecordDetailApiSchema } from './schemas/master-record.js';\nimport type { Result } from './utils/result.js';\nimport { err, ok } from './utils/result.js';\n\nfunction createRootElement<T>(name: XMLRootElementValues, object: T) {\n return {\n [name]: object,\n };\n}\n\nconst XML_ROOT_ELEMENTS = {\n SEARCH_REQUEST: 'SearchMasterRecordRQ',\n SEARCH_RESPONSE: 'SearchMasterRecordRS',\n UPSERT_REQUEST: 'ManageMasterRecordRQ',\n UPSERT_RESPONSE: 'ManageMasterRecordRS',\n} as const;\n\ntype XMLRootElementValues =\n (typeof XML_ROOT_ELEMENTS)[keyof typeof XML_ROOT_ELEMENTS];\n\n/**\n * Error thrown by AVES API operations\n */\nexport class AvesError extends Error {\n constructor(\n message: string,\n public readonly status?: string,\n public readonly errorCode?: string,\n public readonly errorDescription?: string\n ) {\n super(message);\n this.name = 'AvesError';\n }\n}\n\n/**\n * AVES XML REST API client\n */\nexport class AvesClient {\n /**\n * @param baseURL - Base URL of the AVES API\n * @param hostID - 6-digit identification code\n * @param xtoken - Authentication token\n * @param languageCode - Optional 2-digit language code\n */\n constructor(\n private readonly baseURL: string,\n private readonly hostID: string,\n private readonly xtoken: string,\n private readonly languageCode?: string\n ) {\n this.baseURL = baseURL.replace(/\\/$/, '');\n }\n\n private createRqHeader() {\n return {\n '@HostID': this.hostID,\n '@Xtoken': this.xtoken,\n '@Interface': 'WEB' as const,\n '@UserName': 'WEB' as const,\n ...(this.languageCode && { '@LanguageCode': this.languageCode }),\n };\n }\n\n private createUrl(endpoint: string) {\n return `${this.baseURL}${endpoint}`;\n }\n\n private get endpoints() {\n return {\n search: '/interop/masterRecords/v2/rest/Search',\n upsert: '/interop/masterRecords/v2/rest/InsertOrUpdate',\n } as const;\n }\n\n private handleApiStatus<T>(\n output: T,\n rsStatus: {\n status?: string;\n errorCode?: string;\n errorDescription?: string;\n warnings?: string[];\n }\n ): Result<T, AvesError> {\n const status = rsStatus?.status;\n\n if (status === 'ERROR' || status === 'TIMEOUT') {\n return err(\n new AvesError(\n rsStatus.errorDescription || `API Error: ${status}`,\n status,\n rsStatus.errorCode,\n rsStatus.errorDescription\n )\n );\n }\n\n if (status === 'WARNING') {\n const warnings = rsStatus.warnings?.join(', ');\n console.warn('AVES API Warning:', warnings);\n }\n\n return ok(output);\n }\n\n private toAvesError(error: unknown, defaultMessage: string): AvesError {\n if (error instanceof AvesError) {\n return error;\n }\n if (error instanceof Error) {\n return new AvesError(error.message);\n }\n return new AvesError(defaultMessage);\n }\n\n private async request<T>(\n endpoint: string,\n requestBody: Record<string, unknown>,\n responseRootKey: string,\n responseSchema:\n | typeof ManageMasterRecordResponseSchema\n | typeof SearchMasterRecordResponseSchema\n ): Promise<Result<T, AvesError>> {\n try {\n const url = this.createUrl(endpoint);\n const xmlBody = jsonToXml(requestBody);\n\n const response = await r(url, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/xml',\n },\n body: xmlBody,\n });\n\n const responseText = await response.body.text();\n\n if (response.statusCode !== 200) {\n return err(new AvesError(responseText, response.statusCode.toString()));\n }\n\n const jsonResponse = xmlToJson(responseText);\n const rootElement = jsonResponse[responseRootKey];\n\n if (!rootElement) {\n return err(\n new AvesError(\n `Invalid response structure: missing root element '${responseRootKey}'`,\n undefined,\n 'VALIDATION_ERROR'\n )\n );\n }\n\n const parseResult = safeParse(responseSchema, rootElement);\n\n if (!parseResult.success) {\n return err(\n new AvesError(\n `Invalid response format: ${parseResult.issues\n .map((i) => i.message)\n .join(', ')}`,\n '400',\n 'VALIDATION_ERROR'\n )\n );\n }\n\n return this.handleApiStatus(\n parseResult.output as T,\n parseResult.output.rsStatus\n );\n } catch (error) {\n return err(this.toAvesError(error, 'Unknown error occurred'));\n }\n }\n\n /**\n * Search for master records\n * @returns Result containing list of matching master records in camelCase or error\n */\n async search(\n params: SearchMasterRecord\n ): Promise<Result<SearchMasterRecordRS, AvesError>> {\n try {\n const requestData = parse(SearchMasterRecordRequestSchema, {\n RqHeader: this.createRqHeader(),\n SearchMasterRecord: params,\n });\n\n const requestBody = createRootElement(\n XML_ROOT_ELEMENTS.SEARCH_REQUEST,\n requestData\n );\n\n return await this.request<SearchMasterRecordRS>(\n this.endpoints.search,\n requestBody,\n XML_ROOT_ELEMENTS.SEARCH_RESPONSE,\n SearchMasterRecordResponseSchema\n );\n } catch (error) {\n return err(\n this.toAvesError(error, 'Validation error occurred during search')\n );\n }\n }\n\n /**\n * Insert or update a master record\n * @param record - Master record data in camelCase\n * @returns Result containing response with customer record code in camelCase or error\n */\n async upsertRecord(\n record: MasterRecordDetail\n ): Promise<Result<ManageMasterRecordRS, AvesError>> {\n try {\n const apiRecord = parse(MasterRecordDetailApiSchema, record);\n\n const masterRecordDetail = {\n '@InsertCriteria': 'T' as const,\n ...apiRecord,\n };\n\n const requestData = parse(ManageMasterRecordRequestSchema, {\n RqHeader: this.createRqHeader(),\n MasterRecordDetail: masterRecordDetail,\n });\n\n const requestBody = createRootElement(\n XML_ROOT_ELEMENTS.UPSERT_REQUEST,\n requestData\n );\n\n return await this.request<ManageMasterRecordRS>(\n this.endpoints.upsert,\n requestBody,\n XML_ROOT_ELEMENTS.UPSERT_RESPONSE,\n ManageMasterRecordResponseSchema\n );\n } catch (error) {\n return err(\n this.toAvesError(error, 'Validation error occurred during upsert')\n );\n }\n }\n}\n","import { XMLParser, XMLBuilder } from 'fast-xml-parser';\n\nconst parserOptions = {\n ignoreAttributes: false,\n attributeNamePrefix: '@',\n parseAttributeValue: true,\n parseTrueNumberOnly: false,\n trimValues: true,\n ignoreNameSpace: true,\n removeNSPrefix: true,\n parseTagValue: true,\n};\n\nconst builderOptions = {\n ignoreAttributes: false,\n attributeNamePrefix: '@',\n suppressEmptyNode: false,\n};\n\nconst parser = new XMLParser(parserOptions);\nconst builder = new XMLBuilder(builderOptions);\n\n/**\n * Converts JSON to XML string\n */\nexport function jsonToXml(json: Record<string, unknown>): string {\n return builder.build(json);\n}\n\n/**\n * Converts XML string to JSON object\n * Attributes are parsed with @ prefix\n */\nexport function xmlToJson(xml: string): Record<string, unknown> {\n return parser.parse(xml);\n}\n","import * as v from 'valibot';\nimport { RqHeaderSchema, RsStatusSchema } from './common.js';\nimport { FinancialDetailSchema, DynamicFieldsSchema } from './master-record.js';\nimport {\n createApiSchema,\n createResponseSchema,\n} from '../utils/schema-transform.js';\n\nconst LastModificationDateInputSchema = v.object({\n minDate: v.string(),\n maxDate: v.string(),\n});\n\nconst languageCodeField = v.optional(\n v.pipe(v.string(), v.minLength(2), v.maxLength(2))\n);\n\n/**\n * Search by CODE - requires recordCode\n */\nconst CodeSearchSchema = v.object({\n searchType: v.literal('CODE'),\n recordCode: v.pipe(v.string(), v.minLength(6), v.maxLength(6)),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by NAME - requires name, optionally city\n */\nconst NameSearchSchema = v.object({\n searchType: v.literal('NAME'),\n name: v.string(),\n city: v.optional(v.string()),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by VATCODE - requires vatCode, optionally phoneNumber\n */\nconst VatCodeSearchSchema = v.object({\n searchType: v.literal('VATCODE'),\n vatCode: v.string(),\n phoneNumber: v.optional(v.string()),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by ZONE - requires zipCode and countyCode, optionally city\n */\nconst ZoneSearchSchema = v.object({\n searchType: v.literal('ZONE'),\n zipCode: v.string(),\n countyCode: v.string(),\n city: v.optional(v.string()),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by CATEGORY - requires categoryCode\n */\nconst CategorySearchSchema = v.object({\n searchType: v.literal('CATEGORY'),\n categoryCode: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by EMAIL - requires email\n */\nconst EmailSearchSchema = v.object({\n searchType: v.literal('EMAIL'),\n email: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by LASTMODDATE - requires lastModificationDate\n */\nconst LastModDateSearchSchema = v.object({\n searchType: v.literal('LASTMODDATE'),\n lastModificationDate: LastModificationDateInputSchema,\n languageCode: languageCodeField,\n});\n\n/**\n * Search by SEARCH FIELD - requires searchFieldValue\n */\nconst SearchFieldSearchSchema = v.object({\n searchType: v.literal('SEARCH_FIELD'),\n searchFieldValue: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by EXTERNAL_REF_CODE - requires searchFieldValue\n */\nconst ExternalRefCodeSearchSchema = v.object({\n searchType: v.literal('EXTERNAL_REF_CODE'),\n searchFieldValue: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search master record input schema (camelCase)\n * Conditional fields based on searchType\n */\nexport const SearchMasterRecordSchema = v.union([\n CodeSearchSchema,\n NameSearchSchema,\n VatCodeSearchSchema,\n ZoneSearchSchema,\n CategorySearchSchema,\n EmailSearchSchema,\n LastModDateSearchSchema,\n SearchFieldSearchSchema,\n ExternalRefCodeSearchSchema,\n]);\n\n/**\n * Search master record schema for API requests (transforms to PascalCase)\n */\nexport const SearchMasterRecordApiSchema = createApiSchema(\n SearchMasterRecordSchema\n);\n\n/**\n * Complete search request schema with header\n */\nexport const SearchMasterRecordRequestSchema = v.object({\n RqHeader: RqHeaderSchema,\n SearchMasterRecord: SearchMasterRecordApiSchema,\n});\n\nconst MasterRecordDetailApiValidationSchema = v.object({\n '@RecordCode': v.optional(\n v.pipe(\n v.union([v.string(), v.number()]),\n v.transform((val) => String(val)),\n v.minLength(6),\n v.maxLength(6)\n )\n ),\n '@InsertCriteria': v.optional(\n v.union([v.literal('S'), v.literal('N'), v.literal('T'), v.literal('M')])\n ),\n CreatedDate: v.optional(v.string()),\n RecordType: v.optional(\n v.union([v.literal('CUSTOMER'), v.literal('SUPPLIER')])\n ),\n RecordStatus: v.optional(\n v.union(\n [\n v.literal('ENABLED'),\n v.literal('DISABLED'),\n v.literal('WARNING'),\n v.literal('BLACKLISTED'),\n ],\n 'ENABLED'\n )\n ),\n Moniker: v.optional(v.string()),\n Name: v.optional(v.string()),\n LanguageCode: v.optional(v.pipe(v.string(), v.minLength(2), v.maxLength(2))),\n Address: v.optional(v.string()),\n ZipCode: v.optional(v.string()),\n CityName: v.optional(v.string()),\n CountyCode: v.optional(v.string()),\n StateCode: v.optional(v.string()),\n CategoryCode: v.optional(v.string()),\n FirstPhoneNumber: v.optional(v.string()),\n MobilePhoneNumber: v.optional(v.string()),\n Email: v.optional(v.string()),\n Gender: v.optional(v.string()),\n BirthDate: v.optional(v.string()),\n FiscalCode: v.optional(v.string()),\n NewsletterDisabled: v.optional(\n v.union([v.literal('true'), v.literal('false'), v.boolean()])\n ),\n FinancialDetail: v.optional(FinancialDetailSchema),\n DynamicFields: v.optional(v.array(DynamicFieldsSchema)),\n});\n\nconst MasterRecordListApiSchema = v.object({\n MasterRecordDetail: v.optional(\n v.pipe(\n v.union([\n v.array(MasterRecordDetailApiValidationSchema),\n MasterRecordDetailApiValidationSchema,\n ]),\n v.transform((input) => {\n if (!input) return undefined;\n return Array.isArray(input) ? input : [input];\n })\n )\n ),\n});\n\n/**\n * Search master record response schema (transforms to camelCase)\n */\nexport const SearchMasterRecordResponseSchema = createResponseSchema(\n v.object({\n RsStatus: RsStatusSchema,\n MasterRecordList: v.optional(MasterRecordListApiSchema),\n })\n);\n","import * as v from 'valibot';\n\n/**\n * Request header schema with authentication credentials\n */\nexport const RqHeaderSchema = v.object({\n '@HostID': v.pipe(v.string(), v.minLength(6), v.maxLength(6)),\n '@Xtoken': v.string(),\n '@Interface': v.literal('WEB'),\n '@UserName': v.literal('WEB'),\n '@LanguageCode': v.optional(\n v.pipe(v.string(), v.minLength(2), v.maxLength(2))\n ),\n});\n\nconst warningsSchema = v.optional(\n v.pipe(\n v.string(),\n v.transform((input) => input.split(','))\n )\n);\n\n/**\n * Response status schema indicating success, error, or warning\n */\nexport const RsStatusSchema = v.object({\n '@Status': v.union([\n v.literal('OK'),\n v.literal('ERROR'),\n v.literal('WARNING'),\n v.literal('TIMEOUT'),\n ]),\n ErrorCode: v.optional(v.string()),\n ErrorDescription: v.optional(v.string()),\n Warnings: warningsSchema,\n});\n","import * as v from 'valibot';\nimport {\n createApiSchema,\n createResponseSchema,\n} from '../utils/schema-transform.js';\n\nconst FinancialDetailInputSchema = v.object({\n currencyCode: v.string(),\n creditLimit: v.optional(v.string()),\n c_PaymentType: v.optional(\n v.union([\n v.literal('CASH'),\n v.literal('BANK'),\n v.literal('RID'),\n v.literal('RIBA'),\n v.literal('SPECIFIC_CODE'),\n ])\n ),\n c_SpecPaymentTypeCode: v.optional(v.string()),\n s_PaymentType: v.optional(\n v.union([\n v.literal('CASH'),\n v.literal('BANK'),\n v.literal('RID'),\n v.literal('RIBA'),\n v.literal('SPECIFIC_CODE'),\n ])\n ),\n s_SpecPaymentTypeCode: v.optional(v.string()),\n});\n\n/**\n * Financial detail schema for API requests (transforms to PascalCase)\n */\nexport const FinancialDetailSchema = createApiSchema(\n FinancialDetailInputSchema\n);\n\nconst DynamicFieldsInputSchema = v.object({\n key: v.string(),\n value: v.string(),\n});\n\n/**\n * Dynamic fields schema for API requests (transforms to PascalCase)\n */\nexport const DynamicFieldsSchema = createApiSchema(DynamicFieldsInputSchema);\n\n/**\n * Master record detail input schema (camelCase)\n */\nexport const MasterRecordDetailSchema = v.object({\n recordCode: v.optional(v.pipe(v.string(), v.minLength(6), v.maxLength(6))),\n insertCriteria: v.optional(\n v.union([v.literal('S'), v.literal('N'), v.literal('T'), v.literal('M')])\n ),\n createdDate: v.optional(v.string()),\n recordType: v.optional(\n v.union([v.literal('CUSTOMER'), v.literal('SUPPLIER')], 'CUSTOMER')\n ),\n recordStatus: v.optional(\n v.union(\n [\n v.literal('ENABLED'),\n v.literal('DISABLED'),\n v.literal('WARNING'),\n v.literal('BLACKLISTED'),\n ],\n 'ENABLED'\n )\n ),\n moniker: v.optional(v.string()),\n name: v.optional(v.string()),\n extraInfo: v.optional(v.string()),\n languageCode: v.pipe(v.string(), v.minLength(2), v.maxLength(2)),\n address: v.optional(v.string()),\n zipCode: v.optional(v.string()),\n cityName: v.optional(v.string()),\n countyCode: v.optional(v.string()),\n stateCode: v.optional(v.string()),\n categoryCode: v.optional(v.string()),\n firstPhoneNumber: v.optional(v.string()),\n mobilePhoneNumber: v.optional(v.string()),\n email: v.optional(v.string()),\n gender: v.optional(v.string()),\n birthDate: v.optional(v.string()),\n fiscalCode: v.optional(v.string()),\n vatCode: v.optional(v.string()),\n financialDetail: v.optional(FinancialDetailInputSchema),\n dynamicFields: v.optional(v.array(DynamicFieldsInputSchema)),\n});\n\n/**\n * Master record detail schema for API requests (transforms to PascalCase)\n */\nexport const MasterRecordDetailApiSchema = createApiSchema(\n MasterRecordDetailSchema\n);\n\n/**\n * Master record detail response schema (transforms to camelCase)\n */\nexport const MasterRecordDetailResponseSchema = createResponseSchema(\n MasterRecordDetailApiSchema\n);\n","import * as v from 'valibot';\nimport type { BaseSchema } from 'valibot';\nimport { camelToPascalKeys, pascalToCamelKeys } from './case-transform.js';\n\n/**\n * Creates a schema that transforms camelCase input to PascalCase for API requests\n */\nexport function createApiSchema<TInput extends BaseSchema<any, any, any>>(\n inputSchema: TInput\n) {\n return v.pipe(\n inputSchema,\n v.transform((input) => camelToPascalKeys(input))\n );\n}\n\n/**\n * Creates a schema that transforms PascalCase API responses to camelCase\n */\nexport function createResponseSchema<TApi extends BaseSchema<any, any, any>>(\n apiSchema: TApi\n) {\n return v.pipe(\n apiSchema,\n v.transform((input) => pascalToCamelKeys(input))\n );\n}\n","type CamelFromDelimiter<S extends string> = S extends `${infer H}_${infer T}`\n ? `${H}${Capitalize<CamelFromDelimiter<T>>}`\n : S extends `${infer H}-${infer T}`\n ? `${H}${Capitalize<CamelFromDelimiter<T>>}`\n : S;\n\ntype ToCamelCase<S extends string> =\n CamelFromDelimiter<S> extends `${infer F}${infer R}`\n ? `${Lowercase<F>}${R}`\n : CamelFromDelimiter<S>;\n\ntype PascalFromDelimiter<S extends string> = S extends `${infer H}_${infer T}`\n ? `${Capitalize<H>}${Capitalize<PascalFromDelimiter<T>>}`\n : S extends `${infer H}-${infer T}`\n ? `${Capitalize<H>}${Capitalize<PascalFromDelimiter<T>>}`\n : S;\n\ntype ToPascalCase<S extends string> =\n PascalFromDelimiter<S> extends `${infer F}${infer R}`\n ? `${Capitalize<F>}${R}`\n : Capitalize<PascalFromDelimiter<S>>;\n\nexport type Camelize<T> = T extends readonly (infer U)[]\n ? Camelize<U>[]\n : T extends object\n ? {\n [K in keyof T as K extends `@${infer Rest}`\n ? ToCamelCase<Rest> // Strip @ prefix and camelCase the rest\n : ToCamelCase<K & string>]: Camelize<T[K]>;\n }\n : T;\n\nexport type Pascalize<T> = T extends readonly (infer U)[]\n ? Pascalize<U>[]\n : T extends object\n ? {\n [K in keyof T as K extends `@${infer Rest}`\n ? ToPascalCase<Rest> // Strip @ prefix and PascalCase the rest\n : ToPascalCase<K & string>]: Pascalize<T[K]>;\n }\n : T;\n\nfunction camelToPascal(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nfunction pascalToCamel(str: string): string {\n return str.charAt(0).toLowerCase() + str.slice(1);\n}\n\nconst ATTRIBUTE_FIELDS = new Set([\n 'recordCode',\n 'insertCriteria',\n 'currencyCode',\n 'creditLimit',\n 'c_PaymentType',\n 'c_SpecPaymentTypeCode',\n 's_PaymentType',\n 's_SpecPaymentTypeCode',\n 'key',\n 'value',\n 'minDate',\n 'maxDate',\n 'hostID',\n 'xtoken',\n 'interface',\n 'userName',\n 'status',\n]);\n\n/**\n * Transforms object keys from camelCase to PascalCase\n * Adds @ prefix to fields in ATTRIBUTE_FIELDS for XML attributes\n */\nexport function camelToPascalKeys<T>(obj: T): Pascalize<T> {\n if (!obj || typeof obj !== 'object') {\n return obj as Pascalize<T>;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => camelToPascalKeys(item)) as Pascalize<T>;\n }\n\n if (\n obj instanceof Date ||\n obj instanceof RegExp ||\n obj instanceof Map ||\n obj instanceof Set ||\n obj instanceof Error\n ) {\n return obj as Pascalize<T>;\n }\n\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n const isAttribute = ATTRIBUTE_FIELDS.has(key);\n const pascalKey = camelToPascal(key);\n const finalKey = isAttribute ? `@${pascalKey}` : pascalKey;\n\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n if (\n value instanceof Date ||\n value instanceof RegExp ||\n value instanceof Map ||\n value instanceof Set ||\n value instanceof Error\n ) {\n result[finalKey] = value;\n } else {\n result[finalKey] = camelToPascalKeys(value as Record<string, unknown>);\n }\n } else if (Array.isArray(value)) {\n result[finalKey] = value.map((item) =>\n typeof item === 'object' && item && !Array.isArray(item)\n ? camelToPascalKeys(item as Record<string, unknown>)\n : item\n );\n } else {\n result[finalKey] = value;\n }\n }\n return result as Pascalize<T>;\n}\n\n/**\n * Transforms object keys from PascalCase to camelCase\n * Strips @ prefix from XML attributes\n */\nexport function pascalToCamelKeys<T>(obj: T): Camelize<T> {\n if (!obj || typeof obj !== 'object') {\n return obj as Camelize<T>;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => pascalToCamelKeys(item)) as Camelize<T>;\n }\n\n if (\n obj instanceof Date ||\n obj instanceof RegExp ||\n obj instanceof Map ||\n obj instanceof Set ||\n obj instanceof Error\n ) {\n return obj as Camelize<T>;\n }\n\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n if (key.startsWith('@')) {\n const strippedKey = key.slice(1);\n const camelKey = pascalToCamel(strippedKey);\n result[camelKey] = value;\n } else {\n const camelKey = pascalToCamel(key);\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n if (\n value instanceof Date ||\n value instanceof RegExp ||\n value instanceof Map ||\n value instanceof Set ||\n value instanceof Error\n ) {\n result[camelKey] = value;\n } else {\n result[camelKey] = pascalToCamelKeys(\n value as Record<string, unknown>\n );\n }\n } else if (Array.isArray(value)) {\n result[camelKey] = value.map((item) =>\n typeof item === 'object' && item && !Array.isArray(item)\n ? pascalToCamelKeys(item as Record<string, unknown>)\n : item\n );\n } else {\n result[camelKey] = value;\n }\n }\n }\n return result as Camelize<T>;\n}\n","import * as v from 'valibot';\nimport { RqHeaderSchema, RsStatusSchema } from './common.js';\nimport { FinancialDetailSchema, DynamicFieldsSchema } from './master-record.js';\nimport { createResponseSchema } from '../utils/schema-transform.js';\n\nconst CustomerRecordApiSchema = v.object({\n CustomerRecordCode: v.pipe(\n v.union([v.string(), v.number()]),\n v.transform((val) => String(val)),\n v.minLength(6),\n v.maxLength(6)\n ),\n});\n\nconst MasterRecordDetailApiValidationSchema = v.object({\n '@RecordCode': v.optional(v.pipe(v.string(), v.minLength(6), v.maxLength(6))),\n '@InsertCriteria': v.optional(\n v.union([v.literal('S'), v.literal('N'), v.literal('T'), v.literal('M')])\n ),\n CreatedDate: v.optional(v.string()),\n RecordType: v.optional(\n v.union([v.literal('CUSTOMER'), v.literal('SUPPLIER')])\n ),\n RecordStatus: v.optional(\n v.union(\n [\n v.literal('ENABLED'),\n v.literal('DISABLED'),\n v.literal('WARNING'),\n v.literal('BLACKLISTED'),\n ],\n 'ENABLED'\n )\n ),\n Moniker: v.optional(v.string()),\n Name: v.optional(v.string()),\n LanguageCode: v.optional(v.pipe(v.string(), v.minLength(2), v.maxLength(2))),\n Address: v.optional(v.string()),\n ZipCode: v.optional(v.string()),\n CityName: v.optional(v.string()),\n CountyCode: v.optional(v.string()),\n StateCode: v.optional(v.string()),\n CategoryCode: v.optional(v.string()),\n FirstPhoneNumber: v.optional(v.string()),\n MobilePhoneNumber: v.optional(v.string()),\n Email: v.optional(v.string()),\n Gender: v.optional(v.string()),\n BirthDate: v.optional(v.string()),\n FiscalCode: v.optional(v.string()),\n NewsletterDisabled: v.optional(\n v.union([v.literal('true'), v.literal('false'), v.boolean()])\n ),\n FinancialDetail: v.optional(FinancialDetailSchema),\n DynamicFields: v.optional(v.array(DynamicFieldsSchema)),\n});\n\n/**\n * Complete upsert request schema with header and required InsertCriteria\n */\nexport const ManageMasterRecordRequestSchema = v.object({\n RqHeader: RqHeaderSchema,\n MasterRecordDetail: v.intersect([\n MasterRecordDetailApiValidationSchema,\n v.object({\n '@InsertCriteria': v.union([\n v.literal('S'),\n v.literal('N'),\n v.literal('T'),\n v.literal('M'),\n ]),\n }),\n ]),\n});\n\n/**\n * Upsert master record response schema (transforms to camelCase)\n */\nexport const ManageMasterRecordResponseSchema = createResponseSchema(\n v.object({\n RsStatus: RsStatusSchema,\n CustomerRecordRS: v.optional(CustomerRecordApiSchema),\n })\n);\n","/**\n * Result type for functional error handling\n */\nexport type Result<T, E = Error> =\n | { success: true; data: T }\n | { success: false; error: E };\n\n/**\n * Creates a successful result\n */\nexport function ok<T>(data: T): Result<T, never> {\n return { success: true, data };\n}\n\n/**\n * Creates an error result\n */\nexport function err<E>(error: E): Result<never, E> {\n return { success: false, error };\n}\n"],"mappings":"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","names":["index_exports","__export","AvesClient","AvesError","__toCommonJS","import_undici","import_valibot","import_fast_xml_parser","parserOptions","builderOptions","parser","builder","jsonToXml","json","xmlToJson","xml","v","v","RqHeaderSchema","warningsSchema","input","RsStatusSchema","v","v","camelToPascal","str","pascalToCamel","ATTRIBUTE_FIELDS","camelToPascalKeys","obj","item","result","key","value","isAttribute","pascalKey","finalKey","pascalToCamelKeys","strippedKey","camelKey","createApiSchema","inputSchema","input","camelToPascalKeys","createResponseSchema","apiSchema","pascalToCamelKeys","FinancialDetailInputSchema","FinancialDetailSchema","createApiSchema","DynamicFieldsInputSchema","DynamicFieldsSchema","MasterRecordDetailSchema","MasterRecordDetailApiSchema","MasterRecordDetailResponseSchema","createResponseSchema","LastModificationDateInputSchema","languageCodeField","CodeSearchSchema","NameSearchSchema","VatCodeSearchSchema","ZoneSearchSchema","CategorySearchSchema","EmailSearchSchema","LastModDateSearchSchema","SearchFieldSearchSchema","ExternalRefCodeSearchSchema","SearchMasterRecordSchema","SearchMasterRecordApiSchema","createApiSchema","SearchMasterRecordRequestSchema","RqHeaderSchema","MasterRecordDetailApiValidationSchema","val","FinancialDetailSchema","DynamicFieldsSchema","MasterRecordListApiSchema","input","SearchMasterRecordResponseSchema","createResponseSchema","RsStatusSchema","v","CustomerRecordApiSchema","val","MasterRecordDetailApiValidationSchema","FinancialDetailSchema","DynamicFieldsSchema","ManageMasterRecordRequestSchema","RqHeaderSchema","ManageMasterRecordResponseSchema","createResponseSchema","RsStatusSchema","ok","data","err","error","createRootElement","name","object","XML_ROOT_ELEMENTS","AvesError","message","status","errorCode","errorDescription","AvesClient","baseURL","hostID","xtoken","languageCode","endpoint","output","rsStatus","err","warnings","ok","error","defaultMessage","requestBody","responseRootKey","responseSchema","url","xmlBody","jsonToXml","response","r","responseText","rootElement","xmlToJson","parseResult","i","params","requestData","SearchMasterRecordRequestSchema","SearchMasterRecordResponseSchema","record","masterRecordDetail","MasterRecordDetailApiSchema","ManageMasterRecordRequestSchema","ManageMasterRecordResponseSchema"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/client.ts","../src/xml-client.ts","../src/error.ts","../src/schemas/search.ts","../src/schemas/common.ts","../src/schemas/master-record.ts","../src/utils/schema-transform.ts","../src/utils/case-transform.ts","../src/schemas/upsert.ts","../src/utils/result.ts","../src/utils/url.ts","../src/utils/timeout.ts"],"sourcesContent":["// Main client\nexport { AvesClient, type AvesClientOptions } from './client.js';\nexport { AvesError } from './error.js';\n\n// Types\nexport type {\n RqHeader,\n RsStatus,\n FinancialDetail,\n MasterRecordDetail,\n MasterRecordDetailResponse,\n SearchMasterRecord,\n SearchMasterRecordRS,\n ManageMasterRecordRequest,\n ManageMasterRecordRS,\n} from './types.js';\n","import { request as r } from 'undici';\nimport { BaseIssue, BaseSchema, parse, safeParse, ValiError } from 'valibot';\nimport { jsonToXml, xmlToJson } from './xml-client.js';\nimport {\n SearchMasterRecordRequestSchema,\n SearchMasterRecordResponseSchema,\n} from './schemas/search.js';\nimport {\n ManageMasterRecordRequestSchema,\n ManageMasterRecordResponseSchema,\n} from './schemas/upsert.js';\nimport type {\n AvesClientOptions,\n ManageMasterRecordRS,\n MasterRecordDetail,\n RsStatus,\n SearchMasterRecord,\n SearchMasterRecordRS,\n} from './types.js';\nimport { MasterRecordDetailApiSchema } from './schemas/master-record.js';\nimport type { Result } from './utils/result.js';\nimport { err, ok } from './utils/result.js';\nimport {\n apiError,\n AvesError,\n buildDetails,\n isAbortError,\n unknownError,\n validationError,\n} from './error.js';\nimport { parseUrl } from './utils/url.js';\nimport { createTimeoutSignal } from './utils/timeout.js';\n\nfunction createRootElement<T>(name: XMLRootElementValues, object: T) {\n return {\n [name]: object,\n };\n}\n\nconst XML_ROOT_ELEMENTS = {\n SEARCH_REQUEST: 'SearchMasterRecordRQ',\n SEARCH_RESPONSE: 'SearchMasterRecordRS',\n UPSERT_REQUEST: 'ManageMasterRecordRQ',\n UPSERT_RESPONSE: 'ManageMasterRecordRS',\n} as const;\n\ntype XMLRootElementValues =\n (typeof XML_ROOT_ELEMENTS)[keyof typeof XML_ROOT_ELEMENTS];\n\n/**\n * AVES XML REST API client\n */\nexport class AvesClient {\n /**\n * @param options - Client configuration options\n * @param options.baseURL - Base URL of the AVES API\n * @param options.hostID - 6-digit identification code\n * @param options.xtoken - Authentication token\n * @param options.languageCode - Optional 2-digit language code\n * @param options.timeoutMs - Optional request timeout in milliseconds\n */\n constructor(private readonly options: AvesClientOptions) {}\n\n private createRqHeader() {\n return {\n '@HostID': this.options.hostID,\n '@Xtoken': this.options.xtoken,\n '@Interface': 'WEB' as const,\n '@UserName': 'WEB' as const,\n ...(this.options.languageCode && {\n '@LanguageCode': this.options.languageCode,\n }),\n };\n }\n\n private createUrl(endpoint: string) {\n return parseUrl(this.options.baseURL, endpoint);\n }\n\n private get endpoints() {\n return {\n search: '/interop/masterRecords/v2/rest/Search',\n upsert: '/interop/masterRecords/v2/rest/InsertOrUpdate',\n } as const;\n }\n\n private handleApiStatus<T extends { rsStatus: RsStatus }>(\n output: T,\n ): Result<T, AvesError> {\n const rsStatus = output.rsStatus;\n const status = rsStatus?.status;\n\n if (status !== 'OK') {\n return err(\n apiError(\n rsStatus.errorDescription as string,\n status,\n rsStatus.errorCode,\n ),\n );\n }\n\n return ok(output);\n }\n\n private toAvesError(error: unknown, defaultMessage: string): AvesError {\n if (error instanceof AvesError) {\n return error;\n }\n if (error instanceof ValiError) {\n const details = buildDetails(error.issues);\n return validationError(`Validation error: ${details}`);\n }\n if (error instanceof Error) {\n return unknownError(error.message);\n }\n return unknownError(defaultMessage);\n }\n\n private async request<T extends { rsStatus: RsStatus }>(\n endpoint: string,\n requestBody: Record<string, unknown>,\n responseRootKey: string,\n responseSchema: BaseSchema<unknown, T, BaseIssue<unknown>>,\n ): Promise<Result<T, AvesError>> {\n const { signal, clear } = createTimeoutSignal(\n this.options.timeoutMs ?? 30_000,\n );\n\n try {\n const url = this.createUrl(endpoint);\n const xmlBody = jsonToXml(requestBody);\n\n const response = await r(url, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/xml',\n },\n body: xmlBody,\n signal,\n });\n\n const responseText = await response.body.text();\n\n if (response.statusCode !== 200) {\n return err(apiError(responseText, 'ERROR', response.statusCode));\n }\n\n const jsonResponse = xmlToJson(responseText);\n const rootElement = jsonResponse[responseRootKey];\n\n if (!rootElement) {\n return err(\n validationError(\n `Invalid response structure: missing root element '${responseRootKey}'`,\n ),\n );\n }\n\n const parseResult = safeParse(responseSchema, rootElement);\n if (!parseResult.success) {\n const details = buildDetails(parseResult.issues);\n return err(validationError(`Invalid response format: ${details}`));\n }\n return this.handleApiStatus(parseResult.output);\n } catch (error) {\n if (isAbortError(error)) {\n return err(apiError('Request timed out', 'TIMEOUT'));\n }\n return err(this.toAvesError(error, 'Unknown error occurred'));\n } finally {\n clear?.();\n }\n }\n\n /**\n * Search for master records\n * @returns Result containing list of matching master records in camelCase or error\n */\n async search(\n params: SearchMasterRecord,\n ): Promise<Result<SearchMasterRecordRS, AvesError>> {\n try {\n const requestData = parse(SearchMasterRecordRequestSchema, {\n RqHeader: this.createRqHeader(),\n SearchMasterRecord: params,\n });\n\n const requestBody = createRootElement(\n XML_ROOT_ELEMENTS.SEARCH_REQUEST,\n requestData,\n );\n\n return this.request<SearchMasterRecordRS>(\n this.endpoints.search,\n requestBody,\n XML_ROOT_ELEMENTS.SEARCH_RESPONSE,\n SearchMasterRecordResponseSchema,\n );\n } catch (error) {\n return err(\n this.toAvesError(error, 'Validation error occurred during search'),\n );\n }\n }\n\n /**\n * Insert or update a master record\n * @param record - Master record data in camelCase\n * @returns Result containing response with customer record code in camelCase or error\n */\n async upsertRecord(\n record: MasterRecordDetail,\n ): Promise<Result<ManageMasterRecordRS, AvesError>> {\n try {\n const apiRecord = parse(MasterRecordDetailApiSchema, record);\n\n const requestData = parse(ManageMasterRecordRequestSchema, {\n RqHeader: this.createRqHeader(),\n MasterRecordDetail: apiRecord,\n });\n\n const requestBody = createRootElement(\n XML_ROOT_ELEMENTS.UPSERT_REQUEST,\n requestData,\n );\n\n return this.request<ManageMasterRecordRS>(\n this.endpoints.upsert,\n requestBody,\n XML_ROOT_ELEMENTS.UPSERT_RESPONSE,\n ManageMasterRecordResponseSchema,\n );\n } catch (error) {\n return err(\n this.toAvesError(error, 'Validation error occurred during upsert'),\n );\n }\n }\n}\n","import { XMLParser, XMLBuilder } from 'fast-xml-parser';\nimport { AvesError } from './error.js';\n\nconst parserOptions = {\n ignoreAttributes: false,\n attributeNamePrefix: '@',\n parseAttributeValue: false,\n trimValues: true,\n ignoreNameSpace: true,\n removeNSPrefix: true,\n parseTagValue: false,\n};\n\nconst builderOptions = {\n ignoreAttributes: false,\n attributeNamePrefix: '@',\n suppressEmptyNode: true,\n};\n\nconst parser = new XMLParser(parserOptions);\nconst builder = new XMLBuilder(builderOptions);\n\n/**\n * Converts JSON to XML string\n */\nexport function jsonToXml(json: Record<string, unknown>): string {\n try {\n return builder.build(json);\n } catch (error) {\n throw new AvesError(\n 'validation',\n `Failed to convert JSON to XML: ${error instanceof Error ? error.message : 'Unknown error'}`,\n );\n }\n}\n\n/**\n * Converts XML string to JSON object\n * Attributes are parsed with @ prefix\n */\nexport function xmlToJson(xml: string): Record<string, unknown> {\n try {\n return parser.parse(xml);\n } catch (error) {\n throw new AvesError(\n 'validation',\n `Failed to convert XML to JSON: ${error instanceof Error ? error.message : 'Unknown error'}`,\n );\n }\n}\n","import { BaseIssue } from 'valibot';\n\nexport const ERROR_KINDS = {\n VALIDATION: 'validation',\n API: 'api',\n UNKNOWN: 'unknown',\n} as const;\n\nexport type ErrorKind = (typeof ERROR_KINDS)[keyof typeof ERROR_KINDS];\n\n/**\n * Error thrown by AVES API operations\n */\nexport class AvesError extends Error {\n constructor(\n public readonly kind: ErrorKind,\n public readonly message: string,\n public readonly status?: string,\n public readonly code?: number | string,\n ) {\n super(message);\n this.name = 'AvesError';\n this.status = status?.toLowerCase();\n this.code = this.parseCode(code);\n }\n\n private parseCode(code?: number | string): number {\n if (typeof code === 'string') {\n return Number.parseInt(code);\n }\n return code ?? 0;\n }\n}\n\nexport function validationError(message: string): AvesError {\n return new AvesError(ERROR_KINDS.VALIDATION, message);\n}\n\nexport function apiError(\n message: string,\n status?: string,\n code?: number | string,\n): AvesError {\n return new AvesError(ERROR_KINDS.API, message, status, code);\n}\n\nexport function unknownError(message: string): AvesError {\n return new AvesError(ERROR_KINDS.UNKNOWN, message);\n}\n\nexport function buildDetails(issues: readonly BaseIssue<unknown>[]): string {\n return issues\n .map((issue) => {\n const path =\n issue.path && issue.path.length > 0\n ? issue.path\n .map((segment) =>\n typeof segment === 'string' || typeof segment === 'number'\n ? String(segment)\n : 'key' in segment\n ? String((segment as any).key)\n : '',\n )\n .filter(Boolean)\n .join('.')\n : undefined;\n\n const text = issue.message ?? 'Invalid value';\n return path ? `${path}: ${text}` : text;\n })\n .join('; ');\n}\n\nexport function isAbortError(error: unknown): boolean {\n return error instanceof Error && error.name === 'AbortError';\n}\n","import * as v from 'valibot';\nimport { RqHeaderSchema, RsStatusSchema } from './common.js';\nimport { MasterRecordDetailApiValidationSchema } from './master-record.js';\nimport {\n createApiSchema,\n createResponseSchema,\n} from '../utils/schema-transform.js';\n\nconst LastModificationDateInputSchema = v.object({\n minDate: v.string(),\n maxDate: v.string(),\n});\n\nconst languageCodeField = v.optional(\n v.pipe(v.string(), v.minLength(2), v.maxLength(2)),\n);\n\n/**\n * Search by CODE - requires recordCode\n */\nconst CodeSearchSchema = v.object({\n searchType: v.literal('CODE'),\n recordCode: v.pipe(v.string(), v.minLength(5), v.maxLength(6)),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by NAME - requires name, optionally city\n */\nconst NameSearchSchema = v.object({\n searchType: v.literal('NAME'),\n name: v.string(),\n city: v.optional(v.string()),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by VATCODE - requires vatCode, optionally phoneNumber\n */\nconst VatCodeSearchSchema = v.object({\n searchType: v.literal('VATCODE'),\n vatCode: v.string(),\n phoneNumber: v.optional(v.string()),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by ZONE - requires zipCode and countyCode, optionally city\n */\nconst ZoneSearchSchema = v.object({\n searchType: v.literal('ZONE'),\n zipCode: v.string(),\n countyCode: v.string(),\n city: v.optional(v.string()),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by CATEGORY - requires categoryCode\n */\nconst CategorySearchSchema = v.object({\n searchType: v.literal('CATEGORY'),\n categoryCode: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by EMAIL - requires email\n */\nconst EmailSearchSchema = v.object({\n searchType: v.literal('EMAIL'),\n email: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by LASTMODDATE - requires lastModificationDate\n */\nconst LastModDateSearchSchema = v.object({\n searchType: v.literal('LASTMODDATE'),\n lastModificationDate: LastModificationDateInputSchema,\n languageCode: languageCodeField,\n});\n\n/**\n * Search by SEARCH FIELD - requires searchFieldValue\n */\nconst SearchFieldSearchSchema = v.object({\n searchType: v.literal('SEARCH_FIELD'),\n searchFieldValue: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by EXTERNAL_REF_CODE - requires searchFieldValue\n */\nconst ExternalRefCodeSearchSchema = v.object({\n searchType: v.literal('EXTERNAL_REF_CODE'),\n searchFieldValue: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search master record input schema (camelCase)\n * Conditional fields based on searchType\n */\nexport const SearchMasterRecordSchema = v.union([\n CodeSearchSchema,\n NameSearchSchema,\n VatCodeSearchSchema,\n ZoneSearchSchema,\n CategorySearchSchema,\n EmailSearchSchema,\n LastModDateSearchSchema,\n SearchFieldSearchSchema,\n ExternalRefCodeSearchSchema,\n]);\n\nconst transformRecordCode = (input: Record<string, unknown>) => {\n if (!('@RecordCode' in input)) return input;\n const recordCode = input['@RecordCode'];\n if (!recordCode) return input;\n const { ['@RecordCode']: _discard, ...rest } = input;\n return {\n ...rest,\n RecordCode: recordCode,\n };\n};\n\n/**\n * Search master record schema for API requests (transforms to PascalCase)\n */\nexport const SearchMasterRecordApiSchema = v.pipe(\n createApiSchema(SearchMasterRecordSchema),\n v.transform((input) => transformRecordCode(input)),\n);\n\n/**\n * Complete search request schema with header\n * Flattens SearchMasterRecord fields to root level\n */\nexport const SearchMasterRecordRequestSchema = v.pipe(\n v.object({\n RqHeader: RqHeaderSchema,\n SearchMasterRecord: SearchMasterRecordApiSchema,\n }),\n v.transform((input) => {\n const { SearchMasterRecord: searchFields, RqHeader, ...rest } = input;\n return {\n RqHeader,\n ...searchFields,\n ...rest,\n };\n }),\n);\n\nconst MasterRecordListApiSchema = v.object({\n MasterRecordDetail: v.optional(\n v.pipe(\n v.union([\n v.array(MasterRecordDetailApiValidationSchema),\n MasterRecordDetailApiValidationSchema,\n ]),\n v.transform((input) => {\n if (!input) return undefined;\n return Array.isArray(input) ? input : [input];\n }),\n ),\n ),\n});\n\n/**\n * Search master record response schema (transforms to camelCase)\n */\nexport const SearchMasterRecordResponseSchema = createResponseSchema(\n v.object({\n RsStatus: RsStatusSchema,\n MasterRecordList: v.optional(MasterRecordListApiSchema),\n }),\n);\n","import * as v from 'valibot';\n\n/**\n * Request header schema with authentication credentials\n */\nexport const RqHeaderSchema = v.object({\n '@HostID': v.pipe(v.string(), v.minLength(6), v.maxLength(6)),\n '@Xtoken': v.string(),\n '@Interface': v.literal('WEB'),\n '@UserName': v.literal('WEB'),\n '@LanguageCode': v.optional(\n v.pipe(v.string(), v.minLength(2), v.maxLength(2)),\n ),\n});\n\nconst warningsSchema = v.optional(\n v.pipe(\n v.string(),\n v.transform((input) => input.split(',')),\n ),\n);\n\n/**\n * Response status schema indicating success, error, or warning\n */\nexport const RsStatusSchema = v.pipe(\n v.object({\n '@Status': v.union([\n v.literal('OK'),\n v.literal('ERROR'),\n v.literal('WARNING'),\n v.literal('TIMEOUT'),\n ]),\n ErrorCode: v.optional(\n v.pipe(\n v.union([v.string(), v.number()]),\n v.transform((val) => Number(val)),\n ),\n ),\n ErrorDescription: v.optional(v.string()),\n Warnings: warningsSchema,\n }),\n v.transform((input) => {\n return {\n status: input['@Status'],\n errorCode: input.ErrorCode,\n errorDescription: input.ErrorDescription,\n warnings: input.Warnings,\n };\n }),\n);\n","import * as v from 'valibot';\nimport {\n createApiSchema,\n createResponseSchema,\n createApiValidationSchema,\n} from '../utils/schema-transform.js';\n\nconst paymentTypeSchema = v.union([\n v.literal('CASH'),\n v.literal('BANK'),\n v.literal('RID'),\n v.literal('RIBA'),\n v.literal('SPECIFIC_CODE'),\n]);\n\nconst FinancialDetailInputSchema = v.object({\n currencyCode: v.optional(v.string()),\n creditLimit: v.optional(v.string()),\n c_PaymentType: v.optional(paymentTypeSchema),\n c_SpecPaymentTypeCode: v.optional(v.string()),\n s_PaymentType: v.optional(paymentTypeSchema),\n s_SpecPaymentTypeCode: v.optional(v.string()),\n enableElectronicInvoicing: v.optional(v.union([v.literal('true'), v.literal('false'), v.boolean()])),\n electronicInvoicingType: v.optional(v.string()),\n});\n\n/**\n * Financial detail schema for API requests (transforms to PascalCase)\n */\nexport const FinancialDetailSchema = createApiSchema(\n FinancialDetailInputSchema,\n);\n\n/**\n * Financial detail validation schema (already transformed PascalCase with @ attributes)\n */\nexport const FinancialDetailApiValidationSchema = createApiValidationSchema(\n FinancialDetailInputSchema,\n);\n\nconst DynamicFieldsInputSchema = v.object({\n key: v.string(),\n value: v.string(),\n});\n\n/**\n * Dynamic fields schema for API requests (transforms to PascalCase)\n */\nexport const DynamicFieldsSchema = createApiSchema(DynamicFieldsInputSchema);\n\n/**\n * Dynamic fields validation schema (already transformed PascalCase with @ attributes)\n */\nexport const DynamicFieldsApiValidationSchema = createApiValidationSchema(\n DynamicFieldsInputSchema,\n);\n\nconst flagSchema = v.union([v.literal(0), v.literal(1)]);\n\nconst recordStatusSchema = v.union([\n v.literal('ENABLED'),\n v.literal('DISABLED'),\n v.literal('WARNING'),\n v.literal('BLACKLISTED'),\n]);\n\nconst recordTypeSchema = v.union([\n v.literal('CUSTOMER'),\n v.literal('SUPPLIER'),\n v.literal('GENERAL'),\n]);\n\nconst insertCriteriaSchema = v.union([\n v.literal('S'),\n v.literal('N'),\n v.literal('T'),\n v.literal('M'),\n]);\n\nconst AccountPoliciesInputSchema = v.object({\n acceptProfilingPolicies: v.optional(flagSchema),\n acceptPrivacyPolicies: v.optional(flagSchema),\n acceptNewsletterPolicies: v.optional(flagSchema),\n});\n\n/**\n * Account policies schema for API requests (transforms to PascalCase with @ attributes)\n */\nexport const AccountPoliciesSchema = createApiSchema(\n AccountPoliciesInputSchema,\n);\n\n/**\n * Account policies validation schema (already transformed PascalCase with @ attributes)\n */\nexport const AccountPoliciesApiValidationSchema = createApiValidationSchema(\n AccountPoliciesInputSchema,\n);\n\n/**\n * Master record detail input schema (camelCase)\n */\nexport const MasterRecordDetailSchema = v.object({\n recordCode: v.optional(v.pipe(v.string(), v.minLength(6), v.maxLength(6))),\n insertCriteria: v.optional(insertCriteriaSchema),\n createdDate: v.optional(v.string()),\n recordType: v.optional(v.union([recordTypeSchema], 'CUSTOMER')),\n recordStatus: v.optional(v.union([recordStatusSchema], 'ENABLED')),\n moniker: v.optional(v.string()),\n name: v.optional(v.string()),\n extraInfo: v.optional(v.string()),\n languageCode: v.pipe(v.string(), v.minLength(2), v.maxLength(2)),\n address: v.optional(v.string()),\n zipCode: v.optional(v.string()),\n cityName: v.optional(v.string()),\n countyCode: v.optional(v.string()),\n stateCode: v.optional(v.string()),\n categoryCode: v.optional(v.string()),\n firstPhoneNumber: v.optional(v.string()),\n mobilePhoneNumber: v.optional(v.string()),\n email: v.optional(v.string()),\n gender: v.optional(v.string()),\n birthDate: v.optional(v.string()),\n fiscalCode: v.optional(v.string()),\n vatCode: v.optional(v.string()),\n accountPolicies: v.optional(AccountPoliciesInputSchema),\n financialDetail: v.optional(FinancialDetailInputSchema),\n dynamicFields: v.optional(DynamicFieldsInputSchema),\n});\n\n/**\n * Master record detail schema for API requests (transforms to PascalCase)\n */\nexport const MasterRecordDetailApiSchema = createApiSchema(\n MasterRecordDetailSchema,\n);\n\n/**\n * Master record detail response schema (transforms to camelCase)\n */\nexport const MasterRecordDetailResponseSchema = createResponseSchema(\n MasterRecordDetailApiSchema,\n);\n\n/**\n * Master record detail API validation schema (PascalCase with @ attributes)\n * Used for both search responses and upsert requests\n * All fields are optional as responses may not contain all fields\n */\nexport const MasterRecordDetailApiValidationSchema = v.object({\n '@RecordCode': v.optional(v.pipe(v.string(), v.minLength(5), v.maxLength(6))),\n '@InsertCriteria': v.optional(insertCriteriaSchema),\n CreatedDate: v.optional(v.string()),\n ModifiedDate: v.optional(v.string()),\n RecordType: v.optional(\n v.union([\n v.literal('CUSTOMER'),\n v.literal('SUPPLIER'),\n v.literal('GENERAL'),\n ]),\n ),\n LoginType: v.optional(v.string()),\n RecordStatus: v.optional(recordStatusSchema),\n Moniker: v.optional(v.string()),\n Name: v.optional(v.string()),\n ExtraInfo: v.optional(v.string()),\n LanguageCode: v.optional(v.pipe(v.string(), v.minLength(1), v.maxLength(2))),\n Address: v.optional(v.string()),\n ZipCode: v.optional(v.string()),\n CityName: v.optional(v.string()),\n CountyCode: v.optional(v.string()),\n StateCode: v.optional(v.string()),\n CategoryCode: v.optional(v.string()),\n PromoterCode: v.optional(v.string()),\n FirstPhoneNumber: v.optional(v.string()),\n MobilePhoneNumber: v.optional(v.string()),\n Email: v.optional(v.string()),\n Gender: v.optional(v.string()),\n BirthDate: v.optional(v.string()),\n EncryptedPassword: v.optional(v.union([v.literal('true'), v.literal('false'), v.boolean()])),\n FiscalCode: v.optional(v.string()),\n VatCode: v.optional(v.string()),\n NewsletterDisabled: v.optional(v.union([v.literal('true'), v.literal('false'), v.boolean()])),\n SupplierRefMasterRecords: v.optional(v.any()),\n AccountPolicies: v.optional(AccountPoliciesApiValidationSchema),\n FinancialDetail: v.optional(FinancialDetailApiValidationSchema),\n DynamicFields: v.optional(v.array(DynamicFieldsApiValidationSchema)),\n});\n","import * as v from 'valibot';\nimport type { BaseSchema, ObjectEntries } from 'valibot';\nimport {\n camelToPascalKeys,\n pascalToCamelKeys,\n ATTRIBUTE_FIELDS,\n} from './case-transform.js';\n\n/**\n * Creates a schema that transforms camelCase input to PascalCase for API requests\n */\nexport function createApiSchema<TInput extends BaseSchema<any, any, any>>(\n inputSchema: TInput,\n) {\n return v.pipe(\n inputSchema,\n v.transform((input) => camelToPascalKeys(input)),\n );\n}\n\n/**\n * Creates a schema that transforms PascalCase API responses to camelCase\n */\nexport function createResponseSchema<TApi extends BaseSchema<any, any, any>>(\n apiSchema: TApi,\n) {\n return v.pipe(\n apiSchema,\n v.transform((input) => pascalToCamelKeys(input)),\n );\n}\n\n/**\n * Creates a validation schema for already-transformed PascalCase data with @ attributes\n * Used for nested objects like AccountPolicies, FinancialDetail, DynamicFields\n * Takes the same input schema used in createApiSchema and generates the validation schema\n * by directly using the ATTRIBUTE_FIELDS logic to determine which fields become attributes\n */\nexport function createApiValidationSchema<TEntries extends ObjectEntries>(\n inputSchema: v.ObjectSchema<TEntries, any>,\n) {\n const validationEntries: Record<string, any> = {};\n\n // Build validation schema based on ATTRIBUTE_FIELDS\n for (const key in inputSchema.entries) {\n const isAttribute = ATTRIBUTE_FIELDS.has(key);\n const pascalKey = key.charAt(0).toUpperCase() + key.slice(1);\n const finalKey = isAttribute ? `@${pascalKey}` : pascalKey;\n\n validationEntries[finalKey] = inputSchema.entries[key];\n }\n\n return v.object(validationEntries as TEntries);\n}\n","type CamelFromDelimiter<S extends string> = S extends `${infer H}_${infer T}`\n ? `${H}${Capitalize<CamelFromDelimiter<T>>}`\n : S extends `${infer H}-${infer T}`\n ? `${H}${Capitalize<CamelFromDelimiter<T>>}`\n : S;\n\ntype ToCamelCase<S extends string> =\n CamelFromDelimiter<S> extends `${infer F}${infer R}`\n ? `${Lowercase<F>}${R}`\n : CamelFromDelimiter<S>;\n\ntype PascalFromDelimiter<S extends string> = S extends `${infer H}_${infer T}`\n ? `${Capitalize<H>}${Capitalize<PascalFromDelimiter<T>>}`\n : S extends `${infer H}-${infer T}`\n ? `${Capitalize<H>}${Capitalize<PascalFromDelimiter<T>>}`\n : S;\n\ntype ToPascalCase<S extends string> =\n PascalFromDelimiter<S> extends `${infer F}${infer R}`\n ? `${Capitalize<F>}${R}`\n : Capitalize<PascalFromDelimiter<S>>;\n\nexport type Camelize<T> = T extends readonly (infer U)[]\n ? Camelize<U>[]\n : T extends object\n ? {\n [K in keyof T as K extends `@${infer Rest}`\n ? ToCamelCase<Rest> // Strip @ prefix and camelCase the rest\n : ToCamelCase<K & string>]: Camelize<T[K]>;\n }\n : T;\n\nexport type Pascalize<T> = T extends readonly (infer U)[]\n ? Pascalize<U>[]\n : T extends object\n ? {\n [K in keyof T as K extends `@${infer Rest}`\n ? ToPascalCase<Rest> // Strip @ prefix and PascalCase the rest\n : ToPascalCase<K & string>]: Pascalize<T[K]>;\n }\n : T;\n\nfunction camelToPascal(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nfunction pascalToCamel(str: string): string {\n return str.charAt(0).toLowerCase() + str.slice(1);\n}\n\n/**\n * Checks if an object is a special built-in type that should not be transformed\n */\nfunction isSpecialObject(obj: unknown): boolean {\n return (\n obj instanceof Date ||\n obj instanceof RegExp ||\n obj instanceof Map ||\n obj instanceof Set ||\n obj instanceof Error\n );\n}\n\nexport const ATTRIBUTE_FIELDS = new Set([\n 'recordCode',\n 'insertCriteria',\n 'currencyCode',\n 'creditLimit',\n 'c_PaymentType',\n 'c_SpecPaymentTypeCode',\n 's_PaymentType',\n 's_SpecPaymentTypeCode',\n 'enableElectronicInvoicing',\n 'electronicInvoicingType',\n 'key',\n 'value',\n 'minDate',\n 'maxDate',\n 'hostID',\n 'xtoken',\n 'interface',\n 'userName',\n 'status',\n 'acceptProfilingPolicies',\n 'acceptPrivacyPolicies',\n 'acceptNewsletterPolicies',\n]);\n\n/**\n * Transforms object keys from camelCase to PascalCase\n * Adds @ prefix to fields in ATTRIBUTE_FIELDS for XML attributes\n */\nexport function camelToPascalKeys<T>(obj: T): Pascalize<T> {\n if (!obj || typeof obj !== 'object') {\n return obj as Pascalize<T>;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => camelToPascalKeys(item)) as Pascalize<T>;\n }\n\n if (isSpecialObject(obj)) {\n return obj as Pascalize<T>;\n }\n\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n const isAttribute = ATTRIBUTE_FIELDS.has(key);\n const pascalKey = camelToPascal(key);\n const finalKey = isAttribute ? `@${pascalKey}` : pascalKey;\n\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n if (isSpecialObject(value)) {\n result[finalKey] = value;\n } else {\n result[finalKey] = camelToPascalKeys(value as Record<string, unknown>);\n }\n } else if (Array.isArray(value)) {\n result[finalKey] = value.map((item) =>\n typeof item === 'object' && item && !Array.isArray(item)\n ? camelToPascalKeys(item as Record<string, unknown>)\n : item,\n );\n } else {\n result[finalKey] = value;\n }\n }\n return result as Pascalize<T>;\n}\n\n/**\n * Transforms object keys from PascalCase to camelCase\n * Strips @ prefix from XML attributes\n */\nexport function pascalToCamelKeys<T>(obj: T): Camelize<T> {\n if (!obj || typeof obj !== 'object') {\n return obj as Camelize<T>;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => pascalToCamelKeys(item)) as Camelize<T>;\n }\n\n if (isSpecialObject(obj)) {\n return obj as Camelize<T>;\n }\n\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n if (key.startsWith('@')) {\n const strippedKey = key.slice(1);\n const camelKey = pascalToCamel(strippedKey);\n result[camelKey] = value;\n } else {\n const camelKey = pascalToCamel(key);\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n if (isSpecialObject(value)) {\n result[camelKey] = value;\n } else {\n result[camelKey] = pascalToCamelKeys(\n value as Record<string, unknown>,\n );\n }\n } else if (Array.isArray(value)) {\n result[camelKey] = value.map((item) =>\n typeof item === 'object' && item && !Array.isArray(item)\n ? pascalToCamelKeys(item as Record<string, unknown>)\n : item,\n );\n } else {\n result[camelKey] = value;\n }\n }\n }\n return result as Camelize<T>;\n}\n","import * as v from 'valibot';\nimport { RqHeaderSchema, RsStatusSchema } from './common.js';\nimport { MasterRecordDetailApiValidationSchema } from './master-record.js';\nimport { createResponseSchema } from '../utils/schema-transform.js';\n\n/**\n * Complete upsert request schema with header and required InsertCriteria\n */\nexport const ManageMasterRecordRequestSchema = v.object({\n RqHeader: RqHeaderSchema,\n MasterRecordDetail: MasterRecordDetailApiValidationSchema,\n});\n\n/**\n * Upsert master record response schema (transforms to camelCase)\n */\nexport const ManageMasterRecordResponseSchema = createResponseSchema(\n v.object({\n RsStatus: RsStatusSchema,\n MasterRecordDetail: v.optional(MasterRecordDetailApiValidationSchema),\n }),\n);\n","/**\n * Result type for functional error handling\n */\nexport type Result<T, E = Error> =\n | { success: true; data: T }\n | { success: false; error: E };\n\n/**\n * Creates a successful result\n */\nexport function ok<T>(data: T): Result<T, never> {\n return { success: true, data };\n}\n\n/**\n * Creates an error result\n */\nexport function err<E>(error: E): Result<never, E> {\n return { success: false, error };\n}\n","import { AvesError } from '../error.js';\n\nfunction buildUrl(baseURL: string, endpoint: string): URL {\n try {\n const base = new URL(baseURL);\n const basePath = base.pathname.endsWith('/')\n ? base.pathname.slice(0, -1)\n : base.pathname;\n const combinedPath = basePath + endpoint;\n\n return new URL(combinedPath, base);\n } catch (error) {\n throw new AvesError(\n 'validation',\n `Invalid baseURL: ${error instanceof Error ? error.message : 'Invalid URL format'}`,\n );\n }\n}\n\n/**\n * Validates and combines baseURL with endpoint\n * @param baseURL - Base URL (must be http:// or https://)\n * @param endpoint - Endpoint path (must start with /)\n * @returns Combined URL string\n * @throws AvesError if URL is invalid or protocol is not http/https\n */\nexport function parseUrl(baseURL: string, endpoint: string): string {\n if (!endpoint.startsWith('/')) {\n throw new AvesError(\n 'validation',\n `Invalid endpoint: endpoint must start with '/' but got '${endpoint}'`,\n );\n }\n\n const normalizedBaseURL = baseURL.replace(/\\/$/, '');\n\n const url = buildUrl(normalizedBaseURL, endpoint);\n\n if (url.protocol !== 'http:' && url.protocol !== 'https:') {\n throw new AvesError(\n 'validation',\n `Invalid protocol: baseURL must use http:// or https:// but got '${url.protocol}'`,\n );\n }\n\n return url.toString();\n}\n","export interface TimeoutController {\n signal: AbortSignal;\n clear?: () => void;\n}\n\n/**\n * Create an AbortSignal that will automatically abort after `timeoutMs`.\n * If `timeoutMs` is not provided or <= 0, no automatic abort is scheduled.\n */\nexport function createTimeoutSignal(timeoutMs?: number): TimeoutController {\n const controller = new AbortController();\n\n if (!timeoutMs || timeoutMs <= 0) {\n return { signal: controller.signal };\n }\n\n const timeoutId = setTimeout(() => controller.abort(), timeoutMs);\n\n return {\n signal: controller.signal,\n clear: () => clearTimeout(timeoutId),\n };\n}\n"],"mappings":"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","names":["index_exports","__export","AvesClient","AvesError","__toCommonJS","import_undici","import_valibot","import_fast_xml_parser","ERROR_KINDS","AvesError","kind","message","status","code","validationError","apiError","unknownError","buildDetails","issues","issue","path","segment","text","isAbortError","error","parserOptions","builderOptions","parser","builder","jsonToXml","json","error","AvesError","xmlToJson","xml","v","v","RqHeaderSchema","warningsSchema","input","RsStatusSchema","val","v","v","camelToPascal","str","pascalToCamel","isSpecialObject","obj","ATTRIBUTE_FIELDS","camelToPascalKeys","item","result","key","value","isAttribute","pascalKey","finalKey","pascalToCamelKeys","strippedKey","camelKey","createApiSchema","inputSchema","input","camelToPascalKeys","createResponseSchema","apiSchema","pascalToCamelKeys","createApiValidationSchema","validationEntries","key","isAttribute","ATTRIBUTE_FIELDS","pascalKey","finalKey","paymentTypeSchema","FinancialDetailInputSchema","FinancialDetailSchema","createApiSchema","FinancialDetailApiValidationSchema","createApiValidationSchema","DynamicFieldsInputSchema","DynamicFieldsSchema","DynamicFieldsApiValidationSchema","flagSchema","recordStatusSchema","recordTypeSchema","insertCriteriaSchema","AccountPoliciesInputSchema","AccountPoliciesSchema","AccountPoliciesApiValidationSchema","MasterRecordDetailSchema","MasterRecordDetailApiSchema","MasterRecordDetailResponseSchema","createResponseSchema","MasterRecordDetailApiValidationSchema","LastModificationDateInputSchema","languageCodeField","CodeSearchSchema","NameSearchSchema","VatCodeSearchSchema","ZoneSearchSchema","CategorySearchSchema","EmailSearchSchema","LastModDateSearchSchema","SearchFieldSearchSchema","ExternalRefCodeSearchSchema","SearchMasterRecordSchema","transformRecordCode","input","recordCode","_discard","rest","SearchMasterRecordApiSchema","createApiSchema","SearchMasterRecordRequestSchema","RqHeaderSchema","searchFields","RqHeader","MasterRecordListApiSchema","MasterRecordDetailApiValidationSchema","SearchMasterRecordResponseSchema","createResponseSchema","RsStatusSchema","v","ManageMasterRecordRequestSchema","RqHeaderSchema","MasterRecordDetailApiValidationSchema","ManageMasterRecordResponseSchema","createResponseSchema","RsStatusSchema","ok","data","err","error","buildUrl","baseURL","endpoint","base","combinedPath","error","AvesError","parseUrl","normalizedBaseURL","url","createTimeoutSignal","timeoutMs","controller","timeoutId","createRootElement","name","object","XML_ROOT_ELEMENTS","AvesClient","options","endpoint","parseUrl","output","rsStatus","status","err","apiError","ok","error","defaultMessage","AvesError","details","buildDetails","validationError","unknownError","requestBody","responseRootKey","responseSchema","signal","clear","createTimeoutSignal","url","xmlBody","jsonToXml","response","r","responseText","rootElement","xmlToJson","parseResult","isAbortError","params","requestData","SearchMasterRecordRequestSchema","SearchMasterRecordResponseSchema","record","apiRecord","MasterRecordDetailApiSchema","ManageMasterRecordRequestSchema","ManageMasterRecordResponseSchema"]}
|
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{request as ge}from"undici";import{parse as x,safeParse as Re}from"valibot";import{XMLParser as K,XMLBuilder as j}from"fast-xml-parser";var V={ignoreAttributes:!1,attributeNamePrefix:"@",parseAttributeValue:!0,parseTrueNumberOnly:!1,trimValues:!0,ignoreNameSpace:!0,removeNSPrefix:!0,parseTagValue:!0},W={ignoreAttributes:!1,attributeNamePrefix:"@",suppressEmptyNode:!1},X=new K(V),G=new j(W);function I(a){return G.build(a)}function b(a){return X.parse(a)}import*as e from"valibot";import*as i from"valibot";var C=i.object({"@HostID":i.pipe(i.string(),i.minLength(6),i.maxLength(6)),"@Xtoken":i.string(),"@Interface":i.literal("WEB"),"@UserName":i.literal("WEB"),"@LanguageCode":i.optional(i.pipe(i.string(),i.minLength(2),i.maxLength(2)))}),Q=i.optional(i.pipe(i.string(),i.transform(a=>a.split(",")))),T=i.object({"@Status":i.union([i.literal("OK"),i.literal("ERROR"),i.literal("WARNING"),i.literal("TIMEOUT")]),ErrorCode:i.optional(i.string()),ErrorDescription:i.optional(i.string()),Warnings:Q});import*as t from"valibot";import*as g from"valibot";function Z(a){return a.charAt(0).toUpperCase()+a.slice(1)}function F(a){return a.charAt(0).toLowerCase()+a.slice(1)}var J=new Set(["recordCode","insertCriteria","currencyCode","creditLimit","c_PaymentType","c_SpecPaymentTypeCode","s_PaymentType","s_SpecPaymentTypeCode","key","value","minDate","maxDate","hostID","xtoken","interface","userName","status"]);function h(a){if(!a||typeof a!="object")return a;if(Array.isArray(a))return a.map(s=>h(s));if(a instanceof Date||a instanceof RegExp||a instanceof Map||a instanceof Set||a instanceof Error)return a;let o={};for(let[s,n]of Object.entries(a)){let l=J.has(s),c=Z(s),u=l?`@${c}`:c;n&&typeof n=="object"&&!Array.isArray(n)?n instanceof Date||n instanceof RegExp||n instanceof Map||n instanceof Set||n instanceof Error?o[u]=n:o[u]=h(n):Array.isArray(n)?o[u]=n.map(p=>typeof p=="object"&&p&&!Array.isArray(p)?h(p):p):o[u]=n}return o}function f(a){if(!a||typeof a!="object")return a;if(Array.isArray(a))return a.map(s=>f(s));if(a instanceof Date||a instanceof RegExp||a instanceof Map||a instanceof Set||a instanceof Error)return a;let o={};for(let[s,n]of Object.entries(a))if(s.startsWith("@")){let l=s.slice(1),c=F(l);o[c]=n}else{let l=F(s);n&&typeof n=="object"&&!Array.isArray(n)?n instanceof Date||n instanceof RegExp||n instanceof Map||n instanceof Set||n instanceof Error?o[l]=n:o[l]=f(n):Array.isArray(n)?o[l]=n.map(c=>typeof c=="object"&&c&&!Array.isArray(c)?f(c):c):o[l]=n}return o}function R(a){return g.pipe(a,g.transform(o=>h(o)))}function S(a){return g.pipe(a,g.transform(o=>f(o)))}var O=t.object({currencyCode:t.string(),creditLimit:t.optional(t.string()),c_PaymentType:t.optional(t.union([t.literal("CASH"),t.literal("BANK"),t.literal("RID"),t.literal("RIBA"),t.literal("SPECIFIC_CODE")])),c_SpecPaymentTypeCode:t.optional(t.string()),s_PaymentType:t.optional(t.union([t.literal("CASH"),t.literal("BANK"),t.literal("RID"),t.literal("RIBA"),t.literal("SPECIFIC_CODE")])),s_SpecPaymentTypeCode:t.optional(t.string())}),E=R(O),w=t.object({key:t.string(),value:t.string()}),D=R(w),Y=t.object({recordCode:t.optional(t.pipe(t.string(),t.minLength(6),t.maxLength(6))),insertCriteria:t.optional(t.union([t.literal("S"),t.literal("N"),t.literal("T"),t.literal("M")])),createdDate:t.optional(t.string()),recordType:t.optional(t.union([t.literal("CUSTOMER"),t.literal("SUPPLIER")],"CUSTOMER")),recordStatus:t.optional(t.union([t.literal("ENABLED"),t.literal("DISABLED"),t.literal("WARNING"),t.literal("BLACKLISTED")],"ENABLED")),moniker:t.optional(t.string()),name:t.optional(t.string()),extraInfo:t.optional(t.string()),languageCode:t.pipe(t.string(),t.minLength(2),t.maxLength(2)),address:t.optional(t.string()),zipCode:t.optional(t.string()),cityName:t.optional(t.string()),countyCode:t.optional(t.string()),stateCode:t.optional(t.string()),categoryCode:t.optional(t.string()),firstPhoneNumber:t.optional(t.string()),mobilePhoneNumber:t.optional(t.string()),email:t.optional(t.string()),gender:t.optional(t.string()),birthDate:t.optional(t.string()),fiscalCode:t.optional(t.string()),vatCode:t.optional(t.string()),financialDetail:t.optional(O),dynamicFields:t.optional(t.array(w))}),M=R(Y),Ae=S(M);var ee=e.object({minDate:e.string(),maxDate:e.string()}),m=e.optional(e.pipe(e.string(),e.minLength(2),e.maxLength(2))),te=e.object({searchType:e.literal("CODE"),recordCode:e.pipe(e.string(),e.minLength(6),e.maxLength(6)),languageCode:m}),re=e.object({searchType:e.literal("NAME"),name:e.string(),city:e.optional(e.string()),languageCode:m}),ae=e.object({searchType:e.literal("VATCODE"),vatCode:e.string(),phoneNumber:e.optional(e.string()),languageCode:m}),ne=e.object({searchType:e.literal("ZONE"),zipCode:e.string(),countyCode:e.string(),city:e.optional(e.string()),languageCode:m}),oe=e.object({searchType:e.literal("CATEGORY"),categoryCode:e.string(),languageCode:m}),ie=e.object({searchType:e.literal("EMAIL"),email:e.string(),languageCode:m}),se=e.object({searchType:e.literal("LASTMODDATE"),lastModificationDate:ee,languageCode:m}),ce=e.object({searchType:e.literal("SEARCH_FIELD"),searchFieldValue:e.string(),languageCode:m}),le=e.object({searchType:e.literal("EXTERNAL_REF_CODE"),searchFieldValue:e.string(),languageCode:m}),ve=e.union([te,re,ae,ne,oe,ie,se,ce,le]),pe=R(ve),_=e.object({RqHeader:C,SearchMasterRecord:pe}),$=e.object({"@RecordCode":e.optional(e.pipe(e.union([e.string(),e.number()]),e.transform(a=>String(a)),e.minLength(6),e.maxLength(6))),"@InsertCriteria":e.optional(e.union([e.literal("S"),e.literal("N"),e.literal("T"),e.literal("M")])),CreatedDate:e.optional(e.string()),RecordType:e.optional(e.union([e.literal("CUSTOMER"),e.literal("SUPPLIER")])),RecordStatus:e.optional(e.union([e.literal("ENABLED"),e.literal("DISABLED"),e.literal("WARNING"),e.literal("BLACKLISTED")],"ENABLED")),Moniker:e.optional(e.string()),Name:e.optional(e.string()),LanguageCode:e.optional(e.pipe(e.string(),e.minLength(2),e.maxLength(2))),Address:e.optional(e.string()),ZipCode:e.optional(e.string()),CityName:e.optional(e.string()),CountyCode:e.optional(e.string()),StateCode:e.optional(e.string()),CategoryCode:e.optional(e.string()),FirstPhoneNumber:e.optional(e.string()),MobilePhoneNumber:e.optional(e.string()),Email:e.optional(e.string()),Gender:e.optional(e.string()),BirthDate:e.optional(e.string()),FiscalCode:e.optional(e.string()),NewsletterDisabled:e.optional(e.union([e.literal("true"),e.literal("false"),e.boolean()])),FinancialDetail:e.optional(E),DynamicFields:e.optional(e.array(D))}),me=e.object({MasterRecordDetail:e.optional(e.pipe(e.union([e.array($),$]),e.transform(a=>{if(a)return Array.isArray(a)?a:[a]})))}),U=S(e.object({RsStatus:T,MasterRecordList:e.optional(me)}));import*as r from"valibot";var de=r.object({CustomerRecordCode:r.pipe(r.union([r.string(),r.number()]),r.transform(a=>String(a)),r.minLength(6),r.maxLength(6))}),ue=r.object({"@RecordCode":r.optional(r.pipe(r.string(),r.minLength(6),r.maxLength(6))),"@InsertCriteria":r.optional(r.union([r.literal("S"),r.literal("N"),r.literal("T"),r.literal("M")])),CreatedDate:r.optional(r.string()),RecordType:r.optional(r.union([r.literal("CUSTOMER"),r.literal("SUPPLIER")])),RecordStatus:r.optional(r.union([r.literal("ENABLED"),r.literal("DISABLED"),r.literal("WARNING"),r.literal("BLACKLISTED")],"ENABLED")),Moniker:r.optional(r.string()),Name:r.optional(r.string()),LanguageCode:r.optional(r.pipe(r.string(),r.minLength(2),r.maxLength(2))),Address:r.optional(r.string()),ZipCode:r.optional(r.string()),CityName:r.optional(r.string()),CountyCode:r.optional(r.string()),StateCode:r.optional(r.string()),CategoryCode:r.optional(r.string()),FirstPhoneNumber:r.optional(r.string()),MobilePhoneNumber:r.optional(r.string()),Email:r.optional(r.string()),Gender:r.optional(r.string()),BirthDate:r.optional(r.string()),FiscalCode:r.optional(r.string()),NewsletterDisabled:r.optional(r.union([r.literal("true"),r.literal("false"),r.boolean()])),FinancialDetail:r.optional(E),DynamicFields:r.optional(r.array(D))}),B=r.object({RqHeader:C,MasterRecordDetail:r.intersect([ue,r.object({"@InsertCriteria":r.union([r.literal("S"),r.literal("N"),r.literal("T"),r.literal("M")])})])}),k=S(r.object({RsStatus:T,CustomerRecordRS:r.optional(de)}));function H(a){return{success:!0,data:a}}function d(a){return{success:!1,error:a}}function z(a,o){return{[a]:o}}var A={SEARCH_REQUEST:"SearchMasterRecordRQ",SEARCH_RESPONSE:"SearchMasterRecordRS",UPSERT_REQUEST:"ManageMasterRecordRQ",UPSERT_RESPONSE:"ManageMasterRecordRS"},v=class extends Error{constructor(s,n,l,c){super(s);this.status=n;this.errorCode=l;this.errorDescription=c;this.name="AvesError"}},L=class{constructor(o,s,n,l){this.baseURL=o;this.hostID=s;this.xtoken=n;this.languageCode=l;this.baseURL=o.replace(/\/$/,"")}createRqHeader(){return{"@HostID":this.hostID,"@Xtoken":this.xtoken,"@Interface":"WEB","@UserName":"WEB",...this.languageCode&&{"@LanguageCode":this.languageCode}}}createUrl(o){return`${this.baseURL}${o}`}get endpoints(){return{search:"/interop/masterRecords/v2/rest/Search",upsert:"/interop/masterRecords/v2/rest/InsertOrUpdate"}}handleApiStatus(o,s){let n=s?.status;if(n==="ERROR"||n==="TIMEOUT")return d(new v(s.errorDescription||`API Error: ${n}`,n,s.errorCode,s.errorDescription));if(n==="WARNING"){let l=s.warnings?.join(", ");console.warn("AVES API Warning:",l)}return H(o)}toAvesError(o,s){return o instanceof v?o:o instanceof Error?new v(o.message):new v(s)}async request(o,s,n,l){try{let c=this.createUrl(o),u=I(s),p=await ge(c,{method:"POST",headers:{"Content-Type":"application/xml"},body:u}),P=await p.body.text();if(p.statusCode!==200)return d(new v(P,p.statusCode.toString()));let N=b(P)[n];if(!N)return d(new v(`Invalid response structure: missing root element '${n}'`,void 0,"VALIDATION_ERROR"));let y=Re(l,N);return y.success?this.handleApiStatus(y.output,y.output.rsStatus):d(new v(`Invalid response format: ${y.issues.map(q=>q.message).join(", ")}`,"400","VALIDATION_ERROR"))}catch(c){return d(this.toAvesError(c,"Unknown error occurred"))}}async search(o){try{let s=x(_,{RqHeader:this.createRqHeader(),SearchMasterRecord:o}),n=z(A.SEARCH_REQUEST,s);return await this.request(this.endpoints.search,n,A.SEARCH_RESPONSE,U)}catch(s){return d(this.toAvesError(s,"Validation error occurred during search"))}}async upsertRecord(o){try{let n={"@InsertCriteria":"T",...x(M,o)},l=x(B,{RqHeader:this.createRqHeader(),MasterRecordDetail:n}),c=z(A.UPSERT_REQUEST,l);return await this.request(this.endpoints.upsert,c,A.UPSERT_RESPONSE,k)}catch(s){return d(this.toAvesError(s,"Validation error occurred during upsert"))}}};export{L as AvesClient,v as AvesError};
|
|
1
|
+
import{request as Oe}from"undici";import{parse as _,safeParse as Ue,ValiError as ke}from"valibot";import{XMLParser as ie,XMLBuilder as se}from"fast-xml-parser";var L={VALIDATION:"validation",API:"api",UNKNOWN:"unknown"},l=class extends Error{constructor(a,n,s,c){super(n);this.kind=a;this.message=n;this.status=s;this.code=c;this.name="AvesError",this.status=s?.toLowerCase(),this.code=this.parseCode(c)}parseCode(a){return typeof a=="string"?Number.parseInt(a):a??0}};function E(t){return new l(L.VALIDATION,t)}function T(t,r,a){return new l(L.API,t,r,a)}function I(t){return new l(L.UNKNOWN,t)}function N(t){return t.map(r=>{let a=r.path&&r.path.length>0?r.path.map(s=>typeof s=="string"||typeof s=="number"?String(s):"key"in s?String(s.key):"").filter(Boolean).join("."):void 0,n=r.message??"Invalid value";return a?`${a}: ${n}`:n}).join("; ")}function H(t){return t instanceof Error&&t.name==="AbortError"}var ce={ignoreAttributes:!1,attributeNamePrefix:"@",parseAttributeValue:!1,trimValues:!0,ignoreNameSpace:!0,removeNSPrefix:!0,parseTagValue:!1},le={ignoreAttributes:!1,attributeNamePrefix:"@",suppressEmptyNode:!0},pe=new ie(ce),ve=new se(le);function z(t){try{return ve.build(t)}catch(r){throw new l("validation",`Failed to convert JSON to XML: ${r instanceof Error?r.message:"Unknown error"}`)}}function q(t){try{return pe.parse(t)}catch(r){throw new l("validation",`Failed to convert XML to JSON: ${r instanceof Error?r.message:"Unknown error"}`)}}import*as o from"valibot";import*as i from"valibot";var C=i.object({"@HostID":i.pipe(i.string(),i.minLength(6),i.maxLength(6)),"@Xtoken":i.string(),"@Interface":i.literal("WEB"),"@UserName":i.literal("WEB"),"@LanguageCode":i.optional(i.pipe(i.string(),i.minLength(2),i.maxLength(2)))}),me=i.optional(i.pipe(i.string(),i.transform(t=>t.split(",")))),A=i.pipe(i.object({"@Status":i.union([i.literal("OK"),i.literal("ERROR"),i.literal("WARNING"),i.literal("TIMEOUT")]),ErrorCode:i.optional(i.pipe(i.union([i.string(),i.number()]),i.transform(t=>Number(t)))),ErrorDescription:i.optional(i.string()),Warnings:me}),i.transform(t=>({status:t["@Status"],errorCode:t.ErrorCode,errorDescription:t.ErrorDescription,warnings:t.Warnings})));import*as e from"valibot";import*as d from"valibot";function de(t){return t.charAt(0).toUpperCase()+t.slice(1)}function V(t){return t.charAt(0).toLowerCase()+t.slice(1)}function x(t){return t instanceof Date||t instanceof RegExp||t instanceof Map||t instanceof Set||t instanceof Error}var w=new Set(["recordCode","insertCriteria","currencyCode","creditLimit","c_PaymentType","c_SpecPaymentTypeCode","s_PaymentType","s_SpecPaymentTypeCode","enableElectronicInvoicing","electronicInvoicingType","key","value","minDate","maxDate","hostID","xtoken","interface","userName","status","acceptProfilingPolicies","acceptPrivacyPolicies","acceptNewsletterPolicies"]);function h(t){if(!t||typeof t!="object")return t;if(Array.isArray(t))return t.map(a=>h(a));if(x(t))return t;let r={};for(let[a,n]of Object.entries(t)){let s=w.has(a),c=de(a),g=s?`@${c}`:c;n&&typeof n=="object"&&!Array.isArray(n)?x(n)?r[g]=n:r[g]=h(n):Array.isArray(n)?r[g]=n.map(p=>typeof p=="object"&&p&&!Array.isArray(p)?h(p):p):r[g]=n}return r}function f(t){if(!t||typeof t!="object")return t;if(Array.isArray(t))return t.map(a=>f(a));if(x(t))return t;let r={};for(let[a,n]of Object.entries(t))if(a.startsWith("@")){let s=a.slice(1),c=V(s);r[c]=n}else{let s=V(a);n&&typeof n=="object"&&!Array.isArray(n)?x(n)?r[s]=n:r[s]=f(n):Array.isArray(n)?r[s]=n.map(c=>typeof c=="object"&&c&&!Array.isArray(c)?f(c):c):r[s]=n}return r}function u(t){return d.pipe(t,d.transform(r=>h(r)))}function R(t){return d.pipe(t,d.transform(r=>f(r)))}function M(t){let r={};for(let a in t.entries){let n=w.has(a),s=a.charAt(0).toUpperCase()+a.slice(1),c=n?`@${s}`:s;r[c]=t.entries[a]}return d.object(r)}var X=e.union([e.literal("CASH"),e.literal("BANK"),e.literal("RID"),e.literal("RIBA"),e.literal("SPECIFIC_CODE")]),U=e.object({currencyCode:e.optional(e.string()),creditLimit:e.optional(e.string()),c_PaymentType:e.optional(X),c_SpecPaymentTypeCode:e.optional(e.string()),s_PaymentType:e.optional(X),s_SpecPaymentTypeCode:e.optional(e.string()),enableElectronicInvoicing:e.optional(e.union([e.literal("true"),e.literal("false"),e.boolean()])),electronicInvoicingType:e.optional(e.string())}),Xe=u(U),ue=M(U),k=e.object({key:e.string(),value:e.string()}),We=u(k),ge=M(k),O=e.union([e.literal(0),e.literal(1)]),W=e.union([e.literal("ENABLED"),e.literal("DISABLED"),e.literal("WARNING"),e.literal("BLACKLISTED")]),Re=e.union([e.literal("CUSTOMER"),e.literal("SUPPLIER"),e.literal("GENERAL")]),G=e.union([e.literal("S"),e.literal("N"),e.literal("T"),e.literal("M")]),$=e.object({acceptProfilingPolicies:e.optional(O),acceptPrivacyPolicies:e.optional(O),acceptNewsletterPolicies:e.optional(O)}),Ge=u($),Se=M($),he=e.object({recordCode:e.optional(e.pipe(e.string(),e.minLength(6),e.maxLength(6))),insertCriteria:e.optional(G),createdDate:e.optional(e.string()),recordType:e.optional(e.union([Re],"CUSTOMER")),recordStatus:e.optional(e.union([W],"ENABLED")),moniker:e.optional(e.string()),name:e.optional(e.string()),extraInfo:e.optional(e.string()),languageCode:e.pipe(e.string(),e.minLength(2),e.maxLength(2)),address:e.optional(e.string()),zipCode:e.optional(e.string()),cityName:e.optional(e.string()),countyCode:e.optional(e.string()),stateCode:e.optional(e.string()),categoryCode:e.optional(e.string()),firstPhoneNumber:e.optional(e.string()),mobilePhoneNumber:e.optional(e.string()),email:e.optional(e.string()),gender:e.optional(e.string()),birthDate:e.optional(e.string()),fiscalCode:e.optional(e.string()),vatCode:e.optional(e.string()),accountPolicies:e.optional($),financialDetail:e.optional(U),dynamicFields:e.optional(k)}),F=u(he),Qe=R(F),S=e.object({"@RecordCode":e.optional(e.pipe(e.string(),e.minLength(5),e.maxLength(6))),"@InsertCriteria":e.optional(G),CreatedDate:e.optional(e.string()),ModifiedDate:e.optional(e.string()),RecordType:e.optional(e.union([e.literal("CUSTOMER"),e.literal("SUPPLIER"),e.literal("GENERAL")])),LoginType:e.optional(e.string()),RecordStatus:e.optional(W),Moniker:e.optional(e.string()),Name:e.optional(e.string()),ExtraInfo:e.optional(e.string()),LanguageCode:e.optional(e.pipe(e.string(),e.minLength(1),e.maxLength(2))),Address:e.optional(e.string()),ZipCode:e.optional(e.string()),CityName:e.optional(e.string()),CountyCode:e.optional(e.string()),StateCode:e.optional(e.string()),CategoryCode:e.optional(e.string()),PromoterCode:e.optional(e.string()),FirstPhoneNumber:e.optional(e.string()),MobilePhoneNumber:e.optional(e.string()),Email:e.optional(e.string()),Gender:e.optional(e.string()),BirthDate:e.optional(e.string()),EncryptedPassword:e.optional(e.union([e.literal("true"),e.literal("false"),e.boolean()])),FiscalCode:e.optional(e.string()),VatCode:e.optional(e.string()),NewsletterDisabled:e.optional(e.union([e.literal("true"),e.literal("false"),e.boolean()])),SupplierRefMasterRecords:e.optional(e.any()),AccountPolicies:e.optional(Se),FinancialDetail:e.optional(ue),DynamicFields:e.optional(e.array(ge))});var fe=o.object({minDate:o.string(),maxDate:o.string()}),v=o.optional(o.pipe(o.string(),o.minLength(2),o.maxLength(2))),ye=o.object({searchType:o.literal("CODE"),recordCode:o.pipe(o.string(),o.minLength(5),o.maxLength(6)),languageCode:v}),Ee=o.object({searchType:o.literal("NAME"),name:o.string(),city:o.optional(o.string()),languageCode:v}),Te=o.object({searchType:o.literal("VATCODE"),vatCode:o.string(),phoneNumber:o.optional(o.string()),languageCode:v}),Ce=o.object({searchType:o.literal("ZONE"),zipCode:o.string(),countyCode:o.string(),city:o.optional(o.string()),languageCode:v}),Ae=o.object({searchType:o.literal("CATEGORY"),categoryCode:o.string(),languageCode:v}),xe=o.object({searchType:o.literal("EMAIL"),email:o.string(),languageCode:v}),Me=o.object({searchType:o.literal("LASTMODDATE"),lastModificationDate:fe,languageCode:v}),De=o.object({searchType:o.literal("SEARCH_FIELD"),searchFieldValue:o.string(),languageCode:v}),be=o.object({searchType:o.literal("EXTERNAL_REF_CODE"),searchFieldValue:o.string(),languageCode:v}),Pe=o.union([ye,Ee,Te,Ce,Ae,xe,Me,De,be]),Le=t=>{if(!("@RecordCode"in t))return t;let r=t["@RecordCode"];if(!r)return t;let{["@RecordCode"]:a,...n}=t;return{...n,RecordCode:r}},Ie=o.pipe(u(Pe),o.transform(t=>Le(t))),Q=o.pipe(o.object({RqHeader:C,SearchMasterRecord:Ie}),o.transform(t=>{let{SearchMasterRecord:r,RqHeader:a,...n}=t;return{RqHeader:a,...r,...n}})),Ne=o.object({MasterRecordDetail:o.optional(o.pipe(o.union([o.array(S),S]),o.transform(t=>{if(t)return Array.isArray(t)?t:[t]})))}),J=R(o.object({RsStatus:A,MasterRecordList:o.optional(Ne)}));import*as y from"valibot";var Z=y.object({RqHeader:C,MasterRecordDetail:S}),Y=R(y.object({RsStatus:A,MasterRecordDetail:y.optional(S)}));function ee(t){return{success:!0,data:t}}function m(t){return{success:!1,error:t}}function we(t,r){try{let a=new URL(t),s=(a.pathname.endsWith("/")?a.pathname.slice(0,-1):a.pathname)+r;return new URL(s,a)}catch(a){throw new l("validation",`Invalid baseURL: ${a instanceof Error?a.message:"Invalid URL format"}`)}}function te(t,r){if(!r.startsWith("/"))throw new l("validation",`Invalid endpoint: endpoint must start with '/' but got '${r}'`);let a=t.replace(/\/$/,""),n=we(a,r);if(n.protocol!=="http:"&&n.protocol!=="https:")throw new l("validation",`Invalid protocol: baseURL must use http:// or https:// but got '${n.protocol}'`);return n.toString()}function re(t){let r=new AbortController;if(!t||t<=0)return{signal:r.signal};let a=setTimeout(()=>r.abort(),t);return{signal:r.signal,clear:()=>clearTimeout(a)}}function oe(t,r){return{[t]:r}}var D={SEARCH_REQUEST:"SearchMasterRecordRQ",SEARCH_RESPONSE:"SearchMasterRecordRS",UPSERT_REQUEST:"ManageMasterRecordRQ",UPSERT_RESPONSE:"ManageMasterRecordRS"},K=class{constructor(r){this.options=r}createRqHeader(){return{"@HostID":this.options.hostID,"@Xtoken":this.options.xtoken,"@Interface":"WEB","@UserName":"WEB",...this.options.languageCode&&{"@LanguageCode":this.options.languageCode}}}createUrl(r){return te(this.options.baseURL,r)}get endpoints(){return{search:"/interop/masterRecords/v2/rest/Search",upsert:"/interop/masterRecords/v2/rest/InsertOrUpdate"}}handleApiStatus(r){let a=r.rsStatus,n=a?.status;return n!=="OK"?m(T(a.errorDescription,n,a.errorCode)):ee(r)}toAvesError(r,a){if(r instanceof l)return r;if(r instanceof ke){let n=N(r.issues);return E(`Validation error: ${n}`)}return r instanceof Error?I(r.message):I(a)}async request(r,a,n,s){let{signal:c,clear:g}=re(this.options.timeoutMs??3e4);try{let p=this.createUrl(r),ae=z(a),b=await Oe(p,{method:"POST",headers:{"Content-Type":"application/xml"},body:ae,signal:c}),j=await b.body.text();if(b.statusCode!==200)return m(T(j,"ERROR",b.statusCode));let B=q(j)[n];if(!B)return m(E(`Invalid response structure: missing root element '${n}'`));let P=Ue(s,B);if(!P.success){let ne=N(P.issues);return m(E(`Invalid response format: ${ne}`))}return this.handleApiStatus(P.output)}catch(p){return H(p)?m(T("Request timed out","TIMEOUT")):m(this.toAvesError(p,"Unknown error occurred"))}finally{g?.()}}async search(r){try{let a=_(Q,{RqHeader:this.createRqHeader(),SearchMasterRecord:r}),n=oe(D.SEARCH_REQUEST,a);return this.request(this.endpoints.search,n,D.SEARCH_RESPONSE,J)}catch(a){return m(this.toAvesError(a,"Validation error occurred during search"))}}async upsertRecord(r){try{let a=_(F,r),n=_(Z,{RqHeader:this.createRqHeader(),MasterRecordDetail:a}),s=oe(D.UPSERT_REQUEST,n);return this.request(this.endpoints.upsert,s,D.UPSERT_RESPONSE,Y)}catch(a){return m(this.toAvesError(a,"Validation error occurred during upsert"))}}};export{K as AvesClient,l as AvesError};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/client.ts","../src/xml-client.ts","../src/schemas/search.ts","../src/schemas/common.ts","../src/schemas/master-record.ts","../src/utils/schema-transform.ts","../src/utils/case-transform.ts","../src/schemas/upsert.ts","../src/utils/result.ts"],"sourcesContent":["import { request as r } from 'undici';\nimport { parse, safeParse } from 'valibot';\nimport { jsonToXml, xmlToJson } from './xml-client.js';\nimport {\n SearchMasterRecordRequestSchema,\n SearchMasterRecordResponseSchema,\n} from './schemas/search.js';\nimport {\n ManageMasterRecordRequestSchema,\n ManageMasterRecordResponseSchema,\n} from './schemas/upsert.js';\nimport type {\n ManageMasterRecordRS,\n MasterRecordDetail,\n SearchMasterRecord,\n SearchMasterRecordRS,\n} from './types.js';\nimport { MasterRecordDetailApiSchema } from './schemas/master-record.js';\nimport type { Result } from './utils/result.js';\nimport { err, ok } from './utils/result.js';\n\nfunction createRootElement<T>(name: XMLRootElementValues, object: T) {\n return {\n [name]: object,\n };\n}\n\nconst XML_ROOT_ELEMENTS = {\n SEARCH_REQUEST: 'SearchMasterRecordRQ',\n SEARCH_RESPONSE: 'SearchMasterRecordRS',\n UPSERT_REQUEST: 'ManageMasterRecordRQ',\n UPSERT_RESPONSE: 'ManageMasterRecordRS',\n} as const;\n\ntype XMLRootElementValues =\n (typeof XML_ROOT_ELEMENTS)[keyof typeof XML_ROOT_ELEMENTS];\n\n/**\n * Error thrown by AVES API operations\n */\nexport class AvesError extends Error {\n constructor(\n message: string,\n public readonly status?: string,\n public readonly errorCode?: string,\n public readonly errorDescription?: string\n ) {\n super(message);\n this.name = 'AvesError';\n }\n}\n\n/**\n * AVES XML REST API client\n */\nexport class AvesClient {\n /**\n * @param baseURL - Base URL of the AVES API\n * @param hostID - 6-digit identification code\n * @param xtoken - Authentication token\n * @param languageCode - Optional 2-digit language code\n */\n constructor(\n private readonly baseURL: string,\n private readonly hostID: string,\n private readonly xtoken: string,\n private readonly languageCode?: string\n ) {\n this.baseURL = baseURL.replace(/\\/$/, '');\n }\n\n private createRqHeader() {\n return {\n '@HostID': this.hostID,\n '@Xtoken': this.xtoken,\n '@Interface': 'WEB' as const,\n '@UserName': 'WEB' as const,\n ...(this.languageCode && { '@LanguageCode': this.languageCode }),\n };\n }\n\n private createUrl(endpoint: string) {\n return `${this.baseURL}${endpoint}`;\n }\n\n private get endpoints() {\n return {\n search: '/interop/masterRecords/v2/rest/Search',\n upsert: '/interop/masterRecords/v2/rest/InsertOrUpdate',\n } as const;\n }\n\n private handleApiStatus<T>(\n output: T,\n rsStatus: {\n status?: string;\n errorCode?: string;\n errorDescription?: string;\n warnings?: string[];\n }\n ): Result<T, AvesError> {\n const status = rsStatus?.status;\n\n if (status === 'ERROR' || status === 'TIMEOUT') {\n return err(\n new AvesError(\n rsStatus.errorDescription || `API Error: ${status}`,\n status,\n rsStatus.errorCode,\n rsStatus.errorDescription\n )\n );\n }\n\n if (status === 'WARNING') {\n const warnings = rsStatus.warnings?.join(', ');\n console.warn('AVES API Warning:', warnings);\n }\n\n return ok(output);\n }\n\n private toAvesError(error: unknown, defaultMessage: string): AvesError {\n if (error instanceof AvesError) {\n return error;\n }\n if (error instanceof Error) {\n return new AvesError(error.message);\n }\n return new AvesError(defaultMessage);\n }\n\n private async request<T>(\n endpoint: string,\n requestBody: Record<string, unknown>,\n responseRootKey: string,\n responseSchema:\n | typeof ManageMasterRecordResponseSchema\n | typeof SearchMasterRecordResponseSchema\n ): Promise<Result<T, AvesError>> {\n try {\n const url = this.createUrl(endpoint);\n const xmlBody = jsonToXml(requestBody);\n\n const response = await r(url, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/xml',\n },\n body: xmlBody,\n });\n\n const responseText = await response.body.text();\n\n if (response.statusCode !== 200) {\n return err(new AvesError(responseText, response.statusCode.toString()));\n }\n\n const jsonResponse = xmlToJson(responseText);\n const rootElement = jsonResponse[responseRootKey];\n\n if (!rootElement) {\n return err(\n new AvesError(\n `Invalid response structure: missing root element '${responseRootKey}'`,\n undefined,\n 'VALIDATION_ERROR'\n )\n );\n }\n\n const parseResult = safeParse(responseSchema, rootElement);\n\n if (!parseResult.success) {\n return err(\n new AvesError(\n `Invalid response format: ${parseResult.issues\n .map((i) => i.message)\n .join(', ')}`,\n '400',\n 'VALIDATION_ERROR'\n )\n );\n }\n\n return this.handleApiStatus(\n parseResult.output as T,\n parseResult.output.rsStatus\n );\n } catch (error) {\n return err(this.toAvesError(error, 'Unknown error occurred'));\n }\n }\n\n /**\n * Search for master records\n * @returns Result containing list of matching master records in camelCase or error\n */\n async search(\n params: SearchMasterRecord\n ): Promise<Result<SearchMasterRecordRS, AvesError>> {\n try {\n const requestData = parse(SearchMasterRecordRequestSchema, {\n RqHeader: this.createRqHeader(),\n SearchMasterRecord: params,\n });\n\n const requestBody = createRootElement(\n XML_ROOT_ELEMENTS.SEARCH_REQUEST,\n requestData\n );\n\n return await this.request<SearchMasterRecordRS>(\n this.endpoints.search,\n requestBody,\n XML_ROOT_ELEMENTS.SEARCH_RESPONSE,\n SearchMasterRecordResponseSchema\n );\n } catch (error) {\n return err(\n this.toAvesError(error, 'Validation error occurred during search')\n );\n }\n }\n\n /**\n * Insert or update a master record\n * @param record - Master record data in camelCase\n * @returns Result containing response with customer record code in camelCase or error\n */\n async upsertRecord(\n record: MasterRecordDetail\n ): Promise<Result<ManageMasterRecordRS, AvesError>> {\n try {\n const apiRecord = parse(MasterRecordDetailApiSchema, record);\n\n const masterRecordDetail = {\n '@InsertCriteria': 'T' as const,\n ...apiRecord,\n };\n\n const requestData = parse(ManageMasterRecordRequestSchema, {\n RqHeader: this.createRqHeader(),\n MasterRecordDetail: masterRecordDetail,\n });\n\n const requestBody = createRootElement(\n XML_ROOT_ELEMENTS.UPSERT_REQUEST,\n requestData\n );\n\n return await this.request<ManageMasterRecordRS>(\n this.endpoints.upsert,\n requestBody,\n XML_ROOT_ELEMENTS.UPSERT_RESPONSE,\n ManageMasterRecordResponseSchema\n );\n } catch (error) {\n return err(\n this.toAvesError(error, 'Validation error occurred during upsert')\n );\n }\n }\n}\n","import { XMLParser, XMLBuilder } from 'fast-xml-parser';\n\nconst parserOptions = {\n ignoreAttributes: false,\n attributeNamePrefix: '@',\n parseAttributeValue: true,\n parseTrueNumberOnly: false,\n trimValues: true,\n ignoreNameSpace: true,\n removeNSPrefix: true,\n parseTagValue: true,\n};\n\nconst builderOptions = {\n ignoreAttributes: false,\n attributeNamePrefix: '@',\n suppressEmptyNode: false,\n};\n\nconst parser = new XMLParser(parserOptions);\nconst builder = new XMLBuilder(builderOptions);\n\n/**\n * Converts JSON to XML string\n */\nexport function jsonToXml(json: Record<string, unknown>): string {\n return builder.build(json);\n}\n\n/**\n * Converts XML string to JSON object\n * Attributes are parsed with @ prefix\n */\nexport function xmlToJson(xml: string): Record<string, unknown> {\n return parser.parse(xml);\n}\n","import * as v from 'valibot';\nimport { RqHeaderSchema, RsStatusSchema } from './common.js';\nimport { FinancialDetailSchema, DynamicFieldsSchema } from './master-record.js';\nimport {\n createApiSchema,\n createResponseSchema,\n} from '../utils/schema-transform.js';\n\nconst LastModificationDateInputSchema = v.object({\n minDate: v.string(),\n maxDate: v.string(),\n});\n\nconst languageCodeField = v.optional(\n v.pipe(v.string(), v.minLength(2), v.maxLength(2))\n);\n\n/**\n * Search by CODE - requires recordCode\n */\nconst CodeSearchSchema = v.object({\n searchType: v.literal('CODE'),\n recordCode: v.pipe(v.string(), v.minLength(6), v.maxLength(6)),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by NAME - requires name, optionally city\n */\nconst NameSearchSchema = v.object({\n searchType: v.literal('NAME'),\n name: v.string(),\n city: v.optional(v.string()),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by VATCODE - requires vatCode, optionally phoneNumber\n */\nconst VatCodeSearchSchema = v.object({\n searchType: v.literal('VATCODE'),\n vatCode: v.string(),\n phoneNumber: v.optional(v.string()),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by ZONE - requires zipCode and countyCode, optionally city\n */\nconst ZoneSearchSchema = v.object({\n searchType: v.literal('ZONE'),\n zipCode: v.string(),\n countyCode: v.string(),\n city: v.optional(v.string()),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by CATEGORY - requires categoryCode\n */\nconst CategorySearchSchema = v.object({\n searchType: v.literal('CATEGORY'),\n categoryCode: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by EMAIL - requires email\n */\nconst EmailSearchSchema = v.object({\n searchType: v.literal('EMAIL'),\n email: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by LASTMODDATE - requires lastModificationDate\n */\nconst LastModDateSearchSchema = v.object({\n searchType: v.literal('LASTMODDATE'),\n lastModificationDate: LastModificationDateInputSchema,\n languageCode: languageCodeField,\n});\n\n/**\n * Search by SEARCH FIELD - requires searchFieldValue\n */\nconst SearchFieldSearchSchema = v.object({\n searchType: v.literal('SEARCH_FIELD'),\n searchFieldValue: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by EXTERNAL_REF_CODE - requires searchFieldValue\n */\nconst ExternalRefCodeSearchSchema = v.object({\n searchType: v.literal('EXTERNAL_REF_CODE'),\n searchFieldValue: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search master record input schema (camelCase)\n * Conditional fields based on searchType\n */\nexport const SearchMasterRecordSchema = v.union([\n CodeSearchSchema,\n NameSearchSchema,\n VatCodeSearchSchema,\n ZoneSearchSchema,\n CategorySearchSchema,\n EmailSearchSchema,\n LastModDateSearchSchema,\n SearchFieldSearchSchema,\n ExternalRefCodeSearchSchema,\n]);\n\n/**\n * Search master record schema for API requests (transforms to PascalCase)\n */\nexport const SearchMasterRecordApiSchema = createApiSchema(\n SearchMasterRecordSchema\n);\n\n/**\n * Complete search request schema with header\n */\nexport const SearchMasterRecordRequestSchema = v.object({\n RqHeader: RqHeaderSchema,\n SearchMasterRecord: SearchMasterRecordApiSchema,\n});\n\nconst MasterRecordDetailApiValidationSchema = v.object({\n '@RecordCode': v.optional(\n v.pipe(\n v.union([v.string(), v.number()]),\n v.transform((val) => String(val)),\n v.minLength(6),\n v.maxLength(6)\n )\n ),\n '@InsertCriteria': v.optional(\n v.union([v.literal('S'), v.literal('N'), v.literal('T'), v.literal('M')])\n ),\n CreatedDate: v.optional(v.string()),\n RecordType: v.optional(\n v.union([v.literal('CUSTOMER'), v.literal('SUPPLIER')])\n ),\n RecordStatus: v.optional(\n v.union(\n [\n v.literal('ENABLED'),\n v.literal('DISABLED'),\n v.literal('WARNING'),\n v.literal('BLACKLISTED'),\n ],\n 'ENABLED'\n )\n ),\n Moniker: v.optional(v.string()),\n Name: v.optional(v.string()),\n LanguageCode: v.optional(v.pipe(v.string(), v.minLength(2), v.maxLength(2))),\n Address: v.optional(v.string()),\n ZipCode: v.optional(v.string()),\n CityName: v.optional(v.string()),\n CountyCode: v.optional(v.string()),\n StateCode: v.optional(v.string()),\n CategoryCode: v.optional(v.string()),\n FirstPhoneNumber: v.optional(v.string()),\n MobilePhoneNumber: v.optional(v.string()),\n Email: v.optional(v.string()),\n Gender: v.optional(v.string()),\n BirthDate: v.optional(v.string()),\n FiscalCode: v.optional(v.string()),\n NewsletterDisabled: v.optional(\n v.union([v.literal('true'), v.literal('false'), v.boolean()])\n ),\n FinancialDetail: v.optional(FinancialDetailSchema),\n DynamicFields: v.optional(v.array(DynamicFieldsSchema)),\n});\n\nconst MasterRecordListApiSchema = v.object({\n MasterRecordDetail: v.optional(\n v.pipe(\n v.union([\n v.array(MasterRecordDetailApiValidationSchema),\n MasterRecordDetailApiValidationSchema,\n ]),\n v.transform((input) => {\n if (!input) return undefined;\n return Array.isArray(input) ? input : [input];\n })\n )\n ),\n});\n\n/**\n * Search master record response schema (transforms to camelCase)\n */\nexport const SearchMasterRecordResponseSchema = createResponseSchema(\n v.object({\n RsStatus: RsStatusSchema,\n MasterRecordList: v.optional(MasterRecordListApiSchema),\n })\n);\n","import * as v from 'valibot';\n\n/**\n * Request header schema with authentication credentials\n */\nexport const RqHeaderSchema = v.object({\n '@HostID': v.pipe(v.string(), v.minLength(6), v.maxLength(6)),\n '@Xtoken': v.string(),\n '@Interface': v.literal('WEB'),\n '@UserName': v.literal('WEB'),\n '@LanguageCode': v.optional(\n v.pipe(v.string(), v.minLength(2), v.maxLength(2))\n ),\n});\n\nconst warningsSchema = v.optional(\n v.pipe(\n v.string(),\n v.transform((input) => input.split(','))\n )\n);\n\n/**\n * Response status schema indicating success, error, or warning\n */\nexport const RsStatusSchema = v.object({\n '@Status': v.union([\n v.literal('OK'),\n v.literal('ERROR'),\n v.literal('WARNING'),\n v.literal('TIMEOUT'),\n ]),\n ErrorCode: v.optional(v.string()),\n ErrorDescription: v.optional(v.string()),\n Warnings: warningsSchema,\n});\n","import * as v from 'valibot';\nimport {\n createApiSchema,\n createResponseSchema,\n} from '../utils/schema-transform.js';\n\nconst FinancialDetailInputSchema = v.object({\n currencyCode: v.string(),\n creditLimit: v.optional(v.string()),\n c_PaymentType: v.optional(\n v.union([\n v.literal('CASH'),\n v.literal('BANK'),\n v.literal('RID'),\n v.literal('RIBA'),\n v.literal('SPECIFIC_CODE'),\n ])\n ),\n c_SpecPaymentTypeCode: v.optional(v.string()),\n s_PaymentType: v.optional(\n v.union([\n v.literal('CASH'),\n v.literal('BANK'),\n v.literal('RID'),\n v.literal('RIBA'),\n v.literal('SPECIFIC_CODE'),\n ])\n ),\n s_SpecPaymentTypeCode: v.optional(v.string()),\n});\n\n/**\n * Financial detail schema for API requests (transforms to PascalCase)\n */\nexport const FinancialDetailSchema = createApiSchema(\n FinancialDetailInputSchema\n);\n\nconst DynamicFieldsInputSchema = v.object({\n key: v.string(),\n value: v.string(),\n});\n\n/**\n * Dynamic fields schema for API requests (transforms to PascalCase)\n */\nexport const DynamicFieldsSchema = createApiSchema(DynamicFieldsInputSchema);\n\n/**\n * Master record detail input schema (camelCase)\n */\nexport const MasterRecordDetailSchema = v.object({\n recordCode: v.optional(v.pipe(v.string(), v.minLength(6), v.maxLength(6))),\n insertCriteria: v.optional(\n v.union([v.literal('S'), v.literal('N'), v.literal('T'), v.literal('M')])\n ),\n createdDate: v.optional(v.string()),\n recordType: v.optional(\n v.union([v.literal('CUSTOMER'), v.literal('SUPPLIER')], 'CUSTOMER')\n ),\n recordStatus: v.optional(\n v.union(\n [\n v.literal('ENABLED'),\n v.literal('DISABLED'),\n v.literal('WARNING'),\n v.literal('BLACKLISTED'),\n ],\n 'ENABLED'\n )\n ),\n moniker: v.optional(v.string()),\n name: v.optional(v.string()),\n extraInfo: v.optional(v.string()),\n languageCode: v.pipe(v.string(), v.minLength(2), v.maxLength(2)),\n address: v.optional(v.string()),\n zipCode: v.optional(v.string()),\n cityName: v.optional(v.string()),\n countyCode: v.optional(v.string()),\n stateCode: v.optional(v.string()),\n categoryCode: v.optional(v.string()),\n firstPhoneNumber: v.optional(v.string()),\n mobilePhoneNumber: v.optional(v.string()),\n email: v.optional(v.string()),\n gender: v.optional(v.string()),\n birthDate: v.optional(v.string()),\n fiscalCode: v.optional(v.string()),\n vatCode: v.optional(v.string()),\n financialDetail: v.optional(FinancialDetailInputSchema),\n dynamicFields: v.optional(v.array(DynamicFieldsInputSchema)),\n});\n\n/**\n * Master record detail schema for API requests (transforms to PascalCase)\n */\nexport const MasterRecordDetailApiSchema = createApiSchema(\n MasterRecordDetailSchema\n);\n\n/**\n * Master record detail response schema (transforms to camelCase)\n */\nexport const MasterRecordDetailResponseSchema = createResponseSchema(\n MasterRecordDetailApiSchema\n);\n","import * as v from 'valibot';\nimport type { BaseSchema } from 'valibot';\nimport { camelToPascalKeys, pascalToCamelKeys } from './case-transform.js';\n\n/**\n * Creates a schema that transforms camelCase input to PascalCase for API requests\n */\nexport function createApiSchema<TInput extends BaseSchema<any, any, any>>(\n inputSchema: TInput\n) {\n return v.pipe(\n inputSchema,\n v.transform((input) => camelToPascalKeys(input))\n );\n}\n\n/**\n * Creates a schema that transforms PascalCase API responses to camelCase\n */\nexport function createResponseSchema<TApi extends BaseSchema<any, any, any>>(\n apiSchema: TApi\n) {\n return v.pipe(\n apiSchema,\n v.transform((input) => pascalToCamelKeys(input))\n );\n}\n","type CamelFromDelimiter<S extends string> = S extends `${infer H}_${infer T}`\n ? `${H}${Capitalize<CamelFromDelimiter<T>>}`\n : S extends `${infer H}-${infer T}`\n ? `${H}${Capitalize<CamelFromDelimiter<T>>}`\n : S;\n\ntype ToCamelCase<S extends string> =\n CamelFromDelimiter<S> extends `${infer F}${infer R}`\n ? `${Lowercase<F>}${R}`\n : CamelFromDelimiter<S>;\n\ntype PascalFromDelimiter<S extends string> = S extends `${infer H}_${infer T}`\n ? `${Capitalize<H>}${Capitalize<PascalFromDelimiter<T>>}`\n : S extends `${infer H}-${infer T}`\n ? `${Capitalize<H>}${Capitalize<PascalFromDelimiter<T>>}`\n : S;\n\ntype ToPascalCase<S extends string> =\n PascalFromDelimiter<S> extends `${infer F}${infer R}`\n ? `${Capitalize<F>}${R}`\n : Capitalize<PascalFromDelimiter<S>>;\n\nexport type Camelize<T> = T extends readonly (infer U)[]\n ? Camelize<U>[]\n : T extends object\n ? {\n [K in keyof T as K extends `@${infer Rest}`\n ? ToCamelCase<Rest> // Strip @ prefix and camelCase the rest\n : ToCamelCase<K & string>]: Camelize<T[K]>;\n }\n : T;\n\nexport type Pascalize<T> = T extends readonly (infer U)[]\n ? Pascalize<U>[]\n : T extends object\n ? {\n [K in keyof T as K extends `@${infer Rest}`\n ? ToPascalCase<Rest> // Strip @ prefix and PascalCase the rest\n : ToPascalCase<K & string>]: Pascalize<T[K]>;\n }\n : T;\n\nfunction camelToPascal(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nfunction pascalToCamel(str: string): string {\n return str.charAt(0).toLowerCase() + str.slice(1);\n}\n\nconst ATTRIBUTE_FIELDS = new Set([\n 'recordCode',\n 'insertCriteria',\n 'currencyCode',\n 'creditLimit',\n 'c_PaymentType',\n 'c_SpecPaymentTypeCode',\n 's_PaymentType',\n 's_SpecPaymentTypeCode',\n 'key',\n 'value',\n 'minDate',\n 'maxDate',\n 'hostID',\n 'xtoken',\n 'interface',\n 'userName',\n 'status',\n]);\n\n/**\n * Transforms object keys from camelCase to PascalCase\n * Adds @ prefix to fields in ATTRIBUTE_FIELDS for XML attributes\n */\nexport function camelToPascalKeys<T>(obj: T): Pascalize<T> {\n if (!obj || typeof obj !== 'object') {\n return obj as Pascalize<T>;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => camelToPascalKeys(item)) as Pascalize<T>;\n }\n\n if (\n obj instanceof Date ||\n obj instanceof RegExp ||\n obj instanceof Map ||\n obj instanceof Set ||\n obj instanceof Error\n ) {\n return obj as Pascalize<T>;\n }\n\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n const isAttribute = ATTRIBUTE_FIELDS.has(key);\n const pascalKey = camelToPascal(key);\n const finalKey = isAttribute ? `@${pascalKey}` : pascalKey;\n\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n if (\n value instanceof Date ||\n value instanceof RegExp ||\n value instanceof Map ||\n value instanceof Set ||\n value instanceof Error\n ) {\n result[finalKey] = value;\n } else {\n result[finalKey] = camelToPascalKeys(value as Record<string, unknown>);\n }\n } else if (Array.isArray(value)) {\n result[finalKey] = value.map((item) =>\n typeof item === 'object' && item && !Array.isArray(item)\n ? camelToPascalKeys(item as Record<string, unknown>)\n : item\n );\n } else {\n result[finalKey] = value;\n }\n }\n return result as Pascalize<T>;\n}\n\n/**\n * Transforms object keys from PascalCase to camelCase\n * Strips @ prefix from XML attributes\n */\nexport function pascalToCamelKeys<T>(obj: T): Camelize<T> {\n if (!obj || typeof obj !== 'object') {\n return obj as Camelize<T>;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => pascalToCamelKeys(item)) as Camelize<T>;\n }\n\n if (\n obj instanceof Date ||\n obj instanceof RegExp ||\n obj instanceof Map ||\n obj instanceof Set ||\n obj instanceof Error\n ) {\n return obj as Camelize<T>;\n }\n\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n if (key.startsWith('@')) {\n const strippedKey = key.slice(1);\n const camelKey = pascalToCamel(strippedKey);\n result[camelKey] = value;\n } else {\n const camelKey = pascalToCamel(key);\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n if (\n value instanceof Date ||\n value instanceof RegExp ||\n value instanceof Map ||\n value instanceof Set ||\n value instanceof Error\n ) {\n result[camelKey] = value;\n } else {\n result[camelKey] = pascalToCamelKeys(\n value as Record<string, unknown>\n );\n }\n } else if (Array.isArray(value)) {\n result[camelKey] = value.map((item) =>\n typeof item === 'object' && item && !Array.isArray(item)\n ? pascalToCamelKeys(item as Record<string, unknown>)\n : item\n );\n } else {\n result[camelKey] = value;\n }\n }\n }\n return result as Camelize<T>;\n}\n","import * as v from 'valibot';\nimport { RqHeaderSchema, RsStatusSchema } from './common.js';\nimport { FinancialDetailSchema, DynamicFieldsSchema } from './master-record.js';\nimport { createResponseSchema } from '../utils/schema-transform.js';\n\nconst CustomerRecordApiSchema = v.object({\n CustomerRecordCode: v.pipe(\n v.union([v.string(), v.number()]),\n v.transform((val) => String(val)),\n v.minLength(6),\n v.maxLength(6)\n ),\n});\n\nconst MasterRecordDetailApiValidationSchema = v.object({\n '@RecordCode': v.optional(v.pipe(v.string(), v.minLength(6), v.maxLength(6))),\n '@InsertCriteria': v.optional(\n v.union([v.literal('S'), v.literal('N'), v.literal('T'), v.literal('M')])\n ),\n CreatedDate: v.optional(v.string()),\n RecordType: v.optional(\n v.union([v.literal('CUSTOMER'), v.literal('SUPPLIER')])\n ),\n RecordStatus: v.optional(\n v.union(\n [\n v.literal('ENABLED'),\n v.literal('DISABLED'),\n v.literal('WARNING'),\n v.literal('BLACKLISTED'),\n ],\n 'ENABLED'\n )\n ),\n Moniker: v.optional(v.string()),\n Name: v.optional(v.string()),\n LanguageCode: v.optional(v.pipe(v.string(), v.minLength(2), v.maxLength(2))),\n Address: v.optional(v.string()),\n ZipCode: v.optional(v.string()),\n CityName: v.optional(v.string()),\n CountyCode: v.optional(v.string()),\n StateCode: v.optional(v.string()),\n CategoryCode: v.optional(v.string()),\n FirstPhoneNumber: v.optional(v.string()),\n MobilePhoneNumber: v.optional(v.string()),\n Email: v.optional(v.string()),\n Gender: v.optional(v.string()),\n BirthDate: v.optional(v.string()),\n FiscalCode: v.optional(v.string()),\n NewsletterDisabled: v.optional(\n v.union([v.literal('true'), v.literal('false'), v.boolean()])\n ),\n FinancialDetail: v.optional(FinancialDetailSchema),\n DynamicFields: v.optional(v.array(DynamicFieldsSchema)),\n});\n\n/**\n * Complete upsert request schema with header and required InsertCriteria\n */\nexport const ManageMasterRecordRequestSchema = v.object({\n RqHeader: RqHeaderSchema,\n MasterRecordDetail: v.intersect([\n MasterRecordDetailApiValidationSchema,\n v.object({\n '@InsertCriteria': v.union([\n v.literal('S'),\n v.literal('N'),\n v.literal('T'),\n v.literal('M'),\n ]),\n }),\n ]),\n});\n\n/**\n * Upsert master record response schema (transforms to camelCase)\n */\nexport const ManageMasterRecordResponseSchema = createResponseSchema(\n v.object({\n RsStatus: RsStatusSchema,\n CustomerRecordRS: v.optional(CustomerRecordApiSchema),\n })\n);\n","/**\n * Result type for functional error handling\n */\nexport type Result<T, E = Error> =\n | { success: true; data: T }\n | { success: false; error: E };\n\n/**\n * Creates a successful result\n */\nexport function ok<T>(data: T): Result<T, never> {\n return { success: true, data };\n}\n\n/**\n * Creates an error result\n */\nexport function err<E>(error: E): Result<never, E> {\n return { success: false, error };\n}\n"],"mappings":"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","names":["r","parse","safeParse","XMLParser","XMLBuilder","parserOptions","builderOptions","parser","builder","jsonToXml","json","xmlToJson","xml","v","v","RqHeaderSchema","warningsSchema","input","RsStatusSchema","v","v","camelToPascal","str","pascalToCamel","ATTRIBUTE_FIELDS","camelToPascalKeys","obj","item","result","key","value","isAttribute","pascalKey","finalKey","pascalToCamelKeys","strippedKey","camelKey","createApiSchema","inputSchema","input","camelToPascalKeys","createResponseSchema","apiSchema","pascalToCamelKeys","FinancialDetailInputSchema","FinancialDetailSchema","createApiSchema","DynamicFieldsInputSchema","DynamicFieldsSchema","MasterRecordDetailSchema","MasterRecordDetailApiSchema","MasterRecordDetailResponseSchema","createResponseSchema","LastModificationDateInputSchema","languageCodeField","CodeSearchSchema","NameSearchSchema","VatCodeSearchSchema","ZoneSearchSchema","CategorySearchSchema","EmailSearchSchema","LastModDateSearchSchema","SearchFieldSearchSchema","ExternalRefCodeSearchSchema","SearchMasterRecordSchema","SearchMasterRecordApiSchema","createApiSchema","SearchMasterRecordRequestSchema","RqHeaderSchema","MasterRecordDetailApiValidationSchema","val","FinancialDetailSchema","DynamicFieldsSchema","MasterRecordListApiSchema","input","SearchMasterRecordResponseSchema","createResponseSchema","RsStatusSchema","v","CustomerRecordApiSchema","val","MasterRecordDetailApiValidationSchema","FinancialDetailSchema","DynamicFieldsSchema","ManageMasterRecordRequestSchema","RqHeaderSchema","ManageMasterRecordResponseSchema","createResponseSchema","RsStatusSchema","ok","data","err","error","createRootElement","name","object","XML_ROOT_ELEMENTS","AvesError","message","status","errorCode","errorDescription","AvesClient","baseURL","hostID","xtoken","languageCode","endpoint","output","rsStatus","err","warnings","ok","error","defaultMessage","requestBody","responseRootKey","responseSchema","url","xmlBody","jsonToXml","response","r","responseText","rootElement","xmlToJson","parseResult","safeParse","i","params","requestData","parse","SearchMasterRecordRequestSchema","SearchMasterRecordResponseSchema","record","masterRecordDetail","MasterRecordDetailApiSchema","ManageMasterRecordRequestSchema","ManageMasterRecordResponseSchema"]}
|
|
1
|
+
{"version":3,"sources":["../src/client.ts","../src/xml-client.ts","../src/error.ts","../src/schemas/search.ts","../src/schemas/common.ts","../src/schemas/master-record.ts","../src/utils/schema-transform.ts","../src/utils/case-transform.ts","../src/schemas/upsert.ts","../src/utils/result.ts","../src/utils/url.ts","../src/utils/timeout.ts"],"sourcesContent":["import { request as r } from 'undici';\nimport { BaseIssue, BaseSchema, parse, safeParse, ValiError } from 'valibot';\nimport { jsonToXml, xmlToJson } from './xml-client.js';\nimport {\n SearchMasterRecordRequestSchema,\n SearchMasterRecordResponseSchema,\n} from './schemas/search.js';\nimport {\n ManageMasterRecordRequestSchema,\n ManageMasterRecordResponseSchema,\n} from './schemas/upsert.js';\nimport type {\n AvesClientOptions,\n ManageMasterRecordRS,\n MasterRecordDetail,\n RsStatus,\n SearchMasterRecord,\n SearchMasterRecordRS,\n} from './types.js';\nimport { MasterRecordDetailApiSchema } from './schemas/master-record.js';\nimport type { Result } from './utils/result.js';\nimport { err, ok } from './utils/result.js';\nimport {\n apiError,\n AvesError,\n buildDetails,\n isAbortError,\n unknownError,\n validationError,\n} from './error.js';\nimport { parseUrl } from './utils/url.js';\nimport { createTimeoutSignal } from './utils/timeout.js';\n\nfunction createRootElement<T>(name: XMLRootElementValues, object: T) {\n return {\n [name]: object,\n };\n}\n\nconst XML_ROOT_ELEMENTS = {\n SEARCH_REQUEST: 'SearchMasterRecordRQ',\n SEARCH_RESPONSE: 'SearchMasterRecordRS',\n UPSERT_REQUEST: 'ManageMasterRecordRQ',\n UPSERT_RESPONSE: 'ManageMasterRecordRS',\n} as const;\n\ntype XMLRootElementValues =\n (typeof XML_ROOT_ELEMENTS)[keyof typeof XML_ROOT_ELEMENTS];\n\n/**\n * AVES XML REST API client\n */\nexport class AvesClient {\n /**\n * @param options - Client configuration options\n * @param options.baseURL - Base URL of the AVES API\n * @param options.hostID - 6-digit identification code\n * @param options.xtoken - Authentication token\n * @param options.languageCode - Optional 2-digit language code\n * @param options.timeoutMs - Optional request timeout in milliseconds\n */\n constructor(private readonly options: AvesClientOptions) {}\n\n private createRqHeader() {\n return {\n '@HostID': this.options.hostID,\n '@Xtoken': this.options.xtoken,\n '@Interface': 'WEB' as const,\n '@UserName': 'WEB' as const,\n ...(this.options.languageCode && {\n '@LanguageCode': this.options.languageCode,\n }),\n };\n }\n\n private createUrl(endpoint: string) {\n return parseUrl(this.options.baseURL, endpoint);\n }\n\n private get endpoints() {\n return {\n search: '/interop/masterRecords/v2/rest/Search',\n upsert: '/interop/masterRecords/v2/rest/InsertOrUpdate',\n } as const;\n }\n\n private handleApiStatus<T extends { rsStatus: RsStatus }>(\n output: T,\n ): Result<T, AvesError> {\n const rsStatus = output.rsStatus;\n const status = rsStatus?.status;\n\n if (status !== 'OK') {\n return err(\n apiError(\n rsStatus.errorDescription as string,\n status,\n rsStatus.errorCode,\n ),\n );\n }\n\n return ok(output);\n }\n\n private toAvesError(error: unknown, defaultMessage: string): AvesError {\n if (error instanceof AvesError) {\n return error;\n }\n if (error instanceof ValiError) {\n const details = buildDetails(error.issues);\n return validationError(`Validation error: ${details}`);\n }\n if (error instanceof Error) {\n return unknownError(error.message);\n }\n return unknownError(defaultMessage);\n }\n\n private async request<T extends { rsStatus: RsStatus }>(\n endpoint: string,\n requestBody: Record<string, unknown>,\n responseRootKey: string,\n responseSchema: BaseSchema<unknown, T, BaseIssue<unknown>>,\n ): Promise<Result<T, AvesError>> {\n const { signal, clear } = createTimeoutSignal(\n this.options.timeoutMs ?? 30_000,\n );\n\n try {\n const url = this.createUrl(endpoint);\n const xmlBody = jsonToXml(requestBody);\n\n const response = await r(url, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/xml',\n },\n body: xmlBody,\n signal,\n });\n\n const responseText = await response.body.text();\n\n if (response.statusCode !== 200) {\n return err(apiError(responseText, 'ERROR', response.statusCode));\n }\n\n const jsonResponse = xmlToJson(responseText);\n const rootElement = jsonResponse[responseRootKey];\n\n if (!rootElement) {\n return err(\n validationError(\n `Invalid response structure: missing root element '${responseRootKey}'`,\n ),\n );\n }\n\n const parseResult = safeParse(responseSchema, rootElement);\n if (!parseResult.success) {\n const details = buildDetails(parseResult.issues);\n return err(validationError(`Invalid response format: ${details}`));\n }\n return this.handleApiStatus(parseResult.output);\n } catch (error) {\n if (isAbortError(error)) {\n return err(apiError('Request timed out', 'TIMEOUT'));\n }\n return err(this.toAvesError(error, 'Unknown error occurred'));\n } finally {\n clear?.();\n }\n }\n\n /**\n * Search for master records\n * @returns Result containing list of matching master records in camelCase or error\n */\n async search(\n params: SearchMasterRecord,\n ): Promise<Result<SearchMasterRecordRS, AvesError>> {\n try {\n const requestData = parse(SearchMasterRecordRequestSchema, {\n RqHeader: this.createRqHeader(),\n SearchMasterRecord: params,\n });\n\n const requestBody = createRootElement(\n XML_ROOT_ELEMENTS.SEARCH_REQUEST,\n requestData,\n );\n\n return this.request<SearchMasterRecordRS>(\n this.endpoints.search,\n requestBody,\n XML_ROOT_ELEMENTS.SEARCH_RESPONSE,\n SearchMasterRecordResponseSchema,\n );\n } catch (error) {\n return err(\n this.toAvesError(error, 'Validation error occurred during search'),\n );\n }\n }\n\n /**\n * Insert or update a master record\n * @param record - Master record data in camelCase\n * @returns Result containing response with customer record code in camelCase or error\n */\n async upsertRecord(\n record: MasterRecordDetail,\n ): Promise<Result<ManageMasterRecordRS, AvesError>> {\n try {\n const apiRecord = parse(MasterRecordDetailApiSchema, record);\n\n const requestData = parse(ManageMasterRecordRequestSchema, {\n RqHeader: this.createRqHeader(),\n MasterRecordDetail: apiRecord,\n });\n\n const requestBody = createRootElement(\n XML_ROOT_ELEMENTS.UPSERT_REQUEST,\n requestData,\n );\n\n return this.request<ManageMasterRecordRS>(\n this.endpoints.upsert,\n requestBody,\n XML_ROOT_ELEMENTS.UPSERT_RESPONSE,\n ManageMasterRecordResponseSchema,\n );\n } catch (error) {\n return err(\n this.toAvesError(error, 'Validation error occurred during upsert'),\n );\n }\n }\n}\n","import { XMLParser, XMLBuilder } from 'fast-xml-parser';\nimport { AvesError } from './error.js';\n\nconst parserOptions = {\n ignoreAttributes: false,\n attributeNamePrefix: '@',\n parseAttributeValue: false,\n trimValues: true,\n ignoreNameSpace: true,\n removeNSPrefix: true,\n parseTagValue: false,\n};\n\nconst builderOptions = {\n ignoreAttributes: false,\n attributeNamePrefix: '@',\n suppressEmptyNode: true,\n};\n\nconst parser = new XMLParser(parserOptions);\nconst builder = new XMLBuilder(builderOptions);\n\n/**\n * Converts JSON to XML string\n */\nexport function jsonToXml(json: Record<string, unknown>): string {\n try {\n return builder.build(json);\n } catch (error) {\n throw new AvesError(\n 'validation',\n `Failed to convert JSON to XML: ${error instanceof Error ? error.message : 'Unknown error'}`,\n );\n }\n}\n\n/**\n * Converts XML string to JSON object\n * Attributes are parsed with @ prefix\n */\nexport function xmlToJson(xml: string): Record<string, unknown> {\n try {\n return parser.parse(xml);\n } catch (error) {\n throw new AvesError(\n 'validation',\n `Failed to convert XML to JSON: ${error instanceof Error ? error.message : 'Unknown error'}`,\n );\n }\n}\n","import { BaseIssue } from 'valibot';\n\nexport const ERROR_KINDS = {\n VALIDATION: 'validation',\n API: 'api',\n UNKNOWN: 'unknown',\n} as const;\n\nexport type ErrorKind = (typeof ERROR_KINDS)[keyof typeof ERROR_KINDS];\n\n/**\n * Error thrown by AVES API operations\n */\nexport class AvesError extends Error {\n constructor(\n public readonly kind: ErrorKind,\n public readonly message: string,\n public readonly status?: string,\n public readonly code?: number | string,\n ) {\n super(message);\n this.name = 'AvesError';\n this.status = status?.toLowerCase();\n this.code = this.parseCode(code);\n }\n\n private parseCode(code?: number | string): number {\n if (typeof code === 'string') {\n return Number.parseInt(code);\n }\n return code ?? 0;\n }\n}\n\nexport function validationError(message: string): AvesError {\n return new AvesError(ERROR_KINDS.VALIDATION, message);\n}\n\nexport function apiError(\n message: string,\n status?: string,\n code?: number | string,\n): AvesError {\n return new AvesError(ERROR_KINDS.API, message, status, code);\n}\n\nexport function unknownError(message: string): AvesError {\n return new AvesError(ERROR_KINDS.UNKNOWN, message);\n}\n\nexport function buildDetails(issues: readonly BaseIssue<unknown>[]): string {\n return issues\n .map((issue) => {\n const path =\n issue.path && issue.path.length > 0\n ? issue.path\n .map((segment) =>\n typeof segment === 'string' || typeof segment === 'number'\n ? String(segment)\n : 'key' in segment\n ? String((segment as any).key)\n : '',\n )\n .filter(Boolean)\n .join('.')\n : undefined;\n\n const text = issue.message ?? 'Invalid value';\n return path ? `${path}: ${text}` : text;\n })\n .join('; ');\n}\n\nexport function isAbortError(error: unknown): boolean {\n return error instanceof Error && error.name === 'AbortError';\n}\n","import * as v from 'valibot';\nimport { RqHeaderSchema, RsStatusSchema } from './common.js';\nimport { MasterRecordDetailApiValidationSchema } from './master-record.js';\nimport {\n createApiSchema,\n createResponseSchema,\n} from '../utils/schema-transform.js';\n\nconst LastModificationDateInputSchema = v.object({\n minDate: v.string(),\n maxDate: v.string(),\n});\n\nconst languageCodeField = v.optional(\n v.pipe(v.string(), v.minLength(2), v.maxLength(2)),\n);\n\n/**\n * Search by CODE - requires recordCode\n */\nconst CodeSearchSchema = v.object({\n searchType: v.literal('CODE'),\n recordCode: v.pipe(v.string(), v.minLength(5), v.maxLength(6)),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by NAME - requires name, optionally city\n */\nconst NameSearchSchema = v.object({\n searchType: v.literal('NAME'),\n name: v.string(),\n city: v.optional(v.string()),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by VATCODE - requires vatCode, optionally phoneNumber\n */\nconst VatCodeSearchSchema = v.object({\n searchType: v.literal('VATCODE'),\n vatCode: v.string(),\n phoneNumber: v.optional(v.string()),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by ZONE - requires zipCode and countyCode, optionally city\n */\nconst ZoneSearchSchema = v.object({\n searchType: v.literal('ZONE'),\n zipCode: v.string(),\n countyCode: v.string(),\n city: v.optional(v.string()),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by CATEGORY - requires categoryCode\n */\nconst CategorySearchSchema = v.object({\n searchType: v.literal('CATEGORY'),\n categoryCode: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by EMAIL - requires email\n */\nconst EmailSearchSchema = v.object({\n searchType: v.literal('EMAIL'),\n email: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by LASTMODDATE - requires lastModificationDate\n */\nconst LastModDateSearchSchema = v.object({\n searchType: v.literal('LASTMODDATE'),\n lastModificationDate: LastModificationDateInputSchema,\n languageCode: languageCodeField,\n});\n\n/**\n * Search by SEARCH FIELD - requires searchFieldValue\n */\nconst SearchFieldSearchSchema = v.object({\n searchType: v.literal('SEARCH_FIELD'),\n searchFieldValue: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search by EXTERNAL_REF_CODE - requires searchFieldValue\n */\nconst ExternalRefCodeSearchSchema = v.object({\n searchType: v.literal('EXTERNAL_REF_CODE'),\n searchFieldValue: v.string(),\n languageCode: languageCodeField,\n});\n\n/**\n * Search master record input schema (camelCase)\n * Conditional fields based on searchType\n */\nexport const SearchMasterRecordSchema = v.union([\n CodeSearchSchema,\n NameSearchSchema,\n VatCodeSearchSchema,\n ZoneSearchSchema,\n CategorySearchSchema,\n EmailSearchSchema,\n LastModDateSearchSchema,\n SearchFieldSearchSchema,\n ExternalRefCodeSearchSchema,\n]);\n\nconst transformRecordCode = (input: Record<string, unknown>) => {\n if (!('@RecordCode' in input)) return input;\n const recordCode = input['@RecordCode'];\n if (!recordCode) return input;\n const { ['@RecordCode']: _discard, ...rest } = input;\n return {\n ...rest,\n RecordCode: recordCode,\n };\n};\n\n/**\n * Search master record schema for API requests (transforms to PascalCase)\n */\nexport const SearchMasterRecordApiSchema = v.pipe(\n createApiSchema(SearchMasterRecordSchema),\n v.transform((input) => transformRecordCode(input)),\n);\n\n/**\n * Complete search request schema with header\n * Flattens SearchMasterRecord fields to root level\n */\nexport const SearchMasterRecordRequestSchema = v.pipe(\n v.object({\n RqHeader: RqHeaderSchema,\n SearchMasterRecord: SearchMasterRecordApiSchema,\n }),\n v.transform((input) => {\n const { SearchMasterRecord: searchFields, RqHeader, ...rest } = input;\n return {\n RqHeader,\n ...searchFields,\n ...rest,\n };\n }),\n);\n\nconst MasterRecordListApiSchema = v.object({\n MasterRecordDetail: v.optional(\n v.pipe(\n v.union([\n v.array(MasterRecordDetailApiValidationSchema),\n MasterRecordDetailApiValidationSchema,\n ]),\n v.transform((input) => {\n if (!input) return undefined;\n return Array.isArray(input) ? input : [input];\n }),\n ),\n ),\n});\n\n/**\n * Search master record response schema (transforms to camelCase)\n */\nexport const SearchMasterRecordResponseSchema = createResponseSchema(\n v.object({\n RsStatus: RsStatusSchema,\n MasterRecordList: v.optional(MasterRecordListApiSchema),\n }),\n);\n","import * as v from 'valibot';\n\n/**\n * Request header schema with authentication credentials\n */\nexport const RqHeaderSchema = v.object({\n '@HostID': v.pipe(v.string(), v.minLength(6), v.maxLength(6)),\n '@Xtoken': v.string(),\n '@Interface': v.literal('WEB'),\n '@UserName': v.literal('WEB'),\n '@LanguageCode': v.optional(\n v.pipe(v.string(), v.minLength(2), v.maxLength(2)),\n ),\n});\n\nconst warningsSchema = v.optional(\n v.pipe(\n v.string(),\n v.transform((input) => input.split(',')),\n ),\n);\n\n/**\n * Response status schema indicating success, error, or warning\n */\nexport const RsStatusSchema = v.pipe(\n v.object({\n '@Status': v.union([\n v.literal('OK'),\n v.literal('ERROR'),\n v.literal('WARNING'),\n v.literal('TIMEOUT'),\n ]),\n ErrorCode: v.optional(\n v.pipe(\n v.union([v.string(), v.number()]),\n v.transform((val) => Number(val)),\n ),\n ),\n ErrorDescription: v.optional(v.string()),\n Warnings: warningsSchema,\n }),\n v.transform((input) => {\n return {\n status: input['@Status'],\n errorCode: input.ErrorCode,\n errorDescription: input.ErrorDescription,\n warnings: input.Warnings,\n };\n }),\n);\n","import * as v from 'valibot';\nimport {\n createApiSchema,\n createResponseSchema,\n createApiValidationSchema,\n} from '../utils/schema-transform.js';\n\nconst paymentTypeSchema = v.union([\n v.literal('CASH'),\n v.literal('BANK'),\n v.literal('RID'),\n v.literal('RIBA'),\n v.literal('SPECIFIC_CODE'),\n]);\n\nconst FinancialDetailInputSchema = v.object({\n currencyCode: v.optional(v.string()),\n creditLimit: v.optional(v.string()),\n c_PaymentType: v.optional(paymentTypeSchema),\n c_SpecPaymentTypeCode: v.optional(v.string()),\n s_PaymentType: v.optional(paymentTypeSchema),\n s_SpecPaymentTypeCode: v.optional(v.string()),\n enableElectronicInvoicing: v.optional(v.union([v.literal('true'), v.literal('false'), v.boolean()])),\n electronicInvoicingType: v.optional(v.string()),\n});\n\n/**\n * Financial detail schema for API requests (transforms to PascalCase)\n */\nexport const FinancialDetailSchema = createApiSchema(\n FinancialDetailInputSchema,\n);\n\n/**\n * Financial detail validation schema (already transformed PascalCase with @ attributes)\n */\nexport const FinancialDetailApiValidationSchema = createApiValidationSchema(\n FinancialDetailInputSchema,\n);\n\nconst DynamicFieldsInputSchema = v.object({\n key: v.string(),\n value: v.string(),\n});\n\n/**\n * Dynamic fields schema for API requests (transforms to PascalCase)\n */\nexport const DynamicFieldsSchema = createApiSchema(DynamicFieldsInputSchema);\n\n/**\n * Dynamic fields validation schema (already transformed PascalCase with @ attributes)\n */\nexport const DynamicFieldsApiValidationSchema = createApiValidationSchema(\n DynamicFieldsInputSchema,\n);\n\nconst flagSchema = v.union([v.literal(0), v.literal(1)]);\n\nconst recordStatusSchema = v.union([\n v.literal('ENABLED'),\n v.literal('DISABLED'),\n v.literal('WARNING'),\n v.literal('BLACKLISTED'),\n]);\n\nconst recordTypeSchema = v.union([\n v.literal('CUSTOMER'),\n v.literal('SUPPLIER'),\n v.literal('GENERAL'),\n]);\n\nconst insertCriteriaSchema = v.union([\n v.literal('S'),\n v.literal('N'),\n v.literal('T'),\n v.literal('M'),\n]);\n\nconst AccountPoliciesInputSchema = v.object({\n acceptProfilingPolicies: v.optional(flagSchema),\n acceptPrivacyPolicies: v.optional(flagSchema),\n acceptNewsletterPolicies: v.optional(flagSchema),\n});\n\n/**\n * Account policies schema for API requests (transforms to PascalCase with @ attributes)\n */\nexport const AccountPoliciesSchema = createApiSchema(\n AccountPoliciesInputSchema,\n);\n\n/**\n * Account policies validation schema (already transformed PascalCase with @ attributes)\n */\nexport const AccountPoliciesApiValidationSchema = createApiValidationSchema(\n AccountPoliciesInputSchema,\n);\n\n/**\n * Master record detail input schema (camelCase)\n */\nexport const MasterRecordDetailSchema = v.object({\n recordCode: v.optional(v.pipe(v.string(), v.minLength(6), v.maxLength(6))),\n insertCriteria: v.optional(insertCriteriaSchema),\n createdDate: v.optional(v.string()),\n recordType: v.optional(v.union([recordTypeSchema], 'CUSTOMER')),\n recordStatus: v.optional(v.union([recordStatusSchema], 'ENABLED')),\n moniker: v.optional(v.string()),\n name: v.optional(v.string()),\n extraInfo: v.optional(v.string()),\n languageCode: v.pipe(v.string(), v.minLength(2), v.maxLength(2)),\n address: v.optional(v.string()),\n zipCode: v.optional(v.string()),\n cityName: v.optional(v.string()),\n countyCode: v.optional(v.string()),\n stateCode: v.optional(v.string()),\n categoryCode: v.optional(v.string()),\n firstPhoneNumber: v.optional(v.string()),\n mobilePhoneNumber: v.optional(v.string()),\n email: v.optional(v.string()),\n gender: v.optional(v.string()),\n birthDate: v.optional(v.string()),\n fiscalCode: v.optional(v.string()),\n vatCode: v.optional(v.string()),\n accountPolicies: v.optional(AccountPoliciesInputSchema),\n financialDetail: v.optional(FinancialDetailInputSchema),\n dynamicFields: v.optional(DynamicFieldsInputSchema),\n});\n\n/**\n * Master record detail schema for API requests (transforms to PascalCase)\n */\nexport const MasterRecordDetailApiSchema = createApiSchema(\n MasterRecordDetailSchema,\n);\n\n/**\n * Master record detail response schema (transforms to camelCase)\n */\nexport const MasterRecordDetailResponseSchema = createResponseSchema(\n MasterRecordDetailApiSchema,\n);\n\n/**\n * Master record detail API validation schema (PascalCase with @ attributes)\n * Used for both search responses and upsert requests\n * All fields are optional as responses may not contain all fields\n */\nexport const MasterRecordDetailApiValidationSchema = v.object({\n '@RecordCode': v.optional(v.pipe(v.string(), v.minLength(5), v.maxLength(6))),\n '@InsertCriteria': v.optional(insertCriteriaSchema),\n CreatedDate: v.optional(v.string()),\n ModifiedDate: v.optional(v.string()),\n RecordType: v.optional(\n v.union([\n v.literal('CUSTOMER'),\n v.literal('SUPPLIER'),\n v.literal('GENERAL'),\n ]),\n ),\n LoginType: v.optional(v.string()),\n RecordStatus: v.optional(recordStatusSchema),\n Moniker: v.optional(v.string()),\n Name: v.optional(v.string()),\n ExtraInfo: v.optional(v.string()),\n LanguageCode: v.optional(v.pipe(v.string(), v.minLength(1), v.maxLength(2))),\n Address: v.optional(v.string()),\n ZipCode: v.optional(v.string()),\n CityName: v.optional(v.string()),\n CountyCode: v.optional(v.string()),\n StateCode: v.optional(v.string()),\n CategoryCode: v.optional(v.string()),\n PromoterCode: v.optional(v.string()),\n FirstPhoneNumber: v.optional(v.string()),\n MobilePhoneNumber: v.optional(v.string()),\n Email: v.optional(v.string()),\n Gender: v.optional(v.string()),\n BirthDate: v.optional(v.string()),\n EncryptedPassword: v.optional(v.union([v.literal('true'), v.literal('false'), v.boolean()])),\n FiscalCode: v.optional(v.string()),\n VatCode: v.optional(v.string()),\n NewsletterDisabled: v.optional(v.union([v.literal('true'), v.literal('false'), v.boolean()])),\n SupplierRefMasterRecords: v.optional(v.any()),\n AccountPolicies: v.optional(AccountPoliciesApiValidationSchema),\n FinancialDetail: v.optional(FinancialDetailApiValidationSchema),\n DynamicFields: v.optional(v.array(DynamicFieldsApiValidationSchema)),\n});\n","import * as v from 'valibot';\nimport type { BaseSchema, ObjectEntries } from 'valibot';\nimport {\n camelToPascalKeys,\n pascalToCamelKeys,\n ATTRIBUTE_FIELDS,\n} from './case-transform.js';\n\n/**\n * Creates a schema that transforms camelCase input to PascalCase for API requests\n */\nexport function createApiSchema<TInput extends BaseSchema<any, any, any>>(\n inputSchema: TInput,\n) {\n return v.pipe(\n inputSchema,\n v.transform((input) => camelToPascalKeys(input)),\n );\n}\n\n/**\n * Creates a schema that transforms PascalCase API responses to camelCase\n */\nexport function createResponseSchema<TApi extends BaseSchema<any, any, any>>(\n apiSchema: TApi,\n) {\n return v.pipe(\n apiSchema,\n v.transform((input) => pascalToCamelKeys(input)),\n );\n}\n\n/**\n * Creates a validation schema for already-transformed PascalCase data with @ attributes\n * Used for nested objects like AccountPolicies, FinancialDetail, DynamicFields\n * Takes the same input schema used in createApiSchema and generates the validation schema\n * by directly using the ATTRIBUTE_FIELDS logic to determine which fields become attributes\n */\nexport function createApiValidationSchema<TEntries extends ObjectEntries>(\n inputSchema: v.ObjectSchema<TEntries, any>,\n) {\n const validationEntries: Record<string, any> = {};\n\n // Build validation schema based on ATTRIBUTE_FIELDS\n for (const key in inputSchema.entries) {\n const isAttribute = ATTRIBUTE_FIELDS.has(key);\n const pascalKey = key.charAt(0).toUpperCase() + key.slice(1);\n const finalKey = isAttribute ? `@${pascalKey}` : pascalKey;\n\n validationEntries[finalKey] = inputSchema.entries[key];\n }\n\n return v.object(validationEntries as TEntries);\n}\n","type CamelFromDelimiter<S extends string> = S extends `${infer H}_${infer T}`\n ? `${H}${Capitalize<CamelFromDelimiter<T>>}`\n : S extends `${infer H}-${infer T}`\n ? `${H}${Capitalize<CamelFromDelimiter<T>>}`\n : S;\n\ntype ToCamelCase<S extends string> =\n CamelFromDelimiter<S> extends `${infer F}${infer R}`\n ? `${Lowercase<F>}${R}`\n : CamelFromDelimiter<S>;\n\ntype PascalFromDelimiter<S extends string> = S extends `${infer H}_${infer T}`\n ? `${Capitalize<H>}${Capitalize<PascalFromDelimiter<T>>}`\n : S extends `${infer H}-${infer T}`\n ? `${Capitalize<H>}${Capitalize<PascalFromDelimiter<T>>}`\n : S;\n\ntype ToPascalCase<S extends string> =\n PascalFromDelimiter<S> extends `${infer F}${infer R}`\n ? `${Capitalize<F>}${R}`\n : Capitalize<PascalFromDelimiter<S>>;\n\nexport type Camelize<T> = T extends readonly (infer U)[]\n ? Camelize<U>[]\n : T extends object\n ? {\n [K in keyof T as K extends `@${infer Rest}`\n ? ToCamelCase<Rest> // Strip @ prefix and camelCase the rest\n : ToCamelCase<K & string>]: Camelize<T[K]>;\n }\n : T;\n\nexport type Pascalize<T> = T extends readonly (infer U)[]\n ? Pascalize<U>[]\n : T extends object\n ? {\n [K in keyof T as K extends `@${infer Rest}`\n ? ToPascalCase<Rest> // Strip @ prefix and PascalCase the rest\n : ToPascalCase<K & string>]: Pascalize<T[K]>;\n }\n : T;\n\nfunction camelToPascal(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nfunction pascalToCamel(str: string): string {\n return str.charAt(0).toLowerCase() + str.slice(1);\n}\n\n/**\n * Checks if an object is a special built-in type that should not be transformed\n */\nfunction isSpecialObject(obj: unknown): boolean {\n return (\n obj instanceof Date ||\n obj instanceof RegExp ||\n obj instanceof Map ||\n obj instanceof Set ||\n obj instanceof Error\n );\n}\n\nexport const ATTRIBUTE_FIELDS = new Set([\n 'recordCode',\n 'insertCriteria',\n 'currencyCode',\n 'creditLimit',\n 'c_PaymentType',\n 'c_SpecPaymentTypeCode',\n 's_PaymentType',\n 's_SpecPaymentTypeCode',\n 'enableElectronicInvoicing',\n 'electronicInvoicingType',\n 'key',\n 'value',\n 'minDate',\n 'maxDate',\n 'hostID',\n 'xtoken',\n 'interface',\n 'userName',\n 'status',\n 'acceptProfilingPolicies',\n 'acceptPrivacyPolicies',\n 'acceptNewsletterPolicies',\n]);\n\n/**\n * Transforms object keys from camelCase to PascalCase\n * Adds @ prefix to fields in ATTRIBUTE_FIELDS for XML attributes\n */\nexport function camelToPascalKeys<T>(obj: T): Pascalize<T> {\n if (!obj || typeof obj !== 'object') {\n return obj as Pascalize<T>;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => camelToPascalKeys(item)) as Pascalize<T>;\n }\n\n if (isSpecialObject(obj)) {\n return obj as Pascalize<T>;\n }\n\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n const isAttribute = ATTRIBUTE_FIELDS.has(key);\n const pascalKey = camelToPascal(key);\n const finalKey = isAttribute ? `@${pascalKey}` : pascalKey;\n\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n if (isSpecialObject(value)) {\n result[finalKey] = value;\n } else {\n result[finalKey] = camelToPascalKeys(value as Record<string, unknown>);\n }\n } else if (Array.isArray(value)) {\n result[finalKey] = value.map((item) =>\n typeof item === 'object' && item && !Array.isArray(item)\n ? camelToPascalKeys(item as Record<string, unknown>)\n : item,\n );\n } else {\n result[finalKey] = value;\n }\n }\n return result as Pascalize<T>;\n}\n\n/**\n * Transforms object keys from PascalCase to camelCase\n * Strips @ prefix from XML attributes\n */\nexport function pascalToCamelKeys<T>(obj: T): Camelize<T> {\n if (!obj || typeof obj !== 'object') {\n return obj as Camelize<T>;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => pascalToCamelKeys(item)) as Camelize<T>;\n }\n\n if (isSpecialObject(obj)) {\n return obj as Camelize<T>;\n }\n\n const result: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(obj)) {\n if (key.startsWith('@')) {\n const strippedKey = key.slice(1);\n const camelKey = pascalToCamel(strippedKey);\n result[camelKey] = value;\n } else {\n const camelKey = pascalToCamel(key);\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n if (isSpecialObject(value)) {\n result[camelKey] = value;\n } else {\n result[camelKey] = pascalToCamelKeys(\n value as Record<string, unknown>,\n );\n }\n } else if (Array.isArray(value)) {\n result[camelKey] = value.map((item) =>\n typeof item === 'object' && item && !Array.isArray(item)\n ? pascalToCamelKeys(item as Record<string, unknown>)\n : item,\n );\n } else {\n result[camelKey] = value;\n }\n }\n }\n return result as Camelize<T>;\n}\n","import * as v from 'valibot';\nimport { RqHeaderSchema, RsStatusSchema } from './common.js';\nimport { MasterRecordDetailApiValidationSchema } from './master-record.js';\nimport { createResponseSchema } from '../utils/schema-transform.js';\n\n/**\n * Complete upsert request schema with header and required InsertCriteria\n */\nexport const ManageMasterRecordRequestSchema = v.object({\n RqHeader: RqHeaderSchema,\n MasterRecordDetail: MasterRecordDetailApiValidationSchema,\n});\n\n/**\n * Upsert master record response schema (transforms to camelCase)\n */\nexport const ManageMasterRecordResponseSchema = createResponseSchema(\n v.object({\n RsStatus: RsStatusSchema,\n MasterRecordDetail: v.optional(MasterRecordDetailApiValidationSchema),\n }),\n);\n","/**\n * Result type for functional error handling\n */\nexport type Result<T, E = Error> =\n | { success: true; data: T }\n | { success: false; error: E };\n\n/**\n * Creates a successful result\n */\nexport function ok<T>(data: T): Result<T, never> {\n return { success: true, data };\n}\n\n/**\n * Creates an error result\n */\nexport function err<E>(error: E): Result<never, E> {\n return { success: false, error };\n}\n","import { AvesError } from '../error.js';\n\nfunction buildUrl(baseURL: string, endpoint: string): URL {\n try {\n const base = new URL(baseURL);\n const basePath = base.pathname.endsWith('/')\n ? base.pathname.slice(0, -1)\n : base.pathname;\n const combinedPath = basePath + endpoint;\n\n return new URL(combinedPath, base);\n } catch (error) {\n throw new AvesError(\n 'validation',\n `Invalid baseURL: ${error instanceof Error ? error.message : 'Invalid URL format'}`,\n );\n }\n}\n\n/**\n * Validates and combines baseURL with endpoint\n * @param baseURL - Base URL (must be http:// or https://)\n * @param endpoint - Endpoint path (must start with /)\n * @returns Combined URL string\n * @throws AvesError if URL is invalid or protocol is not http/https\n */\nexport function parseUrl(baseURL: string, endpoint: string): string {\n if (!endpoint.startsWith('/')) {\n throw new AvesError(\n 'validation',\n `Invalid endpoint: endpoint must start with '/' but got '${endpoint}'`,\n );\n }\n\n const normalizedBaseURL = baseURL.replace(/\\/$/, '');\n\n const url = buildUrl(normalizedBaseURL, endpoint);\n\n if (url.protocol !== 'http:' && url.protocol !== 'https:') {\n throw new AvesError(\n 'validation',\n `Invalid protocol: baseURL must use http:// or https:// but got '${url.protocol}'`,\n );\n }\n\n return url.toString();\n}\n","export interface TimeoutController {\n signal: AbortSignal;\n clear?: () => void;\n}\n\n/**\n * Create an AbortSignal that will automatically abort after `timeoutMs`.\n * If `timeoutMs` is not provided or <= 0, no automatic abort is scheduled.\n */\nexport function createTimeoutSignal(timeoutMs?: number): TimeoutController {\n const controller = new AbortController();\n\n if (!timeoutMs || timeoutMs <= 0) {\n return { signal: controller.signal };\n }\n\n const timeoutId = setTimeout(() => controller.abort(), timeoutMs);\n\n return {\n signal: controller.signal,\n clear: () => clearTimeout(timeoutId),\n };\n}\n"],"mappings":"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","names":["r","parse","safeParse","ValiError","XMLParser","XMLBuilder","ERROR_KINDS","AvesError","kind","message","status","code","validationError","apiError","unknownError","buildDetails","issues","issue","path","segment","text","isAbortError","error","parserOptions","builderOptions","parser","XMLParser","builder","XMLBuilder","jsonToXml","json","error","AvesError","xmlToJson","xml","v","v","RqHeaderSchema","warningsSchema","input","RsStatusSchema","val","v","v","camelToPascal","str","pascalToCamel","isSpecialObject","obj","ATTRIBUTE_FIELDS","camelToPascalKeys","item","result","key","value","isAttribute","pascalKey","finalKey","pascalToCamelKeys","strippedKey","camelKey","createApiSchema","inputSchema","input","camelToPascalKeys","createResponseSchema","apiSchema","pascalToCamelKeys","createApiValidationSchema","validationEntries","key","isAttribute","ATTRIBUTE_FIELDS","pascalKey","finalKey","paymentTypeSchema","FinancialDetailInputSchema","FinancialDetailSchema","createApiSchema","FinancialDetailApiValidationSchema","createApiValidationSchema","DynamicFieldsInputSchema","DynamicFieldsSchema","DynamicFieldsApiValidationSchema","flagSchema","recordStatusSchema","recordTypeSchema","insertCriteriaSchema","AccountPoliciesInputSchema","AccountPoliciesSchema","AccountPoliciesApiValidationSchema","MasterRecordDetailSchema","MasterRecordDetailApiSchema","MasterRecordDetailResponseSchema","createResponseSchema","MasterRecordDetailApiValidationSchema","LastModificationDateInputSchema","languageCodeField","CodeSearchSchema","NameSearchSchema","VatCodeSearchSchema","ZoneSearchSchema","CategorySearchSchema","EmailSearchSchema","LastModDateSearchSchema","SearchFieldSearchSchema","ExternalRefCodeSearchSchema","SearchMasterRecordSchema","transformRecordCode","input","recordCode","_discard","rest","SearchMasterRecordApiSchema","createApiSchema","SearchMasterRecordRequestSchema","RqHeaderSchema","searchFields","RqHeader","MasterRecordListApiSchema","MasterRecordDetailApiValidationSchema","SearchMasterRecordResponseSchema","createResponseSchema","RsStatusSchema","v","ManageMasterRecordRequestSchema","RqHeaderSchema","MasterRecordDetailApiValidationSchema","ManageMasterRecordResponseSchema","createResponseSchema","RsStatusSchema","ok","data","err","error","buildUrl","baseURL","endpoint","base","combinedPath","error","AvesError","parseUrl","normalizedBaseURL","url","createTimeoutSignal","timeoutMs","controller","timeoutId","createRootElement","name","object","XML_ROOT_ELEMENTS","AvesClient","options","endpoint","parseUrl","output","rsStatus","status","err","apiError","ok","error","defaultMessage","AvesError","ValiError","details","buildDetails","validationError","unknownError","requestBody","responseRootKey","responseSchema","signal","clear","createTimeoutSignal","url","xmlBody","jsonToXml","response","r","responseText","rootElement","xmlToJson","parseResult","safeParse","isAbortError","params","requestData","parse","SearchMasterRecordRequestSchema","SearchMasterRecordResponseSchema","record","apiRecord","MasterRecordDetailApiSchema","ManageMasterRecordRequestSchema","ManageMasterRecordResponseSchema"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "aves-sdk",
|
|
3
|
-
"version": "1.2.
|
|
3
|
+
"version": "1.2.14",
|
|
4
4
|
"description": "TypeScript SDK for AVES XML REST",
|
|
5
5
|
"homepage": "https://github.com/simoneguglielmi/aves-sdk#readme",
|
|
6
6
|
"repository": [
|
|
@@ -59,8 +59,8 @@
|
|
|
59
59
|
"devDependencies": {
|
|
60
60
|
"@tsconfig/node22": "^22.0.5",
|
|
61
61
|
"@types/node": "^24.6.2",
|
|
62
|
-
"@typescript-eslint/eslint-plugin": "^8.
|
|
63
|
-
"@typescript-eslint/parser": "^8.
|
|
62
|
+
"@typescript-eslint/eslint-plugin": "^8.53.1",
|
|
63
|
+
"@typescript-eslint/parser": "^8.53.1",
|
|
64
64
|
"eslint": "^9.39.2",
|
|
65
65
|
"rimraf": "^6.1.2",
|
|
66
66
|
"tsup": "^8.5.1",
|