querysub 0.437.0 → 0.439.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.
Files changed (81) hide show
  1. package/.eslintrc.js +50 -50
  2. package/bin/deploy.js +0 -0
  3. package/bin/function.js +0 -0
  4. package/bin/server.js +0 -0
  5. package/costsBenefits.txt +115 -115
  6. package/deploy.ts +2 -2
  7. package/package.json +2 -2
  8. package/spec.txt +1192 -1192
  9. package/src/-a-archives/archives.ts +202 -202
  10. package/src/-a-archives/archivesDisk.ts +454 -454
  11. package/src/-a-auth/certs.ts +540 -540
  12. package/src/-a-auth/node-forge-ed25519.d.ts +16 -16
  13. package/src/-b-authorities/dnsAuthority.ts +138 -138
  14. package/src/-c-identity/IdentityController.ts +258 -258
  15. package/src/-d-trust/NetworkTrust2.ts +180 -180
  16. package/src/-e-certs/EdgeCertController.ts +252 -252
  17. package/src/-e-certs/certAuthority.ts +201 -201
  18. package/src/-f-node-discovery/NodeDiscovery.ts +640 -640
  19. package/src/-g-core-values/NodeCapabilities.ts +200 -200
  20. package/src/-h-path-value-serialize/stringSerializer.ts +175 -175
  21. package/src/0-path-value-core/PathValueCommitter.ts +468 -468
  22. package/src/0-path-value-core/PathValueController.ts +0 -2
  23. package/src/0-path-value-core/archiveLocks/archiveSnapshots.ts +37 -1
  24. package/src/0-path-value-core/pathValueCore.ts +12 -0
  25. package/src/2-proxy/PathValueProxyWatcher.ts +2542 -2542
  26. package/src/2-proxy/TransactionDelayer.ts +94 -94
  27. package/src/2-proxy/pathDatabaseProxyBase.ts +36 -36
  28. package/src/2-proxy/pathValueProxy.ts +159 -159
  29. package/src/3-path-functions/PathFunctionRunner.ts +24 -13
  30. package/src/3-path-functions/PathFunctionRunnerMain.ts +87 -87
  31. package/src/3-path-functions/pathFunctionLoader.ts +516 -516
  32. package/src/3-path-functions/tests/rejectTest.ts +76 -76
  33. package/src/4-deploy/deployCheck.ts +6 -6
  34. package/src/4-dom/css.tsx +29 -29
  35. package/src/4-dom/cssTypes.d.ts +211 -211
  36. package/src/4-dom/qreact.tsx +2799 -2799
  37. package/src/4-dom/qreactTest.tsx +410 -410
  38. package/src/4-querysub/permissions.ts +335 -335
  39. package/src/4-querysub/querysubPrediction.ts +483 -483
  40. package/src/5-diagnostics/qreactDebug.tsx +400 -346
  41. package/src/TestController.ts +34 -34
  42. package/src/bits.ts +104 -104
  43. package/src/buffers.ts +69 -69
  44. package/src/diagnostics/ActionsHistory.ts +57 -57
  45. package/src/diagnostics/PathDistributionInfo.tsx +9 -1
  46. package/src/diagnostics/listenOnDebugger.ts +71 -71
  47. package/src/diagnostics/logs/IndexedLogs/BufferUnitIndex.ts +1 -1
  48. package/src/diagnostics/logs/diskLogger.ts +6 -0
  49. package/src/diagnostics/misc-pages/SnapshotViewer.tsx +78 -1
  50. package/src/diagnostics/periodic.ts +111 -111
  51. package/src/diagnostics/trackResources.ts +91 -91
  52. package/src/diagnostics/watchdog.ts +120 -120
  53. package/src/errors.ts +133 -133
  54. package/src/forceProduction.ts +2 -2
  55. package/src/fs.ts +80 -80
  56. package/src/functional/diff.ts +857 -857
  57. package/src/functional/promiseCache.ts +78 -78
  58. package/src/functional/random.ts +8 -8
  59. package/src/functional/stats.ts +60 -60
  60. package/src/heapDumps.ts +665 -665
  61. package/src/https.ts +1 -1
  62. package/src/library-components/AspectSizedComponent.tsx +87 -87
  63. package/src/library-components/ButtonSelector.tsx +64 -64
  64. package/src/library-components/DropdownCustom.tsx +150 -150
  65. package/src/library-components/DropdownSelector.tsx +31 -31
  66. package/src/library-components/InlinePopup.tsx +66 -66
  67. package/src/library-components/uncaughtToast.tsx +2 -0
  68. package/src/misc/color.ts +29 -29
  69. package/src/misc/hash.ts +83 -83
  70. package/src/misc/ipPong.js +13 -13
  71. package/src/misc/networking.ts +1 -1
  72. package/src/misc/random.ts +44 -44
  73. package/src/misc.ts +196 -196
  74. package/src/path.ts +255 -255
  75. package/src/persistentLocalStore.ts +41 -41
  76. package/src/promise.ts +14 -14
  77. package/src/storage/fileSystemPointer.ts +71 -71
  78. package/src/test/heapProcess.ts +35 -35
  79. package/src/zip.ts +15 -15
  80. package/tsconfig.json +26 -26
  81. package/yarnSpec.txt +56 -56
