@abtnode/blocklet-services 1.7.8 → 1.7.11
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/api/index.js +41 -1
- package/api/routes/blocklet.js +2 -2
- package/api/services/auth/connect/login.js +9 -1
- package/api/services/auth/connect/switch-passport.js +107 -0
- package/api/services/auth/connect/switch-profile.js +60 -0
- package/api/services/auth/index.js +4 -0
- package/api/util/attach-shared-utils.js +1 -1
- package/api/util/index.js +8 -2
- package/build/asset-manifest.json +32 -34
- package/build/index.html +1 -1
- package/build/precache-manifest.6bba5a0937fec8cc0577975770db10ff.js +114 -0
- package/build/service-worker.js +1 -1
- package/build/static/css/4.6e1172e8.chunk.css +2 -0
- package/build/static/css/4.6e1172e8.chunk.css.map +1 -0
- package/build/static/js/0.8641a485.chunk.js +3 -0
- package/build/static/js/{0.eaf6eaf4.chunk.js.LICENSE.txt → 0.8641a485.chunk.js.LICENSE.txt} +0 -0
- package/build/static/js/0.8641a485.chunk.js.map +1 -0
- package/build/static/js/1.d6f10e20.chunk.js +2 -0
- package/build/static/js/1.d6f10e20.chunk.js.map +1 -0
- package/build/static/js/10.eae356ec.chunk.js +2 -0
- package/build/static/js/10.eae356ec.chunk.js.map +1 -0
- package/build/static/js/4.973ae192.chunk.js +3 -0
- package/build/static/js/{4.76d33dd5.chunk.js.LICENSE.txt → 4.973ae192.chunk.js.LICENSE.txt} +0 -0
- package/build/static/js/4.973ae192.chunk.js.map +1 -0
- package/build/static/js/5.a97b78a4.chunk.js +2 -0
- package/build/static/js/5.a97b78a4.chunk.js.map +1 -0
- package/build/static/js/6.60aaf58a.chunk.js +2 -0
- package/build/static/js/6.60aaf58a.chunk.js.map +1 -0
- package/build/static/js/7.6ffbad13.chunk.js +2 -0
- package/build/static/js/7.6ffbad13.chunk.js.map +1 -0
- package/build/static/js/8.7e2dd683.chunk.js +2 -0
- package/build/static/js/8.7e2dd683.chunk.js.map +1 -0
- package/build/static/js/9.9561f820.chunk.js +2 -0
- package/build/static/js/{9.7e4058e6.chunk.js.map → 9.9561f820.chunk.js.map} +1 -1
- package/build/static/js/main.73e47d11.chunk.js +2 -0
- package/build/static/js/main.73e47d11.chunk.js.map +1 -0
- package/build/static/js/{runtime-main.64859e7d.js → runtime-main.d47db38c.js} +2 -2
- package/build/static/js/{runtime-main.64859e7d.js.map → runtime-main.d47db38c.js.map} +1 -1
- package/package.json +26 -27
- package/build/precache-manifest.e66a1944c5bb1778fa8adfe34f4c1f85.js +0 -186
- package/build/static/css/4.634341e0.chunk.css +0 -2
- package/build/static/css/4.634341e0.chunk.css.map +0 -1
- package/build/static/js/0.eaf6eaf4.chunk.js +0 -3
- package/build/static/js/0.eaf6eaf4.chunk.js.map +0 -1
- package/build/static/js/1.1492a6e4.chunk.js +0 -2
- package/build/static/js/1.1492a6e4.chunk.js.map +0 -1
- package/build/static/js/10.434fab75.chunk.js +0 -2
- package/build/static/js/10.434fab75.chunk.js.map +0 -1
- package/build/static/js/4.76d33dd5.chunk.js +0 -3
- package/build/static/js/4.76d33dd5.chunk.js.map +0 -1
- package/build/static/js/5.011a4e81.chunk.js +0 -2
- package/build/static/js/5.011a4e81.chunk.js.map +0 -1
- package/build/static/js/6.7b36f606.chunk.js +0 -2
- package/build/static/js/6.7b36f606.chunk.js.map +0 -1
- package/build/static/js/7.e474a8ba.chunk.js +0 -2
- package/build/static/js/7.e474a8ba.chunk.js.map +0 -1
- package/build/static/js/8.9861fd50.chunk.js +0 -2
- package/build/static/js/8.9861fd50.chunk.js.map +0 -1
- package/build/static/js/9.7e4058e6.chunk.js +0 -2
- package/build/static/js/main.3bfc814a.chunk.js +0 -2
- package/build/static/js/main.3bfc814a.chunk.js.map +0 -1
- package/build/static/media/rubik-all-400-normal.c2324103.woff +0 -0
- package/build/static/media/rubik-all-500-normal.000c3408.woff +0 -0
- package/build/static/media/rubik-all-600-normal.30df2fd0.woff +0 -0
- package/build/static/media/rubik-cyrillic-400-normal.49f3ce37.woff2 +0 -0
- package/build/static/media/rubik-cyrillic-500-normal.0c1bd2ab.woff2 +0 -0
- package/build/static/media/rubik-cyrillic-600-normal.b76031ea.woff2 +0 -0
- package/build/static/media/rubik-cyrillic-ext-400-normal.d3902986.woff2 +0 -0
- package/build/static/media/rubik-cyrillic-ext-500-normal.7e493ee0.woff2 +0 -0
- package/build/static/media/rubik-cyrillic-ext-600-normal.f4b6c519.woff2 +0 -0
- package/build/static/media/rubik-hebrew-400-normal.0ebef856.woff2 +0 -0
- package/build/static/media/rubik-hebrew-500-normal.3664f2b5.woff2 +0 -0
- package/build/static/media/rubik-hebrew-600-normal.6207349a.woff2 +0 -0
- package/build/static/media/rubik-latin-400-normal.b836d2ed.woff2 +0 -0
- package/build/static/media/rubik-latin-500-normal.18984747.woff2 +0 -0
- package/build/static/media/rubik-latin-600-normal.b1216018.woff2 +0 -0
- package/build/static/media/rubik-latin-ext-400-normal.69a88832.woff2 +0 -0
- package/build/static/media/rubik-latin-ext-500-normal.21b63491.woff2 +0 -0
- package/build/static/media/rubik-latin-ext-600-normal.d0d90e83.woff2 +0 -0
- package/configs/auth.json +0 -67
package/api/index.js
CHANGED
|
@@ -76,7 +76,11 @@ module.exports = function createServer(node, serverOptions = {}) {
|
|
|
76
76
|
const notificationService = initNotification({ node, options });
|
|
77
77
|
|
|
78
78
|
// Proxy engine
|
|
79
|
-
const proxy = httpProxy.createProxyServer({
|
|
79
|
+
const proxy = httpProxy.createProxyServer({
|
|
80
|
+
timeout: 3600 * 1000,
|
|
81
|
+
proxyTimeout: 3600 * 1000,
|
|
82
|
+
});
|
|
83
|
+
|
|
80
84
|
proxy.safeWeb = (req, res, opts = {}) => {
|
|
81
85
|
proxy.web(req, res, opts, (error) => {
|
|
82
86
|
if (error) {
|
|
@@ -285,9 +289,45 @@ module.exports = function createServer(node, serverOptions = {}) {
|
|
|
285
289
|
wsRouter.use('**', async (req, socket, head) => {
|
|
286
290
|
const { target } = ensureProxyUrl(req);
|
|
287
291
|
if (target) {
|
|
292
|
+
let isOpen = false;
|
|
293
|
+
let timer;
|
|
294
|
+
let proxyReq;
|
|
295
|
+
|
|
296
|
+
const setProxyReq = (x) => {
|
|
297
|
+
proxyReq = x;
|
|
298
|
+
};
|
|
299
|
+
|
|
300
|
+
const setIsOpen = () => {
|
|
301
|
+
isOpen = true;
|
|
302
|
+
clearTimeout(timer);
|
|
303
|
+
};
|
|
304
|
+
|
|
305
|
+
proxy.once('open', setIsOpen);
|
|
306
|
+
proxy.once('proxyReqWs', setProxyReq);
|
|
307
|
+
|
|
308
|
+
timer = setTimeout(() => {
|
|
309
|
+
if (!isOpen) {
|
|
310
|
+
proxy.off('open', setIsOpen);
|
|
311
|
+
proxy.off('proxyReqWs', setProxyReq);
|
|
312
|
+
|
|
313
|
+
socket.write('HTTP/1.1 502 Proxy Timeout\r\n\r\n');
|
|
314
|
+
socket.destroy();
|
|
315
|
+
|
|
316
|
+
proxyReq?.destroy();
|
|
317
|
+
proxyReq = null;
|
|
318
|
+
}
|
|
319
|
+
}, 120 * 1000);
|
|
320
|
+
|
|
288
321
|
proxy.ws(req, socket, head, { target }, (error) => {
|
|
322
|
+
proxy.off('open', setIsOpen);
|
|
323
|
+
proxy.off('proxyReqWs', setProxyReq);
|
|
324
|
+
clearTimeout(timer);
|
|
325
|
+
proxyReq = null;
|
|
326
|
+
|
|
289
327
|
if (error) {
|
|
290
328
|
logger.error('socket proxy error', { from: req.url, to: target, error });
|
|
329
|
+
socket.write('HTTP/1.1 502 Proxy Error\r\n\r\n');
|
|
330
|
+
socket.destroy();
|
|
291
331
|
}
|
|
292
332
|
});
|
|
293
333
|
} else {
|
package/api/routes/blocklet.js
CHANGED
|
@@ -98,8 +98,6 @@ module.exports = {
|
|
|
98
98
|
});
|
|
99
99
|
|
|
100
100
|
if (fromSetup) {
|
|
101
|
-
await node.setBlockletInitialized({ did: blocklet.meta.did });
|
|
102
|
-
|
|
103
101
|
const { did: userDid, role } = req.user;
|
|
104
102
|
const { wallet, name, passportColor } = await req.getBlockletInfo();
|
|
105
103
|
const teamDid = blocklet.meta.did;
|
|
@@ -107,6 +105,8 @@ module.exports = {
|
|
|
107
105
|
const { pk, locale = 'en', extra = {} } = user;
|
|
108
106
|
const { baseUrl } = extra;
|
|
109
107
|
|
|
108
|
+
await node.setBlockletInitialized({ did: blocklet.meta.did, owner: { did: userDid, pk } });
|
|
109
|
+
|
|
110
110
|
// create vc
|
|
111
111
|
const vc = createPassportVC({
|
|
112
112
|
issuerName: name,
|
|
@@ -120,7 +120,7 @@ module.exports = function createRoutes(node, authenticator, createSessionToken)
|
|
|
120
120
|
// Get passport
|
|
121
121
|
const trustedPassports = (blocklet.trustedPassports || []).map((x) => x.issuerDid);
|
|
122
122
|
const trustedIssuers = [teamAppDid, ...trustedPassports].filter(Boolean);
|
|
123
|
-
|
|
123
|
+
const { vc: inputVC } = await getVCFromClaims({
|
|
124
124
|
claims,
|
|
125
125
|
challenge,
|
|
126
126
|
trustedIssuers,
|
|
@@ -128,6 +128,8 @@ module.exports = function createRoutes(node, authenticator, createSessionToken)
|
|
|
128
128
|
locale,
|
|
129
129
|
});
|
|
130
130
|
|
|
131
|
+
let vc = inputVC;
|
|
132
|
+
|
|
131
133
|
const config = (await req.getServiceConfig(NODE_SERVICES.AUTH)) || {};
|
|
132
134
|
const [invitedUserOnly, defaultRole, issuePassport] = await isInvitedUserOnly(config, node, teamDid);
|
|
133
135
|
|
|
@@ -240,6 +242,12 @@ module.exports = function createRoutes(node, authenticator, createSessionToken)
|
|
|
240
242
|
await updateSession({ sessionToken }, true);
|
|
241
243
|
logger.info('login.success', { userDid, role });
|
|
242
244
|
|
|
245
|
+
// if user provides owner passport AND app does not have owner, set this user to owner
|
|
246
|
+
if (inputVC && role === ROLES.OWNER && !blocklet.settings?.owner) {
|
|
247
|
+
logger.info('Bind owner for blocklet', { teamDid, userDid });
|
|
248
|
+
await node.setBlockletInitialized({ did: teamDid, owner: { did: userDid, pk: userPk } });
|
|
249
|
+
}
|
|
250
|
+
|
|
243
251
|
// issue passport for the first login user in a invite-only team
|
|
244
252
|
if (issuePassport) {
|
|
245
253
|
return {
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
const get = require('lodash/get');
|
|
2
|
+
const { messages, getVCFromClaims, getUser, validatePassportStatus } = require('@abtnode/auth/lib/auth');
|
|
3
|
+
const { ROLES, VC_TYPE_GENERAL_PASSPORT, VC_TYPE_NODE_PASSPORT } = require('@abtnode/constant');
|
|
4
|
+
const {
|
|
5
|
+
validatePassport,
|
|
6
|
+
isUserPassportRevoked,
|
|
7
|
+
getRoleFromLocalPassport,
|
|
8
|
+
getRoleFromExternalPassport,
|
|
9
|
+
createUserPassport,
|
|
10
|
+
} = require('@abtnode/auth/lib/passport');
|
|
11
|
+
|
|
12
|
+
const vcTypes = [VC_TYPE_GENERAL_PASSPORT, VC_TYPE_NODE_PASSPORT];
|
|
13
|
+
|
|
14
|
+
module.exports = function createRoutes(node, authenticator, createSessionToken) {
|
|
15
|
+
return {
|
|
16
|
+
action: 'switch-passport',
|
|
17
|
+
onConnect: async ({ req, userDid, extraParams: { locale, connectedDid } }) => {
|
|
18
|
+
if (userDid && connectedDid && userDid !== connectedDid) {
|
|
19
|
+
throw new Error(messages.userMismatch[locale]);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
const { wallet, did: teamDid } = await req.getBlockletInfo();
|
|
23
|
+
const user = await getUser(node, teamDid, userDid);
|
|
24
|
+
|
|
25
|
+
if (!user) {
|
|
26
|
+
throw new Error(messages.userNotFound[locale]);
|
|
27
|
+
}
|
|
28
|
+
if (!user.approved) {
|
|
29
|
+
throw new Error(messages.notAuthorized[locale]);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
return {
|
|
33
|
+
verifiableCredential: async ({ context }) => {
|
|
34
|
+
const { request } = context;
|
|
35
|
+
const blocklet = await request.getBlocklet();
|
|
36
|
+
|
|
37
|
+
const trustedPassports = (blocklet.trustedPassports || []).map((x) => x.issuerDid);
|
|
38
|
+
const trustedIssuers = [wallet.address, ...trustedPassports].filter(Boolean);
|
|
39
|
+
|
|
40
|
+
return {
|
|
41
|
+
description: messages.requestPassport[locale],
|
|
42
|
+
item: vcTypes,
|
|
43
|
+
trustedIssuers,
|
|
44
|
+
optional: false,
|
|
45
|
+
};
|
|
46
|
+
},
|
|
47
|
+
};
|
|
48
|
+
},
|
|
49
|
+
|
|
50
|
+
onAuth: async ({ claims, challenge, userDid, updateSession, extraParams, req }) => {
|
|
51
|
+
const { locale } = extraParams;
|
|
52
|
+
const blocklet = await req.getBlocklet();
|
|
53
|
+
const { wallet, name, did: teamDid } = await req.getBlockletInfo();
|
|
54
|
+
|
|
55
|
+
// Validate user
|
|
56
|
+
const user = await getUser(node, teamDid, userDid);
|
|
57
|
+
if (!user) {
|
|
58
|
+
throw new Error(messages.userNotFound[locale]);
|
|
59
|
+
}
|
|
60
|
+
if (!user.approved) {
|
|
61
|
+
throw new Error(messages.notAuthorized[locale]);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
// Get passport
|
|
65
|
+
const trustedPassports = (blocklet.trustedPassports || []).map((x) => x.issuerDid);
|
|
66
|
+
const trustedIssuers = [wallet.address, ...trustedPassports].filter(Boolean);
|
|
67
|
+
const { vc } = await getVCFromClaims({ claims, challenge, trustedIssuers, vcTypes, locale });
|
|
68
|
+
|
|
69
|
+
// Get user passport from vc
|
|
70
|
+
let passport = createUserPassport(vc);
|
|
71
|
+
if (passport && isUserPassportRevoked(user, passport)) {
|
|
72
|
+
throw new Error(messages.passportRevoked[locale](name));
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
// Get role
|
|
76
|
+
let role = ROLES.GUEST;
|
|
77
|
+
await validatePassport(get(vc, 'credentialSubject.passport'));
|
|
78
|
+
const issuerId = get(vc, 'issuer.id');
|
|
79
|
+
if (issuerId === wallet.address) {
|
|
80
|
+
role = getRoleFromLocalPassport(get(vc, 'credentialSubject.passport'));
|
|
81
|
+
} else {
|
|
82
|
+
// map external passport to local role
|
|
83
|
+
const { mappings = [] } = (blocklet.trustedPassports || []).find((x) => x.issuerDid === issuerId) || {};
|
|
84
|
+
role = await getRoleFromExternalPassport({
|
|
85
|
+
passport: get(vc, 'credentialSubject.passport'),
|
|
86
|
+
node,
|
|
87
|
+
teamDid,
|
|
88
|
+
locale,
|
|
89
|
+
mappings,
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
// check status of external passport if passport has an endpoint
|
|
93
|
+
const endpoint = get(vc, 'credentialStatus.id');
|
|
94
|
+
if (endpoint) {
|
|
95
|
+
await validatePassportStatus({ vcId: vc.id, endpoint, locale });
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
// Recreate passport with correct role
|
|
100
|
+
passport = createUserPassport(vc, { role });
|
|
101
|
+
|
|
102
|
+
// Generate new session token that client can save to localStorage
|
|
103
|
+
const sessionToken = await createSessionToken(userDid, { passport, role });
|
|
104
|
+
await updateSession({ sessionToken }, true);
|
|
105
|
+
},
|
|
106
|
+
};
|
|
107
|
+
};
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
const get = require('lodash/get');
|
|
2
|
+
const { messages, getUser } = require('@abtnode/auth/lib/auth');
|
|
3
|
+
const { NODE_SERVICES } = require('@abtnode/constant');
|
|
4
|
+
|
|
5
|
+
module.exports = function createRoutes(node) {
|
|
6
|
+
return {
|
|
7
|
+
action: 'switch-profile',
|
|
8
|
+
onConnect: async ({ req, userDid, extraParams: { locale, connectedDid } }) => {
|
|
9
|
+
if (userDid && connectedDid && userDid !== connectedDid) {
|
|
10
|
+
throw new Error(messages.userMismatch[locale]);
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
const config = await req.getServiceConfig(NODE_SERVICES.AUTH);
|
|
14
|
+
if (get(config, 'allowSwitchProfile', true) === false) {
|
|
15
|
+
throw new Error(messages.actionForbidden[locale]);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const { did: teamDid } = await req.getBlockletInfo();
|
|
19
|
+
const user = await getUser(node, teamDid, userDid);
|
|
20
|
+
|
|
21
|
+
if (!user) {
|
|
22
|
+
throw new Error(messages.userNotFound[locale]);
|
|
23
|
+
}
|
|
24
|
+
if (!user.approved) {
|
|
25
|
+
throw new Error(messages.notAuthorized[locale]);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
return {
|
|
29
|
+
profile: {
|
|
30
|
+
fields: get(config, 'profileFields') || ['fullName', 'avatar'],
|
|
31
|
+
description: messages.description[locale],
|
|
32
|
+
},
|
|
33
|
+
};
|
|
34
|
+
},
|
|
35
|
+
|
|
36
|
+
onAuth: async ({ req, claims, userDid, extraParams: { locale } }) => {
|
|
37
|
+
const { did: teamDid } = await req.getBlockletInfo();
|
|
38
|
+
|
|
39
|
+
// check user approved
|
|
40
|
+
const user = await getUser(node, teamDid, userDid);
|
|
41
|
+
if (!user) {
|
|
42
|
+
throw new Error(messages.userNotFound[locale]);
|
|
43
|
+
}
|
|
44
|
+
if (!user.approved) {
|
|
45
|
+
throw new Error(messages.notAuthorized[locale]);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// Update user
|
|
49
|
+
const profile = claims.find((x) => x.type === 'profile');
|
|
50
|
+
await node.updateUser({
|
|
51
|
+
teamDid,
|
|
52
|
+
user: {
|
|
53
|
+
...user,
|
|
54
|
+
...profile,
|
|
55
|
+
locale,
|
|
56
|
+
},
|
|
57
|
+
});
|
|
58
|
+
},
|
|
59
|
+
};
|
|
60
|
+
};
|
|
@@ -17,6 +17,8 @@ const createIssuePassportAuth = require('./connect/issue-passport');
|
|
|
17
17
|
const createLostPassportListAuth = require('./connect/lost-passport-list');
|
|
18
18
|
const createLostPassportIssueAuth = require('./connect/lost-passport-issue');
|
|
19
19
|
const createSetupAuth = require('./connect/setup');
|
|
20
|
+
const createSwitchProfileAuth = require('./connect/switch-profile');
|
|
21
|
+
const createSwitchPassportAuth = require('./connect/switch-passport');
|
|
20
22
|
const createSessionRoutes = require('./session');
|
|
21
23
|
const createPassportRoutes = require('./passport');
|
|
22
24
|
const { getRedirectUrl } = require('../../util');
|
|
@@ -126,6 +128,8 @@ const init = ({ node, options }) => {
|
|
|
126
128
|
handler.attach(Object.assign({ app }, createLostPassportListAuth(node, authenticator, createSessionToken)));
|
|
127
129
|
handler.attach(Object.assign({ app }, createLostPassportIssueAuth(node, authenticator, createSessionToken)));
|
|
128
130
|
handler.attach(Object.assign({ app }, createSetupAuth(node, authenticator, createSessionToken)));
|
|
131
|
+
handler.attach(Object.assign({ app }, createSwitchProfileAuth(node, authenticator, createSessionToken)));
|
|
132
|
+
handler.attach(Object.assign({ app }, createSwitchPassportAuth(node, authenticator, createSessionToken)));
|
|
129
133
|
});
|
|
130
134
|
};
|
|
131
135
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
const get = require('lodash/get');
|
|
2
2
|
|
|
3
3
|
const getBlockletInfo = require('@blocklet/meta/lib/info');
|
|
4
|
-
const { getDefaultServiceConfig, findService } = require('@
|
|
4
|
+
const { getDefaultServiceConfig, findService } = require('@blocklet/meta/lib/service');
|
|
5
5
|
const logger = require('@abtnode/logger')(require('../../package.json').name);
|
|
6
6
|
const cache = require('../cache');
|
|
7
7
|
|
package/api/util/index.js
CHANGED
|
@@ -31,7 +31,7 @@ const getLogoFromLogoUrl = (blocklet, version) => {
|
|
|
31
31
|
};
|
|
32
32
|
|
|
33
33
|
const getBlockletLogo = ({ baseUrl, blocklet }) => {
|
|
34
|
-
const version = blocklet
|
|
34
|
+
const version = get(blocklet, 'meta.version', '');
|
|
35
35
|
|
|
36
36
|
if (!baseUrl) {
|
|
37
37
|
return getLogoFromLogoUrl(blocklet, version);
|
|
@@ -77,9 +77,11 @@ const ensureProxyUrl = (req) => {
|
|
|
77
77
|
|
|
78
78
|
const getRedirectUrl = ({ req, pagePath }) => {
|
|
79
79
|
const baseUrl = getBaseUrl(req);
|
|
80
|
-
|
|
81
80
|
const redirectUrlObj = new URL(`http://localhost${req.url}`);
|
|
81
|
+
// 重定向时考虑 serverUrl 查询参数的处理
|
|
82
|
+
const serverUrl = redirectUrlObj.searchParams.get('serverUrl');
|
|
82
83
|
redirectUrlObj.searchParams.delete('__start__');
|
|
84
|
+
redirectUrlObj.searchParams.delete('serverUrl');
|
|
83
85
|
const redirectUrl = `${baseUrl.replace(/\/+$/, '')}${redirectUrlObj.pathname}${redirectUrlObj.search}`;
|
|
84
86
|
|
|
85
87
|
const url = new URL(`http://localhost${joinUrl(baseUrl, WELLKNOWN_SERVICE_PATH_PREFIX, pagePath || '/')}`);
|
|
@@ -90,6 +92,10 @@ const getRedirectUrl = ({ req, pagePath }) => {
|
|
|
90
92
|
url.searchParams.set('locale', locale);
|
|
91
93
|
}
|
|
92
94
|
|
|
95
|
+
if (serverUrl) {
|
|
96
|
+
url.searchParams.set('serverUrl', serverUrl);
|
|
97
|
+
}
|
|
98
|
+
|
|
93
99
|
return `${url.pathname}${url.search}`;
|
|
94
100
|
};
|
|
95
101
|
|
|
@@ -1,43 +1,41 @@
|
|
|
1
1
|
{
|
|
2
2
|
"files": {
|
|
3
|
-
"static/js/0.
|
|
4
|
-
"static/js/0.
|
|
5
|
-
"static/js/1.
|
|
6
|
-
"static/js/1.
|
|
7
|
-
"main.js": "/.blocklet/proxy/blocklet-service/static/js/main.
|
|
8
|
-
"main.js.map": "/.blocklet/proxy/blocklet-service/static/js/main.
|
|
9
|
-
"runtime-main.js": "/.blocklet/proxy/blocklet-service/static/js/runtime-main.
|
|
10
|
-
"runtime-main.js.map": "/.blocklet/proxy/blocklet-service/static/js/runtime-main.
|
|
11
|
-
"static/css/4.
|
|
12
|
-
"static/js/4.
|
|
13
|
-
"static/js/4.
|
|
14
|
-
"static/js/5.
|
|
15
|
-
"static/js/5.
|
|
16
|
-
"static/js/6.
|
|
17
|
-
"static/js/6.
|
|
18
|
-
"static/js/7.
|
|
19
|
-
"static/js/7.
|
|
20
|
-
"static/js/8.
|
|
21
|
-
"static/js/8.
|
|
22
|
-
"static/js/9.
|
|
23
|
-
"static/js/9.
|
|
24
|
-
"static/js/10.
|
|
25
|
-
"static/js/10.
|
|
3
|
+
"static/js/0.8641a485.chunk.js": "/.blocklet/proxy/blocklet-service/static/js/0.8641a485.chunk.js",
|
|
4
|
+
"static/js/0.8641a485.chunk.js.map": "/.blocklet/proxy/blocklet-service/static/js/0.8641a485.chunk.js.map",
|
|
5
|
+
"static/js/1.d6f10e20.chunk.js": "/.blocklet/proxy/blocklet-service/static/js/1.d6f10e20.chunk.js",
|
|
6
|
+
"static/js/1.d6f10e20.chunk.js.map": "/.blocklet/proxy/blocklet-service/static/js/1.d6f10e20.chunk.js.map",
|
|
7
|
+
"main.js": "/.blocklet/proxy/blocklet-service/static/js/main.73e47d11.chunk.js",
|
|
8
|
+
"main.js.map": "/.blocklet/proxy/blocklet-service/static/js/main.73e47d11.chunk.js.map",
|
|
9
|
+
"runtime-main.js": "/.blocklet/proxy/blocklet-service/static/js/runtime-main.d47db38c.js",
|
|
10
|
+
"runtime-main.js.map": "/.blocklet/proxy/blocklet-service/static/js/runtime-main.d47db38c.js.map",
|
|
11
|
+
"static/css/4.6e1172e8.chunk.css": "/.blocklet/proxy/blocklet-service/static/css/4.6e1172e8.chunk.css",
|
|
12
|
+
"static/js/4.973ae192.chunk.js": "/.blocklet/proxy/blocklet-service/static/js/4.973ae192.chunk.js",
|
|
13
|
+
"static/js/4.973ae192.chunk.js.map": "/.blocklet/proxy/blocklet-service/static/js/4.973ae192.chunk.js.map",
|
|
14
|
+
"static/js/5.a97b78a4.chunk.js": "/.blocklet/proxy/blocklet-service/static/js/5.a97b78a4.chunk.js",
|
|
15
|
+
"static/js/5.a97b78a4.chunk.js.map": "/.blocklet/proxy/blocklet-service/static/js/5.a97b78a4.chunk.js.map",
|
|
16
|
+
"static/js/6.60aaf58a.chunk.js": "/.blocklet/proxy/blocklet-service/static/js/6.60aaf58a.chunk.js",
|
|
17
|
+
"static/js/6.60aaf58a.chunk.js.map": "/.blocklet/proxy/blocklet-service/static/js/6.60aaf58a.chunk.js.map",
|
|
18
|
+
"static/js/7.6ffbad13.chunk.js": "/.blocklet/proxy/blocklet-service/static/js/7.6ffbad13.chunk.js",
|
|
19
|
+
"static/js/7.6ffbad13.chunk.js.map": "/.blocklet/proxy/blocklet-service/static/js/7.6ffbad13.chunk.js.map",
|
|
20
|
+
"static/js/8.7e2dd683.chunk.js": "/.blocklet/proxy/blocklet-service/static/js/8.7e2dd683.chunk.js",
|
|
21
|
+
"static/js/8.7e2dd683.chunk.js.map": "/.blocklet/proxy/blocklet-service/static/js/8.7e2dd683.chunk.js.map",
|
|
22
|
+
"static/js/9.9561f820.chunk.js": "/.blocklet/proxy/blocklet-service/static/js/9.9561f820.chunk.js",
|
|
23
|
+
"static/js/9.9561f820.chunk.js.map": "/.blocklet/proxy/blocklet-service/static/js/9.9561f820.chunk.js.map",
|
|
24
|
+
"static/js/10.eae356ec.chunk.js": "/.blocklet/proxy/blocklet-service/static/js/10.eae356ec.chunk.js",
|
|
25
|
+
"static/js/10.eae356ec.chunk.js.map": "/.blocklet/proxy/blocklet-service/static/js/10.eae356ec.chunk.js.map",
|
|
26
26
|
"index.html": "/.blocklet/proxy/blocklet-service/index.html",
|
|
27
|
-
"precache-manifest.
|
|
27
|
+
"precache-manifest.6bba5a0937fec8cc0577975770db10ff.js": "/.blocklet/proxy/blocklet-service/precache-manifest.6bba5a0937fec8cc0577975770db10ff.js",
|
|
28
28
|
"service-worker.js": "/.blocklet/proxy/blocklet-service/service-worker.js",
|
|
29
|
-
"static/css/4.
|
|
30
|
-
"static/js/0.
|
|
31
|
-
"static/js/4.
|
|
29
|
+
"static/css/4.6e1172e8.chunk.css.map": "/.blocklet/proxy/blocklet-service/static/css/4.6e1172e8.chunk.css.map",
|
|
30
|
+
"static/js/0.8641a485.chunk.js.LICENSE.txt": "/.blocklet/proxy/blocklet-service/static/js/0.8641a485.chunk.js.LICENSE.txt",
|
|
31
|
+
"static/js/4.973ae192.chunk.js.LICENSE.txt": "/.blocklet/proxy/blocklet-service/static/js/4.973ae192.chunk.js.LICENSE.txt",
|
|
32
32
|
"static/media/400.css": "/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-latin-ext-400-normal.84fa8bc1.woff2",
|
|
33
|
-
"static/media/700.css": "/.blocklet/proxy/blocklet-service/static/media/lato-latin-ext-700-normal.a48b0f04.woff2"
|
|
34
|
-
"static/media/500.css": "/.blocklet/proxy/blocklet-service/static/media/rubik-latin-ext-500-normal.21b63491.woff2",
|
|
35
|
-
"static/media/600.css": "/.blocklet/proxy/blocklet-service/static/media/rubik-latin-ext-600-normal.d0d90e83.woff2"
|
|
33
|
+
"static/media/700.css": "/.blocklet/proxy/blocklet-service/static/media/lato-latin-ext-700-normal.a48b0f04.woff2"
|
|
36
34
|
},
|
|
37
35
|
"entrypoints": [
|
|
38
|
-
"static/js/runtime-main.
|
|
39
|
-
"static/css/4.
|
|
40
|
-
"static/js/4.
|
|
41
|
-
"static/js/main.
|
|
36
|
+
"static/js/runtime-main.d47db38c.js",
|
|
37
|
+
"static/css/4.6e1172e8.chunk.css",
|
|
38
|
+
"static/js/4.973ae192.chunk.js",
|
|
39
|
+
"static/js/main.73e47d11.chunk.js"
|
|
42
40
|
]
|
|
43
41
|
}
|
package/build/index.html
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
<!doctype html><html lang="en"><head><meta charset="utf-8"/><link rel="shortcut icon" href="/.well-known/service/static/favicon.ico"/><meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=0"/><meta name="theme-color" content="#000000"/><title>Blocklet Service</title><script src="/.well-known/service/api/env"></script><link href="/.blocklet/proxy/blocklet-service/static/css/4.
|
|
1
|
+
<!doctype html><html lang="en"><head><meta charset="utf-8"/><link rel="shortcut icon" href="/.well-known/service/static/favicon.ico"/><meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=0"/><meta name="theme-color" content="#000000"/><title>Blocklet Service</title><script src="/.well-known/service/api/env"></script><link href="/.blocklet/proxy/blocklet-service/static/css/4.6e1172e8.chunk.css" rel="stylesheet"></head><body><noscript>You need to enable JavaScript to run this app.</noscript><div id="root"></div><script>!function(e){function t(t){for(var n,c,i=t[0],l=t[1],f=t[2],s=t[3]||[],d=0,h=[];d<i.length;d++)c=i[d],Object.prototype.hasOwnProperty.call(o,c)&&o[c]&&h.push(o[c][0]),o[c]=0;for(n in l)Object.prototype.hasOwnProperty.call(l,n)&&(e[n]=l[n]);for(p&&p(t),u.push.apply(u,s);h.length;)h.shift()();return a.push.apply(a,f||[]),r()}function r(){for(var e,t=0;t<a.length;t++){for(var r=a[t],n=!0,l=1;l<r.length;l++){var f=r[l];0!==o[f]&&(n=!1)}n&&(a.splice(t--,1),e=i(i.s=r[0]))}return 0===a.length&&(u.forEach((function(e){if(void 0===o[e]){o[e]=null;var t=document.createElement("link");i.nc&&t.setAttribute("nonce",i.nc),t.rel="prefetch",t.as="script",t.href=c(e),document.head.appendChild(t)}})),u.length=0),e}var n={},o={3:0},a=[],u=[];function c(e){return i.p+"static/js/"+({}[e]||e)+"."+{0:"8641a485",1:"d6f10e20",5:"a97b78a4",6:"60aaf58a",7:"6ffbad13",8:"7e2dd683",9:"9561f820",10:"eae356ec"}[e]+".chunk.js"}function i(t){if(n[t])return n[t].exports;var r=n[t]={i:t,l:!1,exports:{}};return e[t].call(r.exports,r,r.exports,i),r.l=!0,r.exports}i.e=function(e){var t=[],r=o[e];if(0!==r)if(r)t.push(r[2]);else{var n=new Promise((function(t,n){r=o[e]=[t,n]}));t.push(r[2]=n);var a,u=document.createElement("script");u.charset="utf-8",u.timeout=120,i.nc&&u.setAttribute("nonce",i.nc),u.src=c(e);var l=new Error;a=function(t){u.onerror=u.onload=null,clearTimeout(f);var r=o[e];if(0!==r){if(r){var n=t&&("load"===t.type?"missing":t.type),a=t&&t.target&&t.target.src;l.message="Loading chunk "+e+" failed.\n("+n+": "+a+")",l.name="ChunkLoadError",l.type=n,l.request=a,r[1](l)}o[e]=void 0}};var f=setTimeout((function(){a({type:"timeout",target:u})}),12e4);u.onerror=u.onload=a,document.head.appendChild(u)}return Promise.all(t)},i.m=e,i.c=n,i.d=function(e,t,r){i.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},i.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},i.t=function(e,t){if(1&t&&(e=i(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(i.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var n in e)i.d(r,n,function(t){return e[t]}.bind(null,n));return r},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,"a",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p="/.blocklet/proxy/blocklet-service/",i.oe=function(e){throw console.error(e),e};var l=this["webpackJsonp@abtnode/blocklet-services"]=this["webpackJsonp@abtnode/blocklet-services"]||[],f=l.push.bind(l);l.push=t,l=l.slice();for(var s=0;s<l.length;s++)t(l[s]);var p=f;r()}([])</script><script src="/.blocklet/proxy/blocklet-service/static/js/4.973ae192.chunk.js"></script><script src="/.blocklet/proxy/blocklet-service/static/js/main.73e47d11.chunk.js"></script></body></html>
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
self.__precacheManifest = (self.__precacheManifest || []).concat([
|
|
2
|
+
{
|
|
3
|
+
"revision": "17b89e7b66ac3ce0d38d406f58ff7617",
|
|
4
|
+
"url": "/.blocklet/proxy/blocklet-service/index.html"
|
|
5
|
+
},
|
|
6
|
+
{
|
|
7
|
+
"revision": "21fa9fb0eb31456e8a3a",
|
|
8
|
+
"url": "/.blocklet/proxy/blocklet-service/static/css/4.6e1172e8.chunk.css"
|
|
9
|
+
},
|
|
10
|
+
{
|
|
11
|
+
"revision": "0f753569d791e77fb7fe",
|
|
12
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/0.8641a485.chunk.js"
|
|
13
|
+
},
|
|
14
|
+
{
|
|
15
|
+
"revision": "327dea51c54983f5708f4242bceacaed",
|
|
16
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/0.8641a485.chunk.js.LICENSE.txt"
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
"revision": "85120b3c1f61c452cbcf",
|
|
20
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/1.d6f10e20.chunk.js"
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
"revision": "41837fa479ea4ec70880",
|
|
24
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/10.eae356ec.chunk.js"
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
"revision": "21fa9fb0eb31456e8a3a",
|
|
28
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/4.973ae192.chunk.js"
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
"revision": "ff58a668e6d753fa035087a671c28199",
|
|
32
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/4.973ae192.chunk.js.LICENSE.txt"
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
"revision": "8dd20f1b08a1809a0506",
|
|
36
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/5.a97b78a4.chunk.js"
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
"revision": "2ef366c977548d4b126b",
|
|
40
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/6.60aaf58a.chunk.js"
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
"revision": "720fa5bd6dd6387ed923",
|
|
44
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/7.6ffbad13.chunk.js"
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
"revision": "e9a09e425c605f74b307",
|
|
48
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/8.7e2dd683.chunk.js"
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
"revision": "e3f6d6b168900962d252",
|
|
52
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/9.9561f820.chunk.js"
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
"revision": "0d137dbd2339ca1d9a64",
|
|
56
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/main.73e47d11.chunk.js"
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
"revision": "9a17203f116f3efb5e79",
|
|
60
|
+
"url": "/.blocklet/proxy/blocklet-service/static/js/runtime-main.d47db38c.js"
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
"revision": "a82dcb33d52ed6fa529e5ae8d5fda7f3",
|
|
64
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/lato-all-400-normal.a82dcb33.woff"
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
"revision": "8190ee0ec407348bfdc1daad2c035281",
|
|
68
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/lato-all-700-normal.8190ee0e.woff"
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
"revision": "e1b3b5908c9cf23dfb2b9c52b9a023ab",
|
|
72
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/lato-latin-400-normal.e1b3b590.woff2"
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
"revision": "de69cf9e514df447d1b0bb16f49d2457",
|
|
76
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/lato-latin-700-normal.de69cf9e.woff2"
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
"revision": "4bde07f991ba6af69a1e009fd7ce9d1a",
|
|
80
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/lato-latin-ext-400-normal.4bde07f9.woff2"
|
|
81
|
+
},
|
|
82
|
+
{
|
|
83
|
+
"revision": "a48b0f049358d7503c497abb4dcbc4d6",
|
|
84
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/lato-latin-ext-700-normal.a48b0f04.woff2"
|
|
85
|
+
},
|
|
86
|
+
{
|
|
87
|
+
"revision": "50636a553bb564fe4fe8dc664d85b298",
|
|
88
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-all-400-normal.50636a55.woff"
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
"revision": "d8183030e0fe9f809fdf84cb488fca64",
|
|
92
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-cyrillic-400-normal.d8183030.woff2"
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
"revision": "918b4f73b73f6a405af57abf5a9de9f2",
|
|
96
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-cyrillic-ext-400-normal.918b4f73.woff2"
|
|
97
|
+
},
|
|
98
|
+
{
|
|
99
|
+
"revision": "5334a11ece16a5954e0635afa7668b08",
|
|
100
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-greek-400-normal.5334a11e.woff2"
|
|
101
|
+
},
|
|
102
|
+
{
|
|
103
|
+
"revision": "df389c9932278468b5b0bcdbc9864163",
|
|
104
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-greek-ext-400-normal.df389c99.woff2"
|
|
105
|
+
},
|
|
106
|
+
{
|
|
107
|
+
"revision": "8d1b929856b2ef150dc86f2f38a5dc5b",
|
|
108
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-latin-400-normal.8d1b9298.woff2"
|
|
109
|
+
},
|
|
110
|
+
{
|
|
111
|
+
"revision": "84fa8bc12ba88bbb2144273fa45b508b",
|
|
112
|
+
"url": "/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-latin-ext-400-normal.84fa8bc1.woff2"
|
|
113
|
+
}
|
|
114
|
+
]);
|
package/build/service-worker.js
CHANGED
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
importScripts("https://storage.googleapis.com/workbox-cdn/releases/4.3.1/workbox-sw.js");
|
|
15
15
|
|
|
16
16
|
importScripts(
|
|
17
|
-
"/.blocklet/proxy/blocklet-service/precache-manifest.
|
|
17
|
+
"/.blocklet/proxy/blocklet-service/precache-manifest.6bba5a0937fec8cc0577975770db10ff.js"
|
|
18
18
|
);
|
|
19
19
|
|
|
20
20
|
self.addEventListener('message', (event) => {
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
@font-face{font-family:"Lato";font-style:normal;font-display:swap;font-weight:400;src:url(/.blocklet/proxy/blocklet-service/static/media/lato-latin-ext-400-normal.4bde07f9.woff2) format("woff2"),url(/.blocklet/proxy/blocklet-service/static/media/lato-all-400-normal.a82dcb33.woff) format("woff");unicode-range:U+0100-024f,U+0259,U+1e??,U+2020,U+20a0-20ab,U+20ad-20cf,U+2113,U+2c60-2c7f,U+a720-a7ff}@font-face{font-family:"Lato";font-style:normal;font-display:swap;font-weight:400;src:url(/.blocklet/proxy/blocklet-service/static/media/lato-latin-400-normal.e1b3b590.woff2) format("woff2"),url(/.blocklet/proxy/blocklet-service/static/media/lato-all-400-normal.a82dcb33.woff) format("woff");unicode-range:U+00??,U+0131,U+0152-0153,U+02bb-02bc,U+02c6,U+02da,U+02dc,U+2000-206f,U+2074,U+20ac,U+2122,U+2191,U+2193,U+2212,U+2215,U+feff,U+fffd}@font-face{font-family:"Lato";font-style:normal;font-display:swap;font-weight:700;src:url(/.blocklet/proxy/blocklet-service/static/media/lato-latin-ext-700-normal.a48b0f04.woff2) format("woff2"),url(/.blocklet/proxy/blocklet-service/static/media/lato-all-700-normal.8190ee0e.woff) format("woff");unicode-range:U+0100-024f,U+0259,U+1e??,U+2020,U+20a0-20ab,U+20ad-20cf,U+2113,U+2c60-2c7f,U+a720-a7ff}@font-face{font-family:"Lato";font-style:normal;font-display:swap;font-weight:700;src:url(/.blocklet/proxy/blocklet-service/static/media/lato-latin-700-normal.de69cf9e.woff2) format("woff2"),url(/.blocklet/proxy/blocklet-service/static/media/lato-all-700-normal.8190ee0e.woff) format("woff");unicode-range:U+00??,U+0131,U+0152-0153,U+02bb-02bc,U+02c6,U+02da,U+02dc,U+2000-206f,U+2074,U+20ac,U+2122,U+2191,U+2193,U+2212,U+2215,U+feff,U+fffd}@font-face{font-family:"Ubuntu Mono";font-style:normal;font-display:swap;font-weight:400;src:url(/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-cyrillic-ext-400-normal.918b4f73.woff2) format("woff2"),url(/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-all-400-normal.50636a55.woff) format("woff");unicode-range:U+0460-052f,U+1c80-1c88,U+20b4,U+2de0-2dff,U+a640-a69f,U+fe2e-fe2f}@font-face{font-family:"Ubuntu Mono";font-style:normal;font-display:swap;font-weight:400;src:url(/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-cyrillic-400-normal.d8183030.woff2) format("woff2"),url(/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-all-400-normal.50636a55.woff) format("woff");unicode-range:U+0400-045f,U+0490-0491,U+04b0-04b1,U+2116}@font-face{font-family:"Ubuntu Mono";font-style:normal;font-display:swap;font-weight:400;src:url(/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-greek-ext-400-normal.df389c99.woff2) format("woff2"),url(/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-all-400-normal.50636a55.woff) format("woff");unicode-range:U+1f??}@font-face{font-family:"Ubuntu Mono";font-style:normal;font-display:swap;font-weight:400;src:url(/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-greek-400-normal.5334a11e.woff2) format("woff2"),url(/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-all-400-normal.50636a55.woff) format("woff");unicode-range:U+0370-03ff}@font-face{font-family:"Ubuntu Mono";font-style:normal;font-display:swap;font-weight:400;src:url(/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-latin-ext-400-normal.84fa8bc1.woff2) format("woff2"),url(/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-all-400-normal.50636a55.woff) format("woff");unicode-range:U+0100-024f,U+0259,U+1e??,U+2020,U+20a0-20ab,U+20ad-20cf,U+2113,U+2c60-2c7f,U+a720-a7ff}@font-face{font-family:"Ubuntu Mono";font-style:normal;font-display:swap;font-weight:400;src:url(/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-latin-400-normal.8d1b9298.woff2) format("woff2"),url(/.blocklet/proxy/blocklet-service/static/media/ubuntu-mono-all-400-normal.50636a55.woff) format("woff");unicode-range:U+00??,U+0131,U+0152-0153,U+02bb-02bc,U+02c6,U+02da,U+02dc,U+2000-206f,U+2074,U+20ac,U+2122,U+2191,U+2193,U+2212,U+2215,U+feff,U+fffd}
|
|
2
|
+
/*# sourceMappingURL=4.6e1172e8.chunk.css.map */
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["400.css","700.css"],"names":[],"mappings":"AACA,WACE,kBAAmB,CACnB,iBAAkB,CAClB,iBAAkB,CAClB,eAAgB,CAChB,qNAA2H,CAC3H,qGACF,CAEA,WACE,kBAAmB,CACnB,iBAAkB,CAClB,iBAAkB,CAClB,eAAgB,CAChB,iNAAuH,CACvH,mJACF,CChBA,WACE,kBAAmB,CACnB,iBAAkB,CAClB,iBAAkB,CAClB,eAAgB,CAChB,qNAA2H,CAC3H,qGACF,CAEA,WACE,kBAAmB,CACnB,iBAAkB,CAClB,iBAAkB,CAClB,eAAgB,CAChB,iNAAuH,CACvH,mJACF,CDhBA,WACE,yBAA0B,CAC1B,iBAAkB,CAClB,iBAAkB,CAClB,eAAgB,CAChB,sOAA4I,CAC5I,gFACF,CAEA,WACE,yBAA0B,CAC1B,iBAAkB,CAClB,iBAAkB,CAClB,eAAgB,CAChB,kOAAwI,CACxI,wDACF,CAEA,WACE,yBAA0B,CAC1B,iBAAkB,CAClB,iBAAkB,CAClB,eAAgB,CAChB,mOAAyI,CACzI,oBACF,CAEA,WACE,yBAA0B,CAC1B,iBAAkB,CAClB,iBAAkB,CAClB,eAAgB,CAChB,+NAAqI,CACrI,yBACF,CAEA,WACE,yBAA0B,CAC1B,iBAAkB,CAClB,iBAAkB,CAClB,eAAgB,CAChB,mOAAyI,CACzI,qGACF,CAEA,WACE,yBAA0B,CAC1B,iBAAkB,CAClB,iBAAkB,CAClB,eAAgB,CAChB,+NAAqI,CACrI,mJACF","file":"4.6e1172e8.chunk.css","sourcesContent":["/* ubuntu-mono-cyrillic-ext-400-normal*/\n@font-face {\n font-family: 'Ubuntu Mono';\n font-style: normal;\n font-display: swap;\n font-weight: 400;\n src: url('./files/ubuntu-mono-cyrillic-ext-400-normal.woff2') format('woff2'), url('./files/ubuntu-mono-all-400-normal.woff') format('woff');\n unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;\n}\n/* ubuntu-mono-cyrillic-400-normal*/\n@font-face {\n font-family: 'Ubuntu Mono';\n font-style: normal;\n font-display: swap;\n font-weight: 400;\n src: url('./files/ubuntu-mono-cyrillic-400-normal.woff2') format('woff2'), url('./files/ubuntu-mono-all-400-normal.woff') format('woff');\n unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;\n}\n/* ubuntu-mono-greek-ext-400-normal*/\n@font-face {\n font-family: 'Ubuntu Mono';\n font-style: normal;\n font-display: swap;\n font-weight: 400;\n src: url('./files/ubuntu-mono-greek-ext-400-normal.woff2') format('woff2'), url('./files/ubuntu-mono-all-400-normal.woff') format('woff');\n unicode-range: U+1F00-1FFF;\n}\n/* ubuntu-mono-greek-400-normal*/\n@font-face {\n font-family: 'Ubuntu Mono';\n font-style: normal;\n font-display: swap;\n font-weight: 400;\n src: url('./files/ubuntu-mono-greek-400-normal.woff2') format('woff2'), url('./files/ubuntu-mono-all-400-normal.woff') format('woff');\n unicode-range: U+0370-03FF;\n}\n/* ubuntu-mono-latin-ext-400-normal*/\n@font-face {\n font-family: 'Ubuntu Mono';\n font-style: normal;\n font-display: swap;\n font-weight: 400;\n src: url('./files/ubuntu-mono-latin-ext-400-normal.woff2') format('woff2'), url('./files/ubuntu-mono-all-400-normal.woff') format('woff');\n unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;\n}\n/* ubuntu-mono-latin-400-normal*/\n@font-face {\n font-family: 'Ubuntu Mono';\n font-style: normal;\n font-display: swap;\n font-weight: 400;\n src: url('./files/ubuntu-mono-latin-400-normal.woff2') format('woff2'), url('./files/ubuntu-mono-all-400-normal.woff') format('woff');\n unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;\n}\n","/* lato-latin-ext-700-normal*/\n@font-face {\n font-family: 'Lato';\n font-style: normal;\n font-display: swap;\n font-weight: 700;\n src: url('./files/lato-latin-ext-700-normal.woff2') format('woff2'), url('./files/lato-all-700-normal.woff') format('woff');\n unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;\n}\n/* lato-latin-700-normal*/\n@font-face {\n font-family: 'Lato';\n font-style: normal;\n font-display: swap;\n font-weight: 700;\n src: url('./files/lato-latin-700-normal.woff2') format('woff2'), url('./files/lato-all-700-normal.woff') format('woff');\n unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;\n}\n"]}
|