@mocanetwork/airkit 1.1.0 → 1.2.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/airkit.cjs.js +50 -0
- package/dist/airkit.esm.js +50 -0
- package/dist/airkit.umd.js +50 -0
- package/dist/types/airService.d.ts +5 -0
- package/dist/types/common/realm/messaging/auth.d.ts +8 -1
- package/dist/types/common/realm/messaging/types.d.ts +9 -1
- package/dist/types/common/realm/partner/config.d.ts +1 -0
- package/dist/types/messageService.d.ts +2 -0
- package/package.json +1 -1
package/dist/airkit.cjs.js
CHANGED
|
@@ -120,6 +120,8 @@ const AirAuthMessageTypes = {
|
|
|
120
120
|
SIGN_SIWE_MESSAGE_RESPONSE: "air_auth_sign_siwe_message_response",
|
|
121
121
|
CROSS_PARTNER_TOKEN_REQUEST: "air_auth_cross_partner_token_request",
|
|
122
122
|
CROSS_PARTNER_TOKEN_RESPONSE: "air_auth_cross_partner_token_response",
|
|
123
|
+
GET_PARTNER_ACCESS_TOKEN_REQUEST: "air_auth_get_partner_access_token_request",
|
|
124
|
+
GET_PARTNER_ACCESS_TOKEN_RESPONSE: "air_auth_get_partner_access_token_response",
|
|
123
125
|
LOGOUT_REQUEST: "air_auth_logout_request",
|
|
124
126
|
LOGOUT_RESPONSE: "air_auth_logout_response",
|
|
125
127
|
RESET_WALLET_COMMUNICATION: "air_auth_reset_wallet_communication"
|
|
@@ -145,6 +147,8 @@ const AirMessageTypes = {
|
|
|
145
147
|
EXECUTE_ACTION_RESPONSE: "air_execute_action_response",
|
|
146
148
|
REVOKE_PERMISSIONS_REQUEST: "air_revoke_permissions_request",
|
|
147
149
|
REVOKE_PERMISSIONS_RESPONSE: "air_revoke_permissions_response",
|
|
150
|
+
LIST_ALL_SESSION_KEY_SCOPES_REQUEST: "air_list_all_session_key_scopes_request",
|
|
151
|
+
LIST_ALL_SESSION_KEY_SCOPES_RESPONSE: "air_list_all_session_key_scopes_response",
|
|
148
152
|
WALLET_IFRAME_VISIBILITY_REQUEST: "air_wallet_iframe_visibility_request",
|
|
149
153
|
IS_SMART_ACCOUNT_DEPLOYED_REQUEST: "air_is_smart_account_deployed_request",
|
|
150
154
|
IS_SMART_ACCOUNT_DEPLOYED_RESPONSE: "air_is_smart_account_deployed_response",
|
|
@@ -1376,6 +1380,7 @@ const ACCOUNT_MESSAGES = [
|
|
|
1376
1380
|
AirMessageTypes.EXECUTE_ACTION_RESPONSE,
|
|
1377
1381
|
AirMessageTypes.REVOKE_PERMISSIONS_RESPONSE,
|
|
1378
1382
|
AirMessageTypes.GRANT_PERMISSIONS_RESPONSE,
|
|
1383
|
+
AirMessageTypes.LIST_ALL_SESSION_KEY_SCOPES_RESPONSE,
|
|
1379
1384
|
AirMessageTypes.WALLET_INITIALIZED,
|
|
1380
1385
|
AirMessageTypes.WALLET_IFRAME_VISIBILITY_REQUEST,
|
|
1381
1386
|
AirMessageTypes.LOGOUT_RESPONSE,
|
|
@@ -1388,6 +1393,7 @@ const AUTH_MESSAGES = [
|
|
|
1388
1393
|
AirAuthMessageTypes.LOGOUT_RESPONSE,
|
|
1389
1394
|
AirAuthMessageTypes.PARTNER_USER_INFO_RESPONSE,
|
|
1390
1395
|
AirAuthMessageTypes.CROSS_PARTNER_TOKEN_RESPONSE,
|
|
1396
|
+
AirAuthMessageTypes.GET_PARTNER_ACCESS_TOKEN_RESPONSE,
|
|
1391
1397
|
AirAuthMessageTypes.IFRAME_VISIBILITY_REQUEST,
|
|
1392
1398
|
];
|
|
1393
1399
|
class AirMessageService {
|
|
@@ -1601,6 +1607,12 @@ class AirMessageService {
|
|
|
1601
1607
|
walletIframe.contentWindow.postMessage({ type: AirMessageTypes.GRANT_PERMISSIONS_REQUEST, payload }, origin);
|
|
1602
1608
|
return response;
|
|
1603
1609
|
}
|
|
1610
|
+
async sendListAllSessionKeyScopesRequest(walletIframe) {
|
|
1611
|
+
const response = firstValueFrom(this.messages$.pipe(filter((msg) => msg.type === AirMessageTypes.LIST_ALL_SESSION_KEY_SCOPES_RESPONSE)));
|
|
1612
|
+
const { origin } = new URL(walletIframe.src);
|
|
1613
|
+
walletIframe.contentWindow.postMessage({ type: AirMessageTypes.LIST_ALL_SESSION_KEY_SCOPES_REQUEST }, origin);
|
|
1614
|
+
return response;
|
|
1615
|
+
}
|
|
1604
1616
|
onWalletInitialized() {
|
|
1605
1617
|
return firstValueFrom(this.messages$.pipe(filter((msg) => msg.type === AirMessageTypes.WALLET_INITIALIZED)));
|
|
1606
1618
|
}
|
|
@@ -1662,6 +1674,12 @@ class AirMessageService {
|
|
|
1662
1674
|
this._providerMessage$ = new Subject();
|
|
1663
1675
|
this._providerEvent$ = new Subject();
|
|
1664
1676
|
}
|
|
1677
|
+
async sendGetPartnerAccessTokenRequest(authIframe) {
|
|
1678
|
+
const response = firstValueFrom(this.authMessage$.pipe(filter((msg) => msg.type === AirAuthMessageTypes.GET_PARTNER_ACCESS_TOKEN_RESPONSE)));
|
|
1679
|
+
const { origin } = new URL(authIframe.src);
|
|
1680
|
+
authIframe.contentWindow.postMessage({ type: AirAuthMessageTypes.GET_PARTNER_ACCESS_TOKEN_REQUEST }, origin);
|
|
1681
|
+
return response;
|
|
1682
|
+
}
|
|
1665
1683
|
}
|
|
1666
1684
|
var AirMessageService$1 = AirMessageService.instance;
|
|
1667
1685
|
|
|
@@ -2033,6 +2051,24 @@ class AirService {
|
|
|
2033
2051
|
throw AirServiceError.from(error);
|
|
2034
2052
|
}
|
|
2035
2053
|
}
|
|
2054
|
+
/**
|
|
2055
|
+
* @experimental This method is experimental and will change in the future.
|
|
2056
|
+
*/
|
|
2057
|
+
async listAllSessionKeyScopes() {
|
|
2058
|
+
if (!__classPrivateFieldGet(this, _AirService_isAuthInitialized, "f"))
|
|
2059
|
+
throw new Error("Service is not initialized");
|
|
2060
|
+
await __classPrivateFieldGet(this, _AirService_instances, "m", _AirService_ensureWallet).call(this);
|
|
2061
|
+
try {
|
|
2062
|
+
const { payload } = await AirMessageService$1.sendListAllSessionKeyScopesRequest(__classPrivateFieldGet(this, _AirService_walletIframeController, "f").iframeElement);
|
|
2063
|
+
if (payload.success === false) {
|
|
2064
|
+
throw new AirServiceError(payload.errorName, payload.errorMessage);
|
|
2065
|
+
}
|
|
2066
|
+
return payload.sessionKeyScopes;
|
|
2067
|
+
}
|
|
2068
|
+
catch (error) {
|
|
2069
|
+
throw AirServiceError.from(error);
|
|
2070
|
+
}
|
|
2071
|
+
}
|
|
2036
2072
|
/**
|
|
2037
2073
|
* @experimental This method is experimental and will change in the future.
|
|
2038
2074
|
*/
|
|
@@ -2163,6 +2199,20 @@ class AirService {
|
|
|
2163
2199
|
clearEventListeners() {
|
|
2164
2200
|
__classPrivateFieldSet(this, _AirService_airAuthListener, [], "f");
|
|
2165
2201
|
}
|
|
2202
|
+
async getPartnerAccessToken() {
|
|
2203
|
+
if (!__classPrivateFieldGet(this, _AirService_isAuthInitialized, "f"))
|
|
2204
|
+
throw new Error("Service is not initialized");
|
|
2205
|
+
if (!this.isLoggedIn)
|
|
2206
|
+
throw new Error("No active session to get partner access token");
|
|
2207
|
+
const result = await AirMessageService$1.sendGetPartnerAccessTokenRequest(__classPrivateFieldGet(this, _AirService_authIframeController, "f").iframeElement);
|
|
2208
|
+
if (result.payload.success === false) {
|
|
2209
|
+
throw new AirServiceError(result.payload.errorName, result.payload.errorMessage);
|
|
2210
|
+
}
|
|
2211
|
+
if (!result.payload.partnerAccessToken) {
|
|
2212
|
+
throw new Error("Partner access token not found in response");
|
|
2213
|
+
}
|
|
2214
|
+
return result.payload.partnerAccessToken;
|
|
2215
|
+
}
|
|
2166
2216
|
}
|
|
2167
2217
|
_AirService_loginResult = new WeakMap(), _AirService_buildEnv = new WeakMap(), _AirService_enableLogging = new WeakMap(), _AirService_partnerId = new WeakMap(), _AirService_authIframeController = new WeakMap(), _AirService_isAuthInitialized = new WeakMap(), _AirService_airAuthListener = new WeakMap(), _AirService_walletIframeController = new WeakMap(), _AirService_walletInitialization = new WeakMap(), _AirService_walletLoggedInResult = new WeakMap(), _AirService_airWalletProvider = new WeakMap(), _AirService_instances = new WeakSet(), _AirService_ensureWallet = async function _AirService_ensureWallet(option) {
|
|
2168
2218
|
if (!this.isInitialized)
|
package/dist/airkit.esm.js
CHANGED
|
@@ -118,6 +118,8 @@ const AirAuthMessageTypes = {
|
|
|
118
118
|
SIGN_SIWE_MESSAGE_RESPONSE: "air_auth_sign_siwe_message_response",
|
|
119
119
|
CROSS_PARTNER_TOKEN_REQUEST: "air_auth_cross_partner_token_request",
|
|
120
120
|
CROSS_PARTNER_TOKEN_RESPONSE: "air_auth_cross_partner_token_response",
|
|
121
|
+
GET_PARTNER_ACCESS_TOKEN_REQUEST: "air_auth_get_partner_access_token_request",
|
|
122
|
+
GET_PARTNER_ACCESS_TOKEN_RESPONSE: "air_auth_get_partner_access_token_response",
|
|
121
123
|
LOGOUT_REQUEST: "air_auth_logout_request",
|
|
122
124
|
LOGOUT_RESPONSE: "air_auth_logout_response",
|
|
123
125
|
RESET_WALLET_COMMUNICATION: "air_auth_reset_wallet_communication"
|
|
@@ -143,6 +145,8 @@ const AirMessageTypes = {
|
|
|
143
145
|
EXECUTE_ACTION_RESPONSE: "air_execute_action_response",
|
|
144
146
|
REVOKE_PERMISSIONS_REQUEST: "air_revoke_permissions_request",
|
|
145
147
|
REVOKE_PERMISSIONS_RESPONSE: "air_revoke_permissions_response",
|
|
148
|
+
LIST_ALL_SESSION_KEY_SCOPES_REQUEST: "air_list_all_session_key_scopes_request",
|
|
149
|
+
LIST_ALL_SESSION_KEY_SCOPES_RESPONSE: "air_list_all_session_key_scopes_response",
|
|
146
150
|
WALLET_IFRAME_VISIBILITY_REQUEST: "air_wallet_iframe_visibility_request",
|
|
147
151
|
IS_SMART_ACCOUNT_DEPLOYED_REQUEST: "air_is_smart_account_deployed_request",
|
|
148
152
|
IS_SMART_ACCOUNT_DEPLOYED_RESPONSE: "air_is_smart_account_deployed_response",
|
|
@@ -1374,6 +1378,7 @@ const ACCOUNT_MESSAGES = [
|
|
|
1374
1378
|
AirMessageTypes.EXECUTE_ACTION_RESPONSE,
|
|
1375
1379
|
AirMessageTypes.REVOKE_PERMISSIONS_RESPONSE,
|
|
1376
1380
|
AirMessageTypes.GRANT_PERMISSIONS_RESPONSE,
|
|
1381
|
+
AirMessageTypes.LIST_ALL_SESSION_KEY_SCOPES_RESPONSE,
|
|
1377
1382
|
AirMessageTypes.WALLET_INITIALIZED,
|
|
1378
1383
|
AirMessageTypes.WALLET_IFRAME_VISIBILITY_REQUEST,
|
|
1379
1384
|
AirMessageTypes.LOGOUT_RESPONSE,
|
|
@@ -1386,6 +1391,7 @@ const AUTH_MESSAGES = [
|
|
|
1386
1391
|
AirAuthMessageTypes.LOGOUT_RESPONSE,
|
|
1387
1392
|
AirAuthMessageTypes.PARTNER_USER_INFO_RESPONSE,
|
|
1388
1393
|
AirAuthMessageTypes.CROSS_PARTNER_TOKEN_RESPONSE,
|
|
1394
|
+
AirAuthMessageTypes.GET_PARTNER_ACCESS_TOKEN_RESPONSE,
|
|
1389
1395
|
AirAuthMessageTypes.IFRAME_VISIBILITY_REQUEST,
|
|
1390
1396
|
];
|
|
1391
1397
|
class AirMessageService {
|
|
@@ -1599,6 +1605,12 @@ class AirMessageService {
|
|
|
1599
1605
|
walletIframe.contentWindow.postMessage({ type: AirMessageTypes.GRANT_PERMISSIONS_REQUEST, payload }, origin);
|
|
1600
1606
|
return response;
|
|
1601
1607
|
}
|
|
1608
|
+
async sendListAllSessionKeyScopesRequest(walletIframe) {
|
|
1609
|
+
const response = firstValueFrom(this.messages$.pipe(filter((msg) => msg.type === AirMessageTypes.LIST_ALL_SESSION_KEY_SCOPES_RESPONSE)));
|
|
1610
|
+
const { origin } = new URL(walletIframe.src);
|
|
1611
|
+
walletIframe.contentWindow.postMessage({ type: AirMessageTypes.LIST_ALL_SESSION_KEY_SCOPES_REQUEST }, origin);
|
|
1612
|
+
return response;
|
|
1613
|
+
}
|
|
1602
1614
|
onWalletInitialized() {
|
|
1603
1615
|
return firstValueFrom(this.messages$.pipe(filter((msg) => msg.type === AirMessageTypes.WALLET_INITIALIZED)));
|
|
1604
1616
|
}
|
|
@@ -1660,6 +1672,12 @@ class AirMessageService {
|
|
|
1660
1672
|
this._providerMessage$ = new Subject();
|
|
1661
1673
|
this._providerEvent$ = new Subject();
|
|
1662
1674
|
}
|
|
1675
|
+
async sendGetPartnerAccessTokenRequest(authIframe) {
|
|
1676
|
+
const response = firstValueFrom(this.authMessage$.pipe(filter((msg) => msg.type === AirAuthMessageTypes.GET_PARTNER_ACCESS_TOKEN_RESPONSE)));
|
|
1677
|
+
const { origin } = new URL(authIframe.src);
|
|
1678
|
+
authIframe.contentWindow.postMessage({ type: AirAuthMessageTypes.GET_PARTNER_ACCESS_TOKEN_REQUEST }, origin);
|
|
1679
|
+
return response;
|
|
1680
|
+
}
|
|
1663
1681
|
}
|
|
1664
1682
|
var AirMessageService$1 = AirMessageService.instance;
|
|
1665
1683
|
|
|
@@ -2031,6 +2049,24 @@ class AirService {
|
|
|
2031
2049
|
throw AirServiceError.from(error);
|
|
2032
2050
|
}
|
|
2033
2051
|
}
|
|
2052
|
+
/**
|
|
2053
|
+
* @experimental This method is experimental and will change in the future.
|
|
2054
|
+
*/
|
|
2055
|
+
async listAllSessionKeyScopes() {
|
|
2056
|
+
if (!__classPrivateFieldGet(this, _AirService_isAuthInitialized, "f"))
|
|
2057
|
+
throw new Error("Service is not initialized");
|
|
2058
|
+
await __classPrivateFieldGet(this, _AirService_instances, "m", _AirService_ensureWallet).call(this);
|
|
2059
|
+
try {
|
|
2060
|
+
const { payload } = await AirMessageService$1.sendListAllSessionKeyScopesRequest(__classPrivateFieldGet(this, _AirService_walletIframeController, "f").iframeElement);
|
|
2061
|
+
if (payload.success === false) {
|
|
2062
|
+
throw new AirServiceError(payload.errorName, payload.errorMessage);
|
|
2063
|
+
}
|
|
2064
|
+
return payload.sessionKeyScopes;
|
|
2065
|
+
}
|
|
2066
|
+
catch (error) {
|
|
2067
|
+
throw AirServiceError.from(error);
|
|
2068
|
+
}
|
|
2069
|
+
}
|
|
2034
2070
|
/**
|
|
2035
2071
|
* @experimental This method is experimental and will change in the future.
|
|
2036
2072
|
*/
|
|
@@ -2161,6 +2197,20 @@ class AirService {
|
|
|
2161
2197
|
clearEventListeners() {
|
|
2162
2198
|
__classPrivateFieldSet(this, _AirService_airAuthListener, [], "f");
|
|
2163
2199
|
}
|
|
2200
|
+
async getPartnerAccessToken() {
|
|
2201
|
+
if (!__classPrivateFieldGet(this, _AirService_isAuthInitialized, "f"))
|
|
2202
|
+
throw new Error("Service is not initialized");
|
|
2203
|
+
if (!this.isLoggedIn)
|
|
2204
|
+
throw new Error("No active session to get partner access token");
|
|
2205
|
+
const result = await AirMessageService$1.sendGetPartnerAccessTokenRequest(__classPrivateFieldGet(this, _AirService_authIframeController, "f").iframeElement);
|
|
2206
|
+
if (result.payload.success === false) {
|
|
2207
|
+
throw new AirServiceError(result.payload.errorName, result.payload.errorMessage);
|
|
2208
|
+
}
|
|
2209
|
+
if (!result.payload.partnerAccessToken) {
|
|
2210
|
+
throw new Error("Partner access token not found in response");
|
|
2211
|
+
}
|
|
2212
|
+
return result.payload.partnerAccessToken;
|
|
2213
|
+
}
|
|
2164
2214
|
}
|
|
2165
2215
|
_AirService_loginResult = new WeakMap(), _AirService_buildEnv = new WeakMap(), _AirService_enableLogging = new WeakMap(), _AirService_partnerId = new WeakMap(), _AirService_authIframeController = new WeakMap(), _AirService_isAuthInitialized = new WeakMap(), _AirService_airAuthListener = new WeakMap(), _AirService_walletIframeController = new WeakMap(), _AirService_walletInitialization = new WeakMap(), _AirService_walletLoggedInResult = new WeakMap(), _AirService_airWalletProvider = new WeakMap(), _AirService_instances = new WeakSet(), _AirService_ensureWallet = async function _AirService_ensureWallet(option) {
|
|
2166
2216
|
if (!this.isInitialized)
|
package/dist/airkit.umd.js
CHANGED
|
@@ -124,6 +124,8 @@
|
|
|
124
124
|
SIGN_SIWE_MESSAGE_RESPONSE: "air_auth_sign_siwe_message_response",
|
|
125
125
|
CROSS_PARTNER_TOKEN_REQUEST: "air_auth_cross_partner_token_request",
|
|
126
126
|
CROSS_PARTNER_TOKEN_RESPONSE: "air_auth_cross_partner_token_response",
|
|
127
|
+
GET_PARTNER_ACCESS_TOKEN_REQUEST: "air_auth_get_partner_access_token_request",
|
|
128
|
+
GET_PARTNER_ACCESS_TOKEN_RESPONSE: "air_auth_get_partner_access_token_response",
|
|
127
129
|
LOGOUT_REQUEST: "air_auth_logout_request",
|
|
128
130
|
LOGOUT_RESPONSE: "air_auth_logout_response",
|
|
129
131
|
RESET_WALLET_COMMUNICATION: "air_auth_reset_wallet_communication"
|
|
@@ -149,6 +151,8 @@
|
|
|
149
151
|
EXECUTE_ACTION_RESPONSE: "air_execute_action_response",
|
|
150
152
|
REVOKE_PERMISSIONS_REQUEST: "air_revoke_permissions_request",
|
|
151
153
|
REVOKE_PERMISSIONS_RESPONSE: "air_revoke_permissions_response",
|
|
154
|
+
LIST_ALL_SESSION_KEY_SCOPES_REQUEST: "air_list_all_session_key_scopes_request",
|
|
155
|
+
LIST_ALL_SESSION_KEY_SCOPES_RESPONSE: "air_list_all_session_key_scopes_response",
|
|
152
156
|
WALLET_IFRAME_VISIBILITY_REQUEST: "air_wallet_iframe_visibility_request",
|
|
153
157
|
IS_SMART_ACCOUNT_DEPLOYED_REQUEST: "air_is_smart_account_deployed_request",
|
|
154
158
|
IS_SMART_ACCOUNT_DEPLOYED_RESPONSE: "air_is_smart_account_deployed_response",
|
|
@@ -1380,6 +1384,7 @@
|
|
|
1380
1384
|
AirMessageTypes.EXECUTE_ACTION_RESPONSE,
|
|
1381
1385
|
AirMessageTypes.REVOKE_PERMISSIONS_RESPONSE,
|
|
1382
1386
|
AirMessageTypes.GRANT_PERMISSIONS_RESPONSE,
|
|
1387
|
+
AirMessageTypes.LIST_ALL_SESSION_KEY_SCOPES_RESPONSE,
|
|
1383
1388
|
AirMessageTypes.WALLET_INITIALIZED,
|
|
1384
1389
|
AirMessageTypes.WALLET_IFRAME_VISIBILITY_REQUEST,
|
|
1385
1390
|
AirMessageTypes.LOGOUT_RESPONSE,
|
|
@@ -1392,6 +1397,7 @@
|
|
|
1392
1397
|
AirAuthMessageTypes.LOGOUT_RESPONSE,
|
|
1393
1398
|
AirAuthMessageTypes.PARTNER_USER_INFO_RESPONSE,
|
|
1394
1399
|
AirAuthMessageTypes.CROSS_PARTNER_TOKEN_RESPONSE,
|
|
1400
|
+
AirAuthMessageTypes.GET_PARTNER_ACCESS_TOKEN_RESPONSE,
|
|
1395
1401
|
AirAuthMessageTypes.IFRAME_VISIBILITY_REQUEST,
|
|
1396
1402
|
];
|
|
1397
1403
|
class AirMessageService {
|
|
@@ -1605,6 +1611,12 @@
|
|
|
1605
1611
|
walletIframe.contentWindow.postMessage({ type: AirMessageTypes.GRANT_PERMISSIONS_REQUEST, payload }, origin);
|
|
1606
1612
|
return response;
|
|
1607
1613
|
}
|
|
1614
|
+
async sendListAllSessionKeyScopesRequest(walletIframe) {
|
|
1615
|
+
const response = firstValueFrom(this.messages$.pipe(filter((msg) => msg.type === AirMessageTypes.LIST_ALL_SESSION_KEY_SCOPES_RESPONSE)));
|
|
1616
|
+
const { origin } = new URL(walletIframe.src);
|
|
1617
|
+
walletIframe.contentWindow.postMessage({ type: AirMessageTypes.LIST_ALL_SESSION_KEY_SCOPES_REQUEST }, origin);
|
|
1618
|
+
return response;
|
|
1619
|
+
}
|
|
1608
1620
|
onWalletInitialized() {
|
|
1609
1621
|
return firstValueFrom(this.messages$.pipe(filter((msg) => msg.type === AirMessageTypes.WALLET_INITIALIZED)));
|
|
1610
1622
|
}
|
|
@@ -1666,6 +1678,12 @@
|
|
|
1666
1678
|
this._providerMessage$ = new Subject();
|
|
1667
1679
|
this._providerEvent$ = new Subject();
|
|
1668
1680
|
}
|
|
1681
|
+
async sendGetPartnerAccessTokenRequest(authIframe) {
|
|
1682
|
+
const response = firstValueFrom(this.authMessage$.pipe(filter((msg) => msg.type === AirAuthMessageTypes.GET_PARTNER_ACCESS_TOKEN_RESPONSE)));
|
|
1683
|
+
const { origin } = new URL(authIframe.src);
|
|
1684
|
+
authIframe.contentWindow.postMessage({ type: AirAuthMessageTypes.GET_PARTNER_ACCESS_TOKEN_REQUEST }, origin);
|
|
1685
|
+
return response;
|
|
1686
|
+
}
|
|
1669
1687
|
}
|
|
1670
1688
|
var AirMessageService$1 = AirMessageService.instance;
|
|
1671
1689
|
|
|
@@ -2037,6 +2055,24 @@
|
|
|
2037
2055
|
throw AirServiceError.from(error);
|
|
2038
2056
|
}
|
|
2039
2057
|
}
|
|
2058
|
+
/**
|
|
2059
|
+
* @experimental This method is experimental and will change in the future.
|
|
2060
|
+
*/
|
|
2061
|
+
async listAllSessionKeyScopes() {
|
|
2062
|
+
if (!__classPrivateFieldGet(this, _AirService_isAuthInitialized, "f"))
|
|
2063
|
+
throw new Error("Service is not initialized");
|
|
2064
|
+
await __classPrivateFieldGet(this, _AirService_instances, "m", _AirService_ensureWallet).call(this);
|
|
2065
|
+
try {
|
|
2066
|
+
const { payload } = await AirMessageService$1.sendListAllSessionKeyScopesRequest(__classPrivateFieldGet(this, _AirService_walletIframeController, "f").iframeElement);
|
|
2067
|
+
if (payload.success === false) {
|
|
2068
|
+
throw new AirServiceError(payload.errorName, payload.errorMessage);
|
|
2069
|
+
}
|
|
2070
|
+
return payload.sessionKeyScopes;
|
|
2071
|
+
}
|
|
2072
|
+
catch (error) {
|
|
2073
|
+
throw AirServiceError.from(error);
|
|
2074
|
+
}
|
|
2075
|
+
}
|
|
2040
2076
|
/**
|
|
2041
2077
|
* @experimental This method is experimental and will change in the future.
|
|
2042
2078
|
*/
|
|
@@ -2167,6 +2203,20 @@
|
|
|
2167
2203
|
clearEventListeners() {
|
|
2168
2204
|
__classPrivateFieldSet(this, _AirService_airAuthListener, [], "f");
|
|
2169
2205
|
}
|
|
2206
|
+
async getPartnerAccessToken() {
|
|
2207
|
+
if (!__classPrivateFieldGet(this, _AirService_isAuthInitialized, "f"))
|
|
2208
|
+
throw new Error("Service is not initialized");
|
|
2209
|
+
if (!this.isLoggedIn)
|
|
2210
|
+
throw new Error("No active session to get partner access token");
|
|
2211
|
+
const result = await AirMessageService$1.sendGetPartnerAccessTokenRequest(__classPrivateFieldGet(this, _AirService_authIframeController, "f").iframeElement);
|
|
2212
|
+
if (result.payload.success === false) {
|
|
2213
|
+
throw new AirServiceError(result.payload.errorName, result.payload.errorMessage);
|
|
2214
|
+
}
|
|
2215
|
+
if (!result.payload.partnerAccessToken) {
|
|
2216
|
+
throw new Error("Partner access token not found in response");
|
|
2217
|
+
}
|
|
2218
|
+
return result.payload.partnerAccessToken;
|
|
2219
|
+
}
|
|
2170
2220
|
}
|
|
2171
2221
|
_AirService_loginResult = new WeakMap(), _AirService_buildEnv = new WeakMap(), _AirService_enableLogging = new WeakMap(), _AirService_partnerId = new WeakMap(), _AirService_authIframeController = new WeakMap(), _AirService_isAuthInitialized = new WeakMap(), _AirService_airAuthListener = new WeakMap(), _AirService_walletIframeController = new WeakMap(), _AirService_walletInitialization = new WeakMap(), _AirService_walletLoggedInResult = new WeakMap(), _AirService_airWalletProvider = new WeakMap(), _AirService_instances = new WeakSet(), _AirService_ensureWallet = async function _AirService_ensureWallet(option) {
|
|
2172
2222
|
if (!this.isInitialized)
|
|
@@ -34,6 +34,10 @@ declare class AirService {
|
|
|
34
34
|
sessionOwnerPrivateKey: string;
|
|
35
35
|
permissionIds: string[];
|
|
36
36
|
}>;
|
|
37
|
+
/**
|
|
38
|
+
* @experimental This method is experimental and will change in the future.
|
|
39
|
+
*/
|
|
40
|
+
listAllSessionKeyScopes(): Promise<ActionPolicyInfo[]>;
|
|
37
41
|
/**
|
|
38
42
|
* @experimental This method is experimental and will change in the future.
|
|
39
43
|
*/
|
|
@@ -63,5 +67,6 @@ declare class AirService {
|
|
|
63
67
|
on(listener: AirEventListener): void;
|
|
64
68
|
off(listener: AirEventListener): void;
|
|
65
69
|
clearEventListeners(): void;
|
|
70
|
+
getPartnerAccessToken(): Promise<string>;
|
|
66
71
|
}
|
|
67
72
|
export default AirService;
|
|
@@ -23,6 +23,8 @@ export declare const AirAuthMessageTypes: {
|
|
|
23
23
|
readonly SIGN_SIWE_MESSAGE_RESPONSE: "air_auth_sign_siwe_message_response";
|
|
24
24
|
readonly CROSS_PARTNER_TOKEN_REQUEST: "air_auth_cross_partner_token_request";
|
|
25
25
|
readonly CROSS_PARTNER_TOKEN_RESPONSE: "air_auth_cross_partner_token_response";
|
|
26
|
+
readonly GET_PARTNER_ACCESS_TOKEN_REQUEST: "air_auth_get_partner_access_token_request";
|
|
27
|
+
readonly GET_PARTNER_ACCESS_TOKEN_RESPONSE: "air_auth_get_partner_access_token_response";
|
|
26
28
|
readonly LOGOUT_REQUEST: "air_auth_logout_request";
|
|
27
29
|
readonly LOGOUT_RESPONSE: "air_auth_logout_response";
|
|
28
30
|
readonly RESET_WALLET_COMMUNICATION: "air_auth_reset_wallet_communication";
|
|
@@ -133,5 +135,10 @@ export type AirAuthResetWalletCommunicationRequestMessage = AirAuthMessageBaseWi
|
|
|
133
135
|
export type AirAuthIframeVisibilityRequestMessage = AirAuthMessageBase<"air_auth_iframe_visibility_request", {
|
|
134
136
|
visible: boolean;
|
|
135
137
|
}>;
|
|
136
|
-
export type
|
|
138
|
+
export type AirAuthGetPartnerAccessTokenRequestMessage = AirAuthMessageBaseWithoutPayload<"air_auth_get_partner_access_token_request">;
|
|
139
|
+
export type AirAuthGetPartnerAccessTokenResponsePayload = AirAuthSuccess & {
|
|
140
|
+
partnerAccessToken: string;
|
|
141
|
+
};
|
|
142
|
+
export type AirAuthGetPartnerAccessTokenResponseMessage = AirAuthMessageBase<"air_auth_get_partner_access_token_response", AirAuthGetPartnerAccessTokenResponsePayload>;
|
|
143
|
+
export type AirAuthMessage = AirAuthSetupCompletedMessage | AirAuthInitializationRequestMessage | AirAuthInitializationResponseMessage | AirAuthLoginRequestMessage | AirAuthLoginResponseToEmbedMessage | AirAuthLoginResponseToWalletServiceMessage | AirAuthUserInfoRequestMessage | AirAuthUserInfoResponseMessage | AirAuthPartnerUserInfoRequestMessage | AirAuthPartnerUserInfoResponseMessage | AirAuthRefreshTokenRequestMessage | AirAuthRefreshTokenResponseMessage | AirAuthWalletTokenRequestMessage | AirAuthWalletTokenResponseMessage | AirAuthInitWalletCommunicationMessage | AirAuthSetupWalletRequestMessage | AirAuthSetupWalletResponseMessage | AirAuthSignSiweMessageRequestMessage | AirAuthSignSiweMessageResponseMessage | AirAuthCrossPartnerTokenRequestMessage | AirAuthCrossPartnerTokenResponseMessage | AirAuthLogoutRequestMessage | AirAuthLogoutResponseMessage | AirAuthIframeVisibilityRequestMessage | AirAuthResetWalletCommunicationRequestMessage | AirAuthGetPartnerAccessTokenRequestMessage | AirAuthGetPartnerAccessTokenResponseMessage;
|
|
137
144
|
export {};
|
|
@@ -22,6 +22,8 @@ export declare const AirMessageTypes: {
|
|
|
22
22
|
readonly EXECUTE_ACTION_RESPONSE: "air_execute_action_response";
|
|
23
23
|
readonly REVOKE_PERMISSIONS_REQUEST: "air_revoke_permissions_request";
|
|
24
24
|
readonly REVOKE_PERMISSIONS_RESPONSE: "air_revoke_permissions_response";
|
|
25
|
+
readonly LIST_ALL_SESSION_KEY_SCOPES_REQUEST: "air_list_all_session_key_scopes_request";
|
|
26
|
+
readonly LIST_ALL_SESSION_KEY_SCOPES_RESPONSE: "air_list_all_session_key_scopes_response";
|
|
25
27
|
readonly WALLET_IFRAME_VISIBILITY_REQUEST: "air_wallet_iframe_visibility_request";
|
|
26
28
|
readonly IS_SMART_ACCOUNT_DEPLOYED_REQUEST: "air_is_smart_account_deployed_request";
|
|
27
29
|
readonly IS_SMART_ACCOUNT_DEPLOYED_RESPONSE: "air_is_smart_account_deployed_response";
|
|
@@ -114,10 +116,16 @@ export type AirRevokePermissionsResponseMessage = AirMessageBase<"air_revoke_per
|
|
|
114
116
|
export type AirExecuteActionResponseMessage = AirMessageBase<"air_execute_action_response", (AirSuccessPayload & {
|
|
115
117
|
txHash: string;
|
|
116
118
|
}) | AirErrorPayload>;
|
|
119
|
+
export type AirListAllSessionKeyScopesSuccess = {
|
|
120
|
+
success: true;
|
|
121
|
+
sessionKeyScopes: ActionPolicyInfo[];
|
|
122
|
+
};
|
|
123
|
+
export type AirListAllSessionKeyScopesRequestMessage = AirMessageBaseWithoutPayload<"air_list_all_session_key_scopes_request">;
|
|
124
|
+
export type AirListAllSessionKeyScopesResponseMessage = AirMessageBase<"air_list_all_session_key_scopes_response", AirListAllSessionKeyScopesSuccess | AirErrorPayload>;
|
|
117
125
|
export type AirWalletIframeVisibilityRequestMessage = AirMessageBase<"air_wallet_iframe_visibility_request", {
|
|
118
126
|
visible: boolean;
|
|
119
127
|
}>;
|
|
120
128
|
export type AirLogoutRequestMessage = AirMessageBaseWithoutPayload<"air_logout_request">;
|
|
121
129
|
export type AirLogoutResponseMessage = AirMessageBase<"air_logout_response", AirSuccessPayload | AirErrorPayload>;
|
|
122
|
-
export type AirMessage = AirInitializationRequestMessage | AirInitializationResponseMessage | AirWalletInitializedMessage | AirWalletLoginRequestMessage | AirWalletLoginResponseMessage | AirSetupMfaRequestMessage | AirSetupMfaResponseMessage | AirClaimIdRequestMessage | AirClaimIdResponseMessage | AirInitAuthCommunicationMessage | AirIsSmartAccountDeployedRequestMessage | AirIsSmartAccountDeployedResponseMessage | AirDeploySmartAccountRequestMessage | AirDeploySmartAccountResponseMessage | AirGrantPermissionsRequestMessage | AirGrantPermissionsResponseMessage | AirRevokePermissionsRequestMessage | AirRevokePermissionsResponseMessage | AirExecuteActionRequestMessage | AirExecuteActionResponseMessage | AirWalletIframeVisibilityRequestMessage | AirLogoutRequestMessage | AirLogoutResponseMessage;
|
|
130
|
+
export type AirMessage = AirInitializationRequestMessage | AirInitializationResponseMessage | AirWalletInitializedMessage | AirWalletLoginRequestMessage | AirWalletLoginResponseMessage | AirSetupMfaRequestMessage | AirSetupMfaResponseMessage | AirClaimIdRequestMessage | AirClaimIdResponseMessage | AirInitAuthCommunicationMessage | AirIsSmartAccountDeployedRequestMessage | AirIsSmartAccountDeployedResponseMessage | AirDeploySmartAccountRequestMessage | AirDeploySmartAccountResponseMessage | AirGrantPermissionsRequestMessage | AirGrantPermissionsResponseMessage | AirRevokePermissionsRequestMessage | AirRevokePermissionsResponseMessage | AirExecuteActionRequestMessage | AirExecuteActionResponseMessage | AirListAllSessionKeyScopesRequestMessage | AirListAllSessionKeyScopesResponseMessage | AirWalletIframeVisibilityRequestMessage | AirLogoutRequestMessage | AirLogoutResponseMessage;
|
|
123
131
|
export {};
|
|
@@ -46,6 +46,7 @@ declare class AirMessageService {
|
|
|
46
46
|
sendWalletInitializationRequest(walletIframe: HTMLIFrameElement, payload: AirInitializationRequestMessage["payload"]): Promise<import("./common/realm/messaging/types").AirInitializationResponseMessage>;
|
|
47
47
|
sendCrossPartnerTokenRequest(authIframe: HTMLIFrameElement, targetPartnerUrl: string): Promise<import("./common/realm/messaging/auth").AirAuthCrossPartnerTokenResponseMessage>;
|
|
48
48
|
sendGrantPermissionsRequest(walletIframe: HTMLIFrameElement, payload: AirGrantPermissionsRequestMessage["payload"]): Promise<import("./common/realm/messaging/types").AirGrantPermissionsResponseMessage>;
|
|
49
|
+
sendListAllSessionKeyScopesRequest(walletIframe: HTMLIFrameElement): Promise<import("./common/realm/messaging/types").AirListAllSessionKeyScopesResponseMessage>;
|
|
49
50
|
onWalletInitialized(): Promise<import("./common/realm/messaging/types").AirWalletInitializedMessage>;
|
|
50
51
|
sendWalletLoginRequest(walletIframe: HTMLIFrameElement): Promise<import("./common/realm/messaging/types").AirWalletLoginResponseMessage>;
|
|
51
52
|
sendSetupMfaRequest(walletIframe: HTMLIFrameElement): Promise<import("./common/realm/messaging/types").AirSetupMfaResponseMessage>;
|
|
@@ -57,6 +58,7 @@ declare class AirMessageService {
|
|
|
57
58
|
private setupAuthObservables;
|
|
58
59
|
private setupAirObservables;
|
|
59
60
|
private setupWalletObservables;
|
|
61
|
+
sendGetPartnerAccessTokenRequest(authIframe: HTMLIFrameElement): Promise<import("./common/realm/messaging/auth").AirAuthGetPartnerAccessTokenResponseMessage>;
|
|
60
62
|
}
|
|
61
63
|
declare const _default: AirMessageService;
|
|
62
64
|
export default _default;
|