@onekeyfe/hd-web-sdk 0.1.25 → 0.1.28

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.
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAsKA,QAAA,MAAM,cAAc,qCAOlB,CAAC;AAEH,eAAe,cAAc,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAgLA,QAAA,MAAM,cAAc,qCAOlB,CAAC;AAEH,eAAe,cAAc,CAAC"}
package/dist/index.js CHANGED
@@ -33,7 +33,7 @@ const handleMessage = (message) => __awaiter(void 0, void 0, void 0, function* (
33
33
  eventEmitter.emit(message.event, message);
34
34
  break;
35
35
  case hd_core_1.DEVICE_EVENT:
36
- if (message.type === hd_core_1.DEVICE.FEATURES) {
36
+ if ([hd_core_1.DEVICE.CONNECT, hd_core_1.DEVICE.DISCONNECT, hd_core_1.DEVICE.FEATURES, hd_core_1.DEVICE.SUPPORT_FEATURES].includes(message.type)) {
37
37
  eventEmitter.emit(message.type, message.payload);
38
38
  }
39
39
  break;
@@ -57,15 +57,17 @@ const uiResponse = (response) => {
57
57
  const cancel = (connectId) => {
58
58
  (0, bridgeUtils_1.sendMessage)({ event: hd_core_1.IFRAME.CANCEL, type: hd_core_1.IFRAME.CANCEL, payload: { connectId } });
59
59
  };
60
+ let prevFrameInstance = null;
60
61
  const createJSBridge = (messageEvent) => {
61
- var _a;
62
+ var _a, _b, _c;
62
63
  if (messageEvent.origin !== iframe.origin) {
63
64
  return;
64
65
  }
65
- if (!bridgeUtils_1.hostBridge) {
66
+ if (!bridgeUtils_1.hostBridge || prevFrameInstance !== ((_a = iframe.instance) === null || _a === void 0 ? void 0 : _a.contentWindow)) {
67
+ (0, bridgeUtils_1.resetListenerFlag)();
66
68
  (0, bridgeUtils_1.createJsBridge)({
67
69
  isHost: true,
68
- remoteFrame: (_a = iframe.instance) === null || _a === void 0 ? void 0 : _a.contentWindow,
70
+ remoteFrame: (_b = iframe.instance) === null || _b === void 0 ? void 0 : _b.contentWindow,
69
71
  remoteFrameName: bridge_config_1.default.iframeName,
70
72
  selfFrameName: bridge_config_1.default.hostName,
71
73
  channel: bridge_config_1.default.channel,
@@ -82,6 +84,7 @@ const createJSBridge = (messageEvent) => {
82
84
  return response;
83
85
  }),
84
86
  });
87
+ prevFrameInstance = (_c = iframe.instance) === null || _c === void 0 ? void 0 : _c.contentWindow;
85
88
  }
86
89
  };
87
90
  const init = (settings) => __awaiter(void 0, void 0, void 0, function* () {
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
@@ -2,6 +2,7 @@ import { IJsBridgeIframeConfig, JsBridgeIframe } from '@onekeyfe/cross-inpage-pr
2
2
  import { CoreMessage } from '@onekeyfe/hd-core';
3
3
  declare let frameBridge: JsBridgeIframe;
4
4
  declare let hostBridge: JsBridgeIframe;
5
+ export declare const resetListenerFlag: () => void;
5
6
  export declare const createJsBridge: (params: IJsBridgeIframeConfig & {
6
7
  isHost: boolean;
7
8
  }) => void;
@@ -1 +1 @@
1
- {"version":3,"file":"bridgeUtils.d.ts","sourceRoot":"","sources":["../../src/utils/bridgeUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;AAC7F,OAAO,EAAE,WAAW,EAA0B,MAAM,mBAAmB,CAAC;AAKxE,QAAA,IAAI,WAAW,EAAE,cAAc,CAAC;AAEhC,QAAA,IAAI,UAAU,EAAE,cAAc,CAAC;AAI/B,eAAO,MAAM,cAAc,WAAY,qBAAqB,GAAG;IAAE,MAAM,EAAE,OAAO,CAAA;CAAE,SAOjF,CAAC;AAEF,eAAO,MAAM,WAAW,aAAoB,WAAW,uBAAkB,QAAQ,GAAG,CAmBnF,CAAC;AAEF,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,CAAC"}
1
+ {"version":3,"file":"bridgeUtils.d.ts","sourceRoot":"","sources":["../../src/utils/bridgeUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,qBAAqB,EACrB,cAAc,EAEf,MAAM,sCAAsC,CAAC;AAC9C,OAAO,EAAE,WAAW,EAA0B,MAAM,mBAAmB,CAAC;AAKxE,QAAA,IAAI,WAAW,EAAE,cAAc,CAAC;AAEhC,QAAA,IAAI,UAAU,EAAE,cAAc,CAAC;AAI/B,eAAO,MAAM,iBAAiB,YAA0C,CAAC;AAEzE,eAAO,MAAM,cAAc,WAAY,qBAAqB,GAAG;IAAE,MAAM,EAAE,OAAO,CAAA;CAAE,SAOjF,CAAC;AAEF,eAAO,MAAM,WAAW,aAAoB,WAAW,uBAAkB,QAAQ,GAAG,CAmBnF,CAAC;AAEF,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,CAAC"}
@@ -9,7 +9,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
9
9
  });
10
10
  };
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.hostBridge = exports.frameBridge = exports.sendMessage = exports.createJsBridge = void 0;
12
+ exports.hostBridge = exports.frameBridge = exports.sendMessage = exports.createJsBridge = exports.resetListenerFlag = void 0;
13
13
  const cross_inpage_provider_core_1 = require("@onekeyfe/cross-inpage-provider-core");
14
14
  const hd_core_1 = require("@onekeyfe/hd-core");
15
15
  const hd_shared_1 = require("@onekeyfe/hd-shared");
@@ -19,6 +19,8 @@ exports.frameBridge = frameBridge;
19
19
  let hostBridge;
20
20
  exports.hostBridge = hostBridge;
21
21
  const Log = (0, hd_core_1.getLogger)(hd_core_1.LoggerNames.SendMessage);
22
+ const resetListenerFlag = () => (0, cross_inpage_provider_core_1.setPostMessageListenerFlag)(false);
23
+ exports.resetListenerFlag = resetListenerFlag;
22
24
  const createJsBridge = (params) => {
23
25
  const bridge = new cross_inpage_provider_core_1.JsBridgeIframe(params);
24
26
  if (params.isHost) {
@@ -1 +1 @@
1
- {"version":3,"file":"bridgeUtils.js","sourceRoot":"","sources":["../../src/utils/bridgeUtils.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qFAA6F;AAC7F,+CAAwE;AACxE,mDAA6C;AAC7C,2DAAqD;AAGrD,IAAI,WAA2B,CAAC;AAoCvB,kCAAW;AAlCpB,IAAI,UAA0B,CAAC;AAkCT,gCAAU;AAhChC,MAAM,GAAG,GAAG,IAAA,mBAAS,EAAC,qBAAW,CAAC,WAAW,CAAC,CAAC;AAExC,MAAM,cAAc,GAAG,CAAC,MAAmD,EAAE,EAAE;IACpF,MAAM,MAAM,GAAG,IAAI,2CAAc,CAAC,MAAM,CAAC,CAAC;IAC1C,IAAI,MAAM,CAAC,MAAM,EAAE;QACjB,qBAAA,UAAU,GAAG,MAAM,CAAC;KACrB;SAAM;QACL,sBAAA,WAAW,GAAG,MAAM,CAAC;KACtB;AACH,CAAC,CAAC;AAPW,QAAA,cAAc,kBAOzB;AAEK,MAAM,WAAW,GAAG,CAAO,QAAqB,EAAE,MAAM,GAAG,IAAI,EAAgB,EAAE;IACtF,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,WAAW,CAAC;IAEjD,IAAI;QACF,IAAI,QAAQ,CAAC,KAAK,KAAK,WAAW,EAAE;YAClC,GAAG,CAAC,KAAK,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;SAClC;QACD,MAAM,MAAM,GAAG,MAAM,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,CAAC;YACnC,KAAK,EAAE,uBAAc,CAAC,KAAK;YAC3B,IAAI,oBAAO,QAAQ,CAAE;SACtB,CAAC,CAAA,CAAC;QACH,IAAI,QAAQ,CAAC,KAAK,KAAK,WAAW,EAAE;YAClC,GAAG,CAAC,KAAK,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;SACjC;QACD,OAAO,MAAM,CAAC;KACf;IAAC,OAAO,KAAK,EAAE;QACd,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACjB,MAAM,kBAAM,CAAC,oBAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;KAClD;AACH,CAAC,CAAA,CAAC;AAnBW,QAAA,WAAW,eAmBtB"}
1
+ {"version":3,"file":"bridgeUtils.js","sourceRoot":"","sources":["../../src/utils/bridgeUtils.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qFAI8C;AAC9C,+CAAwE;AACxE,mDAA6C;AAC7C,2DAAqD;AAGrD,IAAI,WAA2B,CAAC;AAsCvB,kCAAW;AApCpB,IAAI,UAA0B,CAAC;AAoCT,gCAAU;AAlChC,MAAM,GAAG,GAAG,IAAA,mBAAS,EAAC,qBAAW,CAAC,WAAW,CAAC,CAAC;AAExC,MAAM,iBAAiB,GAAG,GAAG,EAAE,CAAC,IAAA,uDAA0B,EAAC,KAAK,CAAC,CAAC;AAA5D,QAAA,iBAAiB,qBAA2C;AAElE,MAAM,cAAc,GAAG,CAAC,MAAmD,EAAE,EAAE;IACpF,MAAM,MAAM,GAAG,IAAI,2CAAc,CAAC,MAAM,CAAC,CAAC;IAC1C,IAAI,MAAM,CAAC,MAAM,EAAE;QACjB,qBAAA,UAAU,GAAG,MAAM,CAAC;KACrB;SAAM;QACL,sBAAA,WAAW,GAAG,MAAM,CAAC;KACtB;AACH,CAAC,CAAC;AAPW,QAAA,cAAc,kBAOzB;AAEK,MAAM,WAAW,GAAG,CAAO,QAAqB,EAAE,MAAM,GAAG,IAAI,EAAgB,EAAE;IACtF,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,WAAW,CAAC;IAEjD,IAAI;QACF,IAAI,QAAQ,CAAC,KAAK,KAAK,WAAW,EAAE;YAClC,GAAG,CAAC,KAAK,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;SAClC;QACD,MAAM,MAAM,GAAG,MAAM,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,CAAC;YACnC,KAAK,EAAE,uBAAc,CAAC,KAAK;YAC3B,IAAI,oBAAO,QAAQ,CAAE;SACtB,CAAC,CAAA,CAAC;QACH,IAAI,QAAQ,CAAC,KAAK,KAAK,WAAW,EAAE;YAClC,GAAG,CAAC,KAAK,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;SACjC;QACD,OAAO,MAAM,CAAC;KACf;IAAC,OAAO,KAAK,EAAE;QACd,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACjB,MAAM,kBAAM,CAAC,oBAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;KAClD;AACH,CAAC,CAAA,CAAC;AAnBW,QAAA,WAAW,eAmBtB"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@onekeyfe/hd-web-sdk",
3
- "version": "0.1.25",
3
+ "version": "0.1.28",
4
4
  "author": "OneKey",
5
5
  "homepage": "https://github.com/OneKeyHQ/hardware-js-sdk#readme",
6
6
  "license": "ISC",
@@ -21,10 +21,10 @@
21
21
  "test": "echo \"Error: run tests from root\" && exit 1"
22
22
  },
23
23
  "dependencies": {
24
- "@onekeyfe/cross-inpage-provider-core": "^0.0.14",
25
- "@onekeyfe/hd-core": "^0.1.25",
26
- "@onekeyfe/hd-shared": "^0.1.25",
27
- "@onekeyfe/hd-transport-http": "^0.1.25"
24
+ "@onekeyfe/cross-inpage-provider-core": "^0.0.17",
25
+ "@onekeyfe/hd-core": "^0.1.28",
26
+ "@onekeyfe/hd-shared": "^0.1.28",
27
+ "@onekeyfe/hd-transport-http": "^0.1.28"
28
28
  },
29
29
  "devDependencies": {
30
30
  "@babel/plugin-proposal-optional-chaining": "^7.17.12",
@@ -45,5 +45,5 @@
45
45
  "webpack-cli": "^4.9.2",
46
46
  "webpack-plugin-serve": "^1.6.0"
47
47
  },
48
- "gitHead": "2e8f7aecfd69191596348a5591abba1bf61a20b2"
48
+ "gitHead": "84236b7baecf937399e557aa2d9a5b47ecd01d3f"
49
49
  }
package/src/index.ts CHANGED
@@ -21,7 +21,7 @@ import HardwareSdk, {
21
21
  import { ERRORS, HardwareError, HardwareErrorCode } from '@onekeyfe/hd-shared';
22
22
  import * as iframe from './iframe/builder';
23
23
  import JSBridgeConfig from './iframe/bridge-config';
24
- import { sendMessage, createJsBridge, hostBridge } from './utils/bridgeUtils';
24
+ import { sendMessage, createJsBridge, hostBridge, resetListenerFlag } from './utils/bridgeUtils';
25
25
 
26
26
  const eventEmitter = new EventEmitter();
27
27
  const Log = getLogger(LoggerNames.Connect);
@@ -40,12 +40,18 @@ const handleMessage = async (message: CoreMessage) => {
40
40
  eventEmitter.emit(message.event, message);
41
41
  eventEmitter.emit(message.type, message.payload);
42
42
  break;
43
+
43
44
  case LOG_EVENT:
44
45
  case FIRMWARE_EVENT:
45
46
  eventEmitter.emit(message.event, message);
46
47
  break;
48
+
47
49
  case DEVICE_EVENT:
48
- if (message.type === DEVICE.FEATURES) {
50
+ if (
51
+ (
52
+ [DEVICE.CONNECT, DEVICE.DISCONNECT, DEVICE.FEATURES, DEVICE.SUPPORT_FEATURES] as string[]
53
+ ).includes(message.type)
54
+ ) {
49
55
  eventEmitter.emit(message.type, message.payload);
50
56
  }
51
57
  break;
@@ -74,11 +80,13 @@ const cancel = (connectId?: string) => {
74
80
  sendMessage({ event: IFRAME.CANCEL, type: IFRAME.CANCEL, payload: { connectId } });
75
81
  };
76
82
 
83
+ let prevFrameInstance: Window | null | undefined = null;
77
84
  const createJSBridge = (messageEvent: PostMessageEvent) => {
78
85
  if (messageEvent.origin !== iframe.origin) {
79
86
  return;
80
87
  }
81
- if (!hostBridge) {
88
+ if (!hostBridge || prevFrameInstance !== iframe.instance?.contentWindow) {
89
+ resetListenerFlag();
82
90
  createJsBridge({
83
91
  isHost: true,
84
92
  remoteFrame: iframe.instance?.contentWindow as Window,
@@ -99,6 +107,8 @@ const createJSBridge = (messageEvent: PostMessageEvent) => {
99
107
  return response;
100
108
  },
101
109
  });
110
+
111
+ prevFrameInstance = iframe.instance?.contentWindow;
102
112
  }
103
113
  };
104
114
 
@@ -1,4 +1,8 @@
1
- import { IJsBridgeIframeConfig, JsBridgeIframe } from '@onekeyfe/cross-inpage-provider-core';
1
+ import {
2
+ IJsBridgeIframeConfig,
3
+ JsBridgeIframe,
4
+ setPostMessageListenerFlag,
5
+ } from '@onekeyfe/cross-inpage-provider-core';
2
6
  import { CoreMessage, getLogger, LoggerNames } from '@onekeyfe/hd-core';
3
7
  import { ERRORS } from '@onekeyfe/hd-shared';
4
8
  import JSBridgeConfig from '../iframe/bridge-config';
@@ -10,6 +14,8 @@ let hostBridge: JsBridgeIframe;
10
14
 
11
15
  const Log = getLogger(LoggerNames.SendMessage);
12
16
 
17
+ export const resetListenerFlag = () => setPostMessageListenerFlag(false);
18
+
13
19
  export const createJsBridge = (params: IJsBridgeIframeConfig & { isHost: boolean }) => {
14
20
  const bridge = new JsBridgeIframe(params);
15
21
  if (params.isHost) {