@@ -1,92 +1,92 @@
1
- import { runInfinitePoll } from "socket-function/src/batching";
2
- import { lazy } from "socket-function/src/caching";
3
- import { formatNumber } from "socket-function/src/formatting/format";
4
- import { blue } from "socket-function/src/formatting/logColors";
5
- import { isNode } from "socket-function/src/misc";
6
- import { registerPeriodic } from "./periodic";
7
- import { registerMeasureInfo } from "socket-function/src/profiling/measure";
8
- import { logNodeStateStats } from "../-0-hooks/hooks";
9
-
10
- let resources: {
11
- name: string;
12
- getCount: () => number;
13
- }[] = [];
14
-
15
- export function registerResource<T extends Set<unknown> | Map<unknown, unknown> | unknown[]>(name: string, data: T): T {
16
- let getCount: () => number;
17
- if (Array.isArray(data)) {
18
- getCount = () => data.length;
19
- } else {
20
- getCount = () => data.size;
21
- }
22
- resources.push({ name, getCount });
23
- return data;
24
- }
25
- export function registerMapArrayResource<T extends Map<unknown, unknown[]>>(name: string, data: T): T {
26
- let getCount = () => {
27
- let sum = 0;
28
- for (let value of data.values()) {
29
- sum += value.length;
30
- }
31
- return sum;
32
- };
33
- resources.push({ name, getCount });
34
- return data;
35
- }
36
- export function registerDynamicResource(name: string, getCount: () => number) {
37
- resources.push({ name, getCount });
38
- }
39
-
40
- function getHeapSize() {
41
- if (isNode()) {
42
- let usage = process.memoryUsage();
43
- // Not really the heap size, but it is more what we are looking for
44
- return usage.rss;
45
- } else {
46
- return (window.performance as any).memory.totalJSHeapSize;
47
- }
48
- }
49
- function getUsedHeapSize() {
50
- if (isNode()) {
51
- let usage = process.memoryUsage();
52
- return usage.heapUsed + usage.arrayBuffers;
53
- } else {
54
- if (!window.performance) return 0;
55
- return (window.performance as any).memory.usedJSHeapSize;
56
- }
57
- }
58
- function getBufferUsage() {
59
- if (isNode()) {
60
- let usage = process.memoryUsage();
61
- return usage.arrayBuffers;
62
- } else {
63
- return 0;
64
- }
65
- }
66
-
67
- registerDynamicResource("Heap", getUsedHeapSize);
68
- registerDynamicResource("Buffers", getBufferUsage);
69
- registerDynamicResource("Used Memory", getHeapSize);
70
-
71
- function logResourcesNow() {
72
- let resourcesWithCounts = resources.map(resource => ({ ...resource, count: resource.getCount() }));
73
- resourcesWithCounts.sort((a, b) => b.count - a.count);
74
- if (!isNode()) {
75
- console.log(`Memory usage ${blue(formatNumber(getUsedHeapSize()) + "B")}/${blue(formatNumber(getHeapSize()) + "B")} at ${new Date().toISOString()}`);
76
- for (let resource of resourcesWithCounts) {
77
- if (resource.count === 0) continue;
78
- console.log(` ${resource.name}: ${formatNumber(resource.count)}`);
79
- }
80
- } else {
81
- for (let resource of resourcesWithCounts) {
82
- if (resource.count === 0) continue;
83
- logNodeStateStats(resource.name, formatNumber, resource.count);
84
- }
85
- }
86
- }
87
-
88
- registerMeasureInfo(() => {
89
- return `MEM ${formatNumber(getUsedHeapSize())}B+${formatNumber(getBufferUsage())}B/${formatNumber(getHeapSize())}B `;
90
- });
91
-
1
+ import { runInfinitePoll } from "socket-function/src/batching";
2
+ import { lazy } from "socket-function/src/caching";
3
+ import { formatNumber } from "socket-function/src/formatting/format";
4
+ import { blue } from "socket-function/src/formatting/logColors";
5
+ import { isNode } from "socket-function/src/misc";
6
+ import { registerPeriodic } from "./periodic";
7
+ import { registerMeasureInfo } from "socket-function/src/profiling/measure";
8
+ import { logNodeStateStats } from "../-0-hooks/hooks";
9
+
10
+ let resources: {
11
+ name: string;
12
+ getCount: () => number;
13
+ }[] = [];
14
+
15
+ export function registerResource<T extends Set<unknown> | Map<unknown, unknown> | unknown[]>(name: string, data: T): T {
16
+ let getCount: () => number;
17
+ if (Array.isArray(data)) {
18
+ getCount = () => data.length;
19
+ } else {
20
+ getCount = () => data.size;
21
+ }
22
+ resources.push({ name, getCount });
23
+ return data;
24
+ }
25
+ export function registerMapArrayResource<T extends Map<unknown, unknown[]>>(name: string, data: T): T {
26
+ let getCount = () => {
27
+ let sum = 0;
28
+ for (let value of data.values()) {
29
+ sum += value.length;
30
+ }
31
+ return sum;
32
+ };
33
+ resources.push({ name, getCount });
34
+ return data;
35
+ }
36
+ export function registerDynamicResource(name: string, getCount: () => number) {
37
+ resources.push({ name, getCount });
38
+ }
39
+
40
+ function getHeapSize() {
41
+ if (isNode()) {
42
+ let usage = process.memoryUsage();
43
+ // Not really the heap size, but it is more what we are looking for
44
+ return usage.rss;
45
+ } else {
46
+ return (window.performance as any).memory.totalJSHeapSize;
47
+ }
48
+ }
49
+ function getUsedHeapSize() {
50
+ if (isNode()) {
51
+ let usage = process.memoryUsage();
52
+ return usage.heapUsed + usage.arrayBuffers;
53
+ } else {
54
+ if (!window.performance) return 0;
55
+ return (window.performance as any).memory.usedJSHeapSize;
56
+ }
57
+ }
58
+ function getBufferUsage() {
59
+ if (isNode()) {
60
+ let usage = process.memoryUsage();
61
+ return usage.arrayBuffers;
62
+ } else {
63
+ return 0;
64
+ }
65
+ }
66
+
67
+ registerDynamicResource("Heap", getUsedHeapSize);
68
+ registerDynamicResource("Buffers", getBufferUsage);
69
+ registerDynamicResource("Used Memory", getHeapSize);
70
+
71
+ function logResourcesNow() {
72
+ let resourcesWithCounts = resources.map(resource => ({ ...resource, count: resource.getCount() }));
73
+ resourcesWithCounts.sort((a, b) => b.count - a.count);
74
+ if (!isNode()) {
75
+ console.log(`Memory usage ${blue(formatNumber(getUsedHeapSize()) + "B")}/${blue(formatNumber(getHeapSize()) + "B")} at ${new Date().toISOString()}`);
76
+ for (let resource of resourcesWithCounts) {
77
+ if (resource.count === 0) continue;
78
+ console.log(` ${resource.name}: ${formatNumber(resource.count)}`);
79
+ }
80
+ } else {
81
+ for (let resource of resourcesWithCounts) {
82
+ if (resource.count === 0) continue;
83
+ logNodeStateStats(resource.name, formatNumber, resource.count);
84
+ }
85
+ }
86
+ }
87
+
88
+ registerMeasureInfo(() => {
89
+ return `MEM ${formatNumber(getUsedHeapSize())}B+${formatNumber(getBufferUsage())}B/${formatNumber(getHeapSize())}B `;
90
+ });
91
+
92
92
  registerPeriodic(logResourcesNow);
