@jsenv/core 36.3.1 → 37.0.1
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/js/autoreload.js +6 -5
- package/dist/js/import_meta_hot.js +4 -4
- package/dist/js/server_events_client.js +422 -304
- package/dist/jsenv_core.js +3819 -3256
- package/package.json +17 -17
- package/src/build/build.js +342 -658
- package/src/build/build_urls_generator.js +8 -8
- package/src/build/build_versions_manager.js +495 -0
- package/src/build/version_mappings_injection.js +27 -16
- package/src/dev/file_service.js +80 -91
- package/src/dev/start_dev_server.js +5 -3
- package/src/kitchen/errors.js +16 -16
- package/src/kitchen/fetched_content_compliance.js +4 -8
- package/src/kitchen/kitchen.js +367 -939
- package/src/kitchen/prepend_content.js +13 -35
- package/src/kitchen/url_graph/references.js +713 -0
- package/src/kitchen/url_graph/sort_by_dependencies.js +2 -2
- package/src/kitchen/url_graph/url_content.js +96 -0
- package/src/kitchen/url_graph/url_graph.js +439 -0
- package/src/kitchen/url_graph/url_graph_report.js +6 -4
- package/src/kitchen/url_graph/url_graph_visitor.js +14 -12
- package/src/kitchen/url_graph/url_info_transformations.js +180 -184
- package/src/plugins/autoreload/client/autoreload.js +1 -0
- package/src/plugins/autoreload/client/reload.js +6 -6
- package/src/plugins/autoreload/jsenv_plugin_autoreload.js +2 -2
- package/src/plugins/autoreload/jsenv_plugin_autoreload_client.js +2 -2
- package/src/plugins/autoreload/jsenv_plugin_autoreload_server.js +84 -78
- package/src/plugins/autoreload/jsenv_plugin_hot_search_param.js +52 -0
- package/src/plugins/cache_control/jsenv_plugin_cache_control.js +1 -1
- package/src/plugins/commonjs_globals/jsenv_plugin_commonjs_globals.js +2 -2
- package/src/plugins/global_scenarios/jsenv_plugin_global_scenarios.js +3 -3
- package/src/plugins/import_meta_hot/client/import_meta_hot.js +4 -4
- package/src/plugins/import_meta_hot/jsenv_plugin_import_meta_hot.js +18 -20
- package/src/plugins/import_meta_scenarios/jsenv_plugin_import_meta_scenarios.js +2 -2
- package/src/plugins/importmap/jsenv_plugin_importmap.js +35 -37
- package/src/plugins/inlining/jsenv_plugin_inlining.js +1 -17
- package/src/plugins/inlining/jsenv_plugin_inlining_as_data_url.js +70 -50
- package/src/plugins/inlining/jsenv_plugin_inlining_into_html.js +72 -54
- package/src/plugins/plugin_controller.js +92 -27
- package/src/plugins/protocol_file/jsenv_plugin_protocol_file.js +18 -20
- package/src/plugins/reference_analysis/css/jsenv_plugin_css_reference_analysis.js +4 -5
- package/src/plugins/reference_analysis/data_urls/jsenv_plugin_data_urls_analysis.js +18 -16
- package/src/plugins/reference_analysis/directory/jsenv_plugin_directory_reference_analysis.js +13 -20
- package/src/plugins/reference_analysis/html/jsenv_plugin_html_reference_analysis.js +55 -72
- package/src/plugins/reference_analysis/js/jsenv_plugin_js_reference_analysis.js +33 -42
- package/src/plugins/reference_analysis/jsenv_plugin_reference_analysis.js +16 -7
- package/src/plugins/reference_analysis/webmanifest/jsenv_plugin_webmanifest_reference_analysis.js +4 -3
- package/src/plugins/resolution_node_esm/jsenv_plugin_node_esm_resolution.js +16 -6
- package/src/plugins/resolution_node_esm/node_esm_resolver.js +30 -24
- package/src/plugins/resolution_web/jsenv_plugin_web_resolution.js +8 -5
- package/src/plugins/ribbon/jsenv_plugin_ribbon.js +3 -3
- package/src/plugins/server_events/client/server_events_client.js +460 -15
- package/src/plugins/server_events/jsenv_plugin_server_events_client_injection.js +13 -29
- package/src/plugins/version_search_param/jsenv_plugin_version_search_param.js +1 -1
- package/src/build/version_generator.js +0 -19
- package/src/kitchen/url_graph/url_graph_loader.js +0 -77
- package/src/kitchen/url_graph.js +0 -322
- package/src/plugins/autoreload/jsenv_plugin_hmr.js +0 -42
- package/src/plugins/resolution_node_esm/url_type_from_reference.js +0 -13
- package/src/plugins/server_events/client/connection_manager.js +0 -170
- package/src/plugins/server_events/client/event_source_connection.js +0 -83
- package/src/plugins/server_events/client/events_manager.js +0 -75
- package/src/plugins/server_events/client/web_socket_connection.js +0 -81
- /package/src/kitchen/{url_specifier_encoding.js → url_graph/url_specifier_encoding.js} +0 -0
|
@@ -1,170 +0,0 @@
|
|
|
1
|
-
const READY_STATES = {
|
|
2
|
-
CONNECTING: "connecting",
|
|
3
|
-
OPEN: "open",
|
|
4
|
-
CLOSING: "closing",
|
|
5
|
-
CLOSED: "closed",
|
|
6
|
-
};
|
|
7
|
-
|
|
8
|
-
export const createConnectionManager = (
|
|
9
|
-
attemptConnection,
|
|
10
|
-
{ retry, retryAfter, retryMaxAttempt, retryAllocatedMs },
|
|
11
|
-
) => {
|
|
12
|
-
const readyState = {
|
|
13
|
-
value: READY_STATES.CLOSED,
|
|
14
|
-
goTo: (value) => {
|
|
15
|
-
if (value === readyState.value) {
|
|
16
|
-
return;
|
|
17
|
-
}
|
|
18
|
-
readyState.value = value;
|
|
19
|
-
readyState.onchange();
|
|
20
|
-
},
|
|
21
|
-
onchange: () => {},
|
|
22
|
-
};
|
|
23
|
-
|
|
24
|
-
let _disconnect = () => {};
|
|
25
|
-
const connect = () => {
|
|
26
|
-
if (
|
|
27
|
-
readyState.value === READY_STATES.CONNECTING ||
|
|
28
|
-
readyState.value === READY_STATES.OPEN
|
|
29
|
-
) {
|
|
30
|
-
return;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
let retryCount = 0;
|
|
34
|
-
let msSpent = 0;
|
|
35
|
-
const attempt = () => {
|
|
36
|
-
readyState.goTo(READY_STATES.CONNECTING);
|
|
37
|
-
let timeout;
|
|
38
|
-
const cancelAttempt = attemptConnection({
|
|
39
|
-
onClosed: () => {
|
|
40
|
-
if (!retry) {
|
|
41
|
-
readyState.goTo(READY_STATES.CLOSED);
|
|
42
|
-
console.info(`[jsenv] failed to connect to server`);
|
|
43
|
-
return;
|
|
44
|
-
}
|
|
45
|
-
if (retryCount > retryMaxAttempt) {
|
|
46
|
-
readyState.goTo(READY_STATES.CLOSED);
|
|
47
|
-
console.info(
|
|
48
|
-
`[jsenv] could not connect to server after ${retryMaxAttempt} attempt`,
|
|
49
|
-
);
|
|
50
|
-
return;
|
|
51
|
-
}
|
|
52
|
-
if (retryAllocatedMs && msSpent > retryAllocatedMs) {
|
|
53
|
-
readyState.goTo(READY_STATES.CLOSED);
|
|
54
|
-
console.info(
|
|
55
|
-
`[jsenv] could not connect to server in less than ${retryAllocatedMs}ms`,
|
|
56
|
-
);
|
|
57
|
-
return;
|
|
58
|
-
}
|
|
59
|
-
// if closed while open -> connection lost
|
|
60
|
-
// otherwise it's the attempt to connect for the first time
|
|
61
|
-
// or to reconnect
|
|
62
|
-
if (readyState.value === READY_STATES.OPEN) {
|
|
63
|
-
console.info(`[jsenv] server connection lost; retrying to connect`);
|
|
64
|
-
}
|
|
65
|
-
retryCount++;
|
|
66
|
-
timeout = setTimeout(() => {
|
|
67
|
-
msSpent += retryAfter;
|
|
68
|
-
attempt();
|
|
69
|
-
}, retryAfter);
|
|
70
|
-
},
|
|
71
|
-
onOpen: () => {
|
|
72
|
-
readyState.goTo(READY_STATES.OPEN);
|
|
73
|
-
// console.info(`[jsenv] connected to server`)
|
|
74
|
-
},
|
|
75
|
-
});
|
|
76
|
-
_disconnect = () => {
|
|
77
|
-
cancelAttempt();
|
|
78
|
-
clearTimeout(timeout);
|
|
79
|
-
readyState.goTo(READY_STATES.CLOSED);
|
|
80
|
-
};
|
|
81
|
-
};
|
|
82
|
-
attempt();
|
|
83
|
-
};
|
|
84
|
-
|
|
85
|
-
const disconnect = () => {
|
|
86
|
-
if (
|
|
87
|
-
readyState.value !== READY_STATES.CONNECTING &&
|
|
88
|
-
readyState.value !== READY_STATES.OPEN
|
|
89
|
-
) {
|
|
90
|
-
console.warn(
|
|
91
|
-
`disconnect() ignored because connection is ${readyState.value}`,
|
|
92
|
-
);
|
|
93
|
-
return null;
|
|
94
|
-
}
|
|
95
|
-
return _disconnect();
|
|
96
|
-
};
|
|
97
|
-
|
|
98
|
-
const removePageUnloadListener = listenPageUnload(() => {
|
|
99
|
-
if (
|
|
100
|
-
readyState.value === READY_STATES.CONNECTING ||
|
|
101
|
-
readyState.value === READY_STATES.OPEN
|
|
102
|
-
) {
|
|
103
|
-
_disconnect();
|
|
104
|
-
}
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
return {
|
|
108
|
-
readyState,
|
|
109
|
-
connect,
|
|
110
|
-
disconnect,
|
|
111
|
-
destroy: () => {
|
|
112
|
-
removePageUnloadListener();
|
|
113
|
-
disconnect();
|
|
114
|
-
},
|
|
115
|
-
};
|
|
116
|
-
};
|
|
117
|
-
|
|
118
|
-
// const listenPageMightFreeze = (callback) => {
|
|
119
|
-
// const removePageHideListener = listenEvent(window, "pagehide", (pageHideEvent) => {
|
|
120
|
-
// if (pageHideEvent.persisted === true) {
|
|
121
|
-
// callback(pageHideEvent)
|
|
122
|
-
// }
|
|
123
|
-
// })
|
|
124
|
-
// return removePageHideListener
|
|
125
|
-
// }
|
|
126
|
-
|
|
127
|
-
// const listenPageFreeze = (callback) => {
|
|
128
|
-
// const removeFreezeListener = listenEvent(document, "freeze", (freezeEvent) => {
|
|
129
|
-
// callback(freezeEvent)
|
|
130
|
-
// })
|
|
131
|
-
// return removeFreezeListener
|
|
132
|
-
// }
|
|
133
|
-
|
|
134
|
-
// const listenPageIsRestored = (callback) => {
|
|
135
|
-
// const removeResumeListener = listenEvent(document, "resume", (resumeEvent) => {
|
|
136
|
-
// removePageshowListener()
|
|
137
|
-
// callback(resumeEvent)
|
|
138
|
-
// })
|
|
139
|
-
// const removePageshowListener = listenEvent(window, "pageshow", (pageshowEvent) => {
|
|
140
|
-
// if (pageshowEvent.persisted === true) {
|
|
141
|
-
// removePageshowListener()
|
|
142
|
-
// removeResumeListener()
|
|
143
|
-
// callback(pageshowEvent)
|
|
144
|
-
// }
|
|
145
|
-
// })
|
|
146
|
-
// return () => {
|
|
147
|
-
// removeResumeListener()
|
|
148
|
-
// removePageshowListener()
|
|
149
|
-
// }
|
|
150
|
-
// }
|
|
151
|
-
|
|
152
|
-
const listenPageUnload = (callback) => {
|
|
153
|
-
const removePageHideListener = listenEvent(
|
|
154
|
-
window,
|
|
155
|
-
"pagehide",
|
|
156
|
-
(pageHideEvent) => {
|
|
157
|
-
if (pageHideEvent.persisted !== true) {
|
|
158
|
-
callback(pageHideEvent);
|
|
159
|
-
}
|
|
160
|
-
},
|
|
161
|
-
);
|
|
162
|
-
return removePageHideListener;
|
|
163
|
-
};
|
|
164
|
-
|
|
165
|
-
const listenEvent = (emitter, event, callback) => {
|
|
166
|
-
emitter.addEventListener(event, callback);
|
|
167
|
-
return () => {
|
|
168
|
-
emitter.removeEventListener(event, callback);
|
|
169
|
-
};
|
|
170
|
-
};
|
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
import { createConnectionManager } from "./connection_manager.js";
|
|
2
|
-
import { createEventsManager } from "./events_manager.js";
|
|
3
|
-
|
|
4
|
-
export const createEventSourceConnection = (
|
|
5
|
-
eventSourceUrl,
|
|
6
|
-
{
|
|
7
|
-
withCredentials = true,
|
|
8
|
-
lastEventId,
|
|
9
|
-
useEventsToManageConnection = true,
|
|
10
|
-
retry = false,
|
|
11
|
-
retryMaxAttempt = Infinity,
|
|
12
|
-
retryAllocatedMs = Infinity,
|
|
13
|
-
} = {},
|
|
14
|
-
) => {
|
|
15
|
-
const eventSourceOrigin = new URL(eventSourceUrl).origin;
|
|
16
|
-
const attemptConnection = ({ onOpen, onClosed }) => {
|
|
17
|
-
const url = lastEventId
|
|
18
|
-
? addLastEventIdIntoUrlSearchParams(eventSourceUrl, lastEventId)
|
|
19
|
-
: eventSourceUrl;
|
|
20
|
-
let eventSource = new EventSource(url, { withCredentials });
|
|
21
|
-
eventSource.onerror = () => {
|
|
22
|
-
eventSource.onerror = null;
|
|
23
|
-
eventSource.onopen = null;
|
|
24
|
-
eventSource.onmessage = null;
|
|
25
|
-
eventSource = null;
|
|
26
|
-
onClosed();
|
|
27
|
-
};
|
|
28
|
-
eventSource.onopen = () => {
|
|
29
|
-
eventSource.onopen = null;
|
|
30
|
-
onOpen();
|
|
31
|
-
};
|
|
32
|
-
eventSource.onmessage = (messageEvent) => {
|
|
33
|
-
if (messageEvent.origin === eventSourceOrigin) {
|
|
34
|
-
if (messageEvent.lastEventId) {
|
|
35
|
-
lastEventId = messageEvent.lastEventId;
|
|
36
|
-
}
|
|
37
|
-
const event = JSON.parse(messageEvent.data);
|
|
38
|
-
eventsManager.triggerCallbacks(event);
|
|
39
|
-
}
|
|
40
|
-
};
|
|
41
|
-
return () => {
|
|
42
|
-
if (eventSource) {
|
|
43
|
-
eventSource.close();
|
|
44
|
-
}
|
|
45
|
-
};
|
|
46
|
-
};
|
|
47
|
-
const connectionManager = createConnectionManager(attemptConnection, {
|
|
48
|
-
retry,
|
|
49
|
-
retryMaxAttempt,
|
|
50
|
-
retryAllocatedMs,
|
|
51
|
-
});
|
|
52
|
-
const eventsManager = createEventsManager({
|
|
53
|
-
effect: () => {
|
|
54
|
-
if (useEventsToManageConnection) {
|
|
55
|
-
connectionManager.connect();
|
|
56
|
-
return () => {
|
|
57
|
-
connectionManager.disconnect();
|
|
58
|
-
};
|
|
59
|
-
}
|
|
60
|
-
return null;
|
|
61
|
-
},
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
return {
|
|
65
|
-
readyState: connectionManager.readyState,
|
|
66
|
-
listenEvents: (namedCallbacks) => {
|
|
67
|
-
return eventsManager.addCallbacks(namedCallbacks);
|
|
68
|
-
},
|
|
69
|
-
destroy: () => {
|
|
70
|
-
connectionManager.destroy();
|
|
71
|
-
eventsManager.destroy();
|
|
72
|
-
},
|
|
73
|
-
};
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
const addLastEventIdIntoUrlSearchParams = (url, lastEventId) => {
|
|
77
|
-
if (url.indexOf("?") === -1) {
|
|
78
|
-
url += "?";
|
|
79
|
-
} else {
|
|
80
|
-
url += "&";
|
|
81
|
-
}
|
|
82
|
-
return `${url}last-event-id=${encodeURIComponent(lastEventId)}`;
|
|
83
|
-
};
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
export const createEventsManager = ({ effect = () => {} } = {}) => {
|
|
2
|
-
const callbacksMap = new Map();
|
|
3
|
-
let cleanup;
|
|
4
|
-
const addCallbacks = (namedCallbacks) => {
|
|
5
|
-
let callbacksMapSize = callbacksMap.size;
|
|
6
|
-
Object.keys(namedCallbacks).forEach((eventName) => {
|
|
7
|
-
const callback = namedCallbacks[eventName];
|
|
8
|
-
const existingCallbacks = callbacksMap.get(eventName);
|
|
9
|
-
let callbacks;
|
|
10
|
-
if (existingCallbacks) {
|
|
11
|
-
callbacks = existingCallbacks;
|
|
12
|
-
} else {
|
|
13
|
-
callbacks = [];
|
|
14
|
-
callbacksMap.set(eventName, callbacks);
|
|
15
|
-
}
|
|
16
|
-
callbacks.push(callback);
|
|
17
|
-
});
|
|
18
|
-
if (effect && callbacksMapSize === 0 && callbacksMapSize.size > 0) {
|
|
19
|
-
cleanup = effect();
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
let removed = false;
|
|
23
|
-
return () => {
|
|
24
|
-
if (removed) return;
|
|
25
|
-
removed = true;
|
|
26
|
-
callbacksMapSize = callbacksMap.size;
|
|
27
|
-
Object.keys(namedCallbacks).forEach((eventName) => {
|
|
28
|
-
const callback = namedCallbacks[eventName];
|
|
29
|
-
const callbacks = callbacksMap.get(eventName);
|
|
30
|
-
if (callbacks) {
|
|
31
|
-
const index = callbacks.indexOf(callback);
|
|
32
|
-
if (index > -1) {
|
|
33
|
-
callbacks.splice(index, 1);
|
|
34
|
-
if (callbacks.length === 0) {
|
|
35
|
-
callbacksMap.delete(eventName);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
});
|
|
40
|
-
namedCallbacks = null; // allow garbage collect
|
|
41
|
-
if (
|
|
42
|
-
cleanup &&
|
|
43
|
-
typeof cleanup === "function" &&
|
|
44
|
-
callbacksMapSize > 0 &&
|
|
45
|
-
callbacksMapSize.size === 0
|
|
46
|
-
) {
|
|
47
|
-
cleanup();
|
|
48
|
-
cleanup = null;
|
|
49
|
-
}
|
|
50
|
-
};
|
|
51
|
-
};
|
|
52
|
-
|
|
53
|
-
const triggerCallbacks = (event) => {
|
|
54
|
-
const callbacks = callbacksMap.get(event.type);
|
|
55
|
-
if (callbacks) {
|
|
56
|
-
callbacks.forEach((callback) => {
|
|
57
|
-
callback(event);
|
|
58
|
-
});
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
|
|
62
|
-
const destroy = () => {
|
|
63
|
-
callbacksMap.clear();
|
|
64
|
-
if (cleanup) {
|
|
65
|
-
cleanup();
|
|
66
|
-
cleanup = null;
|
|
67
|
-
}
|
|
68
|
-
};
|
|
69
|
-
|
|
70
|
-
return {
|
|
71
|
-
addCallbacks,
|
|
72
|
-
triggerCallbacks,
|
|
73
|
-
destroy,
|
|
74
|
-
};
|
|
75
|
-
};
|
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
import { createConnectionManager } from "./connection_manager.js";
|
|
2
|
-
import { createEventsManager } from "./events_manager.js";
|
|
3
|
-
|
|
4
|
-
export const createWebSocketConnection = (
|
|
5
|
-
websocketUrl,
|
|
6
|
-
{
|
|
7
|
-
protocols = ["jsenv"],
|
|
8
|
-
useEventsToManageConnection = true,
|
|
9
|
-
retry = false,
|
|
10
|
-
retryAfter = 1000,
|
|
11
|
-
retryMaxAttempt = Infinity,
|
|
12
|
-
retryAllocatedMs = Infinity,
|
|
13
|
-
} = {},
|
|
14
|
-
) => {
|
|
15
|
-
const connectionManager = createConnectionManager(
|
|
16
|
-
({ onClosed, onOpen }) => {
|
|
17
|
-
let socket = new WebSocket(websocketUrl, protocols);
|
|
18
|
-
let interval;
|
|
19
|
-
const cleanup = () => {
|
|
20
|
-
if (socket) {
|
|
21
|
-
socket.onerror = null;
|
|
22
|
-
socket.onopen = null;
|
|
23
|
-
socket.onclose = null;
|
|
24
|
-
socket.onmessage = null;
|
|
25
|
-
socket = null;
|
|
26
|
-
clearInterval(interval);
|
|
27
|
-
}
|
|
28
|
-
};
|
|
29
|
-
socket.onerror = () => {
|
|
30
|
-
cleanup();
|
|
31
|
-
onClosed();
|
|
32
|
-
};
|
|
33
|
-
socket.onopen = () => {
|
|
34
|
-
socket.onopen = null;
|
|
35
|
-
onOpen();
|
|
36
|
-
interval = setInterval(() => {
|
|
37
|
-
socket.send('{"type":"ping"}');
|
|
38
|
-
}, 30_000);
|
|
39
|
-
};
|
|
40
|
-
socket.onclose = () => {
|
|
41
|
-
cleanup();
|
|
42
|
-
onClosed();
|
|
43
|
-
};
|
|
44
|
-
socket.onmessage = (messageEvent) => {
|
|
45
|
-
const event = JSON.parse(messageEvent.data);
|
|
46
|
-
eventsManager.triggerCallbacks(event);
|
|
47
|
-
};
|
|
48
|
-
return () => {
|
|
49
|
-
if (socket) {
|
|
50
|
-
socket.close();
|
|
51
|
-
cleanup();
|
|
52
|
-
}
|
|
53
|
-
};
|
|
54
|
-
},
|
|
55
|
-
{ retry, retryAfter, retryMaxAttempt, retryAllocatedMs },
|
|
56
|
-
);
|
|
57
|
-
const eventsManager = createEventsManager({
|
|
58
|
-
effect: () => {
|
|
59
|
-
if (useEventsToManageConnection) {
|
|
60
|
-
connectionManager.connect();
|
|
61
|
-
return () => {
|
|
62
|
-
connectionManager.disconnect();
|
|
63
|
-
};
|
|
64
|
-
}
|
|
65
|
-
return null;
|
|
66
|
-
},
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
return {
|
|
70
|
-
readyState: connectionManager.readyState,
|
|
71
|
-
connect: connectionManager.connect,
|
|
72
|
-
disconnect: connectionManager.disconnect,
|
|
73
|
-
listenEvents: (namedCallbacks) => {
|
|
74
|
-
return eventsManager.addCallbacks(namedCallbacks);
|
|
75
|
-
},
|
|
76
|
-
destroy: () => {
|
|
77
|
-
connectionManager.destroy();
|
|
78
|
-
eventsManager.destroy();
|
|
79
|
-
},
|
|
80
|
-
};
|
|
81
|
-
};
|
|
File without changes
|