dome-embedded-app-sdk 0.2.2 → 0.2.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.domeSdk=t():e.domeSdk=t()}(this,(()=>(()=>{"use strict";var e={d:(t,s)=>{for(var r in s)e.o(s,r)&&!e.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:s[r]})},o:(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r:e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}},t={};e.r(t),e.d(t,{CardSdk:()=>h,CryptoA01:()=>r,ViewerSdk:()=>d});const s="0.2.2";class r{constructor(){if(this.subtleCrypto=window.crypto?.subtle,!this.subtleCrypto)throw new Error("SubtleCrypto API is not available in this environment.")}async decrypt(e,t,s){try{if(!e)throw new Error("Invalid token");const r=this.base64UrlDecode(e);if(128!==r[0])throw new Error("Invalid version");r.slice(1,9);const a=r.slice(9,25),i=r.slice(25,-32),n=r.slice(-32),o=await this.deriveKey(t,s),{hmacKey:c,aesKey:d}=await this.splitKey(o),l=r.slice(0,-32);if(!new Uint8Array(await this.subtleCrypto.sign("HMAC",c,l)).every(((e,t)=>e===n[t])))throw new Error("Invalid HMAC. Token has been tampered with!");const u=await this.subtleCrypto.decrypt({name:"AES-CBC",iv:a},d,i);return(new TextDecoder).decode(u)}catch(e){throw console.log("Error in decrypt:",e),e}}async deriveKey(e,t,s=1e4){const r=new TextEncoder,a=await this.subtleCrypto.importKey("raw",r.encode(e),"PBKDF2",!1,["deriveKey"]);return this.subtleCrypto.deriveKey({name:"PBKDF2",hash:"SHA-256",salt:r.encode(t),iterations:s},a,{name:"AES-CBC",length:256},!0,["encrypt","decrypt"])}async splitKey(e){const t=new Uint8Array(await this.subtleCrypto.exportKey("raw",e));return{hmacKey:await this.subtleCrypto.importKey("raw",t.slice(0,16),{name:"HMAC",hash:"SHA-256"},!1,["sign","verify"]),aesKey:await this.subtleCrypto.importKey("raw",t.slice(16),{name:"AES-CBC"},!1,["encrypt","decrypt"])}}base64UrlDecode(e){const t=e.replace(/-/g,"+").replace(/_/g,"/"),s=atob(t);return new Uint8Array([...s].map((e=>e.charCodeAt(0))))}}var a,i,n;!function(e){e.CONNECTION_SUCCESS="CONNECTION_SUCCESS",e.INIT="INIT",e.REQUEST_SAVE="REQUEST_SAVE",e.REQUEST_CLOSE="REQUEST_CLOSE",e.REQUEST_INITIAL_DATA="REQUEST_INITIAL_DATA",e.SET_DIRTY="SET_DIRTY",e.SEND_CLOSE="SEND_CLOSE",e.SEND_EXCEPTION="SEND_EXCEPTION"}(a||(a={})),function(e){e.INIT_MESSAGE_CHANNEL="INIT_MESSAGE_CHANNEL"}(i||(i={})),function(e){e.CONNECT="CONNECT",e.REQUEST_CLOSE="REQUEST_CLOSE",e.REQUEST_SAVE="REQUEST_SAVE",e.SAVE_ERROR="SAVE_ERROR",e.SAVE_SUCCESS="SAVE_SUCCESS",e.DATA_CHANGE="DATA_CHANGE",e.FILE_DATA="FILE_DATA",e.WRITE_FILE_ACK="WRITE_FILE_ACK",e.READ_FILE_ACK="READ_FILE_ACK",e.DELETE_FILE_ACK="DELETE_FILE_ACK",e.LIST_FILES_ACK="LIST_FILES_ACK",e.INIT_ACK="INIT_ACK",e.ERROR="ERROR",e.REFRESH="REFRESH"}(n||(n={}));new Set("undefined"==typeof window?[]:[window.location.origin,"https://dome.so","https://spaces.intouchapp.com/","http://localhost:4200","http://localhost:4201","null"]);const o=new Set(["dome","intouchapp"]);class c{constructor(){this.targetOrigin="*",this.isAppReady=!1,this.port2=null,this.runtimeHost="unknown",this.parentHostDetails=null,this.parentCapabilities=null,this.handleDeepLinkClick=e=>{if("webapp"!==this.runtimeHost)return;if(!(e.target instanceof Element))return;const t=e.target.closest("a[href]");if(!t)return;const s=t.getAttribute("href")??"";this.emitDeepLink(s)&&e.preventDefault()},this.detectHost(),this.setupDeepLinkInterception()}detectHost(){void 0!==window.AndroidBridge?this.runtimeHost="android":void 0!==window.webkit?this.runtimeHost="ios":this.runtimeHost="webapp",this.runtimeHost}setupDeepLinkInterception(){"webapp"===this.runtimeHost&&"undefined"!=typeof document&&document.addEventListener("click",this.handleDeepLinkClick,!0)}emitDeepLink(e){if("string"!=typeof e||""===e.trim())return console.warn("emitDeepLink called without a valid href"),!1;const t=e.split(":")[0]?.toLowerCase();return!(!t||!o.has(t))&&(this.sendMessage(l.OPEN_DEEPLINK,{url:e}),!0)}updateParentContext(e,t){if(!e&&!t)return;const s={...this.parentHostDetails??{type:this.runtimeHost},...e??{}};s.type||(s.type=this.runtimeHost);const r=t??this.parentCapabilities??s.capabilities;t&&(this.parentCapabilities=t),r?s.capabilities=r:delete s.capabilities,this.parentHostDetails=s,this.parentCapabilities=r??null}getHost(){return this.parentHostDetails??{type:this.runtimeHost}}sendMessage(e,t){const s={type:e,data:t??null};switch(this.runtimeHost){case"android":window.AndroidBridge?.sendMessage(JSON.stringify(s));break;case"ios":window?.webkit?.messageHandlers?window.webkit?.messageHandlers.appHandler.postMessage(JSON.stringify(s)):console.error("webkit.messageHandlers not found");break;case"webapp":this.port2?this.port2.postMessage(s):console.error("Web connection is not established.");break;default:console.error("Unsupported host, cannot send message.")}this.runtimeHost}sendAppInit(){this.isAppReady||(this.isAppReady=!0,this.sendMessage(a.INIT,{sdk:{ver:s}}))}safeInvoke(e,t,s){const r=t[e];"function"==typeof r?r(s):console.warn(`Handler for '${String(e)}' is not defined.`)}setupParentConnection(){return new Promise(((e,t)=>{switch(this.runtimeHost){case"android":window.receiveFromAndroid=e=>{this.handleMessage(e.type,e.data)},e();break;case"ios":window.receiveFromIOS=e=>{this.handleMessage(e.type,e.data)},e();break;case"webapp":if(this.port2)return console.warn("Connection already established. Skipping reinitialization."),void e();const r=t=>{const{type:s}=t.data||{};s===n.CONNECT&&t.ports&&t.ports.length>0&&(this.port2=t.ports[0],this.port2.onmessage=e=>this.handlePortMessage(e),window.removeEventListener("message",r),this.notifyConnectionSuccess(),e())};window.addEventListener("message",r),window.parent?window.parent.postMessage({type:i.INIT_MESSAGE_CHANNEL,data:{sdk:{ver:s}}},this.targetOrigin):console.error("Parent window not available to initialize message channel.");break;default:console.error("Unknown host."),t("Unknown host")}}))}notifyConnectionSuccess(){this.sendMessage(a.CONNECTION_SUCCESS)}handlePortMessage(e){const{type:t,data:s}=e.data||{};t&&this.handleMessage(t,s)}handleMessage(e,t){throw new Error("Subclasses must implement handleMessage.")}}class d extends c{constructor(){super(),this.handler=null,this.pendingRequests=new Map,this.pendingInitAck=null}static init(e){return d.initialized?(console.warn("ViewerSdk is already initialized. Skipping initialization."),d.instance):(d.instance||(d.instance=new d,d.instance.setupParentConnection().then((()=>{try{d.instance.initializeViewerSdk()}catch(e){console.error("Error in initializeViewerSdk:",e)}})).catch((e=>{console.error("init: Error setting up parent connection!",e),console.trace("called from:")}))),e&&d.instance.setHandler(e),d.initialized=!0,d.instance)}setHandler(e){this.handler=e,this.pendingInitAck&&(this.safeInvoke("onInitialData",this.handler,this.pendingInitAck),this.pendingInitAck=null)}canRead(e){return!!e?.includes("r")}canWrite(e){return!!e?.includes("w")||!!e?.includes("*")}initializeViewerSdk(){this.sendAppInit()}requestInitialData(){this.sendMessage(a.REQUEST_INITIAL_DATA)}requestSave(e,t){const s=function(){if("undefined"!=typeof window&&window.crypto&&window.crypto.randomUUID)return window.crypto.randomUUID();if("undefined"!=typeof crypto&&crypto.randomUUID)return crypto.randomUUID();throw new Error("UUID generation is not supported in this environment")}();return this.sendMessage(a.REQUEST_SAVE,{doc:e,isDataDirty:t,requestId:s}),new Promise(((e,t)=>{this.pendingRequests.set(s,e),this.pendingRequests.set(s+"_reject",t),setTimeout((()=>{this.pendingRequests.has(s)&&(this.pendingRequests.delete(s),this.pendingRequests.delete(s+"_reject"))}),3e4)}))}handleOnSave(e){const{requestId:t,status:s,message:r}=e,a=this.pendingRequests.get(t),i=this.pendingRequests.get(t+"_reject");a&&("error"===s?i?.({status:s,message:r}):a({status:s,message:r}),this.pendingRequests.delete(t),this.pendingRequests.delete(t+"_reject"))}setDirty(e){this.sendMessage(a.SET_DIRTY,e)}sendClose(e,t){this.sendMessage(a.SEND_CLOSE,{doc:e,isDataDirty:t})}sendException(e){this.sendMessage(a.SEND_EXCEPTION,e)}handleMessage(e,t){if(e===n.INIT_ACK&&this.updateParentContext(t?.host,t?.capabilities),this.handler)switch(e){case n.INIT_ACK:this.safeInvoke("onInitialData",this.handler,t);break;case n.DATA_CHANGE:this.safeInvoke("onDataChange",this.handler,t);break;case n.REQUEST_CLOSE:this.safeInvoke("onCloseRequest",this.handler);break;case n.REQUEST_SAVE:this.safeInvoke("onSaveRequest",this.handler);break;case n.SAVE_SUCCESS:case n.SAVE_ERROR:this.handleOnSave(t);break;default:console.warn(`No handler found for message type: ${e}`)}else e===n.INIT_ACK?(console.warn("Handler not set. Storing INIT_ACK message for later processing."),this.pendingInitAck=t):console.error("Message handler not found for type:",e)}}var l;d.initialized=!1,function(e){e.APP_READY="APP_READY",e.INIT="INIT",e.READ_FILE="READ_FILE",e.WRITE_FILE="WRITE_FILE",e.DELETE_FILE="DELETE_FILE",e.LIST_FILES="LIST_FILES",e.FILE_DIRTY="FILE_DIRTY",e.OPEN_DEEPLINK="OPEN_DEEPLINK"}(l||(l={}));class u{constructor(e,t){this.cardIuid=e,this.containerIuid=t,this.openPromise=null}isSupported(){return"undefined"!=typeof indexedDB}async openDb(){return this.isSupported()?(this.openPromise||(this.openPromise=new Promise((e=>{this.openWithVersion(u.DB_VERSION,e)}))),this.openPromise):null}openWithVersion(e,t){let s="ensure";const r=indexedDB.open(this.cardIuid,e);r.onupgradeneeded=e=>{s=0===(e.oldVersion||0)?"create":"ensure",this.configureStores(r.result)},r.onsuccess=()=>{const e=r.result;if(!this.hasRequiredStores(e)){const s=e.version+1;return e.close(),void this.openWithVersion(s,t)}this.updateStoresMetadata(e,"ensure"===s).catch((()=>{})).finally((()=>t(e)))},r.onerror=()=>t(null)}configureStores(e){e.objectStoreNames.contains(u.DATA_STORE)||e.createObjectStore(u.DATA_STORE),e.objectStoreNames.contains(u.NAME_LOOKUP_STORE)||e.createObjectStore(u.NAME_LOOKUP_STORE),e.objectStoreNames.contains(u.INFO_STORE)||e.createObjectStore(u.INFO_STORE)}hasRequiredStores(e){const t=e.objectStoreNames;return t.contains(u.DATA_STORE)&&t.contains(u.NAME_LOOKUP_STORE)&&t.contains(u.INFO_STORE)}static nowMicros(){return Math.trunc(1e3*Date.now())}updateStoresMetadata(e,t){return Promise.all([this.ensureStoreVersion(e,u.DATA_STORE),this.ensureStoreVersion(e,u.NAME_LOOKUP_STORE),this.updateCardInfo(e,t)]).then((()=>{}))}ensureStoreVersion(e,t){return e.objectStoreNames.contains(t)?new Promise((s=>{try{const r=e.transaction(t,"readwrite"),a=r.objectStore(t),i=()=>s();r.oncomplete=i,r.onerror=i,r.onabort=i,a.put("1.0.0",u.STORE_VERSION_KEY)}catch{s()}})):Promise.resolve()}async updateCardInfo(e,t){if(!e.objectStoreNames.contains(u.INFO_STORE))return;const s=await this.readInfoValue(e,"container_iuid"),r=t?await this.readInfoValue(e,"ts_c"):void 0,a=this.containerIuid??s??null,i=t&&r?r:u.nowMicros();await Promise.all([this.writeInfoValue(e,"container_iuid",a),this.writeInfoValue(e,"ts_c",i)]).catch((()=>{}))}readInfoValue(e,t){return new Promise((s=>{try{const r=e.transaction(u.INFO_STORE,"readonly"),a=r.objectStore(u.INFO_STORE).get(t);a.onsuccess=()=>s(a.result),a.onerror=()=>s(void 0)}catch{s(void 0)}}))}writeInfoValue(e,t,s){return new Promise((r=>{try{const a=e.transaction(u.INFO_STORE,"readwrite"),i=a.objectStore(u.INFO_STORE),n=()=>r();a.oncomplete=n,a.onerror=n,a.onabort=n,i.put(s,t)}catch{r()}}))}keyFor(e){return e}static normalizeName(e){if("string"!=typeof e)return null;const t=e.trim();return t||null}async put(e,t){const s=await this.openDb();s&&await new Promise((r=>{const a=s.transaction(u.DATA_STORE,"readwrite");a.objectStore(u.DATA_STORE).put(t,e).onsuccess=()=>r(),a.oncomplete=()=>r(),a.onerror=()=>r(),a.onabort=()=>r()}))}async get(e){const t=await this.openDb();if(t)return new Promise((s=>{const r=t.transaction(u.DATA_STORE,"readonly").objectStore(u.DATA_STORE).get(e);r.onsuccess=()=>s(r.result),r.onerror=()=>s(void 0)}))}async delete(e){const t=await this.openDb();t&&await new Promise((s=>{const r=t.transaction(u.DATA_STORE,"readwrite");r.objectStore(u.DATA_STORE).delete(e).onsuccess=()=>s(),r.oncomplete=()=>s(),r.onerror=()=>s(),r.onabort=()=>s()}))}static async hashName(e){const t="undefined"!=typeof globalThis?globalThis.crypto:void 0;if(!t?.subtle?.digest)throw new Error("CardFS name hashing requires SubtleCrypto support");const s=u.encodeText(e),r=await t.subtle.digest("SHA-256",s);return u.bufferToBase64(r)}static encodeText(e){if("undefined"!=typeof TextEncoder)return(new TextEncoder).encode(e).buffer;const t=new Uint8Array(e.length);for(let s=0;s<e.length;s++)t[s]=e.charCodeAt(s);return t.buffer}static bufferToBase64(e){let t="";const s=new Uint8Array(e);for(let e=0;e<s.length;e++)t+=String.fromCharCode(s[e]);return btoa(t)}async getIuidForName(e){const t=u.normalizeName(e);if(!t)return;const s=await this.openDb();if(!s)return;const r=await u.hashName(t);return new Promise((e=>{const t=s.transaction(u.NAME_LOOKUP_STORE,"readonly").objectStore(u.NAME_LOOKUP_STORE).get(r);t.onsuccess=()=>e(t.result),t.onerror=()=>e(void 0)}))}async upsertNameLookup(e,t){const s=u.normalizeName(e);if(!s)return;const r=await this.openDb();if(!r)return;const a=await u.hashName(s);await new Promise((e=>{const s=r.transaction(u.NAME_LOOKUP_STORE,"readwrite"),i=s.objectStore(u.NAME_LOOKUP_STORE);i.put(t,a);i.openCursor().onsuccess=e=>{const s=e.target.result;s&&(s.key!==a&&s.value===t&&s.delete(),s.continue())},s.oncomplete=()=>e(),s.onerror=()=>e(),s.onabort=()=>e()}))}async deleteNameLookupByName(e){const t=u.normalizeName(e);if(!t)return;const s=await this.openDb();if(!s)return;const r=await u.hashName(t);await new Promise((e=>{const t=s.transaction(u.NAME_LOOKUP_STORE,"readwrite");t.objectStore(u.NAME_LOOKUP_STORE).delete(r),t.oncomplete=()=>e(),t.onerror=()=>e(),t.onabort=()=>e()}))}async deleteNameLookupByIuid(e){if(!e)return;const t=await this.openDb();t&&await new Promise((s=>{const r=t.transaction(u.NAME_LOOKUP_STORE,"readwrite");r.objectStore(u.NAME_LOOKUP_STORE).openCursor().onsuccess=t=>{const s=t.target.result;s&&(s.value===e&&s.delete(),s.continue())},r.oncomplete=()=>s(),r.onerror=()=>s(),r.onabort=()=>s()}))}static estimateSize(e){if(null==e)return 0;if("undefined"!=typeof Blob&&e instanceof Blob)return e.size;if(e instanceof ArrayBuffer)return e.byteLength;if(ArrayBuffer.isView(e))return e.byteLength;if("string"==typeof e)return new Blob([e]).size;try{return new Blob([JSON.stringify(e)]).size}catch{return 0}}async cacheDocument(e,t){if(!e?.iuid)return;await this.put(this.keyFor(`${e.iuid}_object`),e);const s=u.normalizeName(e.name);if(s&&await this.upsertNameLookup(s,e.iuid),void 0===t)return void await this.delete(this.keyFor(`${e.iuid}_data`));u.estimateSize(t)<=u.MAX_DATA_BYTES?await this.put(this.keyFor(`${e.iuid}_data`),t):await this.delete(this.keyFor(`${e.iuid}_data`))}async getByName(e){const t=u.normalizeName(e);if(!t)return null;const s=await this.getIuidForName(t);if(!s)return null;const r=await this.get(this.keyFor(`${s}_object`));if(!r)return null;return{iuid:s,object:r,data:await this.get(this.keyFor(`${s}_data`))}}async getByIuid(e){if(!e)return null;const t=await this.get(this.keyFor(`${e}_object`));if(!t)return null;return{iuid:e,object:t,data:await this.get(this.keyFor(`${e}_data`))}}async deleteByName(e){const t=await this.getByName(e);await this.deleteNameLookupByName(e),t&&(await this.delete(this.keyFor(`${t.iuid}_object`)),await this.delete(this.keyFor(`${t.iuid}_data`)))}async deleteByIuid(e,t){t&&await this.deleteNameLookupByName(t),await this.deleteNameLookupByIuid(e),await this.delete(this.keyFor(`${e}_object`)),await this.delete(this.keyFor(`${e}_data`))}async getAllCachedObjects(){const e=await this.openDb();return e?new Promise((t=>{const s=[],r=e.transaction(u.DATA_STORE,"readonly").objectStore(u.DATA_STORE).openCursor();r.onsuccess=e=>{const r=e.target.result;if(!r)return void t(s);const a=r.key;"string"==typeof a&&a.endsWith("_object")&&s.push(r.value),r.continue()},r.onerror=()=>t(s)})):[]}}u.DB_VERSION=2,u.DATA_STORE="cardfs",u.NAME_LOOKUP_STORE="cardfs_name_iuid_lookup",u.INFO_STORE="info",u.STORE_VERSION_KEY="ver",u.MAX_DATA_BYTES=5242880;class h extends c{resolveCardFsTarget(e,t){const s="string"==typeof e?{name:e}:e??{},r="string"==typeof s.name?s.name.trim():void 0,a="string"==typeof s.iuid?s.iuid.trim():void 0;if(!r&&!a)throw new Error(`cardsFS.${t} requires a file name or document iuid`);return{name:r,iuid:a}}describeCardFsTarget(e){return e.name&&e.iuid?`"${e.name}" (iuid ${e.iuid})`:e.name?`"${e.name}"`:e.iuid?`iuid ${e.iuid}`:"document"}buildCardFsMessagePayload(e,t){return{...e.name?{name:e.name}:{},...e.iuid?{iuid:e.iuid}:{},...t??{}}}getCardIuid(){return this.dataStore?.iuid||null}ensureCardFsCache(){if(!this.shouldUseCardFsFallback())return null;if(!this.cardFsCache){const e=this.getCardIuid();e&&(this.cardFsCache=new u(e,this.containerIuid))}return this.cardFsCache}supportsParentCardFs(){return!!this.parentCapabilities?.card_fs}shouldUseCardFsFallback(){return!this.supportsParentCardFs()}constructor(){super(),this.handler=null,this.accessToken="",this.fileReadResolvers=new Map,this.fileWriteResolvers=new Map,this.fsReadRequests=new Map,this.fsWriteRequests=new Map,this.cardFsCache=null,this.pendingAcks=new Map,this.handleMessage=(e,t)=>{if(e===n.INIT_ACK&&this.updateParentContext(t?.host,t?.capabilities),!this.handler)throw new Error("Message handler not found!");const s=t?.messageId;if(s&&this.pendingAcks.has(s)){const{resolve:e,timeout:r}=this.pendingAcks.get(s);return clearTimeout(r),this.pendingAcks.delete(s),void e(t)}switch(e){case n.INIT_ACK:this.dataStore.kw1=t.key_wa1,this.dataStore.iuid=t.iuid,t.iuid?this.shouldUseCardFsFallback()?this.cardFsCache=new u(t.iuid,this.containerIuid):this.cardFsCache=null:this.shouldUseCardFsFallback()||(this.cardFsCache=null);try{this.cryptoA01.decrypt(this.dataStore.denc,t.key_wa1+this.dataStore.kw2,t.iuid).then((e=>{const s=JSON.parse(e),r=s?.container?.iuid;r&&(this.containerIuid=r,this.shouldUseCardFsFallback()&&this.dataStore?.iuid&&(this.cardFsCache=new u(this.dataStore.iuid,this.containerIuid)));const a="string"==typeof s?.api_token?s.api_token.trim():"";a?this.accessToken=a:console.warn("CardSdk: INIT_ACK payload missing api_token; fallback APIs may fail without auth"),this.handler&&this.safeInvoke("onInit",this.handler,{...s,ui:t.ui}),delete this.dataStore.denc})).catch((e=>{throw console.error("Final decrypt error",e),e}))}catch(e){console.error("Decryption failed!",e),this.sendEventError("dec2_failed",e.message)}break;case n.FILE_DATA:{const e=t?.messageId;if(e&&this.fsReadRequests.has(e)){const{messageId:s,...r}=t||{};return void this.handleFsReadDataMessage(e,r)}const s=t?.name;if(s&&this.fileReadResolvers.has(s)){const e=this.fileReadResolvers.get(s);this.fileReadResolvers.delete(s),e(t)}else console.warn("CardSdk: FILE_DATA received but no resolver found for",s);break}case n.DATA_CHANGE:this.safeInvoke("onFileChange",this.handler,t);case n.SAVE_SUCCESS:{const e=t?.messageId;if(e&&this.fsWriteRequests.has(e))return void this.handleFsWriteSuccess(e,t);const s=t?.name;if(s&&this.fileWriteResolvers.has(s)){const{resolve:e}=this.fileWriteResolvers.get(s);this.fileWriteResolvers.delete(s),e()}else console.warn("CardSdk: SAVE_SUCCESS received but no resolver found for",s);break}case n.SAVE_ERROR:{const e=t?.messageId;if(e&&this.fsWriteRequests.has(e))return void this.handleFsWriteError(e,t);const s=t?.name;if(s&&this.fileWriteResolvers.has(s)){const{reject:e}=this.fileWriteResolvers.get(s);this.fileWriteResolvers.delete(s),e(new Error(t?.message||"Unknown write error"))}else console.warn("CardSdk: SAVE_ERROR received but no resolver found for",s);break}case n.ERROR:{const e=t?.messageId;if(e){const s=t?.message||"Unknown error";if(this.fsReadRequests.has(e))return void this.failFsReadRequest(e,new Error(s));if(this.fsWriteRequests.has(e))return void this.failFsWriteRequest(e,new Error(s))}this.safeInvoke("onError",this.handler,t);break}case n.REFRESH:this.safeInvoke("onRefreshRequest",this.handler,t);break;default:console.warn(`No handler found for message type: ${e}`)}},this.cryptoA01=new r,this.cardsFS={read:(e,t)=>this.cardsFsRead(e,t),write:(e,t,s)=>this.cardsFsWrite(e,t,s),delete:(e,t)=>this.cardsFsDelete(e,t),list:e=>this.cardsFsList(e)}}static async init(e,t,s){try{return h.instance||(h.instance=new h,h.instance.setupParentConnection().then((()=>{h.instance.initializeCardSdk(e)})).catch((e=>{console.error(e)})),t&&h.instance.setHandler(t)),h.instance}catch(e){throw console.error("CardSdk: Unrecoverable error in init",e),e}}setHandler(e){this.handler=e}openDeepLink(e){this.emitDeepLink(e)||console.warn("openDeepLink ignored; provide a dome:// or intouchapp:// href")}async initializeCardSdk(e){let t="CardSdk::initializeCardSdk:";try{if(!e)throw new Error("Invalid secret");const s=window.IT_DATA_AF1;if(!s)throw console.error(t,"No data"),new Error("No data");const r=window.location.href;const a=new URL(r).pathname.split("/wa/").filter(Boolean)[1].split("/")[0].split("").reverse().join("").substring(4,25);if(!a)throw new Error("Cannot decrypt (1)");const i=await this.cryptoA01.decrypt(s,e,a);try{const e=JSON.parse(i);if(!e.ite)throw new Error("Invalid data");this.dataStore={denc:e.d,kw2:e.kw2},h.instance.sendInit(e.ite)}catch(e){throw console.error("Initial Decryption failed (2):",e),e}}catch(e){console.error(t,"Init failed:",e),this.sendEventError("init_failed",e.message)}}async sendInit(e){this.sendMessage(l.INIT,{token:e,sdk:{ver:s}})}sendMessageWithAck(e,t,s,r=15e3,a){const i=crypto.randomUUID();if(a)try{a(i)}catch(e){return Promise.reject(e)}return new Promise(((a,n)=>{const o=setTimeout((()=>{this.pendingAcks.delete(i),n(new Error(`${s} not received in time`))}),r);this.pendingAcks.set(i,{resolve:a,reject:n,timeout:o}),this.sendMessage(e,{...t,messageId:i})}))}cardsFsRead(e,t){let s;try{s=this.resolveCardFsTarget(e,"read")}catch(e){return Promise.reject(e)}return this.shouldUseCardFsFallback()?this.cardsFsReadFallback(s,void 0,t):new Promise(((e,r)=>{let a=null;const i=this.describeCardFsTarget(s);this.sendMessageWithAck(l.READ_FILE,this.buildCardFsMessagePayload(s),n.READ_FILE_ACK,h.CARD_FS_ACK_TIMEOUT_MS,(s=>{a=s;const n={name:i,onUpdate:t,resolve:e,reject:r,hasResolved:!1};n.noResponseTimeout=setTimeout((()=>{this.failFsReadRequest(s,new Error(`cardsFS.read timed out for ${i}`))}),h.FS_RESPONSE_TIMEOUT_MS),this.fsReadRequests.set(s,n)})).catch((e=>{const t=e instanceof Error?e:new Error(String(e));a?this.failFsReadRequest(a,t):r(t)}))}))}cardsFsWrite(e,t,s){let r;try{r=this.resolveCardFsTarget(e,"write")}catch(e){return Promise.reject(e)}return this.shouldUseCardFsFallback()?this.cardsFsWriteFallback(r,t).then((e=>{try{s?.(e)}catch(e){console.error("cardsFS.write fallback callback threw",e)}return e})):new Promise(((e,a)=>{let i=null;const o=this.describeCardFsTarget(r);this.sendMessageWithAck(l.WRITE_FILE,this.buildCardFsMessagePayload(r,{data:t}),n.WRITE_FILE_ACK,h.CARD_FS_ACK_TIMEOUT_MS,(t=>{i=t;const r={name:o,onResult:s,resolve:e,reject:a,timeout:setTimeout((()=>{this.failFsWriteRequest(t,new Error(`cardsFS.write timed out for ${o}`))}),h.FS_RESPONSE_TIMEOUT_MS)};this.fsWriteRequests.set(t,r)})).catch((e=>{const t=e instanceof Error?e:new Error(String(e));i?this.failFsWriteRequest(i,t):a(t)}))}))}cardsFsDelete(e,t){let s;try{s=this.resolveCardFsTarget(e,"delete")}catch(e){return Promise.reject(e)}return this.shouldUseCardFsFallback()?this.cardsFsDeleteFallback(s).then((e=>{try{t?.(e)}catch(e){console.error("cardsFS.delete fallback callback threw",e)}return e})):new Promise(((e,r)=>{this.sendMessageWithAck(l.DELETE_FILE,this.buildCardFsMessagePayload(s),n.DELETE_FILE_ACK,h.CARD_FS_ACK_TIMEOUT_MS).then((s=>{const{messageId:r,...a}=s||{};t?.(a),e(a)})).catch((e=>{r(e instanceof Error?e:new Error(String(e)))}))}))}cardsFsList(e){return this.shouldUseCardFsFallback()?this.cardsFsListFallback().then((t=>{try{e?.(t)}catch(e){console.error("cardsFS.list fallback callback threw",e)}return t})):new Promise(((t,s)=>{this.sendMessageWithAck(l.LIST_FILES,{},n.LIST_FILES_ACK,h.CARD_FS_ACK_TIMEOUT_MS).then((s=>{const{messageId:r,...a}=s||{};e?.(a),t(a)})).catch((e=>{s(e instanceof Error?e:new Error(String(e)))}))}))}handleFsReadDataMessage(e,t){const s=this.fsReadRequests.get(e);if(s){if(s.noResponseTimeout&&(clearTimeout(s.noResponseTimeout),s.noResponseTimeout=void 0),"function"==typeof s.onUpdate)try{s.onUpdate(t)}catch(e){console.error("cardsFS.read callback threw",e)}s.hasResolved||(s.hasResolved=!0,s.resolve(t)),s.cleanupTimeout&&clearTimeout(s.cleanupTimeout),s.cleanupTimeout=setTimeout((()=>{this.clearFsReadRequest(e)}),h.FS_READ_RETENTION_MS)}}clearFsReadRequest(e){const t=this.fsReadRequests.get(e);if(t)return t.noResponseTimeout&&clearTimeout(t.noResponseTimeout),t.cleanupTimeout&&clearTimeout(t.cleanupTimeout),this.fsReadRequests.delete(e),t}failFsReadRequest(e,t){const s=this.clearFsReadRequest(e);s&&s.reject(t)}clearFsWriteRequest(e){const t=this.fsWriteRequests.get(e);if(t)return clearTimeout(t.timeout),this.fsWriteRequests.delete(e),t}failFsWriteRequest(e,t){const s=this.clearFsWriteRequest(e);s&&s.reject(t)}handleFsWriteSuccess(e,t){const s=this.clearFsWriteRequest(e);if(!s)return;const{messageId:r,...a}=t||{};if("function"==typeof s.onResult)try{s.onResult(a)}catch(e){console.error("cardsFS.write callback threw",e)}s.resolve(a)}handleFsWriteError(e,t){const s=this.clearFsWriteRequest(e);if(!s)return;const r=t instanceof Error?t:new Error(t?.message||"Unknown write error");s.reject(r)}async cardsFsReadFallback(e,t,s){if(!this.shouldUseCardFsFallback())throw new Error("cardsFS.read fallback is disabled because parent supports card_fs");const r=this.getCardIuid();if(!r)throw new Error("cardsFS.read fallback failed: card not initialized");const a=this.ensureCardFsCache();let i=null;const n=this.describeCardFsTarget(e),o=(r,a,n,o,c)=>{if(!r)return;const d={name:o??e.name??r?.name??e.iuid??"document",iuid:c??r?.iuid??e.iuid??null,object:r,data:a,from_cache:n};if(t&&this.fsReadRequests.has(t))this.handleFsReadDataMessage(t,d);else if("function"==typeof s)try{s(d)}catch(e){console.error("cardsFS.read fallback callback threw",e)}i||(i=d)};if(a)try{let t=null;e.iuid&&(t=await a.getByIuid(e.iuid)),!t&&e.name&&(t=await a.getByName(e.name)),t?.object&&o(t.object,t.data,!0,t.object?.name??e.name,t.iuid)}catch(e){console.warn("cardsFS.read cache lookup failed",e)}try{const t=await this.fetchDocumentPayload(r,e);t&&(await(a?.cacheDocument(t.object,t.data)),o(t.object,t.data,!1,t.object?.name,t.object?.iuid))}catch(e){if(!i)throw e;console.warn("cardsFS.read fresh fetch failed",e)}if(!i)throw new Error(`cardsFS.read fallback could not locate ${n}`);return i}async cardsFsWriteFallback(e,t,s){if(!this.shouldUseCardFsFallback())throw new Error("cardsFS.write fallback is disabled because parent supports card_fs");const r=this.getCardIuid();if(!r)throw new Error("cardsFS.write fallback failed: card not initialized");await this.upsertDocumentViaApi(r,e,t);const a=await this.fetchDocumentPayload(r,e);await(this.ensureCardFsCache()?.cacheDocument(a.object,a.data));const i={name:a.object?.name??e.name??e.iuid??null,iuid:a.object?.iuid??e.iuid??null,object:a.object,data:a.data};return s&&this.fsWriteRequests.has(s)&&this.handleFsWriteSuccess(s,i),i}async cardsFsDeleteFallback(e){if(!this.shouldUseCardFsFallback())throw new Error("cardsFS.delete fallback is disabled because parent supports card_fs");const t=this.getCardIuid();if(!t)throw new Error("cardsFS.delete fallback failed: card not initialized");const s=this.ensureCardFsCache(),r=await this.fetchDocumentMetadataByTarget(t,e).catch((()=>null)),a=r?.iuid??e.iuid??null,i=r?.name??e.name??null;if(!a)return e.name&&await(s?.deleteByName(e.name)),{name:i,iuid:null,deleted:!1};const n=await fetch(`/api/v1/documents/${a}/`,{method:"DELETE",headers:this.authHeader()});if(!n.ok&&404!==n.status){const e=await n.text().catch((()=>"delete failed"));throw new Error(`cardsFS.delete fallback failed: ${e}`)}await(s?.deleteByIuid(a,i??void 0));return{name:i??a,iuid:a,deleted:404!==n.status}}async cardsFsListFallback(){if(!this.shouldUseCardFsFallback())throw new Error("cardsFS.list fallback is disabled because parent supports card_fs");const e=this.getCardIuid();if(!e)throw new Error("cardsFS.list fallback failed: card not initialized");const t=this.ensureCardFsCache();try{const s=await this.fetchAllDocuments(e);if(t)for(const e of s)await t.cacheDocument(e,void 0);return{documents:s,from_cache:!1}}catch(e){const s=await(t?.getAllCachedObjects());if(s&&s.length>0)return{documents:s,from_cache:!0};throw e}}authHeader(){return this.accessToken?{Authorization:`Bearer ${this.accessToken}`}:{}}jsonHeaders(){return{...this.authHeader(),"Content-Type":"application/json"}}async fetchDocumentMetadataByTarget(e,t){return t.iuid?this.fetchDocumentMetadataByIuid(t.iuid):t.name?this.fetchDocumentMetadataByName(e,t.name):null}async fetchDocumentMetadataByIuid(e){const t=await fetch(`/api/v1/documents/${e}/`,{method:"GET",headers:this.authHeader()});if(404===t.status)return null;if(!t.ok){const e=await t.text().catch((()=>"metadata lookup failed"));throw new Error(`cardsFS metadata fetch failed: ${e}`)}return t.json().catch((()=>null))}normalizeDocumentsResponse(e){return Array.isArray(e?.results)?e.results:Array.isArray(e)?e:e?[e]:[]}extractHttpErrorMessage(e,t){if(!e)return t;if("string"==typeof e)return e;if(e instanceof Error&&e.message)return e.message;const s=e?.error??e;return s instanceof Blob?t:"string"==typeof s?s:s?.detail?s.detail:s?.message?s.message:"string"==typeof s?.statusText&&s.statusText.trim()?s.statusText:t}async fetchDocumentMetadataByName(e,t){if(!t)return null;const s=await fetch(`/api/v1/documents/with_card/${e}/?name=${encodeURIComponent(t)}`,{method:"GET",headers:this.authHeader()});if(!s.ok){if(404===s.status)return null;const e=await s.text().catch((()=>"metadata lookup failed"));throw new Error(`cardsFS metadata fetch failed: ${e}`)}const r=await s.json().catch((()=>null)),a=this.normalizeDocumentsResponse(r);return a.find((e=>e?.name===t))??a[0]??null}async fetchAllDocuments(e){const t=await fetch(`/api/v1/documents/with_card/${e}/`,{method:"GET",headers:this.authHeader()});if(!t.ok){const e=await t.text().catch((()=>"list failed"));throw new Error(`cardsFS.list failed: ${e}`)}const s=await t.json().catch((()=>null));return this.normalizeDocumentsResponse(s)}async fetchDocumentPayload(e,t){const s="string"==typeof t?{name:t}:t,r=await this.fetchDocumentMetadataByTarget(e,s);if(!r)throw new Error(`cardsFS document not found: ${this.describeCardFsTarget(s)}`);return{object:r,data:await this.fetchDocumentData(r)}}async fetchDocumentData(e){if(void 0!==e?.data)return e.data;const t=e?.orig?.url||e?.url?.original||e?.url;if(!t||"string"!=typeof t)return null;const s=await fetch(t);if(!s.ok){const e=await s.text().catch((()=>"download failed"));throw new Error(`cardsFS data fetch failed: ${e}`)}const r=s.headers.get("Content-Type")||"";return r.includes("application/json")?s.json():r.startsWith("text/")?s.text():s.arrayBuffer()}async buildFileFormData(e,t){let s;const r=e=>{if(e instanceof ArrayBuffer)return new Blob([e.slice(0)],{type:"application/octet-stream"});if("undefined"!=typeof SharedArrayBuffer&&e instanceof SharedArrayBuffer){const t=new Uint8Array(e),s=new Uint8Array(t.length);return s.set(t),new Blob([s.buffer],{type:"application/octet-stream"})}if(ArrayBuffer.isView(e)){const t=new Uint8Array(e.buffer,e.byteOffset,e.byteLength),s=new Uint8Array(t.length);return s.set(t),new Blob([s.buffer],{type:"application/octet-stream"})}const t=new Uint8Array(e),s=new Uint8Array(t.length);return s.set(t),new Blob([s.buffer],{type:"application/octet-stream"})};if(t instanceof File)s=t;else if("undefined"!=typeof Blob&&t instanceof Blob)s=new File([t],e,{type:t.type||"application/octet-stream"});else if("undefined"!=typeof SharedArrayBuffer&&t instanceof SharedArrayBuffer){const a=r(t);s=new File([a],e,{type:a.type})}else if(t instanceof ArrayBuffer){const a=r(t);s=new File([a],e,{type:a.type})}else if(ArrayBuffer.isView(t)){const a=r(t);s=new File([a],e,{type:a.type})}else if("string"==typeof t){const r=new Blob([t],{type:"text/plain"});s=new File([r],e,{type:r.type})}else{const r=JSON.stringify(t??{}),a=new Blob([r],{type:"application/json"});s=new File([a],e,{type:a.type})}const a=new FormData;return a.append("file",s),a}async upsertDocumentViaApi(e,t,s){const r=await this.buildFileFormData(t.name??t.iuid??"document",s);if(t.iuid){const e=await fetch(`/api/v1/documents/${t.iuid}/`,{method:"PUT",headers:this.authHeader(),body:r});if(!e.ok){const t=await e.text().catch((()=>"update failed"));throw new Error(`cardsFS.write update failed: ${t}`)}return}const a=t.name?await this.fetchDocumentMetadataByName(e,t.name).catch((()=>null)):null;if(a?.iuid){const e=await fetch(`/api/v1/documents/${a.iuid}/`,{method:"PUT",headers:this.authHeader(),body:r});if(!e.ok){const t=await e.text().catch((()=>"update failed"));throw new Error(`cardsFS.write update failed: ${t}`)}return}const i=await fetch("/api/v1/documents/",{method:"POST",headers:this.authHeader(),body:r});if(!i.ok){const e=await i.text().catch((()=>"upload failed"));throw new Error(`cardsFS.write upload failed: ${e}`)}const n=await i.json().catch((()=>null)),o=Array.isArray(n?.results)?n.results[0]:n,c=o?.iuid;if(!c)throw new Error("cardsFS.write upload failed: missing document iuid");const d=await fetch(`/api/v1/documents/with_card/${e}/`,{method:"POST",headers:this.jsonHeaders(),body:JSON.stringify({documents:[c]})});if(!d.ok){const e=await d.text().catch((()=>"attach failed"));throw new Error(`cardsFS.write attach failed: ${e}`)}}async getDocumentAttachedToCard(e,t="default"){const s=new URL(`/api/v1/documents/attached_to/${e}/`);s.searchParams.set("name",t);const r=await fetch(s.toString(),{method:"GET",headers:{Authorization:`Bearer ${this.accessToken||""}`,"Content-Type":"application/json"}});if(!r.ok){const e=await r.text();throw new Error(`Fetch failed: ${e}`)}return r.json()}async postDocumentAttachedToCard(e,t){const s=await fetch(`/api/v1/documents/attached_to/${e}/`,{method:"POST",headers:{Authorization:`Bearer ${this.accessToken||""}`,"Content-Type":"application/json"},body:JSON.stringify(t)});if(!s.ok){const e=await s.text();throw new Error(`Post failed: ${e}`)}return s.json()}async getCardDocument(e,t){const s=await fetch(`/api/v1/documents/with_card/${e}/?name=${t}`,{method:"GET",headers:{Authorization:`Bearer ${this.accessToken||""}`,"Content-Type":"application/json"}});return await s.json()}formatErrorMessage(e){if("string"==typeof e&&e.trim())return e;if(e instanceof Error)return e.message||e.toString();if(e&&"object"==typeof e){if("string"==typeof e.message)return e.message;try{return JSON.stringify(e)}catch{return Object.prototype.toString.call(e)}}return null!=e?String(e):"Unknown error"}sendEventError(e,t,s=void 0){const r={message:this.formatErrorMessage(t),error_code:e,data:s??null};this.handler&&this.safeInvoke("onError",this.handler,r)}setFileDirty(e){this.sendMessage(l.FILE_DIRTY,e)}getUsername(e){const t=e?.name;return t&&Object.values(t).some((e=>e))?function(e){const{prefix:t="",given:s="",middle:r="",family:a="",suffix:i=""}=e||{};return[t,s,r,a,i].filter((e=>e)).join(" ").trim()}(t):""}}return h.FS_RESPONSE_TIMEOUT_MS=3e4,h.FS_READ_RETENTION_MS=5e3,h.CARD_FS_ACK_TIMEOUT_MS=5e3,t})()));
1
+ !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.domeSdk=t():e.domeSdk=t()}(this,(()=>(()=>{"use strict";var e={d:(t,s)=>{for(var r in s)e.o(s,r)&&!e.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:s[r]})},o:(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r:e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}},t={};e.r(t),e.d(t,{CardSdk:()=>u,CryptoA01:()=>r,ViewerSdk:()=>d});const s="0.2.3";class r{constructor(){if(this.subtleCrypto=window.crypto?.subtle,!this.subtleCrypto)throw new Error("SubtleCrypto API is not available in this environment.")}async decrypt(e,t,s){try{if(!e)throw new Error("Invalid token");const r=this.base64UrlDecode(e);if(128!==r[0])throw new Error("Invalid version");r.slice(1,9);const a=r.slice(9,25),i=r.slice(25,-32),n=r.slice(-32),o=await this.deriveKey(t,s),{hmacKey:c,aesKey:d}=await this.splitKey(o),l=r.slice(0,-32);if(!new Uint8Array(await this.subtleCrypto.sign("HMAC",c,l)).every(((e,t)=>e===n[t])))throw new Error("Invalid HMAC. Token has been tampered with!");const h=await this.subtleCrypto.decrypt({name:"AES-CBC",iv:a},d,i);return(new TextDecoder).decode(h)}catch(e){throw console.log("Error in decrypt:",e),e}}async deriveKey(e,t,s=1e4){const r=new TextEncoder,a=await this.subtleCrypto.importKey("raw",r.encode(e),"PBKDF2",!1,["deriveKey"]);return this.subtleCrypto.deriveKey({name:"PBKDF2",hash:"SHA-256",salt:r.encode(t),iterations:s},a,{name:"AES-CBC",length:256},!0,["encrypt","decrypt"])}async splitKey(e){const t=new Uint8Array(await this.subtleCrypto.exportKey("raw",e));return{hmacKey:await this.subtleCrypto.importKey("raw",t.slice(0,16),{name:"HMAC",hash:"SHA-256"},!1,["sign","verify"]),aesKey:await this.subtleCrypto.importKey("raw",t.slice(16),{name:"AES-CBC"},!1,["encrypt","decrypt"])}}base64UrlDecode(e){const t=e.replace(/-/g,"+").replace(/_/g,"/"),s=atob(t);return new Uint8Array([...s].map((e=>e.charCodeAt(0))))}}var a,i,n;!function(e){e.CONNECTION_SUCCESS="CONNECTION_SUCCESS",e.INIT="INIT",e.REQUEST_SAVE="REQUEST_SAVE",e.REQUEST_CLOSE="REQUEST_CLOSE",e.REQUEST_INITIAL_DATA="REQUEST_INITIAL_DATA",e.SET_DIRTY="SET_DIRTY",e.SEND_CLOSE="SEND_CLOSE",e.SEND_EXCEPTION="SEND_EXCEPTION"}(a||(a={})),function(e){e.INIT_MESSAGE_CHANNEL="INIT_MESSAGE_CHANNEL"}(i||(i={})),function(e){e.CONNECT="CONNECT",e.REQUEST_CLOSE="REQUEST_CLOSE",e.REQUEST_SAVE="REQUEST_SAVE",e.SAVE_ERROR="SAVE_ERROR",e.SAVE_SUCCESS="SAVE_SUCCESS",e.DATA_CHANGE="DATA_CHANGE",e.FILE_DATA="FILE_DATA",e.WRITE_FILE_ACK="WRITE_FILE_ACK",e.READ_FILE_ACK="READ_FILE_ACK",e.DELETE_FILE_ACK="DELETE_FILE_ACK",e.LIST_FILES_ACK="LIST_FILES_ACK",e.INIT_ACK="INIT_ACK",e.ERROR="ERROR",e.REFRESH="REFRESH"}(n||(n={}));new Set("undefined"==typeof window?[]:[window.location.origin,"https://dome.so","https://spaces.intouchapp.com/","http://localhost:4200","http://localhost:4201","null"]);const o=new Set(["dome","intouchapp"]);class c{constructor(){this.targetOrigin="*",this.isAppReady=!1,this.port2=null,this.runtimeHost="unknown",this.parentHostDetails=null,this.parentCapabilities=null,this.handleDeepLinkClick=e=>{if("webapp"!==this.runtimeHost)return;if(!(e.target instanceof Element))return;const t=e.target.closest("a[href]");if(!t)return;const s=t.getAttribute("href")??"";this.emitDeepLink(s)&&e.preventDefault()},console.info(`Initializing Dome Embedded App SDK v${s}`),this.detectHost(),this.setupDeepLinkInterception()}detectHost(){void 0!==window.AndroidBridge?this.runtimeHost="android":void 0!==window.webkit?this.runtimeHost="ios":this.runtimeHost="webapp",this.runtimeHost}setupDeepLinkInterception(){"webapp"===this.runtimeHost&&"undefined"!=typeof document&&document.addEventListener("click",this.handleDeepLinkClick,!0)}emitDeepLink(e){if("string"!=typeof e||""===e.trim())return console.warn("emitDeepLink called without a valid href"),!1;const t=e.split(":")[0]?.toLowerCase();return!(!t||!o.has(t))&&(this.sendMessage(l.OPEN_DEEPLINK,{url:e}),!0)}updateParentContext(e,t){if(!e&&!t)return;const s={...this.parentHostDetails??{type:this.runtimeHost},...e??{}};s.type||(s.type=this.runtimeHost);const r=t??this.parentCapabilities??s.capabilities;t&&(this.parentCapabilities=t),r?s.capabilities=r:delete s.capabilities,this.parentHostDetails=s,this.parentCapabilities=r??null,r?console.info("Host capabilities detected",{host_type:s.type,capabilities:r}):console.info("Host capabilities not found",{hostType:s.type})}getHost(){return this.parentHostDetails??{type:this.runtimeHost}}sendMessage(e,t){const s={type:e,data:t??null};switch(this.runtimeHost){case"android":window.AndroidBridge?.sendMessage(JSON.stringify(s));break;case"ios":window?.webkit?.messageHandlers?window.webkit?.messageHandlers.appHandler.postMessage(JSON.stringify(s)):console.error("webkit.messageHandlers not found");break;case"webapp":this.port2?this.port2.postMessage(s):console.error("Web connection is not established.");break;default:console.error("Unsupported host, cannot send message.")}this.runtimeHost}sendAppInit(){this.isAppReady||(this.isAppReady=!0,this.sendMessage(a.INIT,{sdk:{ver:s}}))}safeInvoke(e,t,s){const r=t[e];"function"==typeof r?r(s):console.warn(`Handler for '${String(e)}' is not defined.`)}setupParentConnection(){return new Promise(((e,t)=>{switch(this.runtimeHost){case"android":window.receiveFromAndroid=e=>{this.handleMessage(e.type,e.data)},e();break;case"ios":window.receiveFromIOS=e=>{this.handleMessage(e.type,e.data)},e();break;case"webapp":if(this.port2)return console.warn("Connection already established. Skipping reinitialization."),void e();const r=t=>{const{type:s}=t.data||{};s===n.CONNECT&&t.ports&&t.ports.length>0&&(this.port2=t.ports[0],this.port2.onmessage=e=>this.handlePortMessage(e),window.removeEventListener("message",r),this.notifyConnectionSuccess(),e())};window.addEventListener("message",r),window.parent?window.parent.postMessage({type:i.INIT_MESSAGE_CHANNEL,data:{sdk:{ver:s}}},this.targetOrigin):console.error("Parent window not available to initialize message channel.");break;default:console.error("Unknown host."),t("Unknown host")}}))}notifyConnectionSuccess(){this.sendMessage(a.CONNECTION_SUCCESS)}handlePortMessage(e){const{type:t,data:s}=e.data||{};t&&this.handleMessage(t,s)}handleMessage(e,t){throw new Error("Subclasses must implement handleMessage.")}}class d extends c{constructor(){super(),this.handler=null,this.pendingRequests=new Map,this.pendingInitAck=null}static init(e){return d.initialized?(console.warn("ViewerSdk is already initialized. Skipping initialization."),d.instance):(d.instance||(d.instance=new d,d.instance.setupParentConnection().then((()=>{try{d.instance.initializeViewerSdk()}catch(e){console.error("Error in initializeViewerSdk:",e)}})).catch((e=>{console.error("init: Error setting up parent connection!",e),console.trace("called from:")}))),e&&d.instance.setHandler(e),d.initialized=!0,d.instance)}setHandler(e){this.handler=e,this.pendingInitAck&&(this.safeInvoke("onInitialData",this.handler,this.pendingInitAck),this.pendingInitAck=null)}canRead(e){return!!e?.includes("r")}canWrite(e){return!!e?.includes("w")||!!e?.includes("*")}initializeViewerSdk(){this.sendAppInit()}requestInitialData(){this.sendMessage(a.REQUEST_INITIAL_DATA)}requestSave(e,t){const s=function(){if("undefined"!=typeof window&&window.crypto&&window.crypto.randomUUID)return window.crypto.randomUUID();if("undefined"!=typeof crypto&&crypto.randomUUID)return crypto.randomUUID();throw new Error("UUID generation is not supported in this environment")}();return this.sendMessage(a.REQUEST_SAVE,{doc:e,isDataDirty:t,requestId:s}),new Promise(((e,t)=>{this.pendingRequests.set(s,e),this.pendingRequests.set(s+"_reject",t),setTimeout((()=>{this.pendingRequests.has(s)&&(this.pendingRequests.delete(s),this.pendingRequests.delete(s+"_reject"))}),3e4)}))}handleOnSave(e){const{requestId:t,status:s,message:r}=e,a=this.pendingRequests.get(t),i=this.pendingRequests.get(t+"_reject");a&&("error"===s?i?.({status:s,message:r}):a({status:s,message:r}),this.pendingRequests.delete(t),this.pendingRequests.delete(t+"_reject"))}setDirty(e){this.sendMessage(a.SET_DIRTY,e)}sendClose(e,t){this.sendMessage(a.SEND_CLOSE,{doc:e,isDataDirty:t})}sendException(e){this.sendMessage(a.SEND_EXCEPTION,e)}handleMessage(e,t){if(e===n.INIT_ACK&&this.updateParentContext(t?.host,t?.capabilities),this.handler)switch(e){case n.INIT_ACK:this.safeInvoke("onInitialData",this.handler,t);break;case n.DATA_CHANGE:this.safeInvoke("onDataChange",this.handler,t);break;case n.REQUEST_CLOSE:this.safeInvoke("onCloseRequest",this.handler);break;case n.REQUEST_SAVE:this.safeInvoke("onSaveRequest",this.handler);break;case n.SAVE_SUCCESS:case n.SAVE_ERROR:this.handleOnSave(t);break;default:console.warn(`No handler found for message type: ${e}`)}else e===n.INIT_ACK?(console.warn("Handler not set. Storing INIT_ACK message for later processing."),this.pendingInitAck=t):console.error("Message handler not found for type:",e)}}var l;d.initialized=!1,function(e){e.APP_READY="APP_READY",e.INIT="INIT",e.READ_FILE="READ_FILE",e.WRITE_FILE="WRITE_FILE",e.DELETE_FILE="DELETE_FILE",e.LIST_FILES="LIST_FILES",e.FILE_DIRTY="FILE_DIRTY",e.OPEN_DEEPLINK="OPEN_DEEPLINK"}(l||(l={}));class h{constructor(e,t){this.cardIuid=e,this.containerIuid=t,this.openPromise=null}isSupported(){return"undefined"!=typeof indexedDB}async openDb(){return this.isSupported()?(this.openPromise||(this.openPromise=new Promise((e=>{this.openWithVersion(h.DB_VERSION,e)}))),this.openPromise):null}openWithVersion(e,t){let s="ensure";const r=indexedDB.open(this.cardIuid,e);r.onupgradeneeded=e=>{s=0===(e.oldVersion||0)?"create":"ensure",this.configureStores(r.result)},r.onsuccess=()=>{const e=r.result;if(!this.hasRequiredStores(e)){const s=e.version+1;return e.close(),void this.openWithVersion(s,t)}this.updateStoresMetadata(e,"ensure"===s).catch((()=>{})).finally((()=>t(e)))},r.onerror=()=>t(null)}configureStores(e){e.objectStoreNames.contains(h.DATA_STORE)||e.createObjectStore(h.DATA_STORE),e.objectStoreNames.contains(h.NAME_LOOKUP_STORE)||e.createObjectStore(h.NAME_LOOKUP_STORE),e.objectStoreNames.contains(h.INFO_STORE)||e.createObjectStore(h.INFO_STORE)}hasRequiredStores(e){const t=e.objectStoreNames;return t.contains(h.DATA_STORE)&&t.contains(h.NAME_LOOKUP_STORE)&&t.contains(h.INFO_STORE)}static nowMicros(){return Math.trunc(1e3*Date.now())}updateStoresMetadata(e,t){return Promise.all([this.ensureStoreVersion(e,h.DATA_STORE),this.ensureStoreVersion(e,h.NAME_LOOKUP_STORE),this.updateCardInfo(e,t)]).then((()=>{}))}ensureStoreVersion(e,t){return e.objectStoreNames.contains(t)?new Promise((s=>{try{const r=e.transaction(t,"readwrite"),a=r.objectStore(t),i=()=>s();r.oncomplete=i,r.onerror=i,r.onabort=i,a.put("1.0.0",h.STORE_VERSION_KEY)}catch{s()}})):Promise.resolve()}async updateCardInfo(e,t){if(!e.objectStoreNames.contains(h.INFO_STORE))return;const s=await this.readInfoValue(e,"container_iuid"),r=t?await this.readInfoValue(e,"ts_c"):void 0,a=this.containerIuid??s??null,i=t&&r?r:h.nowMicros();await Promise.all([this.writeInfoValue(e,"container_iuid",a),this.writeInfoValue(e,"ts_c",i)]).catch((()=>{}))}readInfoValue(e,t){return new Promise((s=>{try{const r=e.transaction(h.INFO_STORE,"readonly"),a=r.objectStore(h.INFO_STORE).get(t);a.onsuccess=()=>s(a.result),a.onerror=()=>s(void 0)}catch{s(void 0)}}))}writeInfoValue(e,t,s){return new Promise((r=>{try{const a=e.transaction(h.INFO_STORE,"readwrite"),i=a.objectStore(h.INFO_STORE),n=()=>r();a.oncomplete=n,a.onerror=n,a.onabort=n,i.put(s,t)}catch{r()}}))}keyFor(e){return e}static normalizeName(e){if("string"!=typeof e)return null;const t=e.trim();return t||null}async put(e,t){const s=await this.openDb();s&&await new Promise((r=>{const a=s.transaction(h.DATA_STORE,"readwrite");a.objectStore(h.DATA_STORE).put(t,e).onsuccess=()=>r(),a.oncomplete=()=>r(),a.onerror=()=>r(),a.onabort=()=>r()}))}async get(e){const t=await this.openDb();if(t)return new Promise((s=>{const r=t.transaction(h.DATA_STORE,"readonly").objectStore(h.DATA_STORE).get(e);r.onsuccess=()=>s(r.result),r.onerror=()=>s(void 0)}))}async delete(e){const t=await this.openDb();t&&await new Promise((s=>{const r=t.transaction(h.DATA_STORE,"readwrite");r.objectStore(h.DATA_STORE).delete(e).onsuccess=()=>s(),r.oncomplete=()=>s(),r.onerror=()=>s(),r.onabort=()=>s()}))}static async hashName(e){const t="undefined"!=typeof globalThis?globalThis.crypto:void 0;if(!t?.subtle?.digest)throw new Error("CardFS name hashing requires SubtleCrypto support");const s=h.encodeText(e),r=await t.subtle.digest("SHA-256",s);return h.bufferToBase64(r)}static encodeText(e){if("undefined"!=typeof TextEncoder)return(new TextEncoder).encode(e).buffer;const t=new Uint8Array(e.length);for(let s=0;s<e.length;s++)t[s]=e.charCodeAt(s);return t.buffer}static bufferToBase64(e){let t="";const s=new Uint8Array(e);for(let e=0;e<s.length;e++)t+=String.fromCharCode(s[e]);return btoa(t)}async getIuidForName(e){const t=h.normalizeName(e);if(!t)return;const s=await this.openDb();if(!s)return;const r=await h.hashName(t);return new Promise((e=>{const t=s.transaction(h.NAME_LOOKUP_STORE,"readonly").objectStore(h.NAME_LOOKUP_STORE).get(r);t.onsuccess=()=>e(t.result),t.onerror=()=>e(void 0)}))}async upsertNameLookup(e,t){const s=h.normalizeName(e);if(!s)return;const r=await this.openDb();if(!r)return;const a=await h.hashName(s);await new Promise((e=>{const s=r.transaction(h.NAME_LOOKUP_STORE,"readwrite"),i=s.objectStore(h.NAME_LOOKUP_STORE);i.put(t,a);i.openCursor().onsuccess=e=>{const s=e.target.result;s&&(s.key!==a&&s.value===t&&s.delete(),s.continue())},s.oncomplete=()=>e(),s.onerror=()=>e(),s.onabort=()=>e()}))}async deleteNameLookupByName(e){const t=h.normalizeName(e);if(!t)return;const s=await this.openDb();if(!s)return;const r=await h.hashName(t);await new Promise((e=>{const t=s.transaction(h.NAME_LOOKUP_STORE,"readwrite");t.objectStore(h.NAME_LOOKUP_STORE).delete(r),t.oncomplete=()=>e(),t.onerror=()=>e(),t.onabort=()=>e()}))}async deleteNameLookupByIuid(e){if(!e)return;const t=await this.openDb();t&&await new Promise((s=>{const r=t.transaction(h.NAME_LOOKUP_STORE,"readwrite");r.objectStore(h.NAME_LOOKUP_STORE).openCursor().onsuccess=t=>{const s=t.target.result;s&&(s.value===e&&s.delete(),s.continue())},r.oncomplete=()=>s(),r.onerror=()=>s(),r.onabort=()=>s()}))}static estimateSize(e){if(null==e)return 0;if("undefined"!=typeof Blob&&e instanceof Blob)return e.size;if(e instanceof ArrayBuffer)return e.byteLength;if(ArrayBuffer.isView(e))return e.byteLength;if("string"==typeof e)return new Blob([e]).size;try{return new Blob([JSON.stringify(e)]).size}catch{return 0}}async cacheDocument(e,t){if(!e?.iuid)return;await this.put(this.keyFor(`${e.iuid}_object`),e);const s=h.normalizeName(e.name);if(s&&await this.upsertNameLookup(s,e.iuid),void 0===t)return void await this.delete(this.keyFor(`${e.iuid}_data`));h.estimateSize(t)<=h.MAX_DATA_BYTES?await this.put(this.keyFor(`${e.iuid}_data`),t):await this.delete(this.keyFor(`${e.iuid}_data`))}async getByName(e){const t=h.normalizeName(e);if(!t)return null;const s=await this.getIuidForName(t);if(!s)return null;const r=await this.get(this.keyFor(`${s}_object`));if(!r)return null;return{iuid:s,object:r,data:await this.get(this.keyFor(`${s}_data`))}}async getByIuid(e){if(!e)return null;const t=await this.get(this.keyFor(`${e}_object`));if(!t)return null;return{iuid:e,object:t,data:await this.get(this.keyFor(`${e}_data`))}}async deleteByName(e){const t=await this.getByName(e);await this.deleteNameLookupByName(e),t&&(await this.delete(this.keyFor(`${t.iuid}_object`)),await this.delete(this.keyFor(`${t.iuid}_data`)))}async deleteByIuid(e,t){t&&await this.deleteNameLookupByName(t),await this.deleteNameLookupByIuid(e),await this.delete(this.keyFor(`${e}_object`)),await this.delete(this.keyFor(`${e}_data`))}async getAllCachedObjects(){const e=await this.openDb();return e?new Promise((t=>{const s=[],r=e.transaction(h.DATA_STORE,"readonly").objectStore(h.DATA_STORE).openCursor();r.onsuccess=e=>{const r=e.target.result;if(!r)return void t(s);const a=r.key;"string"==typeof a&&a.endsWith("_object")&&s.push(r.value),r.continue()},r.onerror=()=>t(s)})):[]}}h.DB_VERSION=2,h.DATA_STORE="cardfs",h.NAME_LOOKUP_STORE="cardfs_name_iuid_lookup",h.INFO_STORE="info",h.STORE_VERSION_KEY="ver",h.MAX_DATA_BYTES=5242880;class u extends c{resolveCardFsTarget(e,t){const s="string"==typeof e?{name:e}:e??{},r="string"==typeof s.name?s.name.trim():void 0,a="string"==typeof s.iuid?s.iuid.trim():void 0;if(!r&&!a)throw new Error(`cardsFS.${t} requires a file name or document iuid`);return{name:r,iuid:a}}describeCardFsTarget(e){return e.name&&e.iuid?`"${e.name}" (iuid ${e.iuid})`:e.name?`"${e.name}"`:e.iuid?`iuid ${e.iuid}`:"document"}buildCardFsMessagePayload(e,t){return{...e.name?{name:e.name}:{},...e.iuid?{iuid:e.iuid}:{},...t??{}}}getCardIuid(){return this.dataStore?.iuid||null}ensureCardFsCache(){if(!this.shouldUseCardFsFallback())return null;if(!this.cardFsCache){const e=this.getCardIuid();e&&(this.cardFsCache=new h(e,this.containerIuid))}return this.cardFsCache}supportsParentCardFs(){return!!this.parentCapabilities?.card_fs}shouldUseCardFsFallback(){return!this.supportsParentCardFs()}constructor(){super(),this.handler=null,this.accessToken="",this.fileReadResolvers=new Map,this.fileWriteResolvers=new Map,this.fsReadRequests=new Map,this.fsWriteRequests=new Map,this.cardFsCache=null,this.pendingAcks=new Map,this.handleMessage=(e,t)=>{if(e===n.INIT_ACK&&this.updateParentContext(t?.host,t?.capabilities),!this.handler)throw new Error("Message handler not found!");const s=t?.messageId;if(s&&this.pendingAcks.has(s)){const{resolve:e,timeout:r}=this.pendingAcks.get(s);return clearTimeout(r),this.pendingAcks.delete(s),void e(t)}switch(e){case n.INIT_ACK:this.dataStore.kw1=t.key_wa1,this.dataStore.iuid=t.iuid,t.iuid?this.shouldUseCardFsFallback()?this.cardFsCache=new h(t.iuid,this.containerIuid):this.cardFsCache=null:this.shouldUseCardFsFallback()||(this.cardFsCache=null);try{this.cryptoA01.decrypt(this.dataStore.denc,t.key_wa1+this.dataStore.kw2,t.iuid).then((e=>{const s=JSON.parse(e),r=s?.container?.iuid;r&&(this.containerIuid=r,this.shouldUseCardFsFallback()&&this.dataStore?.iuid&&(this.cardFsCache=new h(this.dataStore.iuid,this.containerIuid)));const a="string"==typeof s?.api_token?s.api_token.trim():"";a?this.accessToken=a:console.warn("CardSdk: INIT_ACK payload missing api_token; fallback APIs may fail without auth"),this.handler&&this.safeInvoke("onInit",this.handler,{...s,ui:t.ui}),delete this.dataStore.denc})).catch((e=>{throw console.error("Final decrypt error",e),e}))}catch(e){console.error("Decryption failed!",e),this.sendEventError("dec2_failed",e.message)}break;case n.FILE_DATA:{const e=t?.messageId;if(e&&this.fsReadRequests.has(e)){const{messageId:s,...r}=t||{};return void this.handleFsReadDataMessage(e,r)}const s=t?.name;if(s&&this.fileReadResolvers.has(s)){const e=this.fileReadResolvers.get(s);this.fileReadResolvers.delete(s),e(t)}else console.warn("CardSdk: FILE_DATA received but no resolver found for",s);break}case n.DATA_CHANGE:this.safeInvoke("onFileChange",this.handler,t);case n.SAVE_SUCCESS:{const e=t?.messageId;if(e&&this.fsWriteRequests.has(e))return void this.handleFsWriteSuccess(e,t);const s=t?.name;if(s&&this.fileWriteResolvers.has(s)){const{resolve:e}=this.fileWriteResolvers.get(s);this.fileWriteResolvers.delete(s),e()}else console.warn("CardSdk: SAVE_SUCCESS received but no resolver found for",s);break}case n.SAVE_ERROR:{const e=t?.messageId;if(e&&this.fsWriteRequests.has(e))return void this.handleFsWriteError(e,t);const s=t?.name;if(s&&this.fileWriteResolvers.has(s)){const{reject:e}=this.fileWriteResolvers.get(s);this.fileWriteResolvers.delete(s),e(new Error(t?.message||"Unknown write error"))}else console.warn("CardSdk: SAVE_ERROR received but no resolver found for",s);break}case n.ERROR:{const e=t?.messageId;if(e){const s=t?.message||"Unknown error";if(this.fsReadRequests.has(e))return void this.failFsReadRequest(e,new Error(s));if(this.fsWriteRequests.has(e))return void this.failFsWriteRequest(e,new Error(s))}this.safeInvoke("onError",this.handler,t);break}case n.REFRESH:this.safeInvoke("onRefreshRequest",this.handler,t);break;default:console.warn(`No handler found for message type: ${e}`)}},this.cryptoA01=new r,this.cardsFS={read:(e,t)=>this.cardsFsRead(e,t),write:(e,t,s)=>this.cardsFsWrite(e,t,s),delete:(e,t)=>this.cardsFsDelete(e,t),list:e=>this.cardsFsList(e)}}static async init(e,t,s){try{return u.instance||(u.instance=new u,u.instance.setupParentConnection().then((()=>{u.instance.initializeCardSdk(e)})).catch((e=>{console.error(e)})),t&&u.instance.setHandler(t)),u.instance}catch(e){throw console.error("CardSdk: Unrecoverable error in init",e),e}}setHandler(e){this.handler=e}openDeepLink(e){this.emitDeepLink(e)||console.warn("openDeepLink ignored; provide a dome:// or intouchapp:// href")}async initializeCardSdk(e){let t="CardSdk::initializeCardSdk:";try{if(!e)throw new Error("Invalid secret");const s=window.IT_DATA_AF1;if(!s)throw console.error(t,"No data"),new Error("No data");const r=window.location.href;const a=new URL(r).pathname.split("/wa/").filter(Boolean)[1].split("/")[0].split("").reverse().join("").substring(4,25);if(!a)throw new Error("Cannot decrypt (1)");const i=await this.cryptoA01.decrypt(s,e,a);try{const e=JSON.parse(i);if(!e.ite)throw new Error("Invalid data");this.dataStore={denc:e.d,kw2:e.kw2},u.instance.sendInit(e.ite)}catch(e){throw console.error("Initial Decryption failed (2):",e),e}}catch(e){console.error(t,"Init failed:",e),this.sendEventError("init_failed",e.message)}}async sendInit(e){this.sendMessage(l.INIT,{token:e,sdk:{ver:s}})}sendMessageWithAck(e,t,s,r=15e3,a){const i=crypto.randomUUID();if(a)try{a(i)}catch(e){return Promise.reject(e)}return new Promise(((a,n)=>{const o=setTimeout((()=>{this.pendingAcks.delete(i),n(new Error(`${s} not received in time`))}),r);this.pendingAcks.set(i,{resolve:a,reject:n,timeout:o}),this.sendMessage(e,{...t,messageId:i})}))}cardsFsRead(e,t){let s;try{s=this.resolveCardFsTarget(e,"read")}catch(e){return Promise.reject(e)}return this.shouldUseCardFsFallback()?this.cardsFsReadFallback(s,void 0,t):new Promise(((e,r)=>{let a=null;const i=this.describeCardFsTarget(s);this.sendMessageWithAck(l.READ_FILE,this.buildCardFsMessagePayload(s),n.READ_FILE_ACK,u.CARD_FS_ACK_TIMEOUT_MS,(s=>{a=s;const n={name:i,onUpdate:t,resolve:e,reject:r,hasResolved:!1};n.noResponseTimeout=setTimeout((()=>{this.failFsReadRequest(s,new Error(`cardsFS.read timed out for ${i}`))}),u.FS_RESPONSE_TIMEOUT_MS),this.fsReadRequests.set(s,n)})).catch((e=>{const t=e instanceof Error?e:new Error(String(e));a?this.failFsReadRequest(a,t):r(t)}))}))}cardsFsWrite(e,t,s){let r;try{r=this.resolveCardFsTarget(e,"write")}catch(e){return Promise.reject(e)}return this.shouldUseCardFsFallback()?this.cardsFsWriteFallback(r,t).then((e=>{try{s?.(e)}catch(e){console.error("cardsFS.write fallback callback threw",e)}return e})):new Promise(((e,a)=>{let i=null;const o=this.describeCardFsTarget(r);this.sendMessageWithAck(l.WRITE_FILE,this.buildCardFsMessagePayload(r,{data:t}),n.WRITE_FILE_ACK,u.CARD_FS_ACK_TIMEOUT_MS,(t=>{i=t;const r={name:o,onResult:s,resolve:e,reject:a,timeout:setTimeout((()=>{this.failFsWriteRequest(t,new Error(`cardsFS.write timed out for ${o}`))}),u.FS_RESPONSE_TIMEOUT_MS)};this.fsWriteRequests.set(t,r)})).catch((e=>{const t=e instanceof Error?e:new Error(String(e));i?this.failFsWriteRequest(i,t):a(t)}))}))}cardsFsDelete(e,t){let s;try{s=this.resolveCardFsTarget(e,"delete")}catch(e){return Promise.reject(e)}return this.shouldUseCardFsFallback()?this.cardsFsDeleteFallback(s).then((e=>{try{t?.(e)}catch(e){console.error("cardsFS.delete fallback callback threw",e)}return e})):new Promise(((e,r)=>{this.sendMessageWithAck(l.DELETE_FILE,this.buildCardFsMessagePayload(s),n.DELETE_FILE_ACK,u.CARD_FS_ACK_TIMEOUT_MS).then((s=>{const{messageId:r,...a}=s||{};t?.(a),e(a)})).catch((e=>{r(e instanceof Error?e:new Error(String(e)))}))}))}cardsFsList(e){return this.shouldUseCardFsFallback()?this.cardsFsListFallback().then((t=>{try{e?.(t)}catch(e){console.error("cardsFS.list fallback callback threw",e)}return t})):new Promise(((t,s)=>{this.sendMessageWithAck(l.LIST_FILES,{},n.LIST_FILES_ACK,u.CARD_FS_ACK_TIMEOUT_MS).then((s=>{const{messageId:r,...a}=s||{};e?.(a),t(a)})).catch((e=>{s(e instanceof Error?e:new Error(String(e)))}))}))}handleFsReadDataMessage(e,t){const s=this.fsReadRequests.get(e);if(s){if(s.noResponseTimeout&&(clearTimeout(s.noResponseTimeout),s.noResponseTimeout=void 0),"function"==typeof s.onUpdate)try{s.onUpdate(t)}catch(e){console.error("cardsFS.read callback threw",e)}s.hasResolved||(s.hasResolved=!0,s.resolve(t)),s.cleanupTimeout&&clearTimeout(s.cleanupTimeout),s.cleanupTimeout=setTimeout((()=>{this.clearFsReadRequest(e)}),u.FS_READ_RETENTION_MS)}}clearFsReadRequest(e){const t=this.fsReadRequests.get(e);if(t)return t.noResponseTimeout&&clearTimeout(t.noResponseTimeout),t.cleanupTimeout&&clearTimeout(t.cleanupTimeout),this.fsReadRequests.delete(e),t}failFsReadRequest(e,t){const s=this.clearFsReadRequest(e);s&&s.reject(t)}clearFsWriteRequest(e){const t=this.fsWriteRequests.get(e);if(t)return clearTimeout(t.timeout),this.fsWriteRequests.delete(e),t}failFsWriteRequest(e,t){const s=this.clearFsWriteRequest(e);s&&s.reject(t)}handleFsWriteSuccess(e,t){const s=this.clearFsWriteRequest(e);if(!s)return;const{messageId:r,...a}=t||{};if("function"==typeof s.onResult)try{s.onResult(a)}catch(e){console.error("cardsFS.write callback threw",e)}s.resolve(a)}handleFsWriteError(e,t){const s=this.clearFsWriteRequest(e);if(!s)return;const r=t instanceof Error?t:new Error(t?.message||"Unknown write error");s.reject(r)}async cardsFsReadFallback(e,t,s){if(!this.shouldUseCardFsFallback())throw new Error("cardsFS.read fallback is disabled because parent supports card_fs");const r=this.getCardIuid();if(!r)throw new Error("cardsFS.read fallback failed: card not initialized");const a=this.ensureCardFsCache();let i=null;const n=this.describeCardFsTarget(e),o=(r,a,n,o,c)=>{if(!r)return;const d={name:o??e.name??r?.name??e.iuid??"document",iuid:c??r?.iuid??e.iuid??null,object:r,data:a,from_cache:n};if(t&&this.fsReadRequests.has(t))this.handleFsReadDataMessage(t,d);else if("function"==typeof s)try{s(d)}catch(e){console.error("cardsFS.read fallback callback threw",e)}i||(i=d)};if(a)try{let t=null;e.iuid&&(t=await a.getByIuid(e.iuid)),!t&&e.name&&(t=await a.getByName(e.name)),t?.object&&o(t.object,t.data,!0,t.object?.name??e.name,t.iuid)}catch(e){console.warn("cardsFS.read cache lookup failed",e)}try{const t=await this.fetchDocumentPayload(r,e);t&&(await(a?.cacheDocument(t.object,t.data)),o(t.object,t.data,!1,t.object?.name,t.object?.iuid))}catch(e){if(!i)throw e;console.warn("cardsFS.read fresh fetch failed",e)}if(!i)throw new Error(`cardsFS.read fallback could not locate ${n}`);return i}async cardsFsWriteFallback(e,t,s){if(!this.shouldUseCardFsFallback())throw new Error("cardsFS.write fallback is disabled because parent supports card_fs");const r=this.getCardIuid();if(!r)throw new Error("cardsFS.write fallback failed: card not initialized");await this.upsertDocumentViaApi(r,e,t);const a=await this.fetchDocumentPayload(r,e);await(this.ensureCardFsCache()?.cacheDocument(a.object,a.data));const i={name:a.object?.name??e.name??e.iuid??null,iuid:a.object?.iuid??e.iuid??null,object:a.object,data:a.data};return s&&this.fsWriteRequests.has(s)&&this.handleFsWriteSuccess(s,i),i}async cardsFsDeleteFallback(e){if(!this.shouldUseCardFsFallback())throw new Error("cardsFS.delete fallback is disabled because parent supports card_fs");const t=this.getCardIuid();if(!t)throw new Error("cardsFS.delete fallback failed: card not initialized");const s=this.ensureCardFsCache(),r=await this.fetchDocumentMetadataByTarget(t,e).catch((()=>null)),a=r?.iuid??e.iuid??null,i=r?.name??e.name??null;if(!a)return e.name&&await(s?.deleteByName(e.name)),{name:i,iuid:null,deleted:!1};const n=await fetch(`/api/v1/documents/${a}/`,{method:"DELETE",headers:this.authHeader()});if(!n.ok&&404!==n.status){const e=await n.text().catch((()=>"delete failed"));throw new Error(`cardsFS.delete fallback failed: ${e}`)}await(s?.deleteByIuid(a,i??void 0));return{name:i??a,iuid:a,deleted:404!==n.status}}async cardsFsListFallback(){if(!this.shouldUseCardFsFallback())throw new Error("cardsFS.list fallback is disabled because parent supports card_fs");const e=this.getCardIuid();if(!e)throw new Error("cardsFS.list fallback failed: card not initialized");const t=this.ensureCardFsCache();try{const s=await this.fetchAllDocuments(e);if(t)for(const e of s)await t.cacheDocument(e,void 0);return{documents:s,from_cache:!1}}catch(e){const s=await(t?.getAllCachedObjects());if(s&&s.length>0)return{documents:s,from_cache:!0};throw e}}authHeader(){return this.accessToken?{Authorization:`Bearer ${this.accessToken}`}:{}}jsonHeaders(){return{...this.authHeader(),"Content-Type":"application/json"}}async fetchDocumentMetadataByTarget(e,t){return t.iuid?this.fetchDocumentMetadataByIuid(t.iuid):t.name?this.fetchDocumentMetadataByName(e,t.name):null}async fetchDocumentMetadataByIuid(e){const t=await fetch(`/api/v1/documents/${e}/`,{method:"GET",headers:this.authHeader()});if(404===t.status)return null;if(!t.ok){const e=await t.text().catch((()=>"metadata lookup failed"));throw new Error(`cardsFS metadata fetch failed: ${e}`)}return t.json().catch((()=>null))}normalizeDocumentsResponse(e){return Array.isArray(e?.results)?e.results:Array.isArray(e)?e:e?[e]:[]}extractHttpErrorMessage(e,t){if(!e)return t;if("string"==typeof e)return e;if(e instanceof Error&&e.message)return e.message;const s=e?.error??e;return s instanceof Blob?t:"string"==typeof s?s:s?.detail?s.detail:s?.message?s.message:"string"==typeof s?.statusText&&s.statusText.trim()?s.statusText:t}async fetchDocumentMetadataByName(e,t){if(!t)return null;const s=await fetch(`/api/v1/documents/with_card/${e}/?name=${encodeURIComponent(t)}`,{method:"GET",headers:this.authHeader()});if(!s.ok){if(404===s.status)return null;const e=await s.text().catch((()=>"metadata lookup failed"));throw new Error(`cardsFS metadata fetch failed: ${e}`)}const r=await s.json().catch((()=>null)),a=this.normalizeDocumentsResponse(r);return a.find((e=>e?.name===t))??a[0]??null}async fetchAllDocuments(e){const t=await fetch(`/api/v1/documents/with_card/${e}/`,{method:"GET",headers:this.authHeader()});if(!t.ok){const e=await t.text().catch((()=>"list failed"));throw new Error(`cardsFS.list failed: ${e}`)}const s=await t.json().catch((()=>null));return this.normalizeDocumentsResponse(s)}async fetchDocumentPayload(e,t){const s="string"==typeof t?{name:t}:t,r=await this.fetchDocumentMetadataByTarget(e,s);if(!r)throw new Error(`cardsFS document not found: ${this.describeCardFsTarget(s)}`);return{object:r,data:await this.fetchDocumentData(r)}}async fetchDocumentData(e){if(void 0!==e?.data)return e.data;const t=e?.orig?.url||e?.url?.original||e?.url;if(!t||"string"!=typeof t)return null;const s=await fetch(t);if(!s.ok){const e=await s.text().catch((()=>"download failed"));throw new Error(`cardsFS data fetch failed: ${e}`)}const r=s.headers.get("Content-Type")||"";return r.includes("application/json")?s.json():r.startsWith("text/")?s.text():s.arrayBuffer()}async buildFileFormData(e,t){let s;const r=e=>{if(e instanceof ArrayBuffer)return new Blob([e.slice(0)],{type:"application/octet-stream"});if("undefined"!=typeof SharedArrayBuffer&&e instanceof SharedArrayBuffer){const t=new Uint8Array(e),s=new Uint8Array(t.length);return s.set(t),new Blob([s.buffer],{type:"application/octet-stream"})}if(ArrayBuffer.isView(e)){const t=new Uint8Array(e.buffer,e.byteOffset,e.byteLength),s=new Uint8Array(t.length);return s.set(t),new Blob([s.buffer],{type:"application/octet-stream"})}const t=new Uint8Array(e),s=new Uint8Array(t.length);return s.set(t),new Blob([s.buffer],{type:"application/octet-stream"})};if(t instanceof File)s=t;else if("undefined"!=typeof Blob&&t instanceof Blob)s=new File([t],e,{type:t.type||"application/octet-stream"});else if("undefined"!=typeof SharedArrayBuffer&&t instanceof SharedArrayBuffer){const a=r(t);s=new File([a],e,{type:a.type})}else if(t instanceof ArrayBuffer){const a=r(t);s=new File([a],e,{type:a.type})}else if(ArrayBuffer.isView(t)){const a=r(t);s=new File([a],e,{type:a.type})}else if("string"==typeof t){const r=new Blob([t],{type:"text/plain"});s=new File([r],e,{type:r.type})}else{const r=JSON.stringify(t??{}),a=new Blob([r],{type:"application/json"});s=new File([a],e,{type:a.type})}const a=new FormData;return a.append("file",s),a}async upsertDocumentViaApi(e,t,s){const r=await this.buildFileFormData(t.name??t.iuid??"document",s);if(t.iuid){const e=await fetch(`/api/v1/documents/${t.iuid}/`,{method:"PUT",headers:this.authHeader(),body:r});if(!e.ok){const t=await e.text().catch((()=>"update failed"));throw new Error(`cardsFS.write update failed: ${t}`)}return}const a=t.name?await this.fetchDocumentMetadataByName(e,t.name).catch((()=>null)):null;if(a?.iuid){const e=await fetch(`/api/v1/documents/${a.iuid}/`,{method:"PUT",headers:this.authHeader(),body:r});if(!e.ok){const t=await e.text().catch((()=>"update failed"));throw new Error(`cardsFS.write update failed: ${t}`)}return}const i=await fetch("/api/v1/documents/",{method:"POST",headers:this.authHeader(),body:r});if(!i.ok){const e=await i.text().catch((()=>"upload failed"));throw new Error(`cardsFS.write upload failed: ${e}`)}const n=await i.json().catch((()=>null)),o=Array.isArray(n?.results)?n.results[0]:n,c=o?.iuid;if(!c)throw new Error("cardsFS.write upload failed: missing document iuid");const d=await fetch(`/api/v1/documents/with_card/${e}/`,{method:"POST",headers:this.jsonHeaders(),body:JSON.stringify({documents:[c]})});if(!d.ok){const e=await d.text().catch((()=>"attach failed"));throw new Error(`cardsFS.write attach failed: ${e}`)}}async getDocumentAttachedToCard(e,t="default"){const s=new URL(`/api/v1/documents/attached_to/${e}/`);s.searchParams.set("name",t);const r=await fetch(s.toString(),{method:"GET",headers:{Authorization:`Bearer ${this.accessToken||""}`,"Content-Type":"application/json"}});if(!r.ok){const e=await r.text();throw new Error(`Fetch failed: ${e}`)}return r.json()}async postDocumentAttachedToCard(e,t){const s=await fetch(`/api/v1/documents/attached_to/${e}/`,{method:"POST",headers:{Authorization:`Bearer ${this.accessToken||""}`,"Content-Type":"application/json"},body:JSON.stringify(t)});if(!s.ok){const e=await s.text();throw new Error(`Post failed: ${e}`)}return s.json()}async getCardDocument(e,t){const s=await fetch(`/api/v1/documents/with_card/${e}/?name=${t}`,{method:"GET",headers:{Authorization:`Bearer ${this.accessToken||""}`,"Content-Type":"application/json"}});return await s.json()}formatErrorMessage(e){if("string"==typeof e&&e.trim())return e;if(e instanceof Error)return e.message||e.toString();if(e&&"object"==typeof e){if("string"==typeof e.message)return e.message;try{return JSON.stringify(e)}catch{return Object.prototype.toString.call(e)}}return null!=e?String(e):"Unknown error"}sendEventError(e,t,s=void 0){const r={message:this.formatErrorMessage(t),error_code:e,data:s??null};this.handler&&this.safeInvoke("onError",this.handler,r)}setFileDirty(e){this.sendMessage(l.FILE_DIRTY,e)}getUsername(e){const t=e?.name;return t&&Object.values(t).some((e=>e))?function(e){const{prefix:t="",given:s="",middle:r="",family:a="",suffix:i=""}=e||{};return[t,s,r,a,i].filter((e=>e)).join(" ").trim()}(t):""}}return u.FS_RESPONSE_TIMEOUT_MS=3e4,u.FS_READ_RETENTION_MS=5e3,u.CARD_FS_ACK_TIMEOUT_MS=5e3,t})()));
2
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","mappings":"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","sources":["webpack://domeSdk/webpack/universalModuleDefinition","webpack://domeSdk/webpack/bootstrap","webpack://domeSdk/webpack/runtime/define property getters","webpack://domeSdk/webpack/runtime/hasOwnProperty shorthand","webpack://domeSdk/webpack/runtime/make namespace object","webpack://domeSdk/./src/crypto.ts","webpack://domeSdk/./src/dome-sdk.ts","webpack://domeSdk/./src/utils.ts"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"domeSdk\"] = factory();\n\telse\n\t\troot[\"domeSdk\"] = factory();\n})(this, () => {\nreturn ","// The require scope\nvar __webpack_require__ = {};\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","// Provide enc / dec using Algorithm01\nexport class CryptoA01 {\n constructor() {\n // Initialize subtleCrypto once\n this.subtleCrypto = window.crypto?.subtle;\n if (!this.subtleCrypto) {\n throw new Error('SubtleCrypto API is not available in this environment.');\n }\n }\n /**\n * Perform decryption using AES based V1 algorithm.\n *\n * string: the encrypted string (base64 encoded)\n * password: the password used for encryption\n * salt: the base64 encoded salt used\n */\n async decrypt(token, password, salt) {\n try {\n if (!token) {\n throw new Error(\"Invalid token\");\n }\n const tokenBytes = this.base64UrlDecode(token);\n // Extract token components\n const version = tokenBytes[0];\n if (version !== 0x80) {\n // console.log(\"Incorrect Version: \", version);\n throw new Error('Invalid version');\n }\n const timestamp = tokenBytes.slice(1, 9);\n const iv = tokenBytes.slice(9, 25);\n const ciphertext = tokenBytes.slice(25, -32);\n const hmacFromToken = tokenBytes.slice(-32);\n // Derive the key and split it into HMAC and AES keys\n const fullKey = await this.deriveKey(password, salt);\n const { hmacKey, aesKey } = await this.splitKey(fullKey);\n // Compute HMAC over version + timestamp + IV + ciphertext\n const hmacInput = tokenBytes.slice(0, -32);\n const computedHmac = new Uint8Array(await this.subtleCrypto.sign('HMAC', hmacKey, hmacInput));\n // Validate HMAC\n if (!computedHmac.every((byte, i) => byte === hmacFromToken[i])) {\n throw new Error('Invalid HMAC. Token has been tampered with!');\n }\n // Decrypt the ciphertext\n const decrypted = await this.subtleCrypto.decrypt({\n name: 'AES-CBC',\n iv: iv,\n }, aesKey, ciphertext);\n // Convert decrypted data to UTF-8 string\n const decoder = new TextDecoder();\n return decoder.decode(decrypted);\n }\n catch (err) {\n console.log(\"Error in decrypt:\", err);\n throw err;\n }\n }\n async deriveKey(password, salt, iterations = 10000) {\n const encoder = new TextEncoder();\n const keyMaterial = await this.subtleCrypto.importKey(\"raw\", encoder.encode(password), \"PBKDF2\", false, [\"deriveKey\"]);\n return this.subtleCrypto.deriveKey({\n name: \"PBKDF2\",\n hash: \"SHA-256\",\n salt: encoder.encode(salt),\n iterations: iterations,\n }, keyMaterial, { name: \"AES-CBC\", length: 256 }, true, // Allow export of the derived key (req for splitting)\n [\"encrypt\", \"decrypt\"]);\n }\n // Split the full key into HMAC and AES keys\n async splitKey(fullKey) {\n const rawKey = new Uint8Array(await this.subtleCrypto.exportKey('raw', fullKey));\n // Split the key into HMAC (first 16 bytes) and AES (last 16 bytes)\n const hmacKey = await this.subtleCrypto.importKey('raw', rawKey.slice(0, 16), { name: 'HMAC', hash: 'SHA-256' }, false, ['sign', 'verify']);\n const aesKey = await this.subtleCrypto.importKey('raw', rawKey.slice(16), { name: 'AES-CBC' }, false, ['encrypt', 'decrypt']);\n return { hmacKey, aesKey };\n }\n // Decode Base64 URL-safe strings\n base64UrlDecode(base64) {\n // assumes URL safe encoding that has + in place of - and _ in place of /\n const base64String = base64.replace(/-/g, '+').replace(/_/g, '/');\n const decodedString = atob(base64String);\n return new Uint8Array([...decodedString].map(c => c.charCodeAt(0)));\n }\n}\n","import pkg from \"../package.json\";\nimport { generateUUID, getNameString } from './utils';\nimport { CryptoA01 } from './crypto';\n// Enum defining message types sent from the viewer to the parent application\nexport var ViewerMessageType;\n(function (ViewerMessageType) {\n ViewerMessageType[\"CONNECTION_SUCCESS\"] = \"CONNECTION_SUCCESS\";\n ViewerMessageType[\"INIT\"] = \"INIT\";\n ViewerMessageType[\"REQUEST_SAVE\"] = \"REQUEST_SAVE\";\n ViewerMessageType[\"REQUEST_CLOSE\"] = \"REQUEST_CLOSE\";\n ViewerMessageType[\"REQUEST_INITIAL_DATA\"] = \"REQUEST_INITIAL_DATA\";\n ViewerMessageType[\"SET_DIRTY\"] = \"SET_DIRTY\";\n ViewerMessageType[\"SEND_CLOSE\"] = \"SEND_CLOSE\";\n ViewerMessageType[\"SEND_EXCEPTION\"] = \"SEND_EXCEPTION\";\n})(ViewerMessageType || (ViewerMessageType = {}));\nvar CommonSdkMessageType;\n(function (CommonSdkMessageType) {\n CommonSdkMessageType[\"INIT_MESSAGE_CHANNEL\"] = \"INIT_MESSAGE_CHANNEL\";\n})(CommonSdkMessageType || (CommonSdkMessageType = {}));\n// Enum defining message types sent from the parent application to the embedded app\nvar ClientMessageType;\n(function (ClientMessageType) {\n ClientMessageType[\"CONNECT\"] = \"CONNECT\";\n ClientMessageType[\"REQUEST_CLOSE\"] = \"REQUEST_CLOSE\";\n ClientMessageType[\"REQUEST_SAVE\"] = \"REQUEST_SAVE\";\n ClientMessageType[\"SAVE_ERROR\"] = \"SAVE_ERROR\";\n ClientMessageType[\"SAVE_SUCCESS\"] = \"SAVE_SUCCESS\";\n ClientMessageType[\"DATA_CHANGE\"] = \"DATA_CHANGE\";\n ClientMessageType[\"FILE_DATA\"] = \"FILE_DATA\";\n ClientMessageType[\"WRITE_FILE_ACK\"] = \"WRITE_FILE_ACK\";\n ClientMessageType[\"READ_FILE_ACK\"] = \"READ_FILE_ACK\";\n ClientMessageType[\"DELETE_FILE_ACK\"] = \"DELETE_FILE_ACK\";\n ClientMessageType[\"LIST_FILES_ACK\"] = \"LIST_FILES_ACK\";\n ClientMessageType[\"INIT_ACK\"] = \"INIT_ACK\";\n ClientMessageType[\"ERROR\"] = \"ERROR\";\n ClientMessageType[\"REFRESH\"] = \"REFRESH\";\n})(ClientMessageType || (ClientMessageType = {}));\n;\nconst ALLOWED_ORIGINS = new Set(getAllowedOrigins());\nconst ALLOWED_DEEP_LINK_PROTOCOLS = new Set([\"dome\", \"intouchapp\"]);\nconst CARD_FS_VERSION = '1.0.0';\nfunction getAllowedOrigins() {\n if (typeof window === 'undefined')\n return [];\n return [\n window.location.origin,\n 'https://dome.so',\n 'https://spaces.intouchapp.com/',\n 'http://localhost:4200',\n 'http://localhost:4201',\n 'null',\n ];\n}\n/**\n * DomeEmbeddedAppSdk:\n * Base SDK class providing methods to send messages to the parent application.\n */\nclass DomeEmbeddedAppSdk {\n constructor() {\n this.targetOrigin = \"*\";\n this.isAppReady = false;\n this.port2 = null;\n this.runtimeHost = \"unknown\"; // Transport/runtime host\n this.parentHostDetails = null;\n this.parentCapabilities = null;\n this.handleDeepLinkClick = (event) => {\n if (this.runtimeHost !== \"webapp\")\n return;\n if (!(event.target instanceof Element))\n return;\n const anchor = event.target.closest(\"a[href]\");\n if (!anchor)\n return;\n const href = anchor.getAttribute(\"href\") ?? \"\";\n if (this.emitDeepLink(href)) {\n event.preventDefault();\n }\n };\n this.detectHost();\n this.setupDeepLinkInterception();\n }\n /**\n * Detects the host (iOS, Android, or Web) and saves it.\n */\n detectHost() {\n if (typeof window.AndroidBridge !== \"undefined\") {\n this.runtimeHost = \"android\";\n }\n else if (typeof window.webkit !== \"undefined\") {\n this.runtimeHost = \"ios\";\n }\n else {\n this.runtimeHost = \"webapp\";\n }\n console.debug(`Detected host: ${this.runtimeHost}`);\n }\n /**\n * Listens for deep link anchor clicks on web to forward them to the parent app.\n */\n setupDeepLinkInterception() {\n if (this.runtimeHost !== \"webapp\")\n return;\n if (typeof document === \"undefined\")\n return;\n document.addEventListener(\"click\", this.handleDeepLinkClick, true);\n }\n /**\n * Sends an OPEN_DEEPLINK message when the href uses an allowed protocol.\n * @returns true if the message was dispatched, false otherwise.\n */\n emitDeepLink(href) {\n if (typeof href !== \"string\" || href.trim() === \"\") {\n console.warn(\"emitDeepLink called without a valid href\");\n return false;\n }\n const protocol = href.split(\":\")[0]?.toLowerCase();\n if (!protocol || !ALLOWED_DEEP_LINK_PROTOCOLS.has(protocol)) {\n return false;\n }\n this.sendMessage(CardMessageType.OPEN_DEEPLINK, { url: href });\n return true;\n }\n updateParentContext(host, capabilities) {\n if (!host && !capabilities) {\n return;\n }\n const base = this.parentHostDetails ?? { type: this.runtimeHost };\n const merged = {\n ...base,\n ...(host ?? {}),\n };\n if (!merged.type) {\n merged.type = this.runtimeHost;\n }\n const nextCapabilities = capabilities ?? this.parentCapabilities ?? merged.capabilities;\n if (capabilities) {\n this.parentCapabilities = capabilities;\n }\n if (nextCapabilities) {\n merged.capabilities = nextCapabilities;\n }\n else {\n delete merged.capabilities;\n }\n this.parentHostDetails = merged;\n this.parentCapabilities = nextCapabilities ?? null;\n console.debug(\"host context and capabilities:\", { host, capabilities });\n }\n getHost() {\n return this.parentHostDetails ?? { type: this.runtimeHost };\n }\n /**\n * Method to send messages to the parent application.\n * Ensures the parent window exists and sends a structured message with type and data.\n * @param type - The type of message being sent\n * @param data - (Optional) payload data for the message\n */\n sendMessage(type, data) {\n const message = { type, data: data ?? null };\n switch (this.runtimeHost) {\n case \"android\":\n window.AndroidBridge?.sendMessage(JSON.stringify(message));\n break;\n case \"ios\":\n if (window?.webkit?.messageHandlers) {\n window.webkit?.messageHandlers.appHandler.postMessage(JSON.stringify(message));\n }\n else {\n console.error(\"webkit.messageHandlers not found\");\n }\n break;\n case \"webapp\":\n if (this.port2) {\n this.port2.postMessage(message);\n }\n else {\n console.error(\"Web connection is not established.\");\n }\n break;\n default:\n console.error(\"Unsupported host, cannot send message.\");\n break;\n }\n console.debug(`Sent message to ${this.runtimeHost}:`, message);\n }\n /**\n * Notifies the parent application that the app is ready, if it hasn’t already.\n */\n sendAppInit() {\n if (!this.isAppReady) {\n this.isAppReady = true;\n this.sendMessage(ViewerMessageType.INIT, { sdk: { ver: pkg.version } });\n }\n }\n /**\n * Safely invokes a function from the handler object if it exists.\n * and logs a warning if the handler is not provided for the given message type.\n *\n * @param eventName - Name of the event method to be invoked from the handler.\n * @param handlerObj - The handler object that contains the message handling methods.\n * @param data - (Optional) The data to be passed to the handler function if invoked.\n */\n safeInvoke(eventName, handlerObj, data) {\n const handler = handlerObj[eventName];\n if (typeof handler === 'function') {\n handler(data);\n }\n else {\n console.warn(`Handler for '${String(eventName)}' is not defined.`);\n }\n }\n // Sets up connection with iframe parent using message channel\n // Call this once only in the lifetime. Should be called\n // _before_ iFrame's onLoad is called (otherwise messaging will\n // not be setup)\n setupParentConnection() {\n return new Promise((resolve, reject) => {\n switch (this.runtimeHost) {\n case \"android\":\n window.receiveFromAndroid = (message) => {\n console.debug(\"Message received from Android:\", message);\n this.handleMessage(message.type, message.data);\n };\n resolve();\n break;\n case \"ios\":\n window.receiveFromIOS = (message) => {\n console.debug(\"Message received from iOS:\", message);\n this.handleMessage(message.type, message.data);\n };\n resolve();\n break;\n case \"webapp\":\n if (this.port2) {\n console.warn(\"Connection already established. Skipping reinitialization.\");\n resolve();\n return;\n }\n const handleMessage = (event) => {\n const { type } = event.data || {};\n if (type !== ClientMessageType.CONNECT)\n return;\n if (event.ports && event.ports.length > 0) {\n this.port2 = event.ports[0];\n this.port2.onmessage = (e) => this.handlePortMessage(e);\n window.removeEventListener(\"message\", handleMessage); // Cleanup\n this.notifyConnectionSuccess();\n resolve();\n }\n };\n // Listen for browser-based `message` events\n window.addEventListener(\"message\", handleMessage);\n // Notify parent to initialize a message channel\n if (window.parent) {\n window.parent.postMessage({ type: CommonSdkMessageType.INIT_MESSAGE_CHANNEL, data: { sdk: { ver: pkg.version } } }, this.targetOrigin);\n }\n else {\n console.error(\"Parent window not available to initialize message channel.\");\n }\n break;\n default:\n console.error(\"Unknown host.\");\n reject(\"Unknown host\");\n }\n });\n }\n // Send CONNECTION_SUCCESS message to parent\n notifyConnectionSuccess() {\n this.sendMessage(ViewerMessageType.CONNECTION_SUCCESS);\n }\n // Handle messages coming over message channel port\n handlePortMessage(event) {\n const { type, data } = event.data || {};\n if (!type)\n return;\n // Delegate to subclass-specific message handler\n this.handleMessage(type, data);\n }\n // Common method for handling messages to be implemented by sub-classes\n handleMessage(type, data) {\n throw new Error(\"Subclasses must implement handleMessage.\");\n }\n}\n/**\n * ViewerSdk:\n * A subclass of DomeEmbeddedAppSdk specifically for document viewer applications.\n * It includes additional methods and properties to manage app interactions.\n */\nexport class ViewerSdk extends DomeEmbeddedAppSdk {\n constructor() {\n super();\n this.handler = null; // Handler instance for client messages\n this.pendingRequests = new Map();\n this.pendingInitAck = null;\n }\n /**\n * Static initialization method to get or create the singleton instance of ViewerSdk.\n * Allows setting the handler during initialization.\n * @param handler - (Optional) Custom handler for different message types\n * @returns The singleton ViewerSdk instance\n */\n static init(handler) {\n console.debug(\"init called\", handler && \"with handler\");\n // Prevent reinitialization if already initialized\n if (ViewerSdk.initialized) {\n console.warn(\"ViewerSdk is already initialized. Skipping initialization.\");\n return ViewerSdk.instance;\n }\n if (!ViewerSdk.instance) {\n ViewerSdk.instance = new ViewerSdk();\n // Initialize parent communication - REQUIRED!\n ViewerSdk.instance.setupParentConnection()\n .then(() => {\n try {\n // Connection established with parent\n ViewerSdk.instance.initializeViewerSdk();\n }\n catch (err) {\n console.error(\"Error in initializeViewerSdk:\", err);\n }\n })\n .catch((err) => {\n console.error(\"init: Error setting up parent connection!\", err);\n console.trace(\"called from:\");\n });\n }\n if (handler) {\n ViewerSdk.instance.setHandler(handler); // Set handler if provided during initialization\n }\n // Mark as initialized\n ViewerSdk.initialized = true;\n return ViewerSdk.instance;\n }\n /**\n * Method to set or update the handler object.\n * @param handler - Custom handler for different message types\n */\n setHandler(handler) {\n this.handler = handler;\n // If INIT_ACK message was received and stored, process it now\n if (this.pendingInitAck) {\n console.debug(\"Processing pending INIT_ACK message after handler is set.\");\n this.safeInvoke(\"onInitialData\", this.handler, this.pendingInitAck);\n this.pendingInitAck = null; // Clear the stored message\n }\n }\n /**\n * Checks if the given permissions string allows reading.\n * @param perms - The permissions string.\n * @returns - True if the permission string includes read access.\n */\n canRead(perms) {\n return !!perms?.includes('r');\n }\n /**\n * Checks if the given permissions string allows writing.\n * @param perms - The permissions string.\n * @returns - True if the permission string includes write access.\n */\n canWrite(perms) {\n return !!perms?.includes('w') || !!perms?.includes('*');\n }\n // Initializes the viewer SDK, setting up the message listener and sending an initial \"ready\" message.\n initializeViewerSdk() {\n console.debug(\"initializing viewer sdk\");\n this.sendAppInit();\n }\n /**\n * Sends a request to the parent application to retrieve initial data.\n */\n requestInitialData() {\n this.sendMessage(ViewerMessageType.REQUEST_INITIAL_DATA);\n }\n /**\n * Sends a request to the parent application to save data.\n * @param doc - payload data to be saved\n * @param isDataDirty - Boolean indicating indicating modified data\n */\n requestSave(doc, isDataDirty) {\n const requestId = generateUUID();\n // Send save request with the generated requestId\n this.sendMessage(ViewerMessageType.REQUEST_SAVE, { doc, isDataDirty, requestId });\n return new Promise((resolve, reject) => {\n this.pendingRequests.set(requestId, resolve);\n this.pendingRequests.set(requestId + '_reject', reject);\n // Timeout if the parent fails to respond in time\n setTimeout(() => {\n if (this.pendingRequests.has(requestId)) {\n this.pendingRequests.delete(requestId);\n this.pendingRequests.delete(requestId + '_reject');\n }\n }, 30000);\n });\n }\n handleOnSave(data) {\n const { requestId, status, message } = data;\n // Check if we have a pending request for this requestId\n const resolve = this.pendingRequests.get(requestId);\n const reject = this.pendingRequests.get(requestId + '_reject');\n if (resolve) {\n // If status is \"error\", reject the promise, otherwise resolve it\n if (status === \"error\") {\n reject?.({ status, message });\n }\n else {\n resolve({ status, message });\n }\n // Clean up\n this.pendingRequests.delete(requestId);\n this.pendingRequests.delete(requestId + '_reject');\n }\n }\n /**\n * Sets the viewer's \"dirty\" state, indicating modified data.\n * @param isDirty - Boolean indicating whether the viewer has modified data\n */\n setDirty(isDirty) {\n this.sendMessage(ViewerMessageType.SET_DIRTY, isDirty);\n }\n /**\n * Sends a close request to the parent, with information on whether the data is dirty.\n * @param doc - Latest document data\n * @param isDataDirty - Boolean indicating indicating modified data\n */\n sendClose(doc, isDataDirty) {\n this.sendMessage(ViewerMessageType.SEND_CLOSE, { doc, isDataDirty });\n }\n /**\n * Sends an exception to parent.\n * @param error - An error object with name and message or an error string\n */\n sendException(error) {\n this.sendMessage(ViewerMessageType.SEND_EXCEPTION, error);\n }\n // Sets up the message listener for viewer to receive messages from the parent.\n handleMessage(type, data) {\n console.debug(\"handleMessage called for:\", type, \"with data:\", data);\n if (type === ClientMessageType.INIT_ACK) {\n this.updateParentContext(data?.host, data?.capabilities);\n }\n if (!this.handler) {\n if (type === ClientMessageType.INIT_ACK) {\n console.warn(\"Handler not set. Storing INIT_ACK message for later processing.\");\n this.pendingInitAck = data; // Save INIT_ACK message\n }\n else {\n console.error(\"Message handler not found for type:\", type);\n }\n return;\n }\n switch (type) {\n case ClientMessageType.INIT_ACK:\n this.safeInvoke(\"onInitialData\", this.handler, data);\n break;\n case ClientMessageType.DATA_CHANGE:\n this.safeInvoke(\"onDataChange\", this.handler, data);\n break;\n case ClientMessageType.REQUEST_CLOSE:\n this.safeInvoke(\"onCloseRequest\", this.handler);\n break;\n case ClientMessageType.REQUEST_SAVE:\n this.safeInvoke(\"onSaveRequest\", this.handler);\n break;\n case ClientMessageType.SAVE_SUCCESS:\n this.handleOnSave(data);\n break;\n case ClientMessageType.SAVE_ERROR:\n this.handleOnSave(data);\n break;\n default:\n console.warn(`No handler found for message type: ${type}`);\n }\n }\n}\nViewerSdk.initialized = false;\n// Card SDK\n// Enum defining message types sent from the card to the parent application\nexport var CardMessageType;\n(function (CardMessageType) {\n CardMessageType[\"APP_READY\"] = \"APP_READY\";\n CardMessageType[\"INIT\"] = \"INIT\";\n CardMessageType[\"READ_FILE\"] = \"READ_FILE\";\n CardMessageType[\"WRITE_FILE\"] = \"WRITE_FILE\";\n CardMessageType[\"DELETE_FILE\"] = \"DELETE_FILE\";\n CardMessageType[\"LIST_FILES\"] = \"LIST_FILES\";\n CardMessageType[\"FILE_DIRTY\"] = \"FILE_DIRTY\";\n CardMessageType[\"OPEN_DEEPLINK\"] = \"OPEN_DEEPLINK\";\n})(CardMessageType || (CardMessageType = {}));\n;\nclass CardFsCache {\n constructor(cardIuid, containerIuid) {\n this.cardIuid = cardIuid;\n this.containerIuid = containerIuid;\n this.openPromise = null;\n }\n isSupported() {\n return typeof indexedDB !== \"undefined\";\n }\n async openDb() {\n if (!this.isSupported())\n return null;\n if (!this.openPromise) {\n this.openPromise = new Promise((resolve) => {\n this.openWithVersion(CardFsCache.DB_VERSION, resolve);\n });\n }\n return this.openPromise;\n }\n openWithVersion(version, resolve) {\n let infoAction = \"ensure\";\n const request = indexedDB.open(this.cardIuid, version);\n request.onupgradeneeded = (event) => {\n infoAction = (event.oldVersion || 0) === 0 ? \"create\" : \"ensure\";\n this.configureStores(request.result);\n };\n request.onsuccess = () => {\n const db = request.result;\n if (!this.hasRequiredStores(db)) {\n const nextVersion = db.version + 1;\n db.close();\n this.openWithVersion(nextVersion, resolve);\n return;\n }\n this.updateStoresMetadata(db, infoAction === \"ensure\")\n .catch(() => undefined)\n .finally(() => resolve(db));\n };\n request.onerror = () => resolve(null);\n }\n configureStores(db) {\n if (!db.objectStoreNames.contains(CardFsCache.DATA_STORE)) {\n db.createObjectStore(CardFsCache.DATA_STORE);\n }\n if (!db.objectStoreNames.contains(CardFsCache.NAME_LOOKUP_STORE)) {\n db.createObjectStore(CardFsCache.NAME_LOOKUP_STORE);\n }\n if (!db.objectStoreNames.contains(CardFsCache.INFO_STORE)) {\n db.createObjectStore(CardFsCache.INFO_STORE);\n }\n }\n hasRequiredStores(db) {\n const stores = db.objectStoreNames;\n return (stores.contains(CardFsCache.DATA_STORE) &&\n stores.contains(CardFsCache.NAME_LOOKUP_STORE) &&\n stores.contains(CardFsCache.INFO_STORE));\n }\n static nowMicros() {\n return Math.trunc(Date.now() * 1000);\n }\n updateStoresMetadata(db, preserveExistingInfoTs) {\n return Promise.all([\n this.ensureStoreVersion(db, CardFsCache.DATA_STORE),\n this.ensureStoreVersion(db, CardFsCache.NAME_LOOKUP_STORE),\n this.updateCardInfo(db, preserveExistingInfoTs),\n ]).then(() => undefined);\n }\n ensureStoreVersion(db, storeName) {\n if (!db.objectStoreNames.contains(storeName)) {\n return Promise.resolve();\n }\n return new Promise((resolve) => {\n try {\n const tx = db.transaction(storeName, \"readwrite\");\n const store = tx.objectStore(storeName);\n const finalize = () => resolve();\n tx.oncomplete = finalize;\n tx.onerror = finalize;\n tx.onabort = finalize;\n store.put(CARD_FS_VERSION, CardFsCache.STORE_VERSION_KEY);\n }\n catch {\n resolve();\n }\n });\n }\n async updateCardInfo(db, preserveExistingTs) {\n if (!db.objectStoreNames.contains(CardFsCache.INFO_STORE)) {\n return;\n }\n const existingContainer = await this.readInfoValue(db, \"container_iuid\");\n const existingTs = preserveExistingTs ? await this.readInfoValue(db, \"ts_c\") : undefined;\n const containerValue = this.containerIuid ?? existingContainer ?? null;\n const timestampValue = preserveExistingTs && existingTs ? existingTs : CardFsCache.nowMicros();\n await Promise.all([\n this.writeInfoValue(db, \"container_iuid\", containerValue),\n this.writeInfoValue(db, \"ts_c\", timestampValue),\n ]).catch(() => undefined);\n }\n readInfoValue(db, key) {\n return new Promise((resolve) => {\n try {\n const tx = db.transaction(CardFsCache.INFO_STORE, \"readonly\");\n const store = tx.objectStore(CardFsCache.INFO_STORE);\n const request = store.get(key);\n request.onsuccess = () => resolve(request.result);\n request.onerror = () => resolve(undefined);\n }\n catch {\n resolve(undefined);\n }\n });\n }\n writeInfoValue(db, key, value) {\n return new Promise((resolve) => {\n try {\n const tx = db.transaction(CardFsCache.INFO_STORE, \"readwrite\");\n const store = tx.objectStore(CardFsCache.INFO_STORE);\n const finalize = () => resolve();\n tx.oncomplete = finalize;\n tx.onerror = finalize;\n tx.onabort = finalize;\n store.put(value, key);\n }\n catch {\n resolve();\n }\n });\n }\n keyFor(suffix) {\n return suffix;\n }\n static normalizeName(name) {\n if (typeof name !== \"string\")\n return null;\n const trimmed = name.trim();\n return trimmed ? trimmed : null;\n }\n async put(key, value) {\n const db = await this.openDb();\n if (!db)\n return;\n await new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.DATA_STORE, \"readwrite\");\n const store = tx.objectStore(CardFsCache.DATA_STORE);\n store.put(value, key).onsuccess = () => resolve();\n tx.oncomplete = () => resolve();\n tx.onerror = () => resolve();\n tx.onabort = () => resolve();\n });\n }\n async get(key) {\n const db = await this.openDb();\n if (!db)\n return undefined;\n return new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.DATA_STORE, \"readonly\");\n const store = tx.objectStore(CardFsCache.DATA_STORE);\n const request = store.get(key);\n request.onsuccess = () => resolve(request.result);\n request.onerror = () => resolve(undefined);\n });\n }\n async delete(key) {\n const db = await this.openDb();\n if (!db)\n return;\n await new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.DATA_STORE, \"readwrite\");\n const store = tx.objectStore(CardFsCache.DATA_STORE);\n store.delete(key).onsuccess = () => resolve();\n tx.oncomplete = () => resolve();\n tx.onerror = () => resolve();\n tx.onabort = () => resolve();\n });\n }\n static async hashName(name) {\n const cryptoRef = typeof globalThis !== 'undefined' ? globalThis.crypto : undefined;\n if (!cryptoRef?.subtle?.digest) {\n throw new Error('CardFS name hashing requires SubtleCrypto support');\n }\n const encoded = CardFsCache.encodeText(name);\n const digest = await cryptoRef.subtle.digest('SHA-256', encoded);\n return CardFsCache.bufferToBase64(digest);\n }\n static encodeText(value) {\n if (typeof TextEncoder !== 'undefined') {\n return new TextEncoder().encode(value).buffer;\n }\n const result = new Uint8Array(value.length);\n for (let i = 0; i < value.length; i++) {\n result[i] = value.charCodeAt(i);\n }\n return result.buffer;\n }\n static bufferToBase64(buffer) {\n let binary = '';\n const bytes = new Uint8Array(buffer);\n for (let i = 0; i < bytes.length; i++) {\n binary += String.fromCharCode(bytes[i]);\n }\n return btoa(binary);\n }\n async getIuidForName(name) {\n const normalized = CardFsCache.normalizeName(name);\n if (!normalized)\n return undefined;\n const db = await this.openDb();\n if (!db)\n return undefined;\n const hashed = await CardFsCache.hashName(normalized);\n return new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.NAME_LOOKUP_STORE, \"readonly\");\n const store = tx.objectStore(CardFsCache.NAME_LOOKUP_STORE);\n const request = store.get(hashed);\n request.onsuccess = () => resolve(request.result);\n request.onerror = () => resolve(undefined);\n });\n }\n async upsertNameLookup(name, iuid) {\n const normalized = CardFsCache.normalizeName(name);\n if (!normalized)\n return;\n const db = await this.openDb();\n if (!db)\n return;\n const hashed = await CardFsCache.hashName(normalized);\n await new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.NAME_LOOKUP_STORE, \"readwrite\");\n const store = tx.objectStore(CardFsCache.NAME_LOOKUP_STORE);\n store.put(iuid, hashed);\n const cursorRequest = store.openCursor();\n cursorRequest.onsuccess = (event) => {\n const cursor = event.target.result;\n if (!cursor)\n return;\n if (cursor.key !== hashed && cursor.value === iuid) {\n cursor.delete();\n }\n cursor.continue();\n };\n tx.oncomplete = () => resolve();\n tx.onerror = () => resolve();\n tx.onabort = () => resolve();\n });\n }\n async deleteNameLookupByName(name) {\n const normalized = CardFsCache.normalizeName(name);\n if (!normalized)\n return;\n const db = await this.openDb();\n if (!db)\n return;\n const hashed = await CardFsCache.hashName(normalized);\n await new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.NAME_LOOKUP_STORE, \"readwrite\");\n const store = tx.objectStore(CardFsCache.NAME_LOOKUP_STORE);\n store.delete(hashed);\n tx.oncomplete = () => resolve();\n tx.onerror = () => resolve();\n tx.onabort = () => resolve();\n });\n }\n async deleteNameLookupByIuid(iuid) {\n if (!iuid)\n return;\n const db = await this.openDb();\n if (!db)\n return;\n await new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.NAME_LOOKUP_STORE, \"readwrite\");\n const store = tx.objectStore(CardFsCache.NAME_LOOKUP_STORE);\n const request = store.openCursor();\n request.onsuccess = (event) => {\n const cursor = event.target.result;\n if (!cursor)\n return;\n if (cursor.value === iuid) {\n cursor.delete();\n }\n cursor.continue();\n };\n tx.oncomplete = () => resolve();\n tx.onerror = () => resolve();\n tx.onabort = () => resolve();\n });\n }\n static estimateSize(data) {\n if (data == null)\n return 0;\n if (typeof Blob !== \"undefined\" && data instanceof Blob)\n return data.size;\n if (data instanceof ArrayBuffer)\n return data.byteLength;\n if (ArrayBuffer.isView(data))\n return data.byteLength;\n if (typeof data === \"string\")\n return new Blob([data]).size;\n try {\n return new Blob([JSON.stringify(data)]).size;\n }\n catch {\n return 0;\n }\n }\n async cacheDocument(doc, data) {\n if (!doc?.iuid)\n return;\n await this.put(this.keyFor(`${doc.iuid}_object`), doc);\n const normalizedName = CardFsCache.normalizeName(doc.name);\n if (normalizedName) {\n await this.upsertNameLookup(normalizedName, doc.iuid);\n }\n if (data === undefined) {\n await this.delete(this.keyFor(`${doc.iuid}_data`));\n return;\n }\n const size = CardFsCache.estimateSize(data);\n if (size <= CardFsCache.MAX_DATA_BYTES) {\n await this.put(this.keyFor(`${doc.iuid}_data`), data);\n }\n else {\n await this.delete(this.keyFor(`${doc.iuid}_data`));\n }\n }\n async getByName(name) {\n const normalizedName = CardFsCache.normalizeName(name);\n if (!normalizedName)\n return null;\n const iuid = await this.getIuidForName(normalizedName);\n if (!iuid)\n return null;\n const object = await this.get(this.keyFor(`${iuid}_object`));\n if (!object)\n return null;\n const data = await this.get(this.keyFor(`${iuid}_data`));\n return { iuid, object, data };\n }\n async getByIuid(iuid) {\n if (!iuid)\n return null;\n const object = await this.get(this.keyFor(`${iuid}_object`));\n if (!object)\n return null;\n const data = await this.get(this.keyFor(`${iuid}_data`));\n return { iuid, object, data };\n }\n async deleteByName(name) {\n const entry = await this.getByName(name);\n await this.deleteNameLookupByName(name);\n if (!entry)\n return;\n await this.delete(this.keyFor(`${entry.iuid}_object`));\n await this.delete(this.keyFor(`${entry.iuid}_data`));\n }\n async deleteByIuid(iuid, name) {\n if (name) {\n await this.deleteNameLookupByName(name);\n }\n await this.deleteNameLookupByIuid(iuid);\n await this.delete(this.keyFor(`${iuid}_object`));\n await this.delete(this.keyFor(`${iuid}_data`));\n }\n async getAllCachedObjects() {\n const db = await this.openDb();\n if (!db)\n return [];\n return new Promise((resolve) => {\n const results = [];\n const tx = db.transaction(CardFsCache.DATA_STORE, \"readonly\");\n const store = tx.objectStore(CardFsCache.DATA_STORE);\n const request = store.openCursor();\n request.onsuccess = (event) => {\n const cursor = event.target.result;\n if (!cursor) {\n resolve(results);\n return;\n }\n const key = cursor.key;\n if (typeof key === \"string\" && key.endsWith(\"_object\")) {\n results.push(cursor.value);\n }\n cursor.continue();\n };\n request.onerror = () => resolve(results);\n });\n }\n}\nCardFsCache.DB_VERSION = 2;\nCardFsCache.DATA_STORE = \"cardfs\";\nCardFsCache.NAME_LOOKUP_STORE = \"cardfs_name_iuid_lookup\";\nCardFsCache.INFO_STORE = \"info\";\nCardFsCache.STORE_VERSION_KEY = \"ver\";\nCardFsCache.MAX_DATA_BYTES = 5 * 1024 * 1024;\n/**\n * Use CardSdk to create webapp cards\n */\nexport class CardSdk extends DomeEmbeddedAppSdk {\n resolveCardFsTarget(target, operation) {\n const normalized = typeof target === \"string\" ? { name: target } : (target ?? {});\n const name = typeof normalized.name === \"string\" ? normalized.name.trim() : undefined;\n const iuid = typeof normalized.iuid === \"string\" ? normalized.iuid.trim() : undefined;\n if (!name && !iuid) {\n throw new Error(`cardsFS.${operation} requires a file name or document iuid`);\n }\n return { name, iuid };\n }\n describeCardFsTarget(target) {\n if (target.name && target.iuid) {\n return `\"${target.name}\" (iuid ${target.iuid})`;\n }\n if (target.name) {\n return `\"${target.name}\"`;\n }\n if (target.iuid) {\n return `iuid ${target.iuid}`;\n }\n return \"document\";\n }\n buildCardFsMessagePayload(target, extra) {\n return {\n ...(target.name ? { name: target.name } : {}),\n ...(target.iuid ? { iuid: target.iuid } : {}),\n ...(extra ?? {}),\n };\n }\n getCardIuid() {\n return this.dataStore?.iuid || null;\n }\n ensureCardFsCache() {\n if (!this.shouldUseCardFsFallback()) {\n return null;\n }\n if (!this.cardFsCache) {\n const cardIuid = this.getCardIuid();\n if (cardIuid) {\n this.cardFsCache = new CardFsCache(cardIuid, this.containerIuid);\n }\n }\n return this.cardFsCache;\n }\n supportsParentCardFs() {\n return !!this.parentCapabilities?.card_fs;\n }\n shouldUseCardFsFallback() {\n return !this.supportsParentCardFs();\n }\n constructor() {\n super();\n this.handler = null; // Handler instance for client messages\n this.accessToken = '';\n this.fileReadResolvers = new Map();\n this.fileWriteResolvers = new Map();\n // Track in-flight FS operations by messageId so we can settle promises on callback\n this.fsReadRequests = new Map();\n this.fsWriteRequests = new Map();\n this.cardFsCache = null;\n this.pendingAcks = new Map();\n // Sets up the message listener for cards to receive messages from the parent.\n this.handleMessage = (type, data) => {\n if (type === ClientMessageType.INIT_ACK) {\n this.updateParentContext(data?.host, data?.capabilities);\n }\n if (!this.handler) {\n throw new Error(\"Message handler not found!\");\n }\n // Check for ACK response with messageId\n const messageId = data?.messageId;\n if (messageId && this.pendingAcks.has(messageId)) {\n const { resolve, timeout } = this.pendingAcks.get(messageId);\n clearTimeout(timeout);\n this.pendingAcks.delete(messageId);\n resolve(data);\n return;\n }\n switch (type) {\n case ClientMessageType.INIT_ACK:\n // Parent sent INIT_ACK\n console.debug(\"CardSdk: INIT_ACK received\");\n this.dataStore.kw1 = data.key_wa1;\n this.dataStore.iuid = data.iuid;\n if (data.iuid) {\n if (this.shouldUseCardFsFallback()) {\n this.cardFsCache = new CardFsCache(data.iuid, this.containerIuid);\n }\n else {\n this.cardFsCache = null;\n }\n }\n else if (!this.shouldUseCardFsFallback()) {\n this.cardFsCache = null;\n }\n try {\n this.cryptoA01.decrypt(this.dataStore.denc, data.key_wa1 + this.dataStore.kw2, data.iuid)\n .then((decData) => {\n console.debug(\"CardSdk: INIT_ACK: decrypted data \", decData);\n const decryptedData = JSON.parse(decData);\n const decryptedContainerIuid = decryptedData?.container?.iuid;\n if (decryptedContainerIuid) {\n this.containerIuid = decryptedContainerIuid;\n if (this.shouldUseCardFsFallback() && this.dataStore?.iuid) {\n this.cardFsCache = new CardFsCache(this.dataStore.iuid, this.containerIuid);\n }\n }\n const apiToken = typeof decryptedData?.api_token === \"string\" ? decryptedData.api_token.trim() : \"\";\n if (apiToken) {\n this.accessToken = apiToken;\n console.debug(\"CardSdk: Stored API token from INIT_ACK payload\");\n }\n else {\n console.warn(\"CardSdk: INIT_ACK payload missing api_token; fallback APIs may fail without auth\");\n }\n if (this.handler)\n this.safeInvoke(\"onInit\", this.handler, { ...decryptedData, ui: data.ui });\n // no need for orig enc data.. free to delete it\n delete this.dataStore.denc;\n })\n .catch((err) => {\n console.error(\"Final decrypt error\", err);\n throw err;\n });\n }\n catch (err) {\n console.error(\"Decryption failed!\", err);\n this.sendEventError('dec2_failed', err.message);\n }\n break;\n case ClientMessageType.FILE_DATA: {\n const responseId = data?.messageId;\n if (responseId && this.fsReadRequests.has(responseId)) {\n // cardsFS.read payload from parent (cached or fresh)\n const { messageId: _ignored, ...payload } = data || {};\n this.handleFsReadDataMessage(responseId, payload);\n return;\n }\n const fileName = data?.name;\n if (fileName && this.fileReadResolvers.has(fileName)) {\n const resolver = this.fileReadResolvers.get(fileName);\n this.fileReadResolvers.delete(fileName);\n resolver(data);\n }\n else {\n console.warn(\"CardSdk: FILE_DATA received but no resolver found for\", fileName);\n }\n break;\n }\n case ClientMessageType.DATA_CHANGE:\n this.safeInvoke(\"onFileChange\", this.handler, data);\n case ClientMessageType.SAVE_SUCCESS: {\n const responseId = data?.messageId;\n if (responseId && this.fsWriteRequests.has(responseId)) {\n // cardsFS write/list/delete success routed by messageId\n this.handleFsWriteSuccess(responseId, data);\n return;\n }\n const savedName = data?.name;\n if (savedName && this.fileWriteResolvers.has(savedName)) {\n const { resolve } = this.fileWriteResolvers.get(savedName);\n this.fileWriteResolvers.delete(savedName);\n resolve();\n }\n else {\n console.warn(\"CardSdk: SAVE_SUCCESS received but no resolver found for\", savedName);\n }\n break;\n }\n case ClientMessageType.SAVE_ERROR: {\n const responseId = data?.messageId;\n if (responseId && this.fsWriteRequests.has(responseId)) {\n // cardsFS write/list/delete failure routed by messageId\n this.handleFsWriteError(responseId, data);\n return;\n }\n const failedName = data?.name;\n if (failedName && this.fileWriteResolvers.has(failedName)) {\n const { reject } = this.fileWriteResolvers.get(failedName);\n this.fileWriteResolvers.delete(failedName);\n reject(new Error(data?.message || 'Unknown write error'));\n }\n else {\n console.warn(\"CardSdk: SAVE_ERROR received but no resolver found for\", failedName);\n }\n break;\n }\n case ClientMessageType.ERROR: {\n const responseId = data?.messageId;\n if (responseId) {\n const message = data?.message || 'Unknown error';\n if (this.fsReadRequests.has(responseId)) {\n // cardsFS read error surfaced by the parent\n this.failFsReadRequest(responseId, new Error(message));\n return;\n }\n if (this.fsWriteRequests.has(responseId)) {\n // cardsFS write/delete/list error surfaced by the parent\n this.failFsWriteRequest(responseId, new Error(message));\n return;\n }\n }\n // Parent sent an ERROR\n this.safeInvoke(\"onError\", this.handler, data);\n break;\n }\n case ClientMessageType.REFRESH:\n // Asking for UI refresh\n this.safeInvoke(\"onRefreshRequest\", this.handler, data);\n break;\n default:\n console.warn(`No handler found for message type: ${type}`);\n }\n };\n this.cryptoA01 = new CryptoA01();\n this.cardsFS = {\n read: (target, onUpdate) => this.cardsFsRead(target, onUpdate),\n write: (target, fileData, onResult) => this.cardsFsWrite(target, fileData, onResult),\n delete: (target, onResult) => this.cardsFsDelete(target, onResult),\n list: (onResult) => this.cardsFsList(onResult),\n };\n console.debug(\"CardSdk::constructor: done\");\n }\n /**\n * Static initialization method to get or create the singleton instance of CardSdk.\n * @param secret - The card developer secret key\n * @param handler - (Optional) Handler for different events emitted by the SDK\n * @returns The singleton CardSdk instance\n */\n static async init(secret, handler, options) {\n try {\n console.debug(\"CardSdk::init\");\n if (!CardSdk.instance) {\n CardSdk.instance = new CardSdk();\n // Initialize parent communication - REQUIRED!\n CardSdk.instance.setupParentConnection()\n .then(() => {\n // Connection established with parents..\n // Initialize SDK in async\n CardSdk.instance.initializeCardSdk(secret);\n })\n .catch((err) => {\n console.error(err);\n });\n }\n else {\n return CardSdk.instance;\n }\n // Setup handlers\n if (handler) {\n CardSdk.instance.setHandler(handler); // Set handler if provided during initialization\n }\n return CardSdk.instance;\n }\n catch (err) {\n console.error(\"CardSdk: Unrecoverable error in init\", err);\n throw err;\n }\n }\n /**\n * Method to set or update the handler object.\n * @param handler - Custom handler for different message types\n */\n setHandler(handler) {\n this.handler = handler;\n }\n /**\n * Sends a deep link request to the parent directly from the card.\n */\n openDeepLink(href) {\n if (!this.emitDeepLink(href)) {\n console.warn(\"openDeepLink ignored; provide a dome:// or intouchapp:// href\");\n }\n }\n // Function to initialize SDK after instance is created\n async initializeCardSdk(secret) {\n let TAG = \"CardSdk::initializeCardSdk:\";\n try {\n console.debug(TAG, \"enter\");\n if (!secret) {\n throw new Error(\"Invalid secret\");\n }\n // Get data from HTML\n const data_af1 = window.IT_DATA_AF1;\n if (!data_af1) {\n console.error(TAG, \"No data\");\n throw new Error('No data');\n }\n const url = window.location.href;\n console.debug(TAG, \"url:\", url);\n const urlObject = new URL(url);\n // Take the string between /wa/ and / \n let url_part = urlObject.pathname.split(\"/wa/\").filter(Boolean)[1].split(\"/\")[0];\n const ss = url_part.split('').reverse().join('').substring(4, 25);\n console.debug(TAG, \"ss:\", ss);\n if (!ss) {\n throw new Error('Cannot decrypt (1)');\n }\n const decData = await this.cryptoA01.decrypt(data_af1, secret, ss);\n try {\n const dataFromServer = JSON.parse(decData);\n console.debug(\"CardSdk: dataFromServer:\", dataFromServer);\n if (!dataFromServer.ite) {\n throw new Error(\"Invalid data\");\n }\n this.dataStore = {\n 'denc': dataFromServer.d,\n 'kw2': dataFromServer.kw2\n };\n CardSdk.instance.sendInit(dataFromServer.ite);\n }\n catch (err) {\n console.error(\"Initial Decryption failed (2):\", err);\n throw err;\n }\n }\n catch (err) {\n console.error(TAG, \"Init failed:\", err);\n this.sendEventError('init_failed', err.message);\n }\n }\n async sendInit(token) {\n this.sendMessage(CardMessageType.INIT, { 'token': token, sdk: { ver: pkg.version } });\n }\n sendMessageWithAck(type, data, ackType, timeoutMs = 15000, onMessageId) {\n const messageId = crypto.randomUUID();\n if (onMessageId) {\n try {\n onMessageId(messageId);\n }\n catch (err) {\n return Promise.reject(err);\n }\n }\n return new Promise((resolve, reject) => {\n const timeout = setTimeout(() => {\n this.pendingAcks.delete(messageId);\n reject(new Error(`${ackType} not received in time`));\n }, timeoutMs);\n this.pendingAcks.set(messageId, { resolve, reject, timeout });\n this.sendMessage(type, { ...data, messageId });\n });\n }\n // cardsSdk.cardsFS.read implementation - resolves on first response, optional onUpdate for subsequent payloads\n cardsFsRead(targetInput, onUpdate) {\n let target;\n try {\n target = this.resolveCardFsTarget(targetInput, \"read\");\n }\n catch (err) {\n return Promise.reject(err);\n }\n if (this.shouldUseCardFsFallback()) {\n console.debug(\"cardsFS.read using fallback implementation for\", target);\n return this.cardsFsReadFallback(target, undefined, onUpdate);\n }\n console.debug(\"cardsFS.read delegating to parent for\", target);\n return new Promise((resolve, reject) => {\n let registeredMessageId = null;\n const targetLabel = this.describeCardFsTarget(target);\n const registerRequest = (messageId) => {\n registeredMessageId = messageId;\n // Track this read so FILE_DATA updates can resolve the promise or stream via onUpdate\n const request = {\n name: targetLabel,\n onUpdate,\n resolve,\n reject,\n hasResolved: false,\n };\n request.noResponseTimeout = setTimeout(() => {\n this.failFsReadRequest(messageId, new Error(`cardsFS.read timed out for ${targetLabel}`));\n }, CardSdk.FS_RESPONSE_TIMEOUT_MS);\n this.fsReadRequests.set(messageId, request);\n };\n // Parent ACK provides a messageId that subsequent FILE_DATA responses will reuse\n this.sendMessageWithAck(CardMessageType.READ_FILE, this.buildCardFsMessagePayload(target), ClientMessageType.READ_FILE_ACK, CardSdk.CARD_FS_ACK_TIMEOUT_MS, registerRequest).catch((err) => {\n const error = err instanceof Error ? err : new Error(String(err));\n if (registeredMessageId) {\n this.failFsReadRequest(registeredMessageId, error);\n }\n else {\n reject(error);\n }\n });\n });\n }\n // cardsSdk.cardsFS.write - resolves when parent confirms write\n cardsFsWrite(targetInput, fileData, onResult) {\n let target;\n try {\n target = this.resolveCardFsTarget(targetInput, \"write\");\n }\n catch (err) {\n return Promise.reject(err);\n }\n if (this.shouldUseCardFsFallback()) {\n console.debug(\"cardsFS.write using fallback implementation for\", target);\n return this.cardsFsWriteFallback(target, fileData)\n .then((result) => {\n try {\n onResult?.(result);\n }\n catch (callbackErr) {\n console.error(\"cardsFS.write fallback callback threw\", callbackErr);\n }\n return result;\n });\n }\n console.debug(\"cardsFS.write delegating to parent for\", target);\n return new Promise((resolve, reject) => {\n let registeredMessageId = null;\n const targetLabel = this.describeCardFsTarget(target);\n const registerRequest = (messageId) => {\n registeredMessageId = messageId;\n const request = {\n name: targetLabel,\n onResult,\n resolve,\n reject,\n timeout: setTimeout(() => {\n this.failFsWriteRequest(messageId, new Error(`cardsFS.write timed out for ${targetLabel}`));\n }, CardSdk.FS_RESPONSE_TIMEOUT_MS),\n };\n this.fsWriteRequests.set(messageId, request);\n };\n this.sendMessageWithAck(CardMessageType.WRITE_FILE, this.buildCardFsMessagePayload(target, { data: fileData }), ClientMessageType.WRITE_FILE_ACK, CardSdk.CARD_FS_ACK_TIMEOUT_MS, registerRequest).catch((err) => {\n const error = err instanceof Error ? err : new Error(String(err));\n if (registeredMessageId) {\n this.failFsWriteRequest(registeredMessageId, error);\n }\n else {\n reject(error);\n }\n });\n });\n }\n // cardsSdk.cardsFS.delete - simple request/ack flow\n cardsFsDelete(targetInput, onResult) {\n let target;\n try {\n target = this.resolveCardFsTarget(targetInput, \"delete\");\n }\n catch (err) {\n return Promise.reject(err);\n }\n if (this.shouldUseCardFsFallback()) {\n console.debug(\"cardsFS.delete using fallback implementation for\", target);\n return this.cardsFsDeleteFallback(target)\n .then((result) => {\n try {\n onResult?.(result);\n }\n catch (callbackErr) {\n console.error(\"cardsFS.delete fallback callback threw\", callbackErr);\n }\n return result;\n });\n }\n console.debug(\"cardsFS.delete delegating to parent for\", target);\n return new Promise((resolve, reject) => {\n this.sendMessageWithAck(CardMessageType.DELETE_FILE, this.buildCardFsMessagePayload(target), ClientMessageType.DELETE_FILE_ACK, CardSdk.CARD_FS_ACK_TIMEOUT_MS)\n .then((data) => {\n const { messageId: _ignored, ...result } = data || {};\n onResult?.(result);\n resolve(result);\n })\n .catch((err) => {\n reject(err instanceof Error ? err : new Error(String(err)));\n });\n });\n }\n // cardsSdk.cardsFS.list - returns metadata list provided by parent\n cardsFsList(onResult) {\n if (this.shouldUseCardFsFallback()) {\n console.debug(\"cardsFS.list using fallback implementation\");\n return this.cardsFsListFallback()\n .then((result) => {\n try {\n onResult?.(result);\n }\n catch (callbackErr) {\n console.error(\"cardsFS.list fallback callback threw\", callbackErr);\n }\n return result;\n });\n }\n console.debug(\"cardsFS.list delegating to parent\");\n return new Promise((resolve, reject) => {\n this.sendMessageWithAck(CardMessageType.LIST_FILES, {}, ClientMessageType.LIST_FILES_ACK, CardSdk.CARD_FS_ACK_TIMEOUT_MS)\n .then((data) => {\n const { messageId: _ignored, ...result } = data || {};\n onResult?.(result);\n resolve(result);\n })\n .catch((err) => {\n reject(err instanceof Error ? err : new Error(String(err)));\n });\n });\n }\n // Handle FILE_DATA updates (cached + fresh) for cardsFS.read\n handleFsReadDataMessage(messageId, payload) {\n const request = this.fsReadRequests.get(messageId);\n if (!request)\n return;\n if (request.noResponseTimeout) {\n clearTimeout(request.noResponseTimeout);\n request.noResponseTimeout = undefined;\n }\n if (typeof request.onUpdate === \"function\") {\n try {\n request.onUpdate(payload);\n }\n catch (err) {\n console.error(\"cardsFS.read callback threw\", err);\n }\n }\n if (!request.hasResolved) {\n // Resolve the original promise only once (typically cached data or the first fresh payload)\n request.hasResolved = true;\n request.resolve(payload);\n }\n if (request.cleanupTimeout) {\n clearTimeout(request.cleanupTimeout);\n }\n request.cleanupTimeout = setTimeout(() => {\n this.clearFsReadRequest(messageId);\n }, CardSdk.FS_READ_RETENTION_MS);\n }\n // Remove read request bookkeeping and clear timers\n clearFsReadRequest(messageId) {\n const request = this.fsReadRequests.get(messageId);\n if (!request)\n return undefined;\n if (request.noResponseTimeout) {\n clearTimeout(request.noResponseTimeout);\n }\n if (request.cleanupTimeout) {\n clearTimeout(request.cleanupTimeout);\n }\n this.fsReadRequests.delete(messageId);\n return request;\n }\n failFsReadRequest(messageId, error) {\n const request = this.clearFsReadRequest(messageId);\n if (request) {\n request.reject(error);\n }\n }\n // Remove write request bookkeeping\n clearFsWriteRequest(messageId) {\n const request = this.fsWriteRequests.get(messageId);\n if (!request)\n return undefined;\n clearTimeout(request.timeout);\n this.fsWriteRequests.delete(messageId);\n return request;\n }\n failFsWriteRequest(messageId, error) {\n const request = this.clearFsWriteRequest(messageId);\n if (request) {\n request.reject(error);\n }\n }\n // Resolve write/list/delete promise with payload and invoke optional callback\n handleFsWriteSuccess(messageId, payload) {\n const request = this.clearFsWriteRequest(messageId);\n if (!request)\n return;\n const { messageId: _ignored, ...result } = payload || {};\n if (typeof request.onResult === \"function\") {\n try {\n request.onResult(result);\n }\n catch (err) {\n console.error(\"cardsFS.write callback threw\", err);\n }\n }\n request.resolve(result);\n }\n handleFsWriteError(messageId, payload) {\n const request = this.clearFsWriteRequest(messageId);\n if (!request)\n return;\n const errorMessage = payload?.message || 'Unknown write error';\n const error = payload instanceof Error ? payload : new Error(errorMessage);\n request.reject(error);\n }\n async cardsFsReadFallback(target, requestId, onUpdate) {\n if (!this.shouldUseCardFsFallback()) {\n throw new Error(\"cardsFS.read fallback is disabled because parent supports card_fs\");\n }\n const cardIuid = this.getCardIuid();\n if (!cardIuid) {\n throw new Error(\"cardsFS.read fallback failed: card not initialized\");\n }\n const cache = this.ensureCardFsCache();\n let firstPayload = null;\n const targetLabel = this.describeCardFsTarget(target);\n const emit = (object, data, fromCache, explicitName, explicitIuid) => {\n if (!object)\n return;\n const payloadName = explicitName ?? target.name ?? object?.name ?? target.iuid ?? \"document\";\n const payloadIuid = explicitIuid ?? object?.iuid ?? target.iuid ?? null;\n const messagePayload = {\n name: payloadName,\n iuid: payloadIuid,\n object,\n data,\n from_cache: fromCache,\n };\n if (requestId && this.fsReadRequests.has(requestId)) {\n this.handleFsReadDataMessage(requestId, messagePayload);\n }\n else if (typeof onUpdate === \"function\") {\n try {\n onUpdate(messagePayload);\n }\n catch (err) {\n console.error(\"cardsFS.read fallback callback threw\", err);\n }\n }\n if (!firstPayload) {\n firstPayload = messagePayload;\n }\n };\n if (cache) {\n try {\n let cached = null;\n if (target.iuid) {\n cached = await cache.getByIuid(target.iuid);\n }\n if (!cached && target.name) {\n cached = await cache.getByName(target.name);\n }\n if (cached?.object) {\n emit(cached.object, cached.data, true, cached.object?.name ?? target.name, cached.iuid);\n }\n }\n catch (err) {\n console.warn(\"cardsFS.read cache lookup failed\", err);\n }\n }\n try {\n const freshPayload = await this.fetchDocumentPayload(cardIuid, target);\n if (freshPayload) {\n await cache?.cacheDocument(freshPayload.object, freshPayload.data);\n emit(freshPayload.object, freshPayload.data, false, freshPayload.object?.name, freshPayload.object?.iuid);\n }\n }\n catch (err) {\n if (!firstPayload) {\n throw err;\n }\n console.warn(\"cardsFS.read fresh fetch failed\", err);\n }\n if (!firstPayload) {\n throw new Error(`cardsFS.read fallback could not locate ${targetLabel}`);\n }\n return firstPayload;\n }\n async cardsFsWriteFallback(target, fileData, requestId) {\n if (!this.shouldUseCardFsFallback()) {\n throw new Error(\"cardsFS.write fallback is disabled because parent supports card_fs\");\n }\n const cardIuid = this.getCardIuid();\n if (!cardIuid) {\n throw new Error(\"cardsFS.write fallback failed: card not initialized\");\n }\n console.debug(\"cardsFS.write fallback invoked for target\", target);\n await this.upsertDocumentViaApi(cardIuid, target, fileData);\n const payload = await this.fetchDocumentPayload(cardIuid, target);\n await this.ensureCardFsCache()?.cacheDocument(payload.object, payload.data);\n const enrichedPayload = {\n name: payload.object?.name ?? target.name ?? target.iuid ?? null,\n iuid: payload.object?.iuid ?? target.iuid ?? null,\n object: payload.object,\n data: payload.data,\n };\n if (requestId && this.fsWriteRequests.has(requestId)) {\n this.handleFsWriteSuccess(requestId, enrichedPayload);\n }\n return enrichedPayload;\n }\n async cardsFsDeleteFallback(target) {\n if (!this.shouldUseCardFsFallback()) {\n throw new Error(\"cardsFS.delete fallback is disabled because parent supports card_fs\");\n }\n const cardIuid = this.getCardIuid();\n if (!cardIuid) {\n throw new Error(\"cardsFS.delete fallback failed: card not initialized\");\n }\n console.debug(\"cardsFS.delete fallback invoked for target\", target);\n const cache = this.ensureCardFsCache();\n const doc = await this.fetchDocumentMetadataByTarget(cardIuid, target).catch(() => null);\n const deleteIuid = doc?.iuid ?? target.iuid ?? null;\n const resolvedName = doc?.name ?? target.name ?? null;\n if (!deleteIuid) {\n if (target.name) {\n await cache?.deleteByName(target.name);\n }\n return { name: resolvedName, iuid: null, deleted: false };\n }\n const response = await fetch(`/api/v1/documents/${deleteIuid}/`, {\n method: 'DELETE',\n headers: this.authHeader(),\n });\n if (!response.ok && response.status !== 404) {\n const message = await response.text().catch(() => 'delete failed');\n throw new Error(`cardsFS.delete fallback failed: ${message}`);\n }\n await cache?.deleteByIuid(deleteIuid, resolvedName ?? undefined);\n const deleted = response.status !== 404;\n return {\n name: resolvedName ?? deleteIuid,\n iuid: deleteIuid,\n deleted,\n };\n }\n async cardsFsListFallback() {\n if (!this.shouldUseCardFsFallback()) {\n throw new Error(\"cardsFS.list fallback is disabled because parent supports card_fs\");\n }\n const cardIuid = this.getCardIuid();\n if (!cardIuid) {\n throw new Error(\"cardsFS.list fallback failed: card not initialized\");\n }\n const cache = this.ensureCardFsCache();\n try {\n const documents = await this.fetchAllDocuments(cardIuid);\n if (cache) {\n for (const doc of documents) {\n await cache.cacheDocument(doc, undefined);\n }\n }\n return { documents, from_cache: false };\n }\n catch (err) {\n const cachedDocs = await cache?.getAllCachedObjects();\n if (cachedDocs && cachedDocs.length > 0) {\n return { documents: cachedDocs, from_cache: true };\n }\n throw err;\n }\n }\n authHeader() {\n return this.accessToken ? { 'Authorization': `Bearer ${this.accessToken}` } : {};\n }\n jsonHeaders() {\n return { ...this.authHeader(), 'Content-Type': 'application/json' };\n }\n async fetchDocumentMetadataByTarget(cardIuid, target) {\n if (target.iuid) {\n return this.fetchDocumentMetadataByIuid(target.iuid);\n }\n if (target.name) {\n return this.fetchDocumentMetadataByName(cardIuid, target.name);\n }\n return null;\n }\n async fetchDocumentMetadataByIuid(iuid) {\n const response = await fetch(`/api/v1/documents/${iuid}/`, {\n method: 'GET',\n headers: this.authHeader(),\n });\n if (response.status === 404) {\n return null;\n }\n if (!response.ok) {\n const message = await response.text().catch(() => 'metadata lookup failed');\n throw new Error(`cardsFS metadata fetch failed: ${message}`);\n }\n return response.json().catch(() => null);\n }\n normalizeDocumentsResponse(body) {\n if (Array.isArray(body?.results)) {\n return body.results;\n }\n if (Array.isArray(body)) {\n return body;\n }\n return body ? [body] : [];\n }\n extractHttpErrorMessage(error, fallback) {\n if (!error) {\n return fallback;\n }\n if (typeof error === \"string\") {\n return error;\n }\n if (error instanceof Error && error.message) {\n return error.message;\n }\n const payload = error?.error ?? error;\n if (payload instanceof Blob) {\n return fallback;\n }\n if (typeof payload === \"string\") {\n return payload;\n }\n if (payload?.detail) {\n return payload.detail;\n }\n if (payload?.message) {\n return payload.message;\n }\n if (typeof payload?.statusText === \"string\" && payload.statusText.trim()) {\n return payload.statusText;\n }\n return fallback;\n }\n async fetchDocumentMetadataByName(cardIuid, name) {\n if (!name)\n return null;\n const response = await fetch(`/api/v1/documents/with_card/${cardIuid}/?name=${encodeURIComponent(name)}`, {\n method: 'GET',\n headers: this.authHeader(),\n });\n if (!response.ok) {\n if (response.status === 404)\n return null;\n const message = await response.text().catch(() => 'metadata lookup failed');\n throw new Error(`cardsFS metadata fetch failed: ${message}`);\n }\n const body = await response.json().catch(() => null);\n const documents = this.normalizeDocumentsResponse(body);\n return documents.find((doc) => doc?.name === name) ?? documents[0] ?? null;\n }\n async fetchAllDocuments(cardIuid) {\n const response = await fetch(`/api/v1/documents/with_card/${cardIuid}/`, {\n method: 'GET',\n headers: this.authHeader(),\n });\n if (!response.ok) {\n const message = await response.text().catch(() => 'list failed');\n throw new Error(`cardsFS.list failed: ${message}`);\n }\n const body = await response.json().catch(() => null);\n return this.normalizeDocumentsResponse(body);\n }\n async fetchDocumentPayload(cardIuid, target) {\n const resolvedTarget = typeof target === \"string\" ? { name: target } : target;\n const doc = await this.fetchDocumentMetadataByTarget(cardIuid, resolvedTarget);\n if (!doc) {\n throw new Error(`cardsFS document not found: ${this.describeCardFsTarget(resolvedTarget)}`);\n }\n const data = await this.fetchDocumentData(doc);\n return { object: doc, data };\n }\n async fetchDocumentData(doc) {\n if (doc?.data !== undefined) {\n return doc.data;\n }\n const url = doc?.orig?.url || doc?.url?.original || doc?.url;\n if (!url || typeof url !== 'string') {\n return null;\n }\n const response = await fetch(url);\n if (!response.ok) {\n const message = await response.text().catch(() => 'download failed');\n throw new Error(`cardsFS data fetch failed: ${message}`);\n }\n const contentType = response.headers.get('Content-Type') || '';\n if (contentType.includes('application/json')) {\n return response.json();\n }\n if (contentType.startsWith('text/')) {\n return response.text();\n }\n return response.arrayBuffer();\n }\n async buildFileFormData(name, fileData) {\n let file;\n const toBinaryBlob = (input) => {\n if (input instanceof ArrayBuffer) {\n return new Blob([input.slice(0)], { type: 'application/octet-stream' });\n }\n if (typeof SharedArrayBuffer !== 'undefined' && input instanceof SharedArrayBuffer) {\n const viewFromShared = new Uint8Array(input);\n const copy = new Uint8Array(viewFromShared.length);\n copy.set(viewFromShared);\n return new Blob([copy.buffer], { type: 'application/octet-stream' });\n }\n if (ArrayBuffer.isView(input)) {\n const view = new Uint8Array(input.buffer, input.byteOffset, input.byteLength);\n const copy = new Uint8Array(view.length);\n copy.set(view);\n return new Blob([copy.buffer], { type: 'application/octet-stream' });\n }\n const arrayBufferLike = input;\n const view = new Uint8Array(arrayBufferLike);\n const copy = new Uint8Array(view.length);\n copy.set(view);\n return new Blob([copy.buffer], { type: 'application/octet-stream' });\n };\n if (fileData instanceof File) {\n file = fileData;\n }\n else if (typeof Blob !== 'undefined' && fileData instanceof Blob) {\n file = new File([fileData], name, { type: fileData.type || 'application/octet-stream' });\n }\n else if (typeof SharedArrayBuffer !== 'undefined' && fileData instanceof SharedArrayBuffer) {\n const blob = toBinaryBlob(fileData);\n file = new File([blob], name, { type: blob.type });\n }\n else if (fileData instanceof ArrayBuffer) {\n const blob = toBinaryBlob(fileData);\n file = new File([blob], name, { type: blob.type });\n }\n else if (ArrayBuffer.isView(fileData)) {\n const blob = toBinaryBlob(fileData);\n file = new File([blob], name, { type: blob.type });\n }\n else if (typeof fileData === 'string') {\n const blob = new Blob([fileData], { type: 'text/plain' });\n file = new File([blob], name, { type: blob.type });\n }\n else {\n const jsonString = JSON.stringify(fileData ?? {});\n const blob = new Blob([jsonString], { type: 'application/json' });\n file = new File([blob], name, { type: blob.type });\n }\n const formData = new FormData();\n formData.append('file', file);\n return formData;\n }\n async upsertDocumentViaApi(cardIuid, target, fileData) {\n const formData = await this.buildFileFormData(target.name ?? target.iuid ?? 'document', fileData);\n if (target.iuid) {\n const response = await fetch(`/api/v1/documents/${target.iuid}/`, {\n method: 'PUT',\n headers: this.authHeader(),\n body: formData,\n });\n if (!response.ok) {\n const message = await response.text().catch(() => 'update failed');\n throw new Error(`cardsFS.write update failed: ${message}`);\n }\n return;\n }\n const existing = target.name\n ? await this.fetchDocumentMetadataByName(cardIuid, target.name).catch(() => null)\n : null;\n if (existing?.iuid) {\n const response = await fetch(`/api/v1/documents/${existing.iuid}/`, {\n method: 'PUT',\n headers: this.authHeader(),\n body: formData,\n });\n if (!response.ok) {\n const message = await response.text().catch(() => 'update failed');\n throw new Error(`cardsFS.write update failed: ${message}`);\n }\n return;\n }\n const uploadResponse = await fetch(`/api/v1/documents/`, {\n method: 'POST',\n headers: this.authHeader(),\n body: formData,\n });\n if (!uploadResponse.ok) {\n const message = await uploadResponse.text().catch(() => 'upload failed');\n throw new Error(`cardsFS.write upload failed: ${message}`);\n }\n const uploadBody = await uploadResponse.json().catch(() => null);\n const uploadedDoc = Array.isArray(uploadBody?.results) ? uploadBody.results[0] : uploadBody;\n const newIuid = uploadedDoc?.iuid;\n if (!newIuid) {\n throw new Error('cardsFS.write upload failed: missing document iuid');\n }\n const attachResponse = await fetch(`/api/v1/documents/with_card/${cardIuid}/`, {\n method: 'POST',\n headers: this.jsonHeaders(),\n body: JSON.stringify({ documents: [newIuid] }),\n });\n if (!attachResponse.ok) {\n const message = await attachResponse.text().catch(() => 'attach failed');\n throw new Error(`cardsFS.write attach failed: ${message}`);\n }\n }\n /**\n * Get document associated with the current card\n */\n async getDocumentAttachedToCard(card_iuid, document_name = 'default') {\n const url = new URL(`/api/v1/documents/attached_to/${card_iuid}/`);\n url.searchParams.set('name', document_name);\n const response = await fetch(url.toString(), {\n method: 'GET',\n headers: {\n 'Authorization': `Bearer ${this.accessToken || ''}`,\n 'Content-Type': 'application/json'\n }\n });\n if (!response.ok) {\n const error = await response.text();\n throw new Error(`Fetch failed: ${error}`);\n }\n return response.json();\n }\n /**\n * Save document attached to current card\n */\n async postDocumentAttachedToCard(card_iuid, document) {\n const response = await fetch(`/api/v1/documents/attached_to/${card_iuid}/`, {\n method: 'POST',\n headers: {\n 'Authorization': `Bearer ${this.accessToken || ''}`,\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(document)\n });\n if (!response.ok) {\n const error = await response.text();\n throw new Error(`Post failed: ${error}`);\n }\n return response.json();\n }\n async getCardDocument(card_iuid, doc_name) {\n const response = await fetch(`/api/v1/documents/with_card/${card_iuid}/?name=${doc_name}`, {\n method: 'GET',\n headers: {\n 'Authorization': `Bearer ${this.accessToken || ''}`,\n 'Content-Type': 'application/json',\n },\n });\n const data = await response.json();\n return data;\n }\n // Send event on error (clients will get \"onError\" event)\n formatErrorMessage(input) {\n if (typeof input === \"string\" && input.trim()) {\n return input;\n }\n if (input instanceof Error) {\n return input.message || input.toString();\n }\n if (input && typeof input === \"object\") {\n if (typeof input.message === \"string\") {\n return input.message;\n }\n try {\n return JSON.stringify(input);\n }\n catch {\n return Object.prototype.toString.call(input);\n }\n }\n if (input != null) {\n return String(input);\n }\n return \"Unknown error\";\n }\n sendEventError(error_code, message, data = undefined) {\n const data_to_send = {\n message: this.formatErrorMessage(message),\n error_code,\n data: data ?? null,\n };\n if (this.handler)\n this.safeInvoke(\"onError\", this.handler, data_to_send);\n }\n setFileDirty(data) {\n this.sendMessage(CardMessageType.FILE_DIRTY, data);\n }\n // Get username string from user object received from parent\n getUsername(userObj) {\n const nameObj = userObj?.name;\n if (nameObj && Object.values(nameObj).some(value => value)) {\n return getNameString(nameObj);\n }\n return '';\n }\n}\n// How long we wait for parent responses before rejecting (ms)\nCardSdk.FS_RESPONSE_TIMEOUT_MS = 30000;\n// Keep read handlers alive briefly to allow cached+fresh events (ms)\nCardSdk.FS_READ_RETENTION_MS = 5000;\nCardSdk.CARD_FS_ACK_TIMEOUT_MS = 5000;\n","/**\n * Helper function to generate a unique requestId (UUID).\n * This uses the browser's crypto API for random UUID generation.\n */\nexport function generateUUID() {\n // If in a browser environment with crypto support (modern browsers)\n if (typeof window !== 'undefined' && window.crypto && window.crypto.randomUUID) {\n return window.crypto.randomUUID();\n }\n // Fallback for non-browser environments (e.g., Node.js)\n if (typeof crypto !== 'undefined' && crypto.randomUUID) {\n return crypto.randomUUID();\n }\n // Fallback for environments without crypto support\n throw new Error('UUID generation is not supported in this environment');\n}\n/**\n * Helper function to get username from user object\n * @param nameObj the user object\n */\nexport function getNameString(nameObj) {\n const { prefix = '', given = '', middle = '', family = '', suffix = '' } = nameObj || {};\n const fullname = [prefix, given, middle, family, suffix].filter(namePart => namePart).join(' ');\n return fullname.trim();\n}\n"],"names":["root","factory","exports","module","define","amd","this","__webpack_require__","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","Symbol","toStringTag","value","CryptoA01","constructor","subtleCrypto","window","crypto","subtle","Error","decrypt","token","password","salt","tokenBytes","base64UrlDecode","slice","iv","ciphertext","hmacFromToken","fullKey","deriveKey","hmacKey","aesKey","splitKey","hmacInput","Uint8Array","sign","every","byte","i","decrypted","name","TextDecoder","decode","err","console","log","iterations","encoder","TextEncoder","keyMaterial","importKey","encode","hash","length","rawKey","exportKey","base64","base64String","replace","decodedString","atob","map","c","charCodeAt","ViewerMessageType","CommonSdkMessageType","ClientMessageType","Set","location","origin","ALLOWED_DEEP_LINK_PROTOCOLS","DomeEmbeddedAppSdk","targetOrigin","isAppReady","port2","runtimeHost","parentHostDetails","parentCapabilities","handleDeepLinkClick","event","target","Element","anchor","closest","href","getAttribute","emitDeepLink","preventDefault","detectHost","setupDeepLinkInterception","AndroidBridge","webkit","document","addEventListener","trim","warn","protocol","split","toLowerCase","has","sendMessage","CardMessageType","OPEN_DEEPLINK","url","updateParentContext","host","capabilities","merged","type","nextCapabilities","getHost","data","message","JSON","stringify","messageHandlers","appHandler","postMessage","error","sendAppInit","INIT","sdk","ver","safeInvoke","eventName","handlerObj","handler","String","setupParentConnection","Promise","resolve","reject","receiveFromAndroid","handleMessage","receiveFromIOS","CONNECT","ports","onmessage","e","handlePortMessage","removeEventListener","notifyConnectionSuccess","parent","INIT_MESSAGE_CHANNEL","CONNECTION_SUCCESS","ViewerSdk","super","pendingRequests","Map","pendingInitAck","init","initialized","instance","then","initializeViewerSdk","catch","trace","setHandler","canRead","perms","includes","canWrite","requestInitialData","REQUEST_INITIAL_DATA","requestSave","doc","isDataDirty","requestId","randomUUID","generateUUID","REQUEST_SAVE","set","setTimeout","delete","handleOnSave","status","setDirty","isDirty","SET_DIRTY","sendClose","SEND_CLOSE","sendException","SEND_EXCEPTION","INIT_ACK","DATA_CHANGE","REQUEST_CLOSE","SAVE_SUCCESS","SAVE_ERROR","CardFsCache","cardIuid","containerIuid","openPromise","isSupported","indexedDB","openDb","openWithVersion","DB_VERSION","version","infoAction","request","open","onupgradeneeded","oldVersion","configureStores","result","onsuccess","db","hasRequiredStores","nextVersion","close","updateStoresMetadata","finally","onerror","objectStoreNames","contains","DATA_STORE","createObjectStore","NAME_LOOKUP_STORE","INFO_STORE","stores","nowMicros","Math","trunc","Date","now","preserveExistingInfoTs","all","ensureStoreVersion","updateCardInfo","storeName","tx","transaction","store","objectStore","finalize","oncomplete","onabort","put","STORE_VERSION_KEY","preserveExistingTs","existingContainer","readInfoValue","existingTs","undefined","containerValue","timestampValue","writeInfoValue","keyFor","suffix","normalizeName","trimmed","hashName","cryptoRef","globalThis","digest","encoded","encodeText","bufferToBase64","buffer","binary","bytes","fromCharCode","btoa","getIuidForName","normalized","hashed","upsertNameLookup","iuid","openCursor","cursor","continue","deleteNameLookupByName","deleteNameLookupByIuid","estimateSize","Blob","size","ArrayBuffer","byteLength","isView","cacheDocument","normalizedName","MAX_DATA_BYTES","getByName","object","getByIuid","deleteByName","entry","deleteByIuid","getAllCachedObjects","results","endsWith","push","CardSdk","resolveCardFsTarget","operation","describeCardFsTarget","buildCardFsMessagePayload","extra","getCardIuid","dataStore","ensureCardFsCache","shouldUseCardFsFallback","cardFsCache","supportsParentCardFs","card_fs","accessToken","fileReadResolvers","fileWriteResolvers","fsReadRequests","fsWriteRequests","pendingAcks","messageId","timeout","clearTimeout","kw1","key_wa1","cryptoA01","denc","kw2","decData","decryptedData","parse","decryptedContainerIuid","container","apiToken","api_token","ui","sendEventError","FILE_DATA","responseId","_ignored","payload","handleFsReadDataMessage","fileName","resolver","handleFsWriteSuccess","savedName","handleFsWriteError","failedName","ERROR","failFsReadRequest","failFsWriteRequest","REFRESH","cardsFS","read","onUpdate","cardsFsRead","write","fileData","onResult","cardsFsWrite","cardsFsDelete","list","cardsFsList","secret","options","initializeCardSdk","openDeepLink","TAG","data_af1","IT_DATA_AF1","ss","URL","pathname","filter","Boolean","reverse","join","substring","dataFromServer","ite","d","sendInit","sendMessageWithAck","ackType","timeoutMs","onMessageId","targetInput","cardsFsReadFallback","registeredMessageId","targetLabel","READ_FILE","READ_FILE_ACK","CARD_FS_ACK_TIMEOUT_MS","hasResolved","noResponseTimeout","FS_RESPONSE_TIMEOUT_MS","cardsFsWriteFallback","callbackErr","WRITE_FILE","WRITE_FILE_ACK","cardsFsDeleteFallback","DELETE_FILE","DELETE_FILE_ACK","cardsFsListFallback","LIST_FILES","LIST_FILES_ACK","cleanupTimeout","clearFsReadRequest","FS_READ_RETENTION_MS","clearFsWriteRequest","cache","firstPayload","emit","fromCache","explicitName","explicitIuid","messagePayload","from_cache","cached","freshPayload","fetchDocumentPayload","upsertDocumentViaApi","enrichedPayload","fetchDocumentMetadataByTarget","deleteIuid","resolvedName","deleted","response","fetch","method","headers","authHeader","ok","text","documents","fetchAllDocuments","cachedDocs","jsonHeaders","fetchDocumentMetadataByIuid","fetchDocumentMetadataByName","json","normalizeDocumentsResponse","body","Array","isArray","extractHttpErrorMessage","fallback","detail","statusText","encodeURIComponent","find","resolvedTarget","fetchDocumentData","orig","original","contentType","startsWith","arrayBuffer","buildFileFormData","file","toBinaryBlob","input","SharedArrayBuffer","viewFromShared","copy","view","byteOffset","File","blob","jsonString","formData","FormData","append","existing","uploadResponse","uploadBody","uploadedDoc","newIuid","attachResponse","getDocumentAttachedToCard","card_iuid","document_name","searchParams","toString","postDocumentAttachedToCard","getCardDocument","doc_name","formatErrorMessage","error_code","data_to_send","setFileDirty","FILE_DIRTY","getUsername","userObj","nameObj","values","some","prefix","given","middle","family","namePart","getNameString"],"sourceRoot":""}
1
+ {"version":3,"file":"index.js","mappings":"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","sources":["webpack://domeSdk/webpack/universalModuleDefinition","webpack://domeSdk/webpack/bootstrap","webpack://domeSdk/webpack/runtime/define property getters","webpack://domeSdk/webpack/runtime/hasOwnProperty shorthand","webpack://domeSdk/webpack/runtime/make namespace object","webpack://domeSdk/./src/crypto.ts","webpack://domeSdk/./src/dome-sdk.ts","webpack://domeSdk/./src/utils.ts"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"domeSdk\"] = factory();\n\telse\n\t\troot[\"domeSdk\"] = factory();\n})(this, () => {\nreturn ","// The require scope\nvar __webpack_require__ = {};\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","// Provide enc / dec using Algorithm01\nexport class CryptoA01 {\n constructor() {\n // Initialize subtleCrypto once\n this.subtleCrypto = window.crypto?.subtle;\n if (!this.subtleCrypto) {\n throw new Error('SubtleCrypto API is not available in this environment.');\n }\n }\n /**\n * Perform decryption using AES based V1 algorithm.\n *\n * string: the encrypted string (base64 encoded)\n * password: the password used for encryption\n * salt: the base64 encoded salt used\n */\n async decrypt(token, password, salt) {\n try {\n if (!token) {\n throw new Error(\"Invalid token\");\n }\n const tokenBytes = this.base64UrlDecode(token);\n // Extract token components\n const version = tokenBytes[0];\n if (version !== 0x80) {\n // console.log(\"Incorrect Version: \", version);\n throw new Error('Invalid version');\n }\n const timestamp = tokenBytes.slice(1, 9);\n const iv = tokenBytes.slice(9, 25);\n const ciphertext = tokenBytes.slice(25, -32);\n const hmacFromToken = tokenBytes.slice(-32);\n // Derive the key and split it into HMAC and AES keys\n const fullKey = await this.deriveKey(password, salt);\n const { hmacKey, aesKey } = await this.splitKey(fullKey);\n // Compute HMAC over version + timestamp + IV + ciphertext\n const hmacInput = tokenBytes.slice(0, -32);\n const computedHmac = new Uint8Array(await this.subtleCrypto.sign('HMAC', hmacKey, hmacInput));\n // Validate HMAC\n if (!computedHmac.every((byte, i) => byte === hmacFromToken[i])) {\n throw new Error('Invalid HMAC. Token has been tampered with!');\n }\n // Decrypt the ciphertext\n const decrypted = await this.subtleCrypto.decrypt({\n name: 'AES-CBC',\n iv: iv,\n }, aesKey, ciphertext);\n // Convert decrypted data to UTF-8 string\n const decoder = new TextDecoder();\n return decoder.decode(decrypted);\n }\n catch (err) {\n console.log(\"Error in decrypt:\", err);\n throw err;\n }\n }\n async deriveKey(password, salt, iterations = 10000) {\n const encoder = new TextEncoder();\n const keyMaterial = await this.subtleCrypto.importKey(\"raw\", encoder.encode(password), \"PBKDF2\", false, [\"deriveKey\"]);\n return this.subtleCrypto.deriveKey({\n name: \"PBKDF2\",\n hash: \"SHA-256\",\n salt: encoder.encode(salt),\n iterations: iterations,\n }, keyMaterial, { name: \"AES-CBC\", length: 256 }, true, // Allow export of the derived key (req for splitting)\n [\"encrypt\", \"decrypt\"]);\n }\n // Split the full key into HMAC and AES keys\n async splitKey(fullKey) {\n const rawKey = new Uint8Array(await this.subtleCrypto.exportKey('raw', fullKey));\n // Split the key into HMAC (first 16 bytes) and AES (last 16 bytes)\n const hmacKey = await this.subtleCrypto.importKey('raw', rawKey.slice(0, 16), { name: 'HMAC', hash: 'SHA-256' }, false, ['sign', 'verify']);\n const aesKey = await this.subtleCrypto.importKey('raw', rawKey.slice(16), { name: 'AES-CBC' }, false, ['encrypt', 'decrypt']);\n return { hmacKey, aesKey };\n }\n // Decode Base64 URL-safe strings\n base64UrlDecode(base64) {\n // assumes URL safe encoding that has + in place of - and _ in place of /\n const base64String = base64.replace(/-/g, '+').replace(/_/g, '/');\n const decodedString = atob(base64String);\n return new Uint8Array([...decodedString].map(c => c.charCodeAt(0)));\n }\n}\n","import pkg from \"../package.json\";\nimport { generateUUID, getNameString } from './utils';\nimport { CryptoA01 } from './crypto';\n// Enum defining message types sent from the viewer to the parent application\nexport var ViewerMessageType;\n(function (ViewerMessageType) {\n ViewerMessageType[\"CONNECTION_SUCCESS\"] = \"CONNECTION_SUCCESS\";\n ViewerMessageType[\"INIT\"] = \"INIT\";\n ViewerMessageType[\"REQUEST_SAVE\"] = \"REQUEST_SAVE\";\n ViewerMessageType[\"REQUEST_CLOSE\"] = \"REQUEST_CLOSE\";\n ViewerMessageType[\"REQUEST_INITIAL_DATA\"] = \"REQUEST_INITIAL_DATA\";\n ViewerMessageType[\"SET_DIRTY\"] = \"SET_DIRTY\";\n ViewerMessageType[\"SEND_CLOSE\"] = \"SEND_CLOSE\";\n ViewerMessageType[\"SEND_EXCEPTION\"] = \"SEND_EXCEPTION\";\n})(ViewerMessageType || (ViewerMessageType = {}));\nvar CommonSdkMessageType;\n(function (CommonSdkMessageType) {\n CommonSdkMessageType[\"INIT_MESSAGE_CHANNEL\"] = \"INIT_MESSAGE_CHANNEL\";\n})(CommonSdkMessageType || (CommonSdkMessageType = {}));\n// Enum defining message types sent from the parent application to the embedded app\nvar ClientMessageType;\n(function (ClientMessageType) {\n ClientMessageType[\"CONNECT\"] = \"CONNECT\";\n ClientMessageType[\"REQUEST_CLOSE\"] = \"REQUEST_CLOSE\";\n ClientMessageType[\"REQUEST_SAVE\"] = \"REQUEST_SAVE\";\n ClientMessageType[\"SAVE_ERROR\"] = \"SAVE_ERROR\";\n ClientMessageType[\"SAVE_SUCCESS\"] = \"SAVE_SUCCESS\";\n ClientMessageType[\"DATA_CHANGE\"] = \"DATA_CHANGE\";\n ClientMessageType[\"FILE_DATA\"] = \"FILE_DATA\";\n ClientMessageType[\"WRITE_FILE_ACK\"] = \"WRITE_FILE_ACK\";\n ClientMessageType[\"READ_FILE_ACK\"] = \"READ_FILE_ACK\";\n ClientMessageType[\"DELETE_FILE_ACK\"] = \"DELETE_FILE_ACK\";\n ClientMessageType[\"LIST_FILES_ACK\"] = \"LIST_FILES_ACK\";\n ClientMessageType[\"INIT_ACK\"] = \"INIT_ACK\";\n ClientMessageType[\"ERROR\"] = \"ERROR\";\n ClientMessageType[\"REFRESH\"] = \"REFRESH\";\n})(ClientMessageType || (ClientMessageType = {}));\n;\nconst ALLOWED_ORIGINS = new Set(getAllowedOrigins());\nconst ALLOWED_DEEP_LINK_PROTOCOLS = new Set([\"dome\", \"intouchapp\"]);\nconst CARD_FS_VERSION = '1.0.0';\nfunction getAllowedOrigins() {\n if (typeof window === 'undefined')\n return [];\n return [\n window.location.origin,\n 'https://dome.so',\n 'https://spaces.intouchapp.com/',\n 'http://localhost:4200',\n 'http://localhost:4201',\n 'null',\n ];\n}\n/**\n * DomeEmbeddedAppSdk:\n * Base SDK class providing methods to send messages to the parent application.\n */\nclass DomeEmbeddedAppSdk {\n constructor() {\n this.targetOrigin = \"*\";\n this.isAppReady = false;\n this.port2 = null;\n this.runtimeHost = \"unknown\"; // Transport/runtime host\n this.parentHostDetails = null;\n this.parentCapabilities = null;\n this.handleDeepLinkClick = (event) => {\n if (this.runtimeHost !== \"webapp\")\n return;\n if (!(event.target instanceof Element))\n return;\n const anchor = event.target.closest(\"a[href]\");\n if (!anchor)\n return;\n const href = anchor.getAttribute(\"href\") ?? \"\";\n if (this.emitDeepLink(href)) {\n event.preventDefault();\n }\n };\n console.info(`Initializing Dome Embedded App SDK v${pkg.version}`);\n this.detectHost();\n this.setupDeepLinkInterception();\n }\n /**\n * Detects the host (iOS, Android, or Web) and saves it.\n */\n detectHost() {\n if (typeof window.AndroidBridge !== \"undefined\") {\n this.runtimeHost = \"android\";\n }\n else if (typeof window.webkit !== \"undefined\") {\n this.runtimeHost = \"ios\";\n }\n else {\n this.runtimeHost = \"webapp\";\n }\n console.debug(`Detected host: ${this.runtimeHost}`);\n }\n /**\n * Listens for deep link anchor clicks on web to forward them to the parent app.\n */\n setupDeepLinkInterception() {\n if (this.runtimeHost !== \"webapp\")\n return;\n if (typeof document === \"undefined\")\n return;\n document.addEventListener(\"click\", this.handleDeepLinkClick, true);\n }\n /**\n * Sends an OPEN_DEEPLINK message when the href uses an allowed protocol.\n * @returns true if the message was dispatched, false otherwise.\n */\n emitDeepLink(href) {\n if (typeof href !== \"string\" || href.trim() === \"\") {\n console.warn(\"emitDeepLink called without a valid href\");\n return false;\n }\n const protocol = href.split(\":\")[0]?.toLowerCase();\n if (!protocol || !ALLOWED_DEEP_LINK_PROTOCOLS.has(protocol)) {\n return false;\n }\n this.sendMessage(CardMessageType.OPEN_DEEPLINK, { url: href });\n return true;\n }\n updateParentContext(host, capabilities) {\n if (!host && !capabilities) {\n return;\n }\n const base = this.parentHostDetails ?? { type: this.runtimeHost };\n const merged = {\n ...base,\n ...(host ?? {}),\n };\n if (!merged.type) {\n merged.type = this.runtimeHost;\n }\n const nextCapabilities = capabilities ?? this.parentCapabilities ?? merged.capabilities;\n if (capabilities) {\n this.parentCapabilities = capabilities;\n }\n if (nextCapabilities) {\n merged.capabilities = nextCapabilities;\n }\n else {\n delete merged.capabilities;\n }\n this.parentHostDetails = merged;\n this.parentCapabilities = nextCapabilities ?? null;\n if (nextCapabilities) {\n console.info(\"Host capabilities detected\", {\n host_type: merged.type,\n capabilities: nextCapabilities\n });\n }\n else {\n console.info(\"Host capabilities not found\", {\n hostType: merged.type,\n });\n }\n }\n getHost() {\n return this.parentHostDetails ?? { type: this.runtimeHost };\n }\n /**\n * Method to send messages to the parent application.\n * Ensures the parent window exists and sends a structured message with type and data.\n * @param type - The type of message being sent\n * @param data - (Optional) payload data for the message\n */\n sendMessage(type, data) {\n const message = { type, data: data ?? null };\n switch (this.runtimeHost) {\n case \"android\":\n window.AndroidBridge?.sendMessage(JSON.stringify(message));\n break;\n case \"ios\":\n if (window?.webkit?.messageHandlers) {\n window.webkit?.messageHandlers.appHandler.postMessage(JSON.stringify(message));\n }\n else {\n console.error(\"webkit.messageHandlers not found\");\n }\n break;\n case \"webapp\":\n if (this.port2) {\n this.port2.postMessage(message);\n }\n else {\n console.error(\"Web connection is not established.\");\n }\n break;\n default:\n console.error(\"Unsupported host, cannot send message.\");\n break;\n }\n console.debug(`Sent message to ${this.runtimeHost}:`, message);\n }\n /**\n * Notifies the parent application that the app is ready, if it hasn’t already.\n */\n sendAppInit() {\n if (!this.isAppReady) {\n this.isAppReady = true;\n this.sendMessage(ViewerMessageType.INIT, { sdk: { ver: pkg.version } });\n }\n }\n /**\n * Safely invokes a function from the handler object if it exists.\n * and logs a warning if the handler is not provided for the given message type.\n *\n * @param eventName - Name of the event method to be invoked from the handler.\n * @param handlerObj - The handler object that contains the message handling methods.\n * @param data - (Optional) The data to be passed to the handler function if invoked.\n */\n safeInvoke(eventName, handlerObj, data) {\n const handler = handlerObj[eventName];\n if (typeof handler === 'function') {\n handler(data);\n }\n else {\n console.warn(`Handler for '${String(eventName)}' is not defined.`);\n }\n }\n // Sets up connection with iframe parent using message channel\n // Call this once only in the lifetime. Should be called\n // _before_ iFrame's onLoad is called (otherwise messaging will\n // not be setup)\n setupParentConnection() {\n return new Promise((resolve, reject) => {\n switch (this.runtimeHost) {\n case \"android\":\n window.receiveFromAndroid = (message) => {\n console.debug(\"Message received from Android:\", message);\n this.handleMessage(message.type, message.data);\n };\n resolve();\n break;\n case \"ios\":\n window.receiveFromIOS = (message) => {\n console.debug(\"Message received from iOS:\", message);\n this.handleMessage(message.type, message.data);\n };\n resolve();\n break;\n case \"webapp\":\n if (this.port2) {\n console.warn(\"Connection already established. Skipping reinitialization.\");\n resolve();\n return;\n }\n const handleMessage = (event) => {\n const { type } = event.data || {};\n if (type !== ClientMessageType.CONNECT)\n return;\n if (event.ports && event.ports.length > 0) {\n this.port2 = event.ports[0];\n this.port2.onmessage = (e) => this.handlePortMessage(e);\n window.removeEventListener(\"message\", handleMessage); // Cleanup\n this.notifyConnectionSuccess();\n resolve();\n }\n };\n // Listen for browser-based `message` events\n window.addEventListener(\"message\", handleMessage);\n // Notify parent to initialize a message channel\n if (window.parent) {\n window.parent.postMessage({ type: CommonSdkMessageType.INIT_MESSAGE_CHANNEL, data: { sdk: { ver: pkg.version } } }, this.targetOrigin);\n }\n else {\n console.error(\"Parent window not available to initialize message channel.\");\n }\n break;\n default:\n console.error(\"Unknown host.\");\n reject(\"Unknown host\");\n }\n });\n }\n // Send CONNECTION_SUCCESS message to parent\n notifyConnectionSuccess() {\n this.sendMessage(ViewerMessageType.CONNECTION_SUCCESS);\n }\n // Handle messages coming over message channel port\n handlePortMessage(event) {\n const { type, data } = event.data || {};\n if (!type)\n return;\n // Delegate to subclass-specific message handler\n this.handleMessage(type, data);\n }\n // Common method for handling messages to be implemented by sub-classes\n handleMessage(type, data) {\n throw new Error(\"Subclasses must implement handleMessage.\");\n }\n}\n/**\n * ViewerSdk:\n * A subclass of DomeEmbeddedAppSdk specifically for document viewer applications.\n * It includes additional methods and properties to manage app interactions.\n */\nexport class ViewerSdk extends DomeEmbeddedAppSdk {\n constructor() {\n super();\n this.handler = null; // Handler instance for client messages\n this.pendingRequests = new Map();\n this.pendingInitAck = null;\n }\n /**\n * Static initialization method to get or create the singleton instance of ViewerSdk.\n * Allows setting the handler during initialization.\n * @param handler - (Optional) Custom handler for different message types\n * @returns The singleton ViewerSdk instance\n */\n static init(handler) {\n console.debug(\"init called\", handler && \"with handler\");\n // Prevent reinitialization if already initialized\n if (ViewerSdk.initialized) {\n console.warn(\"ViewerSdk is already initialized. Skipping initialization.\");\n return ViewerSdk.instance;\n }\n if (!ViewerSdk.instance) {\n ViewerSdk.instance = new ViewerSdk();\n // Initialize parent communication - REQUIRED!\n ViewerSdk.instance.setupParentConnection()\n .then(() => {\n try {\n // Connection established with parent\n ViewerSdk.instance.initializeViewerSdk();\n }\n catch (err) {\n console.error(\"Error in initializeViewerSdk:\", err);\n }\n })\n .catch((err) => {\n console.error(\"init: Error setting up parent connection!\", err);\n console.trace(\"called from:\");\n });\n }\n if (handler) {\n ViewerSdk.instance.setHandler(handler); // Set handler if provided during initialization\n }\n // Mark as initialized\n ViewerSdk.initialized = true;\n return ViewerSdk.instance;\n }\n /**\n * Method to set or update the handler object.\n * @param handler - Custom handler for different message types\n */\n setHandler(handler) {\n this.handler = handler;\n // If INIT_ACK message was received and stored, process it now\n if (this.pendingInitAck) {\n console.debug(\"Processing pending INIT_ACK message after handler is set.\");\n this.safeInvoke(\"onInitialData\", this.handler, this.pendingInitAck);\n this.pendingInitAck = null; // Clear the stored message\n }\n }\n /**\n * Checks if the given permissions string allows reading.\n * @param perms - The permissions string.\n * @returns - True if the permission string includes read access.\n */\n canRead(perms) {\n return !!perms?.includes('r');\n }\n /**\n * Checks if the given permissions string allows writing.\n * @param perms - The permissions string.\n * @returns - True if the permission string includes write access.\n */\n canWrite(perms) {\n return !!perms?.includes('w') || !!perms?.includes('*');\n }\n // Initializes the viewer SDK, setting up the message listener and sending an initial \"ready\" message.\n initializeViewerSdk() {\n console.debug(\"initializing viewer sdk\");\n this.sendAppInit();\n }\n /**\n * Sends a request to the parent application to retrieve initial data.\n */\n requestInitialData() {\n this.sendMessage(ViewerMessageType.REQUEST_INITIAL_DATA);\n }\n /**\n * Sends a request to the parent application to save data.\n * @param doc - payload data to be saved\n * @param isDataDirty - Boolean indicating indicating modified data\n */\n requestSave(doc, isDataDirty) {\n const requestId = generateUUID();\n // Send save request with the generated requestId\n this.sendMessage(ViewerMessageType.REQUEST_SAVE, { doc, isDataDirty, requestId });\n return new Promise((resolve, reject) => {\n this.pendingRequests.set(requestId, resolve);\n this.pendingRequests.set(requestId + '_reject', reject);\n // Timeout if the parent fails to respond in time\n setTimeout(() => {\n if (this.pendingRequests.has(requestId)) {\n this.pendingRequests.delete(requestId);\n this.pendingRequests.delete(requestId + '_reject');\n }\n }, 30000);\n });\n }\n handleOnSave(data) {\n const { requestId, status, message } = data;\n // Check if we have a pending request for this requestId\n const resolve = this.pendingRequests.get(requestId);\n const reject = this.pendingRequests.get(requestId + '_reject');\n if (resolve) {\n // If status is \"error\", reject the promise, otherwise resolve it\n if (status === \"error\") {\n reject?.({ status, message });\n }\n else {\n resolve({ status, message });\n }\n // Clean up\n this.pendingRequests.delete(requestId);\n this.pendingRequests.delete(requestId + '_reject');\n }\n }\n /**\n * Sets the viewer's \"dirty\" state, indicating modified data.\n * @param isDirty - Boolean indicating whether the viewer has modified data\n */\n setDirty(isDirty) {\n this.sendMessage(ViewerMessageType.SET_DIRTY, isDirty);\n }\n /**\n * Sends a close request to the parent, with information on whether the data is dirty.\n * @param doc - Latest document data\n * @param isDataDirty - Boolean indicating indicating modified data\n */\n sendClose(doc, isDataDirty) {\n this.sendMessage(ViewerMessageType.SEND_CLOSE, { doc, isDataDirty });\n }\n /**\n * Sends an exception to parent.\n * @param error - An error object with name and message or an error string\n */\n sendException(error) {\n this.sendMessage(ViewerMessageType.SEND_EXCEPTION, error);\n }\n // Sets up the message listener for viewer to receive messages from the parent.\n handleMessage(type, data) {\n console.debug(\"handleMessage called for:\", type, \"with data:\", data);\n if (type === ClientMessageType.INIT_ACK) {\n this.updateParentContext(data?.host, data?.capabilities);\n }\n if (!this.handler) {\n if (type === ClientMessageType.INIT_ACK) {\n console.warn(\"Handler not set. Storing INIT_ACK message for later processing.\");\n this.pendingInitAck = data; // Save INIT_ACK message\n }\n else {\n console.error(\"Message handler not found for type:\", type);\n }\n return;\n }\n switch (type) {\n case ClientMessageType.INIT_ACK:\n this.safeInvoke(\"onInitialData\", this.handler, data);\n break;\n case ClientMessageType.DATA_CHANGE:\n this.safeInvoke(\"onDataChange\", this.handler, data);\n break;\n case ClientMessageType.REQUEST_CLOSE:\n this.safeInvoke(\"onCloseRequest\", this.handler);\n break;\n case ClientMessageType.REQUEST_SAVE:\n this.safeInvoke(\"onSaveRequest\", this.handler);\n break;\n case ClientMessageType.SAVE_SUCCESS:\n this.handleOnSave(data);\n break;\n case ClientMessageType.SAVE_ERROR:\n this.handleOnSave(data);\n break;\n default:\n console.warn(`No handler found for message type: ${type}`);\n }\n }\n}\nViewerSdk.initialized = false;\n// Card SDK\n// Enum defining message types sent from the card to the parent application\nexport var CardMessageType;\n(function (CardMessageType) {\n CardMessageType[\"APP_READY\"] = \"APP_READY\";\n CardMessageType[\"INIT\"] = \"INIT\";\n CardMessageType[\"READ_FILE\"] = \"READ_FILE\";\n CardMessageType[\"WRITE_FILE\"] = \"WRITE_FILE\";\n CardMessageType[\"DELETE_FILE\"] = \"DELETE_FILE\";\n CardMessageType[\"LIST_FILES\"] = \"LIST_FILES\";\n CardMessageType[\"FILE_DIRTY\"] = \"FILE_DIRTY\";\n CardMessageType[\"OPEN_DEEPLINK\"] = \"OPEN_DEEPLINK\";\n})(CardMessageType || (CardMessageType = {}));\n;\nclass CardFsCache {\n constructor(cardIuid, containerIuid) {\n this.cardIuid = cardIuid;\n this.containerIuid = containerIuid;\n this.openPromise = null;\n }\n isSupported() {\n return typeof indexedDB !== \"undefined\";\n }\n async openDb() {\n if (!this.isSupported())\n return null;\n if (!this.openPromise) {\n this.openPromise = new Promise((resolve) => {\n this.openWithVersion(CardFsCache.DB_VERSION, resolve);\n });\n }\n return this.openPromise;\n }\n openWithVersion(version, resolve) {\n let infoAction = \"ensure\";\n const request = indexedDB.open(this.cardIuid, version);\n request.onupgradeneeded = (event) => {\n infoAction = (event.oldVersion || 0) === 0 ? \"create\" : \"ensure\";\n this.configureStores(request.result);\n };\n request.onsuccess = () => {\n const db = request.result;\n if (!this.hasRequiredStores(db)) {\n const nextVersion = db.version + 1;\n db.close();\n this.openWithVersion(nextVersion, resolve);\n return;\n }\n this.updateStoresMetadata(db, infoAction === \"ensure\")\n .catch(() => undefined)\n .finally(() => resolve(db));\n };\n request.onerror = () => resolve(null);\n }\n configureStores(db) {\n if (!db.objectStoreNames.contains(CardFsCache.DATA_STORE)) {\n db.createObjectStore(CardFsCache.DATA_STORE);\n }\n if (!db.objectStoreNames.contains(CardFsCache.NAME_LOOKUP_STORE)) {\n db.createObjectStore(CardFsCache.NAME_LOOKUP_STORE);\n }\n if (!db.objectStoreNames.contains(CardFsCache.INFO_STORE)) {\n db.createObjectStore(CardFsCache.INFO_STORE);\n }\n }\n hasRequiredStores(db) {\n const stores = db.objectStoreNames;\n return (stores.contains(CardFsCache.DATA_STORE) &&\n stores.contains(CardFsCache.NAME_LOOKUP_STORE) &&\n stores.contains(CardFsCache.INFO_STORE));\n }\n static nowMicros() {\n return Math.trunc(Date.now() * 1000);\n }\n updateStoresMetadata(db, preserveExistingInfoTs) {\n return Promise.all([\n this.ensureStoreVersion(db, CardFsCache.DATA_STORE),\n this.ensureStoreVersion(db, CardFsCache.NAME_LOOKUP_STORE),\n this.updateCardInfo(db, preserveExistingInfoTs),\n ]).then(() => undefined);\n }\n ensureStoreVersion(db, storeName) {\n if (!db.objectStoreNames.contains(storeName)) {\n return Promise.resolve();\n }\n return new Promise((resolve) => {\n try {\n const tx = db.transaction(storeName, \"readwrite\");\n const store = tx.objectStore(storeName);\n const finalize = () => resolve();\n tx.oncomplete = finalize;\n tx.onerror = finalize;\n tx.onabort = finalize;\n store.put(CARD_FS_VERSION, CardFsCache.STORE_VERSION_KEY);\n }\n catch {\n resolve();\n }\n });\n }\n async updateCardInfo(db, preserveExistingTs) {\n if (!db.objectStoreNames.contains(CardFsCache.INFO_STORE)) {\n return;\n }\n const existingContainer = await this.readInfoValue(db, \"container_iuid\");\n const existingTs = preserveExistingTs ? await this.readInfoValue(db, \"ts_c\") : undefined;\n const containerValue = this.containerIuid ?? existingContainer ?? null;\n const timestampValue = preserveExistingTs && existingTs ? existingTs : CardFsCache.nowMicros();\n await Promise.all([\n this.writeInfoValue(db, \"container_iuid\", containerValue),\n this.writeInfoValue(db, \"ts_c\", timestampValue),\n ]).catch(() => undefined);\n }\n readInfoValue(db, key) {\n return new Promise((resolve) => {\n try {\n const tx = db.transaction(CardFsCache.INFO_STORE, \"readonly\");\n const store = tx.objectStore(CardFsCache.INFO_STORE);\n const request = store.get(key);\n request.onsuccess = () => resolve(request.result);\n request.onerror = () => resolve(undefined);\n }\n catch {\n resolve(undefined);\n }\n });\n }\n writeInfoValue(db, key, value) {\n return new Promise((resolve) => {\n try {\n const tx = db.transaction(CardFsCache.INFO_STORE, \"readwrite\");\n const store = tx.objectStore(CardFsCache.INFO_STORE);\n const finalize = () => resolve();\n tx.oncomplete = finalize;\n tx.onerror = finalize;\n tx.onabort = finalize;\n store.put(value, key);\n }\n catch {\n resolve();\n }\n });\n }\n keyFor(suffix) {\n return suffix;\n }\n static normalizeName(name) {\n if (typeof name !== \"string\")\n return null;\n const trimmed = name.trim();\n return trimmed ? trimmed : null;\n }\n async put(key, value) {\n const db = await this.openDb();\n if (!db)\n return;\n await new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.DATA_STORE, \"readwrite\");\n const store = tx.objectStore(CardFsCache.DATA_STORE);\n store.put(value, key).onsuccess = () => resolve();\n tx.oncomplete = () => resolve();\n tx.onerror = () => resolve();\n tx.onabort = () => resolve();\n });\n }\n async get(key) {\n const db = await this.openDb();\n if (!db)\n return undefined;\n return new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.DATA_STORE, \"readonly\");\n const store = tx.objectStore(CardFsCache.DATA_STORE);\n const request = store.get(key);\n request.onsuccess = () => resolve(request.result);\n request.onerror = () => resolve(undefined);\n });\n }\n async delete(key) {\n const db = await this.openDb();\n if (!db)\n return;\n await new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.DATA_STORE, \"readwrite\");\n const store = tx.objectStore(CardFsCache.DATA_STORE);\n store.delete(key).onsuccess = () => resolve();\n tx.oncomplete = () => resolve();\n tx.onerror = () => resolve();\n tx.onabort = () => resolve();\n });\n }\n static async hashName(name) {\n const cryptoRef = typeof globalThis !== 'undefined' ? globalThis.crypto : undefined;\n if (!cryptoRef?.subtle?.digest) {\n throw new Error('CardFS name hashing requires SubtleCrypto support');\n }\n const encoded = CardFsCache.encodeText(name);\n const digest = await cryptoRef.subtle.digest('SHA-256', encoded);\n return CardFsCache.bufferToBase64(digest);\n }\n static encodeText(value) {\n if (typeof TextEncoder !== 'undefined') {\n return new TextEncoder().encode(value).buffer;\n }\n const result = new Uint8Array(value.length);\n for (let i = 0; i < value.length; i++) {\n result[i] = value.charCodeAt(i);\n }\n return result.buffer;\n }\n static bufferToBase64(buffer) {\n let binary = '';\n const bytes = new Uint8Array(buffer);\n for (let i = 0; i < bytes.length; i++) {\n binary += String.fromCharCode(bytes[i]);\n }\n return btoa(binary);\n }\n async getIuidForName(name) {\n const normalized = CardFsCache.normalizeName(name);\n if (!normalized)\n return undefined;\n const db = await this.openDb();\n if (!db)\n return undefined;\n const hashed = await CardFsCache.hashName(normalized);\n return new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.NAME_LOOKUP_STORE, \"readonly\");\n const store = tx.objectStore(CardFsCache.NAME_LOOKUP_STORE);\n const request = store.get(hashed);\n request.onsuccess = () => resolve(request.result);\n request.onerror = () => resolve(undefined);\n });\n }\n async upsertNameLookup(name, iuid) {\n const normalized = CardFsCache.normalizeName(name);\n if (!normalized)\n return;\n const db = await this.openDb();\n if (!db)\n return;\n const hashed = await CardFsCache.hashName(normalized);\n await new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.NAME_LOOKUP_STORE, \"readwrite\");\n const store = tx.objectStore(CardFsCache.NAME_LOOKUP_STORE);\n store.put(iuid, hashed);\n const cursorRequest = store.openCursor();\n cursorRequest.onsuccess = (event) => {\n const cursor = event.target.result;\n if (!cursor)\n return;\n if (cursor.key !== hashed && cursor.value === iuid) {\n cursor.delete();\n }\n cursor.continue();\n };\n tx.oncomplete = () => resolve();\n tx.onerror = () => resolve();\n tx.onabort = () => resolve();\n });\n }\n async deleteNameLookupByName(name) {\n const normalized = CardFsCache.normalizeName(name);\n if (!normalized)\n return;\n const db = await this.openDb();\n if (!db)\n return;\n const hashed = await CardFsCache.hashName(normalized);\n await new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.NAME_LOOKUP_STORE, \"readwrite\");\n const store = tx.objectStore(CardFsCache.NAME_LOOKUP_STORE);\n store.delete(hashed);\n tx.oncomplete = () => resolve();\n tx.onerror = () => resolve();\n tx.onabort = () => resolve();\n });\n }\n async deleteNameLookupByIuid(iuid) {\n if (!iuid)\n return;\n const db = await this.openDb();\n if (!db)\n return;\n await new Promise((resolve) => {\n const tx = db.transaction(CardFsCache.NAME_LOOKUP_STORE, \"readwrite\");\n const store = tx.objectStore(CardFsCache.NAME_LOOKUP_STORE);\n const request = store.openCursor();\n request.onsuccess = (event) => {\n const cursor = event.target.result;\n if (!cursor)\n return;\n if (cursor.value === iuid) {\n cursor.delete();\n }\n cursor.continue();\n };\n tx.oncomplete = () => resolve();\n tx.onerror = () => resolve();\n tx.onabort = () => resolve();\n });\n }\n static estimateSize(data) {\n if (data == null)\n return 0;\n if (typeof Blob !== \"undefined\" && data instanceof Blob)\n return data.size;\n if (data instanceof ArrayBuffer)\n return data.byteLength;\n if (ArrayBuffer.isView(data))\n return data.byteLength;\n if (typeof data === \"string\")\n return new Blob([data]).size;\n try {\n return new Blob([JSON.stringify(data)]).size;\n }\n catch {\n return 0;\n }\n }\n async cacheDocument(doc, data) {\n if (!doc?.iuid)\n return;\n await this.put(this.keyFor(`${doc.iuid}_object`), doc);\n const normalizedName = CardFsCache.normalizeName(doc.name);\n if (normalizedName) {\n await this.upsertNameLookup(normalizedName, doc.iuid);\n }\n if (data === undefined) {\n await this.delete(this.keyFor(`${doc.iuid}_data`));\n return;\n }\n const size = CardFsCache.estimateSize(data);\n if (size <= CardFsCache.MAX_DATA_BYTES) {\n await this.put(this.keyFor(`${doc.iuid}_data`), data);\n }\n else {\n await this.delete(this.keyFor(`${doc.iuid}_data`));\n }\n }\n async getByName(name) {\n const normalizedName = CardFsCache.normalizeName(name);\n if (!normalizedName)\n return null;\n const iuid = await this.getIuidForName(normalizedName);\n if (!iuid)\n return null;\n const object = await this.get(this.keyFor(`${iuid}_object`));\n if (!object)\n return null;\n const data = await this.get(this.keyFor(`${iuid}_data`));\n return { iuid, object, data };\n }\n async getByIuid(iuid) {\n if (!iuid)\n return null;\n const object = await this.get(this.keyFor(`${iuid}_object`));\n if (!object)\n return null;\n const data = await this.get(this.keyFor(`${iuid}_data`));\n return { iuid, object, data };\n }\n async deleteByName(name) {\n const entry = await this.getByName(name);\n await this.deleteNameLookupByName(name);\n if (!entry)\n return;\n await this.delete(this.keyFor(`${entry.iuid}_object`));\n await this.delete(this.keyFor(`${entry.iuid}_data`));\n }\n async deleteByIuid(iuid, name) {\n if (name) {\n await this.deleteNameLookupByName(name);\n }\n await this.deleteNameLookupByIuid(iuid);\n await this.delete(this.keyFor(`${iuid}_object`));\n await this.delete(this.keyFor(`${iuid}_data`));\n }\n async getAllCachedObjects() {\n const db = await this.openDb();\n if (!db)\n return [];\n return new Promise((resolve) => {\n const results = [];\n const tx = db.transaction(CardFsCache.DATA_STORE, \"readonly\");\n const store = tx.objectStore(CardFsCache.DATA_STORE);\n const request = store.openCursor();\n request.onsuccess = (event) => {\n const cursor = event.target.result;\n if (!cursor) {\n resolve(results);\n return;\n }\n const key = cursor.key;\n if (typeof key === \"string\" && key.endsWith(\"_object\")) {\n results.push(cursor.value);\n }\n cursor.continue();\n };\n request.onerror = () => resolve(results);\n });\n }\n}\nCardFsCache.DB_VERSION = 2;\nCardFsCache.DATA_STORE = \"cardfs\";\nCardFsCache.NAME_LOOKUP_STORE = \"cardfs_name_iuid_lookup\";\nCardFsCache.INFO_STORE = \"info\";\nCardFsCache.STORE_VERSION_KEY = \"ver\";\nCardFsCache.MAX_DATA_BYTES = 5 * 1024 * 1024;\n/**\n * Use CardSdk to create webapp cards\n */\nexport class CardSdk extends DomeEmbeddedAppSdk {\n resolveCardFsTarget(target, operation) {\n const normalized = typeof target === \"string\" ? { name: target } : (target ?? {});\n const name = typeof normalized.name === \"string\" ? normalized.name.trim() : undefined;\n const iuid = typeof normalized.iuid === \"string\" ? normalized.iuid.trim() : undefined;\n if (!name && !iuid) {\n throw new Error(`cardsFS.${operation} requires a file name or document iuid`);\n }\n return { name, iuid };\n }\n describeCardFsTarget(target) {\n if (target.name && target.iuid) {\n return `\"${target.name}\" (iuid ${target.iuid})`;\n }\n if (target.name) {\n return `\"${target.name}\"`;\n }\n if (target.iuid) {\n return `iuid ${target.iuid}`;\n }\n return \"document\";\n }\n buildCardFsMessagePayload(target, extra) {\n return {\n ...(target.name ? { name: target.name } : {}),\n ...(target.iuid ? { iuid: target.iuid } : {}),\n ...(extra ?? {}),\n };\n }\n getCardIuid() {\n return this.dataStore?.iuid || null;\n }\n ensureCardFsCache() {\n if (!this.shouldUseCardFsFallback()) {\n return null;\n }\n if (!this.cardFsCache) {\n const cardIuid = this.getCardIuid();\n if (cardIuid) {\n this.cardFsCache = new CardFsCache(cardIuid, this.containerIuid);\n }\n }\n return this.cardFsCache;\n }\n supportsParentCardFs() {\n return !!this.parentCapabilities?.card_fs;\n }\n shouldUseCardFsFallback() {\n return !this.supportsParentCardFs();\n }\n constructor() {\n super();\n this.handler = null; // Handler instance for client messages\n this.accessToken = '';\n this.fileReadResolvers = new Map();\n this.fileWriteResolvers = new Map();\n // Track in-flight FS operations by messageId so we can settle promises on callback\n this.fsReadRequests = new Map();\n this.fsWriteRequests = new Map();\n this.cardFsCache = null;\n this.pendingAcks = new Map();\n // Sets up the message listener for cards to receive messages from the parent.\n this.handleMessage = (type, data) => {\n if (type === ClientMessageType.INIT_ACK) {\n this.updateParentContext(data?.host, data?.capabilities);\n }\n if (!this.handler) {\n throw new Error(\"Message handler not found!\");\n }\n // Check for ACK response with messageId\n const messageId = data?.messageId;\n if (messageId && this.pendingAcks.has(messageId)) {\n const { resolve, timeout } = this.pendingAcks.get(messageId);\n clearTimeout(timeout);\n this.pendingAcks.delete(messageId);\n resolve(data);\n return;\n }\n switch (type) {\n case ClientMessageType.INIT_ACK:\n // Parent sent INIT_ACK\n console.debug(\"CardSdk: INIT_ACK received\");\n this.dataStore.kw1 = data.key_wa1;\n this.dataStore.iuid = data.iuid;\n if (data.iuid) {\n if (this.shouldUseCardFsFallback()) {\n this.cardFsCache = new CardFsCache(data.iuid, this.containerIuid);\n }\n else {\n this.cardFsCache = null;\n }\n }\n else if (!this.shouldUseCardFsFallback()) {\n this.cardFsCache = null;\n }\n try {\n this.cryptoA01.decrypt(this.dataStore.denc, data.key_wa1 + this.dataStore.kw2, data.iuid)\n .then((decData) => {\n console.debug(\"CardSdk: INIT_ACK: decrypted data \", decData);\n const decryptedData = JSON.parse(decData);\n const decryptedContainerIuid = decryptedData?.container?.iuid;\n if (decryptedContainerIuid) {\n this.containerIuid = decryptedContainerIuid;\n if (this.shouldUseCardFsFallback() && this.dataStore?.iuid) {\n this.cardFsCache = new CardFsCache(this.dataStore.iuid, this.containerIuid);\n }\n }\n const apiToken = typeof decryptedData?.api_token === \"string\" ? decryptedData.api_token.trim() : \"\";\n if (apiToken) {\n this.accessToken = apiToken;\n console.debug(\"CardSdk: Stored API token from INIT_ACK payload\");\n }\n else {\n console.warn(\"CardSdk: INIT_ACK payload missing api_token; fallback APIs may fail without auth\");\n }\n if (this.handler)\n this.safeInvoke(\"onInit\", this.handler, { ...decryptedData, ui: data.ui });\n // no need for orig enc data.. free to delete it\n delete this.dataStore.denc;\n })\n .catch((err) => {\n console.error(\"Final decrypt error\", err);\n throw err;\n });\n }\n catch (err) {\n console.error(\"Decryption failed!\", err);\n this.sendEventError('dec2_failed', err.message);\n }\n break;\n case ClientMessageType.FILE_DATA: {\n const responseId = data?.messageId;\n if (responseId && this.fsReadRequests.has(responseId)) {\n // cardsFS.read payload from parent (cached or fresh)\n const { messageId: _ignored, ...payload } = data || {};\n this.handleFsReadDataMessage(responseId, payload);\n return;\n }\n const fileName = data?.name;\n if (fileName && this.fileReadResolvers.has(fileName)) {\n const resolver = this.fileReadResolvers.get(fileName);\n this.fileReadResolvers.delete(fileName);\n resolver(data);\n }\n else {\n console.warn(\"CardSdk: FILE_DATA received but no resolver found for\", fileName);\n }\n break;\n }\n case ClientMessageType.DATA_CHANGE:\n this.safeInvoke(\"onFileChange\", this.handler, data);\n case ClientMessageType.SAVE_SUCCESS: {\n const responseId = data?.messageId;\n if (responseId && this.fsWriteRequests.has(responseId)) {\n // cardsFS write/list/delete success routed by messageId\n this.handleFsWriteSuccess(responseId, data);\n return;\n }\n const savedName = data?.name;\n if (savedName && this.fileWriteResolvers.has(savedName)) {\n const { resolve } = this.fileWriteResolvers.get(savedName);\n this.fileWriteResolvers.delete(savedName);\n resolve();\n }\n else {\n console.warn(\"CardSdk: SAVE_SUCCESS received but no resolver found for\", savedName);\n }\n break;\n }\n case ClientMessageType.SAVE_ERROR: {\n const responseId = data?.messageId;\n if (responseId && this.fsWriteRequests.has(responseId)) {\n // cardsFS write/list/delete failure routed by messageId\n this.handleFsWriteError(responseId, data);\n return;\n }\n const failedName = data?.name;\n if (failedName && this.fileWriteResolvers.has(failedName)) {\n const { reject } = this.fileWriteResolvers.get(failedName);\n this.fileWriteResolvers.delete(failedName);\n reject(new Error(data?.message || 'Unknown write error'));\n }\n else {\n console.warn(\"CardSdk: SAVE_ERROR received but no resolver found for\", failedName);\n }\n break;\n }\n case ClientMessageType.ERROR: {\n const responseId = data?.messageId;\n if (responseId) {\n const message = data?.message || 'Unknown error';\n if (this.fsReadRequests.has(responseId)) {\n // cardsFS read error surfaced by the parent\n this.failFsReadRequest(responseId, new Error(message));\n return;\n }\n if (this.fsWriteRequests.has(responseId)) {\n // cardsFS write/delete/list error surfaced by the parent\n this.failFsWriteRequest(responseId, new Error(message));\n return;\n }\n }\n // Parent sent an ERROR\n this.safeInvoke(\"onError\", this.handler, data);\n break;\n }\n case ClientMessageType.REFRESH:\n // Asking for UI refresh\n this.safeInvoke(\"onRefreshRequest\", this.handler, data);\n break;\n default:\n console.warn(`No handler found for message type: ${type}`);\n }\n };\n this.cryptoA01 = new CryptoA01();\n this.cardsFS = {\n read: (target, onUpdate) => this.cardsFsRead(target, onUpdate),\n write: (target, fileData, onResult) => this.cardsFsWrite(target, fileData, onResult),\n delete: (target, onResult) => this.cardsFsDelete(target, onResult),\n list: (onResult) => this.cardsFsList(onResult),\n };\n console.debug(\"CardSdk::constructor: done\");\n }\n /**\n * Static initialization method to get or create the singleton instance of CardSdk.\n * @param secret - The card developer secret key\n * @param handler - (Optional) Handler for different events emitted by the SDK\n * @returns The singleton CardSdk instance\n */\n static async init(secret, handler, options) {\n try {\n console.debug(\"CardSdk::init\");\n if (!CardSdk.instance) {\n CardSdk.instance = new CardSdk();\n // Initialize parent communication - REQUIRED!\n CardSdk.instance.setupParentConnection()\n .then(() => {\n // Connection established with parents..\n // Initialize SDK in async\n CardSdk.instance.initializeCardSdk(secret);\n })\n .catch((err) => {\n console.error(err);\n });\n }\n else {\n return CardSdk.instance;\n }\n // Setup handlers\n if (handler) {\n CardSdk.instance.setHandler(handler); // Set handler if provided during initialization\n }\n return CardSdk.instance;\n }\n catch (err) {\n console.error(\"CardSdk: Unrecoverable error in init\", err);\n throw err;\n }\n }\n /**\n * Method to set or update the handler object.\n * @param handler - Custom handler for different message types\n */\n setHandler(handler) {\n this.handler = handler;\n }\n /**\n * Sends a deep link request to the parent directly from the card.\n */\n openDeepLink(href) {\n if (!this.emitDeepLink(href)) {\n console.warn(\"openDeepLink ignored; provide a dome:// or intouchapp:// href\");\n }\n }\n // Function to initialize SDK after instance is created\n async initializeCardSdk(secret) {\n let TAG = \"CardSdk::initializeCardSdk:\";\n try {\n console.debug(TAG, \"enter\");\n if (!secret) {\n throw new Error(\"Invalid secret\");\n }\n // Get data from HTML\n const data_af1 = window.IT_DATA_AF1;\n if (!data_af1) {\n console.error(TAG, \"No data\");\n throw new Error('No data');\n }\n const url = window.location.href;\n console.debug(TAG, \"url:\", url);\n const urlObject = new URL(url);\n // Take the string between /wa/ and / \n let url_part = urlObject.pathname.split(\"/wa/\").filter(Boolean)[1].split(\"/\")[0];\n const ss = url_part.split('').reverse().join('').substring(4, 25);\n console.debug(TAG, \"ss:\", ss);\n if (!ss) {\n throw new Error('Cannot decrypt (1)');\n }\n const decData = await this.cryptoA01.decrypt(data_af1, secret, ss);\n try {\n const dataFromServer = JSON.parse(decData);\n console.debug(\"CardSdk: dataFromServer:\", dataFromServer);\n if (!dataFromServer.ite) {\n throw new Error(\"Invalid data\");\n }\n this.dataStore = {\n 'denc': dataFromServer.d,\n 'kw2': dataFromServer.kw2\n };\n CardSdk.instance.sendInit(dataFromServer.ite);\n }\n catch (err) {\n console.error(\"Initial Decryption failed (2):\", err);\n throw err;\n }\n }\n catch (err) {\n console.error(TAG, \"Init failed:\", err);\n this.sendEventError('init_failed', err.message);\n }\n }\n async sendInit(token) {\n this.sendMessage(CardMessageType.INIT, { 'token': token, sdk: { ver: pkg.version } });\n }\n sendMessageWithAck(type, data, ackType, timeoutMs = 15000, onMessageId) {\n const messageId = crypto.randomUUID();\n if (onMessageId) {\n try {\n onMessageId(messageId);\n }\n catch (err) {\n return Promise.reject(err);\n }\n }\n return new Promise((resolve, reject) => {\n const timeout = setTimeout(() => {\n this.pendingAcks.delete(messageId);\n reject(new Error(`${ackType} not received in time`));\n }, timeoutMs);\n this.pendingAcks.set(messageId, { resolve, reject, timeout });\n this.sendMessage(type, { ...data, messageId });\n });\n }\n // cardsSdk.cardsFS.read implementation - resolves on first response, optional onUpdate for subsequent payloads\n cardsFsRead(targetInput, onUpdate) {\n let target;\n try {\n target = this.resolveCardFsTarget(targetInput, \"read\");\n }\n catch (err) {\n return Promise.reject(err);\n }\n if (this.shouldUseCardFsFallback()) {\n console.debug(\"cardsFS.read using fallback implementation for\", target);\n return this.cardsFsReadFallback(target, undefined, onUpdate);\n }\n console.debug(\"cardsFS.read delegating to parent for\", target);\n return new Promise((resolve, reject) => {\n let registeredMessageId = null;\n const targetLabel = this.describeCardFsTarget(target);\n const registerRequest = (messageId) => {\n registeredMessageId = messageId;\n // Track this read so FILE_DATA updates can resolve the promise or stream via onUpdate\n const request = {\n name: targetLabel,\n onUpdate,\n resolve,\n reject,\n hasResolved: false,\n };\n request.noResponseTimeout = setTimeout(() => {\n this.failFsReadRequest(messageId, new Error(`cardsFS.read timed out for ${targetLabel}`));\n }, CardSdk.FS_RESPONSE_TIMEOUT_MS);\n this.fsReadRequests.set(messageId, request);\n };\n // Parent ACK provides a messageId that subsequent FILE_DATA responses will reuse\n this.sendMessageWithAck(CardMessageType.READ_FILE, this.buildCardFsMessagePayload(target), ClientMessageType.READ_FILE_ACK, CardSdk.CARD_FS_ACK_TIMEOUT_MS, registerRequest).catch((err) => {\n const error = err instanceof Error ? err : new Error(String(err));\n if (registeredMessageId) {\n this.failFsReadRequest(registeredMessageId, error);\n }\n else {\n reject(error);\n }\n });\n });\n }\n // cardsSdk.cardsFS.write - resolves when parent confirms write\n cardsFsWrite(targetInput, fileData, onResult) {\n let target;\n try {\n target = this.resolveCardFsTarget(targetInput, \"write\");\n }\n catch (err) {\n return Promise.reject(err);\n }\n if (this.shouldUseCardFsFallback()) {\n console.debug(\"cardsFS.write using fallback implementation for\", target);\n return this.cardsFsWriteFallback(target, fileData)\n .then((result) => {\n try {\n onResult?.(result);\n }\n catch (callbackErr) {\n console.error(\"cardsFS.write fallback callback threw\", callbackErr);\n }\n return result;\n });\n }\n console.debug(\"cardsFS.write delegating to parent for\", target);\n return new Promise((resolve, reject) => {\n let registeredMessageId = null;\n const targetLabel = this.describeCardFsTarget(target);\n const registerRequest = (messageId) => {\n registeredMessageId = messageId;\n const request = {\n name: targetLabel,\n onResult,\n resolve,\n reject,\n timeout: setTimeout(() => {\n this.failFsWriteRequest(messageId, new Error(`cardsFS.write timed out for ${targetLabel}`));\n }, CardSdk.FS_RESPONSE_TIMEOUT_MS),\n };\n this.fsWriteRequests.set(messageId, request);\n };\n this.sendMessageWithAck(CardMessageType.WRITE_FILE, this.buildCardFsMessagePayload(target, { data: fileData }), ClientMessageType.WRITE_FILE_ACK, CardSdk.CARD_FS_ACK_TIMEOUT_MS, registerRequest).catch((err) => {\n const error = err instanceof Error ? err : new Error(String(err));\n if (registeredMessageId) {\n this.failFsWriteRequest(registeredMessageId, error);\n }\n else {\n reject(error);\n }\n });\n });\n }\n // cardsSdk.cardsFS.delete - simple request/ack flow\n cardsFsDelete(targetInput, onResult) {\n let target;\n try {\n target = this.resolveCardFsTarget(targetInput, \"delete\");\n }\n catch (err) {\n return Promise.reject(err);\n }\n if (this.shouldUseCardFsFallback()) {\n console.debug(\"cardsFS.delete using fallback implementation for\", target);\n return this.cardsFsDeleteFallback(target)\n .then((result) => {\n try {\n onResult?.(result);\n }\n catch (callbackErr) {\n console.error(\"cardsFS.delete fallback callback threw\", callbackErr);\n }\n return result;\n });\n }\n console.debug(\"cardsFS.delete delegating to parent for\", target);\n return new Promise((resolve, reject) => {\n this.sendMessageWithAck(CardMessageType.DELETE_FILE, this.buildCardFsMessagePayload(target), ClientMessageType.DELETE_FILE_ACK, CardSdk.CARD_FS_ACK_TIMEOUT_MS)\n .then((data) => {\n const { messageId: _ignored, ...result } = data || {};\n onResult?.(result);\n resolve(result);\n })\n .catch((err) => {\n reject(err instanceof Error ? err : new Error(String(err)));\n });\n });\n }\n // cardsSdk.cardsFS.list - returns metadata list provided by parent\n cardsFsList(onResult) {\n if (this.shouldUseCardFsFallback()) {\n console.debug(\"cardsFS.list using fallback implementation\");\n return this.cardsFsListFallback()\n .then((result) => {\n try {\n onResult?.(result);\n }\n catch (callbackErr) {\n console.error(\"cardsFS.list fallback callback threw\", callbackErr);\n }\n return result;\n });\n }\n console.debug(\"cardsFS.list delegating to parent\");\n return new Promise((resolve, reject) => {\n this.sendMessageWithAck(CardMessageType.LIST_FILES, {}, ClientMessageType.LIST_FILES_ACK, CardSdk.CARD_FS_ACK_TIMEOUT_MS)\n .then((data) => {\n const { messageId: _ignored, ...result } = data || {};\n onResult?.(result);\n resolve(result);\n })\n .catch((err) => {\n reject(err instanceof Error ? err : new Error(String(err)));\n });\n });\n }\n // Handle FILE_DATA updates (cached + fresh) for cardsFS.read\n handleFsReadDataMessage(messageId, payload) {\n const request = this.fsReadRequests.get(messageId);\n if (!request)\n return;\n if (request.noResponseTimeout) {\n clearTimeout(request.noResponseTimeout);\n request.noResponseTimeout = undefined;\n }\n if (typeof request.onUpdate === \"function\") {\n try {\n request.onUpdate(payload);\n }\n catch (err) {\n console.error(\"cardsFS.read callback threw\", err);\n }\n }\n if (!request.hasResolved) {\n // Resolve the original promise only once (typically cached data or the first fresh payload)\n request.hasResolved = true;\n request.resolve(payload);\n }\n if (request.cleanupTimeout) {\n clearTimeout(request.cleanupTimeout);\n }\n request.cleanupTimeout = setTimeout(() => {\n this.clearFsReadRequest(messageId);\n }, CardSdk.FS_READ_RETENTION_MS);\n }\n // Remove read request bookkeeping and clear timers\n clearFsReadRequest(messageId) {\n const request = this.fsReadRequests.get(messageId);\n if (!request)\n return undefined;\n if (request.noResponseTimeout) {\n clearTimeout(request.noResponseTimeout);\n }\n if (request.cleanupTimeout) {\n clearTimeout(request.cleanupTimeout);\n }\n this.fsReadRequests.delete(messageId);\n return request;\n }\n failFsReadRequest(messageId, error) {\n const request = this.clearFsReadRequest(messageId);\n if (request) {\n request.reject(error);\n }\n }\n // Remove write request bookkeeping\n clearFsWriteRequest(messageId) {\n const request = this.fsWriteRequests.get(messageId);\n if (!request)\n return undefined;\n clearTimeout(request.timeout);\n this.fsWriteRequests.delete(messageId);\n return request;\n }\n failFsWriteRequest(messageId, error) {\n const request = this.clearFsWriteRequest(messageId);\n if (request) {\n request.reject(error);\n }\n }\n // Resolve write/list/delete promise with payload and invoke optional callback\n handleFsWriteSuccess(messageId, payload) {\n const request = this.clearFsWriteRequest(messageId);\n if (!request)\n return;\n const { messageId: _ignored, ...result } = payload || {};\n if (typeof request.onResult === \"function\") {\n try {\n request.onResult(result);\n }\n catch (err) {\n console.error(\"cardsFS.write callback threw\", err);\n }\n }\n request.resolve(result);\n }\n handleFsWriteError(messageId, payload) {\n const request = this.clearFsWriteRequest(messageId);\n if (!request)\n return;\n const errorMessage = payload?.message || 'Unknown write error';\n const error = payload instanceof Error ? payload : new Error(errorMessage);\n request.reject(error);\n }\n async cardsFsReadFallback(target, requestId, onUpdate) {\n if (!this.shouldUseCardFsFallback()) {\n throw new Error(\"cardsFS.read fallback is disabled because parent supports card_fs\");\n }\n const cardIuid = this.getCardIuid();\n if (!cardIuid) {\n throw new Error(\"cardsFS.read fallback failed: card not initialized\");\n }\n const cache = this.ensureCardFsCache();\n let firstPayload = null;\n const targetLabel = this.describeCardFsTarget(target);\n const emit = (object, data, fromCache, explicitName, explicitIuid) => {\n if (!object)\n return;\n const payloadName = explicitName ?? target.name ?? object?.name ?? target.iuid ?? \"document\";\n const payloadIuid = explicitIuid ?? object?.iuid ?? target.iuid ?? null;\n const messagePayload = {\n name: payloadName,\n iuid: payloadIuid,\n object,\n data,\n from_cache: fromCache,\n };\n if (requestId && this.fsReadRequests.has(requestId)) {\n this.handleFsReadDataMessage(requestId, messagePayload);\n }\n else if (typeof onUpdate === \"function\") {\n try {\n onUpdate(messagePayload);\n }\n catch (err) {\n console.error(\"cardsFS.read fallback callback threw\", err);\n }\n }\n if (!firstPayload) {\n firstPayload = messagePayload;\n }\n };\n if (cache) {\n try {\n let cached = null;\n if (target.iuid) {\n cached = await cache.getByIuid(target.iuid);\n }\n if (!cached && target.name) {\n cached = await cache.getByName(target.name);\n }\n if (cached?.object) {\n emit(cached.object, cached.data, true, cached.object?.name ?? target.name, cached.iuid);\n }\n }\n catch (err) {\n console.warn(\"cardsFS.read cache lookup failed\", err);\n }\n }\n try {\n const freshPayload = await this.fetchDocumentPayload(cardIuid, target);\n if (freshPayload) {\n await cache?.cacheDocument(freshPayload.object, freshPayload.data);\n emit(freshPayload.object, freshPayload.data, false, freshPayload.object?.name, freshPayload.object?.iuid);\n }\n }\n catch (err) {\n if (!firstPayload) {\n throw err;\n }\n console.warn(\"cardsFS.read fresh fetch failed\", err);\n }\n if (!firstPayload) {\n throw new Error(`cardsFS.read fallback could not locate ${targetLabel}`);\n }\n return firstPayload;\n }\n async cardsFsWriteFallback(target, fileData, requestId) {\n if (!this.shouldUseCardFsFallback()) {\n throw new Error(\"cardsFS.write fallback is disabled because parent supports card_fs\");\n }\n const cardIuid = this.getCardIuid();\n if (!cardIuid) {\n throw new Error(\"cardsFS.write fallback failed: card not initialized\");\n }\n console.debug(\"cardsFS.write fallback invoked for target\", target);\n await this.upsertDocumentViaApi(cardIuid, target, fileData);\n const payload = await this.fetchDocumentPayload(cardIuid, target);\n await this.ensureCardFsCache()?.cacheDocument(payload.object, payload.data);\n const enrichedPayload = {\n name: payload.object?.name ?? target.name ?? target.iuid ?? null,\n iuid: payload.object?.iuid ?? target.iuid ?? null,\n object: payload.object,\n data: payload.data,\n };\n if (requestId && this.fsWriteRequests.has(requestId)) {\n this.handleFsWriteSuccess(requestId, enrichedPayload);\n }\n return enrichedPayload;\n }\n async cardsFsDeleteFallback(target) {\n if (!this.shouldUseCardFsFallback()) {\n throw new Error(\"cardsFS.delete fallback is disabled because parent supports card_fs\");\n }\n const cardIuid = this.getCardIuid();\n if (!cardIuid) {\n throw new Error(\"cardsFS.delete fallback failed: card not initialized\");\n }\n console.debug(\"cardsFS.delete fallback invoked for target\", target);\n const cache = this.ensureCardFsCache();\n const doc = await this.fetchDocumentMetadataByTarget(cardIuid, target).catch(() => null);\n const deleteIuid = doc?.iuid ?? target.iuid ?? null;\n const resolvedName = doc?.name ?? target.name ?? null;\n if (!deleteIuid) {\n if (target.name) {\n await cache?.deleteByName(target.name);\n }\n return { name: resolvedName, iuid: null, deleted: false };\n }\n const response = await fetch(`/api/v1/documents/${deleteIuid}/`, {\n method: 'DELETE',\n headers: this.authHeader(),\n });\n if (!response.ok && response.status !== 404) {\n const message = await response.text().catch(() => 'delete failed');\n throw new Error(`cardsFS.delete fallback failed: ${message}`);\n }\n await cache?.deleteByIuid(deleteIuid, resolvedName ?? undefined);\n const deleted = response.status !== 404;\n return {\n name: resolvedName ?? deleteIuid,\n iuid: deleteIuid,\n deleted,\n };\n }\n async cardsFsListFallback() {\n if (!this.shouldUseCardFsFallback()) {\n throw new Error(\"cardsFS.list fallback is disabled because parent supports card_fs\");\n }\n const cardIuid = this.getCardIuid();\n if (!cardIuid) {\n throw new Error(\"cardsFS.list fallback failed: card not initialized\");\n }\n const cache = this.ensureCardFsCache();\n try {\n const documents = await this.fetchAllDocuments(cardIuid);\n if (cache) {\n for (const doc of documents) {\n await cache.cacheDocument(doc, undefined);\n }\n }\n return { documents, from_cache: false };\n }\n catch (err) {\n const cachedDocs = await cache?.getAllCachedObjects();\n if (cachedDocs && cachedDocs.length > 0) {\n return { documents: cachedDocs, from_cache: true };\n }\n throw err;\n }\n }\n authHeader() {\n return this.accessToken ? { 'Authorization': `Bearer ${this.accessToken}` } : {};\n }\n jsonHeaders() {\n return { ...this.authHeader(), 'Content-Type': 'application/json' };\n }\n async fetchDocumentMetadataByTarget(cardIuid, target) {\n if (target.iuid) {\n return this.fetchDocumentMetadataByIuid(target.iuid);\n }\n if (target.name) {\n return this.fetchDocumentMetadataByName(cardIuid, target.name);\n }\n return null;\n }\n async fetchDocumentMetadataByIuid(iuid) {\n const response = await fetch(`/api/v1/documents/${iuid}/`, {\n method: 'GET',\n headers: this.authHeader(),\n });\n if (response.status === 404) {\n return null;\n }\n if (!response.ok) {\n const message = await response.text().catch(() => 'metadata lookup failed');\n throw new Error(`cardsFS metadata fetch failed: ${message}`);\n }\n return response.json().catch(() => null);\n }\n normalizeDocumentsResponse(body) {\n if (Array.isArray(body?.results)) {\n return body.results;\n }\n if (Array.isArray(body)) {\n return body;\n }\n return body ? [body] : [];\n }\n extractHttpErrorMessage(error, fallback) {\n if (!error) {\n return fallback;\n }\n if (typeof error === \"string\") {\n return error;\n }\n if (error instanceof Error && error.message) {\n return error.message;\n }\n const payload = error?.error ?? error;\n if (payload instanceof Blob) {\n return fallback;\n }\n if (typeof payload === \"string\") {\n return payload;\n }\n if (payload?.detail) {\n return payload.detail;\n }\n if (payload?.message) {\n return payload.message;\n }\n if (typeof payload?.statusText === \"string\" && payload.statusText.trim()) {\n return payload.statusText;\n }\n return fallback;\n }\n async fetchDocumentMetadataByName(cardIuid, name) {\n if (!name)\n return null;\n const response = await fetch(`/api/v1/documents/with_card/${cardIuid}/?name=${encodeURIComponent(name)}`, {\n method: 'GET',\n headers: this.authHeader(),\n });\n if (!response.ok) {\n if (response.status === 404)\n return null;\n const message = await response.text().catch(() => 'metadata lookup failed');\n throw new Error(`cardsFS metadata fetch failed: ${message}`);\n }\n const body = await response.json().catch(() => null);\n const documents = this.normalizeDocumentsResponse(body);\n return documents.find((doc) => doc?.name === name) ?? documents[0] ?? null;\n }\n async fetchAllDocuments(cardIuid) {\n const response = await fetch(`/api/v1/documents/with_card/${cardIuid}/`, {\n method: 'GET',\n headers: this.authHeader(),\n });\n if (!response.ok) {\n const message = await response.text().catch(() => 'list failed');\n throw new Error(`cardsFS.list failed: ${message}`);\n }\n const body = await response.json().catch(() => null);\n return this.normalizeDocumentsResponse(body);\n }\n async fetchDocumentPayload(cardIuid, target) {\n const resolvedTarget = typeof target === \"string\" ? { name: target } : target;\n const doc = await this.fetchDocumentMetadataByTarget(cardIuid, resolvedTarget);\n if (!doc) {\n throw new Error(`cardsFS document not found: ${this.describeCardFsTarget(resolvedTarget)}`);\n }\n const data = await this.fetchDocumentData(doc);\n return { object: doc, data };\n }\n async fetchDocumentData(doc) {\n if (doc?.data !== undefined) {\n return doc.data;\n }\n const url = doc?.orig?.url || doc?.url?.original || doc?.url;\n if (!url || typeof url !== 'string') {\n return null;\n }\n const response = await fetch(url);\n if (!response.ok) {\n const message = await response.text().catch(() => 'download failed');\n throw new Error(`cardsFS data fetch failed: ${message}`);\n }\n const contentType = response.headers.get('Content-Type') || '';\n if (contentType.includes('application/json')) {\n return response.json();\n }\n if (contentType.startsWith('text/')) {\n return response.text();\n }\n return response.arrayBuffer();\n }\n async buildFileFormData(name, fileData) {\n let file;\n const toBinaryBlob = (input) => {\n if (input instanceof ArrayBuffer) {\n return new Blob([input.slice(0)], { type: 'application/octet-stream' });\n }\n if (typeof SharedArrayBuffer !== 'undefined' && input instanceof SharedArrayBuffer) {\n const viewFromShared = new Uint8Array(input);\n const copy = new Uint8Array(viewFromShared.length);\n copy.set(viewFromShared);\n return new Blob([copy.buffer], { type: 'application/octet-stream' });\n }\n if (ArrayBuffer.isView(input)) {\n const view = new Uint8Array(input.buffer, input.byteOffset, input.byteLength);\n const copy = new Uint8Array(view.length);\n copy.set(view);\n return new Blob([copy.buffer], { type: 'application/octet-stream' });\n }\n const arrayBufferLike = input;\n const view = new Uint8Array(arrayBufferLike);\n const copy = new Uint8Array(view.length);\n copy.set(view);\n return new Blob([copy.buffer], { type: 'application/octet-stream' });\n };\n if (fileData instanceof File) {\n file = fileData;\n }\n else if (typeof Blob !== 'undefined' && fileData instanceof Blob) {\n file = new File([fileData], name, { type: fileData.type || 'application/octet-stream' });\n }\n else if (typeof SharedArrayBuffer !== 'undefined' && fileData instanceof SharedArrayBuffer) {\n const blob = toBinaryBlob(fileData);\n file = new File([blob], name, { type: blob.type });\n }\n else if (fileData instanceof ArrayBuffer) {\n const blob = toBinaryBlob(fileData);\n file = new File([blob], name, { type: blob.type });\n }\n else if (ArrayBuffer.isView(fileData)) {\n const blob = toBinaryBlob(fileData);\n file = new File([blob], name, { type: blob.type });\n }\n else if (typeof fileData === 'string') {\n const blob = new Blob([fileData], { type: 'text/plain' });\n file = new File([blob], name, { type: blob.type });\n }\n else {\n const jsonString = JSON.stringify(fileData ?? {});\n const blob = new Blob([jsonString], { type: 'application/json' });\n file = new File([blob], name, { type: blob.type });\n }\n const formData = new FormData();\n formData.append('file', file);\n return formData;\n }\n async upsertDocumentViaApi(cardIuid, target, fileData) {\n const formData = await this.buildFileFormData(target.name ?? target.iuid ?? 'document', fileData);\n if (target.iuid) {\n const response = await fetch(`/api/v1/documents/${target.iuid}/`, {\n method: 'PUT',\n headers: this.authHeader(),\n body: formData,\n });\n if (!response.ok) {\n const message = await response.text().catch(() => 'update failed');\n throw new Error(`cardsFS.write update failed: ${message}`);\n }\n return;\n }\n const existing = target.name\n ? await this.fetchDocumentMetadataByName(cardIuid, target.name).catch(() => null)\n : null;\n if (existing?.iuid) {\n const response = await fetch(`/api/v1/documents/${existing.iuid}/`, {\n method: 'PUT',\n headers: this.authHeader(),\n body: formData,\n });\n if (!response.ok) {\n const message = await response.text().catch(() => 'update failed');\n throw new Error(`cardsFS.write update failed: ${message}`);\n }\n return;\n }\n const uploadResponse = await fetch(`/api/v1/documents/`, {\n method: 'POST',\n headers: this.authHeader(),\n body: formData,\n });\n if (!uploadResponse.ok) {\n const message = await uploadResponse.text().catch(() => 'upload failed');\n throw new Error(`cardsFS.write upload failed: ${message}`);\n }\n const uploadBody = await uploadResponse.json().catch(() => null);\n const uploadedDoc = Array.isArray(uploadBody?.results) ? uploadBody.results[0] : uploadBody;\n const newIuid = uploadedDoc?.iuid;\n if (!newIuid) {\n throw new Error('cardsFS.write upload failed: missing document iuid');\n }\n const attachResponse = await fetch(`/api/v1/documents/with_card/${cardIuid}/`, {\n method: 'POST',\n headers: this.jsonHeaders(),\n body: JSON.stringify({ documents: [newIuid] }),\n });\n if (!attachResponse.ok) {\n const message = await attachResponse.text().catch(() => 'attach failed');\n throw new Error(`cardsFS.write attach failed: ${message}`);\n }\n }\n /**\n * Get document associated with the current card\n */\n async getDocumentAttachedToCard(card_iuid, document_name = 'default') {\n const url = new URL(`/api/v1/documents/attached_to/${card_iuid}/`);\n url.searchParams.set('name', document_name);\n const response = await fetch(url.toString(), {\n method: 'GET',\n headers: {\n 'Authorization': `Bearer ${this.accessToken || ''}`,\n 'Content-Type': 'application/json'\n }\n });\n if (!response.ok) {\n const error = await response.text();\n throw new Error(`Fetch failed: ${error}`);\n }\n return response.json();\n }\n /**\n * Save document attached to current card\n */\n async postDocumentAttachedToCard(card_iuid, document) {\n const response = await fetch(`/api/v1/documents/attached_to/${card_iuid}/`, {\n method: 'POST',\n headers: {\n 'Authorization': `Bearer ${this.accessToken || ''}`,\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(document)\n });\n if (!response.ok) {\n const error = await response.text();\n throw new Error(`Post failed: ${error}`);\n }\n return response.json();\n }\n async getCardDocument(card_iuid, doc_name) {\n const response = await fetch(`/api/v1/documents/with_card/${card_iuid}/?name=${doc_name}`, {\n method: 'GET',\n headers: {\n 'Authorization': `Bearer ${this.accessToken || ''}`,\n 'Content-Type': 'application/json',\n },\n });\n const data = await response.json();\n return data;\n }\n // Send event on error (clients will get \"onError\" event)\n formatErrorMessage(input) {\n if (typeof input === \"string\" && input.trim()) {\n return input;\n }\n if (input instanceof Error) {\n return input.message || input.toString();\n }\n if (input && typeof input === \"object\") {\n if (typeof input.message === \"string\") {\n return input.message;\n }\n try {\n return JSON.stringify(input);\n }\n catch {\n return Object.prototype.toString.call(input);\n }\n }\n if (input != null) {\n return String(input);\n }\n return \"Unknown error\";\n }\n sendEventError(error_code, message, data = undefined) {\n const data_to_send = {\n message: this.formatErrorMessage(message),\n error_code,\n data: data ?? null,\n };\n if (this.handler)\n this.safeInvoke(\"onError\", this.handler, data_to_send);\n }\n setFileDirty(data) {\n this.sendMessage(CardMessageType.FILE_DIRTY, data);\n }\n // Get username string from user object received from parent\n getUsername(userObj) {\n const nameObj = userObj?.name;\n if (nameObj && Object.values(nameObj).some(value => value)) {\n return getNameString(nameObj);\n }\n return '';\n }\n}\n// How long we wait for parent responses before rejecting (ms)\nCardSdk.FS_RESPONSE_TIMEOUT_MS = 30000;\n// Keep read handlers alive briefly to allow cached+fresh events (ms)\nCardSdk.FS_READ_RETENTION_MS = 5000;\nCardSdk.CARD_FS_ACK_TIMEOUT_MS = 5000;\n","/**\n * Helper function to generate a unique requestId (UUID).\n * This uses the browser's crypto API for random UUID generation.\n */\nexport function generateUUID() {\n // If in a browser environment with crypto support (modern browsers)\n if (typeof window !== 'undefined' && window.crypto && window.crypto.randomUUID) {\n return window.crypto.randomUUID();\n }\n // Fallback for non-browser environments (e.g., Node.js)\n if (typeof crypto !== 'undefined' && crypto.randomUUID) {\n return crypto.randomUUID();\n }\n // Fallback for environments without crypto support\n throw new Error('UUID generation is not supported in this environment');\n}\n/**\n * Helper function to get username from user object\n * @param nameObj the user object\n */\nexport function getNameString(nameObj) {\n const { prefix = '', given = '', middle = '', family = '', suffix = '' } = nameObj || {};\n const fullname = [prefix, given, middle, family, suffix].filter(namePart => namePart).join(' ');\n return fullname.trim();\n}\n"],"names":["root","factory","exports","module","define","amd","this","__webpack_require__","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","Symbol","toStringTag","value","CryptoA01","constructor","subtleCrypto","window","crypto","subtle","Error","decrypt","token","password","salt","tokenBytes","base64UrlDecode","slice","iv","ciphertext","hmacFromToken","fullKey","deriveKey","hmacKey","aesKey","splitKey","hmacInput","Uint8Array","sign","every","byte","i","decrypted","name","TextDecoder","decode","err","console","log","iterations","encoder","TextEncoder","keyMaterial","importKey","encode","hash","length","rawKey","exportKey","base64","base64String","replace","decodedString","atob","map","c","charCodeAt","ViewerMessageType","CommonSdkMessageType","ClientMessageType","Set","location","origin","ALLOWED_DEEP_LINK_PROTOCOLS","DomeEmbeddedAppSdk","targetOrigin","isAppReady","port2","runtimeHost","parentHostDetails","parentCapabilities","handleDeepLinkClick","event","target","Element","anchor","closest","href","getAttribute","emitDeepLink","preventDefault","info","detectHost","setupDeepLinkInterception","AndroidBridge","webkit","document","addEventListener","trim","warn","protocol","split","toLowerCase","has","sendMessage","CardMessageType","OPEN_DEEPLINK","url","updateParentContext","host","capabilities","merged","type","nextCapabilities","host_type","hostType","getHost","data","message","JSON","stringify","messageHandlers","appHandler","postMessage","error","sendAppInit","INIT","sdk","ver","safeInvoke","eventName","handlerObj","handler","String","setupParentConnection","Promise","resolve","reject","receiveFromAndroid","handleMessage","receiveFromIOS","CONNECT","ports","onmessage","e","handlePortMessage","removeEventListener","notifyConnectionSuccess","parent","INIT_MESSAGE_CHANNEL","CONNECTION_SUCCESS","ViewerSdk","super","pendingRequests","Map","pendingInitAck","init","initialized","instance","then","initializeViewerSdk","catch","trace","setHandler","canRead","perms","includes","canWrite","requestInitialData","REQUEST_INITIAL_DATA","requestSave","doc","isDataDirty","requestId","randomUUID","generateUUID","REQUEST_SAVE","set","setTimeout","delete","handleOnSave","status","setDirty","isDirty","SET_DIRTY","sendClose","SEND_CLOSE","sendException","SEND_EXCEPTION","INIT_ACK","DATA_CHANGE","REQUEST_CLOSE","SAVE_SUCCESS","SAVE_ERROR","CardFsCache","cardIuid","containerIuid","openPromise","isSupported","indexedDB","openDb","openWithVersion","DB_VERSION","version","infoAction","request","open","onupgradeneeded","oldVersion","configureStores","result","onsuccess","db","hasRequiredStores","nextVersion","close","updateStoresMetadata","finally","onerror","objectStoreNames","contains","DATA_STORE","createObjectStore","NAME_LOOKUP_STORE","INFO_STORE","stores","nowMicros","Math","trunc","Date","now","preserveExistingInfoTs","all","ensureStoreVersion","updateCardInfo","storeName","tx","transaction","store","objectStore","finalize","oncomplete","onabort","put","STORE_VERSION_KEY","preserveExistingTs","existingContainer","readInfoValue","existingTs","undefined","containerValue","timestampValue","writeInfoValue","keyFor","suffix","normalizeName","trimmed","hashName","cryptoRef","globalThis","digest","encoded","encodeText","bufferToBase64","buffer","binary","bytes","fromCharCode","btoa","getIuidForName","normalized","hashed","upsertNameLookup","iuid","openCursor","cursor","continue","deleteNameLookupByName","deleteNameLookupByIuid","estimateSize","Blob","size","ArrayBuffer","byteLength","isView","cacheDocument","normalizedName","MAX_DATA_BYTES","getByName","object","getByIuid","deleteByName","entry","deleteByIuid","getAllCachedObjects","results","endsWith","push","CardSdk","resolveCardFsTarget","operation","describeCardFsTarget","buildCardFsMessagePayload","extra","getCardIuid","dataStore","ensureCardFsCache","shouldUseCardFsFallback","cardFsCache","supportsParentCardFs","card_fs","accessToken","fileReadResolvers","fileWriteResolvers","fsReadRequests","fsWriteRequests","pendingAcks","messageId","timeout","clearTimeout","kw1","key_wa1","cryptoA01","denc","kw2","decData","decryptedData","parse","decryptedContainerIuid","container","apiToken","api_token","ui","sendEventError","FILE_DATA","responseId","_ignored","payload","handleFsReadDataMessage","fileName","resolver","handleFsWriteSuccess","savedName","handleFsWriteError","failedName","ERROR","failFsReadRequest","failFsWriteRequest","REFRESH","cardsFS","read","onUpdate","cardsFsRead","write","fileData","onResult","cardsFsWrite","cardsFsDelete","list","cardsFsList","secret","options","initializeCardSdk","openDeepLink","TAG","data_af1","IT_DATA_AF1","ss","URL","pathname","filter","Boolean","reverse","join","substring","dataFromServer","ite","d","sendInit","sendMessageWithAck","ackType","timeoutMs","onMessageId","targetInput","cardsFsReadFallback","registeredMessageId","targetLabel","READ_FILE","READ_FILE_ACK","CARD_FS_ACK_TIMEOUT_MS","hasResolved","noResponseTimeout","FS_RESPONSE_TIMEOUT_MS","cardsFsWriteFallback","callbackErr","WRITE_FILE","WRITE_FILE_ACK","cardsFsDeleteFallback","DELETE_FILE","DELETE_FILE_ACK","cardsFsListFallback","LIST_FILES","LIST_FILES_ACK","cleanupTimeout","clearFsReadRequest","FS_READ_RETENTION_MS","clearFsWriteRequest","cache","firstPayload","emit","fromCache","explicitName","explicitIuid","messagePayload","from_cache","cached","freshPayload","fetchDocumentPayload","upsertDocumentViaApi","enrichedPayload","fetchDocumentMetadataByTarget","deleteIuid","resolvedName","deleted","response","fetch","method","headers","authHeader","ok","text","documents","fetchAllDocuments","cachedDocs","jsonHeaders","fetchDocumentMetadataByIuid","fetchDocumentMetadataByName","json","normalizeDocumentsResponse","body","Array","isArray","extractHttpErrorMessage","fallback","detail","statusText","encodeURIComponent","find","resolvedTarget","fetchDocumentData","orig","original","contentType","startsWith","arrayBuffer","buildFileFormData","file","toBinaryBlob","input","SharedArrayBuffer","viewFromShared","copy","view","byteOffset","File","blob","jsonString","formData","FormData","append","existing","uploadResponse","uploadBody","uploadedDoc","newIuid","attachResponse","getDocumentAttachedToCard","card_iuid","document_name","searchParams","toString","postDocumentAttachedToCard","getCardDocument","doc_name","formatErrorMessage","error_code","data_to_send","setFileDirty","FILE_DIRTY","getUsername","userObj","nameObj","values","some","prefix","given","middle","family","namePart","getNameString"],"sourceRoot":""}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dome-embedded-app-sdk",
3
- "version": "0.2.2",
3
+ "version": "0.2.3",
4
4
  "source": "src/index.ts",
5
5
  "main": "./dist/index.js",
6
6
  "types": "./dist/index.d.ts",