dome-embedded-app-sdk 0.2.4-experimental.4 → 0.2.4

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.mjs ADDED
@@ -0,0 +1,2 @@
1
+ var e={d:(t,a)=>{for(var s in a)e.o(a,s)&&!e.o(t,s)&&Object.defineProperty(t,s,{enumerable:!0,get:a[s]})},o:(e,t)=>Object.prototype.hasOwnProperty.call(e,t)},t={};e.d(t,{_X:()=>o,gp:()=>h,T5:()=>w,HD:()=>i,EF:()=>l,V0:()=>c,cu:()=>r,dq:()=>d,O8:()=>f,RS:()=>u});const a="0.2.4",s=new Set(["dome","intouchapp"]);var r,n,i,o;!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"}(r||(r={})),function(e){e.INIT_MESSAGE_CHANNEL="INIT_MESSAGE_CHANNEL"}(n||(n={})),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.AF1_DATA_TOKEN_ACK="AF1_DATA_TOKEN_ACK",e.ERROR="ERROR",e.REFRESH="REFRESH"}(i||(i={})),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",e.AF1_DATA_TOKEN="AF1_DATA_TOKEN"}(o||(o={}));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 a=t.getAttribute("href")??"";this.emitDeepLink(a)&&e.preventDefault()},console.info(`Initializing Dome Embedded App SDK v${a}`),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||!s.has(t))&&(this.sendMessage(o.OPEN_DEEPLINK,{url:e}),!0)}updateParentContext(e,t){if(!e&&!t)return;const a={...this.parentHostDetails??{type:this.runtimeHost},...e??{}};a.type||(a.type=this.runtimeHost);const s=t??this.parentCapabilities??a.capabilities;t&&(this.parentCapabilities=t),s?a.capabilities=s:delete a.capabilities,this.parentHostDetails=a,this.parentCapabilities=s??null,s?console.info("Host capabilities detected",{host_type:a.type,capabilities:s}):console.info("Host capabilities not found",{hostType:a.type})}getHost(){return this.parentHostDetails??{type:this.runtimeHost}}sendMessage(e,t){const a={type:e,data:t??null};switch(this.runtimeHost){case"android":window.AndroidBridge?.sendMessage(JSON.stringify(a));break;case"ios":window?.webkit?.messageHandlers?window.webkit?.messageHandlers.appHandler.postMessage(JSON.stringify(a)):console.error("webkit.messageHandlers not found");break;case"webapp":this.port2?this.port2.postMessage(a):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(r.INIT,{sdk:{ver:a}}))}safeInvoke(e,t,a){const s=t?.[e];"function"==typeof s?s(a):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 s=t=>{const{type:a}=t.data||{};a===i.CONNECT&&t.ports&&t.ports.length>0&&(this.port2=t.ports[0],this.port2.onmessage=e=>this.handlePortMessage(e),window.removeEventListener("message",s),this.notifyConnectionSuccess(),e())};window.addEventListener("message",s),window.parent?window.parent.postMessage({type:n.INIT_MESSAGE_CHANNEL,data:{sdk:{ver:a}}},this.targetOrigin):console.error("Parent window not available to initialize message channel.");break;default:console.error("Unknown host."),t("Unknown host")}}))}notifyConnectionSuccess(){this.sendMessage(r.CONNECTION_SUCCESS)}handlePortMessage(e){const{type:t,data:a}=e.data||{};t&&this.handleMessage(t,a)}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(r.REQUEST_INITIAL_DATA)}requestSave(e,t){const a=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(r.REQUEST_SAVE,{doc:e,isDataDirty:t,requestId:a}),new Promise(((e,t)=>{this.pendingRequests.set(a,e),this.pendingRequests.set(a+"_reject",t),setTimeout((()=>{this.pendingRequests.has(a)&&(this.pendingRequests.delete(a),this.pendingRequests.delete(a+"_reject"))}),3e4)}))}handleOnSave(e){const{requestId:t,status:a,message:s}=e,r=this.pendingRequests.get(t),n=this.pendingRequests.get(t+"_reject");r&&("error"===a?n?.({status:a,message:s}):r({status:a,message:s}),this.pendingRequests.delete(t),this.pendingRequests.delete(t+"_reject"))}setDirty(e){this.sendMessage(r.SET_DIRTY,e)}sendClose(e,t){this.sendMessage(r.SEND_CLOSE,{doc:e,isDataDirty:t})}sendException(e){this.sendMessage(r.SEND_EXCEPTION,e)}handleMessage(e,t){if(e===i.INIT_ACK&&this.updateParentContext(t?.host,t?.capabilities),this.handler)switch(e){case i.INIT_ACK:this.safeInvoke("onInitialData",this.handler,t);break;case i.DATA_CHANGE:this.safeInvoke("onDataChange",this.handler,t);break;case i.REQUEST_CLOSE:this.safeInvoke("onCloseRequest",this.handler);break;case i.REQUEST_SAVE:this.safeInvoke("onSaveRequest",this.handler);break;case i.SAVE_SUCCESS:case i.SAVE_ERROR:this.handleOnSave(t);break;default:console.warn(`No handler found for message type: ${e}`)}else e===i.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)}}d.initialized=!1;class l{constructor(){if(this.subtleCrypto=window.crypto?.subtle,!this.subtleCrypto)throw new Error("SubtleCrypto API is not available in this environment.")}async decrypt(e,t,a){try{if(!e)throw new Error("Invalid token");const s=this.base64UrlDecode(e);if(128!==s[0])throw new Error("Invalid version");s.slice(1,9);const r=s.slice(9,25),n=s.slice(25,-32),i=s.slice(-32),o=await this.deriveKey(t,a),{hmacKey:c,aesKey:d}=await this.splitKey(o),l=s.slice(0,-32);if(!new Uint8Array(await this.subtleCrypto.sign("HMAC",c,l)).every(((e,t)=>e===i[t])))throw new Error("Invalid HMAC. Token has been tampered with!");const u=await this.subtleCrypto.decrypt({name:"AES-CBC",iv:r},d,n);return(new TextDecoder).decode(u)}catch(e){throw console.log("Error in decrypt:",e),e}}async deriveKey(e,t,a=1e4){const s=new TextEncoder,r=await this.subtleCrypto.importKey("raw",s.encode(e),"PBKDF2",!1,["deriveKey"]);return this.subtleCrypto.deriveKey({name:"PBKDF2",hash:"SHA-256",salt:s.encode(t),iterations:a},r,{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,"/"),a=atob(t);return new Uint8Array([...a].map((e=>e.charCodeAt(0))))}}function u(e){if(1===e.v)return function(e){const{seed:t,obf:a}=e,s=new Uint8Array(a.length);for(let e=0;e<a.length;e++)s[e]=a[e]^t+17*e&255;return s}(e);throw new Error(`Unsupported key blob version: ${e.v}`)}var h;!function(e){e.READ="r",e.WRITE="w",e.FORWARD="f",e.SHARE="s",e.DOWNLOAD="d"}(h||(h={}));const f=h;class p{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(p.DB_VERSION,e)}))),this.openPromise):null}openWithVersion(e,t){let a="ensure";const s=indexedDB.open(this.cardIuid,e);s.onupgradeneeded=e=>{a=0===(e.oldVersion||0)?"create":"ensure",this.configureStores(s.result)},s.onsuccess=()=>{const e=s.result;if(!this.hasRequiredStores(e)){const a=e.version+1;return e.close(),void this.openWithVersion(a,t)}this.updateStoresMetadata(e,"ensure"===a).catch((()=>{})).finally((()=>t(e)))},s.onerror=()=>t(null)}configureStores(e){e.objectStoreNames.contains(p.DATA_STORE)||e.createObjectStore(p.DATA_STORE),e.objectStoreNames.contains(p.NAME_LOOKUP_STORE)||e.createObjectStore(p.NAME_LOOKUP_STORE),e.objectStoreNames.contains(p.INFO_STORE)||e.createObjectStore(p.INFO_STORE)}hasRequiredStores(e){const t=e.objectStoreNames;return t.contains(p.DATA_STORE)&&t.contains(p.NAME_LOOKUP_STORE)&&t.contains(p.INFO_STORE)}static nowMicros(){return Math.trunc(1e3*Date.now())}updateStoresMetadata(e,t){return Promise.all([this.ensureStoreVersion(e,p.DATA_STORE),this.ensureStoreVersion(e,p.NAME_LOOKUP_STORE),this.updateCardInfo(e,t)]).then((()=>{}))}ensureStoreVersion(e,t){return e.objectStoreNames.contains(t)?new Promise((a=>{try{const s=e.transaction(t,"readwrite"),r=s.objectStore(t),n=()=>a();s.oncomplete=n,s.onerror=n,s.onabort=n,r.put("1.0.0",p.STORE_VERSION_KEY)}catch{a()}})):Promise.resolve()}async updateCardInfo(e,t){if(!e.objectStoreNames.contains(p.INFO_STORE))return;const a=await this.readInfoValue(e,"container_iuid"),s=t?await this.readInfoValue(e,"ts_c"):void 0,r=this.containerIuid??a??null,n=t&&s?s:p.nowMicros();await Promise.all([this.writeInfoValue(e,"container_iuid",r),this.writeInfoValue(e,"ts_c",n)]).catch((()=>{}))}readInfoValue(e,t){return new Promise((a=>{try{const s=e.transaction(p.INFO_STORE,"readonly"),r=s.objectStore(p.INFO_STORE).get(t);r.onsuccess=()=>a(r.result),r.onerror=()=>a(void 0)}catch{a(void 0)}}))}writeInfoValue(e,t,a){return new Promise((s=>{try{const r=e.transaction(p.INFO_STORE,"readwrite"),n=r.objectStore(p.INFO_STORE),i=()=>s();r.oncomplete=i,r.onerror=i,r.onabort=i,n.put(a,t)}catch{s()}}))}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 a=await this.openDb();a&&await new Promise((s=>{const r=a.transaction(p.DATA_STORE,"readwrite");r.objectStore(p.DATA_STORE).put(t,e).onsuccess=()=>s(),r.oncomplete=()=>s(),r.onerror=()=>s(),r.onabort=()=>s()}))}async get(e){const t=await this.openDb();if(t)return new Promise((a=>{const s=t.transaction(p.DATA_STORE,"readonly").objectStore(p.DATA_STORE).get(e);s.onsuccess=()=>a(s.result),s.onerror=()=>a(void 0)}))}async delete(e){const t=await this.openDb();t&&await new Promise((a=>{const s=t.transaction(p.DATA_STORE,"readwrite");s.objectStore(p.DATA_STORE).delete(e).onsuccess=()=>a(),s.oncomplete=()=>a(),s.onerror=()=>a(),s.onabort=()=>a()}))}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 a=p.encodeText(e),s=await t.subtle.digest("SHA-256",a);return p.bufferToBase64(s)}static encodeText(e){if("undefined"!=typeof TextEncoder)return(new TextEncoder).encode(e).buffer;const t=new Uint8Array(e.length);for(let a=0;a<e.length;a++)t[a]=e.charCodeAt(a);return t.buffer}static bufferToBase64(e){let t="";const a=new Uint8Array(e);for(let e=0;e<a.length;e++)t+=String.fromCharCode(a[e]);return btoa(t)}async getIuidForName(e){const t=p.normalizeName(e);if(!t)return;const a=await this.openDb();if(!a)return;const s=await p.hashName(t);return new Promise((e=>{const t=a.transaction(p.NAME_LOOKUP_STORE,"readonly").objectStore(p.NAME_LOOKUP_STORE).get(s);t.onsuccess=()=>e(t.result),t.onerror=()=>e(void 0)}))}async upsertNameLookup(e,t){const a=p.normalizeName(e);if(!a)return;const s=await this.openDb();if(!s)return;const r=await p.hashName(a);await new Promise((e=>{const a=s.transaction(p.NAME_LOOKUP_STORE,"readwrite"),n=a.objectStore(p.NAME_LOOKUP_STORE);n.put(t,r);n.openCursor().onsuccess=e=>{const a=e.target.result;a&&(a.key!==r&&a.value===t&&a.delete(),a.continue())},a.oncomplete=()=>e(),a.onerror=()=>e(),a.onabort=()=>e()}))}async deleteNameLookupByName(e){const t=p.normalizeName(e);if(!t)return;const a=await this.openDb();if(!a)return;const s=await p.hashName(t);await new Promise((e=>{const t=a.transaction(p.NAME_LOOKUP_STORE,"readwrite");t.objectStore(p.NAME_LOOKUP_STORE).delete(s),t.oncomplete=()=>e(),t.onerror=()=>e(),t.onabort=()=>e()}))}async deleteNameLookupByIuid(e){if(!e)return;const t=await this.openDb();t&&await new Promise((a=>{const s=t.transaction(p.NAME_LOOKUP_STORE,"readwrite");s.objectStore(p.NAME_LOOKUP_STORE).openCursor().onsuccess=t=>{const a=t.target.result;a&&(a.value===e&&a.delete(),a.continue())},s.oncomplete=()=>a(),s.onerror=()=>a(),s.onabort=()=>a()}))}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 a=p.normalizeName(e.name);if(a&&await this.upsertNameLookup(a,e.iuid),void 0===t)return void await this.delete(this.keyFor(`${e.iuid}_data`));p.estimateSize(t)<=p.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=p.normalizeName(e);if(!t)return null;const a=await this.getIuidForName(t);if(!a)return null;const s=await this.get(this.keyFor(`${a}_object`));if(!s)return null;return{iuid:a,object:s,data:await this.get(this.keyFor(`${a}_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 a=[],s=e.transaction(p.DATA_STORE,"readonly").objectStore(p.DATA_STORE).openCursor();s.onsuccess=e=>{const s=e.target.result;if(!s)return void t(a);const r=s.key;"string"==typeof r&&r.endsWith("_object")&&a.push(s.value),s.continue()},s.onerror=()=>t(a)})):[]}}p.DB_VERSION=2,p.DATA_STORE="cardfs",p.NAME_LOOKUP_STORE="cardfs_name_iuid_lookup",p.INFO_STORE="info",p.STORE_VERSION_KEY="ver",p.MAX_DATA_BYTES=5242880;class w extends c{buildCardFsMessagePayload(e,t){return{...e.name?{name:e.name}:{},...e.iuid?{iuid:e.iuid}:{},...t??{}}}assertValidReadHandler(e){if(!e||"function"!=typeof e.next)throw new Error("cardFS.read requires a handler with a next() function");return e}invokeReadHandlerNext(e,t){try{e.next(t)}catch(e){console.error("cardFS.read handler next() threw",e)}}invokeReadHandlerError(e,t){if(e.error)try{e.error(t)}catch(e){console.error("cardFS.read handler error() threw",e)}}sanitizeReadData(e,t){if(null==e)return{value:e,stripped:!1};try{if(p.estimateSize(e)>p.MAX_DATA_BYTES){const e=t?` for ${t}`:"";return console.warn(`cardFS.read payload data exceeded ${p.MAX_DATA_BYTES} bytes${e}; omitting data`),{value:void 0,stripped:!0}}}catch(e){console.warn("cardFS.read payload size estimation failed",e)}return{value:e,stripped:!1}}getCardIuid(){return this.dataStore?.iuid||null}ensureCardFsCache(){if(!this.shouldUseCardFsFallback())return null;if(!this.cardFsCache){const e=this.getCardIuid();e&&(this.cardFsCache=new p(e,this.containerIuid))}return this.cardFsCache}supportsParentCardFs(){return!!this.parentCapabilities?.card_fs}shouldUseCardFsFallback(){return!this.supportsParentCardFs()}constructor(){super(),this.handler=null,this.accessToken="",this.devMode=!1,this.permission=null,this.userRole=null,this.fsReadRequests=new Map,this.fsWriteRequests=new Map,this.cardFsCache=null,this.pendingAcks=new Map,this.handleMessage=(e,t)=>{e===i.INIT_ACK&&this.updateParentContext(t?.host,t?.capabilities);const a=t?.messageId;if(a&&this.pendingAcks.has(a)){const{resolve:e,timeout:s}=this.pendingAcks.get(a);return clearTimeout(s),this.pendingAcks.delete(a),void e(t)}if(a||!this.resolvePendingAckByType(e,t)){if(!this.handler)throw new Error("Message handler not found!");switch(e){case i.INIT_ACK:this.dataStore.kw1=t.key_wa1,this.dataStore.iuid=t.iuid,"boolean"==typeof t?.dev_mode&&(this.devMode=t.dev_mode,this.dataStore.dev_mode=t.dev_mode),t.iuid?this.shouldUseCardFsFallback()?this.cardFsCache=new p(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 a=JSON.parse(e),s=a?.container?.iuid;s&&(this.containerIuid=s,this.shouldUseCardFsFallback()&&this.dataStore?.iuid&&(this.cardFsCache=new p(this.dataStore.iuid,this.containerIuid)));const r="string"==typeof a?.api_token?a.api_token.trim():"";r?this.accessToken=r:console.warn("CardSdk: INIT_ACK payload missing api_token; fallback APIs may fail without auth"),this.permission=a?.perms_v2??null,this.userRole=a?.role??null,this.handler&&this.safeInvoke("onInit",this.handler,{...a,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 i.FILE_DATA:{const e=t?.messageId;if(e&&this.fsReadRequests.has(e)){const{messageId:a,...s}=t||{};return void this.handleFsReadDataMessage(e,s)}console.warn("CardSdk: FILE_DATA received but no matching fsRead request",t?.messageId??t?.name);break}case i.DATA_CHANGE:this.safeInvoke("onFileChange",this.handler,t);case i.SAVE_SUCCESS:{const e=t?.messageId;if(e&&this.fsWriteRequests.has(e))return void this.handleFsWriteSuccess(e,t);console.warn("CardSdk: SAVE_SUCCESS received but no matching fsWrite request",t?.messageId??t?.name);break}case i.SAVE_ERROR:{const e=t?.messageId;if(e&&this.fsWriteRequests.has(e))return void this.handleFsWriteError(e,t);console.warn("CardSdk: SAVE_ERROR received but no matching fsWrite request",t?.messageId??t?.name);break}case i.ERROR:{const e=t?.messageId;if(e){const a=t?.message||"Unknown error";if(this.fsReadRequests.has(e))return void this.failFsReadRequest(e,new Error(a));if(this.fsWriteRequests.has(e))return void this.failFsWriteRequest(e,new Error(a))}this.safeInvoke("onError",this.handler,t);break}case i.REFRESH:this.safeInvoke("onRefreshRequest",this.handler,t);break;case i.AF1_DATA_TOKEN_ACK:break;default:console.warn(`No handler found for message type: ${e}`)}}},this.cryptoA01=new l,this.cardFS={read:(e,t,a=!0)=>{this.cardsFsRead(e,t,a)},readById:(e,t,a=!0)=>{this.cardsFsReadById(e,t,a)},write:(e,t,a)=>this.cardsFsWrite(e,t,a),writeById:(e,t,a)=>this.cardsFsWriteById(e,t,a),delete:(e,t)=>this.cardsFsDelete(e,t),deleteById:(e,t)=>this.cardsFsDeleteById(e,t),list:e=>this.cardsFsList(e)}}static async init(e,t,a){try{return w.instance||(w.instance=new w,w.instance.setupParentConnection().then((()=>{w.instance.initializeCardSdk(e)})).catch((e=>{console.error(e)})),t&&w.instance.setHandler(t)),w.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")}hasPerm(e){if(!e)return!1;const t=this.userRole?.abbr;if(!t)return!0;if("o"===t)return!0;const a=this.permission?.[t];return"string"==typeof a?!!a.includes("*")||a.includes(e):w.DEFAULT_ROLE_PERMISSIONS.includes(e)}canRead(){return this.hasPerm(h.READ)}canWrite(){return this.hasPerm(h.WRITE)}deriveSecretSeed(e){const t=e.split("").reverse().join("").substring(4,25);if(!t)throw new Error("Cannot decrypt (1)");return t}getCardIuidEnc(e){try{const t=e.pathname.split("/wa/").filter(Boolean);if(t.length<2)return null;return(t[1]?.split("/")[0]??null)||null}catch(e){return console.warn("CardSdk: Failed to extract seed token",e),null}}async requestAf1DataFromParent(e){const t=await this.sendMessageWithAck(o.AF1_DATA_TOKEN,{sdk:{ver:a}},i.AF1_DATA_TOKEN_ACK),{messageId:s,...r}=t||{},{cie:n,ck:c,dev_token:d}=r;if(!n||!c||!d)throw new Error("Invalid AF1 data token payload");const l=await this.fetchAf1Data(n,c,d,e),u=l?.data_af1??l?.data?.data_af1;if(!u)throw new Error("AF1 data fetch returned empty payload");return window.IT_DATA_AF1=u,l?.ver&&(window.IT_VERSION=l.ver),l?.env&&(window.IT_ENV=l.env),{dataAf1:u,cie:n}}async fetchAf1Data(e,t,a,s){if(!(e&&t&&a&&s))throw new Error("Invalid AF1 data fetch parameters");const r=new URL(`https://dome.so/api/v1/cards/e/${encodeURIComponent(e)}/data_af1/`);r.searchParams.set("dt",a),r.searchParams.set("rt",s),r.searchParams.set("ck",t);const n=await fetch(r.toString(),{method:"GET"});if(!n.ok){const e=await n.text().catch((()=>n.statusText));throw new Error(`AF1 data fetch failed: ${n.status} ${e}`)}return n.json()}async initializeCardSdk(e){let t="CardSdk::initializeCardSdk:";try{if(!e)throw new Error("Invalid secret");const a=window.location.href,s=new URL(a),r=s.searchParams.get("rt");if(!r)throw new Error("Missing request token");let n=this.getCardIuidEnc(s),i=window.IT_DATA_AF1;if(!i){const{dataAf1:e,cie:t}=await this.requestAf1DataFromParent(r);i=e,n=t||n}if(!i)throw console.error(t,"No data"),new Error("No data");if(!n)throw new Error("Cannot decrypt (missing seed)");const o=this.deriveSecretSeed(n),c=await this.cryptoA01.decrypt(i,e,o);try{const e=JSON.parse(c);if(!e.ite)throw new Error("Invalid data");this.dataStore={denc:e.d,kw2:e.kw2},w.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){const t={token:e,sdk:{ver:a}},s=this.getWebappDetails();s&&(t.wa=s),this.sendMessage(o.INIT,t)}getWebappDetails(){if("undefined"==typeof window)return null;let e={};const t=window.IT_VERSION,a=window.IT_ENV;return t&&(e.ver=String(t)),a&&(e.env=String(a)),Object.keys(e).length?e:null}sendMessageWithAck(e,t,a,s=15e3,r){const n=crypto.randomUUID();if(r)try{r(n)}catch(e){return Promise.reject(e)}return new Promise(((r,i)=>{const o=setTimeout((()=>{this.pendingAcks.delete(n),i(new Error(`${a} not received in time`))}),s);this.pendingAcks.set(n,{resolve:r,reject:i,timeout:o,ackType:a}),this.sendMessage(e,{...t,messageId:n})}))}resolvePendingAckByType(e,t){for(const[a,s]of this.pendingAcks.entries())if(s.ackType===e)return clearTimeout(s.timeout),this.pendingAcks.delete(a),s.resolve(t),!0;return!1}cardsFsRead(e,t,a=!0){const s={name:e},r=this.assertValidReadHandler(t);this.cardsFsReadInternal(s,r,a,"read")}cardsFsReadById(e,t,a=!0){const s={iuid:e},r=this.assertValidReadHandler(t);this.cardsFsReadInternal(s,r,a,"readById")}cardsFsReadInternal(e,t,a,s){if(this.shouldUseCardFsFallback())return void this.cardsFsReadFallback(e,void 0,t,a).catch((e=>{const a=e instanceof Error?e:new Error(String(e));this.invokeReadHandlerError(t,a)}));let r=null;const n=e.name?`"${e.name}"`:e.iuid?`iuid ${e.iuid}`:"document";this.sendMessageWithAck(o.READ_FILE,this.buildCardFsMessagePayload(e,{allow_stale:a}),i.READ_FILE_ACK,w.CARD_FS_ACK_TIMEOUT_MS,(e=>{r=e;const i={name:n,handler:t,allowStale:a};i.noResponseTimeout=setTimeout((()=>{this.failFsReadRequest(e,new Error(`cardFS.${s} timed out for ${n}`))}),w.FS_RESPONSE_TIMEOUT_MS),this.fsReadRequests.set(e,i)})).catch((e=>{const a=e instanceof Error?e:new Error(String(e));r?this.failFsReadRequest(r,a):this.invokeReadHandlerError(t,a)}))}cardsFsWrite(e,t,a){const s={name:e};return this.cardsFsWriteInternal(s,t,a,"write")}cardsFsWriteById(e,t,a){const s={iuid:e};return this.cardsFsWriteInternal(s,t,a,"writeById")}cardsFsWriteInternal(e,t,a,s){return this.shouldUseCardFsFallback()?this.cardsFsWriteFallback(e,t).then((e=>{try{a?.(e)}catch(e){console.error(`cardFS.${s} fallback callback threw`,e)}return e})):new Promise(((r,n)=>{let c=null;const d=e.name?`"${e.name}"`:e.iuid?`iuid ${e.iuid}`:"document";this.sendMessageWithAck(o.WRITE_FILE,this.buildCardFsMessagePayload(e,{data:t}),i.WRITE_FILE_ACK,w.CARD_FS_ACK_TIMEOUT_MS,(e=>{c=e;const t={name:d,onResult:a,resolve:r,reject:n,timeout:setTimeout((()=>{this.failFsWriteRequest(e,new Error(`cardFS.${s} timed out for ${d}`))}),w.FS_RESPONSE_TIMEOUT_MS)};this.fsWriteRequests.set(e,t)})).catch((e=>{const t=e instanceof Error?e:new Error(String(e));c?this.failFsWriteRequest(c,t):n(t)}))}))}cardsFsDelete(e,t){const a={name:e};return this.cardsFsDeleteInternal(a,t,"delete")}cardsFsDeleteById(e,t){const a={iuid:e};return this.cardsFsDeleteInternal(a,t,"deleteById")}cardsFsDeleteInternal(e,t,a){return this.shouldUseCardFsFallback()?this.cardsFsDeleteFallback(e).then((e=>{try{t?.(e)}catch(e){console.error(`cardFS.${a} fallback callback threw`,e)}return e})):new Promise(((a,s)=>{this.sendMessageWithAck(o.DELETE_FILE,this.buildCardFsMessagePayload(e),i.DELETE_FILE_ACK,w.CARD_FS_ACK_TIMEOUT_MS).then((e=>{const{messageId:s,...r}=e||{};t?.(r),a(r)})).catch((e=>{s(e instanceof Error?e:new Error(String(e)))}))}))}cardsFsList(e){return this.shouldUseCardFsFallback()?this.cardsFsListFallback().then((t=>{try{e?.(t)}catch(e){console.error("cardFS.list fallback callback threw",e)}return t})):new Promise(((t,a)=>{this.sendMessageWithAck(o.LIST_FILES,{},i.LIST_FILES_ACK,w.CARD_FS_ACK_TIMEOUT_MS).then((a=>{const{messageId:s,...r}=a||{};e?.(r),t(r)})).catch((e=>{a(e instanceof Error?e:new Error(String(e)))}))}))}handleFsReadDataMessage(e,t){const a=this.fsReadRequests.get(e);if(!a)return;a.noResponseTimeout&&(clearTimeout(a.noResponseTimeout),a.noResponseTimeout=void 0);const s=this.sanitizeReadData(t?.data,a.name),r=Boolean(t?.from_cache??t?.is_stale),n={name:t?.name,iuid:t?.iuid??null,object:t?.object,data:s.value,is_stale:Boolean(t?.is_stale??t?.from_cache),is_complete:"boolean"==typeof t?.is_complete?t.is_complete:!a.allowStale||!r};this.invokeReadHandlerNext(a.handler,n),a.cleanupTimeout&&clearTimeout(a.cleanupTimeout),a.cleanupTimeout=setTimeout((()=>{this.clearFsReadRequest(e)}),w.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 a=this.clearFsReadRequest(e);a&&this.invokeReadHandlerError(a.handler,t)}clearFsWriteRequest(e){const t=this.fsWriteRequests.get(e);if(t)return clearTimeout(t.timeout),this.fsWriteRequests.delete(e),t}failFsWriteRequest(e,t){const a=this.clearFsWriteRequest(e);a&&a.reject(t)}handleFsWriteSuccess(e,t){const a=this.clearFsWriteRequest(e);if(!a)return;const{messageId:s,...r}=t||{};if("function"==typeof a.onResult)try{a.onResult(r)}catch(e){console.error("cardFS.write callback threw",e)}else console.warn("onResult method invalid:",a.onResult);a.resolve(r)}handleFsWriteError(e,t){const a=this.clearFsWriteRequest(e);if(!a)return;const s=t instanceof Error?t:new Error(t?.message||"Unknown write error");a.reject(s)}async cardsFsReadFallback(e,t,a,s=!0){if(!this.shouldUseCardFsFallback())throw new Error("cardFS.read fallback is disabled because parent supports card_fs");const r=this.getCardIuid();if(!r)throw new Error("cardFS.read fallback failed: card not initialized");const n=this.ensureCardFsCache();let i=null;const o=e.name?`"${e.name}"`:e.iuid?`iuid ${e.iuid}`:"document",c=(s,r,n,o,c,d)=>{if(!s)return null;const l=c??e.name??s?.name??e.iuid??"document",u=d??s?.iuid??e.iuid??null,{value:h}=this.sanitizeReadData(r,l),f={name:l,iuid:u,object:s,data:h,is_stale:n,is_complete:o};return t&&this.fsReadRequests.has(t)?this.handleFsReadDataMessage(t,f):this.invokeReadHandlerNext(a,f),i||(i=f),f};let d=null;if(n)try{if(s){let t=null;e.iuid&&(t=await n.getByIuid(e.iuid)),!t&&e.name&&(t=await n.getByName(e.name)),t?.object&&(d=c(t.object,t.data,!0,!1,t.object?.name??e.name,t.iuid))}}catch(e){console.warn("cardFS.read cache lookup failed",e)}try{const t=await this.fetchDocumentPayload(r,e);t?(await(n?.cacheDocument(t.object,t.data)),c(t.object,t.data,!1,!0,t.object?.name,t.object?.iuid)):s&&d&&c(d.object,d.data,!0,!0,d.name,d.iuid??void 0)}catch(e){if(!i){throw e instanceof Error?e:new Error(String(e))}console.warn("cardFS.read fresh fetch failed",e),s&&d&&c(d.object,d.data,!0,!0,d.name,d.iuid??void 0)}if(!i)throw new Error(`cardFS.read fallback could not locate ${o}`)}async cardsFsWriteFallback(e,t,a){if(!this.shouldUseCardFsFallback())throw new Error("cardFS.write fallback is disabled because parent supports card_fs");const s=this.getCardIuid();if(!s)throw new Error("cardFS.write fallback failed: card not initialized");await this.upsertDocumentViaApi(s,e,t);const r=await this.fetchDocumentPayload(s,e);await(this.ensureCardFsCache()?.cacheDocument(r.object,r.data));const n={name:r.object?.name??e.name??null,iuid:r.object?.iuid??e.iuid??null,object:r.object,data:r.data};return a&&this.fsWriteRequests.has(a)&&this.handleFsWriteSuccess(a,n),n}async cardsFsDeleteFallback(e){if(!this.shouldUseCardFsFallback())throw new Error("cardFS.delete fallback is disabled because parent supports card_fs");const t=this.getCardIuid();if(!t)throw new Error("cardFS.delete fallback failed: card not initialized");const a=this.ensureCardFsCache(),s=await this.fetchDocumentMetadataByTarget(t,e).catch((()=>null)),r=s?.iuid??e.iuid??null,n=s?.name??e.name??null;if(!r)return e.name&&await(a?.deleteByName(e.name)),{name:n,iuid:null,deleted:!1};const i=await fetch(`/api/v1/documents/${r}/`,{method:"DELETE",headers:this.authHeader()});if(!i.ok&&404!==i.status){const e=await i.text().catch((()=>"delete failed"));throw new Error(`cardFS.delete fallback failed: ${e}`)}await(a?.deleteByIuid(r,n??void 0));return{name:n??r,iuid:r,deleted:404!==i.status}}async cardsFsListFallback(){if(!this.shouldUseCardFsFallback())throw new Error("cardFS.list fallback is disabled because parent supports card_fs");const e=this.getCardIuid();if(!e)throw new Error("cardFS.list fallback failed: card not initialized");const t=this.ensureCardFsCache();try{const a=await this.fetchAllDocuments(e);if(t)for(const e of a)await t.cacheDocument(e,void 0);return{documents:a,from_cache:!1}}catch(e){const a=await(t?.getAllCachedObjects());if(a&&a.length>0)return{documents:a,from_cache:!0};throw e}}authHeader(){return this.accessToken?{Authorization:`Bearer ${this.accessToken}`}:{}}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(`cardFS metadata fetch failed: ${e}`)}return t.json().catch((()=>null))}normalizeDocumentsResponse(e){return Array.isArray(e?.results)?e.results:Array.isArray(e)?e:e?[e]:[]}async fetchDocumentMetadataByName(e,t){if(!t)return null;const a=await fetch(`/api/v1/documents/with_card/${e}/?name=${encodeURIComponent(t)}`,{method:"GET",headers:this.authHeader()});if(!a.ok){if(404===a.status)return null;const e=await a.text().catch((()=>"metadata lookup failed"));throw new Error(`cardFS metadata fetch failed: ${e}`)}const s=await a.json().catch((()=>null)),r=this.normalizeDocumentsResponse(s);return r.find((e=>e?.name===t))??r[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(`cardFS.list failed: ${e}`)}const a=await t.json().catch((()=>null));return this.normalizeDocumentsResponse(a)}async fetchDocumentPayload(e,t){const a="string"==typeof t?{name:t}:t,s=await this.fetchDocumentMetadataByTarget(e,a);if(!s){const e=a.name?`"${a.name}"`:a.iuid?`iuid ${a.iuid}`:"document";throw new Error(`cardFS document not found: ${e}`)}return{object:s,data:await this.fetchDocumentData(s)}}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 a=await fetch(t);if(!a.ok){const e=await a.text().catch((()=>"download failed"));throw new Error(`cardFS data fetch failed: ${e}`)}const s=a.headers.get("Content-Type")||"";return s.includes("application/json")?a.json():s.startsWith("text/")?a.text():a.arrayBuffer()}async buildFileFormData(e,t){let a;const s=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),a=new Uint8Array(t.length);return a.set(t),new Blob([a.buffer],{type:"application/octet-stream"})}if(ArrayBuffer.isView(e)){const t=new Uint8Array(e.buffer,e.byteOffset,e.byteLength),a=new Uint8Array(t.length);return a.set(t),new Blob([a.buffer],{type:"application/octet-stream"})}const t=new Uint8Array(e),a=new Uint8Array(t.length);return a.set(t),new Blob([a.buffer],{type:"application/octet-stream"})};if(t instanceof File)a=t;else if("undefined"!=typeof Blob&&t instanceof Blob)a=new File([t],e,{type:t.type||"application/octet-stream"});else if("undefined"!=typeof SharedArrayBuffer&&t instanceof SharedArrayBuffer){const r=s(t);a=new File([r],e,{type:r.type})}else if(t instanceof ArrayBuffer){const r=s(t);a=new File([r],e,{type:r.type})}else if(ArrayBuffer.isView(t)){const r=s(t);a=new File([r],e,{type:r.type})}else if("string"==typeof t){const s=new Blob([t],{type:"text/plain"});a=new File([s],e,{type:s.type})}else{const s=JSON.stringify(t??{}),r=new Blob([s],{type:"application/json"});a=new File([r],e,{type:r.type})}const r=new FormData;return r.append("file",a),r}async upsertDocumentViaApi(e,t,a){const s=await this.buildFileFormData(t.name??t.iuid??"document",a);if(t.iuid){const e=await fetch(`/api/v1/documents/${t.iuid}/`,{method:"PUT",headers:this.authHeader(),body:s});if(!e.ok){const t=await e.text().catch((()=>"update failed"));throw new Error(`cardFS.write update failed: ${t}`)}return}const r=t.name?await this.fetchDocumentMetadataByName(e,t.name).catch((()=>null)):null;if(r?.iuid){const e=await fetch(`/api/v1/documents/${r.iuid}/`,{method:"PUT",headers:this.authHeader(),body:s});if(!e.ok){const t=await e.text().catch((()=>"update failed"));throw new Error(`cardFS.write update failed: ${t}`)}return}if(s.append("parent_iuid",e),s.append("attached_to_iuid",e),!t.name)throw new Error('cardFS.write failed: "name" missing');s.append("filename",t.name);const n=await fetch("/api/v1/documents/",{method:"POST",headers:this.authHeader(),body:s});if(!n.ok){const e=await n.text().catch((()=>"upload failed"));throw new Error(`cardFS.write upload failed: ${e}`)}}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,a=void 0){const s={message:this.formatErrorMessage(t),error_code:e,data:a??null};this.handler&&this.safeInvoke("onError",this.handler,s)}setFileDirty(e){this.sendMessage(o.FILE_DIRTY,e)}getUsername(e){const t=e?.name;return t&&Object.values(t).some((e=>e))?function(e){const{prefix:t="",given:a="",middle:s="",family:r="",suffix:n=""}=e||{};return[t,a,s,r,n].filter((e=>e)).join(" ").trim()}(t):""}}w.FS_RESPONSE_TIMEOUT_MS=3e4,w.FS_READ_RETENTION_MS=5e3,w.CARD_FS_ACK_TIMEOUT_MS=5e3,w.DEFAULT_ROLE_PERMISSIONS="r";var E=t._X,m=t.gp,S=t.T5,y=t.HD,_=t.EF,A=t.V0,I=t.cu,F=t.dq,T=t.O8,R=t.RS;export{E as CardMessageType,m as CardPermission,S as CardSdk,y as ClientMessageType,_ as CryptoA01,A as DomeEmbeddedAppSdk,I as ViewerMessageType,F as ViewerSdk,T as cardPermission,R as getKeyFromBlob};
2
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","mappings":"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","sources":["webpack://dome-embedded-app-sdk/webpack/bootstrap","webpack://dome-embedded-app-sdk/webpack/runtime/define property getters","webpack://dome-embedded-app-sdk/webpack/runtime/hasOwnProperty shorthand","webpack://dome-embedded-app-sdk/./src/dome-sdk.ts","webpack://dome-embedded-app-sdk/./src/viewer-sdk.ts","webpack://dome-embedded-app-sdk/./src/utils.ts","webpack://dome-embedded-app-sdk/./src/crypto.ts","webpack://dome-embedded-app-sdk/./src/card-sdk.ts"],"sourcesContent":["// 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))","import pkg from \"../package.json\";\nconst ALLOWED_DEEP_LINK_PROTOCOLS = new Set([\"dome\", \"intouchapp\"]);\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 = {}));\nexport var 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[\"AF1_DATA_TOKEN_ACK\"] = \"AF1_DATA_TOKEN_ACK\";\n ClientMessageType[\"ERROR\"] = \"ERROR\";\n ClientMessageType[\"REFRESH\"] = \"REFRESH\";\n})(ClientMessageType || (ClientMessageType = {}));\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[\"AF1_DATA_TOKEN\"] = \"AF1_DATA_TOKEN\";\n})(CardMessageType || (CardMessageType = {}));\nexport class DomeEmbeddedAppSdk {\n constructor() {\n this.targetOrigin = \"*\";\n this.isAppReady = false;\n this.port2 = null;\n this.runtimeHost = \"unknown\";\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 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 setupDeepLinkInterception() {\n if (this.runtimeHost !== \"webapp\")\n return;\n if (typeof document === \"undefined\")\n return;\n document.addEventListener(\"click\", this.handleDeepLinkClick, true);\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 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 sendAppInit() {\n if (!this.isAppReady) {\n this.isAppReady = true;\n this.sendMessage(ViewerMessageType.INIT, { sdk: { ver: pkg.version } });\n }\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 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);\n this.notifyConnectionSuccess();\n resolve();\n }\n };\n window.addEventListener(\"message\", handleMessage);\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 notifyConnectionSuccess() {\n this.sendMessage(ViewerMessageType.CONNECTION_SUCCESS);\n }\n handlePortMessage(event) {\n const { type, data } = event.data || {};\n if (!type)\n return;\n this.handleMessage(type, data);\n }\n handleMessage(type, data) {\n throw new Error(\"Subclasses must implement handleMessage.\");\n }\n}\n","import { DomeEmbeddedAppSdk, ViewerMessageType, ClientMessageType } from \"./dome-sdk\";\nimport { generateUUID } from \"./utils\";\nexport class ViewerSdk extends DomeEmbeddedAppSdk {\n constructor() {\n super();\n this.handler = null;\n this.pendingRequests = new Map();\n this.pendingInitAck = null;\n }\n static init(handler) {\n console.debug(\"init called\", handler && \"with handler\");\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 ViewerSdk.instance\n .setupParentConnection()\n .then(() => {\n try {\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);\n }\n ViewerSdk.initialized = true;\n return ViewerSdk.instance;\n }\n setHandler(handler) {\n this.handler = handler;\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;\n }\n }\n canRead(perms) {\n return !!perms?.includes(\"r\");\n }\n canWrite(perms) {\n return !!perms?.includes(\"w\") || !!perms?.includes(\"*\");\n }\n initializeViewerSdk() {\n console.debug(\"initializing viewer sdk\");\n this.sendAppInit();\n }\n requestInitialData() {\n this.sendMessage(ViewerMessageType.REQUEST_INITIAL_DATA);\n }\n requestSave(doc, isDataDirty) {\n const requestId = generateUUID();\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 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 const resolve = this.pendingRequests.get(requestId);\n const reject = this.pendingRequests.get(requestId + \"_reject\");\n if (resolve) {\n if (status === \"error\") {\n reject?.({ status, message });\n }\n else {\n resolve({ status, message });\n }\n this.pendingRequests.delete(requestId);\n this.pendingRequests.delete(requestId + \"_reject\");\n }\n }\n setDirty(isDirty) {\n this.sendMessage(ViewerMessageType.SET_DIRTY, isDirty);\n }\n sendClose(doc, isDataDirty) {\n this.sendMessage(ViewerMessageType.SEND_CLOSE, { doc, isDataDirty });\n }\n sendException(error) {\n this.sendMessage(ViewerMessageType.SEND_EXCEPTION, error);\n }\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;\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 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","/**\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","// 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 { DomeEmbeddedAppSdk, CardMessageType, ClientMessageType } from \"./dome-sdk\";\nimport { getNameString } from \"./utils\";\nimport { CryptoA01 } from \"./crypto\";\nconst CARD_FS_VERSION = \"1.0.0\";\nfunction decodeCardKeyBlobV1(blob) {\n const { seed, obf } = blob;\n const out = new Uint8Array(obf.length);\n for (let i = 0; i < obf.length; i++) {\n out[i] = obf[i] ^ ((seed + i * 17) & 0xff);\n }\n return out;\n}\nexport function getKeyFromBlob(blob) {\n switch (blob.v) {\n case 1:\n return decodeCardKeyBlobV1(blob);\n default:\n throw new Error(`Unsupported key blob version: ${blob.v}`);\n }\n}\nexport var CardPermission;\n(function (CardPermission) {\n CardPermission[\"READ\"] = \"r\";\n CardPermission[\"WRITE\"] = \"w\";\n CardPermission[\"FORWARD\"] = \"f\";\n CardPermission[\"SHARE\"] = \"s\";\n CardPermission[\"DOWNLOAD\"] = \"d\";\n})(CardPermission || (CardPermission = {}));\nexport const cardPermission = CardPermission;\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 buildCardFsMessagePayload(target, extra) {\n return {\n ...(target.name ? { name: target.name } : {}),\n ...(target.iuid ? { iuid: target.iuid } : {}),\n ...(extra ?? {}),\n };\n }\n assertValidReadHandler(handler) {\n if (!handler || typeof handler.next !== \"function\") {\n throw new Error(\"cardFS.read requires a handler with a next() function\");\n }\n return handler;\n }\n invokeReadHandlerNext(handler, payload) {\n try {\n handler.next(payload);\n }\n catch (err) {\n console.error(\"cardFS.read handler next() threw\", err);\n }\n }\n invokeReadHandlerError(handler, error) {\n if (!handler.error)\n return;\n try {\n handler.error(error);\n }\n catch (err) {\n console.error(\"cardFS.read handler error() threw\", err);\n }\n }\n sanitizeReadData(data, contextLabel) {\n if (data == null) {\n return { value: data, stripped: false };\n }\n try {\n const size = CardFsCache.estimateSize(data);\n if (size > CardFsCache.MAX_DATA_BYTES) {\n const label = contextLabel ? ` for ${contextLabel}` : \"\";\n console.warn(`cardFS.read payload data exceeded ${CardFsCache.MAX_DATA_BYTES} bytes${label}; omitting data`);\n return { value: undefined, stripped: true };\n }\n }\n catch (err) {\n console.warn(\"cardFS.read payload size estimation failed\", err);\n }\n return { value: data, stripped: false };\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.devMode = false;\n this.permission = null;\n this.userRole = null;\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 // 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 if (!messageId && this.resolvePendingAckByType(type, data)) {\n return;\n }\n if (!this.handler) {\n throw new Error(\"Message handler not found!\");\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 (typeof data?.dev_mode === \"boolean\") {\n this.devMode = data.dev_mode;\n this.dataStore.dev_mode = data.dev_mode;\n }\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 this.permission = decryptedData?.perms_v2 ?? null;\n this.userRole = decryptedData?.role ?? null;\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 // cardFS.read payload from parent (cached or fresh)\n const { messageId: _ignored, ...payload } = data || {};\n this.handleFsReadDataMessage(responseId, payload);\n return;\n }\n console.warn(\"CardSdk: FILE_DATA received but no matching fsRead request\", data?.messageId ?? data?.name);\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 // cardFS write/list/delete success routed by messageId\n this.handleFsWriteSuccess(responseId, data);\n return;\n }\n console.warn(\"CardSdk: SAVE_SUCCESS received but no matching fsWrite request\", data?.messageId ?? data?.name);\n break;\n }\n case ClientMessageType.SAVE_ERROR: {\n const responseId = data?.messageId;\n if (responseId && this.fsWriteRequests.has(responseId)) {\n // cardFS write/list/delete failure routed by messageId\n this.handleFsWriteError(responseId, data);\n return;\n }\n console.warn(\"CardSdk: SAVE_ERROR received but no matching fsWrite request\", data?.messageId ?? data?.name);\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 // cardFS read error surfaced by the parent\n this.failFsReadRequest(responseId, new Error(message));\n return;\n }\n if (this.fsWriteRequests.has(responseId)) {\n // cardFS 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 case ClientMessageType.AF1_DATA_TOKEN_ACK:\n // Handled via sendMessageWithAck resolver (no-op here)\n break;\n default:\n console.warn(`No handler found for message type: ${type}`);\n }\n };\n this.cryptoA01 = new CryptoA01();\n this.cardFS = {\n read: (name, handler, allowStale = true) => {\n this.cardsFsRead(name, handler, allowStale);\n },\n readById: (iuid, handler, allowStale = true) => {\n this.cardsFsReadById(iuid, handler, allowStale);\n },\n write: (name, fileData, onResult) => this.cardsFsWrite(name, fileData, onResult),\n writeById: (iuid, fileData, onResult) => this.cardsFsWriteById(iuid, fileData, onResult),\n delete: (name, onResult) => this.cardsFsDelete(name, onResult),\n deleteById: (iuid, onResult) => this.cardsFsDeleteById(iuid, 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 /**\n * Checks if the user has the requested permission.\n * @param permission - A value from CardPermission enum (e.g CardPermission.READ, CardPermission.WRITE)\n * @returns Boolean based on the permission presence\n */\n hasPerm(permission) {\n if (!permission) {\n return false;\n }\n const abbr = this.userRole?.abbr;\n if (!abbr) {\n return true;\n }\n // If user role is \"Owner\" always return true\n if (abbr === \"o\") {\n return true;\n }\n const grantedPermissions = this.permission?.[abbr];\n if (typeof grantedPermissions === \"string\") {\n if (grantedPermissions.includes(\"*\")) {\n return true;\n }\n return grantedPermissions.includes(permission);\n }\n return CardSdk.DEFAULT_ROLE_PERMISSIONS.includes(permission);\n }\n /**\n * Checks if the permissions allow reading\n * @returns - True if the permission string allows read access to user\n */\n canRead() {\n return this.hasPerm(CardPermission.READ);\n }\n /**\n * Checks if the permissions allow writing\n * @returns - True if the permission string allows write access to user\n */\n canWrite() {\n return this.hasPerm(CardPermission.WRITE);\n }\n deriveSecretSeed(token) {\n const reversed = token.split('').reverse().join('');\n const seed = reversed.substring(4, 25);\n if (!seed) {\n throw new Error('Cannot decrypt (1)');\n }\n return seed;\n }\n getCardIuidEnc(url) {\n try {\n const segments = url.pathname.split(\"/wa/\").filter(Boolean);\n if (segments.length < 2) {\n return null;\n }\n const token = segments[1]?.split(\"/\")[0] ?? null;\n return token || null;\n }\n catch (err) {\n console.warn(\"CardSdk: Failed to extract seed token\", err);\n return null;\n }\n }\n async requestAf1DataFromParent(requestToken) {\n const ackPayload = await this.sendMessageWithAck(CardMessageType.AF1_DATA_TOKEN, { sdk: { ver: pkg.version } }, ClientMessageType.AF1_DATA_TOKEN_ACK);\n const { messageId: _ignored, ...payload } = ackPayload || {};\n const { cie, ck, dev_token } = payload;\n if (!cie || !ck || !dev_token) {\n throw new Error(\"Invalid AF1 data token payload\");\n }\n const res = await this.fetchAf1Data(cie, ck, dev_token, requestToken);\n const dataAf1 = res?.data_af1 ?? res?.data?.data_af1;\n if (!dataAf1) {\n throw new Error(\"AF1 data fetch returned empty payload\");\n }\n window.IT_DATA_AF1 = dataAf1;\n if (res?.ver) {\n window.IT_VERSION = res.ver;\n }\n if (res?.env) {\n window.IT_ENV = res.env;\n }\n return { dataAf1, cie };\n }\n async fetchAf1Data(cie, ck, devToken, requestToken) {\n if (!cie || !ck || !devToken || !requestToken) {\n throw new Error(\"Invalid AF1 data fetch parameters\");\n }\n const endpoint = new URL(`https://dome.so/api/v1/cards/e/${encodeURIComponent(cie)}/data_af1/`);\n endpoint.searchParams.set(\"dt\", devToken);\n endpoint.searchParams.set(\"rt\", requestToken);\n endpoint.searchParams.set(\"ck\", ck);\n const response = await fetch(endpoint.toString(), { method: \"GET\" });\n if (!response.ok) {\n const message = await response.text().catch(() => response.statusText);\n throw new Error(`AF1 data fetch failed: ${response.status} ${message}`);\n }\n return response.json();\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 const url = window.location.href;\n console.debug(TAG, \"url:\", url);\n const urlObject = new URL(url);\n const requestToken = urlObject.searchParams.get(\"rt\");\n if (!requestToken) {\n throw new Error('Missing request token');\n }\n let cardIuidEnc = this.getCardIuidEnc(urlObject);\n let data_af1 = window.IT_DATA_AF1;\n if (!data_af1) {\n console.debug(TAG, \"IT_DATA_AF1 missing. Requesting token via parent\");\n const { dataAf1, cie } = await this.requestAf1DataFromParent(requestToken);\n data_af1 = dataAf1;\n cardIuidEnc = cie || cardIuidEnc;\n }\n if (!data_af1) {\n console.error(TAG, \"No data\");\n throw new Error('No data');\n }\n if (!cardIuidEnc) {\n throw new Error('Cannot decrypt (missing seed)');\n }\n const ss = this.deriveSecretSeed(cardIuidEnc);\n console.debug(TAG, \"ss:\", ss);\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 const payload = { token, sdk: { ver: pkg.version } };\n const webappDetails = this.getWebappDetails();\n if (webappDetails) {\n payload.wa = webappDetails;\n }\n this.sendMessage(CardMessageType.INIT, payload);\n }\n getWebappDetails() {\n if (typeof window === \"undefined\") {\n return null;\n }\n let wa = {};\n const version = window.IT_VERSION;\n const env = window.IT_ENV;\n if (version) {\n wa.ver = String(version);\n }\n if (env) {\n wa.env = String(env);\n }\n return Object.keys(wa).length ? wa : null;\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, ackType });\n this.sendMessage(type, { ...data, messageId });\n });\n }\n resolvePendingAckByType(type, data) {\n for (const [messageId, pending] of this.pendingAcks.entries()) {\n if (pending.ackType !== type) {\n continue;\n }\n clearTimeout(pending.timeout);\n this.pendingAcks.delete(messageId);\n pending.resolve(data);\n return true;\n }\n return false;\n }\n // cardsSdk.cardFS.read implementation - streams updates only via handler callbacks\n cardsFsRead(name, handler, allowStale = true) {\n const target = { name };\n const resolvedHandler = this.assertValidReadHandler(handler);\n this.cardsFsReadInternal(target, resolvedHandler, allowStale, \"read\");\n }\n cardsFsReadById(iuid, handler, allowStale = true) {\n const target = { iuid };\n const resolvedHandler = this.assertValidReadHandler(handler);\n this.cardsFsReadInternal(target, resolvedHandler, allowStale, \"readById\");\n }\n cardsFsReadInternal(target, handler, allowStale, operation) {\n if (this.shouldUseCardFsFallback()) {\n console.debug(`cardFS.${operation} using fallback implementation for`, target);\n void this.cardsFsReadFallback(target, undefined, handler, allowStale).catch((err) => {\n const error = err instanceof Error ? err : new Error(String(err));\n this.invokeReadHandlerError(handler, error);\n });\n return;\n }\n console.debug(`cardFS.${operation} delegating to parent for`, target);\n let registeredMessageId = null;\n const targetLabel = target.name ? `\"${target.name}\"` : (target.iuid ? `iuid ${target.iuid}` : \"document\");\n const registerRequest = (messageId) => {\n registeredMessageId = messageId;\n // Track this read so FILE_DATA updates can stream via handler callbacks\n const request = {\n name: targetLabel,\n handler,\n allowStale,\n };\n request.noResponseTimeout = setTimeout(() => {\n this.failFsReadRequest(messageId, new Error(`cardFS.${operation} 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, { allow_stale: allowStale }), 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 this.invokeReadHandlerError(handler, error);\n }\n });\n }\n // cardsSdk.cardFS.write - resolves when host confirms write\n cardsFsWrite(name, fileData, onResult) {\n const target = { name };\n return this.cardsFsWriteInternal(target, fileData, onResult, \"write\");\n }\n cardsFsWriteById(iuid, fileData, onResult) {\n const target = { iuid };\n return this.cardsFsWriteInternal(target, fileData, onResult, \"writeById\");\n }\n cardsFsWriteInternal(target, fileData, onResult, operation) {\n if (this.shouldUseCardFsFallback()) {\n console.debug(`cardFS.${operation} 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(`cardFS.${operation} fallback callback threw`, callbackErr);\n }\n return result;\n });\n }\n console.debug(`cardFS.${operation} delegating to parent for`, target);\n return new Promise((resolve, reject) => {\n let registeredMessageId = null;\n const targetLabel = target.name ? `\"${target.name}\"` : (target.iuid ? `iuid ${target.iuid}` : \"document\");\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(`cardFS.${operation} 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.cardFS.delete - simple request/ack flow\n cardsFsDelete(name, onResult) {\n const target = { name };\n return this.cardsFsDeleteInternal(target, onResult, \"delete\");\n }\n cardsFsDeleteById(iuid, onResult) {\n const target = { iuid };\n return this.cardsFsDeleteInternal(target, onResult, \"deleteById\");\n }\n cardsFsDeleteInternal(target, onResult, operation) {\n if (this.shouldUseCardFsFallback()) {\n console.debug(`cardFS.${operation} 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(`cardFS.${operation} fallback callback threw`, callbackErr);\n }\n return result;\n });\n }\n console.debug(`cardFS.${operation} 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.cardFS.list - returns metadata list provided by parent\n cardsFsList(onResult) {\n if (this.shouldUseCardFsFallback()) {\n console.debug(\"cardFS.list using fallback implementation\");\n return this.cardsFsListFallback()\n .then((result) => {\n try {\n onResult?.(result);\n }\n catch (callbackErr) {\n console.error(\"cardFS.list fallback callback threw\", callbackErr);\n }\n return result;\n });\n }\n console.debug(\"cardFS.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 cardFS.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 // Guard against oversized payloads even if parent misbehaves\n const sanitized = this.sanitizeReadData(payload?.data, request.name);\n const fromCache = Boolean(payload?.from_cache ?? payload?.is_stale);\n const normalizedPayload = {\n name: payload?.name,\n iuid: payload?.iuid ?? null,\n object: payload?.object,\n data: sanitized.value,\n is_stale: Boolean(payload?.is_stale ?? payload?.from_cache),\n is_complete: typeof payload?.is_complete === \"boolean\"\n ? payload.is_complete\n : (!request.allowStale || !fromCache),\n };\n this.invokeReadHandlerNext(request.handler, normalizedPayload);\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 this.invokeReadHandlerError(request.handler, 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(\"cardFS.write callback threw\", err);\n }\n }\n else {\n console.warn(\"onResult method invalid:\", request.onResult);\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, handler, allowStale = true) {\n if (!this.shouldUseCardFsFallback()) {\n throw new Error(\"cardFS.read fallback is disabled because parent supports card_fs\");\n }\n const cardIuid = this.getCardIuid();\n if (!cardIuid) {\n throw new Error(\"cardFS.read fallback failed: card not initialized\");\n }\n const cache = this.ensureCardFsCache();\n let firstPayload = null;\n const targetLabel = target.name ? `\"${target.name}\"` : (target.iuid ? `iuid ${target.iuid}` : \"document\");\n const emit = (object, data, fromCache, isComplete, explicitName, explicitIuid) => {\n if (!object)\n return null;\n const payloadName = explicitName ?? target.name ?? object?.name ?? target.iuid ?? \"document\";\n const payloadIuid = explicitIuid ?? object?.iuid ?? target.iuid ?? null;\n const { value: safeData } = this.sanitizeReadData(data, payloadName);\n const messagePayload = {\n name: payloadName,\n iuid: payloadIuid,\n object,\n data: safeData,\n is_stale: fromCache,\n is_complete: isComplete,\n };\n if (requestId && this.fsReadRequests.has(requestId)) {\n this.handleFsReadDataMessage(requestId, messagePayload);\n }\n else {\n this.invokeReadHandlerNext(handler, messagePayload);\n }\n if (!firstPayload) {\n firstPayload = messagePayload;\n }\n return messagePayload;\n };\n let lastCachedPayload = null;\n if (cache) {\n try {\n if (allowStale) {\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 lastCachedPayload = emit(cached.object, cached.data, true, false, cached.object?.name ?? target.name, cached.iuid);\n }\n }\n }\n catch (err) {\n console.warn(\"cardFS.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, true, freshPayload.object?.name, freshPayload.object?.iuid);\n }\n else if (allowStale && lastCachedPayload) {\n // Host served data; cached entry kept in sync\n emit(lastCachedPayload.object, lastCachedPayload.data, true, true, lastCachedPayload.name, lastCachedPayload.iuid ?? undefined);\n }\n }\n catch (err) {\n if (!firstPayload) {\n const error = err instanceof Error ? err : new Error(String(err));\n throw error;\n }\n console.warn(\"cardFS.read fresh fetch failed\", err);\n if (allowStale && lastCachedPayload) {\n // Fresh fetch failed but we have cache — mark it complete and return data\n emit(lastCachedPayload.object, lastCachedPayload.data, true, true, lastCachedPayload.name, lastCachedPayload.iuid ?? undefined);\n }\n }\n if (!firstPayload) {\n throw new Error(`cardFS.read fallback could not locate ${targetLabel}`);\n }\n }\n async cardsFsWriteFallback(target, fileData, requestId) {\n if (!this.shouldUseCardFsFallback()) {\n throw new Error(\"cardFS.write fallback is disabled because parent supports card_fs\");\n }\n const cardIuid = this.getCardIuid();\n if (!cardIuid) {\n throw new Error(\"cardFS.write fallback failed: card not initialized\");\n }\n console.debug(\"cardFS.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 ?? 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(\"cardFS.delete fallback is disabled because parent supports card_fs\");\n }\n const cardIuid = this.getCardIuid();\n if (!cardIuid) {\n throw new Error(\"cardFS.delete fallback failed: card not initialized\");\n }\n console.debug(\"cardFS.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(`cardFS.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(\"cardFS.list fallback is disabled because parent supports card_fs\");\n }\n const cardIuid = this.getCardIuid();\n if (!cardIuid) {\n throw new Error(\"cardFS.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 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(`cardFS 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 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(`cardFS 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(`cardFS.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 const targetLabel = resolvedTarget.name ? `\"${resolvedTarget.name}\"` : (resolvedTarget.iuid ? `iuid ${resolvedTarget.iuid}` : \"document\");\n throw new Error(`cardFS document not found: ${targetLabel}`);\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(`cardFS 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 // Normalizes arbitrary card data into a File so it can be uploaded via FormData.\n async buildFileFormData(name, fileData) {\n let file;\n // Helper to copy any buffer-like input into a standalone binary blob.\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 // Already a File from the host page – use as-is.\n file = fileData;\n }\n else if (typeof Blob !== 'undefined' && fileData instanceof Blob) {\n // Blob without a name; wrap it into a File.\n file = new File([fileData], name, { type: fileData.type || 'application/octet-stream' });\n }\n else if (typeof SharedArrayBuffer !== 'undefined' && fileData instanceof SharedArrayBuffer) {\n // SharedArrayBuffer (e.g., from workers) cannot be sent directly; clone the bytes first.\n const blob = toBinaryBlob(fileData);\n file = new File([blob], name, { type: blob.type });\n }\n else if (fileData instanceof ArrayBuffer) {\n // Raw ArrayBuffer data from fetch APIs.\n const blob = toBinaryBlob(fileData);\n file = new File([blob], name, { type: blob.type });\n }\n else if (ArrayBuffer.isView(fileData)) {\n // Typed arrays/DataViews share an ArrayBuffer – copy the view before upload.\n const blob = toBinaryBlob(fileData);\n file = new File([blob], name, { type: blob.type });\n }\n else if (typeof fileData === 'string') {\n // Plain text payload.\n const blob = new Blob([fileData], { type: 'text/plain' });\n file = new File([blob], name, { type: blob.type });\n }\n else {\n // Fallback: JSON stringify structured data.\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(`cardFS.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(`cardFS.write update failed: ${message}`);\n }\n return;\n }\n formData.append('parent_iuid', cardIuid);\n formData.append('attached_to_iuid', cardIuid);\n if (!target.name) {\n throw new Error(`cardFS.write failed: \"name\" missing`);\n }\n formData.append('filename', target.name);\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(`cardFS.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('cardFS.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(`cardFS.write attach failed: ${message}`);\n // }\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;\nCardSdk.DEFAULT_ROLE_PERMISSIONS = \"r\";\n"],"names":["__webpack_require__","exports","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","ALLOWED_DEEP_LINK_PROTOCOLS","Set","ViewerMessageType","CommonSdkMessageType","ClientMessageType","CardMessageType","DomeEmbeddedAppSdk","constructor","this","targetOrigin","isAppReady","port2","runtimeHost","parentHostDetails","parentCapabilities","handleDeepLinkClick","event","target","Element","anchor","closest","href","getAttribute","emitDeepLink","preventDefault","console","info","detectHost","setupDeepLinkInterception","window","AndroidBridge","webkit","document","addEventListener","trim","warn","protocol","split","toLowerCase","has","sendMessage","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","length","onmessage","e","handlePortMessage","removeEventListener","notifyConnectionSuccess","parent","INIT_MESSAGE_CHANNEL","CONNECTION_SUCCESS","Error","ViewerSdk","super","pendingRequests","Map","pendingInitAck","init","initialized","instance","then","initializeViewerSdk","err","catch","trace","setHandler","canRead","perms","includes","canWrite","requestInitialData","REQUEST_INITIAL_DATA","requestSave","doc","isDataDirty","requestId","crypto","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","CryptoA01","subtleCrypto","subtle","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","log","iterations","encoder","TextEncoder","keyMaterial","importKey","encode","hash","rawKey","exportKey","base64","base64String","replace","decodedString","atob","map","c","charCodeAt","getKeyFromBlob","blob","v","seed","obf","out","decodeCardKeyBlobV1","CardPermission","cardPermission","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","value","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","buildCardFsMessagePayload","extra","assertValidReadHandler","next","invokeReadHandlerNext","payload","invokeReadHandlerError","sanitizeReadData","contextLabel","stripped","label","getCardIuid","dataStore","ensureCardFsCache","shouldUseCardFsFallback","cardFsCache","supportsParentCardFs","card_fs","accessToken","devMode","permission","userRole","fsReadRequests","fsWriteRequests","pendingAcks","messageId","timeout","clearTimeout","resolvePendingAckByType","kw1","key_wa1","dev_mode","cryptoA01","denc","kw2","decData","decryptedData","parse","decryptedContainerIuid","container","apiToken","api_token","perms_v2","role","ui","sendEventError","FILE_DATA","responseId","_ignored","handleFsReadDataMessage","handleFsWriteSuccess","handleFsWriteError","ERROR","failFsReadRequest","failFsWriteRequest","REFRESH","AF1_DATA_TOKEN_ACK","cardFS","read","allowStale","cardsFsRead","readById","cardsFsReadById","write","fileData","onResult","cardsFsWrite","writeById","cardsFsWriteById","cardsFsDelete","deleteById","cardsFsDeleteById","list","cardsFsList","secret","options","initializeCardSdk","openDeepLink","hasPerm","abbr","grantedPermissions","DEFAULT_ROLE_PERMISSIONS","READ","WRITE","deriveSecretSeed","reverse","join","substring","getCardIuidEnc","segments","pathname","filter","Boolean","requestAf1DataFromParent","requestToken","ackPayload","sendMessageWithAck","AF1_DATA_TOKEN","cie","ck","dev_token","res","fetchAf1Data","dataAf1","data_af1","IT_DATA_AF1","IT_VERSION","env","IT_ENV","devToken","endpoint","URL","encodeURIComponent","searchParams","response","fetch","toString","method","ok","text","statusText","json","TAG","location","urlObject","cardIuidEnc","ss","dataFromServer","ite","d","sendInit","webappDetails","getWebappDetails","wa","keys","ackType","timeoutMs","onMessageId","pending","entries","resolvedHandler","cardsFsReadInternal","operation","cardsFsReadFallback","registeredMessageId","targetLabel","READ_FILE","allow_stale","READ_FILE_ACK","CARD_FS_ACK_TIMEOUT_MS","noResponseTimeout","FS_RESPONSE_TIMEOUT_MS","cardsFsWriteInternal","cardsFsWriteFallback","callbackErr","WRITE_FILE","WRITE_FILE_ACK","cardsFsDeleteInternal","cardsFsDeleteFallback","DELETE_FILE","DELETE_FILE_ACK","cardsFsListFallback","LIST_FILES","LIST_FILES_ACK","sanitized","fromCache","from_cache","is_stale","normalizedPayload","is_complete","cleanupTimeout","clearFsReadRequest","FS_READ_RETENTION_MS","clearFsWriteRequest","cache","firstPayload","emit","isComplete","explicitName","explicitIuid","payloadName","payloadIuid","safeData","messagePayload","lastCachedPayload","cached","freshPayload","fetchDocumentPayload","upsertDocumentViaApi","enrichedPayload","fetchDocumentMetadataByTarget","deleteIuid","resolvedName","deleted","headers","authHeader","documents","fetchAllDocuments","cachedDocs","fetchDocumentMetadataByIuid","fetchDocumentMetadataByName","normalizeDocumentsResponse","body","Array","isArray","find","resolvedTarget","fetchDocumentData","orig","original","contentType","startsWith","arrayBuffer","buildFileFormData","file","toBinaryBlob","input","SharedArrayBuffer","viewFromShared","copy","view","byteOffset","File","jsonString","formData","FormData","append","existing","uploadResponse","formatErrorMessage","error_code","data_to_send","setFileDirty","FILE_DIRTY","getUsername","userObj","nameObj","values","some","prefix","given","middle","family","namePart","getNameString"],"sourceRoot":""}
@@ -0,0 +1,53 @@
1
+ import { DomeEmbeddedAppSdk, ClientMessageType } from "./dome-sdk";
2
+ export interface Document {
3
+ data: any;
4
+ name: string;
5
+ type: string;
6
+ }
7
+ export interface UiProps {
8
+ theme: string;
9
+ }
10
+ interface SaveStatusData {
11
+ status: "success" | "error";
12
+ message: string;
13
+ }
14
+ export interface ViewerEventHandler {
15
+ onInitialData: (data: {
16
+ doc: Document;
17
+ ui: UiProps;
18
+ isNewFile: boolean;
19
+ perms: any;
20
+ config?: Record<string, any>;
21
+ }) => void;
22
+ onDataChange?: (data: {
23
+ doc: Document;
24
+ perms: any;
25
+ userConsent: "override" | null;
26
+ }) => void;
27
+ onCloseRequest: () => void;
28
+ onSaveRequest: () => void;
29
+ }
30
+ export declare class ViewerSdk extends DomeEmbeddedAppSdk {
31
+ private static instance;
32
+ private static initialized;
33
+ private handler;
34
+ private pendingRequests;
35
+ private pendingInitAck;
36
+ private constructor();
37
+ static init(handler?: ViewerEventHandler): ViewerSdk;
38
+ setHandler(handler: ViewerEventHandler): void;
39
+ canRead(perms?: string): boolean;
40
+ canWrite(perms?: string): boolean;
41
+ initializeViewerSdk(): void;
42
+ requestInitialData(): void;
43
+ requestSave(doc: Document, isDataDirty: boolean): Promise<SaveStatusData>;
44
+ private handleOnSave;
45
+ setDirty(isDirty: boolean): void;
46
+ sendClose(doc: Document, isDataDirty: boolean): void;
47
+ sendException(error: {
48
+ name?: string;
49
+ message: string;
50
+ } | string): void;
51
+ protected handleMessage(type: ClientMessageType, data: any): void;
52
+ }
53
+ export {};
package/package.json CHANGED
@@ -1,12 +1,13 @@
1
1
  {
2
2
  "name": "dome-embedded-app-sdk",
3
- "version": "0.2.4-experimental.4",
3
+ "version": "0.2.4",
4
4
  "source": "src/index.ts",
5
5
  "main": "./dist/index.js",
6
+ "module": "./dist/index.mjs",
6
7
  "types": "./dist/index.d.ts",
7
8
  "exports": {
8
9
  ".": {
9
- "import": "./dist/index.js",
10
+ "import": "./dist/index.mjs",
10
11
  "require": "./dist/index.js"
11
12
  }
12
13
  },
@@ -14,11 +15,12 @@
14
15
  "dist"
15
16
  ],
16
17
  "scripts": {
18
+ "clean": "node ./scripts/clean-dist.mjs",
17
19
  "build:tsc": "tsc --emitDeclarationOnly",
18
20
  "build:webpack": "webpack --config webpack.config.ts",
19
21
  "build:webpack:experimental": "webpack --config webpack.config.ts --env experimental",
20
- "build": "npm run build:tsc && npm run build:webpack",
21
- "build:experimental": "npm run build:tsc && npm run build:webpack:experimental",
22
+ "build": "npm run clean && npm run build:tsc && npm run build:webpack",
23
+ "build:experimental": "npm run clean && npm run build:tsc && npm run build:webpack:experimental",
22
24
  "release": "npm run build && npm publish",
23
25
  "release:experimental": "npm run build:experimental && npm publish --tag experimental",
24
26
  "version:patch": "npm version patch && git push && git push --tags && npm run release",