@myop/sdk 0.0.1 → 0.1.40

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.
Files changed (47) hide show
  1. package/dist/bundled-declarations.d.ts +96 -82
  2. package/dist/cjs/_IframeSDK.3a618a6c.min.js +1 -0
  3. package/dist/cjs/{_IframeSDK.c5a563b1.js → _IframeSDK.5af88b19.js} +120 -2
  4. package/dist/cjs/{_IframeSDK.c5a563b1.js.map → _IframeSDK.5af88b19.js.map} +3 -3
  5. package/dist/cjs/{_MyopHelpers.24c3f801.js → _MyopHelpers.98cae3f9.js} +1 -1
  6. package/dist/cjs/_MyopHelpers.98cae3f9.js.map +7 -0
  7. package/dist/cjs/_MyopHelpers.f3e207e0.min.js +1 -0
  8. package/dist/cjs/{_MyopMessages.de6876c1.js → _MyopMessages.1fdd2452.js} +1 -1
  9. package/dist/cjs/_MyopMessages.1fdd2452.js.map +7 -0
  10. package/dist/cjs/_MyopMessages.71dc535d.min.js +1 -0
  11. package/dist/cjs/_WebComponentSDK.54454042.min.js +1 -0
  12. package/dist/cjs/{_WebComponentSDK.c1dbe840.js → _WebComponentSDK.dec2905a.js} +120 -2
  13. package/dist/cjs/{_WebComponentSDK.c1dbe840.js.map → _WebComponentSDK.dec2905a.js.map} +3 -3
  14. package/dist/cjs/_hostSDK.47eaab83.min.js +1 -0
  15. package/dist/cjs/{_hostSDK.411032df.js → _hostSDK.fcf2c04e.js} +120 -2
  16. package/dist/cjs/{_hostSDK.411032df.js.map → _hostSDK.fcf2c04e.js.map} +3 -3
  17. package/dist/cjs/myop_sdk.js +17 -17
  18. package/dist/cjs/myop_sdk.js.map +1 -1
  19. package/dist/cjs/myop_sdk.min.js +1 -1
  20. package/dist/module/Iframe/index.js +127 -3
  21. package/dist/module/Iframe/index.js.map +3 -3
  22. package/dist/module/SDK.js +472 -393
  23. package/dist/module/SDK.js.map +4 -4
  24. package/dist/module/common/index.js +2 -2
  25. package/dist/module/common/index.js.map +3 -3
  26. package/dist/module/common/utils/serialization.d.ts +2 -1
  27. package/dist/module/helpers/index.js +2 -2
  28. package/dist/module/helpers/index.js.map +3 -3
  29. package/dist/module/host/componentCore.d.ts +1 -1
  30. package/dist/module/host/hostSDK.d.ts +2 -2
  31. package/dist/module/host/index.js +127 -3
  32. package/dist/module/host/index.js.map +3 -3
  33. package/dist/module/host/myopOverride.d.ts +2 -0
  34. package/dist/module/messages/index.js +2 -2
  35. package/dist/module/messages/index.js.map +3 -3
  36. package/dist/module/utils/utils.d.ts +1 -1
  37. package/dist/module/utils/uuid.d.ts +7 -0
  38. package/dist/module/webcomponent/index.js +127 -3
  39. package/dist/module/webcomponent/index.js.map +3 -3
  40. package/package.json +2 -2
  41. package/dist/cjs/_IframeSDK.13abd0a4.min.js +0 -1
  42. package/dist/cjs/_MyopHelpers.24c3f801.js.map +0 -7
  43. package/dist/cjs/_MyopHelpers.a734fddc.min.js +0 -1
  44. package/dist/cjs/_MyopMessages.c2dba3be.min.js +0 -1
  45. package/dist/cjs/_MyopMessages.de6876c1.js.map +0 -7
  46. package/dist/cjs/_WebComponentSDK.16d30aae.min.js +0 -1
  47. package/dist/cjs/_hostSDK.bb1d87e3.min.js +0 -1
@@ -39,7 +39,7 @@ var __async = (__this, __arguments, generator) => {
39
39
  });
40
40
  };
41
41
 
