swpp-backends 2.1.2 → 2.1.4
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/README.md +5 -4
- package/dist/ServiceWorkerBuilder.js +1 -1
- package/dist/index.js +1 -1
- package/dist/resources/sw-template.js +19 -11
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
|
|
5
5
|
swpp-backends(以下简称 swpp)插件的功能是为网站生成一个高度可用的 ServiceWorker(以下简称 SW),为网站优化二次加载、提供离线体验、提高可靠性,并为此附带了一些其它的功能。
|
|
6
6
|
|
|
7
|
-
swpp 的全拼为“
|
|
7
|
+
swpp 的全拼为“Service Worker Plus Plus”(或“Service Worker++”),但是其与已有的插件“hexo-service-worker”并没有关系,插件中所有代码均为我个人开发,这一点请不要误解。
|
|
8
8
|
|
|
9
9
|
swpp 生成的 SW 与其它插件的对比:
|
|
10
10
|
|
|
@@ -14,12 +14,13 @@ swpp 生成的 SW 与其它插件的对比:
|
|
|
14
14
|
| 缓存增量更新 | ✔️ | ❌ |
|
|
15
15
|
| 缓存过期时间 | ❌<sup>1</sup> | ✔️ |
|
|
16
16
|
| 缓存大小限制 | ❌ | ✔️ |
|
|
17
|
-
| 预缓存 |
|
|
17
|
+
| 预缓存 | ❌<sup>2</sup> | ✔️ |
|
|
18
18
|
| Request 篡改 | ✔️ | ❌ |
|
|
19
19
|
| URL 竞速 | ✔️ | ❌ |
|
|
20
20
|
| 备用 URL | ✔️ | ❌ |
|
|
21
|
-
|
|
|
21
|
+
| 204 阻塞响应 | ✔️ | ❌ |
|
|
22
22
|
| 逃生门 | ✔️ | ❌ |
|
|
23
|
+
| 请求合并 | ✔️ | ❌ |
|
|
23
24
|
| 跨平台 | ✔️ | ❌ |
|
|
24
25
|
| 高度自由 | ✔️ | ❌ |
|
|
25
26
|
| 更新 | 非常频繁 | 超过两年没有更新 |
|
|
@@ -30,7 +31,7 @@ swpp 生成的 SW 与其它插件的对比:
|
|
|
30
31
|
+ ❌:不支持
|
|
31
32
|
|
|
32
33
|
1. 因为有增量更新,所以没提供过期的实现,没必要
|
|
33
|
-
|
|
34
|
+
2. 预缓存可以在前端实现,SW 实现这个功能容易拖延注册时间
|
|
34
35
|
|
|
35
36
|
目前支持的平台:
|
|
36
37
|
|
|
@@ -59,7 +59,7 @@ function buildServiceWorker() {
|
|
|
59
59
|
url = new URL(request.url)
|
|
60
60
|
}
|
|
61
61
|
`).replaceAll('// [modifyRequest else-if]', `
|
|
62
|
-
else if (modify) handleFetch(
|
|
62
|
+
else if (modify) handleFetch(fetch(request).catch(err => new Response(err, {status: 499})))
|
|
63
63
|
`);
|
|
64
64
|
}
|
|
65
65
|
if (blockRequest) {
|
package/dist/index.js
CHANGED
|
@@ -10,7 +10,7 @@ const VersionAnalyzer_1 = require("./VersionAnalyzer");
|
|
|
10
10
|
const DomBuilder_1 = require("./DomBuilder");
|
|
11
11
|
// noinspection JSUnusedGlobalSymbols
|
|
12
12
|
exports.default = {
|
|
13
|
-
version: '2.1.
|
|
13
|
+
version: '2.1.4',
|
|
14
14
|
cache: {
|
|
15
15
|
readEjectData: Utils_1.readEjectData, readUpdateJson: Variant_1.readUpdateJson,
|
|
16
16
|
readRules: Variant_1.readRules, readMergeVersionMap: Variant_1.readMergeVersionMap,
|
|
@@ -121,7 +121,7 @@
|
|
|
121
121
|
const spare = getSpareUrls(request.url)
|
|
122
122
|
if (spare) handleFetch(fetchFile(request, false, spare))
|
|
123
123
|
// [modifyRequest else-if]
|
|
124
|
-
else handleFetch(fetch(request))
|
|
124
|
+
else handleFetch(fetch(request).catch(err => new Response(err, {status: 499})))
|
|
125
125
|
}
|
|
126
126
|
})
|
|
127
127
|
|
|
@@ -134,6 +134,7 @@
|
|
|
134
134
|
type: 'update',
|
|
135
135
|
update: info.list,
|
|
136
136
|
version: info.version,
|
|
137
|
+
old: info.old
|
|
137
138
|
})
|
|
138
139
|
)
|
|
139
140
|
})
|
|
@@ -152,7 +153,7 @@
|
|
|
152
153
|
|
|
153
154
|
/**
|
|
154
155
|
* 根据JSON删除缓存
|
|
155
|
-
* @returns {Promise<{version, list}>}
|
|
156
|
+
* @returns {Promise<{version, list, old}>}
|
|
156
157
|
*/
|
|
157
158
|
const updateJson = () => {
|
|
158
159
|
/**
|
|
@@ -171,14 +172,17 @@
|
|
|
171
172
|
// 跨版本幅度过大,直接清理全站
|
|
172
173
|
return true
|
|
173
174
|
}
|
|
174
|
-
/**
|
|
175
|
+
/**
|
|
176
|
+
* 解析字符串
|
|
177
|
+
* @return {Promise<any>}
|
|
178
|
+
*/
|
|
175
179
|
const parseJson = json => dbVersion.read().then(oldVersion => {
|
|
176
180
|
const {info, global} = json
|
|
177
181
|
const newVersion = {global, local: info[0].version, escape: oldVersion?.escape ?? 0}
|
|
178
182
|
//新用户不进行更新操作
|
|
179
183
|
if (!oldVersion) {
|
|
180
184
|
dbVersion.write(newVersion)
|
|
181
|
-
return newVersion
|
|
185
|
+
return {version: newVersion, old: oldVersion}
|
|
182
186
|
}
|
|
183
187
|
let list = new VersionList()
|
|
184
188
|
let refresh = parseChange(list, info, oldVersion.local)
|
|
@@ -189,19 +193,20 @@
|
|
|
189
193
|
if (global !== oldVersion.global) list.force = true
|
|
190
194
|
else list.refresh = true
|
|
191
195
|
}
|
|
192
|
-
return {list, version: newVersion}
|
|
196
|
+
return {list, version: newVersion, old: oldVersion}
|
|
193
197
|
})
|
|
194
198
|
return fetchFile(new Request('/update.json'), false)
|
|
195
199
|
.then(response => {
|
|
196
200
|
if (checkResponse(response))
|
|
197
201
|
return response.json().then(json =>
|
|
198
202
|
parseJson(json).then(result => {
|
|
199
|
-
|
|
203
|
+
const info = {version: result.version, old: result.old}
|
|
204
|
+
if (result.list)
|
|
205
|
+
return deleteCache(result.list)
|
|
200
206
|
.then(list => list.length === 0 ? null : list)
|
|
201
|
-
.then(list => ({list,
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
)
|
|
207
|
+
.then(list => Object.assign({list}, info))
|
|
208
|
+
else return info
|
|
209
|
+
})
|
|
205
210
|
)
|
|
206
211
|
else throw `加载 update.json 时遇到异常,状态码:${response.status}`
|
|
207
212
|
})
|
|
@@ -232,7 +237,10 @@
|
|
|
232
237
|
if (this.force) return true
|
|
233
238
|
// noinspection JSValidateTypes
|
|
234
239
|
url = new URL(url)
|
|
235
|
-
if (this.refresh)
|
|
240
|
+
if (this.refresh) {
|
|
241
|
+
// noinspection JSCheckFunctionSignatures
|
|
242
|
+
return findCache(url).clean
|
|
243
|
+
}
|
|
236
244
|
else {
|
|
237
245
|
for (let it of list) {
|
|
238
246
|
if (it.match(url)) return true
|