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