42
- // src/utils/utils.ts
42
+ // src/utils/uuid.ts
43
43
  var uuidv4 = () => {
44
44
  return "10000000-1000-4000-8000-100000000000".replace(
45
45
  /[018]/g,
@@ -408,4 +408,4 @@ export {
408
408
  exec,
409
409
  removeClass
410
410
  };
411
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3V0aWxzL3V0aWxzLnRzIiwgIi4uLy4uLy4uL3NyYy9tZXNzYWdlcy9CYXNlTWVzc2FnZS50cyIsICIuLi8uLi8uLi9zcmMvbWVzc2FnZXMvRXhlY3V0ZVNjcmlwdE1lc3NhZ2UudHMiLCAiLi4vLi4vLi4vc3JjL21lc3NhZ2VzL0N1c3RvbVJlZk1lc3NhZ2UudHMiLCAiLi4vLi4vLi4vc3JjL2hlbHBlcnMvYXBwbHlTdHlsZXNoZWV0LnRzIiwgIi4uLy4uLy4uL3NyYy9oZWxwZXJzL2lmcmFtZVNraW5VcmxUb2tlbml6ZXIudHMiLCAiLi4vLi4vLi4vc3JjL2hlbHBlcnMvY2xhc3NMaXN0LnRzIiwgIi4uLy4uLy4uL3NyYy9oZWxwZXJzL2NvbmZpZ0J1aWxkZXIudHMiLCAiLi4vLi4vLi4vc3JjL2hlbHBlcnMvQ2xvdWRSZXBvc2l0b3J5LnRzIiwgIi4uLy4uLy4uL3NyYy9oZWxwZXJzL2V4ZWMudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImV4cG9ydCBjb25zdCB1dWlkdjQgPSAoKSA9PiB7XG4gICAgcmV0dXJuIFwiMTAwMDAwMDAtMTAwMC00MDAwLTgwMDAtMTAwMDAwMDAwMDAwXCIucmVwbGFjZSgvWzAxOF0vZywgYyA9PlxuICAgICAgICAoK2MgXiBjcnlwdG8uZ2V0UmFuZG9tVmFsdWVzKG5ldyBVaW50OEFycmF5KDEpKVswXSAmIDE1ID4+ICtjIC8gNCkudG9TdHJpbmcoMTYpXG4gICAgKTtcbn1cblxuZXhwb3J0IGNvbnN0IHdhaXQgPSAobXM6IG51bWJlcikgPT4ge1xuICAgIHJldHVybiBuZXcgUHJvbWlzZShyZXNvbHZlID0+IHNldFRpbWVvdXQocmVzb2x2ZSwgbXMpKTtcbn0iLCAiaW1wb3J0IHtNeW9wTWVzc2FnZUtleX0gZnJvbSBcIi4uL2NvbW1vbi9NeW9wTWVzc2FnZXNcIjtcbmltcG9ydCB7dXVpZHY0fSBmcm9tIFwiLi4vdXRpbHMvdXRpbHNcIjtcbmltcG9ydCB7SU15b3BDb21wb25lbnR9IGZyb20gXCIuLi9ob3N0XCI7XG5pbXBvcnQge0lSZWZDb25maWd9IGZyb20gXCIuLi9jb21tb25cIjtcblxuZXhwb3J0IGNsYXNzIE1lc3NhZ2VEaXJlY3Rpb24ge1xuICAgIHN0YXRpYyBkb3duID0gJ2Rvd24nIGFzIGNvbnN0XG4gICAgc3RhdGljIHVwID0gJ3VwJyBhcyBjb25zdFxufVxuXG5leHBvcnQgdHlwZSBNZXNzYWdlRGlyZWN0aW9uT3B0aW9uID0gJ3VwJyB8ICdkb3duJztcblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJhc2VNeW9wTWVzc2FnZTxUID0gYW55PiB7XG4gICAgaWQgPSB1dWlkdjQoKVxuXG4gICAgc3RhdGljIGNyZWF0ZTxULCBVIGV4dGVuZHMgbmV3ICguLi5hcmdzOiBDb25zdHJ1Y3RvclBhcmFtZXRlcnM8VT4pID0+IFQgPSB0eXBlb2YgdGhpcz4oXG4gICAgICAgIHRoaXM6IFUsXG4gICAgICAgIC4uLmFyZ3M6IENvbnN0cnVjdG9yUGFyYW1ldGVyczxVPlxuICAgICk6IEluc3RhbmNlVHlwZTx0eXBlb2YgdGhpcz4ge1xuICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgIHJldHVybiBuZXcgdGhpcyguLi5hcmdzKTtcbiAgICB9XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgLy9jb25zb2xlLmxvZygnbWVlc2FnZSBpZCBjcmVhdGVkJywgdGhpcy5pZCwgZG9jdW1lbnQubG9jYXRpb24uaHJlZik7XG4gICAgfVxuXG4gICAgbXlvcCA9IHRydWVcblxuICAgIGFic3RyYWN0IG1lc3NhZ2VUeXBlOiBNeW9wTWVzc2FnZUtleSB8IHN0cmluZztcblxuICAgIGNvbnRlbnQ/OiBUXG5cbiAgICAvLyBUT0RPIDogY2FudCBiZSBvcHRpb25hbCBcbiAgICBzb3VyY2U/OiBzdHJpbmdcbiAgICBkZXN0aW5hdGlvbj86IHN0cmluZ1xuXG4gICAgcm91dGU/OiBzdHJpbmdbXVxuXG4gICAgcmVmPzogUmVmXG5cbiAgICBkaXJlY3Rpb24/OiBNZXNzYWdlRGlyZWN0aW9uT3B0aW9uXG5cbiAgICBjbGVhbmFibGU6IGJvb2xlYW4gPSBmYWxzZVxuXG4gICAgaXNUeXBlb2YobXNnOiBCYXNlTXlvcE1lc3NhZ2UpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIG1zZy5tZXNzYWdlVHlwZSA9PT0gdGhpcy5tZXNzYWdlVHlwZVxuICAgIH1cbn1cblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIE15b3BFbGVtZW50TWVzc2FnZTxUID0gYW55PiBleHRlbmRzIEJhc2VNeW9wTWVzc2FnZTxUPiB7XG4gICAgY29uc3RydWN0b3IocHVibGljIHJlZjogUmVmKSB7XG4gICAgICAgIHN1cGVyKClcbiAgICB9XG59XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBNeW9wQmluZFJlcGxheU1lc3NhZ2U8VCA9IGFueT4gZXh0ZW5kcyBCYXNlTXlvcE1lc3NhZ2U8VD4ge1xuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyByZXBsYXlUb0hhbmRsZXI/OiBzdHJpbmcpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG59XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBNeW9wQmluZE1lc3NhZ2U8VCA9IGFueSwgUiBleHRlbmRzIE15b3BCaW5kUmVwbGF5TWVzc2FnZSA9IGFueT4gZXh0ZW5kcyBCYXNlTXlvcE1lc3NhZ2U8VD4ge1xuXG4gICAgcHVibGljIGFic3RyYWN0IHJlcGx5TWVzc2FnZUtleTogTXlvcE1lc3NhZ2VLZXk7XG5cbiAgICBwdWJsaWMgaGFuZGxlclVuaXF1ZUlkID0gdXVpZHY0KClcblxuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBoYW5kbGVyOiAobWVzc2FnZTogUikgPT4gdm9pZCkge1xuICAgICAgICBzdXBlcigpXG4gICAgfVxufVxuXG5leHBvcnQgY2xhc3MgUmVmIHtcbiAgICBwdWJsaWMgbXlvcCA9IHRydWU7XG5cbiAgICBwdWJsaWMgX19ub25Qcm94aWVkPzogUmVmO1xuXG4gICAgc3RhdGljIGNyZWF0ZShzZWxlY3Rvcjogc3RyaW5nLCByZWZDb25maWc/OiBJUmVmQ29uZmlnLCBjb21wb25lbnQ/OiBJTXlvcENvbXBvbmVudCkge1xuICAgICAgICBsZXQgX3JlZkNvbmZpZyA9IHJlZkNvbmZpZztcbiAgICAgICAgaWYgKCFfcmVmQ29uZmlnKSB7XG4gICAgICAgICAgICBfcmVmQ29uZmlnID0ge1xuICAgICAgICAgICAgICAgIGlkOiAnJyxcbiAgICAgICAgICAgICAgICBuYW1lOiAnJyxcbiAgICAgICAgICAgICAgICBkZXNjcmlwdGlvbjogJycsXG4gICAgICAgICAgICAgICAgc2VsZWN0b3JUeXBlOiAnaWQtYXR0cmlidXRlJyxcbiAgICAgICAgICAgICAgICBzZWxlY3Rvcjogc2VsZWN0b3IsXG4gICAgICAgICAgICAgICAgYmVoYXZpb3I6IHtcbiAgICAgICAgICAgICAgICAgICAgdHlwZTogJ2NvZGUnXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSBhcyBJUmVmQ29uZmlnXG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG5ldyBSZWYoX3JlZkNvbmZpZywgY29tcG9uZW50KTtcbiAgICB9XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgcmVmQ29uZmlnOiBJUmVmQ29uZmlnLCBwdWJsaWMgY29tcG9uZW50PzogSU15b3BDb21wb25lbnQpIHtcbiAgICAgICAgdGhpcy5fX25vblByb3hpZWQgPSB7XG4gICAgICAgICAgICAuLi50aGlzLFxuICAgICAgICAgICAgY29tcG9uZW50OiBudWxsIC8vIGluIG9yZGVyIHRvIGJlIHNlcmlhbGl6YWJsZVxuICAgICAgICB9XG4gICAgfVxufVxuIiwgImltcG9ydCB7TXlvcEJpbmRNZXNzYWdlLCBNeW9wQmluZFJlcGxheU1lc3NhZ2V9IGZyb20gXCIuL0Jhc2VNZXNzYWdlXCI7XG5pbXBvcnQge015b3BNZXNzYWdlS2V5fSBmcm9tIFwiLi4vY29tbW9uL015b3BNZXNzYWdlc1wiO1xuaW1wb3J0IHtSb290UmVmfSBmcm9tIFwiLi4vY29tbW9uXCI7XG5pbXBvcnQge21ha2VTZXJpYWxpemFibGV9IGZyb20gXCIuLi9jb21tb24vdXRpbHMvc2VyaWFsaXphdGlvbi50c1wiO1xuXG5jb25zdCBSZXBsYXlNZXNzYWdlS2V5ID0gJ0V4ZWN1dGVTY3JpcHRSZXBseU1lc3NhZ2UnXG5cbmNvbnN0IGZ1bmN0aW9uQm9keVJlZ2V4ID0gLyg/OmZ1bmN0aW9uXFxzKlxcdypcXHMqXFwoW14pXSpcXClcXHMqXFx7KFtcXHNcXFNdKj8pXFx9fChcXChbXildKlxcKVxccyo9PlxccypcXHsoW1xcc1xcU10qPylcXH0pKVxccyokLztcbmNvbnN0IGV4cHJlc3Npb25Cb2R5UmVnZXggPSAvXFwoXFxzKlteKV0rXFxzKlxcKVxccyo9PlxccyooLispLztcblxuZXhwb3J0IGNvbnN0IHN0cmlwRnVuY3Rpb24gPSAoY29udGVudDogc3RyaW5nKSA9PiB7XG4gICAgbGV0IG1hdGNoID0gY29udGVudC5tYXRjaChmdW5jdGlvbkJvZHlSZWdleCk7XG4gICAgaWYgKG1hdGNoKSB7XG4gICAgICAgIHJldHVybiBtYXRjaFsxXSB8fCBtYXRjaFszXTtcbiAgICB9IGVsc2Uge1xuICAgICAgICBsZXQgbWF0Y2ggPSBjb250ZW50Lm1hdGNoKGV4cHJlc3Npb25Cb2R5UmVnZXgpO1xuICAgICAgICBpZiAobWF0Y2gpXG4gICAgICAgICAgICByZXR1cm4gbWF0Y2hbMV0udHJpbSgpO1xuICAgIH1cbn1cblxuZXhwb3J0IHR5cGUgc2NyaXB0SW5wdXRzID0ge1xuICAgIFtrZXk6IHN0cmluZ106IHN0cmluZyB8IG51bWJlciB8IGJvb2xlYW5cbn0gfCB7fTtcblxuZXhwb3J0IHR5cGUgc2NyaXB0VmFyczxUPiA9IHtcbiAgICBzZW5kOiAoZGF0YTogVCkgPT4gdm9pZDtcbiAgICAvLyBjb21wbGV0ZVN0cmVhbTogKCkgPT4gdm9pZDtcbiAgICByb290UmVmOiBSb290UmVmO1xuICAgIG1ha2VTZXJpYWxpemFibGU6IHR5cGVvZiBtYWtlU2VyaWFsaXphYmxlXG59XG5cbmV4cG9ydCB0eXBlIGV4dGVuZGVkU2NyaXB0VmFyczxULCBJPiA9IHtcbiAgICBbSyBpbiBrZXlvZiBJXTogSVtLXTtcbn0gJiBzY3JpcHRWYXJzPFQ+XG5cbmV4cG9ydCBjbGFzcyBFeGVjdXRlU2NyaXB0TWVzc2FnZTxUID0gYW55LCBJIGV4dGVuZHMgc2NyaXB0SW5wdXRzID0gYW55PiBleHRlbmRzIE15b3BCaW5kTWVzc2FnZTxzdHJpbmcsIEV4ZWN1dGVTY3JpcHRSZXBseU1lc3NhZ2U8VD4+IHtcblxuICAgIHJlcGx5TWVzc2FnZUtleTogTXlvcE1lc3NhZ2VLZXkgPSBSZXBsYXlNZXNzYWdlS2V5O1xuICAgIG1lc3NhZ2VUeXBlID0gJ0V4ZWN1dGVTY3JpcHRNZXNzYWdlJztcbiAgICBzY3JpcHQ6IHN0cmluZyA9ICcnXG5cbiAgICBzdGF0aWMgcmVwbGllcktleSA9ICdzZW5kJztcbiAgICBzdGF0aWMgY29tcGxldGVTdHJlYW1LZXkgPSAnY29tcGxldGVTdHJlYW0nO1xuXG4gICAgY29uc3RydWN0b3Ioc2NyaXB0OiAodmFyczogZXh0ZW5kZWRTY3JpcHRWYXJzPFQsIEk+KSA9PiBULCBoYW5kbGVyOiAobWVzc2FnZTogRXhlY3V0ZVNjcmlwdFJlcGx5TWVzc2FnZTxUPikgPT4gdm9pZCA9ICgpID0+IHtcbiAgICB9LCBwdWJsaWMgc2NyaXB0SW5wdXRzPzogSSkge1xuICAgICAgICBzdXBlcihoYW5kbGVyKTtcbiAgICAgICAgdGhpcy5zY3JpcHQgPSBzY3JpcHQudG9TdHJpbmcoKTtcblxuICAgICAgICAvL1RPRE86IGNhbiBiZSByZW1vdmVcbiAgICAgICAgdGhpcy5jb250ZW50ID0gc2NyaXB0LnRvU3RyaW5nKClcbiAgICAgICAgdGhpcy5jb250ZW50ID0gc3RyaXBGdW5jdGlvbih0aGlzLmNvbnRlbnQpO1xuICAgIH1cbn1cblxuZXhwb3J0IGNsYXNzIEV4ZWN1dGVTY3JpcHRSZXBseU1lc3NhZ2U8VCA9IGFueT4gZXh0ZW5kcyBNeW9wQmluZFJlcGxheU1lc3NhZ2U8VD4ge1xuXG4gICAgbWVzc2FnZVR5cGUgPSBSZXBsYXlNZXNzYWdlS2V5O1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIHJlcGxheVRvSGFuZGxlcjogc3RyaW5nLCBwdWJsaWMgY29udGVudDogVCkge1xuICAgICAgICBzdXBlcihyZXBsYXlUb0hhbmRsZXIpO1xuICAgIH1cbn1cbiIsICJpbXBvcnQge1xuICAgIEV4ZWN1dGVTY3JpcHRNZXNzYWdlLFxuICAgIEV4ZWN1dGVTY3JpcHRSZXBseU1lc3NhZ2UsXG4gICAgZXh0ZW5kZWRTY3JpcHRWYXJzLFxuICAgIHNjcmlwdElucHV0cywgc3RyaXBGdW5jdGlvblxufSBmcm9tIFwiLi9FeGVjdXRlU2NyaXB0TWVzc2FnZS50c1wiO1xuXG5leHBvcnQgdHlwZSBjdXN0b21SZWZTY3JpcHRJbnB1dHMgPSB7XG4gICAgZWxlbWVudElkOiBzdHJpbmcsXG4gICAgcmVmPzogSFRNTEVsZW1lbnQsXG4gICAgX3NjcmlwdD86IHN0cmluZyxcbiAgICBfX3NjcmlwdElucHV0cz86IE9iamVjdFxufTtcblxuZXhwb3J0IGNsYXNzIEN1c3RvbVJlZk1lc3NhZ2U8VCA9IGFueSwgSSBleHRlbmRzIHNjcmlwdElucHV0cyA9IGN1c3RvbVJlZlNjcmlwdElucHV0cz4gZXh0ZW5kcyBFeGVjdXRlU2NyaXB0TWVzc2FnZTxULCBJICYgY3VzdG9tUmVmU2NyaXB0SW5wdXRzPiB7XG5cbiAgICBjb25zdHJ1Y3RvcihzY3JpcHQ6ICh2YXJzOiBleHRlbmRlZFNjcmlwdFZhcnM8VCwgSSAmIGN1c3RvbVJlZlNjcmlwdElucHV0cz4pID0+IFQsXG4gICAgICAgICAgICAgICAgcHVibGljIHNjcmlwdElucHV0czogSSAmIGN1c3RvbVJlZlNjcmlwdElucHV0cyxcbiAgICAgICAgICAgICAgICBoYW5kbGVyOiAobWVzc2FnZTogRXhlY3V0ZVNjcmlwdFJlcGx5TWVzc2FnZTxUPikgPT4gdm9pZCA9ICgpID0+IHtcbiAgICAgICAgICAgICAgICB9KSB7XG5cbiAgICAgICAgLy9tb2NrIHZhcnNcbiAgICAgICAgLy8gbGV0IHJvb3RSZWYsIGVsZW1lbnRJZCwgX3NjcmlwdCwgX19zY3JpcHRJbnB1dHM7XG4gICAgICAgIHN1cGVyKCh7cm9vdFJlZiwgZWxlbWVudElkLCBfc2NyaXB0LCBfX3NjcmlwdElucHV0c30pID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHJlZnMgPSAocm9vdFJlZi5zaGFkb3dSb290IHx8IHJvb3RSZWYuY29udGFpbmVyKS5xdWVyeVNlbGVjdG9yQWxsKGBbJHsnbXlvcC1pZCd9PScke2VsZW1lbnRJZH0nXWApO1xuICAgICAgICAgICAgaWYgKHJlZnMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgLy8gIGNvbnN0IHJlZiA9IHJlZnNbMF07XG5cbiAgICAgICAgICAgICAgICAvL1RPRE8gOiB0aGluayBhYm91dCBleHBvc2luZyBcInJlZnNcIiBhbmQgbm90IG9ubHkgXCJyZWZcIlxuICAgICAgICAgICAgICAgIC8vZm9yIGNhc2VzIHdoZXJlIHRoZSBSZWYgaGFzIG11bHRpcGxhdGUgaW1wbGVtZW50YXRpb25zXG5cbiAgICAgICAgICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgICAgICAgICAgX19zY3JpcHRJbnB1dHMucmVmID0gcmVmc1swXTtcblxuICAgICAgICAgICAgICAgIGNvbnN0IGR5bmFtaWNGdW5jdGlvbiA9IG5ldyBGdW5jdGlvbihgcmV0dXJuICgke19zY3JpcHR9KSguLi5hcmd1bWVudHMpYCk7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGR5bmFtaWNGdW5jdGlvbihfX3NjcmlwdElucHV0cyk7XG5cbiAgICAgICAgICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgICAgICAgICAgLy9yZXR1cm4gRnVuY3Rpb24oJ3JlZicsICdyb290UmVmJywgLi4uT2JqZWN0LmtleXMoX19zY3JpcHRJbnB1dHMpLCBfc2NyaXB0ISkocmVmLCByb290UmVmLCAuLi5PYmplY3QudmFsdWVzKF9fc2NyaXB0SW5wdXRzKSlcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJldHVybiBudWxsIGFzIFQ7XG4gICAgICAgIH0sIGhhbmRsZXIpO1xuXG4gICAgICAgIHRoaXMuc2NyaXB0SW5wdXRzID0ge1xuICAgICAgICAgICAgLi4uc2NyaXB0SW5wdXRzLFxuICAgICAgICAgICAgLy9fc2NyaXB0OiBzdHJpcEZ1bmN0aW9uKHNjcmlwdC50b1N0cmluZygpKSxcbiAgICAgICAgICAgIF9zY3JpcHQ6IHNjcmlwdC50b1N0cmluZygpXG4gICAgICAgIH07XG4gICAgfVxufVxuIiwgImltcG9ydCB0eXBlICogYXMgQ1NTIGZyb20gXCJjc3N0eXBlXCI7XG5pbXBvcnQge0lNeW9wQ29tcG9uZW50fSBmcm9tIFwiLi4vaG9zdFwiO1xuaW1wb3J0IHt1dWlkdjR9IGZyb20gXCIuLi91dGlscy91dGlscy50c1wiO1xuaW1wb3J0IHtFeGVjdXRlU2NyaXB0TWVzc2FnZX0gZnJvbSBcIi4uL21lc3NhZ2VzXCI7XG5cbi8vIGlnbm9yaW5nIGRvY3VtZW50YXRpb25cbi8qKiBAaWdub3JlICovXG5leHBvcnQgaW50ZXJmYWNlIENTU1Byb3BlcnRpZXMgZXh0ZW5kcyBDU1MuUHJvcGVydGllczxzdHJpbmcgfCBudW1iZXI+IHtcbn1cblxuZXhwb3J0IHR5cGUgU3R5bGVzaGVldERlZmluaXRpb24gPSB7IFtrZXk6IHN0cmluZ106IENTU1Byb3BlcnRpZXMgfTtcblxuZXhwb3J0IGNvbnN0IGFwcGx5U3R5bGVzaGVldCA9IChjb21wb25lbnQ6IElNeW9wQ29tcG9uZW50LCBzdHlsZXNoZWV0OiBTdHlsZXNoZWV0RGVmaW5pdGlvbiwgY3NzPzogc3RyaW5nKSA9PiB7XG4gICAgY29uc3QgdGFnSWQgPSBgbXlvcC1jc3MtJHt1dWlkdjQoKX1gO1xuICAgIGNvbXBvbmVudC5zZW5kKG5ldyBFeGVjdXRlU2NyaXB0TWVzc2FnZSgoe3Jvb3RSZWYsIF9zdHlsZXNoZWV0LCBfdGFnSWQsIF9jc3N9KSA9PiB7XG4gICAgICAgIGNvbnN0IHN0eWxlVGFnID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnc3R5bGUnKTtcbiAgICAgICAgc3R5bGVUYWcudHlwZSA9ICd0ZXh0L2Nzcyc7XG5cbiAgICAgICAgLy8gQnVpbGQgdGhlIENTUyBzdHJpbmcgZnJvbSB0aGUgc3R5bGVzIG9iamVjdFxuICAgICAgICBsZXQgY3NzU3RyaW5nID0gX2NzcztcblxuICAgICAgICBmb3IgKGNvbnN0IHNlbGVjdG9yIGluIF9zdHlsZXNoZWV0KSB7XG4gICAgICAgICAgICBjc3NTdHJpbmcgKz0gYCR7c2VsZWN0b3J9IHsgYDtcbiAgICAgICAgICAgIGNvbnN0IHByb3BlcnRpZXMgPSBfc3R5bGVzaGVldFtzZWxlY3Rvcl07XG4gICAgICAgICAgICBmb3IgKGNvbnN0IHByb3BlcnR5IGluIHByb3BlcnRpZXMpIHtcbiAgICAgICAgICAgICAgICBjc3NTdHJpbmcgKz0gYCR7cHJvcGVydHl9OiAke3Byb3BlcnRpZXNbcHJvcGVydHldfTsgYDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGNzc1N0cmluZyArPSAnfSAnO1xuICAgICAgICB9XG5cbiAgICAgICAgLy8gU2V0IHRoZSBDU1Mgc3RyaW5nIGFzIHRoZSBjb250ZW50IG9mIHRoZSA8c3R5bGU+IGVsZW1lbnRcbiAgICAgICAgc3R5bGVUYWcuYXBwZW5kQ2hpbGQoZG9jdW1lbnQuY3JlYXRlVGV4dE5vZGUoY3NzU3RyaW5nKSk7XG4gICAgICAgIHN0eWxlVGFnLmlkID0gX3RhZ0lkO1xuICAgICAgICAvLyBBcHBlbmQgdGhlIDxzdHlsZT4gZWxlbWVudFxuICAgICAgICAocm9vdFJlZi5zaGFkb3dSb290IHx8IHJvb3RSZWYuY29udGFpbmVyKS5hcHBlbmRDaGlsZChzdHlsZVRhZyk7XG5cbiAgICB9LCAoKSA9PiB7XG4gICAgfSwge1xuICAgICAgICBfc3R5bGVzaGVldDogc3R5bGVzaGVldCxcbiAgICAgICAgX2NzcyA6IGNzcyA/IGNzcyA6ICcnLFxuICAgICAgICBfdGFnSWQ6IHRhZ0lkXG4gICAgfSkpO1xuXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgICAgY29tcG9uZW50LnNlbmQobmV3IEV4ZWN1dGVTY3JpcHRNZXNzYWdlKCh7cm9vdFJlZiwgX3RhZ0lkfSkgPT4ge1xuICAgICAgICAgICAgY29uc3QgZWxlbWVudCA9IChyb290UmVmLnNoYWRvd1Jvb3QgfHwgZG9jdW1lbnQpLmdldEVsZW1lbnRCeUlkKF90YWdJZCk7XG4gICAgICAgICAgICBpZiAoZWxlbWVudCkge1xuICAgICAgICAgICAgICAgIGVsZW1lbnQucmVtb3ZlKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0sICgpID0+IHtcbiAgICAgICAgfSwge1xuICAgICAgICAgICAgX3RhZ0lkOiB0YWdJZFxuICAgICAgICB9KSlcbiAgICB9XG59XG5cbmV4cG9ydCBjb25zdCBhcHBseVN0eWxlc2hlZXRMaW5rID0gKGNvbXBvbmVudDogSU15b3BDb21wb25lbnQsIGxpbms6IHN0cmluZykgPT4ge1xuICAgIGNvbnN0IHRhZ0lkID0gYG15b3AtY3NzLSR7dXVpZHY0KCl9YDtcbiAgICBjb21wb25lbnQuc2VuZChuZXcgRXhlY3V0ZVNjcmlwdE1lc3NhZ2UoKHtyb290UmVmLCBfdGFnSWQsIF9saW5rfSkgPT4ge1xuICAgICAgICBjb25zdCBsaW5rRWxlbWVudCA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ2xpbmsnKTtcbiAgICAgICAgbGlua0VsZW1lbnQuaWQgPSBfdGFnSWQ7XG4gICAgICAgIGxpbmtFbGVtZW50LnJlbCA9ICdzdHlsZXNoZWV0JztcbiAgICAgICAgbGlua0VsZW1lbnQuaHJlZiA9IF9saW5rO1xuICAgICAgICBkb2N1bWVudC5oZWFkLmFwcGVuZENoaWxkKGxpbmtFbGVtZW50KTtcblxuICAgICAgICAvLyBBcHBlbmQgdGhlIDxzdHlsZT4gZWxlbWVudFxuICAgICAgICAocm9vdFJlZi5zaGFkb3dSb290IHx8IHJvb3RSZWYuY29udGFpbmVyKS5hcHBlbmRDaGlsZChsaW5rRWxlbWVudCk7XG4gICAgfSwgKCkgPT4ge1xuICAgIH0sIHtcbiAgICAgICAgX2xpbmsgOiBsaW5rLFxuICAgICAgICBfdGFnSWQ6IHRhZ0lkXG4gICAgfSkpO1xuXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgICAgY29tcG9uZW50LnNlbmQobmV3IEV4ZWN1dGVTY3JpcHRNZXNzYWdlKCh7cm9vdFJlZiwgX3RhZ0lkfSkgPT4ge1xuICAgICAgICAgICAgY29uc3QgZWxlbWVudCA9IChyb290UmVmLnNoYWRvd1Jvb3QgfHwgZG9jdW1lbnQpLmdldEVsZW1lbnRCeUlkKF90YWdJZCk7XG4gICAgICAgICAgICBpZiAoZWxlbWVudCkge1xuICAgICAgICAgICAgICAgIGVsZW1lbnQucmVtb3ZlKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0sICgpID0+IHtcbiAgICAgICAgfSwge1xuICAgICAgICAgICAgX3RhZ0lkOiB0YWdJZFxuICAgICAgICB9KSlcbiAgICB9XG59XG4iLCAiaW1wb3J0IHtJSWZyYW1lTG9hZGVyQ29uZmlnLCBJU2tpbkNvbmZpZ30gZnJvbSBcIi4uL2NvbW1vblwiO1xuXG5leHBvcnQgdHlwZSBUb2tlbk1hcCA9IFJlY29yZDxzdHJpbmcsIHN0cmluZ3wgbnVtYmVyPlxuXG5jb25zdCByZXBsYWNlVG9rZW5zID0gKGlucHV0OiBzdHJpbmcsIHRva2VuTWFwOiBUb2tlbk1hcCk6IHN0cmluZyA9PiB7XG4gICAgLy8gQ3JlYXRlIGEgcmVnZXggcGF0dGVybiBmcm9tIHRoZSBrZXlzIG9mIHRoZSB0b2tlbk1hcFxuICAgIGNvbnN0IHBhdHRlcm4gPSBuZXcgUmVnRXhwKE9iamVjdC5rZXlzKHRva2VuTWFwKS5qb2luKCd8JyksICdnJyk7XG5cbiAgICAvLyBSZXBsYWNlIHRva2VucyBpbiB0aGUgaW5wdXQgc3RyaW5nIHVzaW5nIHRoZSByZWdleFxuICAgIHJldHVybiBpbnB1dC5yZXBsYWNlKHBhdHRlcm4sIChtYXRjaGVkKSA9PiB7XG4gICAgICAgIC8vIFJldHVybiB0aGUgcmVwbGFjZW1lbnQgdmFsdWUgZnJvbSB0aGUgdG9rZW5NYXBcbiAgICAgICAgcmV0dXJuICh0b2tlbk1hcFttYXRjaGVkXSB8fCBtYXRjaGVkKS50b1N0cmluZygpO1xuICAgIH0pO1xufVxuXG5leHBvcnQgY29uc3QgY3JlYXRlSWZyYW1lU2tpbkJ5VG9rZW5pemVyID0gKHNlbGVjdGVkU2tpbjogSVNraW5Db25maWcsIHRva2VuTWFwOiBUb2tlbk1hcCkgPT4ge1xuICAgIGNvbnN0IHR5cGVkU2tpbkNvbmZpZyA9IChzZWxlY3RlZFNraW4ubG9hZGVyIGFzIElJZnJhbWVMb2FkZXJDb25maWcpXG4gICAgaWYgKHR5cGVkU2tpbkNvbmZpZy50eXBlICE9PSAnSWZyYW1lTG9hZGVyJykge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYGlmcmFtZVNraW5VcmxUb2tlbml6ZXIgcmVjZWl2ZWQgc2tpbiB3aXRoIGxvYWRlciB0eXBlIFwiJHt0eXBlZFNraW5Db25maWcudHlwZX1cIiwgY3VycmVudGx5IG9ubHkgXCJJZnJhbWVMb2FkZXJcIiBpcyBzdXBwb3J0ZWRgKVxuICAgIH1cblxuICAgIHNlbGVjdGVkU2tpbi5sb2FkZXIgPSB7XG4gICAgICAgIC4uLnNlbGVjdGVkU2tpbi5sb2FkZXJcbiAgICB9XG5cbiAgICBzZWxlY3RlZFNraW4ubG9hZGVyLnVybCA9IHJlcGxhY2VUb2tlbnMoc2VsZWN0ZWRTa2luLmxvYWRlci51cmwsIHRva2VuTWFwKTtcblxuICAgIHJldHVybiBzZWxlY3RlZFNraW47XG59XG5cbmV4cG9ydCBjb25zdCBjaGFuZ2VTa2luVXJsQnlUb2tlbml6ZXIgPSAodG9rZW5NYXA6IFRva2VuTWFwKSA9PiB7XG4gICAgcmV0dXJuIGFzeW5jIChzZWxlY3RlZFNraW46IElTa2luQ29uZmlnKSA9PiB7XG4gICAgICAgIHJldHVybiBjcmVhdGVJZnJhbWVTa2luQnlUb2tlbml6ZXIoc2VsZWN0ZWRTa2luLCB0b2tlbk1hcCk7XG4gICAgfVxufSIsICJpbXBvcnQge0N1c3RvbVJlZk1lc3NhZ2V9IGZyb20gXCIuLi9tZXNzYWdlc1wiO1xuaW1wb3J0IHtJTXlvcENvbXBvbmVudH0gZnJvbSBcIi4uL2hvc3RcIjtcblxuLy8gY29uc3Qgc3BhY2UgPSAnICc7XG4vLyBleHBvcnQgY29uc3QgZ2V0Q2xhc3NlcyA9IGFzeW5jIChjb25uZWN0ZWRSZWY6IFJlZik6IFByb21pc2U8c3RyaW5nW10+ID0+IChhd2FpdCBleGVjKGFjdEFzPEhUTUxEaXZFbGVtZW50Pihjb25uZWN0ZWRSZWYpLmNsYXNzTGlzdCkpLnZhbHVlLnNwbGl0KHNwYWNlKTtcbi8vIGV4cG9ydCBjb25zdCBhZGRDbGFzcyA9IGFzeW5jIChjb25uZWN0ZWRSZWY6IFJlZiwgY2xhc3NOYW1lOiBzdHJpbmcpID0+IHtcbi8vICAgICBjb25zdCBjbGFzc2VzID0gYXdhaXQgZ2V0Q2xhc3Nlcyhjb25uZWN0ZWRSZWYpO1xuLy8gICAgIGNsYXNzZXMuaW5jbHVkZXMoY2xhc3NOYW1lKSB8fCBjbGFzc2VzLnB1c2goY2xhc3NOYW1lKTtcbi8vICAgICAvLyBAdHMtaWdub3JlXG4vLyAgICAgY29ubmVjdGVkUmVmLmNsYXNzTGlzdCA9IGNsYXNzZXMuam9pbihzcGFjZSk7XG4vLyB9XG4vLyBleHBvcnQgY29uc3QgcmVtb3ZlQ2xhc3MgPSBhc3luYyAoY29ubmVjdGVkUmVmOiBSZWYsIGNsYXNzTmFtZTogc3RyaW5nLCkgPT4ge1xuLy8gICAgIGxldCBjbGFzc2VzID0gYXdhaXQgZ2V0Q2xhc3Nlcyhjb25uZWN0ZWRSZWYpO1xuLy8gICAgIC8vIEB0cy1pZ25vcmVcbi8vICAgICBjb25uZWN0ZWRSZWYuY2xhc3NMaXN0ID0gY2xhc3Nlcy5maWx0ZXIoYyA9PiBjICE9PSBjbGFzc05hbWUpLmpvaW4oc3BhY2UpO1xuLy8gfVxuLy9cbi8vXG5cbmV4cG9ydCBjb25zdCBhZGRDbGFzcyA9IChjb21wb25lbnQ6IElNeW9wQ29tcG9uZW50LCBjbGFzc05hbWU6IHN0cmluZywgbXlvcElkOiBzdHJpbmcpID0+IHtcbiAgICBjb21wb25lbnQuc2VuZChuZXcgQ3VzdG9tUmVmTWVzc2FnZSgoe3JlZiwgX2NsYXNzTmFtZX0pID0+IHtcbiAgICAgICAgcmVmPy5jbGFzc0xpc3QuYWRkKF9jbGFzc05hbWUpO1xuICAgIH0sIHtcbiAgICAgICAgZWxlbWVudElkOiBteW9wSWQsXG4gICAgICAgIF9jbGFzc05hbWU6IGNsYXNzTmFtZVxuICAgIH0pKTtcbn1cblxuZXhwb3J0IGNvbnN0IHJlbW92ZUNsYXNzID0gKGNvbXBvbmVudDogSU15b3BDb21wb25lbnQsIGNsYXNzTmFtZTogc3RyaW5nLCBteW9wSWQ6IHN0cmluZykgPT4ge1xuICAgIGNvbXBvbmVudC5zZW5kKG5ldyBDdXN0b21SZWZNZXNzYWdlKCh7cmVmLCBfY2xhc3NOYW1lfSkgPT4ge1xuICAgICAgICByZWY/LmNsYXNzTGlzdC5yZW1vdmUoX2NsYXNzTmFtZSk7XG4gICAgfSwge1xuICAgICAgICBlbGVtZW50SWQ6IG15b3BJZCxcbiAgICAgICAgX2NsYXNzTmFtZTogY2xhc3NOYW1lXG4gICAgfSkpO1xufSIsICJpbXBvcnQge1xuICAgIElDb21wb25lbnRDb25maWcsXG4gICAgSUNvbXBvbmVudERlZmluaXRpb25Db25maWcsXG4gICAgSUNvbXBvbmVudEluc3RhbmNlQ29uZmlnLCBJSFRNTExvYWRlckNvbmZpZywgSVJlZkNvbmZpZyxcbiAgICBJU2tpbkxvYWRlckNvbmZpZyxcbiAgICBJU2tpblNlbGVjdG9yQ29uZmlnLFxuICAgIElEZWRpY2F0ZWRTa2luQ29uZmlnLCBJU2tpbkNvbmZpZ1xufSBmcm9tIFwiLi4vY29tbW9uXCI7XG5pbXBvcnQge3V1aWR2NH0gZnJvbSBcIi4uL3V0aWxzL3V0aWxzLnRzXCI7XG5cbmV4cG9ydCBjbGFzcyBTa2luQ29uZmlnIGltcGxlbWVudHMgSVNraW5Db25maWcge1xuICAgIF9ydW5UaW1lSW5zdGFuY2VJZCA9ICdydW50aW1lLWluc3RhbmNlLWlkLScgKyB1dWlkdjQoKTtcbiAgICBfcnVuVGltZUlkID0gJ3J1bnRpbWUtaWQtJyArIHV1aWR2NCgpO1xuICAgIF9ydW5UaW1lTmFtZSA9ICdydW50aW1lLW5hbWUtJyArIHV1aWR2NCgpO1xuXG4gICAgc3RhdGljIGNyZWF0ZSA9ICgpID0+IHtcbiAgICAgICAgcmV0dXJuIG5ldyBTa2luQ29uZmlnKCk7XG4gICAgfVxuXG4gICAgaWQgPSB0aGlzLl9ydW5UaW1lSWQ7XG4gICAgbmFtZSA9IHRoaXMuX3J1blRpbWVOYW1lO1xuICAgIGRlc2NyaXB0aW9uID0gJyc7XG4gICAgbG9hZGVyID0gbnVsbCBhcyB1bmtub3duIGFzIElTa2luTG9hZGVyQ29uZmlnO1xuXG4gICAgd2l0aExvYWRlciA9IChsb2FkZXI6IElTa2luTG9hZGVyQ29uZmlnKSA9PiB7XG4gICAgICAgIHRoaXMubG9hZGVyID0gbG9hZGVyO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICB3aXRoSFRNTExvYWRlciA9IChsb2FkZXI6IE9taXQ8SUhUTUxMb2FkZXJDb25maWcsICd0eXBlJz4pID0+IHtcbiAgICAgICAgbG9hZGVyLnR5cGUgPSAnSFRNTExvYWRlcic7XG4gICAgICAgIHRoaXMubG9hZGVyID0gbG9hZGVyIGFzIElIVE1MTG9hZGVyQ29uZmlnO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICBidWlsZCA9ICgpID0+IHtcbiAgICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxufVxuXG5leHBvcnQgY2xhc3MgQ29tcG9uZW50Q29uZmlnIGltcGxlbWVudHMgSUNvbXBvbmVudENvbmZpZyB7XG4gICAgX3J1blRpbWVJbnN0YW5jZUlkID0gJ3J1bnRpbWUtaW5zdGFuY2UtaWQtJyArIHV1aWR2NCgpO1xuICAgIF9ydW5UaW1lSWQgPSAncnVudGltZS1pZC0nICsgdXVpZHY0KCk7XG4gICAgX3J1blRpbWVOYW1lID0gJ3J1bnRpbWUtbmFtZS0nICsgdXVpZHY0KCk7XG5cbiAgICBzdGF0aWMgY3JlYXRlID0gKCkgPT4ge1xuICAgICAgICByZXR1cm4gbmV3IENvbXBvbmVudENvbmZpZygpO1xuICAgIH1cblxuICAgIGluc3RhbmNlID0ge1xuICAgICAgICBpZDogdGhpcy5fcnVuVGltZUluc3RhbmNlSWQsXG4gICAgICAgIGNvbXBvbmVudElkOiB0aGlzLl9ydW5UaW1lSWQsXG4gICAgICAgIGNvbXBvbmVudE5hbWU6IHRoaXMuX3J1blRpbWVOYW1lLFxuICAgICAgICBza2luU2VsZWN0b3I6IG51bGwgYXMgdW5rbm93biBhcyBJU2tpblNlbGVjdG9yQ29uZmlnXG4gICAgfSBhcyBJQ29tcG9uZW50SW5zdGFuY2VDb25maWc7XG5cbiAgICBuYW1lID0gdGhpcy5fcnVuVGltZU5hbWVcbiAgICB0eXBlID0ge1xuICAgICAgICBpZDogdGhpcy5fcnVuVGltZUlkLFxuICAgICAgICBuYW1lOiB0aGlzLl9ydW5UaW1lTmFtZSxcbiAgICAgICAgZGVzY3JpcHRpb246ICcnLFxuICAgICAgICBwcm9wczogW10sXG4gICAgICAgIHJlZnM6IFtdLFxuICAgICAgICBza2luczogW10sXG4gICAgICAgIGRlZmF1bHRTa2luOiAwXG4gICAgfSBhcyBJQ29tcG9uZW50RGVmaW5pdGlvbkNvbmZpZ1xuXG4gICAgd2l0aEluc3RhbmNlID0gKGluc3RhbmNlOiBJQ29tcG9uZW50SW5zdGFuY2VDb25maWcpID0+IHtcbiAgICAgICAgdGhpcy5pbnN0YW5jZSA9IGluc3RhbmNlO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICB3aXRoVHlwZSA9ICh0eXBlOiBJQ29tcG9uZW50RGVmaW5pdGlvbkNvbmZpZykgPT4ge1xuICAgICAgICB0aGlzLnR5cGUgPSB0eXBlO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICB3aXRoTmFtZSA9IChuYW1lOiBzdHJpbmcpID0+IHtcbiAgICAgICAgdGhpcy5uYW1lID0gbmFtZTtcbiAgICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgd2l0aERlZmF1bHRTa2luID0gKGRlZmF1bHRTa2luOiBJU2tpbkNvbmZpZykgPT4ge1xuICAgICAgICB0aGlzLnR5cGUuc2tpbnMucHVzaChkZWZhdWx0U2tpbik7XG4gICAgICAgIHRoaXMudHlwZS5kZWZhdWx0U2tpbiA9IHRoaXMudHlwZS5za2lucy5sZW5ndGggLSAxO1xuICAgICAgICB0aGlzLmluc3RhbmNlLnNraW5TZWxlY3RvciA9IHtcbiAgICAgICAgICAgIHR5cGU6ICdEZWRpY2F0ZWQnLFxuICAgICAgICAgICAgc2tpbjoge1xuICAgICAgICAgICAgICAgIGlkOiBkZWZhdWx0U2tpbi5pZFxuICAgICAgICAgICAgfVxuICAgICAgICB9IGFzIElEZWRpY2F0ZWRTa2luQ29uZmlnXG5cbiAgICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgd2l0aFJlZiA9IChyZWY6IElSZWZDb25maWcpID0+IHtcbiAgICAgICAgdGhpcy50eXBlLnJlZnMucHVzaChyZWYpO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICB3aXRoQmFzaWNSZWYgPSAocmVmU2VsZWN0b3I6IHN0cmluZykgPT4ge1xuICAgICAgICBjb25zdCBuZXdCYXNpY1JlZiA9IHtcbiAgICAgICAgICAgIGlkOiAnJyxcbiAgICAgICAgICAgIG5hbWU6IHJlZlNlbGVjdG9yLFxuICAgICAgICAgICAgZGVzY3JpcHRpb246ICcnLFxuICAgICAgICAgICAgc2VsZWN0b3JUeXBlOiAnaWQtYXR0cmlidXRlJyxcbiAgICAgICAgICAgIHNlbGVjdG9yOiByZWZTZWxlY3RvcixcbiAgICAgICAgICAgIGJlaGF2aW9yOiB7XG4gICAgICAgICAgICAgICAgdHlwZTogJ2NvZGUnXG4gICAgICAgICAgICB9XG4gICAgICAgIH0gYXMgSVJlZkNvbmZpZ1xuXG4gICAgICAgIHRoaXMudHlwZS5yZWZzLnB1c2gobmV3QmFzaWNSZWYpO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICBidWlsZCA9ICgpID0+IHtcbiAgICAgICAgcmV0dXJuIEpTT04ucGFyc2UoSlNPTi5zdHJpbmdpZnkodGhpcykpXG4gICAgfVxufVxuIiwgImltcG9ydCB7SVVzZXJGbG93fSBmcm9tIFwiLi4vY29tbW9uXCI7XG5cbi8qKlxuICpcbiAqICMjIE92ZXJ2aWV3XG4gKlxuICogVGhlIGBDbG91ZFJlcG9zaXRvcnlgIGNsYXNzIHNlcnZlcyBhcyBhIGNlbnRyYWxpemVkIGRhdGEgYWNjZXNzIGxheWVyIGZvciByZXRyaWV2aW5nIHVzZXIgZmxvd3MgYW5kIGNvbXBvbmVudHMgZnJvbSB0aGUgTXlvcC5kZXYgY2xvdWQgc2VydmljZS4gSXQgaW1wbGVtZW50cyBhIHNpbmdsZXRvbiBwYXR0ZXJuIGFuZCBwcm92aWRlcyBjYWNoaW5nIG1lY2hhbmlzbXMgdG8gb3B0aW1pemUgQVBJIGNhbGxzIGFuZCBpbXByb3ZlIHBlcmZvcm1hbmNlLlxuICpcbiAqICMjIENsYXNzIFN0cnVjdHVyZVxuICpcbiAqICMjIyBDb25zdHJ1Y3RvclxuICpcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGNvbnN0cnVjdG9yKHByaXZhdGUgX2Jhc2VVcmwgPSAnaHR0cHM6Ly9jbG91ZC5teW9wLmRldicpXG4gKiBgYGBcbiAqXG4gKiAqKlBhcmFtZXRlcnM6KipcbiAqIC0gYF9iYXNlVXJsYCAob3B0aW9uYWwpOiBUaGUgYmFzZSBVUkwgZm9yIHRoZSBNeW9wLmRldiBjbG91ZCBBUEkuIERlZmF1bHRzIHRvIGAnaHR0cHM6Ly9jbG91ZC5teW9wLmRldidgXG4gKlxuICogIyMjIFN0YXRpYyBQcm9wZXJ0aWVzXG4gKlxuICogIyMjIyBNYWluXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiBzdGF0aWMgTWFpbiA9IG5ldyBDbG91ZFJlcG9zaXRvcnkoKTtcbiAqIGBgYFxuICpcbiAqIEEgc2luZ2xldG9uIGluc3RhbmNlIG9mIHRoZSBgQ2xvdWRSZXBvc2l0b3J5YCBjbGFzcyB0aGF0IGNhbiBiZSB1c2VkIHRocm91Z2hvdXQgdGhlIGFwcGxpY2F0aW9uIHdpdGhvdXQgY3JlYXRpbmcgbXVsdGlwbGUgaW5zdGFuY2VzLlxuICpcbiAqICMjIyBQcml2YXRlIFByb3BlcnRpZXNcbiAqXG4gKiAjIyMjIHVzZXJGbG93c1xuICogYGBgdHlwZXNjcmlwdFxuICogcHJpdmF0ZSB1c2VyRmxvd3M6IFJlY29yZDxzdHJpbmcsIFByb21pc2U8SVVzZXJGbG93Pj4gPSB7fTtcbiAqIGBgYFxuICpcbiAqIEEgY2FjaGUgb2JqZWN0IHRoYXQgc3RvcmVzIHByb21pc2VzIGZvciB1c2VyIGZsb3dzLCBpbmRleGVkIGJ5IGZsb3cgSUQuIFRoaXMgcHJldmVudHMgZHVwbGljYXRlIEFQSSBjYWxscyBmb3IgdGhlIHNhbWUgZmxvdyBhbmQgZW5zdXJlcyBjb25zaXN0ZW50IGRhdGEgcmV0cmlldmFsLlxuICpcbiAqICMjIyMgX2Jhc2VVcmxcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIHByaXZhdGUgX2Jhc2VVcmw6IHN0cmluZ1xuICogYGBgXG4gKlxuICogVGhlIGJhc2UgVVJMIGZvciB0aGUgY2xvdWQgQVBJIGVuZHBvaW50cywgc2V0IGR1cmluZyBjb25zdHJ1Y3Rpb24uXG4gKlxuICogIyMgTWV0aG9kc1xuICpcbiAqICMjIyBmZXRjaEZsb3coZmxvd0lkOiBzdHJpbmcpXG4gKlxuICogUmV0cmlldmVzIGEgY29tcGxldGUgdXNlciBmbG93IGZyb20gdGhlIGNsb3VkIHJlcG9zaXRvcnksIGluY2x1ZGluZyBhbGwgcmVzb2x2ZWQgY29tcG9uZW50cy5cbiAqXG4gKiAqKlBhcmFtZXRlcnM6KipcbiAqIC0gYGZsb3dJZGA6IFRoZSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIHVzZXIgZmxvdyB0byByZXRyaWV2ZVxuICpcbiAqICoqUmV0dXJuczoqKlxuICogLSBgUHJvbWlzZTxJVXNlckZsb3c+YDogQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgdG8gdGhlIGNvbXBsZXRlIHVzZXIgZmxvdyBvYmplY3RcbiAqXG4gKiAqKkJlaGF2aW9yOioqXG4gKiAtIEltcGxlbWVudHMgcmVxdWVzdCBjYWNoaW5nIHRvIGF2b2lkIGR1cGxpY2F0ZSBBUEkgY2FsbHMgZm9yIHRoZSBzYW1lIGZsb3cgSURcbiAqIC0gTWFrZXMgYSBHRVQgcmVxdWVzdCB0byBgL2Zsb3c/aWQ9e2Zsb3dJZH0mcmVzb2x2ZT1jb21wb25lbnRzYFxuICogLSBBdXRvbWF0aWNhbGx5IHJlc29sdmVzIGNvbXBvbmVudCByZWZlcmVuY2VzIHdpdGhpbiB0aGUgZmxvd1xuICogLSBTdG9yZXMgdGhlIHByb21pc2UgaW4gdGhlIGNhY2hlIGZvciBmdXR1cmUgdXNlXG4gKlxuICogKipFeGFtcGxlIFVzYWdlOioqXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiBjb25zdCBmbG93ID0gYXdhaXQgQ2xvdWRSZXBvc2l0b3J5Lk1haW4uZmV0Y2hGbG93KCdteS1mbG93LWlkJyk7XG4gKiBjb25zb2xlLmxvZyhmbG93LmNvbXBvbmVudHMpO1xuICogYGBgXG4gKlxuICogIyMjIGZldGNoQ29tcG9uZW50KGNvbXBvbmVudElkOiBzdHJpbmcsIGZsb3dJZDogc3RyaW5nKVxuICpcbiAqIFJldHJpZXZlcyBhIHNwZWNpZmljIGNvbXBvbmVudCBmcm9tIHdpdGhpbiBhIHVzZXIgZmxvdy5cbiAqXG4gKiAqKlBhcmFtZXRlcnM6KipcbiAqIC0gYGNvbXBvbmVudElkYDogVGhlIHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGUgY29tcG9uZW50IHRvIHJldHJpZXZlXG4gKiAtIGBmbG93SWRgOiBUaGUgdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSB1c2VyIGZsb3cgY29udGFpbmluZyB0aGUgY29tcG9uZW50XG4gKlxuICogKipSZXR1cm5zOioqXG4gKiAtIGBQcm9taXNlPENvbXBvbmVudCB8IHVuZGVmaW5lZD5gOiBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB0byB0aGUgY29tcG9uZW50IG9iamVjdCBpZiBmb3VuZCwgb3IgdW5kZWZpbmVkIGlmIG5vdCBmb3VuZFxuICpcbiAqICoqQmVoYXZpb3I6KipcbiAqIC0gRmlyc3QgZmV0Y2hlcyB0aGUgY29tcGxldGUgZmxvdyB1c2luZyBgZmV0Y2hGbG93KClgXG4gKiAtIFNlYXJjaGVzIHRocm91Z2ggdGhlIGZsb3cncyBjb21wb25lbnRzIGFycmF5IHRvIGZpbmQgdGhlIG1hdGNoaW5nIGNvbXBvbmVudFxuICogLSBVc2VzIHRoZSBjb21wb25lbnQncyBgdHlwZS5pZGAgcHJvcGVydHkgZm9yIG1hdGNoaW5nXG4gKlxuICogKipFeGFtcGxlIFVzYWdlOioqXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiBjb25zdCBjb21wb25lbnQgPSBhd2FpdCBDbG91ZFJlcG9zaXRvcnkuTWFpbi5mZXRjaENvbXBvbmVudCgnYnV0dG9uLWNvbXBvbmVudCcsICdteS1mbG93LWlkJyk7XG4gKiBpZiAoY29tcG9uZW50KSB7XG4gKiAgICAgY29uc29sZS5sb2coJ0NvbXBvbmVudCBmb3VuZDonLCBjb21wb25lbnQpO1xuICogfSBlbHNlIHtcbiAqICAgICBjb25zb2xlLmxvZygnQ29tcG9uZW50IG5vdCBmb3VuZCBpbiBmbG93Jyk7XG4gKiB9XG4gKiBgYGBcbiAqXG4gKiAjIyBBUEkgSW50ZWdyYXRpb25cbiAqXG4gKiAjIyMgRW5kcG9pbnQgU3RydWN0dXJlXG4gKlxuICogVGhlIGNsYXNzIGludGVncmF0ZXMgd2l0aCB0aGUgZm9sbG93aW5nIE15b3AuZGV2IGNsb3VkIEFQSSBlbmRwb2ludDpcbiAqXG4gKiBgYGBcbiAqIEdFVCB7YmFzZVVybH0vZmxvdz9pZD17Zmxvd0lkfSZyZXNvbHZlPWNvbXBvbmVudHNcbiAqIGBgYFxuICpcbiAqICoqUXVlcnkgUGFyYW1ldGVyczoqKlxuICogLSBgaWRgOiBUaGUgZmxvdyBpZGVudGlmaWVyXG4gKiAtIGByZXNvbHZlPWNvbXBvbmVudHNgOiBJbnN0cnVjdHMgdGhlIEFQSSB0byBpbmNsdWRlIHJlc29sdmVkIGNvbXBvbmVudCBkYXRhIGluIHRoZSByZXNwb25zZVxuICpcbiAqICMjIyBSZXNwb25zZSBGb3JtYXRcbiAqXG4gKiBUaGUgQVBJIGlzIGV4cGVjdGVkIHRvIHJldHVybiBhIEpTT04gcmVzcG9uc2Ugd2l0aCB0aGUgZm9sbG93aW5nIHN0cnVjdHVyZTpcbiAqXG4gKiBgYGBqc29uXG4gKiB7XG4gKiAgICAgXCJpdGVtXCI6IHtcbiAqICAgICAgICAgLy8gSVVzZXJGbG93IG9iamVjdCB3aXRoIHJlc29sdmVkIGNvbXBvbmVudHNcbiAqICAgICAgICAgXCJjb21wb25lbnRzXCI6IFtcbiAqICAgICAgICAgICAgIHtcbiAqICAgICAgICAgICAgICAgICBcInR5cGVcIjoge1xuICogICAgICAgICAgICAgICAgICAgICBcImlkXCI6IFwiY29tcG9uZW50LWlkXCJcbiAqICAgICAgICAgICAgICAgICB9XG4gKiAgICAgICAgICAgICAgICAgLy8gLi4uIG90aGVyIGNvbXBvbmVudCBwcm9wZXJ0aWVzXG4gKiAgICAgICAgICAgICB9XG4gKiAgICAgICAgIF1cbiAqICAgICAgICAgLy8gLi4uIG90aGVyIGZsb3cgcHJvcGVydGllc1xuICogICAgIH1cbiAqIH1cbiAqIGBgYFxuICpcbiAqICMjIENhY2hpbmcgU3RyYXRlZ3lcbiAqXG4gKiBUaGUgYENsb3VkUmVwb3NpdG9yeWAgaW1wbGVtZW50cyBhIHByb21pc2UtYmFzZWQgY2FjaGluZyBtZWNoYW5pc206XG4gKlxuICogMS4gKipDYWNoZSBLZXkqKjogRmxvdyBJRCBpcyB1c2VkIGFzIHRoZSBjYWNoZSBrZXlcbiAqIDIuICoqQ2FjaGUgVmFsdWUqKjogUHJvbWlzZXMgYXJlIGNhY2hlZCByYXRoZXIgdGhhbiByZXNvbHZlZCB2YWx1ZXMgdG8gaGFuZGxlIGNvbmN1cnJlbnQgcmVxdWVzdHNcbiAqIDMuICoqQ2FjaGUgRHVyYXRpb24qKjogQ2FjaGUgcGVyc2lzdHMgZm9yIHRoZSBsaWZldGltZSBvZiB0aGUgcmVwb3NpdG9yeSBpbnN0YW5jZVxuICogNC4gKipDYWNoZSBJbnZhbGlkYXRpb24qKjogTm8gYXV0b21hdGljIGNhY2hlIGludmFsaWRhdGlvbiBpcyBpbXBsZW1lbnRlZFxuICpcbiAqICMjIEVycm9yIEhhbmRsaW5nXG4gKlxuICogLSBOZXR3b3JrIGVycm9ycyBhbmQgQVBJIGZhaWx1cmVzIGFyZSBwcm9wYWdhdGVkIHRocm91Z2ggcHJvbWlzZSByZWplY3Rpb25cbiAqIC0gTm8gc3BlY2lmaWMgZXJyb3IgaGFuZGxpbmcgb3IgcmV0cnkgbG9naWMgaXMgaW1wbGVtZW50ZWQgYXQgdGhlIHJlcG9zaXRvcnkgbGV2ZWxcbiAqIC0gQ29uc3VtZXJzIHNob3VsZCBpbXBsZW1lbnQgYXBwcm9wcmlhdGUgZXJyb3IgaGFuZGxpbmcgd2hlbiBjYWxsaW5nIHJlcG9zaXRvcnkgbWV0aG9kc1xuICpcbiAqICMjIFVzYWdlIFBhdHRlcm5zXG4gKlxuICogIyMjIFNpbmdsZXRvbiBBY2Nlc3NcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGltcG9ydCB7IENsb3VkUmVwb3NpdG9yeSB9IGZyb20gJy4vcGF0aC90by9DbG91ZFJlcG9zaXRvcnknO1xuICpcbiAqIC8vIFVzZSB0aGUgc2luZ2xldG9uIGluc3RhbmNlXG4gKiBjb25zdCBmbG93ID0gYXdhaXQgQ2xvdWRSZXBvc2l0b3J5Lk1haW4uZmV0Y2hGbG93KCdmbG93LWlkJyk7XG4gKiBgYGBcbiAqXG4gKiAjIyMgQ3VzdG9tIEluc3RhbmNlXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiAvLyBDcmVhdGUgYSBjdXN0b20gaW5zdGFuY2Ugd2l0aCBkaWZmZXJlbnQgYmFzZSBVUkxcbiAqIGNvbnN0IGN1c3RvbVJlcG8gPSBuZXcgQ2xvdWRSZXBvc2l0b3J5KCdodHRwczovL2N1c3RvbS1hcGkuZXhhbXBsZS5jb20nKTtcbiAqIGNvbnN0IGZsb3cgPSBhd2FpdCBjdXN0b21SZXBvLmZldGNoRmxvdygnZmxvdy1pZCcpO1xuICogYGBgXG4gKlxuICogIyMjIENvbXBvbmVudCBSZXRyaWV2YWxcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIC8vIEdldCBhIHNwZWNpZmljIGNvbXBvbmVudCBmcm9tIGEgZmxvd1xuICogY29uc3QgY29tcG9uZW50ID0gYXdhaXQgQ2xvdWRSZXBvc2l0b3J5Lk1haW4uZmV0Y2hDb21wb25lbnQoJ2NvbXBvbmVudC1pZCcsICdmbG93LWlkJyk7XG4gKiBgYGBcbiAqXG4gKiAjIyBEZXBlbmRlbmNpZXNcbiAqXG4gKiAtICoqSVVzZXJGbG93Kio6IEludGVyZmFjZSBpbXBvcnRlZCBmcm9tIGAuLi9jb21tb25gIHRoYXQgZGVmaW5lcyB0aGUgc3RydWN0dXJlIG9mIHVzZXIgZmxvdyBvYmplY3RzXG4gKiAtICoqRmV0Y2ggQVBJKio6IFVzZXMgdGhlIG5hdGl2ZSBgZmV0Y2hgIGZ1bmN0aW9uIGZvciBIVFRQIHJlcXVlc3RzXG4gKlxuICogIyMgUGVyZm9ybWFuY2UgQ29uc2lkZXJhdGlvbnNcbiAqXG4gKiAtICoqQ2FjaGluZyoqOiBQcmV2ZW50cyBkdXBsaWNhdGUgQVBJIGNhbGxzIGZvciB0aGUgc2FtZSBmbG93IElEXG4gKiAtICoqUHJvbWlzZSBDYWNoaW5nKio6IEhhbmRsZXMgY29uY3VycmVudCByZXF1ZXN0cyBlZmZpY2llbnRseSBieSBjYWNoaW5nIHByb21pc2VzXG4gKiAtICoqQ29tcG9uZW50IFJlc29sdXRpb24qKjogVGhlIGByZXNvbHZlPWNvbXBvbmVudHNgIHBhcmFtZXRlciBlbnN1cmVzIGNvbXBvbmVudHMgYXJlIGZ1bGx5IHJlc29sdmVkIGluIGEgc2luZ2xlIEFQSSBjYWxsXG4gKlxuICogIyMgRnV0dXJlIEVuaGFuY2VtZW50c1xuICpcbiAqIFRoZSBjbGFzcyBzdHJ1Y3R1cmUgc3VnZ2VzdHMgcGxhbm5lZCBmdW5jdGlvbmFsaXR5IHRoYXQgY291bGQgYmUgaW1wbGVtZW50ZWQ6XG4gKlxuICogLSAqKkNvbXBvbmVudCBDYWNoaW5nKio6IFRoZSBjb21tZW50ZWQgYGNvbXBvbmVudHNgIHByb3BlcnR5IGluZGljYXRlcyBwb3RlbnRpYWwgaW5kaXZpZHVhbCBjb21wb25lbnQgY2FjaGluZ1xuICogLSAqKkNhY2hlIEludmFsaWRhdGlvbioqOiBNZXRob2RzIHRvIGNsZWFyIG9yIHJlZnJlc2ggY2FjaGVkIGRhdGFcbiAqIC0gKipFcnJvciBSZXRyeSBMb2dpYyoqOiBBdXRvbWF0aWMgcmV0cnkgbWVjaGFuaXNtcyBmb3IgZmFpbGVkIHJlcXVlc3RzXG4gKiAtICoqQmF0Y2ggT3BlcmF0aW9ucyoqOiBNZXRob2RzIHRvIGZldGNoIG11bHRpcGxlIGZsb3dzIG9yIGNvbXBvbmVudHMgaW4gYSBzaW5nbGUgcmVxdWVzdFxuICpcbiAqL1xuZXhwb3J0IGNsYXNzIENsb3VkUmVwb3NpdG9yeSB7XG4gICAgc3RhdGljIE1haW4gPSBuZXcgQ2xvdWRSZXBvc2l0b3J5KCk7XG5cbiAgICBwcml2YXRlIHVzZXJGbG93czogUmVjb3JkPHN0cmluZywgUHJvbWlzZTxJVXNlckZsb3c+PiA9IHt9O1xuXG4gICAgLy8gcHJpdmF0ZSBjb21wb25lbnRzOiBSZWNvcmQ8c3RyaW5nLCBQcm9taXNlPElVc2VyRmxvdz4+ID0ge307XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9iYXNlVXJsID0gJ2h0dHBzOi8vY2xvdWQubXlvcC5kZXYnKSB7XG4gICAgfVxuXG4gICAgYXN5bmMgZmV0Y2hDb21wb25lbnQoY29tcG9uZW50SWQ6IHN0cmluZywgZmxvd0lkPzogc3RyaW5nKSB7XG4gICAgICAgIGlmIChmbG93SWQpIHtcbiAgICAgICAgICAgIGNvbnN0IGZsb3cgPSBhd2FpdCB0aGlzLmZldGNoRmxvdyhmbG93SWQpO1xuICAgICAgICAgICAgcmV0dXJuIGZsb3cuY29tcG9uZW50cy5maW5kKGMgPT4gYy50eXBlLmlkID09PSBjb21wb25lbnRJZCk7XG4gICAgICAgIH1lbHNle1xuICAgICAgICAgICAgY29uc3QgZmxvdyA9IGF3YWl0IHRoaXMuZmV0Y2hBdXRvRmxvdyhjb21wb25lbnRJZCk7XG4gICAgICAgICAgICByZXR1cm4gZmxvdy5jb21wb25lbnRzWzBdO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgYXN5bmMgZmV0Y2hBdXRvRmxvdyhjb21wb25lbnRJZDogc3RyaW5nKSB7XG4gICAgICAgIGlmICghdGhpcy51c2VyRmxvd3NbY29tcG9uZW50SWRdKSB7XG4gICAgICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tYXN5bmMtcHJvbWlzZS1leGVjdXRvclxuICAgICAgICAgICAgdGhpcy51c2VyRmxvd3NbY29tcG9uZW50SWRdID0gbmV3IFByb21pc2UoXG4gICAgICAgICAgICAgICAgYXN5bmMgKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3QgcmVzID0gYXdhaXQgZmV0Y2goXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYCR7dGhpcy5fYmFzZVVybH0vZmxvdz9pZD0ke2NvbXBvbmVudElkfSZhdXRvPXRydWVgXG4gICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3QganNvbiA9IGF3YWl0IHJlcy5qc29uKCk7XG4gICAgICAgICAgICAgICAgICAgICAgICByZXNvbHZlKGpzb24uaXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHJlamVjdChlKTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gYXdhaXQgdGhpcy51c2VyRmxvd3NbY29tcG9uZW50SWRdO1xuICAgIH1cblxuXG4gICAgYXN5bmMgZmV0Y2hGbG93KGZsb3dJZDogc3RyaW5nKSB7XG4gICAgICAgIGlmICghdGhpcy51c2VyRmxvd3NbZmxvd0lkXSkge1xuICAgICAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWFzeW5jLXByb21pc2UtZXhlY3V0b3JcbiAgICAgICAgICAgIHRoaXMudXNlckZsb3dzW2Zsb3dJZF0gPSBuZXcgUHJvbWlzZShcbiAgICAgICAgICAgICAgICBhc3luYyAocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBjb25zdCByZXMgPSBhd2FpdCBmZXRjaChcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBgJHt0aGlzLl9iYXNlVXJsfS9mbG93P2lkPSR7Zmxvd0lkfSZyZXNvbHZlPWNvbXBvbmVudHNgXG4gICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3QganNvbiA9IGF3YWl0IHJlcy5qc29uKCk7XG4gICAgICAgICAgICAgICAgICAgICAgICByZXNvbHZlKGpzb24uaXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHJlamVjdChlKTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gYXdhaXQgdGhpcy51c2VyRmxvd3NbZmxvd0lkXTtcbiAgICB9XG59XG4iLCAiZXhwb3J0IGNvbnN0IGV4ZWMgPSBhc3luYyAoZ2V0dGVyOiBhbnkpID0+IHtcbiAgICByZXR1cm4gYXdhaXQgZ2V0dGVyKClcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFPLElBQU0sU0FBUyxNQUFNO0FBQ3hCLFNBQU8sdUNBQXVDO0FBQUEsSUFBUTtBQUFBLElBQVUsUUFDM0QsQ0FBQyxJQUFJLE9BQU8sZ0JBQWdCLElBQUksV0FBVyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksTUFBTSxDQUFDLElBQUksR0FBRyxTQUFTLEVBQUU7QUFBQSxFQUNsRjtBQUNKOzs7QUNRTyxJQUFlLGtCQUFmLE1BQXdDO0FBQUEsRUFXM0MsY0FBYztBQVZkLDhCQUFLLE9BQU87QUFjWixnQ0FBTztBQUlQO0FBR0E7QUFBQTtBQUNBO0FBRUE7QUFFQTtBQUVBO0FBRUEscUNBQXFCO0FBQUEsRUFsQnJCO0FBQUEsRUFWQSxPQUFPLFVBRUEsTUFDc0I7QUFFekIsV0FBTyxJQUFJLEtBQUssR0FBRyxJQUFJO0FBQUEsRUFDM0I7QUFBQSxFQXdCQSxTQUFTLEtB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
411
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3V0aWxzL3V1aWQudHMiLCAiLi4vLi4vLi4vc3JjL21lc3NhZ2VzL0Jhc2VNZXNzYWdlLnRzIiwgIi4uLy4uLy4uL3NyYy9tZXNzYWdlcy9FeGVjdXRlU2NyaXB0TWVzc2FnZS50cyIsICIuLi8uLi8uLi9zcmMvbWVzc2FnZXMvQ3VzdG9tUmVmTWVzc2FnZS50cyIsICIuLi8uLi8uLi9zcmMvaGVscGVycy9hcHBseVN0eWxlc2hlZXQudHMiLCAiLi4vLi4vLi4vc3JjL2hlbHBlcnMvaWZyYW1lU2tpblVybFRva2VuaXplci50cyIsICIuLi8uLi8uLi9zcmMvaGVscGVycy9jbGFzc0xpc3QudHMiLCAiLi4vLi4vLi4vc3JjL2hlbHBlcnMvY29uZmlnQnVpbGRlci50cyIsICIuLi8uLi8uLi9zcmMvaGVscGVycy9DbG91ZFJlcG9zaXRvcnkudHMiLCAiLi4vLi4vLi4vc3JjL2hlbHBlcnMvZXhlYy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLy9UT0RPIDogcmV1c2UgZnJvbSBvbmUgcGxhY2UuXG4vLyBuZWVkcyB0byBiZSB1c2VkIGluIG15b3Atc2RrLCBteW9wLWRhc2hiYW9yZCwgbXlvcC1zZXJ2ZXIsIG15b3AtY2xpIC4uXG5cbmV4cG9ydCBjb25zdCB1dWlkdjQgPSAoKSA9PiB7XG4gICAgcmV0dXJuIFwiMTAwMDAwMDAtMTAwMC00MDAwLTgwMDAtMTAwMDAwMDAwMDAwXCIucmVwbGFjZSgvWzAxOF0vZywgYyA9PlxuICAgICAgICAoK2MgXiBjcnlwdG8uZ2V0UmFuZG9tVmFsdWVzKG5ldyBVaW50OEFycmF5KDEpKVswXSAmIDE1ID4+ICtjIC8gNCkudG9TdHJpbmcoMTYpXG4gICAgKTtcbn1cblxuLy8gQ29udmVydCBVVUlEIHN0cmluZyB0byBieXRlc1xuZXhwb3J0IGNvbnN0IHV1aWRUb0J5dGVzID0gKHV1aWQ6IHN0cmluZyk6IFVpbnQ4QXJyYXkgPT4ge1xuICAgIHJldHVybiBVaW50OEFycmF5LmZyb20oXG4gICAgICAgIHV1aWQucmVwbGFjZSgvLS9nLCAnJykubWF0Y2goLy57MSwyfS9nKSEubWFwKGJ5dGUgPT4gcGFyc2VJbnQoYnl0ZSwgMTYpKVxuICAgICk7XG59O1xuXG4vLyBDb252ZXJ0IGJ5dGVzIHRvIFVVSUQgc3RyaW5nXG5leHBvcnQgY29uc3QgYnl0ZXNUb1V1aWQgPSAoYnl0ZXM6IFVpbnQ4QXJyYXkpOiBzdHJpbmcgPT4ge1xuICAgIGNvbnN0IGhleCA9IFsuLi5ieXRlc10ubWFwKGIgPT4gYi50b1N0cmluZygxNikucGFkU3RhcnQoMiwgJzAnKSkuam9pbignJyk7XG4gICAgcmV0dXJuIFtcbiAgICAgICAgaGV4LnNsaWNlKDAsIDgpLFxuICAgICAgICBoZXguc2xpY2UoOCwgMTIpLFxuICAgICAgICBoZXguc2xpY2UoMTIsIDE2KSxcbiAgICAgICAgaGV4LnNsaWNlKDE2LCAyMCksXG4gICAgICAgIGhleC5zbGljZSgyMClcbiAgICBdLmpvaW4oJy0nKTtcbn07XG5cbi8vIEJhc2U2NCBVUkwtc2FmZSBlbmNvZGVcbmV4cG9ydCBjb25zdCBiYXNlNjRVcmxFbmNvZGUgPSAoYnl0ZXM6IFVpbnQ4QXJyYXkpOiBzdHJpbmcgPT4ge1xuICAgIGNvbnN0IGJhc2U2NCA9IGJ0b2EoU3RyaW5nLmZyb21DaGFyQ29kZSguLi5ieXRlcykpO1xuICAgIHJldHVybiBiYXNlNjQucmVwbGFjZSgvXFwrL2csICctJykucmVwbGFjZSgvXFwvL2csICdfJykucmVwbGFjZSgvPSskLywgJycpO1xufTtcblxuLy8gQmFzZTY0IFVSTC1zYWZlIGRlY29kZVxuZXhwb3J0IGNvbnN0IGJhc2U2NFVybERlY29kZSA9IChzdHI6IHN0cmluZyk6IFVpbnQ4QXJyYXkgPT4ge1xuICAgIGxldCBiYXNlNjQgPSBzdHIucmVwbGFjZSgvLS9nLCAnKycpLnJlcGxhY2UoL18vZywgJy8nKTtcbiAgICB3aGlsZSAoYmFzZTY0Lmxlbmd0aCAlIDQpIGJhc2U2NCArPSAnPSc7XG4gICAgY29uc3QgYmluYXJ5ID0gYXRvYihiYXNlNjQpO1xuICAgIHJldHVybiBVaW50OEFycmF5LmZyb20oYmluYXJ5LCBjaGFyID0+IGNoYXIuY2hhckNvZGVBdCgwKSk7XG59O1xuXG4vLyBDb21wcmVzcyBhbiBhcnJheSBvZiBVVUlEcyBpbnRvIGEgc2hvcnQgVVJMLXNhZmUgc3RyaW5nXG5leHBvcnQgY29uc3QgY29tcHJlc3NVVUlEcyA9ICh1dWlkczogc3RyaW5nW10pOiBzdHJpbmcgPT4ge1xuICAgIGNvbnN0IGFsbEJ5dGVzID0gdXVpZHMuZmxhdE1hcCh1dWlkID0+IEFycmF5LmZyb20odXVpZFRvQnl0ZXModXVpZCkpKTtcbiAgICByZXR1cm4gYmFzZTY0VXJsRW5jb2RlKG5ldyBVaW50OEFycmF5KGFsbEJ5dGVzKSk7XG59O1xuXG4vLyBEZWNvbXByZXNzIGZyb20gVVJMLXNhZmUgc3RyaW5nIGJhY2sgdG8gYW4gYXJyYXkgb2YgVVVJRHNcbmV4cG9ydCBjb25zdCBkZWNvbXByZXNzVVVJRHMgPSAoZW5jb2RlZDogc3RyaW5nKTogc3RyaW5nW10gPT4ge1xuICAgIGNvbnN0IGJ5dGVzID0gYmFzZTY0VXJsRGVjb2RlKGVuY29kZWQpO1xuICAgIGlmIChieXRlcy5sZW5ndGggJSAxNiAhPT0gMCkgdGhyb3cgbmV3IEVycm9yKCdJbnZhbGlkIGlucHV0IGxlbmd0aCcpO1xuXG4gICAgY29uc3QgdXVpZHM6IHN0cmluZ1tdID0gW107XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBieXRlcy5sZW5ndGg7IGkgKz0gMTYpIHtcbiAgICAgICAgdXVpZHMucHVzaChieXRlc1RvVXVpZChieXRlcy5zbGljZShpLCBpICsgMTYpKSk7XG4gICAgfVxuICAgIHJldHVybiB1dWlkcztcbn07XG4iLCAiaW1wb3J0IHtNeW9wTWVzc2FnZUtleX0gZnJvbSBcIi4uL2NvbW1vbi9NeW9wTWVzc2FnZXNcIjtcbmltcG9ydCB7dXVpZHY0fSBmcm9tIFwiLi4vdXRpbHMvdXRpbHNcIjtcbmltcG9ydCB7SU15b3BDb21wb25lbnR9IGZyb20gXCIuLi9ob3N0XCI7XG5pbXBvcnQge0lSZWZDb25maWd9IGZyb20gXCIuLi9jb21tb25cIjtcblxuZXhwb3J0IGNsYXNzIE1lc3NhZ2VEaXJlY3Rpb24ge1xuICAgIHN0YXRpYyBkb3duID0gJ2Rvd24nIGFzIGNvbnN0XG4gICAgc3RhdGljIHVwID0gJ3VwJyBhcyBjb25zdFxufVxuXG5leHBvcnQgdHlwZSBNZXNzYWdlRGlyZWN0aW9uT3B0aW9uID0gJ3VwJyB8ICdkb3duJztcblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJhc2VNeW9wTWVzc2FnZTxUID0gYW55PiB7XG4gICAgaWQgPSB1dWlkdjQoKVxuXG4gICAgc3RhdGljIGNyZWF0ZTxULCBVIGV4dGVuZHMgbmV3ICguLi5hcmdzOiBDb25zdHJ1Y3RvclBhcmFtZXRlcnM8VT4pID0+IFQgPSB0eXBlb2YgdGhpcz4oXG4gICAgICAgIHRoaXM6IFUsXG4gICAgICAgIC4uLmFyZ3M6IENvbnN0cnVjdG9yUGFyYW1ldGVyczxVPlxuICAgICk6IEluc3RhbmNlVHlwZTx0eXBlb2YgdGhpcz4ge1xuICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgIHJldHVybiBuZXcgdGhpcyguLi5hcmdzKTtcbiAgICB9XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgLy9jb25zb2xlLmxvZygnbWVlc2FnZSBpZCBjcmVhdGVkJywgdGhpcy5pZCwgZG9jdW1lbnQubG9jYXRpb24uaHJlZik7XG4gICAgfVxuXG4gICAgbXlvcCA9IHRydWVcblxuICAgIGFic3RyYWN0IG1lc3NhZ2VUeXBlOiBNeW9wTWVzc2FnZUtleSB8IHN0cmluZztcblxuICAgIGNvbnRlbnQ/OiBUXG5cbiAgICAvLyBUT0RPIDogY2FudCBiZSBvcHRpb25hbCBcbiAgICBzb3VyY2U/OiBzdHJpbmdcbiAgICBkZXN0aW5hdGlvbj86IHN0cmluZ1xuXG4gICAgcm91dGU/OiBzdHJpbmdbXVxuXG4gICAgcmVmPzogUmVmXG5cbiAgICBkaXJlY3Rpb24/OiBNZXNzYWdlRGlyZWN0aW9uT3B0aW9uXG5cbiAgICBjbGVhbmFibGU6IGJvb2xlYW4gPSBmYWxzZVxuXG4gICAgaXNUeXBlb2YobXNnOiBCYXNlTXlvcE1lc3NhZ2UpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIG1zZy5tZXNzYWdlVHlwZSA9PT0gdGhpcy5tZXNzYWdlVHlwZVxuICAgIH1cbn1cblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIE15b3BFbGVtZW50TWVzc2FnZTxUID0gYW55PiBleHRlbmRzIEJhc2VNeW9wTWVzc2FnZTxUPiB7XG4gICAgY29uc3RydWN0b3IocHVibGljIHJlZjogUmVmKSB7XG4gICAgICAgIHN1cGVyKClcbiAgICB9XG59XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBNeW9wQmluZFJlcGxheU1lc3NhZ2U8VCA9IGFueT4gZXh0ZW5kcyBCYXNlTXlvcE1lc3NhZ2U8VD4ge1xuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyByZXBsYXlUb0hhbmRsZXI/OiBzdHJpbmcpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG59XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBNeW9wQmluZE1lc3NhZ2U8VCA9IGFueSwgUiBleHRlbmRzIE15b3BCaW5kUmVwbGF5TWVzc2FnZSA9IGFueT4gZXh0ZW5kcyBCYXNlTXlvcE1lc3NhZ2U8VD4ge1xuXG4gICAgcHVibGljIGFic3RyYWN0IHJlcGx5TWVzc2FnZUtleTogTXlvcE1lc3NhZ2VLZXk7XG5cbiAgICBwdWJsaWMgaGFuZGxlclVuaXF1ZUlkID0gdXVpZHY0KClcblxuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBoYW5kbGVyOiAobWVzc2FnZTogUikgPT4gdm9pZCkge1xuICAgICAgICBzdXBlcigpXG4gICAgfVxufVxuXG5leHBvcnQgY2xhc3MgUmVmIHtcbiAgICBwdWJsaWMgbXlvcCA9IHRydWU7XG5cbiAgICBwdWJsaWMgX19ub25Qcm94aWVkPzogUmVmO1xuXG4gICAgc3RhdGljIGNyZWF0ZShzZWxlY3Rvcjogc3RyaW5nLCByZWZDb25maWc/OiBJUmVmQ29uZmlnLCBjb21wb25lbnQ/OiBJTXlvcENvbXBvbmVudCkge1xuICAgICAgICBsZXQgX3JlZkNvbmZpZyA9IHJlZkNvbmZpZztcbiAgICAgICAgaWYgKCFfcmVmQ29uZmlnKSB7XG4gICAgICAgICAgICBfcmVmQ29uZmlnID0ge1xuICAgICAgICAgICAgICAgIGlkOiAnJyxcbiAgICAgICAgICAgICAgICBuYW1lOiAnJyxcbiAgICAgICAgICAgICAgICBkZXNjcmlwdGlvbjogJycsXG4gICAgICAgICAgICAgICAgc2VsZWN0b3JUeXBlOiAnaWQtYXR0cmlidXRlJyxcbiAgICAgICAgICAgICAgICBzZWxlY3Rvcjogc2VsZWN0b3IsXG4gICAgICAgICAgICAgICAgYmVoYXZpb3I6IHtcbiAgICAgICAgICAgICAgICAgICAgdHlwZTogJ2NvZGUnXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSBhcyBJUmVmQ29uZmlnXG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG5ldyBSZWYoX3JlZkNvbmZpZywgY29tcG9uZW50KTtcbiAgICB9XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgcmVmQ29uZmlnOiBJUmVmQ29uZmlnLCBwdWJsaWMgY29tcG9uZW50PzogSU15b3BDb21wb25lbnQpIHtcbiAgICAgICAgdGhpcy5fX25vblByb3hpZWQgPSB7XG4gICAgICAgICAgICAuLi50aGlzLFxuICAgICAgICAgICAgY29tcG9uZW50OiBudWxsIC8vIGluIG9yZGVyIHRvIGJlIHNlcmlhbGl6YWJsZVxuICAgICAgICB9XG4gICAgfVxufVxuIiwgImltcG9ydCB7TXlvcEJpbmRNZXNzYWdlLCBNeW9wQmluZFJlcGxheU1lc3NhZ2V9IGZyb20gXCIuL0Jhc2VNZXNzYWdlXCI7XG5pbXBvcnQge015b3BNZXNzYWdlS2V5fSBmcm9tIFwiLi4vY29tbW9uL015b3BNZXNzYWdlc1wiO1xuaW1wb3J0IHtSb290UmVmfSBmcm9tIFwiLi4vY29tbW9uXCI7XG5pbXBvcnQge21ha2VTZXJpYWxpemFibGV9IGZyb20gXCIuLi9jb21tb24vdXRpbHMvc2VyaWFsaXphdGlvbi50c1wiO1xuXG5jb25zdCBSZXBsYXlNZXNzYWdlS2V5ID0gJ0V4ZWN1dGVTY3JpcHRSZXBseU1lc3NhZ2UnXG5cbmNvbnN0IGZ1bmN0aW9uQm9keVJlZ2V4ID0gLyg/OmZ1bmN0aW9uXFxzKlxcdypcXHMqXFwoW14pXSpcXClcXHMqXFx7KFtcXHNcXFNdKj8pXFx9fChcXChbXildKlxcKVxccyo9PlxccypcXHsoW1xcc1xcU10qPylcXH0pKVxccyokLztcbmNvbnN0IGV4cHJlc3Npb25Cb2R5UmVnZXggPSAvXFwoXFxzKlteKV0rXFxzKlxcKVxccyo9PlxccyooLispLztcblxuZXhwb3J0IGNvbnN0IHN0cmlwRnVuY3Rpb24gPSAoY29udGVudDogc3RyaW5nKSA9PiB7XG4gICAgbGV0IG1hdGNoID0gY29udGVudC5tYXRjaChmdW5jdGlvbkJvZHlSZWdleCk7XG4gICAgaWYgKG1hdGNoKSB7XG4gICAgICAgIHJldHVybiBtYXRjaFsxXSB8fCBtYXRjaFszXTtcbiAgICB9IGVsc2Uge1xuICAgICAgICBsZXQgbWF0Y2ggPSBjb250ZW50Lm1hdGNoKGV4cHJlc3Npb25Cb2R5UmVnZXgpO1xuICAgICAgICBpZiAobWF0Y2gpXG4gICAgICAgICAgICByZXR1cm4gbWF0Y2hbMV0udHJpbSgpO1xuICAgIH1cbn1cblxuZXhwb3J0IHR5cGUgc2NyaXB0SW5wdXRzID0ge1xuICAgIFtrZXk6IHN0cmluZ106IHN0cmluZyB8IG51bWJlciB8IGJvb2xlYW5cbn0gfCB7fTtcblxuZXhwb3J0IHR5cGUgc2NyaXB0VmFyczxUPiA9IHtcbiAgICBzZW5kOiAoZGF0YTogVCkgPT4gdm9pZDtcbiAgICAvLyBjb21wbGV0ZVN0cmVhbTogKCkgPT4gdm9pZDtcbiAgICByb290UmVmOiBSb290UmVmO1xuICAgIG1ha2VTZXJpYWxpemFibGU6IHR5cGVvZiBtYWtlU2VyaWFsaXphYmxlXG59XG5cbmV4cG9ydCB0eXBlIGV4dGVuZGVkU2NyaXB0VmFyczxULCBJPiA9IHtcbiAgICBbSyBpbiBrZXlvZiBJXTogSVtLXTtcbn0gJiBzY3JpcHRWYXJzPFQ+XG5cbmV4cG9ydCBjbGFzcyBFeGVjdXRlU2NyaXB0TWVzc2FnZTxUID0gYW55LCBJIGV4dGVuZHMgc2NyaXB0SW5wdXRzID0gYW55PiBleHRlbmRzIE15b3BCaW5kTWVzc2FnZTxzdHJpbmcsIEV4ZWN1dGVTY3JpcHRSZXBseU1lc3NhZ2U8VD4+IHtcblxuICAgIHJlcGx5TWVzc2FnZUtleTogTXlvcE1lc3NhZ2VLZXkgPSBSZXBsYXlNZXNzYWdlS2V5O1xuICAgIG1lc3NhZ2VUeXBlID0gJ0V4ZWN1dGVTY3JpcHRNZXNzYWdlJztcbiAgICBzY3JpcHQ6IHN0cmluZyA9ICcnXG5cbiAgICBzdGF0aWMgcmVwbGllcktleSA9ICdzZW5kJztcbiAgICBzdGF0aWMgY29tcGxldGVTdHJlYW1LZXkgPSAnY29tcGxldGVTdHJlYW0nO1xuXG4gICAgY29uc3RydWN0b3Ioc2NyaXB0OiAodmFyczogZXh0ZW5kZWRTY3JpcHRWYXJzPFQsIEk+KSA9PiBULCBoYW5kbGVyOiAobWVzc2FnZTogRXhlY3V0ZVNjcmlwdFJlcGx5TWVzc2FnZTxUPikgPT4gdm9pZCA9ICgpID0+IHtcbiAgICB9LCBwdWJsaWMgc2NyaXB0SW5wdXRzPzogSSkge1xuICAgICAgICBzdXBlcihoYW5kbGVyKTtcbiAgICAgICAgdGhpcy5zY3JpcHQgPSBzY3JpcHQudG9TdHJpbmcoKTtcblxuICAgICAgICAvL1RPRE86IGNhbiBiZSByZW1vdmVcbiAgICAgICAgdGhpcy5jb250ZW50ID0gc2NyaXB0LnRvU3RyaW5nKClcbiAgICAgICAgdGhpcy5jb250ZW50ID0gc3RyaXBGdW5jdGlvbih0aGlzLmNvbnRlbnQpO1xuICAgIH1cbn1cblxuZXhwb3J0IGNsYXNzIEV4ZWN1dGVTY3JpcHRSZXBseU1lc3NhZ2U8VCA9IGFueT4gZXh0ZW5kcyBNeW9wQmluZFJlcGxheU1lc3NhZ2U8VD4ge1xuXG4gICAgbWVzc2FnZVR5cGUgPSBSZXBsYXlNZXNzYWdlS2V5O1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIHJlcGxheVRvSGFuZGxlcjogc3RyaW5nLCBwdWJsaWMgY29udGVudDogVCkge1xuICAgICAgICBzdXBlcihyZXBsYXlUb0hhbmRsZXIpO1xuICAgIH1cbn1cbiIsICJpbXBvcnQge1xuICAgIEV4ZWN1dGVTY3JpcHRNZXNzYWdlLFxuICAgIEV4ZWN1dGVTY3JpcHRSZXBseU1lc3NhZ2UsXG4gICAgZXh0ZW5kZWRTY3JpcHRWYXJzLFxuICAgIHNjcmlwdElucHV0cywgc3RyaXBGdW5jdGlvblxufSBmcm9tIFwiLi9FeGVjdXRlU2NyaXB0TWVzc2FnZS50c1wiO1xuXG5leHBvcnQgdHlwZSBjdXN0b21SZWZTY3JpcHRJbnB1dHMgPSB7XG4gICAgZWxlbWVudElkOiBzdHJpbmcsXG4gICAgcmVmPzogSFRNTEVsZW1lbnQsXG4gICAgX3NjcmlwdD86IHN0cmluZyxcbiAgICBfX3NjcmlwdElucHV0cz86IE9iamVjdFxufTtcblxuZXhwb3J0IGNsYXNzIEN1c3RvbVJlZk1lc3NhZ2U8VCA9IGFueSwgSSBleHRlbmRzIHNjcmlwdElucHV0cyA9IGN1c3RvbVJlZlNjcmlwdElucHV0cz4gZXh0ZW5kcyBFeGVjdXRlU2NyaXB0TWVzc2FnZTxULCBJICYgY3VzdG9tUmVmU2NyaXB0SW5wdXRzPiB7XG5cbiAgICBjb25zdHJ1Y3RvcihzY3JpcHQ6ICh2YXJzOiBleHRlbmRlZFNjcmlwdFZhcnM8VCwgSSAmIGN1c3RvbVJlZlNjcmlwdElucHV0cz4pID0+IFQsXG4gICAgICAgICAgICAgICAgcHVibGljIHNjcmlwdElucHV0czogSSAmIGN1c3RvbVJlZlNjcmlwdElucHV0cyxcbiAgICAgICAgICAgICAgICBoYW5kbGVyOiAobWVzc2FnZTogRXhlY3V0ZVNjcmlwdFJlcGx5TWVzc2FnZTxUPikgPT4gdm9pZCA9ICgpID0+IHtcbiAgICAgICAgICAgICAgICB9KSB7XG5cbiAgICAgICAgLy9tb2NrIHZhcnNcbiAgICAgICAgLy8gbGV0IHJvb3RSZWYsIGVsZW1lbnRJZCwgX3NjcmlwdCwgX19zY3JpcHRJbnB1dHM7XG4gICAgICAgIHN1cGVyKCh7cm9vdFJlZiwgZWxlbWVudElkLCBfc2NyaXB0LCBfX3NjcmlwdElucHV0c30pID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHJlZnMgPSAocm9vdFJlZi5zaGFkb3dSb290IHx8IHJvb3RSZWYuY29udGFpbmVyKS5xdWVyeVNlbGVjdG9yQWxsKGBbJHsnbXlvcC1pZCd9PScke2VsZW1lbnRJZH0nXWApO1xuICAgICAgICAgICAgaWYgKHJlZnMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgLy8gIGNvbnN0IHJlZiA9IHJlZnNbMF07XG5cbiAgICAgICAgICAgICAgICAvL1RPRE8gOiB0aGluayBhYm91dCBleHBvc2luZyBcInJlZnNcIiBhbmQgbm90IG9ubHkgXCJyZWZcIlxuICAgICAgICAgICAgICAgIC8vZm9yIGNhc2VzIHdoZXJlIHRoZSBSZWYgaGFzIG11bHRpcGxhdGUgaW1wbGVtZW50YXRpb25zXG5cbiAgICAgICAgICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgICAgICAgICAgX19zY3JpcHRJbnB1dHMucmVmID0gcmVmc1swXTtcblxuICAgICAgICAgICAgICAgIGNvbnN0IGR5bmFtaWNGdW5jdGlvbiA9IG5ldyBGdW5jdGlvbihgcmV0dXJuICgke19zY3JpcHR9KSguLi5hcmd1bWVudHMpYCk7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGR5bmFtaWNGdW5jdGlvbihfX3NjcmlwdElucHV0cyk7XG5cbiAgICAgICAgICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgICAgICAgICAgLy9yZXR1cm4gRnVuY3Rpb24oJ3JlZicsICdyb290UmVmJywgLi4uT2JqZWN0LmtleXMoX19zY3JpcHRJbnB1dHMpLCBfc2NyaXB0ISkocmVmLCByb290UmVmLCAuLi5PYmplY3QudmFsdWVzKF9fc2NyaXB0SW5wdXRzKSlcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJldHVybiBudWxsIGFzIFQ7XG4gICAgICAgIH0sIGhhbmRsZXIpO1xuXG4gICAgICAgIHRoaXMuc2NyaXB0SW5wdXRzID0ge1xuICAgICAgICAgICAgLi4uc2NyaXB0SW5wdXRzLFxuICAgICAgICAgICAgLy9fc2NyaXB0OiBzdHJpcEZ1bmN0aW9uKHNjcmlwdC50b1N0cmluZygpKSxcbiAgICAgICAgICAgIF9zY3JpcHQ6IHNjcmlwdC50b1N0cmluZygpXG4gICAgICAgIH07XG4gICAgfVxufVxuIiwgImltcG9ydCB0eXBlICogYXMgQ1NTIGZyb20gXCJjc3N0eXBlXCI7XG5pbXBvcnQge0lNeW9wQ29tcG9uZW50fSBmcm9tIFwiLi4vaG9zdFwiO1xuaW1wb3J0IHt1dWlkdjR9IGZyb20gXCIuLi91dGlscy91dGlscy50c1wiO1xuaW1wb3J0IHtFeGVjdXRlU2NyaXB0TWVzc2FnZX0gZnJvbSBcIi4uL21lc3NhZ2VzXCI7XG5cbi8vIGlnbm9yaW5nIGRvY3VtZW50YXRpb25cbi8qKiBAaWdub3JlICovXG5leHBvcnQgaW50ZXJmYWNlIENTU1Byb3BlcnRpZXMgZXh0ZW5kcyBDU1MuUHJvcGVydGllczxzdHJpbmcgfCBudW1iZXI+IHtcbn1cblxuZXhwb3J0IHR5cGUgU3R5bGVzaGVldERlZmluaXRpb24gPSB7IFtrZXk6IHN0cmluZ106IENTU1Byb3BlcnRpZXMgfTtcblxuZXhwb3J0IGNvbnN0IGFwcGx5U3R5bGVzaGVldCA9IChjb21wb25lbnQ6IElNeW9wQ29tcG9uZW50LCBzdHlsZXNoZWV0OiBTdHlsZXNoZWV0RGVmaW5pdGlvbiwgY3NzPzogc3RyaW5nKSA9PiB7XG4gICAgY29uc3QgdGFnSWQgPSBgbXlvcC1jc3MtJHt1dWlkdjQoKX1gO1xuICAgIGNvbXBvbmVudC5zZW5kKG5ldyBFeGVjdXRlU2NyaXB0TWVzc2FnZSgoe3Jvb3RSZWYsIF9zdHlsZXNoZWV0LCBfdGFnSWQsIF9jc3N9KSA9PiB7XG4gICAgICAgIGNvbnN0IHN0eWxlVGFnID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnc3R5bGUnKTtcbiAgICAgICAgc3R5bGVUYWcudHlwZSA9ICd0ZXh0L2Nzcyc7XG5cbiAgICAgICAgLy8gQnVpbGQgdGhlIENTUyBzdHJpbmcgZnJvbSB0aGUgc3R5bGVzIG9iamVjdFxuICAgICAgICBsZXQgY3NzU3RyaW5nID0gX2NzcztcblxuICAgICAgICBmb3IgKGNvbnN0IHNlbGVjdG9yIGluIF9zdHlsZXNoZWV0KSB7XG4gICAgICAgICAgICBjc3NTdHJpbmcgKz0gYCR7c2VsZWN0b3J9IHsgYDtcbiAgICAgICAgICAgIGNvbnN0IHByb3BlcnRpZXMgPSBfc3R5bGVzaGVldFtzZWxlY3Rvcl07XG4gICAgICAgICAgICBmb3IgKGNvbnN0IHByb3BlcnR5IGluIHByb3BlcnRpZXMpIHtcbiAgICAgICAgICAgICAgICBjc3NTdHJpbmcgKz0gYCR7cHJvcGVydHl9OiAke3Byb3BlcnRpZXNbcHJvcGVydHldfTsgYDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGNzc1N0cmluZyArPSAnfSAnO1xuICAgICAgICB9XG5cbiAgICAgICAgLy8gU2V0IHRoZSBDU1Mgc3RyaW5nIGFzIHRoZSBjb250ZW50IG9mIHRoZSA8c3R5bGU+IGVsZW1lbnRcbiAgICAgICAgc3R5bGVUYWcuYXBwZW5kQ2hpbGQoZG9jdW1lbnQuY3JlYXRlVGV4dE5vZGUoY3NzU3RyaW5nKSk7XG4gICAgICAgIHN0eWxlVGFnLmlkID0gX3RhZ0lkO1xuICAgICAgICAvLyBBcHBlbmQgdGhlIDxzdHlsZT4gZWxlbWVudFxuICAgICAgICAocm9vdFJlZi5zaGFkb3dSb290IHx8IHJvb3RSZWYuY29udGFpbmVyKS5hcHBlbmRDaGlsZChzdHlsZVRhZyk7XG5cbiAgICB9LCAoKSA9PiB7XG4gICAgfSwge1xuICAgICAgICBfc3R5bGVzaGVldDogc3R5bGVzaGVldCxcbiAgICAgICAgX2NzcyA6IGNzcyA/IGNzcyA6ICcnLFxuICAgICAgICBfdGFnSWQ6IHRhZ0lkXG4gICAgfSkpO1xuXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgICAgY29tcG9uZW50LnNlbmQobmV3IEV4ZWN1dGVTY3JpcHRNZXNzYWdlKCh7cm9vdFJlZiwgX3RhZ0lkfSkgPT4ge1xuICAgICAgICAgICAgY29uc3QgZWxlbWVudCA9IChyb290UmVmLnNoYWRvd1Jvb3QgfHwgZG9jdW1lbnQpLmdldEVsZW1lbnRCeUlkKF90YWdJZCk7XG4gICAgICAgICAgICBpZiAoZWxlbWVudCkge1xuICAgICAgICAgICAgICAgIGVsZW1lbnQucmVtb3ZlKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0sICgpID0+IHtcbiAgICAgICAgfSwge1xuICAgICAgICAgICAgX3RhZ0lkOiB0YWdJZFxuICAgICAgICB9KSlcbiAgICB9XG59XG5cbmV4cG9ydCBjb25zdCBhcHBseVN0eWxlc2hlZXRMaW5rID0gKGNvbXBvbmVudDogSU15b3BDb21wb25lbnQsIGxpbms6IHN0cmluZykgPT4ge1xuICAgIGNvbnN0IHRhZ0lkID0gYG15b3AtY3NzLSR7dXVpZHY0KCl9YDtcbiAgICBjb21wb25lbnQuc2VuZChuZXcgRXhlY3V0ZVNjcmlwdE1lc3NhZ2UoKHtyb290UmVmLCBfdGFnSWQsIF9saW5rfSkgPT4ge1xuICAgICAgICBjb25zdCBsaW5rRWxlbWVudCA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ2xpbmsnKTtcbiAgICAgICAgbGlua0VsZW1lbnQuaWQgPSBfdGFnSWQ7XG4gICAgICAgIGxpbmtFbGVtZW50LnJlbCA9ICdzdHlsZXNoZWV0JztcbiAgICAgICAgbGlua0VsZW1lbnQuaHJlZiA9IF9saW5rO1xuICAgICAgICBkb2N1bWVudC5oZWFkLmFwcGVuZENoaWxkKGxpbmtFbGVtZW50KTtcblxuICAgICAgICAvLyBBcHBlbmQgdGhlIDxzdHlsZT4gZWxlbWVudFxuICAgICAgICAocm9vdFJlZi5zaGFkb3dSb290IHx8IHJvb3RSZWYuY29udGFpbmVyKS5hcHBlbmRDaGlsZChsaW5rRWxlbWVudCk7XG4gICAgfSwgKCkgPT4ge1xuICAgIH0sIHtcbiAgICAgICAgX2xpbmsgOiBsaW5rLFxuICAgICAgICBfdGFnSWQ6IHRhZ0lkXG4gICAgfSkpO1xuXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgICAgY29tcG9uZW50LnNlbmQobmV3IEV4ZWN1dGVTY3JpcHRNZXNzYWdlKCh7cm9vdFJlZiwgX3RhZ0lkfSkgPT4ge1xuICAgICAgICAgICAgY29uc3QgZWxlbWVudCA9IChyb290UmVmLnNoYWRvd1Jvb3QgfHwgZG9jdW1lbnQpLmdldEVsZW1lbnRCeUlkKF90YWdJZCk7XG4gICAgICAgICAgICBpZiAoZWxlbWVudCkge1xuICAgICAgICAgICAgICAgIGVsZW1lbnQucmVtb3ZlKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0sICgpID0+IHtcbiAgICAgICAgfSwge1xuICAgICAgICAgICAgX3RhZ0lkOiB0YWdJZFxuICAgICAgICB9KSlcbiAgICB9XG59XG4iLCAiaW1wb3J0IHtJSWZyYW1lTG9hZGVyQ29uZmlnLCBJU2tpbkNvbmZpZ30gZnJvbSBcIi4uL2NvbW1vblwiO1xuXG5leHBvcnQgdHlwZSBUb2tlbk1hcCA9IFJlY29yZDxzdHJpbmcsIHN0cmluZ3wgbnVtYmVyPlxuXG5jb25zdCByZXBsYWNlVG9rZW5zID0gKGlucHV0OiBzdHJpbmcsIHRva2VuTWFwOiBUb2tlbk1hcCk6IHN0cmluZyA9PiB7XG4gICAgLy8gQ3JlYXRlIGEgcmVnZXggcGF0dGVybiBmcm9tIHRoZSBrZXlzIG9mIHRoZSB0b2tlbk1hcFxuICAgIGNvbnN0IHBhdHRlcm4gPSBuZXcgUmVnRXhwKE9iamVjdC5rZXlzKHRva2VuTWFwKS5qb2luKCd8JyksICdnJyk7XG5cbiAgICAvLyBSZXBsYWNlIHRva2VucyBpbiB0aGUgaW5wdXQgc3RyaW5nIHVzaW5nIHRoZSByZWdleFxuICAgIHJldHVybiBpbnB1dC5yZXBsYWNlKHBhdHRlcm4sIChtYXRjaGVkKSA9PiB7XG4gICAgICAgIC8vIFJldHVybiB0aGUgcmVwbGFjZW1lbnQgdmFsdWUgZnJvbSB0aGUgdG9rZW5NYXBcbiAgICAgICAgcmV0dXJuICh0b2tlbk1hcFttYXRjaGVkXSB8fCBtYXRjaGVkKS50b1N0cmluZygpO1xuICAgIH0pO1xufVxuXG5leHBvcnQgY29uc3QgY3JlYXRlSWZyYW1lU2tpbkJ5VG9rZW5pemVyID0gKHNlbGVjdGVkU2tpbjogSVNraW5Db25maWcsIHRva2VuTWFwOiBUb2tlbk1hcCkgPT4ge1xuICAgIGNvbnN0IHR5cGVkU2tpbkNvbmZpZyA9IChzZWxlY3RlZFNraW4ubG9hZGVyIGFzIElJZnJhbWVMb2FkZXJDb25maWcpXG4gICAgaWYgKHR5cGVkU2tpbkNvbmZpZy50eXBlICE9PSAnSWZyYW1lTG9hZGVyJykge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYGlmcmFtZVNraW5VcmxUb2tlbml6ZXIgcmVjZWl2ZWQgc2tpbiB3aXRoIGxvYWRlciB0eXBlIFwiJHt0eXBlZFNraW5Db25maWcudHlwZX1cIiwgY3VycmVudGx5IG9ubHkgXCJJZnJhbWVMb2FkZXJcIiBpcyBzdXBwb3J0ZWRgKVxuICAgIH1cblxuICAgIHNlbGVjdGVkU2tpbi5sb2FkZXIgPSB7XG4gICAgICAgIC4uLnNlbGVjdGVkU2tpbi5sb2FkZXJcbiAgICB9XG5cbiAgICBzZWxlY3RlZFNraW4ubG9hZGVyLnVybCA9IHJlcGxhY2VUb2tlbnMoc2VsZWN0ZWRTa2luLmxvYWRlci51cmwsIHRva2VuTWFwKTtcblxuICAgIHJldHVybiBzZWxlY3RlZFNraW47XG59XG5cbmV4cG9ydCBjb25zdCBjaGFuZ2VTa2luVXJsQnlUb2tlbml6ZXIgPSAodG9rZW5NYXA6IFRva2VuTWFwKSA9PiB7XG4gICAgcmV0dXJuIGFzeW5jIChzZWxlY3RlZFNraW46IElTa2luQ29uZmlnKSA9PiB7XG4gICAgICAgIHJldHVybiBjcmVhdGVJZnJhbWVTa2luQnlUb2tlbml6ZXIoc2VsZWN0ZWRTa2luLCB0b2tlbk1hcCk7XG4gICAgfVxufSIsICJpbXBvcnQge0N1c3RvbVJlZk1lc3NhZ2V9IGZyb20gXCIuLi9tZXNzYWdlc1wiO1xuaW1wb3J0IHtJTXlvcENvbXBvbmVudH0gZnJvbSBcIi4uL2hvc3RcIjtcblxuLy8gY29uc3Qgc3BhY2UgPSAnICc7XG4vLyBleHBvcnQgY29uc3QgZ2V0Q2xhc3NlcyA9IGFzeW5jIChjb25uZWN0ZWRSZWY6IFJlZik6IFByb21pc2U8c3RyaW5nW10+ID0+IChhd2FpdCBleGVjKGFjdEFzPEhUTUxEaXZFbGVtZW50Pihjb25uZWN0ZWRSZWYpLmNsYXNzTGlzdCkpLnZhbHVlLnNwbGl0KHNwYWNlKTtcbi8vIGV4cG9ydCBjb25zdCBhZGRDbGFzcyA9IGFzeW5jIChjb25uZWN0ZWRSZWY6IFJlZiwgY2xhc3NOYW1lOiBzdHJpbmcpID0+IHtcbi8vICAgICBjb25zdCBjbGFzc2VzID0gYXdhaXQgZ2V0Q2xhc3Nlcyhjb25uZWN0ZWRSZWYpO1xuLy8gICAgIGNsYXNzZXMuaW5jbHVkZXMoY2xhc3NOYW1lKSB8fCBjbGFzc2VzLnB1c2goY2xhc3NOYW1lKTtcbi8vICAgICAvLyBAdHMtaWdub3JlXG4vLyAgICAgY29ubmVjdGVkUmVmLmNsYXNzTGlzdCA9IGNsYXNzZXMuam9pbihzcGFjZSk7XG4vLyB9XG4vLyBleHBvcnQgY29uc3QgcmVtb3ZlQ2xhc3MgPSBhc3luYyAoY29ubmVjdGVkUmVmOiBSZWYsIGNsYXNzTmFtZTogc3RyaW5nLCkgPT4ge1xuLy8gICAgIGxldCBjbGFzc2VzID0gYXdhaXQgZ2V0Q2xhc3Nlcyhjb25uZWN0ZWRSZWYpO1xuLy8gICAgIC8vIEB0cy1pZ25vcmVcbi8vICAgICBjb25uZWN0ZWRSZWYuY2xhc3NMaXN0ID0gY2xhc3Nlcy5maWx0ZXIoYyA9PiBjICE9PSBjbGFzc05hbWUpLmpvaW4oc3BhY2UpO1xuLy8gfVxuLy9cbi8vXG5cbmV4cG9ydCBjb25zdCBhZGRDbGFzcyA9IChjb21wb25lbnQ6IElNeW9wQ29tcG9uZW50LCBjbGFzc05hbWU6IHN0cmluZywgbXlvcElkOiBzdHJpbmcpID0+IHtcbiAgICBjb21wb25lbnQuc2VuZChuZXcgQ3VzdG9tUmVmTWVzc2FnZSgoe3JlZiwgX2NsYXNzTmFtZX0pID0+IHtcbiAgICAgICAgcmVmPy5jbGFzc0xpc3QuYWRkKF9jbGFzc05hbWUpO1xuICAgIH0sIHtcbiAgICAgICAgZWxlbWVudElkOiBteW9wSWQsXG4gICAgICAgIF9jbGFzc05hbWU6IGNsYXNzTmFtZVxuICAgIH0pKTtcbn1cblxuZXhwb3J0IGNvbnN0IHJlbW92ZUNsYXNzID0gKGNvbXBvbmVudDogSU15b3BDb21wb25lbnQsIGNsYXNzTmFtZTogc3RyaW5nLCBteW9wSWQ6IHN0cmluZykgPT4ge1xuICAgIGNvbXBvbmVudC5zZW5kKG5ldyBDdXN0b21SZWZNZXNzYWdlKCh7cmVmLCBfY2xhc3NOYW1lfSkgPT4ge1xuICAgICAgICByZWY/LmNsYXNzTGlzdC5yZW1vdmUoX2NsYXNzTmFtZSk7XG4gICAgfSwge1xuICAgICAgICBlbGVtZW50SWQ6IG15b3BJZCxcbiAgICAgICAgX2NsYXNzTmFtZTogY2xhc3NOYW1lXG4gICAgfSkpO1xufSIsICJpbXBvcnQge1xuICAgIElDb21wb25lbnRDb25maWcsXG4gICAgSUNvbXBvbmVudERlZmluaXRpb25Db25maWcsXG4gICAgSUNvbXBvbmVudEluc3RhbmNlQ29uZmlnLCBJSFRNTExvYWRlckNvbmZpZywgSVJlZkNvbmZpZyxcbiAgICBJU2tpbkxvYWRlckNvbmZpZyxcbiAgICBJU2tpblNlbGVjdG9yQ29uZmlnLFxuICAgIElEZWRpY2F0ZWRTa2luQ29uZmlnLCBJU2tpbkNvbmZpZ1xufSBmcm9tIFwiLi4vY29tbW9uXCI7XG5pbXBvcnQge3V1aWR2NH0gZnJvbSBcIi4uL3V0aWxzL3V0aWxzLnRzXCI7XG5cbmV4cG9ydCBjbGFzcyBTa2luQ29uZmlnIGltcGxlbWVudHMgSVNraW5Db25maWcge1xuICAgIF9ydW5UaW1lSW5zdGFuY2VJZCA9ICdydW50aW1lLWluc3RhbmNlLWlkLScgKyB1dWlkdjQoKTtcbiAgICBfcnVuVGltZUlkID0gJ3J1bnRpbWUtaWQtJyArIHV1aWR2NCgpO1xuICAgIF9ydW5UaW1lTmFtZSA9ICdydW50aW1lLW5hbWUtJyArIHV1aWR2NCgpO1xuXG4gICAgc3RhdGljIGNyZWF0ZSA9ICgpID0+IHtcbiAgICAgICAgcmV0dXJuIG5ldyBTa2luQ29uZmlnKCk7XG4gICAgfVxuXG4gICAgaWQgPSB0aGlzLl9ydW5UaW1lSWQ7XG4gICAgbmFtZSA9IHRoaXMuX3J1blRpbWVOYW1lO1xuICAgIGRlc2NyaXB0aW9uID0gJyc7XG4gICAgbG9hZGVyID0gbnVsbCBhcyB1bmtub3duIGFzIElTa2luTG9hZGVyQ29uZmlnO1xuXG4gICAgd2l0aExvYWRlciA9IChsb2FkZXI6IElTa2luTG9hZGVyQ29uZmlnKSA9PiB7XG4gICAgICAgIHRoaXMubG9hZGVyID0gbG9hZGVyO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICB3aXRoSFRNTExvYWRlciA9IChsb2FkZXI6IE9taXQ8SUhUTUxMb2FkZXJDb25maWcsICd0eXBlJz4pID0+IHtcbiAgICAgICAgbG9hZGVyLnR5cGUgPSAnSFRNTExvYWRlcic7XG4gICAgICAgIHRoaXMubG9hZGVyID0gbG9hZGVyIGFzIElIVE1MTG9hZGVyQ29uZmlnO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICBidWlsZCA9ICgpID0+IHtcbiAgICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxufVxuXG5leHBvcnQgY2xhc3MgQ29tcG9uZW50Q29uZmlnIGltcGxlbWVudHMgSUNvbXBvbmVudENvbmZpZyB7XG4gICAgX3J1blRpbWVJbnN0YW5jZUlkID0gJ3J1bnRpbWUtaW5zdGFuY2UtaWQtJyArIHV1aWR2NCgpO1xuICAgIF9ydW5UaW1lSWQgPSAncnVudGltZS1pZC0nICsgdXVpZHY0KCk7XG4gICAgX3J1blRpbWVOYW1lID0gJ3J1bnRpbWUtbmFtZS0nICsgdXVpZHY0KCk7XG5cbiAgICBzdGF0aWMgY3JlYXRlID0gKCkgPT4ge1xuICAgICAgICByZXR1cm4gbmV3IENvbXBvbmVudENvbmZpZygpO1xuICAgIH1cblxuICAgIGluc3RhbmNlID0ge1xuICAgICAgICBpZDogdGhpcy5fcnVuVGltZUluc3RhbmNlSWQsXG4gICAgICAgIGNvbXBvbmVudElkOiB0aGlzLl9ydW5UaW1lSWQsXG4gICAgICAgIGNvbXBvbmVudE5hbWU6IHRoaXMuX3J1blRpbWVOYW1lLFxuICAgICAgICBza2luU2VsZWN0b3I6IG51bGwgYXMgdW5rbm93biBhcyBJU2tpblNlbGVjdG9yQ29uZmlnXG4gICAgfSBhcyBJQ29tcG9uZW50SW5zdGFuY2VDb25maWc7XG5cbiAgICBuYW1lID0gdGhpcy5fcnVuVGltZU5hbWVcbiAgICB0eXBlID0ge1xuICAgICAgICBpZDogdGhpcy5fcnVuVGltZUlkLFxuICAgICAgICBuYW1lOiB0aGlzLl9ydW5UaW1lTmFtZSxcbiAgICAgICAgZGVzY3JpcHRpb246ICcnLFxuICAgICAgICBwcm9wczogW10sXG4gICAgICAgIHJlZnM6IFtdLFxuICAgICAgICBza2luczogW10sXG4gICAgICAgIGRlZmF1bHRTa2luOiAwXG4gICAgfSBhcyBJQ29tcG9uZW50RGVmaW5pdGlvbkNvbmZpZ1xuXG4gICAgd2l0aEluc3RhbmNlID0gKGluc3RhbmNlOiBJQ29tcG9uZW50SW5zdGFuY2VDb25maWcpID0+IHtcbiAgICAgICAgdGhpcy5pbnN0YW5jZSA9IGluc3RhbmNlO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICB3aXRoVHlwZSA9ICh0eXBlOiBJQ29tcG9uZW50RGVmaW5pdGlvbkNvbmZpZykgPT4ge1xuICAgICAgICB0aGlzLnR5cGUgPSB0eXBlO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICB3aXRoTmFtZSA9IChuYW1lOiBzdHJpbmcpID0+IHtcbiAgICAgICAgdGhpcy5uYW1lID0gbmFtZTtcbiAgICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgd2l0aERlZmF1bHRTa2luID0gKGRlZmF1bHRTa2luOiBJU2tpbkNvbmZpZykgPT4ge1xuICAgICAgICB0aGlzLnR5cGUuc2tpbnMucHVzaChkZWZhdWx0U2tpbik7XG4gICAgICAgIHRoaXMudHlwZS5kZWZhdWx0U2tpbiA9IHRoaXMudHlwZS5za2lucy5sZW5ndGggLSAxO1xuICAgICAgICB0aGlzLmluc3RhbmNlLnNraW5TZWxlY3RvciA9IHtcbiAgICAgICAgICAgIHR5cGU6ICdEZWRpY2F0ZWQnLFxuICAgICAgICAgICAgc2tpbjoge1xuICAgICAgICAgICAgICAgIGlkOiBkZWZhdWx0U2tpbi5pZFxuICAgICAgICAgICAgfVxuICAgICAgICB9IGFzIElEZWRpY2F0ZWRTa2luQ29uZmlnXG5cbiAgICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgd2l0aFJlZiA9IChyZWY6IElSZWZDb25maWcpID0+IHtcbiAgICAgICAgdGhpcy50eXBlLnJlZnMucHVzaChyZWYpO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICB3aXRoQmFzaWNSZWYgPSAocmVmU2VsZWN0b3I6IHN0cmluZykgPT4ge1xuICAgICAgICBjb25zdCBuZXdCYXNpY1JlZiA9IHtcbiAgICAgICAgICAgIGlkOiAnJyxcbiAgICAgICAgICAgIG5hbWU6IHJlZlNlbGVjdG9yLFxuICAgICAgICAgICAgZGVzY3JpcHRpb246ICcnLFxuICAgICAgICAgICAgc2VsZWN0b3JUeXBlOiAnaWQtYXR0cmlidXRlJyxcbiAgICAgICAgICAgIHNlbGVjdG9yOiByZWZTZWxlY3RvcixcbiAgICAgICAgICAgIGJlaGF2aW9yOiB7XG4gICAgICAgICAgICAgICAgdHlwZTogJ2NvZGUnXG4gICAgICAgICAgICB9XG4gICAgICAgIH0gYXMgSVJlZkNvbmZpZ1xuXG4gICAgICAgIHRoaXMudHlwZS5yZWZzLnB1c2gobmV3QmFzaWNSZWYpO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICBidWlsZCA9ICgpID0+IHtcbiAgICAgICAgcmV0dXJuIEpTT04ucGFyc2UoSlNPTi5zdHJpbmdpZnkodGhpcykpXG4gICAgfVxufVxuIiwgImltcG9ydCB7SVVzZXJGbG93fSBmcm9tIFwiLi4vY29tbW9uXCI7XG5cbi8qKlxuICpcbiAqICMjIE92ZXJ2aWV3XG4gKlxuICogVGhlIGBDbG91ZFJlcG9zaXRvcnlgIGNsYXNzIHNlcnZlcyBhcyBhIGNlbnRyYWxpemVkIGRhdGEgYWNjZXNzIGxheWVyIGZvciByZXRyaWV2aW5nIHVzZXIgZmxvd3MgYW5kIGNvbXBvbmVudHMgZnJvbSB0aGUgTXlvcC5kZXYgY2xvdWQgc2VydmljZS4gSXQgaW1wbGVtZW50cyBhIHNpbmdsZXRvbiBwYXR0ZXJuIGFuZCBwcm92aWRlcyBjYWNoaW5nIG1lY2hhbmlzbXMgdG8gb3B0aW1pemUgQVBJIGNhbGxzIGFuZCBpbXByb3ZlIHBlcmZvcm1hbmNlLlxuICpcbiAqICMjIENsYXNzIFN0cnVjdHVyZVxuICpcbiAqICMjIyBDb25zdHJ1Y3RvclxuICpcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGNvbnN0cnVjdG9yKHByaXZhdGUgX2Jhc2VVcmwgPSAnaHR0cHM6Ly9jbG91ZC5teW9wLmRldicpXG4gKiBgYGBcbiAqXG4gKiAqKlBhcmFtZXRlcnM6KipcbiAqIC0gYF9iYXNlVXJsYCAob3B0aW9uYWwpOiBUaGUgYmFzZSBVUkwgZm9yIHRoZSBNeW9wLmRldiBjbG91ZCBBUEkuIERlZmF1bHRzIHRvIGAnaHR0cHM6Ly9jbG91ZC5teW9wLmRldidgXG4gKlxuICogIyMjIFN0YXRpYyBQcm9wZXJ0aWVzXG4gKlxuICogIyMjIyBNYWluXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiBzdGF0aWMgTWFpbiA9IG5ldyBDbG91ZFJlcG9zaXRvcnkoKTtcbiAqIGBgYFxuICpcbiAqIEEgc2luZ2xldG9uIGluc3RhbmNlIG9mIHRoZSBgQ2xvdWRSZXBvc2l0b3J5YCBjbGFzcyB0aGF0IGNhbiBiZSB1c2VkIHRocm91Z2hvdXQgdGhlIGFwcGxpY2F0aW9uIHdpdGhvdXQgY3JlYXRpbmcgbXVsdGlwbGUgaW5zdGFuY2VzLlxuICpcbiAqICMjIyBQcml2YXRlIFByb3BlcnRpZXNcbiAqXG4gKiAjIyMjIHVzZXJGbG93c1xuICogYGBgdHlwZXNjcmlwdFxuICogcHJpdmF0ZSB1c2VyRmxvd3M6IFJlY29yZDxzdHJpbmcsIFByb21pc2U8SVVzZXJGbG93Pj4gPSB7fTtcbiAqIGBgYFxuICpcbiAqIEEgY2FjaGUgb2JqZWN0IHRoYXQgc3RvcmVzIHByb21pc2VzIGZvciB1c2VyIGZsb3dzLCBpbmRleGVkIGJ5IGZsb3cgSUQuIFRoaXMgcHJldmVudHMgZHVwbGljYXRlIEFQSSBjYWxscyBmb3IgdGhlIHNhbWUgZmxvdyBhbmQgZW5zdXJlcyBjb25zaXN0ZW50IGRhdGEgcmV0cmlldmFsLlxuICpcbiAqICMjIyMgX2Jhc2VVcmxcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIHByaXZhdGUgX2Jhc2VVcmw6IHN0cmluZ1xuICogYGBgXG4gKlxuICogVGhlIGJhc2UgVVJMIGZvciB0aGUgY2xvdWQgQVBJIGVuZHBvaW50cywgc2V0IGR1cmluZyBjb25zdHJ1Y3Rpb24uXG4gKlxuICogIyMgTWV0aG9kc1xuICpcbiAqICMjIyBmZXRjaEZsb3coZmxvd0lkOiBzdHJpbmcpXG4gKlxuICogUmV0cmlldmVzIGEgY29tcGxldGUgdXNlciBmbG93IGZyb20gdGhlIGNsb3VkIHJlcG9zaXRvcnksIGluY2x1ZGluZyBhbGwgcmVzb2x2ZWQgY29tcG9uZW50cy5cbiAqXG4gKiAqKlBhcmFtZXRlcnM6KipcbiAqIC0gYGZsb3dJZGA6IFRoZSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIHVzZXIgZmxvdyB0byByZXRyaWV2ZVxuICpcbiAqICoqUmV0dXJuczoqKlxuICogLSBgUHJvbWlzZTxJVXNlckZsb3c+YDogQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgdG8gdGhlIGNvbXBsZXRlIHVzZXIgZmxvdyBvYmplY3RcbiAqXG4gKiAqKkJlaGF2aW9yOioqXG4gKiAtIEltcGxlbWVudHMgcmVxdWVzdCBjYWNoaW5nIHRvIGF2b2lkIGR1cGxpY2F0ZSBBUEkgY2FsbHMgZm9yIHRoZSBzYW1lIGZsb3cgSURcbiAqIC0gTWFrZXMgYSBHRVQgcmVxdWVzdCB0byBgL2Zsb3c/aWQ9e2Zsb3dJZH0mcmVzb2x2ZT1jb21wb25lbnRzYFxuICogLSBBdXRvbWF0aWNhbGx5IHJlc29sdmVzIGNvbXBvbmVudCByZWZlcmVuY2VzIHdpdGhpbiB0aGUgZmxvd1xuICogLSBTdG9yZXMgdGhlIHByb21pc2UgaW4gdGhlIGNhY2hlIGZvciBmdXR1cmUgdXNlXG4gKlxuICogKipFeGFtcGxlIFVzYWdlOioqXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiBjb25zdCBmbG93ID0gYXdhaXQgQ2xvdWRSZXBvc2l0b3J5Lk1haW4uZmV0Y2hGbG93KCdteS1mbG93LWlkJyk7XG4gKiBjb25zb2xlLmxvZyhmbG93LmNvbXBvbmVudHMpO1xuICogYGBgXG4gKlxuICogIyMjIGZldGNoQ29tcG9uZW50KGNvbXBvbmVudElkOiBzdHJpbmcsIGZsb3dJZDogc3RyaW5nKVxuICpcbiAqIFJldHJpZXZlcyBhIHNwZWNpZmljIGNvbXBvbmVudCBmcm9tIHdpdGhpbiBhIHVzZXIgZmxvdy5cbiAqXG4gKiAqKlBhcmFtZXRlcnM6KipcbiAqIC0gYGNvbXBvbmVudElkYDogVGhlIHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGUgY29tcG9uZW50IHRvIHJldHJpZXZlXG4gKiAtIGBmbG93SWRgOiBUaGUgdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSB1c2VyIGZsb3cgY29udGFpbmluZyB0aGUgY29tcG9uZW50XG4gKlxuICogKipSZXR1cm5zOioqXG4gKiAtIGBQcm9taXNlPENvbXBvbmVudCB8IHVuZGVmaW5lZD5gOiBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB0byB0aGUgY29tcG9uZW50IG9iamVjdCBpZiBmb3VuZCwgb3IgdW5kZWZpbmVkIGlmIG5vdCBmb3VuZFxuICpcbiAqICoqQmVoYXZpb3I6KipcbiAqIC0gRmlyc3QgZmV0Y2hlcyB0aGUgY29tcGxldGUgZmxvdyB1c2luZyBgZmV0Y2hGbG93KClgXG4gKiAtIFNlYXJjaGVzIHRocm91Z2ggdGhlIGZsb3cncyBjb21wb25lbnRzIGFycmF5IHRvIGZpbmQgdGhlIG1hdGNoaW5nIGNvbXBvbmVudFxuICogLSBVc2VzIHRoZSBjb21wb25lbnQncyBgdHlwZS5pZGAgcHJvcGVydHkgZm9yIG1hdGNoaW5nXG4gKlxuICogKipFeGFtcGxlIFVzYWdlOioqXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiBjb25zdCBjb21wb25lbnQgPSBhd2FpdCBDbG91ZFJlcG9zaXRvcnkuTWFpbi5mZXRjaENvbXBvbmVudCgnYnV0dG9uLWNvbXBvbmVudCcsICdteS1mbG93LWlkJyk7XG4gKiBpZiAoY29tcG9uZW50KSB7XG4gKiAgICAgY29uc29sZS5sb2coJ0NvbXBvbmVudCBmb3VuZDonLCBjb21wb25lbnQpO1xuICogfSBlbHNlIHtcbiAqICAgICBjb25zb2xlLmxvZygnQ29tcG9uZW50IG5vdCBmb3VuZCBpbiBmbG93Jyk7XG4gKiB9XG4gKiBgYGBcbiAqXG4gKiAjIyBBUEkgSW50ZWdyYXRpb25cbiAqXG4gKiAjIyMgRW5kcG9pbnQgU3RydWN0dXJlXG4gKlxuICogVGhlIGNsYXNzIGludGVncmF0ZXMgd2l0aCB0aGUgZm9sbG93aW5nIE15b3AuZGV2IGNsb3VkIEFQSSBlbmRwb2ludDpcbiAqXG4gKiBgYGBcbiAqIEdFVCB7YmFzZVVybH0vZmxvdz9pZD17Zmxvd0lkfSZyZXNvbHZlPWNvbXBvbmVudHNcbiAqIGBgYFxuICpcbiAqICoqUXVlcnkgUGFyYW1ldGVyczoqKlxuICogLSBgaWRgOiBUaGUgZmxvdyBpZGVudGlmaWVyXG4gKiAtIGByZXNvbHZlPWNvbXBvbmVudHNgOiBJbnN0cnVjdHMgdGhlIEFQSSB0byBpbmNsdWRlIHJlc29sdmVkIGNvbXBvbmVudCBkYXRhIGluIHRoZSByZXNwb25zZVxuICpcbiAqICMjIyBSZXNwb25zZSBGb3JtYXRcbiAqXG4gKiBUaGUgQVBJIGlzIGV4cGVjdGVkIHRvIHJldHVybiBhIEpTT04gcmVzcG9uc2Ugd2l0aCB0aGUgZm9sbG93aW5nIHN0cnVjdHVyZTpcbiAqXG4gKiBgYGBqc29uXG4gKiB7XG4gKiAgICAgXCJpdGVtXCI6IHtcbiAqICAgICAgICAgLy8gSVVzZXJGbG93IG9iamVjdCB3aXRoIHJlc29sdmVkIGNvbXBvbmVudHNcbiAqICAgICAgICAgXCJjb21wb25lbnRzXCI6IFtcbiAqICAgICAgICAgICAgIHtcbiAqICAgICAgICAgICAgICAgICBcInR5cGVcIjoge1xuICogICAgICAgICAgICAgICAgICAgICBcImlkXCI6IFwiY29tcG9uZW50LWlkXCJcbiAqICAgICAgICAgICAgICAgICB9XG4gKiAgICAgICAgICAgICAgICAgLy8gLi4uIG90aGVyIGNvbXBvbmVudCBwcm9wZXJ0aWVzXG4gKiAgICAgICAgICAgICB9XG4gKiAgICAgICAgIF1cbiAqICAgICAgICAgLy8gLi4uIG90aGVyIGZsb3cgcHJvcGVydGllc1xuICogICAgIH1cbiAqIH1cbiAqIGBgYFxuICpcbiAqICMjIENhY2hpbmcgU3RyYXRlZ3lcbiAqXG4gKiBUaGUgYENsb3VkUmVwb3NpdG9yeWAgaW1wbGVtZW50cyBhIHByb21pc2UtYmFzZWQgY2FjaGluZyBtZWNoYW5pc206XG4gKlxuICogMS4gKipDYWNoZSBLZXkqKjogRmxvdyBJRCBpcyB1c2VkIGFzIHRoZSBjYWNoZSBrZXlcbiAqIDIuICoqQ2FjaGUgVmFsdWUqKjogUHJvbWlzZXMgYXJlIGNhY2hlZCByYXRoZXIgdGhhbiByZXNvbHZlZCB2YWx1ZXMgdG8gaGFuZGxlIGNvbmN1cnJlbnQgcmVxdWVzdHNcbiAqIDMuICoqQ2FjaGUgRHVyYXRpb24qKjogQ2FjaGUgcGVyc2lzdHMgZm9yIHRoZSBsaWZldGltZSBvZiB0aGUgcmVwb3NpdG9yeSBpbnN0YW5jZVxuICogNC4gKipDYWNoZSBJbnZhbGlkYXRpb24qKjogTm8gYXV0b21hdGljIGNhY2hlIGludmFsaWRhdGlvbiBpcyBpbXBsZW1lbnRlZFxuICpcbiAqICMjIEVycm9yIEhhbmRsaW5nXG4gKlxuICogLSBOZXR3b3JrIGVycm9ycyBhbmQgQVBJIGZhaWx1cmVzIGFyZSBwcm9wYWdhdGVkIHRocm91Z2ggcHJvbWlzZSByZWplY3Rpb25cbiAqIC0gTm8gc3BlY2lmaWMgZXJyb3IgaGFuZGxpbmcgb3IgcmV0cnkgbG9naWMgaXMgaW1wbGVtZW50ZWQgYXQgdGhlIHJlcG9zaXRvcnkgbGV2ZWxcbiAqIC0gQ29uc3VtZXJzIHNob3VsZCBpbXBsZW1lbnQgYXBwcm9wcmlhdGUgZXJyb3IgaGFuZGxpbmcgd2hlbiBjYWxsaW5nIHJlcG9zaXRvcnkgbWV0aG9kc1xuICpcbiAqICMjIFVzYWdlIFBhdHRlcm5zXG4gKlxuICogIyMjIFNpbmdsZXRvbiBBY2Nlc3NcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGltcG9ydCB7IENsb3VkUmVwb3NpdG9yeSB9IGZyb20gJy4vcGF0aC90by9DbG91ZFJlcG9zaXRvcnknO1xuICpcbiAqIC8vIFVzZSB0aGUgc2luZ2xldG9uIGluc3RhbmNlXG4gKiBjb25zdCBmbG93ID0gYXdhaXQgQ2xvdWRSZXBvc2l0b3J5Lk1haW4uZmV0Y2hGbG93KCdmbG93LWlkJyk7XG4gKiBgYGBcbiAqXG4gKiAjIyMgQ3VzdG9tIEluc3RhbmNlXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiAvLyBDcmVhdGUgYSBjdXN0b20gaW5zdGFuY2Ugd2l0aCBkaWZmZXJlbnQgYmFzZSBVUkxcbiAqIGNvbnN0IGN1c3RvbVJlcG8gPSBuZXcgQ2xvdWRSZXBvc2l0b3J5KCdodHRwczovL2N1c3RvbS1hcGkuZXhhbXBsZS5jb20nKTtcbiAqIGNvbnN0IGZsb3cgPSBhd2FpdCBjdXN0b21SZXBvLmZldGNoRmxvdygnZmxvdy1pZCcpO1xuICogYGBgXG4gKlxuICogIyMjIENvbXBvbmVudCBSZXRyaWV2YWxcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIC8vIEdldCBhIHNwZWNpZmljIGNvbXBvbmVudCBmcm9tIGEgZmxvd1xuICogY29uc3QgY29tcG9uZW50ID0gYXdhaXQgQ2xvdWRSZXBvc2l0b3J5Lk1haW4uZmV0Y2hDb21wb25lbnQoJ2NvbXBvbmVudC1pZCcsICdmbG93LWlkJyk7XG4gKiBgYGBcbiAqXG4gKiAjIyBEZXBlbmRlbmNpZXNcbiAqXG4gKiAtICoqSVVzZXJGbG93Kio6IEludGVyZmFjZSBpbXBvcnRlZCBmcm9tIGAuLi9jb21tb25gIHRoYXQgZGVmaW5lcyB0aGUgc3RydWN0dXJlIG9mIHVzZXIgZmxvdyBvYmplY3RzXG4gKiAtICoqRmV0Y2ggQVBJKio6IFVzZXMgdGhlIG5hdGl2ZSBgZmV0Y2hgIGZ1bmN0aW9uIGZvciBIVFRQIHJlcXVlc3RzXG4gKlxuICogIyMgUGVyZm9ybWFuY2UgQ29uc2lkZXJhdGlvbnNcbiAqXG4gKiAtICoqQ2FjaGluZyoqOiBQcmV2ZW50cyBkdXBsaWNhdGUgQVBJIGNhbGxzIGZvciB0aGUgc2FtZSBmbG93IElEXG4gKiAtICoqUHJvbWlzZSBDYWNoaW5nKio6IEhhbmRsZXMgY29uY3VycmVudCByZXF1ZXN0cyBlZmZpY2llbnRseSBieSBjYWNoaW5nIHByb21pc2VzXG4gKiAtICoqQ29tcG9uZW50IFJlc29sdXRpb24qKjogVGhlIGByZXNvbHZlPWNvbXBvbmVudHNgIHBhcmFtZXRlciBlbnN1cmVzIGNvbXBvbmVudHMgYXJlIGZ1bGx5IHJlc29sdmVkIGluIGEgc2luZ2xlIEFQSSBjYWxsXG4gKlxuICogIyMgRnV0dXJlIEVuaGFuY2VtZW50c1xuICpcbiAqIFRoZSBjbGFzcyBzdHJ1Y3R1cmUgc3VnZ2VzdHMgcGxhbm5lZCBmdW5jdGlvbmFsaXR5IHRoYXQgY291bGQgYmUgaW1wbGVtZW50ZWQ6XG4gKlxuICogLSAqKkNvbXBvbmVudCBDYWNoaW5nKio6IFRoZSBjb21tZW50ZWQgYGNvbXBvbmVudHNgIHByb3BlcnR5IGluZGljYXRlcyBwb3RlbnRpYWwgaW5kaXZpZHVhbCBjb21wb25lbnQgY2FjaGluZ1xuICogLSAqKkNhY2hlIEludmFsaWRhdGlvbioqOiBNZXRob2RzIHRvIGNsZWFyIG9yIHJlZnJlc2ggY2FjaGVkIGRhdGFcbiAqIC0gKipFcnJvciBSZXRyeSBMb2dpYyoqOiBBdXRvbWF0aWMgcmV0cnkgbWVjaGFuaXNtcyBmb3IgZmFpbGVkIHJlcXVlc3RzXG4gKiAtICoqQmF0Y2ggT3BlcmF0aW9ucyoqOiBNZXRob2RzIHRvIGZldGNoIG11bHRpcGxlIGZsb3dzIG9yIGNvbXBvbmVudHMgaW4gYSBzaW5nbGUgcmVxdWVzdFxuICpcbiAqL1xuZXhwb3J0IGNsYXNzIENsb3VkUmVwb3NpdG9yeSB7XG4gICAgc3RhdGljIE1haW4gPSBuZXcgQ2xvdWRSZXBvc2l0b3J5KCk7XG5cbiAgICBwcml2YXRlIHVzZXJGbG93czogUmVjb3JkPHN0cmluZywgUHJvbWlzZTxJVXNlckZsb3c+PiA9IHt9O1xuXG4gICAgLy8gcHJpdmF0ZSBjb21wb25lbnRzOiBSZWNvcmQ8c3RyaW5nLCBQcm9taXNlPElVc2VyRmxvdz4+ID0ge307XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9iYXNlVXJsID0gJ2h0dHBzOi8vY2xvdWQubXlvcC5kZXYnKSB7XG4gICAgfVxuXG4gICAgYXN5bmMgZmV0Y2hDb21wb25lbnQoY29tcG9uZW50SWQ6IHN0cmluZywgZmxvd0lkPzogc3RyaW5nKSB7XG4gICAgICAgIGlmIChmbG93SWQpIHtcbiAgICAgICAgICAgIGNvbnN0IGZsb3cgPSBhd2FpdCB0aGlzLmZldGNoRmxvdyhmbG93SWQpO1xuICAgICAgICAgICAgcmV0dXJuIGZsb3cuY29tcG9uZW50cy5maW5kKGMgPT4gYy50eXBlLmlkID09PSBjb21wb25lbnRJZCk7XG4gICAgICAgIH1lbHNle1xuICAgICAgICAgICAgY29uc3QgZmxvdyA9IGF3YWl0IHRoaXMuZmV0Y2hBdXRvRmxvdyhjb21wb25lbnRJZCk7XG4gICAgICAgICAgICByZXR1cm4gZmxvdy5jb21wb25lbnRzWzBdO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgYXN5bmMgZmV0Y2hBdXRvRmxvdyhjb21wb25lbnRJZDogc3RyaW5nKSB7XG4gICAgICAgIGlmICghdGhpcy51c2VyRmxvd3NbY29tcG9uZW50SWRdKSB7XG4gICAgICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tYXN5bmMtcHJvbWlzZS1leGVjdXRvclxuICAgICAgICAgICAgdGhpcy51c2VyRmxvd3NbY29tcG9uZW50SWRdID0gbmV3IFByb21pc2UoXG4gICAgICAgICAgICAgICAgYXN5bmMgKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3QgcmVzID0gYXdhaXQgZmV0Y2goXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYCR7dGhpcy5fYmFzZVVybH0vZmxvdz9pZD0ke2NvbXBvbmVudElkfSZhdXRvPXRydWVgXG4gICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3QganNvbiA9IGF3YWl0IHJlcy5qc29uKCk7XG4gICAgICAgICAgICAgICAgICAgICAgICByZXNvbHZlKGpzb24uaXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHJlamVjdChlKTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gYXdhaXQgdGhpcy51c2VyRmxvd3NbY29tcG9uZW50SWRdO1xuICAgIH1cblxuXG4gICAgYXN5bmMgZmV0Y2hGbG93KGZsb3dJZDogc3RyaW5nKSB7XG4gICAgICAgIGlmICghdGhpcy51c2VyRmxvd3NbZmxvd0lkXSkge1xuICAgICAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWFzeW5jLXByb21pc2UtZXhlY3V0b3JcbiAgICAgICAgICAgIHRoaXMudXNlckZsb3dzW2Zsb3dJZF0gPSBuZXcgUHJvbWlzZShcbiAgICAgICAgICAgICAgICBhc3luYyAocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBjb25zdCByZXMgPSBhd2FpdCBmZXRjaChcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBgJHt0aGlzLl9iYXNlVXJsfS9mbG93P2lkPSR7Zmxvd0lkfSZyZXNvbHZlPWNvbXBvbmVudHNgXG4gICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3QganNvbiA9IGF3YWl0IHJlcy5qc29uKCk7XG4gICAgICAgICAgICAgICAgICAgICAgICByZXNvbHZlKGpzb24uaXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHJlamVjdChlKTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gYXdhaXQgdGhpcy51c2VyRmxvd3NbZmxvd0lkXTtcbiAgICB9XG59XG4iLCAiZXhwb3J0IGNvbnN0IGV4ZWMgPSBhc3luYyAoZ2V0dGVyOiBhbnkpID0+IHtcbiAgICByZXR1cm4gYXdhaXQgZ2V0dGVyKClcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUdPLElBQU0sU0FBUyxNQUFNO0FBQ3hCLFNBQU8sdUNBQXVDO0FBQUEsSUFBUTtBQUFBLElBQVUsUUFDM0QsQ0FBQyxJQUFJLE9BQU8sZ0JBQWdCLElBQUksV0FBVyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksTUFBTSxDQUFDLElBQUksR0FBRyxTQUFTLEVBQUU7QUFBQSxFQUNsRjtBQUNKOzs7QUNLTyxJQUFlLGtCQUFmLE1BQXdDO0FBQUEsRUFXM0MsY0FBYztBQVZkLDhCQUFLLE9BQU87QUFjWixnQ0FBTztBQUlQO0FBR0E7QUFBQTtBQUNBO0FBRUE7QUFFQTtBQUVBO0FBRUEscUNBQXFCO0FBQUEsRUFsQnJCO0FBQUEsRUFWQSxPQUFPLFVBRUEsTUFDc0I7QUFFekIsV0FBTyxJQUFJLEtBQUssR0FBRyxJQUFJO0FBQUEsRUFDM0I7QUFBQSxFQXdCQSxTQUFTLEtBQStCO0FBQ3BDLFdBQU8s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
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../../src/utils/utils.ts", "../../../src/messages/BaseMessage.ts", "../../../src/messages/ExecuteScriptMessage.ts", "../../../src/messages/CustomRefMessage.ts", "../../../src/helpers/applyStylesheet.ts", "../../../src/helpers/iframeSkinUrlTokenizer.ts", "../../../src/helpers/classList.ts", "../../../src/helpers/configBuilder.ts", "../../../src/helpers/CloudRepository.ts", "../../../src/helpers/exec.ts"],
4
- "sourcesContent": ["export const uuidv4 = () => {\n return \"10000000-1000-4000-8000-100000000000\".replace(/[018]/g, c =>\n (+c ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> +c / 4).toString(16)\n );\n}\n\nexport const wait = (ms: number) => {\n return new Promise(resolve => setTimeout(resolve, ms));\n}", "import {MyopMessageKey} from \"../common/MyopMessages\";\nimport {uuidv4} from \"../utils/utils\";\nimport {IMyopComponent} from \"../host\";\nimport {IRefConfig} from \"../common\";\n\nexport class MessageDirection {\n static down = 'down' as const\n static up = 'up' as const\n}\n\nexport type MessageDirectionOption = 'up' | 'down';\n\nexport abstract class BaseMyopMessage<T = any> {\n id = uuidv4()\n\n static create<T, U extends new (...args: ConstructorParameters<U>) => T = typeof this>(\n this: U,\n ...args: ConstructorParameters<U>\n ): InstanceType<typeof this> {\n // @ts-ignore\n return new this(...args);\n }\n\n constructor() {\n //console.log('meesage id created', this.id, document.location.href);\n }\n\n myop = true\n\n abstract messageType: MyopMessageKey | string;\n\n content?: T\n\n // TODO : cant be optional \n source?: string\n destination?: string\n\n route?: string[]\n\n ref?: Ref\n\n direction?: MessageDirectionOption\n\n cleanable: boolean = false\n\n isTypeof(msg: BaseMyopMessage): boolean {\n return msg.messageType === this.messageType\n }\n}\n\nexport abstract class MyopElementMessage<T = any> extends BaseMyopMessage<T> {\n constructor(public ref: Ref) {\n super()\n }\n}\n\nexport abstract class MyopBindReplayMessage<T = any> extends BaseMyopMessage<T> {\n constructor(public replayToHandler?: string) {\n super();\n }\n}\n\nexport abstract class MyopBindMessage<T = any, R extends MyopBindReplayMessage = any> extends BaseMyopMessage<T> {\n\n public abstract replyMessageKey: MyopMessageKey;\n\n public handlerUniqueId = uuidv4()\n\n constructor(public handler: (message: R) => void) {\n super()\n }\n}\n\nexport class Ref {\n public myop = true;\n\n public __nonProxied?: Ref;\n\n static create(selector: string, refConfig?: IRefConfig, component?: IMyopComponent) {\n let _refConfig = refConfig;\n if (!_refConfig) {\n _refConfig = {\n id: '',\n name: '',\n description: '',\n selectorType: 'id-attribute',\n selector: selector,\n behavior: {\n type: 'code'\n }\n } as IRefConfig\n }\n return new Ref(_refConfig, component);\n }\n\n constructor(public refConfig: IRefConfig, public component?: IMyopComponent) {\n this.__nonProxied = {\n ...this,\n component: null // in order to be serializable\n }\n }\n}\n", "import {MyopBindMessage, MyopBindReplayMessage} from \"./BaseMessage\";\nimport {MyopMessageKey} from \"../common/MyopMessages\";\nimport {RootRef} from \"../common\";\nimport {makeSerializable} from \"../common/utils/serialization.ts\";\n\nconst ReplayMessageKey = 'ExecuteScriptReplyMessage'\n\nconst functionBodyRegex = /(?:function\\s*\\w*\\s*\\([^)]*\\)\\s*\\{([\\s\\S]*?)\\}|(\\([^)]*\\)\\s*=>\\s*\\{([\\s\\S]*?)\\}))\\s*$/;\nconst expressionBodyRegex = /\\(\\s*[^)]+\\s*\\)\\s*=>\\s*(.+)/;\n\nexport const stripFunction = (content: string) => {\n let match = content.match(functionBodyRegex);\n if (match) {\n return match[1] || match[3];\n } else {\n let match = content.match(expressionBodyRegex);\n if (match)\n return match[1].trim();\n }\n}\n\nexport type scriptInputs = {\n [key: string]: string | number | boolean\n} | {};\n\nexport type scriptVars<T> = {\n send: (data: T) => void;\n // completeStream: () => void;\n rootRef: RootRef;\n makeSerializable: typeof makeSerializable\n}\n\nexport type extendedScriptVars<T, I> = {\n [K in keyof I]: I[K];\n} & scriptVars<T>\n\nexport class ExecuteScriptMessage<T = any, I extends scriptInputs = any> extends MyopBindMessage<string, ExecuteScriptReplyMessage<T>> {\n\n replyMessageKey: MyopMessageKey = ReplayMessageKey;\n messageType = 'ExecuteScriptMessage';\n script: string = ''\n\n static replierKey = 'send';\n static completeStreamKey = 'completeStream';\n\n constructor(script: (vars: extendedScriptVars<T, I>) => T, handler: (message: ExecuteScriptReplyMessage<T>) => void = () => {\n }, public scriptInputs?: I) {\n super(handler);\n this.script = script.toString();\n\n //TODO: can be remove\n this.content = script.toString()\n this.content = stripFunction(this.content);\n }\n}\n\nexport class ExecuteScriptReplyMessage<T = any> extends MyopBindReplayMessage<T> {\n\n messageType = ReplayMessageKey;\n\n constructor(public replayToHandler: string, public content: T) {\n super(replayToHandler);\n }\n}\n", "import {\n ExecuteScriptMessage,\n ExecuteScriptReplyMessage,\n extendedScriptVars,\n scriptInputs, stripFunction\n} from \"./ExecuteScriptMessage.ts\";\n\nexport type customRefScriptInputs = {\n elementId: string,\n ref?: HTMLElement,\n _script?: string,\n __scriptInputs?: Object\n};\n\nexport class CustomRefMessage<T = any, I extends scriptInputs = customRefScriptInputs> extends ExecuteScriptMessage<T, I & customRefScriptInputs> {\n\n constructor(script: (vars: extendedScriptVars<T, I & customRefScriptInputs>) => T,\n public scriptInputs: I & customRefScriptInputs,\n handler: (message: ExecuteScriptReplyMessage<T>) => void = () => {\n }) {\n\n //mock vars\n // let rootRef, elementId, _script, __scriptInputs;\n super(({rootRef, elementId, _script, __scriptInputs}) => {\n const refs = (rootRef.shadowRoot || rootRef.container).querySelectorAll(`[${'myop-id'}='${elementId}']`);\n if (refs.length) {\n // const ref = refs[0];\n\n //TODO : think about exposing \"refs\" and not only \"ref\"\n //for cases where the Ref has multiplate implementations\n\n // @ts-ignore\n __scriptInputs.ref = refs[0];\n\n const dynamicFunction = new Function(`return (${_script})(...arguments)`);\n return dynamicFunction(__scriptInputs);\n\n // @ts-ignore\n //return Function('ref', 'rootRef', ...Object.keys(__scriptInputs), _script!)(ref, rootRef, ...Object.values(__scriptInputs))\n }\n return null as T;\n }, handler);\n\n this.scriptInputs = {\n ...scriptInputs,\n //_script: stripFunction(script.toString()),\n _script: script.toString()\n };\n }\n}\n", "import type * as CSS from \"csstype\";\nimport {IMyopComponent} from \"../host\";\nimport {uuidv4} from \"../utils/utils.ts\";\nimport {ExecuteScriptMessage} from \"../messages\";\n\n// ignoring documentation\n/** @ignore */\nexport interface CSSProperties extends CSS.Properties<string | number> {\n}\n\nexport type StylesheetDefinition = { [key: string]: CSSProperties };\n\nexport const applyStylesheet = (component: IMyopComponent, stylesheet: StylesheetDefinition, css?: string) => {\n const tagId = `myop-css-${uuidv4()}`;\n component.send(new ExecuteScriptMessage(({rootRef, _stylesheet, _tagId, _css}) => {\n const styleTag = document.createElement('style');\n styleTag.type = 'text/css';\n\n // Build the CSS string from the styles object\n let cssString = _css;\n\n for (const selector in _stylesheet) {\n cssString += `${selector} { `;\n const properties = _stylesheet[selector];\n for (const property in properties) {\n cssString += `${property}: ${properties[property]}; `;\n }\n cssString += '} ';\n }\n\n // Set the CSS string as the content of the <style> element\n styleTag.appendChild(document.createTextNode(cssString));\n styleTag.id = _tagId;\n // Append the <style> element\n (rootRef.shadowRoot || rootRef.container).appendChild(styleTag);\n\n }, () => {\n }, {\n _stylesheet: stylesheet,\n _css : css ? css : '',\n _tagId: tagId\n }));\n\n return () => {\n component.send(new ExecuteScriptMessage(({rootRef, _tagId}) => {\n const element = (rootRef.shadowRoot || document).getElementById(_tagId);\n if (element) {\n element.remove();\n }\n }, () => {\n }, {\n _tagId: tagId\n }))\n }\n}\n\nexport const applyStylesheetLink = (component: IMyopComponent, link: string) => {\n const tagId = `myop-css-${uuidv4()}`;\n component.send(new ExecuteScriptMessage(({rootRef, _tagId, _link}) => {\n const linkElement = document.createElement('link');\n linkElement.id = _tagId;\n linkElement.rel = 'stylesheet';\n linkElement.href = _link;\n document.head.appendChild(linkElement);\n\n // Append the <style> element\n (rootRef.shadowRoot || rootRef.container).appendChild(linkElement);\n }, () => {\n }, {\n _link : link,\n _tagId: tagId\n }));\n\n return () => {\n component.send(new ExecuteScriptMessage(({rootRef, _tagId}) => {\n const element = (rootRef.shadowRoot || document).getElementById(_tagId);\n if (element) {\n element.remove();\n }\n }, () => {\n }, {\n _tagId: tagId\n }))\n }\n}\n", "import {IIframeLoaderConfig, ISkinConfig} from \"../common\";\n\nexport type TokenMap = Record<string, string| number>\n\nconst replaceTokens = (input: string, tokenMap: TokenMap): string => {\n // Create a regex pattern from the keys of the tokenMap\n const pattern = new RegExp(Object.keys(tokenMap).join('|'), 'g');\n\n // Replace tokens in the input string using the regex\n return input.replace(pattern, (matched) => {\n // Return the replacement value from the tokenMap\n return (tokenMap[matched] || matched).toString();\n });\n}\n\nexport const createIframeSkinByTokenizer = (selectedSkin: ISkinConfig, tokenMap: TokenMap) => {\n const typedSkinConfig = (selectedSkin.loader as IIframeLoaderConfig)\n if (typedSkinConfig.type !== 'IframeLoader') {\n throw new Error(`iframeSkinUrlTokenizer received skin with loader type \"${typedSkinConfig.type}\", currently only \"IframeLoader\" is supported`)\n }\n\n selectedSkin.loader = {\n ...selectedSkin.loader\n }\n\n selectedSkin.loader.url = replaceTokens(selectedSkin.loader.url, tokenMap);\n\n return selectedSkin;\n}\n\nexport const changeSkinUrlByTokenizer = (tokenMap: TokenMap) => {\n return async (selectedSkin: ISkinConfig) => {\n return createIframeSkinByTokenizer(selectedSkin, tokenMap);\n }\n}", "import {CustomRefMessage} from \"../messages\";\nimport {IMyopComponent} from \"../host\";\n\n// const space = ' ';\n// export const getClasses = async (connectedRef: Ref): Promise<string[]> => (await exec(actAs<HTMLDivElement>(connectedRef).classList)).value.split(space);\n// export const addClass = async (connectedRef: Ref, className: string) => {\n// const classes = await getClasses(connectedRef);\n// classes.includes(className) || classes.push(className);\n// // @ts-ignore\n// connectedRef.classList = classes.join(space);\n// }\n// export const removeClass = async (connectedRef: Ref, className: string,) => {\n// let classes = await getClasses(connectedRef);\n// // @ts-ignore\n// connectedRef.classList = classes.filter(c => c !== className).join(space);\n// }\n//\n//\n\nexport const addClass = (component: IMyopComponent, className: string, myopId: string) => {\n component.send(new CustomRefMessage(({ref, _className}) => {\n ref?.classList.add(_className);\n }, {\n elementId: myopId,\n _className: className\n }));\n}\n\nexport const removeClass = (component: IMyopComponent, className: string, myopId: string) => {\n component.send(new CustomRefMessage(({ref, _className}) => {\n ref?.classList.remove(_className);\n }, {\n elementId: myopId,\n _className: className\n }));\n}", "import {\n IComponentConfig,\n IComponentDefinitionConfig,\n IComponentInstanceConfig, IHTMLLoaderConfig, IRefConfig,\n ISkinLoaderConfig,\n ISkinSelectorConfig,\n IDedicatedSkinConfig, ISkinConfig\n} from \"../common\";\nimport {uuidv4} from \"../utils/utils.ts\";\n\nexport class SkinConfig implements ISkinConfig {\n _runTimeInstanceId = 'runtime-instance-id-' + uuidv4();\n _runTimeId = 'runtime-id-' + uuidv4();\n _runTimeName = 'runtime-name-' + uuidv4();\n\n static create = () => {\n return new SkinConfig();\n }\n\n id = this._runTimeId;\n name = this._runTimeName;\n description = '';\n loader = null as unknown as ISkinLoaderConfig;\n\n withLoader = (loader: ISkinLoaderConfig) => {\n this.loader = loader;\n return this;\n }\n\n withHTMLLoader = (loader: Omit<IHTMLLoaderConfig, 'type'>) => {\n loader.type = 'HTMLLoader';\n this.loader = loader as IHTMLLoaderConfig;\n return this;\n }\n\n build = () => {\n return this;\n }\n}\n\nexport class ComponentConfig implements IComponentConfig {\n _runTimeInstanceId = 'runtime-instance-id-' + uuidv4();\n _runTimeId = 'runtime-id-' + uuidv4();\n _runTimeName = 'runtime-name-' + uuidv4();\n\n static create = () => {\n return new ComponentConfig();\n }\n\n instance = {\n id: this._runTimeInstanceId,\n componentId: this._runTimeId,\n componentName: this._runTimeName,\n skinSelector: null as unknown as ISkinSelectorConfig\n } as IComponentInstanceConfig;\n\n name = this._runTimeName\n type = {\n id: this._runTimeId,\n name: this._runTimeName,\n description: '',\n props: [],\n refs: [],\n skins: [],\n defaultSkin: 0\n } as IComponentDefinitionConfig\n\n withInstance = (instance: IComponentInstanceConfig) => {\n this.instance = instance;\n return this;\n }\n\n withType = (type: IComponentDefinitionConfig) => {\n this.type = type;\n return this;\n }\n\n withName = (name: string) => {\n this.name = name;\n return this;\n }\n\n withDefaultSkin = (defaultSkin: ISkinConfig) => {\n this.type.skins.push(defaultSkin);\n this.type.defaultSkin = this.type.skins.length - 1;\n this.instance.skinSelector = {\n type: 'Dedicated',\n skin: {\n id: defaultSkin.id\n }\n } as IDedicatedSkinConfig\n\n return this;\n }\n\n withRef = (ref: IRefConfig) => {\n this.type.refs.push(ref);\n return this;\n }\n\n withBasicRef = (refSelector: string) => {\n const newBasicRef = {\n id: '',\n name: refSelector,\n description: '',\n selectorType: 'id-attribute',\n selector: refSelector,\n behavior: {\n type: 'code'\n }\n } as IRefConfig\n\n this.type.refs.push(newBasicRef);\n return this;\n }\n\n build = () => {\n return JSON.parse(JSON.stringify(this))\n }\n}\n", "import {IUserFlow} from \"../common\";\n\n/**\n *\n * ## Overview\n *\n * The `CloudRepository` class serves as a centralized data access layer for retrieving user flows and components from the Myop.dev cloud service. It implements a singleton pattern and provides caching mechanisms to optimize API calls and improve performance.\n *\n * ## Class Structure\n *\n * ### Constructor\n *\n * ```typescript\n * constructor(private _baseUrl = 'https://cloud.myop.dev')\n * ```\n *\n * **Parameters:**\n * - `_baseUrl` (optional): The base URL for the Myop.dev cloud API. Defaults to `'https://cloud.myop.dev'`\n *\n * ### Static Properties\n *\n * #### Main\n * ```typescript\n * static Main = new CloudRepository();\n * ```\n *\n * A singleton instance of the `CloudRepository` class that can be used throughout the application without creating multiple instances.\n *\n * ### Private Properties\n *\n * #### userFlows\n * ```typescript\n * private userFlows: Record<string, Promise<IUserFlow>> = {};\n * ```\n *\n * A cache object that stores promises for user flows, indexed by flow ID. This prevents duplicate API calls for the same flow and ensures consistent data retrieval.\n *\n * #### _baseUrl\n * ```typescript\n * private _baseUrl: string\n * ```\n *\n * The base URL for the cloud API endpoints, set during construction.\n *\n * ## Methods\n *\n * ### fetchFlow(flowId: string)\n *\n * Retrieves a complete user flow from the cloud repository, including all resolved components.\n *\n * **Parameters:**\n * - `flowId`: The unique identifier for the user flow to retrieve\n *\n * **Returns:**\n * - `Promise<IUserFlow>`: A promise that resolves to the complete user flow object\n *\n * **Behavior:**\n * - Implements request caching to avoid duplicate API calls for the same flow ID\n * - Makes a GET request to `/flow?id={flowId}&resolve=components`\n * - Automatically resolves component references within the flow\n * - Stores the promise in the cache for future use\n *\n * **Example Usage:**\n * ```typescript\n * const flow = await CloudRepository.Main.fetchFlow('my-flow-id');\n * console.log(flow.components);\n * ```\n *\n * ### fetchComponent(componentId: string, flowId: string)\n *\n * Retrieves a specific component from within a user flow.\n *\n * **Parameters:**\n * - `componentId`: The unique identifier for the component to retrieve\n * - `flowId`: The unique identifier for the user flow containing the component\n *\n * **Returns:**\n * - `Promise<Component | undefined>`: A promise that resolves to the component object if found, or undefined if not found\n *\n * **Behavior:**\n * - First fetches the complete flow using `fetchFlow()`\n * - Searches through the flow's components array to find the matching component\n * - Uses the component's `type.id` property for matching\n *\n * **Example Usage:**\n * ```typescript\n * const component = await CloudRepository.Main.fetchComponent('button-component', 'my-flow-id');\n * if (component) {\n * console.log('Component found:', component);\n * } else {\n * console.log('Component not found in flow');\n * }\n * ```\n *\n * ## API Integration\n *\n * ### Endpoint Structure\n *\n * The class integrates with the following Myop.dev cloud API endpoint:\n *\n * ```\n * GET {baseUrl}/flow?id={flowId}&resolve=components\n * ```\n *\n * **Query Parameters:**\n * - `id`: The flow identifier\n * - `resolve=components`: Instructs the API to include resolved component data in the response\n *\n * ### Response Format\n *\n * The API is expected to return a JSON response with the following structure:\n *\n * ```json\n * {\n * \"item\": {\n * // IUserFlow object with resolved components\n * \"components\": [\n * {\n * \"type\": {\n * \"id\": \"component-id\"\n * }\n * // ... other component properties\n * }\n * ]\n * // ... other flow properties\n * }\n * }\n * ```\n *\n * ## Caching Strategy\n *\n * The `CloudRepository` implements a promise-based caching mechanism:\n *\n * 1. **Cache Key**: Flow ID is used as the cache key\n * 2. **Cache Value**: Promises are cached rather than resolved values to handle concurrent requests\n * 3. **Cache Duration**: Cache persists for the lifetime of the repository instance\n * 4. **Cache Invalidation**: No automatic cache invalidation is implemented\n *\n * ## Error Handling\n *\n * - Network errors and API failures are propagated through promise rejection\n * - No specific error handling or retry logic is implemented at the repository level\n * - Consumers should implement appropriate error handling when calling repository methods\n *\n * ## Usage Patterns\n *\n * ### Singleton Access\n * ```typescript\n * import { CloudRepository } from './path/to/CloudRepository';\n *\n * // Use the singleton instance\n * const flow = await CloudRepository.Main.fetchFlow('flow-id');\n * ```\n *\n * ### Custom Instance\n * ```typescript\n * // Create a custom instance with different base URL\n * const customRepo = new CloudRepository('https://custom-api.example.com');\n * const flow = await customRepo.fetchFlow('flow-id');\n * ```\n *\n * ### Component Retrieval\n * ```typescript\n * // Get a specific component from a flow\n * const component = await CloudRepository.Main.fetchComponent('component-id', 'flow-id');\n * ```\n *\n * ## Dependencies\n *\n * - **IUserFlow**: Interface imported from `../common` that defines the structure of user flow objects\n * - **Fetch API**: Uses the native `fetch` function for HTTP requests\n *\n * ## Performance Considerations\n *\n * - **Caching**: Prevents duplicate API calls for the same flow ID\n * - **Promise Caching**: Handles concurrent requests efficiently by caching promises\n * - **Component Resolution**: The `resolve=components` parameter ensures components are fully resolved in a single API call\n *\n * ## Future Enhancements\n *\n * The class structure suggests planned functionality that could be implemented:\n *\n * - **Component Caching**: The commented `components` property indicates potential individual component caching\n * - **Cache Invalidation**: Methods to clear or refresh cached data\n * - **Error Retry Logic**: Automatic retry mechanisms for failed requests\n * - **Batch Operations**: Methods to fetch multiple flows or components in a single request\n *\n */\nexport class CloudRepository {\n static Main = new CloudRepository();\n\n private userFlows: Record<string, Promise<IUserFlow>> = {};\n\n // private components: Record<string, Promise<IUserFlow>> = {};\n\n constructor(private _baseUrl = 'https://cloud.myop.dev') {\n }\n\n async fetchComponent(componentId: string, flowId?: string) {\n if (flowId) {\n const flow = await this.fetchFlow(flowId);\n return flow.components.find(c => c.type.id === componentId);\n }else{\n const flow = await this.fetchAutoFlow(componentId);\n return flow.components[0];\n }\n }\n\n async fetchAutoFlow(componentId: string) {\n if (!this.userFlows[componentId]) {\n // eslint-disable-next-line no-async-promise-executor\n this.userFlows[componentId] = new Promise(\n async (resolve, reject) => {\n try {\n const res = await fetch(\n `${this._baseUrl}/flow?id=${componentId}&auto=true`\n );\n const json = await res.json();\n resolve(json.item);\n } catch (e) {\n reject(e);\n }\n }\n );\n }\n\n return await this.userFlows[componentId];\n }\n\n\n async fetchFlow(flowId: string) {\n if (!this.userFlows[flowId]) {\n // eslint-disable-next-line no-async-promise-executor\n this.userFlows[flowId] = new Promise(\n async (resolve, reject) => {\n try {\n const res = await fetch(\n `${this._baseUrl}/flow?id=${flowId}&resolve=components`\n );\n const json = await res.json();\n resolve(json.item);\n } catch (e) {\n reject(e);\n }\n }\n );\n }\n\n return await this.userFlows[flowId];\n }\n}\n", "export const exec = async (getter: any) => {\n return await getter()\n}\n"],
5
- "mappings": "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",
3
+ "sources": ["../../../src/utils/uuid.ts", "../../../src/messages/BaseMessage.ts", "../../../src/messages/ExecuteScriptMessage.ts", "../../../src/messages/CustomRefMessage.ts", "../../../src/helpers/applyStylesheet.ts", "../../../src/helpers/iframeSkinUrlTokenizer.ts", "../../../src/helpers/classList.ts", "../../../src/helpers/configBuilder.ts", "../../../src/helpers/CloudRepository.ts", "../../../src/helpers/exec.ts"],
4
+ "sourcesContent": ["//TODO : reuse from one place.\n// needs to be used in myop-sdk, myop-dashbaord, myop-server, myop-cli ..\n\nexport const uuidv4 = () => {\n return \"10000000-1000-4000-8000-100000000000\".replace(/[018]/g, c =>\n (+c ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> +c / 4).toString(16)\n );\n}\n\n// Convert UUID string to bytes\nexport const uuidToBytes = (uuid: string): Uint8Array => {\n return Uint8Array.from(\n uuid.replace(/-/g, '').match(/.{1,2}/g)!.map(byte => parseInt(byte, 16))\n );\n};\n\n// Convert bytes to UUID string\nexport const bytesToUuid = (bytes: Uint8Array): string => {\n const hex = [...bytes].map(b => b.toString(16).padStart(2, '0')).join('');\n return [\n hex.slice(0, 8),\n hex.slice(8, 12),\n hex.slice(12, 16),\n hex.slice(16, 20),\n hex.slice(20)\n ].join('-');\n};\n\n// Base64 URL-safe encode\nexport const base64UrlEncode = (bytes: Uint8Array): string => {\n const base64 = btoa(String.fromCharCode(...bytes));\n return base64.replace(/\\+/g, '-').replace(/\\//g, '_').replace(/=+$/, '');\n};\n\n// Base64 URL-safe decode\nexport const base64UrlDecode = (str: string): Uint8Array => {\n let base64 = str.replace(/-/g, '+').replace(/_/g, '/');\n while (base64.length % 4) base64 += '=';\n const binary = atob(base64);\n return Uint8Array.from(binary, char => char.charCodeAt(0));\n};\n\n// Compress an array of UUIDs into a short URL-safe string\nexport const compressUUIDs = (uuids: string[]): string => {\n const allBytes = uuids.flatMap(uuid => Array.from(uuidToBytes(uuid)));\n return base64UrlEncode(new Uint8Array(allBytes));\n};\n\n// Decompress from URL-safe string back to an array of UUIDs\nexport const decompressUUIDs = (encoded: string): string[] => {\n const bytes = base64UrlDecode(encoded);\n if (bytes.length % 16 !== 0) throw new Error('Invalid input length');\n\n const uuids: string[] = [];\n for (let i = 0; i < bytes.length; i += 16) {\n uuids.push(bytesToUuid(bytes.slice(i, i + 16)));\n }\n return uuids;\n};\n", "import {MyopMessageKey} from \"../common/MyopMessages\";\nimport {uuidv4} from \"../utils/utils\";\nimport {IMyopComponent} from \"../host\";\nimport {IRefConfig} from \"../common\";\n\nexport class MessageDirection {\n static down = 'down' as const\n static up = 'up' as const\n}\n\nexport type MessageDirectionOption = 'up' | 'down';\n\nexport abstract class BaseMyopMessage<T = any> {\n id = uuidv4()\n\n static create<T, U extends new (...args: ConstructorParameters<U>) => T = typeof this>(\n this: U,\n ...args: ConstructorParameters<U>\n ): InstanceType<typeof this> {\n // @ts-ignore\n return new this(...args);\n }\n\n constructor() {\n //console.log('meesage id created', this.id, document.location.href);\n }\n\n myop = true\n\n abstract messageType: MyopMessageKey | string;\n\n content?: T\n\n // TODO : cant be optional \n source?: string\n destination?: string\n\n route?: string[]\n\n ref?: Ref\n\n direction?: MessageDirectionOption\n\n cleanable: boolean = false\n\n isTypeof(msg: BaseMyopMessage): boolean {\n return msg.messageType === this.messageType\n }\n}\n\nexport abstract class MyopElementMessage<T = any> extends BaseMyopMessage<T> {\n constructor(public ref: Ref) {\n super()\n }\n}\n\nexport abstract class MyopBindReplayMessage<T = any> extends BaseMyopMessage<T> {\n constructor(public replayToHandler?: string) {\n super();\n }\n}\n\nexport abstract class MyopBindMessage<T = any, R extends MyopBindReplayMessage = any> extends BaseMyopMessage<T> {\n\n public abstract replyMessageKey: MyopMessageKey;\n\n public handlerUniqueId = uuidv4()\n\n constructor(public handler: (message: R) => void) {\n super()\n }\n}\n\nexport class Ref {\n public myop = true;\n\n public __nonProxied?: Ref;\n\n static create(selector: string, refConfig?: IRefConfig, component?: IMyopComponent) {\n let _refConfig = refConfig;\n if (!_refConfig) {\n _refConfig = {\n id: '',\n name: '',\n description: '',\n selectorType: 'id-attribute',\n selector: selector,\n behavior: {\n type: 'code'\n }\n } as IRefConfig\n }\n return new Ref(_refConfig, component);\n }\n\n constructor(public refConfig: IRefConfig, public component?: IMyopComponent) {\n this.__nonProxied = {\n ...this,\n component: null // in order to be serializable\n }\n }\n}\n", "import {MyopBindMessage, MyopBindReplayMessage} from \"./BaseMessage\";\nimport {MyopMessageKey} from \"../common/MyopMessages\";\nimport {RootRef} from \"../common\";\nimport {makeSerializable} from \"../common/utils/serialization.ts\";\n\nconst ReplayMessageKey = 'ExecuteScriptReplyMessage'\n\nconst functionBodyRegex = /(?:function\\s*\\w*\\s*\\([^)]*\\)\\s*\\{([\\s\\S]*?)\\}|(\\([^)]*\\)\\s*=>\\s*\\{([\\s\\S]*?)\\}))\\s*$/;\nconst expressionBodyRegex = /\\(\\s*[^)]+\\s*\\)\\s*=>\\s*(.+)/;\n\nexport const stripFunction = (content: string) => {\n let match = content.match(functionBodyRegex);\n if (match) {\n return match[1] || match[3];\n } else {\n let match = content.match(expressionBodyRegex);\n if (match)\n return match[1].trim();\n }\n}\n\nexport type scriptInputs = {\n [key: string]: string | number | boolean\n} | {};\n\nexport type scriptVars<T> = {\n send: (data: T) => void;\n // completeStream: () => void;\n rootRef: RootRef;\n makeSerializable: typeof makeSerializable\n}\n\nexport type extendedScriptVars<T, I> = {\n [K in keyof I]: I[K];\n} & scriptVars<T>\n\nexport class ExecuteScriptMessage<T = any, I extends scriptInputs = any> extends MyopBindMessage<string, ExecuteScriptReplyMessage<T>> {\n\n replyMessageKey: MyopMessageKey = ReplayMessageKey;\n messageType = 'ExecuteScriptMessage';\n script: string = ''\n\n static replierKey = 'send';\n static completeStreamKey = 'completeStream';\n\n constructor(script: (vars: extendedScriptVars<T, I>) => T, handler: (message: ExecuteScriptReplyMessage<T>) => void = () => {\n }, public scriptInputs?: I) {\n super(handler);\n this.script = script.toString();\n\n //TODO: can be remove\n this.content = script.toString()\n this.content = stripFunction(this.content);\n }\n}\n\nexport class ExecuteScriptReplyMessage<T = any> extends MyopBindReplayMessage<T> {\n\n messageType = ReplayMessageKey;\n\n constructor(public replayToHandler: string, public content: T) {\n super(replayToHandler);\n }\n}\n", "import {\n ExecuteScriptMessage,\n ExecuteScriptReplyMessage,\n extendedScriptVars,\n scriptInputs, stripFunction\n} from \"./ExecuteScriptMessage.ts\";\n\nexport type customRefScriptInputs = {\n elementId: string,\n ref?: HTMLElement,\n _script?: string,\n __scriptInputs?: Object\n};\n\nexport class CustomRefMessage<T = any, I extends scriptInputs = customRefScriptInputs> extends ExecuteScriptMessage<T, I & customRefScriptInputs> {\n\n constructor(script: (vars: extendedScriptVars<T, I & customRefScriptInputs>) => T,\n public scriptInputs: I & customRefScriptInputs,\n handler: (message: ExecuteScriptReplyMessage<T>) => void = () => {\n }) {\n\n //mock vars\n // let rootRef, elementId, _script, __scriptInputs;\n super(({rootRef, elementId, _script, __scriptInputs}) => {\n const refs = (rootRef.shadowRoot || rootRef.container).querySelectorAll(`[${'myop-id'}='${elementId}']`);\n if (refs.length) {\n // const ref = refs[0];\n\n //TODO : think about exposing \"refs\" and not only \"ref\"\n //for cases where the Ref has multiplate implementations\n\n // @ts-ignore\n __scriptInputs.ref = refs[0];\n\n const dynamicFunction = new Function(`return (${_script})(...arguments)`);\n return dynamicFunction(__scriptInputs);\n\n // @ts-ignore\n //return Function('ref', 'rootRef', ...Object.keys(__scriptInputs), _script!)(ref, rootRef, ...Object.values(__scriptInputs))\n }\n return null as T;\n }, handler);\n\n this.scriptInputs = {\n ...scriptInputs,\n //_script: stripFunction(script.toString()),\n _script: script.toString()\n };\n }\n}\n", "import type * as CSS from \"csstype\";\nimport {IMyopComponent} from \"../host\";\nimport {uuidv4} from \"../utils/utils.ts\";\nimport {ExecuteScriptMessage} from \"../messages\";\n\n// ignoring documentation\n/** @ignore */\nexport interface CSSProperties extends CSS.Properties<string | number> {\n}\n\nexport type StylesheetDefinition = { [key: string]: CSSProperties };\n\nexport const applyStylesheet = (component: IMyopComponent, stylesheet: StylesheetDefinition, css?: string) => {\n const tagId = `myop-css-${uuidv4()}`;\n component.send(new ExecuteScriptMessage(({rootRef, _stylesheet, _tagId, _css}) => {\n const styleTag = document.createElement('style');\n styleTag.type = 'text/css';\n\n // Build the CSS string from the styles object\n let cssString = _css;\n\n for (const selector in _stylesheet) {\n cssString += `${selector} { `;\n const properties = _stylesheet[selector];\n for (const property in properties) {\n cssString += `${property}: ${properties[property]}; `;\n }\n cssString += '} ';\n }\n\n // Set the CSS string as the content of the <style> element\n styleTag.appendChild(document.createTextNode(cssString));\n styleTag.id = _tagId;\n // Append the <style> element\n (rootRef.shadowRoot || rootRef.container).appendChild(styleTag);\n\n }, () => {\n }, {\n _stylesheet: stylesheet,\n _css : css ? css : '',\n _tagId: tagId\n }));\n\n return () => {\n component.send(new ExecuteScriptMessage(({rootRef, _tagId}) => {\n const element = (rootRef.shadowRoot || document).getElementById(_tagId);\n if (element) {\n element.remove();\n }\n }, () => {\n }, {\n _tagId: tagId\n }))\n }\n}\n\nexport const applyStylesheetLink = (component: IMyopComponent, link: string) => {\n const tagId = `myop-css-${uuidv4()}`;\n component.send(new ExecuteScriptMessage(({rootRef, _tagId, _link}) => {\n const linkElement = document.createElement('link');\n linkElement.id = _tagId;\n linkElement.rel = 'stylesheet';\n linkElement.href = _link;\n document.head.appendChild(linkElement);\n\n // Append the <style> element\n (rootRef.shadowRoot || rootRef.container).appendChild(linkElement);\n }, () => {\n }, {\n _link : link,\n _tagId: tagId\n }));\n\n return () => {\n component.send(new ExecuteScriptMessage(({rootRef, _tagId}) => {\n const element = (rootRef.shadowRoot || document).getElementById(_tagId);\n if (element) {\n element.remove();\n }\n }, () => {\n }, {\n _tagId: tagId\n }))\n }\n}\n", "import {IIframeLoaderConfig, ISkinConfig} from \"../common\";\n\nexport type TokenMap = Record<string, string| number>\n\nconst replaceTokens = (input: string, tokenMap: TokenMap): string => {\n // Create a regex pattern from the keys of the tokenMap\n const pattern = new RegExp(Object.keys(tokenMap).join('|'), 'g');\n\n // Replace tokens in the input string using the regex\n return input.replace(pattern, (matched) => {\n // Return the replacement value from the tokenMap\n return (tokenMap[matched] || matched).toString();\n });\n}\n\nexport const createIframeSkinByTokenizer = (selectedSkin: ISkinConfig, tokenMap: TokenMap) => {\n const typedSkinConfig = (selectedSkin.loader as IIframeLoaderConfig)\n if (typedSkinConfig.type !== 'IframeLoader') {\n throw new Error(`iframeSkinUrlTokenizer received skin with loader type \"${typedSkinConfig.type}\", currently only \"IframeLoader\" is supported`)\n }\n\n selectedSkin.loader = {\n ...selectedSkin.loader\n }\n\n selectedSkin.loader.url = replaceTokens(selectedSkin.loader.url, tokenMap);\n\n return selectedSkin;\n}\n\nexport const changeSkinUrlByTokenizer = (tokenMap: TokenMap) => {\n return async (selectedSkin: ISkinConfig) => {\n return createIframeSkinByTokenizer(selectedSkin, tokenMap);\n }\n}", "import {CustomRefMessage} from \"../messages\";\nimport {IMyopComponent} from \"../host\";\n\n// const space = ' ';\n// export const getClasses = async (connectedRef: Ref): Promise<string[]> => (await exec(actAs<HTMLDivElement>(connectedRef).classList)).value.split(space);\n// export const addClass = async (connectedRef: Ref, className: string) => {\n// const classes = await getClasses(connectedRef);\n// classes.includes(className) || classes.push(className);\n// // @ts-ignore\n// connectedRef.classList = classes.join(space);\n// }\n// export const removeClass = async (connectedRef: Ref, className: string,) => {\n// let classes = await getClasses(connectedRef);\n// // @ts-ignore\n// connectedRef.classList = classes.filter(c => c !== className).join(space);\n// }\n//\n//\n\nexport const addClass = (component: IMyopComponent, className: string, myopId: string) => {\n component.send(new CustomRefMessage(({ref, _className}) => {\n ref?.classList.add(_className);\n }, {\n elementId: myopId,\n _className: className\n }));\n}\n\nexport const removeClass = (component: IMyopComponent, className: string, myopId: string) => {\n component.send(new CustomRefMessage(({ref, _className}) => {\n ref?.classList.remove(_className);\n }, {\n elementId: myopId,\n _className: className\n }));\n}", "import {\n IComponentConfig,\n IComponentDefinitionConfig,\n IComponentInstanceConfig, IHTMLLoaderConfig, IRefConfig,\n ISkinLoaderConfig,\n ISkinSelectorConfig,\n IDedicatedSkinConfig, ISkinConfig\n} from \"../common\";\nimport {uuidv4} from \"../utils/utils.ts\";\n\nexport class SkinConfig implements ISkinConfig {\n _runTimeInstanceId = 'runtime-instance-id-' + uuidv4();\n _runTimeId = 'runtime-id-' + uuidv4();\n _runTimeName = 'runtime-name-' + uuidv4();\n\n static create = () => {\n return new SkinConfig();\n }\n\n id = this._runTimeId;\n name = this._runTimeName;\n description = '';\n loader = null as unknown as ISkinLoaderConfig;\n\n withLoader = (loader: ISkinLoaderConfig) => {\n this.loader = loader;\n return this;\n }\n\n withHTMLLoader = (loader: Omit<IHTMLLoaderConfig, 'type'>) => {\n loader.type = 'HTMLLoader';\n this.loader = loader as IHTMLLoaderConfig;\n return this;\n }\n\n build = () => {\n return this;\n }\n}\n\nexport class ComponentConfig implements IComponentConfig {\n _runTimeInstanceId = 'runtime-instance-id-' + uuidv4();\n _runTimeId = 'runtime-id-' + uuidv4();\n _runTimeName = 'runtime-name-' + uuidv4();\n\n static create = () => {\n return new ComponentConfig();\n }\n\n instance = {\n id: this._runTimeInstanceId,\n componentId: this._runTimeId,\n componentName: this._runTimeName,\n skinSelector: null as unknown as ISkinSelectorConfig\n } as IComponentInstanceConfig;\n\n name = this._runTimeName\n type = {\n id: this._runTimeId,\n name: this._runTimeName,\n description: '',\n props: [],\n refs: [],\n skins: [],\n defaultSkin: 0\n } as IComponentDefinitionConfig\n\n withInstance = (instance: IComponentInstanceConfig) => {\n this.instance = instance;\n return this;\n }\n\n withType = (type: IComponentDefinitionConfig) => {\n this.type = type;\n return this;\n }\n\n withName = (name: string) => {\n this.name = name;\n return this;\n }\n\n withDefaultSkin = (defaultSkin: ISkinConfig) => {\n this.type.skins.push(defaultSkin);\n this.type.defaultSkin = this.type.skins.length - 1;\n this.instance.skinSelector = {\n type: 'Dedicated',\n skin: {\n id: defaultSkin.id\n }\n } as IDedicatedSkinConfig\n\n return this;\n }\n\n withRef = (ref: IRefConfig) => {\n this.type.refs.push(ref);\n return this;\n }\n\n withBasicRef = (refSelector: string) => {\n const newBasicRef = {\n id: '',\n name: refSelector,\n description: '',\n selectorType: 'id-attribute',\n selector: refSelector,\n behavior: {\n type: 'code'\n }\n } as IRefConfig\n\n this.type.refs.push(newBasicRef);\n return this;\n }\n\n build = () => {\n return JSON.parse(JSON.stringify(this))\n }\n}\n", "import {IUserFlow} from \"../common\";\n\n/**\n *\n * ## Overview\n *\n * The `CloudRepository` class serves as a centralized data access layer for retrieving user flows and components from the Myop.dev cloud service. It implements a singleton pattern and provides caching mechanisms to optimize API calls and improve performance.\n *\n * ## Class Structure\n *\n * ### Constructor\n *\n * ```typescript\n * constructor(private _baseUrl = 'https://cloud.myop.dev')\n * ```\n *\n * **Parameters:**\n * - `_baseUrl` (optional): The base URL for the Myop.dev cloud API. Defaults to `'https://cloud.myop.dev'`\n *\n * ### Static Properties\n *\n * #### Main\n * ```typescript\n * static Main = new CloudRepository();\n * ```\n *\n * A singleton instance of the `CloudRepository` class that can be used throughout the application without creating multiple instances.\n *\n * ### Private Properties\n *\n * #### userFlows\n * ```typescript\n * private userFlows: Record<string, Promise<IUserFlow>> = {};\n * ```\n *\n * A cache object that stores promises for user flows, indexed by flow ID. This prevents duplicate API calls for the same flow and ensures consistent data retrieval.\n *\n * #### _baseUrl\n * ```typescript\n * private _baseUrl: string\n * ```\n *\n * The base URL for the cloud API endpoints, set during construction.\n *\n * ## Methods\n *\n * ### fetchFlow(flowId: string)\n *\n * Retrieves a complete user flow from the cloud repository, including all resolved components.\n *\n * **Parameters:**\n * - `flowId`: The unique identifier for the user flow to retrieve\n *\n * **Returns:**\n * - `Promise<IUserFlow>`: A promise that resolves to the complete user flow object\n *\n * **Behavior:**\n * - Implements request caching to avoid duplicate API calls for the same flow ID\n * - Makes a GET request to `/flow?id={flowId}&resolve=components`\n * - Automatically resolves component references within the flow\n * - Stores the promise in the cache for future use\n *\n * **Example Usage:**\n * ```typescript\n * const flow = await CloudRepository.Main.fetchFlow('my-flow-id');\n * console.log(flow.components);\n * ```\n *\n * ### fetchComponent(componentId: string, flowId: string)\n *\n * Retrieves a specific component from within a user flow.\n *\n * **Parameters:**\n * - `componentId`: The unique identifier for the component to retrieve\n * - `flowId`: The unique identifier for the user flow containing the component\n *\n * **Returns:**\n * - `Promise<Component | undefined>`: A promise that resolves to the component object if found, or undefined if not found\n *\n * **Behavior:**\n * - First fetches the complete flow using `fetchFlow()`\n * - Searches through the flow's components array to find the matching component\n * - Uses the component's `type.id` property for matching\n *\n * **Example Usage:**\n * ```typescript\n * const component = await CloudRepository.Main.fetchComponent('button-component', 'my-flow-id');\n * if (component) {\n * console.log('Component found:', component);\n * } else {\n * console.log('Component not found in flow');\n * }\n * ```\n *\n * ## API Integration\n *\n * ### Endpoint Structure\n *\n * The class integrates with the following Myop.dev cloud API endpoint:\n *\n * ```\n * GET {baseUrl}/flow?id={flowId}&resolve=components\n * ```\n *\n * **Query Parameters:**\n * - `id`: The flow identifier\n * - `resolve=components`: Instructs the API to include resolved component data in the response\n *\n * ### Response Format\n *\n * The API is expected to return a JSON response with the following structure:\n *\n * ```json\n * {\n * \"item\": {\n * // IUserFlow object with resolved components\n * \"components\": [\n * {\n * \"type\": {\n * \"id\": \"component-id\"\n * }\n * // ... other component properties\n * }\n * ]\n * // ... other flow properties\n * }\n * }\n * ```\n *\n * ## Caching Strategy\n *\n * The `CloudRepository` implements a promise-based caching mechanism:\n *\n * 1. **Cache Key**: Flow ID is used as the cache key\n * 2. **Cache Value**: Promises are cached rather than resolved values to handle concurrent requests\n * 3. **Cache Duration**: Cache persists for the lifetime of the repository instance\n * 4. **Cache Invalidation**: No automatic cache invalidation is implemented\n *\n * ## Error Handling\n *\n * - Network errors and API failures are propagated through promise rejection\n * - No specific error handling or retry logic is implemented at the repository level\n * - Consumers should implement appropriate error handling when calling repository methods\n *\n * ## Usage Patterns\n *\n * ### Singleton Access\n * ```typescript\n * import { CloudRepository } from './path/to/CloudRepository';\n *\n * // Use the singleton instance\n * const flow = await CloudRepository.Main.fetchFlow('flow-id');\n * ```\n *\n * ### Custom Instance\n * ```typescript\n * // Create a custom instance with different base URL\n * const customRepo = new CloudRepository('https://custom-api.example.com');\n * const flow = await customRepo.fetchFlow('flow-id');\n * ```\n *\n * ### Component Retrieval\n * ```typescript\n * // Get a specific component from a flow\n * const component = await CloudRepository.Main.fetchComponent('component-id', 'flow-id');\n * ```\n *\n * ## Dependencies\n *\n * - **IUserFlow**: Interface imported from `../common` that defines the structure of user flow objects\n * - **Fetch API**: Uses the native `fetch` function for HTTP requests\n *\n * ## Performance Considerations\n *\n * - **Caching**: Prevents duplicate API calls for the same flow ID\n * - **Promise Caching**: Handles concurrent requests efficiently by caching promises\n * - **Component Resolution**: The `resolve=components` parameter ensures components are fully resolved in a single API call\n *\n * ## Future Enhancements\n *\n * The class structure suggests planned functionality that could be implemented:\n *\n * - **Component Caching**: The commented `components` property indicates potential individual component caching\n * - **Cache Invalidation**: Methods to clear or refresh cached data\n * - **Error Retry Logic**: Automatic retry mechanisms for failed requests\n * - **Batch Operations**: Methods to fetch multiple flows or components in a single request\n *\n */\nexport class CloudRepository {\n static Main = new CloudRepository();\n\n private userFlows: Record<string, Promise<IUserFlow>> = {};\n\n // private components: Record<string, Promise<IUserFlow>> = {};\n\n constructor(private _baseUrl = 'https://cloud.myop.dev') {\n }\n\n async fetchComponent(componentId: string, flowId?: string) {\n if (flowId) {\n const flow = await this.fetchFlow(flowId);\n return flow.components.find(c => c.type.id === componentId);\n }else{\n const flow = await this.fetchAutoFlow(componentId);\n return flow.components[0];\n }\n }\n\n async fetchAutoFlow(componentId: string) {\n if (!this.userFlows[componentId]) {\n // eslint-disable-next-line no-async-promise-executor\n this.userFlows[componentId] = new Promise(\n async (resolve, reject) => {\n try {\n const res = await fetch(\n `${this._baseUrl}/flow?id=${componentId}&auto=true`\n );\n const json = await res.json();\n resolve(json.item);\n } catch (e) {\n reject(e);\n }\n }\n );\n }\n\n return await this.userFlows[componentId];\n }\n\n\n async fetchFlow(flowId: string) {\n if (!this.userFlows[flowId]) {\n // eslint-disable-next-line no-async-promise-executor\n this.userFlows[flowId] = new Promise(\n async (resolve, reject) => {\n try {\n const res = await fetch(\n `${this._baseUrl}/flow?id=${flowId}&resolve=components`\n );\n const json = await res.json();\n resolve(json.item);\n } catch (e) {\n reject(e);\n }\n }\n );\n }\n\n return await this.userFlows[flowId];\n }\n}\n", "export const exec = async (getter: any) => {\n return await getter()\n}\n"],
5
+ "mappings": "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",
6
6
  "names": ["match", "scriptInputs", "scriptInputs"]
7
7
  }
@@ -8,7 +8,7 @@ export declare const connectProps: <T extends componentDefinitionProps>(componen
8
8
  props: propTypes<T>;
9
9
  });
