@seeka-labs/sdk-apps-server 1.1.36 → 1.1.38
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/sdk-apps-server.js +1 -1
- package/dist/sdk-apps-server.js.map +1 -1
- package/dist/sdk-apps-server.module.js +1 -1
- package/dist/sdk-apps-server.module.js.map +1 -1
- package/dist/types/src/api/helper/auth/index.d.ts.map +1 -1
- package/dist/types/src/helpers/util/index.d.ts +1 -1
- package/dist/types/src/helpers/util/index.d.ts.map +1 -1
- package/package.json +2 -2
package/dist/sdk-apps-server.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var e=require("crypto"),t=require("axios"),i=require("openid-client"),r=require("memory-cache"),s=require("http"),o=require("https");function n(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function a(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach(function(i){if("default"!==i){var r=Object.getOwnPropertyDescriptor(e,i);Object.defineProperty(t,i,r.get?r:{enumerable:!0,get:function(){return e[i]}})}}),t.default=e,t}var c,l,p,d,u,h,g,v,f,m,y,k,P,A,S,I,x=/*#__PURE__*/a(e),w=/*#__PURE__*/n(e),C=/*#__PURE__*/n(t),b=/*#__PURE__*/a(i),T=/*#__PURE__*/a(r),E=/*#__PURE__*/n(s),N=/*#__PURE__*/n(o);class U{constructor(){this.appId=void 0,this.appSecret=void 0,this.ingestUrl=void 0,this.issuerUrl=void 0,this.organisationId=void 0,this.applicationInstallId=void 0,this.runtime=void 0,this.logger=void 0,this.grantedPermissions=void 0,this.transformApiRequest=void 0,this.transformApiResponse=void 0,this.hasAnyPermissions=void 0,this.hasAllPermissions=void 0,this.hasPermission=void 0}}class O{constructor(e){this.config=void 0,this.transformOptions=async e=>await this.config.transformApiRequest(e),this.transformResult=async(e,t,i)=>await this.config.transformApiResponse(e,t,i),this.config=e}}class _ extends O{constructor(e,t,i){super(e),this.instance=void 0,this.baseUrl=void 0,this.jsonParseReviver=void 0,this.instance=i||C.default.create(),this.baseUrl=null!=t?t:"https://api.seeka.services"}merge(e,t){let i=this.baseUrl+"/api/identity";i=i.replace(/[?&]$/,"");const r=JSON.stringify(e);return this.transformOptions({data:r,method:"POST",url:i,headers:{"Content-Type":"application/json",Accept:"application/json"},cancelToken:t}).then(e=>this.instance.request(e)).catch(e=>{if(R(e)&&e.response)return e.response;throw e}).then(e=>this.transformResult(i,e,e=>this.processMerge(e)))}processMerge(e){const t=e.status;let i={};if(e.headers&&"object"==typeof e.headers)for(const t in e.headers)e.headers.hasOwnProperty(t)&&(i[t]=e.headers[t]);if(200===t){let t=null;return t=JSON.parse(e.data),Promise.resolve(t)}if(401===t){const r=e.data;let s=null;return s=JSON.parse(r),L("A server side error occurred.",t,r,i,s)}if(422===t){const r=e.data;let s=null;return s=JSON.parse(r),L("A server side error occurred.",t,r,i,s)}if(400===t){const r=e.data;let s=null;return s=JSON.parse(r),L("A server side error occurred.",t,r,i,s)}return 200!==t&&204!==t?L("An unexpected server error occurred.",t,e.data,i):Promise.resolve(null)}}class F extends O{constructor(e,t,i){super(e),this.instance=void 0,this.baseUrl=void 0,this.jsonParseReviver=void 0,this.instance=i||C.default.create(),this.baseUrl=null!=t?t:"https://api.seeka.services"}batch(e,t){let i=this.baseUrl+"/api/ingest";i=i.replace(/[?&]$/,"");const r=JSON.stringify(e);return this.transformOptions({data:r,method:"POST",url:i,headers:{"Content-Type":"application/json"},cancelToken:t}).then(e=>this.instance.request(e)).catch(e=>{if(R(e)&&e.response)return e.response;throw e}).then(e=>this.transformResult(i,e,e=>this.processBatch(e)))}processBatch(e){const t=e.status;let i={};if(e.headers&&"object"==typeof e.headers)for(const t in e.headers)e.headers.hasOwnProperty(t)&&(i[t]=e.headers[t]);if(202===t)return Promise.resolve(null);if(401===t){const r=e.data;let s=null;return s=JSON.parse(r),L("A server side error occurred.",t,r,i,s)}if(422===t){const r=e.data;let s=null;return s=JSON.parse(r),L("A server side error occurred.",t,r,i,s)}if(400===t){const r=e.data;let s=null;return s=JSON.parse(r),L("A server side error occurred.",t,r,i,s)}return 200!==t&&204!==t?L("An unexpected server error occurred.",t,e.data,i):Promise.resolve(null)}}exports.ResponseResultType=void 0,(c=exports.ResponseResultType||(exports.ResponseResultType={})).Undefined="undefined",c.Success="success",c.Failed="failed",exports.PrivacyConsentType=void 0,(l=exports.PrivacyConsentType||(exports.PrivacyConsentType={})).Unknown="unknown",l.Informed="informed",l.Implied="implied",l.Explicit="explicit",l.Active="active",l.Passive="passive",exports.TrackingEventSourceOriginType=void 0,(p=exports.TrackingEventSourceOriginType||(exports.TrackingEventSourceOriginType={})).Browser="browser",p.Server="server",p.Mobile="mobile",p.Desktop="desktop",p.PhysicalStore="physicalStore",p.Email="email",p.Phone="phone",p.Chat="chat",p.Automatic="automatic",exports.TrackingActivityNames=void 0,(d=exports.TrackingActivityNames||(exports.TrackingActivityNames={})).Undefined="undefined",d.PageViewOrganic="pageViewOrganic",d.PageViewUtmAttributed="pageViewUtmAttributed",d.AddPaymentMethod="addPaymentMethod",d.AddToWishlist="addToWishlist",d.ContactMessage="contactMessage",d.Custom="custom",d.SyncCart="syncCart",d.Order="order",d.InitiateCheckout="initiateCheckout",d.AddToCart="addToCart",d.RemoveFromCart="removeFromCart",d.OneTimeItemPurchase="oneTimeItemPurchase",d.SubscriptionItemPurchase="subscriptionItemPurchase",d.ViewProduct="viewProduct",d.ViewPage="viewPage",d.ApplyPromotionalCode="applyPromotionalCode",d.KeywordSearch="keywordSearch",d.UserLoginSignup="userLoginSignup",d.UserLogin="userLogin",d.NewsletterSignup="newsletterSignup",d.Lead="lead",d.ChangeProductAttribute="changeProductAttribute",d.FilterItemsByAttribute="filterItemsByAttribute",d.Schedule="schedule",d.ViewContentItem="viewContentItem",d.StartTrial="startTrial",exports.ECommerceContentType=void 0,(u=exports.ECommerceContentType||(exports.ECommerceContentType={})).Undefined="undefined",u.SingleProduct="singleProduct",u.SingleVariant="singleVariant",u.Collection="collection",exports.ECommercePlatform=void 0,(h=exports.ECommercePlatform||(exports.ECommercePlatform={})).None="none",h.BigCommerce="bigCommerce",h.Shopify="shopify",h.OrderGroove="orderGroove",h.Magento="magento",h.Generic="generic",h.WooCommerce="wooCommerce",h.Demandware="demandware",exports.ECommerceFulfillmentStatus=void 0,(g=exports.ECommerceFulfillmentStatus||(exports.ECommerceFulfillmentStatus={})).Undefined="undefined",g.Fulfilled="fulfilled",g.NoneFulfilled="noneFulfilled",g.PartiallyFulfilled="partiallyFulfilled",g.RestockedOrCancelled="restockedOrCancelled",g.Pending="pending",exports.ECommerceFinancialStatus=void 0,(v=exports.ECommerceFinancialStatus||(exports.ECommerceFinancialStatus={})).Undefined="undefined",v.Pending="pending",v.Authorized="authorized",v.PartiallyPaid="partiallyPaid",v.Paid="paid",v.PartiallyRefunded="partiallyRefunded",v.Refunded="refunded",v.Voided="voided",exports.ConvergePipelineLoggableActivityType=void 0,(f=exports.ConvergePipelineLoggableActivityType||(exports.ConvergePipelineLoggableActivityType={})).Generic="generic",f.ActivityIngress="activityIngress",f.ActivityEgress="activityEgress",f.UserProfile="userProfile",f.SdkLog="sdkLog",f.Detections="detections",f.ActivityEgressFilter="activityEgressFilter",f.Diagnosis="diagnosis",f.PipelineIntegrationOutput="pipelineIntegrationOutput",exports.SdkLogEventLevel=void 0,(m=exports.SdkLogEventLevel||(exports.SdkLogEventLevel={})).Information="information",m.Warning="warning",m.Error="error",m.Verbose="verbose",exports.SeekaWebhookCallType=void 0,(y=exports.SeekaWebhookCallType||(exports.SeekaWebhookCallType={})).None="none",y.Probe="probe",y.AppInstalled="appInstalled",y.IdentityChanged="identityChanged",y.ActivityAccepted="activityAccepted",y.AppInstallSettingsUpdated="appInstallSettingsUpdated",y.AppUninstalled="appUninstalled",y.BrowserSdkPlugin="browserSdkPlugin",exports.ClickAttributionSourcePlatform=void 0,(k=exports.ClickAttributionSourcePlatform||(exports.ClickAttributionSourcePlatform={})).Unknown="unknown",k.Google="google",k.Meta="meta",k.Snapchat="snapchat",k.Pinterest="pinterest",k.TikTok="tikTok",exports.ActivityPipelineActivityFilterType=void 0,(P=exports.ActivityPipelineActivityFilterType||(exports.ActivityPipelineActivityFilterType={})).Undefined="undefined",P.PurchaseMade="purchaseMade",P.ActivityTracked="activityTracked",exports.ConditionComparer=void 0,(A=exports.ConditionComparer||(exports.ConditionComparer={})).Undefined="undefined",A.And="and",A.Or="or",exports.ActivityPipelineActivityFilterSourceItemType=void 0,(S=exports.ActivityPipelineActivityFilterSourceItemType||(exports.ActivityPipelineActivityFilterSourceItemType={})).Undefined="undefined",S.Domain="domain",S.Pipeline="pipeline",S.Wildcard="wildcard",S.Url="url",S.PagePath="pagePath",exports.ConditionOperator=void 0,(I=exports.ConditionOperator||(exports.ConditionOperator={})).Undefined="undefined",I.Equals="equals",I.NotEquals="notEquals",I.Contains="contains",I.NotContains="notContains",I.StartsWith="startsWith",I.EndsWith="endsWith",I.IsNull="isNull",I.NotNull="notNull",I.IsTrue="isTrue",I.IsFalse="isFalse",I.GreaterThanOrEquals="greaterThanOrEquals",I.LessThanOrEquals="lessThanOrEquals",I.GreaterThan="greaterThan",I.LessThan="lessThan",I.Before="before",I.After="after",I.Between="between",I.In="in",I.NotIn="notIn",I.Regex="regEx",I.Any="any";class B extends Error{constructor(e,t,i,r,s){super(),this.message=void 0,this.status=void 0,this.response=void 0,this.headers=void 0,this.result=void 0,this.isApiException=!0,this.message=e,this.status=t,this.response=i,this.headers=r,this.result=s}static isApiException(e){return!0===e.isApiException}}function L(e,t,i,r,s){throw null!=s?s:new B(e,t,i,r,null)}function R(e){return e&&!0===e.isAxiosError}const $=()=>`${q(new Date)}.${M()}`,M=()=>Math.floor(8999999999*Math.random()+1e9).toString(),q=e=>{let t=(e.getUTCMonth()+1).toString();t.length<2&&(t="0"+t);let i=e.getUTCDate().toString();i.length<2&&(i="0"+i);let r=e.getUTCHours().toString();r.length<2&&(r="0"+r);let s=e.getUTCMinutes().toString();s.length<2&&(s="0"+s);let o=e.getUTCSeconds().toString();return o.length<2&&(o="0"+o),`${e.getUTCFullYear()}${t}${i}.${r}${s}${o}`},j=(e,t)=>e.reduce((e,i,r)=>{const s=Math.floor(r/t);return e[s]||(e[s]=[]),e[s].push(i),e},[]),W={identity:{receiveFull:"Identity.Receive.Pii",send:"Identity.Send"},activity:{receiveAnon:"Activity.Receive.Anon",receiveFull:"Activity.Receive.Pii",send:"Activity.Send"}},D="seeka:sdk";class z{constructor(e,t){this.appId=void 0,this.appInstallationId=void 0,this.set=async(e,t,i)=>{const r=this.getKey(e);T.put(r,JSON.stringify(t),i)},this.getOrSet=async(e,t,i)=>{const r=this.getKey(e),s=T.get(r);if(s){const e=JSON.parse(s);return i&&await i(e),e}const o=await t();return o?(T.put(r,JSON.stringify(o.value),o.expiryAbsoluteMilliseconds),o.value):null},this.getKey=e=>this.appInstallationId?`${D}:${this.appId}:${this.appInstallationId}:${e}`:`${D}:${this.appId}:${e}`,this.appId=e,this.appInstallationId=t}}const G=async e=>{const t={applicationId:e.appId,issuer:{url:e.issuerUrl}};e.logger?e.logger.debug("Seeka auth: getting issuer",{...t}):console.debug("Seeka auth: getting issuer",{...t});const i=new z(e.appId,e.applicationInstallId),r=(s=e.issuerUrl+"_"+e.appId,x.createHash("md5").update(s).digest("hex"));var s;return await i.getOrSet(r,async()=>({value:await J(e),expiryAbsoluteMilliseconds:36e5}),async()=>{e.logger?e.logger.verbose("Seeka auth: got issuer from cache",{...t}):console.debug("Seeka auth: got issuer from cache",{...t})})},J=async e=>{const t={applicationId:e.appId,issuer:{url:e.issuerUrl}};return e.logger?e.logger.verbose("Seeka auth: discovering issuer from server",{...t}):console.info("Seeka auth: discovering issuer from server",{...t}),await b.discovery(new URL(e.issuerUrl),e.appId.replace(/-/g,""),e.appSecret,void 0,{timeout:1e4})},V=async e=>{const t=new z(e.appId,e.applicationInstallId),i={applicationId:e.appId,issuer:{url:e.issuerUrl}};return await t.getOrSet("auth:token:appinstall",async()=>{const t=await(async e=>{const t={applicationId:e.appId,issuer:{url:e.issuerUrl}},i=await G(e);if(!i||!i.value)throw new Error("Failed to get issuer");try{let r=await b.clientCredentialsGrant(i.value,{});const s={...t,token:{expires_at:r.expires_at,token_type:r.token_type,scope:r.scope}};return e.logger?e.logger.verbose("Seeka auth: got client access token from server",{...s}):console.info("Seeka auth: got app client token from server",{...s}),{token_type:r.token_type,access_token:r.access_token,expires_in:r.expires_in,id_token:r.id_token,refresh_token:r.refresh_token,scope:r.scope,authorization_details:r.authorization_details}}catch(i){const r={...t,error:i};return e.logger?e.logger.error("Seeka auth: failed to get client access token from server",{...r}):console.debug("Seeka auth: failed to get client access token from server",{...r}),null}})(e);if(!t)return null;const i=await(async(e,t)=>{const i={applicationId:t.appId,issuer:{url:t.issuerUrl}},r=await G(t);if(!r||!r.value)throw new Error("Failed to get issuer");try{const s=await b.genericGrantRequest(r.value,"app_install_token",{applicationInstallId:t.applicationInstallId,access_token:e}),o={...i,token:{expires_at:s.expires_at,token_type:s.token_type,scope:s.scope}};return t.logger?t.logger.verbose("Seeka auth: got app access token from server",{...o}):console.info("Seeka auth: got app access token from server",{...o}),{token_type:s.token_type,access_token:s.access_token,expires_in:s.expires_in,id_token:s.id_token,refresh_token:s.refresh_token,scope:s.scope,authorization_details:s.authorization_details}}catch(e){const r={...i,error:e};return t.logger?t.logger.error("Seeka auth: failed to get app access token from server",{...r}):console.debug("Seeka auth: failed to get app access token from server",{...r}),null}})(t.access_token,e);return i?{value:i,expiryAbsoluteMilliseconds:((i.expires_in>t.expires_in?t.expires_in:i.expires_in)||9e5)-6e4}:null},async()=>{e.logger?e.logger.verbose("Seeka auth: got app token from cache",{...i}):console.debug("Seeka auth: got app token from cache",{...i})})},K=new E.default.Agent({keepAlive:!0,scheduling:"fifo"}),H=new N.default.Agent({keepAlive:!0,scheduling:"fifo"}),X=e=>{const t=C.default.create({httpAgent:K,httpsAgent:H});return t.interceptors.request.use(function(t){const i={url:t.url,method:t.method};return e.logger?e.logger.debug(`Seeka API: making call to ${i.url}`,{...i}):console.debug(`Seeka API: making call to ${i.url}`,{...i}),t},function(t){const i={error:t};return e.logger?e.logger.http("Seeka API: failed to send request",{...i}):console.debug("Seeka API: failed to send request",{...i}),Promise.reject(t)}),t.interceptors.response.use(function(t){var i,r;const s={url:(null==(i=t.request)?void 0:i.url)||t.config.url,method:(null==(r=t.request)?void 0:r.method)||t.config.method,response:{status:t.status}};return e.logger?e.logger.http(`Seeka API: call to ${s.url} succeeded`,{...s}):console.debug(`Seeka API: call to ${s.url} succeeded`,{...s}),t},function(t){var i;const{code:r,status:s,message:o}=t,{headers:n,url:a,method:c}=null==t?void 0:t.config,l={code:r,status:s,message:o,headers:n,url:a,method:c,content:null==t||null==(i=t.response)?void 0:i.data};return e.logger?e.logger.error(`Seeka API: call to ${l.url} failed`,{...l}):console.error(`Seeka API: call to ${l.url} failed`,{...l}),Promise.reject(t)}),t};class Y{constructor(e){this.config=void 0,this.maxBatchSize=50,this.refreshOrPrimeTokenCache=async()=>{await V(this.config)},this.ingestionService=void 0,this.identityService=void 0,this.checkPermission=(e,t)=>{if(!this.config.hasPermission(e))throw new Error("Cannot perform operation "+t+" on installationId "+this.config.applicationInstallId+" without permission "+e+". Currently granted permissions: "+(this.config.grantedPermissions?this.config.grantedPermissions.join(", "):"none"));return!0},this.mergeIdentity=async(e,t)=>{var i;this.checkPermission(W.identity.send,"mergeIdentity");const r=$();return null==(i=(await this.identityService.merge({id:e,src:{method:"",origin:t.origin,time:void 0,loc:t.loc,sess:r,diag:"true"===process.env.SEEKA_DEBUG_ENABLED?r:void 0,runtime:this.config.runtime}})).result)?void 0:i.personId},this.mergeIdentityBatch=async(e,t)=>{this.checkPermission(W.identity.send,"mergeIdentityBatch");const i=$();var r;if(0===e.length)return void(null==(r=this.config.logger)||r.debug("No identities in batch"));const s={method:"",origin:t.origin,time:void 0,loc:t.loc,sess:i,diag:"true"===process.env.SEEKA_DEBUG_ENABLED?i:void 0,runtime:this.config.runtime},o=j(e,this.maxBatchSize);if(o.length>1&&this.config.logger&&this.config.logger.debug(`Identity batch size ${e} is greater than ${this.maxBatchSize}, splitting into ${o.length} batches`),await this.trackActivityBatchRaw({data:o[0].map(e=>({id:{id:e||{},src:{...s}}}))}),o.length>1){const e=o.map((e,t)=>{var i;return 0===t?Promise.resolve():(null==(i=this.config.logger)||i.verbose(`Processing identity batch ${t+1} of ${o.length}`),this.trackActivityBatchRaw({data:e.map(e=>({id:{id:e||{},src:{...s}}}))}))});await Promise.all(e)}},this.trackActivityBatch=async(e,t)=>{this.checkPermission(W.activity.send,"trackActivityBatch");const i=$();var r;if(0===e.length)return void(null==(r=this.config.logger)||r.debug("No activities in batch"));const s={method:"",origin:t.origin,time:void 0,loc:t.loc,sess:i,diag:"true"===process.env.SEEKA_DEBUG_ENABLED?i:void 0,runtime:this.config.runtime},o=j(e,this.maxBatchSize);if(o.length>1&&this.config.logger&&this.config.logger.debug(`Activity batch size ${e.length} is greater than ${this.maxBatchSize}, splitting into ${o.length} batches`),await this.trackActivityBatchRaw({data:o[0].map(e=>({ev:{id:e.profile||{},src:{...s},payload:e.activity}}))}),o.length>1){const e=o.map((e,t)=>{var i;return 0===t?Promise.resolve():(null==(i=this.config.logger)||i.verbose(`Processing activity batch ${t+1} of ${o.length}`),this.trackActivityBatchRaw({data:e.map(e=>({ev:{id:e.profile||{},src:{...s},payload:e.activity}}))}))});await Promise.all(e)}},this.trackActivityBatchRaw=async e=>{await this.ingestionService.batch(e)},this.trackActivityForProfileId=async(e,t,i)=>{this.checkPermission(W.activity.send,"trackActivityForProfileId"),await this.trackActivityForProfileIdBatch([e],t,i)},this.trackActivityForProfileIdBatch=async(e,t,i)=>{this.checkPermission(W.activity.send,"trackActivityForProfileIdBatch"),await this.trackActivityBatch(e.map(e=>({activity:e,profile:t?{seekaPId:t}:void 0})),i)},this.trackActivityForProfile=async(e,t,i)=>{this.checkPermission(W.activity.send,"trackActivityForProfile"),await this.trackActivityForProfileBatch([e],t,i)},this.trackActivityForProfileBatch=async(e,t,i)=>{this.checkPermission(W.activity.send,"trackActivityForProfileBatch"),await this.trackActivityBatch(e.map(e=>({activity:e,profile:t})),i)},this.config=e,this.ingestionService=(e=>new F(e,e.ingestUrl,X(e)))(e),this.identityService=(e=>new _(e,e.ingestUrl,X(e)))(e)}}const Q="x-seeka-signature-sha256",Z=(e,t,i)=>{if(!t)return!1;let r=null;if(t.get&&"function"==typeof t.get)r=t.get(Q);else{const e=t[Q];e&&(Array.isArray(e)&&e.length>0?r=e[0]:("string"==typeof e||e instanceof String)&&(r=e))}if(!r)return!1;const s=ee(e,i)===r;return s||console.warn("Invalid webhook signature"),s},ee=(e,t)=>x.createHmac("sha256",e).update(t).digest("hex"),te=(e,t,i,r,s)=>{const o=new U;return o.appId=e.applicationId,o.appSecret=t,o.ingestUrl=process.env.SEEKA_INGEST_URL||"https://router.seeka.services",o.issuerUrl=process.env.SEEKA_ISSUER_URL||"https://account.seeka.app",o.organisationId=e.organisationId,o.applicationInstallId=e.applicationInstallId,o.runtime={type:"sdk/js/apps-server",ver:"1.1.36",client:i},o.logger=s,o.grantedPermissions=r,o.transformApiRequest=e=>ie(o,e),o.transformApiResponse=async(e,t,i)=>re(o,e,t,i),o.hasAnyPermissions=e=>!(!o.grantedPermissions||0===o.grantedPermissions.length)&&(!e||0===e.length||e.some(e=>o.grantedPermissions.includes(e))),o.hasAllPermissions=e=>!(!o.grantedPermissions||0===o.grantedPermissions.length)&&(!e||0===e.length||e.every(e=>o.grantedPermissions.includes(e))),o.hasPermission=e=>!(!o.grantedPermissions||0===o.grantedPermissions.length)&&(!e||o.grantedPermissions.includes(e)),o},ie=async(e,t)=>{const i=await V(e);return t.headers={...t.headers,"X-OrgId":e.organisationId,Authorization:"Bearer "+(null==i?void 0:i.access_token)},t},re=async(e,t,i,r)=>(i.data=JSON.stringify(i.data),r(i)),se="aes-192-cbc",oe=(e,t)=>{if(!e)return"";if(!t)throw new Error("Secret is required to encrypt data");const i=w.default.scryptSync(t,"salt",24),r=w.default.randomBytes(16),s=w.default.createCipheriv(se,i,r);return[s.update(e,"utf8","hex")+s.final("hex"),Buffer.from(r).toString("hex")].join("|")},ne=(e,t)=>{if(!e)return"";if(!t)throw new Error("Secret is required to decrypt data");const[i,r]=e.split("|");if(!r)throw new Error("IV not found");const s=w.default.scryptSync(t,"salt",24),o=w.default.createDecipheriv(se,s,Buffer.from(r,"hex"));return o.update(i,"hex","utf8")+o.final("utf8")};class ae{constructor(e){this.appSecret=void 0,this.encryptWithAppSecret=e=>{if(!this.appSecret)throw new Error("App secret is required to encrypt data");return oe(e,this.appSecret)},this.decryptWithAppSecret=e=>{if(!this.appSecret)throw new Error("App secret is required to decrypt data");return ne(e,this.appSecret)},this.appSecret=e}}var ce;class le{constructor(e,t){this.context=void 0,this.appCache=void 0,this.appInstallCache=void 0,this.api=void 0,this.logger=void 0,this.crypto=void 0,this.context=e,this.api=new Y(e.config),this.appCache=new z(e.config.appId),this.appInstallCache=new z(e.config.appId,e.config.applicationInstallId),this.crypto=new ae(e.config.appSecret),this.logger=t}}ce=le,le.create=(e,t,i,r,s)=>new ce({config:te({...t},e,{type:i.name,ver:i.version},r,s)},s);const pe=[exports.TrackingActivityNames.Order,exports.TrackingActivityNames.SubscriptionItemPurchase,exports.TrackingActivityNames.OneTimeItemPurchase];var de;exports.IabPrivacyConsentPurposeId=void 0,(de=exports.IabPrivacyConsentPurposeId||(exports.IabPrivacyConsentPurposeId={})).Undefined="undefined",de.MeasureAdvertisingPerformance="measureAdvertisingPerformance";const ue={[exports.IabPrivacyConsentPurposeId.MeasureAdvertisingPerformance]:7};exports.ApiException=B,exports.ApiServiceProxyBase=O,exports.AppPermissionKeys=W,exports.IabPrivacyConsentPurposeIdMap=ue,exports.IdentityServiceProxy=_,exports.IngestServiceProxy=F,exports.SeekaApiHelper=Y,exports.SeekaAppCacheManager=z,exports.SeekaAppConfig=U,exports.SeekaAppHelper=le,exports.chunk=j,exports.decryptText=ne,exports.encryptText=oe,exports.getActivityName=e=>{const t=Object.keys(exports.TrackingActivityNames),i=e.toLowerCase(),r=t.find(e=>e.toLowerCase()===i);return r?exports.TrackingActivityNames[r]:exports.TrackingActivityNames.Custom},exports.isValidSeekaProfileId=function(e){if(!e||0===e.trim().length)return!1;const t=e.split(".").filter(e=>e.trim().length>0);return 4===t.length&&t[0].toLowerCase()==="sk".toLowerCase()&&t[1].toLowerCase()==="1".toLowerCase()&&!isNaN(parseInt(t[2],10))&&!isNaN(parseInt(t[3],10))},exports.matchActivityPipelineFilters=(e,t,i)=>{if(!e.activity)return[];const r=e.activity,s=r.activityName===exports.TrackingActivityNames.Custom?r.activityNameCustom:r.activityName;if(!s)return[];const o=s.toLowerCase(),n=[];return t.forEach(t=>{var a;if(!t)return;switch(t.type){case exports.ActivityPipelineActivityFilterType.ActivityTracked:if(!t.activityNames)return;if(!t.activityNames.find(e=>e.toLowerCase()===o))return;i.verbose("Matched activity tracked filter",{filter:t,activityName:s});break;case exports.ActivityPipelineActivityFilterType.PurchaseMade:if(!r.activityName||!pe.includes(r.activityName))return;i.verbose("Matched purchase made activity filter",{filter:t,activityName:s});break;default:return void i.warn("Unknown activity filter type",{filter:t})}const c=t.sourceFilter;if(!c)return;const l=e.source,p=null!=l&&l.loc?new URL(l.loc).hostname.toLowerCase():null,d=null==l?void 0:l.pipeline,u=null==d||null==(a=d.convergePipelineIntegrationInstanceId)?void 0:a.toLowerCase(),h=c.filters?c.filters.map(e=>{switch(e.type){case exports.ActivityPipelineActivityFilterSourceItemType.Wildcard:return i.verbose("Matched wildcard source filter",{sourceFilter:e}),!0;case exports.ActivityPipelineActivityFilterSourceItemType.Domain:return!(!p||!e.key||p!==e.key.toLowerCase()||(i.verbose("Matched domain source filter",{sourceFilter:e,activityHostname:p}),0));case exports.ActivityPipelineActivityFilterSourceItemType.Pipeline:return!(!u||!e.key||u!==e.key.toLowerCase()||(i.verbose("Matched pipeline source filter",{sourceFilter:e,sourceConvergePipelineIntegrationInstanceId:u}),0))}}):[];switch(c.comparer){case exports.ConditionComparer.And:h.every(e=>!0===e)||n.push(t);break;case exports.ConditionComparer.Or:h.some(e=>!0===e)&&n.push(t);break;default:i.warn("Unknown source filter comparer",{sourceFilters:c})}}),n},exports.separatePersonFullName=e=>{if(!e)return{firstName:null,lastName:null};const t=e.trim().split(" ");return 1===t.length?{firstName:e,lastName:null}:2===t.length?{firstName:t[0],lastName:t[1]}:{firstName:t[0],lastName:t.slice(1).join(" ")}},exports.throwOnInvalidWebhookSignature=(e,t,i)=>{if(!Z(e,t,i))throw new Error("Invalid webhook signature")},exports.validateWebhookSignature=Z,exports.webhookSignatureHeaderName=Q;
|
|
1
|
+
var e=require("crypto"),t=require("axios"),i=require("openid-client"),r=require("winston"),s=require("memory-cache"),o=require("http"),n=require("https");function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function c(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach(function(i){if("default"!==i){var r=Object.getOwnPropertyDescriptor(e,i);Object.defineProperty(t,i,r.get?r:{enumerable:!0,get:function(){return e[i]}})}}),t.default=e,t}var l,p,d,u,h,g,v,f,y,m,k,P,A,S,I,x,w=/*#__PURE__*/c(e),C=/*#__PURE__*/a(e),b=/*#__PURE__*/a(t),T=/*#__PURE__*/c(i),E=/*#__PURE__*/a(r),N=/*#__PURE__*/c(s),U=/*#__PURE__*/a(o),O=/*#__PURE__*/a(n);class _{constructor(){this.appId=void 0,this.appSecret=void 0,this.ingestUrl=void 0,this.issuerUrl=void 0,this.organisationId=void 0,this.applicationInstallId=void 0,this.runtime=void 0,this.logger=void 0,this.grantedPermissions=void 0,this.transformApiRequest=void 0,this.transformApiResponse=void 0,this.hasAnyPermissions=void 0,this.hasAllPermissions=void 0,this.hasPermission=void 0}}class F{constructor(e){this.config=void 0,this.transformOptions=async e=>await this.config.transformApiRequest(e),this.transformResult=async(e,t,i)=>await this.config.transformApiResponse(e,t,i),this.config=e}}class B extends F{constructor(e,t,i){super(e),this.instance=void 0,this.baseUrl=void 0,this.jsonParseReviver=void 0,this.instance=i||b.default.create(),this.baseUrl=null!=t?t:"https://api.seeka.services"}merge(e,t){let i=this.baseUrl+"/api/identity";i=i.replace(/[?&]$/,"");const r=JSON.stringify(e);return this.transformOptions({data:r,method:"POST",url:i,headers:{"Content-Type":"application/json",Accept:"application/json"},cancelToken:t}).then(e=>this.instance.request(e)).catch(e=>{if(q(e)&&e.response)return e.response;throw e}).then(e=>this.transformResult(i,e,e=>this.processMerge(e)))}processMerge(e){const t=e.status;let i={};if(e.headers&&"object"==typeof e.headers)for(const t in e.headers)e.headers.hasOwnProperty(t)&&(i[t]=e.headers[t]);if(200===t){let t=null;return t=JSON.parse(e.data),Promise.resolve(t)}if(401===t){const r=e.data;let s=null;return s=JSON.parse(r),$("A server side error occurred.",t,r,i,s)}if(422===t){const r=e.data;let s=null;return s=JSON.parse(r),$("A server side error occurred.",t,r,i,s)}if(400===t){const r=e.data;let s=null;return s=JSON.parse(r),$("A server side error occurred.",t,r,i,s)}return 200!==t&&204!==t?$("An unexpected server error occurred.",t,e.data,i):Promise.resolve(null)}}class L extends F{constructor(e,t,i){super(e),this.instance=void 0,this.baseUrl=void 0,this.jsonParseReviver=void 0,this.instance=i||b.default.create(),this.baseUrl=null!=t?t:"https://api.seeka.services"}batch(e,t){let i=this.baseUrl+"/api/ingest";i=i.replace(/[?&]$/,"");const r=JSON.stringify(e);return this.transformOptions({data:r,method:"POST",url:i,headers:{"Content-Type":"application/json"},cancelToken:t}).then(e=>this.instance.request(e)).catch(e=>{if(q(e)&&e.response)return e.response;throw e}).then(e=>this.transformResult(i,e,e=>this.processBatch(e)))}processBatch(e){const t=e.status;let i={};if(e.headers&&"object"==typeof e.headers)for(const t in e.headers)e.headers.hasOwnProperty(t)&&(i[t]=e.headers[t]);if(202===t)return Promise.resolve(null);if(401===t){const r=e.data;let s=null;return s=JSON.parse(r),$("A server side error occurred.",t,r,i,s)}if(422===t){const r=e.data;let s=null;return s=JSON.parse(r),$("A server side error occurred.",t,r,i,s)}if(400===t){const r=e.data;let s=null;return s=JSON.parse(r),$("A server side error occurred.",t,r,i,s)}return 200!==t&&204!==t?$("An unexpected server error occurred.",t,e.data,i):Promise.resolve(null)}}exports.ResponseResultType=void 0,(l=exports.ResponseResultType||(exports.ResponseResultType={})).Undefined="undefined",l.Success="success",l.Failed="failed",exports.PrivacyConsentType=void 0,(p=exports.PrivacyConsentType||(exports.PrivacyConsentType={})).Unknown="unknown",p.Informed="informed",p.Implied="implied",p.Explicit="explicit",p.Active="active",p.Passive="passive",exports.TrackingEventSourceOriginType=void 0,(d=exports.TrackingEventSourceOriginType||(exports.TrackingEventSourceOriginType={})).Browser="browser",d.Server="server",d.Mobile="mobile",d.Desktop="desktop",d.PhysicalStore="physicalStore",d.Email="email",d.Phone="phone",d.Chat="chat",d.Automatic="automatic",exports.TrackingActivityNames=void 0,(u=exports.TrackingActivityNames||(exports.TrackingActivityNames={})).Undefined="undefined",u.PageViewOrganic="pageViewOrganic",u.PageViewUtmAttributed="pageViewUtmAttributed",u.AddPaymentMethod="addPaymentMethod",u.AddToWishlist="addToWishlist",u.ContactMessage="contactMessage",u.Custom="custom",u.SyncCart="syncCart",u.Order="order",u.InitiateCheckout="initiateCheckout",u.AddToCart="addToCart",u.RemoveFromCart="removeFromCart",u.OneTimeItemPurchase="oneTimeItemPurchase",u.SubscriptionItemPurchase="subscriptionItemPurchase",u.ViewProduct="viewProduct",u.ViewPage="viewPage",u.ApplyPromotionalCode="applyPromotionalCode",u.KeywordSearch="keywordSearch",u.UserLoginSignup="userLoginSignup",u.UserLogin="userLogin",u.NewsletterSignup="newsletterSignup",u.Lead="lead",u.ChangeProductAttribute="changeProductAttribute",u.FilterItemsByAttribute="filterItemsByAttribute",u.Schedule="schedule",u.ViewContentItem="viewContentItem",u.StartTrial="startTrial",exports.ECommerceContentType=void 0,(h=exports.ECommerceContentType||(exports.ECommerceContentType={})).Undefined="undefined",h.SingleProduct="singleProduct",h.SingleVariant="singleVariant",h.Collection="collection",exports.ECommercePlatform=void 0,(g=exports.ECommercePlatform||(exports.ECommercePlatform={})).None="none",g.BigCommerce="bigCommerce",g.Shopify="shopify",g.OrderGroove="orderGroove",g.Magento="magento",g.Generic="generic",g.WooCommerce="wooCommerce",g.Demandware="demandware",exports.ECommerceFulfillmentStatus=void 0,(v=exports.ECommerceFulfillmentStatus||(exports.ECommerceFulfillmentStatus={})).Undefined="undefined",v.Fulfilled="fulfilled",v.NoneFulfilled="noneFulfilled",v.PartiallyFulfilled="partiallyFulfilled",v.RestockedOrCancelled="restockedOrCancelled",v.Pending="pending",exports.ECommerceFinancialStatus=void 0,(f=exports.ECommerceFinancialStatus||(exports.ECommerceFinancialStatus={})).Undefined="undefined",f.Pending="pending",f.Authorized="authorized",f.PartiallyPaid="partiallyPaid",f.Paid="paid",f.PartiallyRefunded="partiallyRefunded",f.Refunded="refunded",f.Voided="voided",exports.ConvergePipelineLoggableActivityType=void 0,(y=exports.ConvergePipelineLoggableActivityType||(exports.ConvergePipelineLoggableActivityType={})).Generic="generic",y.ActivityIngress="activityIngress",y.ActivityEgress="activityEgress",y.UserProfile="userProfile",y.SdkLog="sdkLog",y.Detections="detections",y.ActivityEgressFilter="activityEgressFilter",y.Diagnosis="diagnosis",y.PipelineIntegrationOutput="pipelineIntegrationOutput",exports.SdkLogEventLevel=void 0,(m=exports.SdkLogEventLevel||(exports.SdkLogEventLevel={})).Information="information",m.Warning="warning",m.Error="error",m.Verbose="verbose",exports.SeekaWebhookCallType=void 0,(k=exports.SeekaWebhookCallType||(exports.SeekaWebhookCallType={})).None="none",k.Probe="probe",k.AppInstalled="appInstalled",k.IdentityChanged="identityChanged",k.ActivityAccepted="activityAccepted",k.AppInstallSettingsUpdated="appInstallSettingsUpdated",k.AppUninstalled="appUninstalled",k.BrowserSdkPlugin="browserSdkPlugin",exports.ClickAttributionSourcePlatform=void 0,(P=exports.ClickAttributionSourcePlatform||(exports.ClickAttributionSourcePlatform={})).Unknown="unknown",P.Google="google",P.Meta="meta",P.Snapchat="snapchat",P.Pinterest="pinterest",P.TikTok="tikTok",exports.ActivityPipelineActivityFilterType=void 0,(A=exports.ActivityPipelineActivityFilterType||(exports.ActivityPipelineActivityFilterType={})).Undefined="undefined",A.PurchaseMade="purchaseMade",A.ActivityTracked="activityTracked",exports.ConditionComparer=void 0,(S=exports.ConditionComparer||(exports.ConditionComparer={})).Undefined="undefined",S.And="and",S.Or="or",exports.ActivityPipelineActivityFilterSourceItemType=void 0,(I=exports.ActivityPipelineActivityFilterSourceItemType||(exports.ActivityPipelineActivityFilterSourceItemType={})).Undefined="undefined",I.Domain="domain",I.Pipeline="pipeline",I.Wildcard="wildcard",I.Url="url",I.PagePath="pagePath",exports.ConditionOperator=void 0,(x=exports.ConditionOperator||(exports.ConditionOperator={})).Undefined="undefined",x.Equals="equals",x.NotEquals="notEquals",x.Contains="contains",x.NotContains="notContains",x.StartsWith="startsWith",x.EndsWith="endsWith",x.IsNull="isNull",x.NotNull="notNull",x.IsTrue="isTrue",x.IsFalse="isFalse",x.GreaterThanOrEquals="greaterThanOrEquals",x.LessThanOrEquals="lessThanOrEquals",x.GreaterThan="greaterThan",x.LessThan="lessThan",x.Before="before",x.After="after",x.Between="between",x.In="in",x.NotIn="notIn",x.Regex="regEx",x.Any="any";class R extends Error{constructor(e,t,i,r,s){super(),this.message=void 0,this.status=void 0,this.response=void 0,this.headers=void 0,this.result=void 0,this.isApiException=!0,this.message=e,this.status=t,this.response=i,this.headers=r,this.result=s}static isApiException(e){return!0===e.isApiException}}function $(e,t,i,r,s){throw null!=s?s:new R(e,t,i,r,null)}function q(e){return e&&!0===e.isAxiosError}const M=()=>`${W(new Date)}.${j()}`,j=()=>Math.floor(8999999999*Math.random()+1e9).toString(),W=e=>{let t=(e.getUTCMonth()+1).toString();t.length<2&&(t="0"+t);let i=e.getUTCDate().toString();i.length<2&&(i="0"+i);let r=e.getUTCHours().toString();r.length<2&&(r="0"+r);let s=e.getUTCMinutes().toString();s.length<2&&(s="0"+s);let o=e.getUTCSeconds().toString();return o.length<2&&(o="0"+o),`${e.getUTCFullYear()}${t}${i}.${r}${s}${o}`},D=(e,t)=>e.reduce((e,i,r)=>{const s=Math.floor(r/t);return e[s]||(e[s]=[]),e[s].push(i),e},[]),z={identity:{receiveFull:"Identity.Receive.Pii",send:"Identity.Send"},activity:{receiveAnon:"Activity.Receive.Anon",receiveFull:"Activity.Receive.Pii",send:"Activity.Send"}},G="seeka:sdk";class J{constructor(e,t){this.appId=void 0,this.appInstallationId=void 0,this.set=async(e,t,i)=>{const r=this.getKey(e);N.put(r,JSON.stringify(t),i)},this.getOrSet=async(e,t,i)=>{const r=this.getKey(e),s=N.get(r);if(s){const e=JSON.parse(s);return i&&await i(e),e}const o=await t();return o?(N.put(r,JSON.stringify(o.value),o.expiryAbsoluteMilliseconds),o.value):null},this.getKey=e=>this.appInstallationId?`${G}:${this.appId}:${this.appInstallationId}:${e}`:`${G}:${this.appId}:${e}`,this.appId=e,this.appInstallationId=t}}const V=async e=>{const t={applicationId:e.appId,issuer:{url:e.issuerUrl}};e.logger?e.logger.debug("Seeka auth: getting issuer",{...t}):console.debug("Seeka auth: getting issuer",{...t});const i=new J(e.appId,e.applicationInstallId),r=(s=e.issuerUrl+"_"+e.appId,w.createHash("md5").update(s).digest("hex"));var s;return await i.getOrSet(r,async()=>{try{return{value:await K(e),expiryAbsoluteMilliseconds:36e5}}catch(i){return e.logger?e.logger.error("Seeka auth: failed getting issuer",{...t,ex:E.default.exceptions.getAllInfo(i)}):console.error("Seeka auth: failed getting issuer",{...t}),null}},async()=>{e.logger?e.logger.verbose("Seeka auth: got issuer from cache",{...t}):console.debug("Seeka auth: got issuer from cache",{...t})})},K=async e=>{const t={applicationId:e.appId,issuer:{url:e.issuerUrl}};return e.logger?e.logger.verbose("Seeka auth: discovering issuer from server",{...t}):console.info("Seeka auth: discovering issuer from server",{...t}),await T.discovery(new URL(e.issuerUrl),e.appId.replace(/-/g,""),e.appSecret,void 0,{timeout:1e4})},H=async e=>{const t=new J(e.appId,e.applicationInstallId),i={applicationId:e.appId,issuer:{url:e.issuerUrl}};return await t.getOrSet("auth:token:appinstall",async()=>{const t=await(async e=>{const t={applicationId:e.appId,issuer:{url:e.issuerUrl}},i=await V(e);if(!i||!i.value)throw new Error("Failed to get issuer");try{let r=await T.clientCredentialsGrant(i.value,{});const s={...t,token:{expires_at:r.expires_at,token_type:r.token_type,scope:r.scope}};return e.logger?e.logger.verbose("Seeka auth: got client access token from server",{...s}):console.info("Seeka auth: got app client token from server",{...s}),{token_type:r.token_type,access_token:r.access_token,expires_in:r.expires_in,id_token:r.id_token,refresh_token:r.refresh_token,scope:r.scope,authorization_details:r.authorization_details}}catch(i){const r={...t,error:i};return e.logger?e.logger.error("Seeka auth: failed to get client access token from server",{...r}):console.debug("Seeka auth: failed to get client access token from server",{...r}),null}})(e);if(!t)return null;const i=await(async(e,t)=>{const i={applicationId:t.appId,issuer:{url:t.issuerUrl}},r=await V(t);if(!r||!r.value)throw new Error("Failed to get issuer");try{const s=await T.genericGrantRequest(r.value,"app_install_token",{applicationInstallId:t.applicationInstallId,access_token:e}),o={...i,token:{expires_at:s.expires_at,token_type:s.token_type,scope:s.scope}};return t.logger?t.logger.verbose("Seeka auth: got app access token from server",{...o}):console.info("Seeka auth: got app access token from server",{...o}),{token_type:s.token_type,access_token:s.access_token,expires_in:s.expires_in,id_token:s.id_token,refresh_token:s.refresh_token,scope:s.scope,authorization_details:s.authorization_details}}catch(e){const r={...i,error:e};return t.logger?t.logger.error("Seeka auth: failed to get app access token from server",{...r}):console.debug("Seeka auth: failed to get app access token from server",{...r}),null}})(t.access_token,e);return i?{value:i,expiryAbsoluteMilliseconds:((i.expires_in>t.expires_in?t.expires_in:i.expires_in)||9e5)-6e4}:null},async()=>{e.logger?e.logger.verbose("Seeka auth: got app token from cache",{...i}):console.debug("Seeka auth: got app token from cache",{...i})})},X=new U.default.Agent({keepAlive:!0,scheduling:"fifo"}),Y=new O.default.Agent({keepAlive:!0,scheduling:"fifo"}),Q=e=>{const t=b.default.create({httpAgent:X,httpsAgent:Y});return t.interceptors.request.use(function(t){const i={url:t.url,method:t.method};return e.logger?e.logger.debug(`Seeka API: making call to ${i.url}`,{...i}):console.debug(`Seeka API: making call to ${i.url}`,{...i}),t},function(t){const i={error:t};return e.logger?e.logger.http("Seeka API: failed to send request",{...i}):console.debug("Seeka API: failed to send request",{...i}),Promise.reject(t)}),t.interceptors.response.use(function(t){var i,r;const s={url:(null==(i=t.request)?void 0:i.url)||t.config.url,method:(null==(r=t.request)?void 0:r.method)||t.config.method,response:{status:t.status}};return e.logger?e.logger.http(`Seeka API: call to ${s.url} succeeded`,{...s}):console.debug(`Seeka API: call to ${s.url} succeeded`,{...s}),t},function(t){var i;const{code:r,status:s,message:o}=t,{headers:n,url:a,method:c}=null==t?void 0:t.config,l={code:r,status:s,message:o,headers:n,url:a,method:c,content:null==t||null==(i=t.response)?void 0:i.data};return e.logger?e.logger.error(`Seeka API: call to ${l.url} failed`,{...l}):console.error(`Seeka API: call to ${l.url} failed`,{...l}),Promise.reject(t)}),t};class Z{constructor(e){this.config=void 0,this.maxBatchSize=50,this.refreshOrPrimeTokenCache=async()=>{await H(this.config)},this.ingestionService=void 0,this.identityService=void 0,this.checkPermission=(e,t)=>{if(!this.config.hasPermission(e))throw new Error("Cannot perform operation "+t+" on installationId "+this.config.applicationInstallId+" without permission "+e+". Currently granted permissions: "+(this.config.grantedPermissions?this.config.grantedPermissions.join(", "):"none"));return!0},this.mergeIdentity=async(e,t)=>{var i;this.checkPermission(z.identity.send,"mergeIdentity");const r=M();return null==(i=(await this.identityService.merge({id:e,src:{method:"",origin:t.origin,time:void 0,loc:t.loc,sess:r,diag:"true"===process.env.SEEKA_DEBUG_ENABLED?r:void 0,runtime:this.config.runtime}})).result)?void 0:i.personId},this.mergeIdentityBatch=async(e,t)=>{this.checkPermission(z.identity.send,"mergeIdentityBatch");const i=M();var r;if(0===e.length)return void(null==(r=this.config.logger)||r.debug("No identities in batch"));const s={method:"",origin:t.origin,time:void 0,loc:t.loc,sess:i,diag:"true"===process.env.SEEKA_DEBUG_ENABLED?i:void 0,runtime:this.config.runtime},o=D(e,this.maxBatchSize);if(o.length>1&&this.config.logger&&this.config.logger.debug(`Identity batch size ${e} is greater than ${this.maxBatchSize}, splitting into ${o.length} batches`),await this.trackActivityBatchRaw({data:o[0].map(e=>({id:{id:e||{},src:{...s}}}))}),o.length>1){const e=o.map((e,t)=>{var i;return 0===t?Promise.resolve():(null==(i=this.config.logger)||i.verbose(`Processing identity batch ${t+1} of ${o.length}`),this.trackActivityBatchRaw({data:e.map(e=>({id:{id:e||{},src:{...s}}}))}))});await Promise.all(e)}},this.trackActivityBatch=async(e,t)=>{this.checkPermission(z.activity.send,"trackActivityBatch");const i=M();var r;if(0===e.length)return void(null==(r=this.config.logger)||r.debug("No activities in batch"));const s={method:"",origin:t.origin,time:void 0,loc:t.loc,sess:i,diag:"true"===process.env.SEEKA_DEBUG_ENABLED?i:void 0,runtime:this.config.runtime},o=D(e,this.maxBatchSize);if(o.length>1&&this.config.logger&&this.config.logger.debug(`Activity batch size ${e.length} is greater than ${this.maxBatchSize}, splitting into ${o.length} batches`),await this.trackActivityBatchRaw({data:o[0].map(e=>({ev:{id:e.profile||{},src:{...s},payload:e.activity}}))}),o.length>1){const e=o.map((e,t)=>{var i;return 0===t?Promise.resolve():(null==(i=this.config.logger)||i.verbose(`Processing activity batch ${t+1} of ${o.length}`),this.trackActivityBatchRaw({data:e.map(e=>({ev:{id:e.profile||{},src:{...s},payload:e.activity}}))}))});await Promise.all(e)}},this.trackActivityBatchRaw=async e=>{await this.ingestionService.batch(e)},this.trackActivityForProfileId=async(e,t,i)=>{this.checkPermission(z.activity.send,"trackActivityForProfileId"),await this.trackActivityForProfileIdBatch([e],t,i)},this.trackActivityForProfileIdBatch=async(e,t,i)=>{this.checkPermission(z.activity.send,"trackActivityForProfileIdBatch"),await this.trackActivityBatch(e.map(e=>({activity:e,profile:t?{seekaPId:t}:void 0})),i)},this.trackActivityForProfile=async(e,t,i)=>{this.checkPermission(z.activity.send,"trackActivityForProfile"),await this.trackActivityForProfileBatch([e],t,i)},this.trackActivityForProfileBatch=async(e,t,i)=>{this.checkPermission(z.activity.send,"trackActivityForProfileBatch"),await this.trackActivityBatch(e.map(e=>({activity:e,profile:t})),i)},this.config=e,this.ingestionService=(e=>new L(e,e.ingestUrl,Q(e)))(e),this.identityService=(e=>new B(e,e.ingestUrl,Q(e)))(e)}}const ee="x-seeka-signature-sha256",te=(e,t,i)=>{if(!t)return!1;let r=null;if(t.get&&"function"==typeof t.get)r=t.get(ee);else{const e=t[ee];e&&(Array.isArray(e)&&e.length>0?r=e[0]:("string"==typeof e||e instanceof String)&&(r=e))}if(!r)return!1;const s=ie(e,i)===r;return s||console.warn("Invalid webhook signature"),s},ie=(e,t)=>w.createHmac("sha256",e).update(t).digest("hex"),re=(e,t,i,r,s)=>{const o=new _;return o.appId=e.applicationId,o.appSecret=t,o.ingestUrl=process.env.SEEKA_INGEST_URL||"https://router.seeka.services",o.issuerUrl=process.env.SEEKA_ISSUER_URL||"https://account.seeka.app",o.organisationId=e.organisationId,o.applicationInstallId=e.applicationInstallId,o.runtime={type:"sdk/js/apps-server",ver:"1.1.38",client:i},o.logger=s,o.grantedPermissions=r,o.transformApiRequest=e=>se(o,e),o.transformApiResponse=async(e,t,i)=>oe(o,e,t,i),o.hasAnyPermissions=e=>!(!o.grantedPermissions||0===o.grantedPermissions.length)&&(!e||0===e.length||e.some(e=>o.grantedPermissions.includes(e))),o.hasAllPermissions=e=>!(!o.grantedPermissions||0===o.grantedPermissions.length)&&(!e||0===e.length||e.every(e=>o.grantedPermissions.includes(e))),o.hasPermission=e=>!(!o.grantedPermissions||0===o.grantedPermissions.length)&&(!e||o.grantedPermissions.includes(e)),o},se=async(e,t)=>{const i=await H(e);return t.headers={...t.headers,"X-OrgId":e.organisationId,Authorization:"Bearer "+(null==i?void 0:i.access_token)},t},oe=async(e,t,i,r)=>(i.data=JSON.stringify(i.data),r(i)),ne="aes-192-cbc",ae=(e,t)=>{if(!e)return"";if(!t)throw new Error("Secret is required to encrypt data");const i=C.default.scryptSync(t,"salt",24),r=C.default.randomBytes(16),s=C.default.createCipheriv(ne,i,r);return[s.update(e,"utf8","hex")+s.final("hex"),Buffer.from(r).toString("hex")].join("|")},ce=(e,t)=>{if(!e)return"";if(!t)throw new Error("Secret is required to decrypt data");const[i,r]=e.split("|");if(!r)throw new Error("IV not found");const s=C.default.scryptSync(t,"salt",24),o=C.default.createDecipheriv(ne,s,Buffer.from(r,"hex"));return o.update(i,"hex","utf8")+o.final("utf8")};class le{constructor(e){this.appSecret=void 0,this.encryptWithAppSecret=e=>{if(!this.appSecret)throw new Error("App secret is required to encrypt data");return ae(e,this.appSecret)},this.decryptWithAppSecret=e=>{if(!this.appSecret)throw new Error("App secret is required to decrypt data");return ce(e,this.appSecret)},this.appSecret=e}}var pe;class de{constructor(e,t){this.context=void 0,this.appCache=void 0,this.appInstallCache=void 0,this.api=void 0,this.logger=void 0,this.crypto=void 0,this.context=e,this.api=new Z(e.config),this.appCache=new J(e.config.appId),this.appInstallCache=new J(e.config.appId,e.config.applicationInstallId),this.crypto=new le(e.config.appSecret),this.logger=t}}pe=de,de.create=(e,t,i,r,s)=>new pe({config:re({...t},e,{type:i.name,ver:i.version},r,s)},s);const ue=[exports.TrackingActivityNames.Order,exports.TrackingActivityNames.SubscriptionItemPurchase,exports.TrackingActivityNames.OneTimeItemPurchase];var he;exports.IabPrivacyConsentPurposeId=void 0,(he=exports.IabPrivacyConsentPurposeId||(exports.IabPrivacyConsentPurposeId={})).Undefined="undefined",he.MeasureAdvertisingPerformance="measureAdvertisingPerformance";const ge={[exports.IabPrivacyConsentPurposeId.MeasureAdvertisingPerformance]:7};exports.ApiException=R,exports.ApiServiceProxyBase=F,exports.AppPermissionKeys=z,exports.IabPrivacyConsentPurposeIdMap=ge,exports.IdentityServiceProxy=B,exports.IngestServiceProxy=L,exports.SeekaApiHelper=Z,exports.SeekaAppCacheManager=J,exports.SeekaAppConfig=_,exports.SeekaAppHelper=de,exports.chunk=D,exports.decryptText=ce,exports.encryptText=ae,exports.getActivityName=e=>{const t=Object.keys(exports.TrackingActivityNames),i=e.toLowerCase(),r=t.find(e=>e.toLowerCase()===i);return r?exports.TrackingActivityNames[r]:exports.TrackingActivityNames.Custom},exports.isValidSeekaProfileId=function(e){if(!e||0===e.trim().length)return!1;const t=e.split(".").filter(e=>e.trim().length>0);return 4===t.length&&t[0].toLowerCase()==="sk".toLowerCase()&&t[1].toLowerCase()==="1".toLowerCase()&&!isNaN(parseInt(t[2],10))&&!isNaN(parseInt(t[3],10))},exports.matchActivityPipelineFilters=(e,t,i)=>{if(!e.activity)return[];const r=e.activity,s=r.activityName===exports.TrackingActivityNames.Custom?r.activityNameCustom:r.activityName;if(!s)return[];const o=s.toLowerCase(),n=[];return t.forEach(t=>{var a;if(!t)return;switch(t.type){case exports.ActivityPipelineActivityFilterType.ActivityTracked:if(!t.activityNames)return;if(!t.activityNames.find(e=>e.toLowerCase()===o))return;i.verbose("Matched activity tracked filter",{filter:t,activityName:s});break;case exports.ActivityPipelineActivityFilterType.PurchaseMade:if(!r.activityName||!ue.includes(r.activityName))return;i.verbose("Matched purchase made activity filter",{filter:t,activityName:s});break;default:return void i.warn("Unknown activity filter type",{filter:t})}const c=t.sourceFilter;if(!c)return;const l=e.source,p=null!=l&&l.loc?new URL(l.loc).hostname.toLowerCase():null,d=null==l?void 0:l.pipeline,u=null==d||null==(a=d.convergePipelineIntegrationInstanceId)?void 0:a.toLowerCase(),h=c.filters?c.filters.map(e=>{switch(e.type){case exports.ActivityPipelineActivityFilterSourceItemType.Wildcard:return i.verbose("Matched wildcard source filter",{sourceFilter:e}),!0;case exports.ActivityPipelineActivityFilterSourceItemType.Domain:return!(!p||!e.key||p!==e.key.toLowerCase()||(i.verbose("Matched domain source filter",{sourceFilter:e,activityHostname:p}),0));case exports.ActivityPipelineActivityFilterSourceItemType.Pipeline:return!(!u||!e.key||u!==e.key.toLowerCase()||(i.verbose("Matched pipeline source filter",{sourceFilter:e,sourceConvergePipelineIntegrationInstanceId:u}),0))}}):[];switch(c.comparer){case exports.ConditionComparer.And:h.every(e=>!0===e)||n.push(t);break;case exports.ConditionComparer.Or:h.some(e=>!0===e)&&n.push(t);break;default:i.warn("Unknown source filter comparer",{sourceFilters:c})}}),n},exports.separatePersonFullName=e=>{if(!e)return{firstName:null,lastName:null};const t=e.trim().split(" ");return 1===t.length?{firstName:e,lastName:null}:2===t.length?{firstName:t[0],lastName:t[1]}:{firstName:t[0],lastName:t.slice(1).join(" ")}},exports.throwOnInvalidWebhookSignature=(e,t,i)=>{if(!te(e,t,i))throw new Error("Invalid webhook signature")},exports.validateWebhookSignature=te,exports.webhookSignatureHeaderName=ee;
|
|
2
2
|
//# sourceMappingURL=sdk-apps-server.js.map
|