Skip to content
Snippets Groups Projects
viamapi-iframe.js 47.6 KiB
Newer Older
  • Learn to ignore specific revisions
  •         executeRestfulFunction("private", viamApi, viamApi.identityHasSession, null).then(executeResult => {
    
              result(executeResult);
            });
          });
        },
        marketingSignUpIdentificator(identificator, reference) {
          return new Penpal.Promise(result => {
    
    Markin Igor's avatar
    Markin Igor committed
            viamApi.setIdentity("marketingapppublickey");
    
            executeRestfulFunction("public", viamApi, viamApi.marketingSignUpIdentificator, null, identificator, reference).then(executeResult => {
    
    Markin Igor's avatar
    Markin Igor committed
              viamApi.setIdentity("");
    
    Markin Igor's avatar
    Markin Igor committed
              viamApi.setSessionData("", "");
    
              result(executeResult);
            });
          });
        },
        marketingGetIdentificatorProfile(identificator, pincode) {
          return new Penpal.Promise(result => {
    
    Markin Igor's avatar
    Markin Igor committed
            viamApi.setIdentity("marketingapppublickey");
    
            executeRestfulFunction("public", viamApi, viamApi.marketingGetIdentificatorProfile, null, identificator, pincode).then(executeResult => {
    
    Markin Igor's avatar
    Markin Igor committed
              viamApi.setIdentity("");
    
    Markin Igor's avatar
    Markin Igor committed
              viamApi.setSessionData("", "");
    
              result(executeResult);
            });
          });
        },
    
        marketingExecuteEventForIdentificator(identificator, pincode, event) {
    
          return new Penpal.Promise(result => {
    
    Markin Igor's avatar
    Markin Igor committed
            viamApi.setIdentity("marketingapppublickey");
    
            executeRestfulFunction("public", viamApi, viamApi.marketingExecuteEventForIdentificator, null, identificator, pincode, event).then(executeResult => {
    
    Markin Igor's avatar
    Markin Igor committed
              viamApi.setIdentity("");
    
    Markin Igor's avatar
    Markin Igor committed
              viamApi.setSessionData("", "");
    
              result(executeResult);
            });
          });
        },
        getCurrentlyAuthenticatedIdentity() {
    
          const { publicKey, x509Certificate } = window.currentlyAuthenticatedIdentity.authentication;
    
          return encodeResponse(
            "200",
            {
              authentication: {
                publicKey,
                x509Certificate
              }
            },
            "Currently authenticated identity"
          );
    
        stringToUtf8ByteArray(str) {
          if (typeof str !== 'string') {
            str = str.toString()
          }
    
    Markin Igor's avatar
    Markin Igor committed
          let res = Buffer.from(str,'utf-8');
    
          return new Penpal.Promise(result => {
            result(res)
          })
        },
        utf8ByteArrayToString(ba) {
          if (!Buffer.isBuffer(ba)) {
            ba = Buffer.from(ba)
          }
    
    Markin Igor's avatar
    Markin Igor committed
          let res = ba.toString('utf-8');
    
          return new Penpal.Promise(result => {
            result(res)
          })
        },
        stringToUtf8Base64(str) {
          if (!Buffer.isBuffer(str)) {
            if (typeof str !== 'string') {
              str = str.toString()
            }
            str = Buffer.from(str, 'utf-8')
          }
    
    Markin Igor's avatar
    Markin Igor committed
          let res = str.toString('base64');
    
          return new Penpal.Promise(result => {
            result(res)
          })
        },
        utf8Base64ToString(strBase64) {
          if (!Buffer.isBuffer(strBase64)) {
            if (typeof strBase64 !== 'string') {
              strBase64 = strBase64.toString()
            }
            strBase64 = Buffer.from(strBase64, 'base64')
          }
    
    Markin Igor's avatar
    Markin Igor committed
          let res = strBase64.toString('utf-8');
    
          return new Penpal.Promise(result => {
            result(res)
          })
        },
        base64ToByteArray(strBase64) {
          if (typeof strBase64 !== 'string') {
            strBase64 = strBase64.toString()
          }
    
    Markin Igor's avatar
    Markin Igor committed
          let res = Buffer.from(strBase64, 'base64');
    
          return new Penpal.Promise(result => {
            result(res)
          })
        },
        byteArrayToBase64(ba) {
          if (!Buffer.isBuffer(ba)) {
            ba = Buffer.from(ba)
          }
    
    Markin Igor's avatar
    Markin Igor committed
          let res = ba.toString('base64');
    
          return new Penpal.Promise(result => {
            result(res)
          })
        },
    
    Alexey Lunin's avatar
    Alexey Lunin committed
    
        // Collabora APIs
    
        collaboraDiscovery() {
    
          return collaboraApi.discovery().then(apps => apps);
    
    Alexey Lunin's avatar
    Alexey Lunin committed
        // WOPI
    
    Alexey Lunin's avatar
    Alexey Lunin committed
        getPassports: async fileId => {
          const authenticationPublicKey = localStorage.getItem("authenticatedIdentity");
    
    Alexey Lunin's avatar
    Alexey Lunin committed
          if (
            !authenticationPublicKey ||
            !window.loadedIdentities[authenticationPublicKey] ||
            !extendPinCodeTtl(authenticationPublicKey)
          ) {
            return encodeResponse("400", "", "Identity not authenticated");
          }
    
    Alexey Lunin's avatar
    Alexey Lunin committed
          const response = await wopiAPI.getPassports(fileId);
          return response.data;
    
        wopiPutFile: async (path, accessToken, file) => {
    
    Alexey Lunin's avatar
    Alexey Lunin committed
          const authenticationPublicKey = localStorage.getItem("authenticatedIdentity");
    
    Alexey Lunin's avatar
    Alexey Lunin committed
          if (
            !authenticationPublicKey ||
            !window.loadedIdentities[authenticationPublicKey] ||
            !extendPinCodeTtl(authenticationPublicKey)
          ) {
            return encodeResponse("400", "", "Identity not authenticated");
          }
    
    
          const response = await wopiAPI.putDocument(path, accessToken, file);
    
    Alexey Lunin's avatar
    Alexey Lunin committed
          return response.data;
    
    Markin Igor's avatar
    Markin Igor committed
    });
    
    connection.promise.then(parent => {
    
      iframeParent = parent;
    
    
      if (!navigator.cookieEnabled) {
        console.warn("Cookie disabled. Can't start library.");
        return;
      }
    
    
      window.addEventListener('storage', event => {
        if (event.key === "authenticatedIdentity" && event.newValue === null) {
    
    Markin Igor's avatar
    Markin Igor committed
          const publicKey = window.currentlyAuthenticatedIdentity.authentication.publicKey;
    
          window.currentlyLoadedIdentity = null;
          window.currentlyAuthenticatedIdentity = null;
    
    Markin Igor's avatar
    Markin Igor committed
          const event = createEvent("LogoutFromAnotherTab", "Logout", [publicKey]);
          parent.onEvent(event);
    
    Markin Igor's avatar
    Markin Igor committed
      const identities = localStorage.getItem("identities");
    
    Markin Igor's avatar
    Markin Igor committed
      console.log("Library loaded at: " + new Date().toISOString());
    
    
      if (identities === "" || identities === null) {
    
    Markin Igor's avatar
    Markin Igor committed
        localStorage.setItem("identities", JSON.stringify({}));
    
    Markin Igor's avatar
    Markin Igor committed
      if (
        localStorage.getItem("uuid") === null ||
        localStorage.getItem("token") === null ||
        localStorage.getItem("authenticatedIdentity") === null
      ) {
    
        const event = createEvent("", "NotAuthenticated");
        parent.onEvent(event);
    
    Markin Igor's avatar
    Markin Igor committed
        localStorage.removeItem("uuid");
        localStorage.removeItem("token");
    
    Markin Igor's avatar
    Markin Igor committed
        localStorage.removeItem("authenticatedIdentity");
    
        const authenticationPublicKey = localStorage.getItem("authenticatedIdentity");
        const pinCode = getPincode(authenticationPublicKey);
    
    Markin Igor's avatar
    Markin Igor committed
        if (pinCode === "" || pinCode === null) {
    
          loadIdentityInternal(authenticationPublicKey, "00000000").then(result => {
    
    Markin Igor's avatar
    Markin Igor committed
            if (result.code !== "200") {
              const event = createEvent(
                "CanNotGetPincodeForAuthenticatedIdentity",
                "IdentityNotLoaded",
    
                [authenticationPublicKey]
    
    Markin Igor's avatar
    Markin Igor committed
              );
              parent.onEvent(event);
    
          loadIdentityInternal(authenticationPublicKey, pinCode).then(result => {
    
    Markin Igor's avatar
    Markin Igor committed
            if (result.code !== "200") {
              const event = createEvent(
                "CanNotLoadIdentity",
                "ErrorDuringLoadingIdentity",
    
                [authenticationPublicKey]
    
    Markin Igor's avatar
    Markin Igor committed
              );
              parent.onEvent(event);
    
      let anynomousDeviceKeyEventsProcessing = false;
      let maxDeviceKeyAnonymousEventTime = 0;
    
      let eventsDeviceEventsProcessing = false;
      let maxDeviceKeyEventTime = 0;
    
      let eventsEntityEventsProcessing = false;
      let maxEntityEventTime = 0;
    
      let identityLoadedEvent = false;
      let identityAuthenticatedEvent = false;
    
    Markin Igor's avatar
    Markin Igor committed
      setInterval(async function () {
        if (window.currentlyAuthenticatedIdentity) {
          const { authentication } = window.currentlyAuthenticatedIdentity;
          const pinCode = getPincode(authentication.publicKey);
          if (pinCode) {
            const identity = await getIdentityFromLocalStorage(authentication.publicKey, pinCode, false);
    
    Markin Igor's avatar
    Markin Igor committed
            window.currentlyLoadedIdentity = identity;
    
            if (!identityAuthenticatedEvent && identity) {
              const event = createEvent("IdentityAuthenticated", "Authenticated", [identity.authentication.publicKey]);
              parent.onEvent(event);
              identityAuthenticatedEvent = true;
            }
    
            const authenticationPublicKey = localStorage.getItem("authenticatedIdentity");
    
    Markin Igor's avatar
    Markin Igor committed
            if (authenticationPublicKey) {
              const result = await loadIdentityInternal(authenticationPublicKey, "00000000");
              if (result.code !== "200") {
                const event = createEvent("CanNotGetPincodeForAuthenticatedIdentity", "IdentityNotLoaded", [authenticationPublicKey]);
                parent.onEvent(event);
                clearPinCodeTtl(authenticationPublicKey);
                window.currentlyAuthenticatedIdentity = null;
              }
    
    Markin Igor's avatar
    Markin Igor committed
            identityAuthenticatedEvent = false;
    
    Markin Igor's avatar
    Markin Igor committed
            window.currentlyLoadedIdentity = null;
    
    Markin Igor's avatar
    Markin Igor committed
        if (window.currentlyLoadedIdentity) {
          const pinCode = getPincode(window.currentlyLoadedIdentity.authentication.publicKey);
          if (!pinCode) {
            if (!identityLoadedEvent) {
              const result = await loadIdentityInternal(window.currentlyLoadedIdentity.authentication.publicKey, "00000000");
    
              if (window.currentlyLoadedIdentity && result.code !== "200") {
    
    Markin Igor's avatar
    Markin Igor committed
                const event = createEvent("CanNotLoadPincodeForLoadedIdentity", "IdentityNotLoaded", [window.currentlyLoadedIdentity.authentication.publicKey]);
                parent.onEvent(event);
                identityLoadedEvent = true;
              }
    
    Markin Igor's avatar
    Markin Igor committed
            identityLoadedEvent = false;
    
    Markin Igor's avatar
    Markin Igor committed
        if (window.currentlyAuthenticatedIdentity) {
          const now = new Date().getTime();
          if (now - window.lastTimeGetProfile > 30000) {
            getProfileData(window.currentlyAuthenticatedIdentity);
    
    Markin Igor's avatar
    Markin Igor committed
            window.lastTimeGetProfile = now;
    
    Markin Igor's avatar
    Markin Igor committed
      }, 50);
    
      const getNewEventsWithoutSession = async () => {
        anynomousDeviceKeyEventsProcessing = true;
        try {
          const executeResult = await executeRestfulFunction("public", viamAnonymousApi, viamAnonymousApi.eventGetNewEventsWithoutSession, null, "devicekey");
          if(executeResult.code === "200") {
            const eventsLen = executeResult.data.length;
            let changedMaxDeviceKeyAnonymousEventTime = false;
            for (let i = 0; i < eventsLen; i++) {
              const event = executeResult.data[i];
              switch (event.type) {
                case "DeviceConfirmed" : {
                  await setIdentityInLocalStorage(window.currentlyLoadedIdentity);
                  parent.onEvent(event);
                  break;
    
                case "QRCodeUpdated" : {
    
                  const actionID = event["actionID"];
                  const QrCode = event["payloads"][1];
    
                  const eventCopy = JSON.parse(JSON.stringify(event));
    
    
                  QRCode.toDataURL(actionID + "," + QrCode, function (err, url) {
    
    Markin Igor's avatar
    Markin Igor committed
                    eventCopy["payloads"].push(url);
    
                  break;
                }
    
                case "KeyDeleted" : {
                  const authenticationPublicKey = localStorage.getItem("authenticatedIdentity");
                  clearPinCodeTtl(authenticationPublicKey);
                  localStorage.removeItem("uuid");
                  localStorage.removeItem("token");
                  localStorage.removeItem("authenticatedIdentity");
                  delete window.loadedIdentities[authenticationPublicKey];
                  window.currentlyLoadedIdentity = null;
                  window.currentlyAuthenticatedIdentity = null;
                  window.lastTimeGetProfile = 0;
    
                  destroyIdentityFromLocalStorage(authenticationPublicKey);
                  break;
                }
    
                default : {
    
              changedMaxDeviceKeyAnonymousEventTime = true;
              maxDeviceKeyAnonymousEventTime = Math.max(maxDeviceKeyAnonymousEventTime, event.stamp);
            }
    
            if(changedMaxDeviceKeyAnonymousEventTime) {
              await executeRestfulFunction("public", viamAnonymousApi, viamAnonymousApi.eventUpdateLastViewedWithoutSession,
                null, "devicekey", maxDeviceKeyAnonymousEventTime.toString());
            }
          }
        } catch (e) {
          console.warn(e);
        }
        anynomousDeviceKeyEventsProcessing = false;
      };
    
      const getNewDeviceEvents = async () => {
        eventsDeviceEventsProcessing = true;
        try {
          const executeResult = await executeRestfulFunction("private", viamApi, viamApi.eventGetNewEvents, null, "devicekey");
          if (executeResult.code === "200") {
            const eventsLen = executeResult.data.length;
            const changedMaxDeviceKeyEventTime = false;
            for (let i = 0; i < eventsLen; i++) {
              const event = executeResult.data[i];
              if (event.type === "QRCodeUpdated") {
                const actionID = event["actionID"];
                const QrCode = event["payloads"][1];
    
                const eventCopy = JSON.parse(JSON.stringify(event));
    
                QRCode.toDataURL(actionID + "," + QrCode, function (err, url) {
                  eventCopy["payloads"].push(url);
                  parent.onEvent(eventCopy);
                });
              } else {
                parent.onEvent(event);
    
              maxDeviceKeyEventTime = Math.max(maxDeviceKeyEventTime, event.stamp);
            }
            if(changedMaxDeviceKeyEventTime) {
              await executeRestfulFunction("private", viamApi, viamApi.eventUpdateLastViewed, null, "devicekey",
                maxDeviceKeyEventTime.toString());
    
        } catch (e) {
          console.warn(e);
    
        eventsDeviceEventsProcessing = false;
      };
    
      const getNewEntityEvents = async () => {
        eventsEntityEventsProcessing = true;
        try {
          const executeResult = await executeRestfulFunction("private", viamApi, viamApi.eventGetNewEvents, null, "entity");
    
          if (executeResult.code === "200") {
            const eventsLen = executeResult.data.length;
            let changedMaxEntityEventTime = false;
            for (let i = 0; i < eventsLen; i++) {
              const event = executeResult.data[i];
              if (event.type === "QRCodeUpdated") {
                const actionID = event["actionID"];
                const QrCode = event["payloads"][1];
    
                const eventCopy = JSON.parse(JSON.stringify(event));
    
                QRCode.toDataURL(actionID + "," + QrCode, function (err, url) {
                  eventCopy["payloads"].push(url);
                  parent.onEvent(eventCopy);
                });
    
    
              parent.onEvent(event);
              changedMaxEntityEventTime = true;
              maxEntityEventTime = Math.max(maxEntityEventTime, event.stamp);
            }
            if(changedMaxEntityEventTime) {
              await executeRestfulFunction("private", viamApi, viamApi.eventUpdateLastViewed, null, "entity",
                maxEntityEventTime.toString());
    
        } catch (e) {
          console.warn(e);
        }
        eventsEntityEventsProcessing = false;
      }
    
      setInterval(() => {
        if (window.currentlyLoadedIdentity && !anynomousDeviceKeyEventsProcessing && !window.currentlyAuthenticatedIdentity) {
          getNewEventsWithoutSession();
        }
    
        if (window.currentlyAuthenticatedIdentity) {
          // These functions has to be executed at the same time.
          !eventsDeviceEventsProcessing && getNewDeviceEvents();
          !eventsEntityEventsProcessing && getNewEntityEvents();