10
10
  export declare const createRefProxy: (target: Ref, component: IMyopComponent) => Ref;
11
- export declare const createRefComponent: <T extends IMyopComponent = IMyopComponent<any, any>>(ref: Ref, componentConfig: IComponentConfig, components: IMyopComponent[], options?: loaderOptions) => Promise<T>;
11
+ export declare const createRefComponent: <T extends IMyopComponent = IMyopComponent>(ref: Ref, componentConfig: IComponentConfig, components: IMyopComponent[], options?: loaderOptions) => Promise<T>;
12
12
  export declare const connectRefs: (component: IMyopComponent, componentConfig: IComponentConfig, components: IMyopComponent[], withoutRefComponents?: boolean) => Promise<void>;
13
13
  export type propTypes<T extends componentDefinitionProps> = {
14
14
  [Property in keyof T]: T[Property] extends {
@@ -28,8 +28,8 @@ export declare class HostSDK {
28
28
  private _getSkinIdBySkinSelector;
29
29
  private runSkinSelector;
30
30
  loaderHooks?: loaderHooks;
31
- loadComponent: <T extends IMyopComponent = IMyopComponent<any, any>>(componentConfig: IComponentConfig, container?: HTMLElement | Ref, options?: loaderOptions) => Promise<T>;
32
- navigate: <T extends IMyopComponent = IMyopComponent<any, any>>(component: IMyopComponent, newComponentConfig: IComponentConfig, options?: navigationOptions) => Promise<T>;
31
+ loadComponent: <T extends IMyopComponent = IMyopComponent>(componentConfig: IComponentConfig, container?: HTMLElement | Ref, options?: loaderOptions) => Promise<T>;
32
+ navigate: <T extends IMyopComponent = IMyopComponent>(component: IMyopComponent, newComponentConfig: IComponentConfig, options?: navigationOptions) => Promise<T>;
33
33
  }
34
34
  export type navigationOptions = {
35
35
  staged?: boolean;