@@ -1,121 +1,121 @@
1
- import { runInfinitePoll, runInfinitePollCallAtStart } from "socket-function/src/batching";
2
- import { FormattedMeasureTable, MeasureProfile, logMeasureTable, startMeasure } from "socket-function/src/profiling/measure";
3
- import { logErrors } from "../errors";
4
- import { isNode, sort } from "socket-function/src/misc";
5
- import debugbreak from "debugbreak";
6
- import { registerPeriodic } from "./periodic";
7
- import { getOwnMachineId } from "../-a-auth/certs";
8
- import { SocketFunction } from "socket-function/SocketFunction";
9
- import { formatPercent, formatTime } from "socket-function/src/formatting/format";
10
- import { pathWatcher } from "../0-path-value-core/PathWatcher";
11
- import { addStatPeriodic, addStatSumPeriodic, addTimeProfileDistribution, registerNodeMetadata } from "../-0-hooks/hooks";
12
- import { logDisk } from "./logs/diskLogger";
13
- import { getDebuggerUrl } from "./listenOnDebugger";
14
- import { isPublic } from "../config";
15
-
16
- let lastProfile: MeasureProfile | undefined;
17
-
18
- addStatPeriodic({
19
- title: "Performance|% Profiled",
20
- getValue: () => {
21
- if (!lastProfile) return 0;
22
- let entries = Object.values(lastProfile.entries);
23
- if (entries.length === 0) return 0;
24
- const timeProfiled = lastProfile.endTime - lastProfile.startTime;
25
-
26
- let timeActive = entries.map(x => x.ownTime.sum).reduce((a, b) => a + b, 0);
27
- return timeActive / timeProfiled;
28
- },
29
- format: formatPercent,
30
- });
31
- registerNodeMetadata({
32
- columnName: "Performance|Top Profiled",
33
- getValue() {
34
- if (!lastProfile) return "";
35
- let entries = Object.values(lastProfile.entries);
36
- if (entries.length === 0) return "";
37
- const timeProfiled = lastProfile.endTime - lastProfile.startTime;
38
-
39
- let rootSums = new Map<string, number>();
40
- for (let entry of entries) {
41
- let name = entry.name.split("|")[0];
42
- let sum = rootSums.get(name) ?? 0;
43
- rootSums.set(name, sum + entry.ownTime.sum);
44
- }
45
- let most = sort(Array.from(rootSums.entries()), x => -x[1])[0];
46
- return `${endEllipsis(most[0], 26)} = ${formatPercent(most[1] / timeProfiled)}`;
47
- },
48
- });
49
- addTimeProfileDistribution("Performance|Network Calls", () => SocketFunction.harvestCallTimes());
50
- addStatPeriodic({
51
- title: "Performance|Pending Net Calls",
52
- getValue: () => SocketFunction.getPendingCallCount(),
53
- });
54
- addStatSumPeriodic({
55
- title: "Performance|Failed Net Calls",
56
- getValue: () => SocketFunction.harvestFailedCallCount(),
57
- });
58
- addTimeProfileDistribution("Performance|Syncing", () => pathWatcher.debug_harvestSyncTimes());
59
-
60
-
61
- function endEllipsis(str: string, maxLength: number) {
62
- if (str.length <= maxLength) return str;
63
- return "..." + str.slice(-(maxLength - 3));
64
- }
65
-
66
- let minTimeToLog = 250;
67
- export function watchdogSetMinTimeToLog(_minTimeToLog: number) {
68
- minTimeToLog = _minTimeToLog;
69
- }
70
-
71
- let measureObj = startMeasure();
72
- function logProfileMeasuresTimingsNow() {
73
- let profile = measureObj.finish();
74
- measureObj = startMeasure();
75
- function diskLogMeasureObj(table: FormattedMeasureTable | undefined) {
76
- if (!table) return;
77
- console.info(table.title, { entries: table.entries });
78
- }
79
- diskLogMeasureObj(logMeasureTable(profile, {
80
- name: `watchdog at ${new Date().toLocaleString()}`,
81
- // NOTE: Much higher min log times, now that we are combining logs.
82
- minTimeToLog: minTimeToLog,
83
- thresholdInTable: 0,
84
- setTitle: true
85
- }));
86
- diskLogMeasureObj(logMeasureTable(profile, {
87
- name: `watchdog at ${new Date().toLocaleString()}`,
88
- mergeDepth: 1,
89
- minTimeToLog: minTimeToLog,
90
- }));
91
-
92
- if (isNode() && !isPublic()) {
93
- let debuggerValue = getDebuggerUrl();
94
- process.stdout.write(`\n${debuggerValue}\n`);
95
- }
96
-
97
- lastProfile = profile;
98
- // if (isNode()) {
99
- // if (SocketFunction.mountedNodeId) {
100
- // console.log("Mounted as " + SocketFunction.mountedNodeId);
101
- // } else {
102
- // console.log("Not mounted");
103
- // }
104
- // }
105
- }
106
- (globalThis as any).logProfileMeasuresNow = logProfileMeasuresTimingsNow;
107
-
108
- (globalThis as any).logUnfiltered = function logUnfiltered(depth = 2) {
109
- let profile = measureObj.finish();
110
- measureObj = startMeasure();
111
- logMeasureTable(profile, {
112
- name: `all logs at ${new Date().toLocaleString()}`,
113
- mergeDepth: depth,
114
- minTimeToLog: 0,
115
- maxTableEntries: 10000000,
116
- thresholdInTable: 0
117
- });
118
- };
119
-
120
-
1
+ import { runInfinitePoll, runInfinitePollCallAtStart } from "socket-function/src/batching";
2
+ import { FormattedMeasureTable, MeasureProfile, logMeasureTable, startMeasure } from "socket-function/src/profiling/measure";
3
+ import { logErrors } from "../errors";
4
+ import { isNode, sort } from "socket-function/src/misc";
5
+ import debugbreak from "debugbreak";
6
+ import { registerPeriodic } from "./periodic";
7
+ import { getOwnMachineId } from "../-a-auth/certs";
8
+ import { SocketFunction } from "socket-function/SocketFunction";
9
+ import { formatPercent, formatTime } from "socket-function/src/formatting/format";
10
+ import { pathWatcher } from "../0-path-value-core/PathWatcher";
11
+ import { addStatPeriodic, addStatSumPeriodic, addTimeProfileDistribution, registerNodeMetadata } from "../-0-hooks/hooks";
12
+ import { logDisk } from "./logs/diskLogger";
13
+ import { getDebuggerUrl } from "./listenOnDebugger";
14
+ import { isPublic } from "../config";
15
+
16
+ let lastProfile: MeasureProfile | undefined;
17
+
18
+ addStatPeriodic({
19
+ title: "Performance|% Profiled",
20
+ getValue: () => {
21
+ if (!lastProfile) return 0;
22
+ let entries = Object.values(lastProfile.entries);
23
+ if (entries.length === 0) return 0;
24
+ const timeProfiled = lastProfile.endTime - lastProfile.startTime;
25
+
26
+ let timeActive = entries.map(x => x.ownTime.sum).reduce((a, b) => a + b, 0);
27
+ return timeActive / timeProfiled;
28
+ },
29
+ format: formatPercent,
30
+ });
31
+ registerNodeMetadata({
32
+ columnName: "Performance|Top Profiled",
33
+ getValue() {
34
+ if (!lastProfile) return "";
35
+ let entries = Object.values(lastProfile.entries);
36
+ if (entries.length === 0) return "";
37
+ const timeProfiled = lastProfile.endTime - lastProfile.startTime;
38
+
39
+ let rootSums = new Map<string, number>();
40
+ for (let entry of entries) {
41
+ let name = entry.name.split("|")[0];
42
+ let sum = rootSums.get(name) ?? 0;
43
+ rootSums.set(name, sum + entry.ownTime.sum);
44
+ }
45
+ let most = sort(Array.from(rootSums.entries()), x => -x[1])[0];
46
+ return `${endEllipsis(most[0], 26)} = ${formatPercent(most[1] / timeProfiled)}`;
47
+ },
48
+ });
49
+ addTimeProfileDistribution("Performance|Network Calls", () => SocketFunction.harvestCallTimes());
50
+ addStatPeriodic({
51
+ title: "Performance|Pending Net Calls",
52
+ getValue: () => SocketFunction.getPendingCallCount(),
53
+ });
54
+ addStatSumPeriodic({
55
+ title: "Performance|Failed Net Calls",
56
+ getValue: () => SocketFunction.harvestFailedCallCount(),
57
+ });
58
+ addTimeProfileDistribution("Performance|Syncing", () => pathWatcher.debug_harvestSyncTimes());
59
+
60
+
61
+ function endEllipsis(str: string, maxLength: number) {
62
+ if (str.length <= maxLength) return str;
63
+ return "..." + str.slice(-(maxLength - 3));
64
+ }
65
+
66
+ let minTimeToLog = 250;
67
+ export function watchdogSetMinTimeToLog(_minTimeToLog: number) {
68
+ minTimeToLog = _minTimeToLog;
69
+ }
70
+
71
+ let measureObj = startMeasure();
72
+ function logProfileMeasuresTimingsNow() {
73
+ let profile = measureObj.finish();
74
+ measureObj = startMeasure();
75
+ function diskLogMeasureObj(table: FormattedMeasureTable | undefined) {
76
+ if (!table) return;
77
+ console.info(table.title, { entries: table.entries });
78
+ }
79
+ diskLogMeasureObj(logMeasureTable(profile, {
80
+ name: `watchdog at ${new Date().toLocaleString()}`,
81
+ // NOTE: Much higher min log times, now that we are combining logs.
82
+ minTimeToLog: minTimeToLog,
83
+ thresholdInTable: 0,
84
+ setTitle: true
85
+ }));
86
+ diskLogMeasureObj(logMeasureTable(profile, {
87
+ name: `watchdog at ${new Date().toLocaleString()}`,
88
+ mergeDepth: 1,
89
+ minTimeToLog: minTimeToLog,
90
+ }));
91
+
92
+ if (isNode() && !isPublic()) {
93
+ let debuggerValue = getDebuggerUrl();
94
+ process.stdout.write(`\n${debuggerValue}\n`);
95
+ }
96
+
97
+ lastProfile = profile;
98
+ // if (isNode()) {
99
+ // if (SocketFunction.mountedNodeId) {
100
+ // console.log("Mounted as " + SocketFunction.mountedNodeId);
101
+ // } else {
102
+ // console.log("Not mounted");
103
+ // }
104
+ // }
105
+ }
106
+ (globalThis as any).logProfileMeasuresNow = logProfileMeasuresTimingsNow;
107
+
108
+ (globalThis as any).logUnfiltered = function logUnfiltered(depth = 2) {
109
+ let profile = measureObj.finish();
110
+ measureObj = startMeasure();
111
+ logMeasureTable(profile, {
112
+ name: `all logs at ${new Date().toLocaleString()}`,
113
+ mergeDepth: depth,
114
+ minTimeToLog: 0,
115
+ maxTableEntries: 10000000,
116
+ thresholdInTable: 0
117
+ });
118
+ };
119
+
120
+
121
121
  registerPeriodic(logProfileMeasuresTimingsNow);