@serve.zone/dcrouter 15.0.2 → 15.0.3

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 (70) hide show
  1. package/deno.json +1 -1
  2. package/dist_serve/bundle.js +768 -768
  3. package/dist_ts/00_commitinfo_data.js +1 -1
  4. package/dist_ts_web/00_commitinfo_data.js +1 -1
  5. package/dist_ts_web/appstate/acme.d.ts +17 -0
  6. package/dist_ts_web/appstate/acme.js +64 -0
  7. package/dist_ts_web/appstate/certificates.d.ts +37 -0
  8. package/dist_ts_web/appstate/certificates.js +107 -0
  9. package/dist_ts_web/appstate/config.d.ts +9 -0
  10. package/dist_ts_web/appstate/config.js +35 -0
  11. package/dist_ts_web/appstate/domains.d.ts +80 -0
  12. package/dist_ts_web/appstate/domains.js +324 -0
  13. package/dist_ts_web/appstate/email-domains.d.ts +25 -0
  14. package/dist_ts_web/appstate/email-domains.js +104 -0
  15. package/dist_ts_web/appstate/email-ops.d.ts +10 -0
  16. package/dist_ts_web/appstate/email-ops.js +40 -0
  17. package/dist_ts_web/appstate/login.d.ts +30 -0
  18. package/dist_ts_web/appstate/login.js +83 -0
  19. package/dist_ts_web/appstate/logs.d.ts +16 -0
  20. package/dist_ts_web/appstate/logs.js +27 -0
  21. package/dist_ts_web/appstate/network.d.ts +50 -0
  22. package/dist_ts_web/appstate/network.js +122 -0
  23. package/dist_ts_web/appstate/profiles-targets.d.ts +45 -0
  24. package/dist_ts_web/appstate/profiles-targets.js +173 -0
  25. package/dist_ts_web/appstate/remoteingress.d.ts +47 -0
  26. package/dist_ts_web/appstate/remoteingress.js +204 -0
  27. package/dist_ts_web/appstate/routes.d.ts +76 -0
  28. package/dist_ts_web/appstate/routes.js +316 -0
  29. package/dist_ts_web/appstate/runtime.d.ts +1 -0
  30. package/dist_ts_web/appstate/runtime.js +276 -0
  31. package/dist_ts_web/appstate/security.d.ts +29 -0
  32. package/dist_ts_web/appstate/security.js +167 -0
  33. package/dist_ts_web/appstate/shared.d.ts +3 -0
  34. package/dist_ts_web/appstate/shared.js +13 -0
  35. package/dist_ts_web/appstate/stats.d.ts +15 -0
  36. package/dist_ts_web/appstate/stats.js +59 -0
  37. package/dist_ts_web/appstate/target-profiles.d.ts +37 -0
  38. package/dist_ts_web/appstate/target-profiles.js +118 -0
  39. package/dist_ts_web/appstate/ui.d.ts +11 -0
  40. package/dist_ts_web/appstate/ui.js +55 -0
  41. package/dist_ts_web/appstate/users.d.ts +27 -0
  42. package/dist_ts_web/appstate/users.js +85 -0
  43. package/dist_ts_web/appstate/vpn.d.ts +44 -0
  44. package/dist_ts_web/appstate/vpn.js +148 -0
  45. package/dist_ts_web/appstate.d.ts +20 -568
  46. package/dist_ts_web/appstate.js +24 -2418
  47. package/package.json +1 -1
  48. package/ts/00_commitinfo_data.ts +1 -1
  49. package/ts_web/00_commitinfo_data.ts +1 -1
  50. package/ts_web/appstate/acme.ts +93 -0
  51. package/ts_web/appstate/certificates.ts +159 -0
  52. package/ts_web/appstate/config.ts +49 -0
  53. package/ts_web/appstate/domains.ts +429 -0
  54. package/ts_web/appstate/email-domains.ts +155 -0
  55. package/ts_web/appstate/email-ops.ts +57 -0
  56. package/ts_web/appstate/login.ts +128 -0
  57. package/ts_web/appstate/logs.ts +50 -0
  58. package/ts_web/appstate/network.ts +161 -0
  59. package/ts_web/appstate/profiles-targets.ts +240 -0
  60. package/ts_web/appstate/remoteingress.ts +300 -0
  61. package/ts_web/appstate/routes.ts +447 -0
  62. package/ts_web/appstate/runtime.ts +308 -0
  63. package/ts_web/appstate/security.ts +229 -0
  64. package/ts_web/appstate/shared.ts +15 -0
  65. package/ts_web/appstate/stats.ts +79 -0
  66. package/ts_web/appstate/target-profiles.ts +164 -0
  67. package/ts_web/appstate/ui.ts +75 -0
  68. package/ts_web/appstate/users.ts +133 -0
  69. package/ts_web/appstate/vpn.ts +234 -0
  70. package/ts_web/appstate.ts +24 -3403
@@ -0,0 +1,83 @@
1
+ import * as plugins from '../plugins.js';
2
+ import * as interfaces from '../../dist_ts_interfaces/index.js';
3
+ import { appState } from './shared.js';
4
+ export const loginStatePart = await appState.getStatePart('login', {
5
+ identity: null,
6
+ isLoggedIn: false,
7
+ }, 'persistent' // Login state persists across browser sessions
8
+ );
9
+ export const getActionContext = () => {
10
+ const identity = loginStatePart.getState().identity;
11
+ // Treat expired JWTs as no identity — prevents stale persisted sessions from firing requests
12
+ if (identity && identity.expiresAt && identity.expiresAt < Date.now()) {
13
+ return { identity: null };
14
+ }
15
+ return { identity };
16
+ };
17
+ // Login Action
18
+ export const loginAction = loginStatePart.createAction(async (statePartArg, dataArg) => {
19
+ const typedRequest = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'adminLoginWithUsernameAndPassword');
20
+ try {
21
+ const response = await typedRequest.fire({
22
+ username: dataArg.username,
23
+ password: dataArg.password,
24
+ authSource: dataArg.authSource,
25
+ });
26
+ if (response.identity) {
27
+ return {
28
+ identity: response.identity,
29
+ isLoggedIn: true,
30
+ };
31
+ }
32
+ return statePartArg.getState();
33
+ }
34
+ catch (error) {
35
+ console.error('Login failed:', error);
36
+ return statePartArg.getState();
37
+ }
38
+ });
39
+ export async function getAdminBootstrapStatus() {
40
+ const request = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'getAdminBootstrapStatus');
41
+ return request.fire({});
42
+ }
43
+ export async function createInitialAdminUser(optionsArg) {
44
+ const context = getActionContext();
45
+ if (!context.identity) {
46
+ throw new Error('No identity available for admin bootstrap');
47
+ }
48
+ const request = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'createInitialAdminUser');
49
+ const response = await request.fire({
50
+ identity: context.identity,
51
+ email: optionsArg.email,
52
+ name: optionsArg.name,
53
+ password: optionsArg.password,
54
+ enableIdpGlobalAuth: optionsArg.enableIdpGlobalAuth,
55
+ });
56
+ if (response.identity) {
57
+ loginStatePart.setState({
58
+ identity: response.identity,
59
+ isLoggedIn: true,
60
+ });
61
+ }
62
+ return response;
63
+ }
64
+ // Logout Action — always clears state, even if identity is expired/missing
65
+ export const logoutAction = loginStatePart.createAction(async (statePartArg) => {
66
+ const context = getActionContext();
67
+ // Try to notify server, but don't block logout if identity is missing/expired
68
+ if (context.identity) {
69
+ const typedRequest = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'adminLogout');
70
+ try {
71
+ await typedRequest.fire({ identity: context.identity });
72
+ }
73
+ catch (error) {
74
+ console.error('Logout error:', error);
75
+ }
76
+ }
77
+ // Always clear login state
78
+ return {
79
+ identity: null,
80
+ isLoggedIn: false,
81
+ };
82
+ });
83
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi90c193ZWIvYXBwc3RhdGUvbG9naW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxLQUFLLFVBQVUsTUFBTSw4QkFBOEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBU3ZDLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxNQUFNLFFBQVEsQ0FBQyxZQUFZLENBQ3ZELE9BQU8sRUFDUDtJQUNFLFFBQVEsRUFBRSxJQUFJO0lBQ2QsVUFBVSxFQUFFLEtBQUs7Q0FDbEIsRUFDRCxZQUFZLENBQUMsK0NBQStDO0NBQzdELENBQUM7QUFPRixNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxHQUFtQixFQUFFO0lBQ25ELE1BQU0sUUFBUSxHQUFHLGNBQWMsQ0FBQyxRQUFRLEVBQUcsQ0FBQyxRQUFRLENBQUM7SUFDckQsNkZBQTZGO0lBQzdGLElBQUksUUFBUSxJQUFJLFFBQVEsQ0FBQyxTQUFTLElBQUksUUFBUSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQztRQUN0RSxPQUFPLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFDRCxPQUFPLEVBQUUsUUFBUSxFQUFFLENBQUM7QUFDdEIsQ0FBQyxDQUFDO0FBRUYsZUFBZTtBQUNmLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxjQUFjLENBQUMsWUFBWSxDQUluRCxLQUFLLEVBQUUsWUFBWSxFQUFFLE9BQU8sRUFBd0IsRUFBRTtJQUN2RCxNQUFNLFlBQVksR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxZQUFZLENBRXpFLGVBQWUsRUFBRSxtQ0FBbUMsQ0FBQyxDQUFDO0lBRXhELElBQUksQ0FBQztRQUNI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
@@ -0,0 +1,16 @@
1
+ import * as plugins from '../plugins.js';
2
+ import * as interfaces from '../../dist_ts_interfaces/index.js';
3
+ export interface ILogState {
4
+ recentLogs: interfaces.data.ILogEntry[];
5
+ isStreaming: boolean;
6
+ filters: {
7
+ level?: string[];
8
+ category?: string[];
9
+ };
10
+ }
11
+ export declare const logStatePart: plugins.deesElement.domtools.plugins.smartstate.StatePart<string, ILogState>;
12
+ export declare const fetchRecentLogsAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<ILogState, {
13
+ limit?: number;
14
+ level?: "debug" | "info" | "warn" | "error";
15
+ category?: "smtp" | "dns" | "security" | "system" | "email";
16
+ }>;
@@ -0,0 +1,27 @@
1
+ import * as plugins from '../plugins.js';
2
+ import * as interfaces from '../../dist_ts_interfaces/index.js';
3
+ import { appState } from './shared.js';
4
+ import { getActionContext } from './login.js';
5
+ export const logStatePart = await appState.getStatePart('logs', {
6
+ recentLogs: [],
7
+ isStreaming: false,
8
+ filters: {},
9
+ }, 'soft');
10
+ // Fetch Recent Logs Action
11
+ export const fetchRecentLogsAction = logStatePart.createAction(async (statePartArg, dataArg) => {
12
+ const context = getActionContext();
13
+ if (!context.identity)
14
+ return statePartArg.getState();
15
+ const logsRequest = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'getRecentLogs');
16
+ const response = await logsRequest.fire({
17
+ identity: context.identity,
18
+ limit: dataArg.limit || 100,
19
+ level: dataArg.level,
20
+ category: dataArg.category,
21
+ });
22
+ return {
23
+ ...statePartArg.getState(),
24
+ recentLogs: response.logs,
25
+ };
26
+ });
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9ncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3RzX3dlYi9hcHBzdGF0ZS9sb2dzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sS0FBSyxVQUFVLE1BQU0sOEJBQThCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN2QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFXOUMsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLE1BQU0sUUFBUSxDQUFDLFlBQVksQ0FDckQsTUFBTSxFQUNOO0lBQ0UsVUFBVSxFQUFFLEVBQUU7SUFDZCxXQUFXLEVBQUUsS0FBSztJQUNsQixPQUFPLEVBQUUsRUFBRTtDQUNaLEVBQ0QsTUFBTSxDQUNQLENBQUM7QUFFRiwyQkFBMkI7QUFDM0IsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcsWUFBWSxDQUFDLFlBQVksQ0FJM0QsS0FBSyxFQUFFLFlBQVksRUFBRSxPQUFPLEVBQXNCLEVBQUU7SUFDckQsTUFBTSxPQUFPLEdBQUcsZ0JBQWdCLEVBQUUsQ0FBQztJQUNuQyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVE7UUFBRSxPQUFPLFlBQVksQ0FBQyxRQUFRLEVBQUcsQ0FBQztJQUV2RCxNQUFNLFdBQVcsR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxZQUFZLENBRXhFLGVBQWUsRUFBRSxlQUFlLENBQUMsQ0FBQztJQUVwQyxNQUFNLFFBQVEsR0FBRyxNQUFNLFdBQVcsQ0FBQyxJQUFJLENBQUM7UUFDdEMsUUFBUSxFQUFFLE9BQU8sQ0FBQyxRQUFRO1FBQzFCLEtBQUssRUFBRSxPQUFPLENBQUMsS0FBSyxJQUFJLEdBQUc7UUFDM0IsS0FBSyxFQUFFLE9BQU8sQ0FBQyxLQUFLO1FBQ3BCLFFBQVEsRUFBRSxPQUFPLENBQUMsUUFBUTtLQUMzQixDQUFDLENBQUM7SUFFSCxPQUFPO1FBQ0wsR0FBRyxZQUFZLENBQUMsUUFBUSxFQUFHO1FBQzNCLFVBQVUsRUFBRSxRQUFRLENBQUMsSUFBSTtLQUMxQixDQUFDO0FBQ0osQ0FBQyxDQUFDLENBQUMifQ==
@@ -0,0 +1,50 @@
1
+ import * as plugins from '../plugins.js';
2
+ import * as interfaces from '../../dist_ts_interfaces/index.js';
3
+ export interface INetworkState {
4
+ connections: interfaces.data.IConnectionInfo[];
5
+ connectionsByIP: {
6
+ [ip: string]: number;
7
+ };
8
+ throughputRate: {
9
+ bytesInPerSecond: number;
10
+ bytesOutPerSecond: number;
11
+ };
12
+ totalBytes: {
13
+ in: number;
14
+ out: number;
15
+ };
16
+ topIPs: Array<{
17
+ ip: string;
18
+ count: number;
19
+ }>;
20
+ topIPsByBandwidth: Array<{
21
+ ip: string;
22
+ count: number;
23
+ bwIn: number;
24
+ bwOut: number;
25
+ }>;
26
+ topASNs: interfaces.data.IAsnActivity[];
27
+ throughputByIP: Array<{
28
+ ip: string;
29
+ in: number;
30
+ out: number;
31
+ }>;
32
+ ipIntelligence: interfaces.data.IIpIntelligenceRecord[];
33
+ domainActivity: interfaces.data.IDomainActivity[];
34
+ throughputHistory: Array<{
35
+ timestamp: number;
36
+ in: number;
37
+ out: number;
38
+ }>;
39
+ requestsPerSecond: number;
40
+ requestsTotal: number;
41
+ backends: interfaces.data.IBackendInfo[];
42
+ frontendProtocols: interfaces.data.IProtocolDistribution | null;
43
+ backendProtocols: interfaces.data.IProtocolDistribution | null;
44
+ lastUpdated: number;
45
+ isLoading: boolean;
46
+ error: string | null;
47
+ }
48
+ export declare const networkStatePart: plugins.deesElement.domtools.plugins.smartstate.StatePart<string, INetworkState>;
49
+ export declare function refreshNetworkIpIntelligence(identity: interfaces.data.IIdentity, ipAddresses: string[]): void;
50
+ export declare const fetchNetworkStatsAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<INetworkState, unknown>;
@@ -0,0 +1,122 @@
1
+ import * as plugins from '../plugins.js';
2
+ import * as interfaces from '../../dist_ts_interfaces/index.js';
3
+ import { appState } from './shared.js';
4
+ import { getActionContext } from './login.js';
5
+ import { runBackgroundRefresh } from './shared.js';
6
+ export const networkStatePart = await appState.getStatePart('network', {
7
+ connections: [],
8
+ connectionsByIP: {},
9
+ throughputRate: { bytesInPerSecond: 0, bytesOutPerSecond: 0 },
10
+ totalBytes: { in: 0, out: 0 },
11
+ topIPs: [],
12
+ topIPsByBandwidth: [],
13
+ topASNs: [],
14
+ throughputByIP: [],
15
+ ipIntelligence: [],
16
+ domainActivity: [],
17
+ throughputHistory: [],
18
+ requestsPerSecond: 0,
19
+ requestsTotal: 0,
20
+ backends: [],
21
+ frontendProtocols: null,
22
+ backendProtocols: null,
23
+ lastUpdated: 0,
24
+ isLoading: false,
25
+ error: null,
26
+ }, 'soft');
27
+ export function refreshNetworkIpIntelligence(identity, ipAddresses) {
28
+ const ips = [...new Set(ipAddresses.filter(Boolean))].slice(0, 100);
29
+ if (ips.length === 0)
30
+ return;
31
+ runBackgroundRefresh('networkIpIntelligence', 'IP intelligence refresh failed:', async () => {
32
+ const intelligenceRequest = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'listIpIntelligence');
33
+ const intelligenceResponse = await intelligenceRequest.fire({
34
+ identity,
35
+ ipAddresses: ips,
36
+ limit: Math.max(100, ips.length),
37
+ });
38
+ networkStatePart.setState({
39
+ ...networkStatePart.getState(),
40
+ ipIntelligence: intelligenceResponse.records || [],
41
+ });
42
+ });
43
+ }
44
+ // Fetch Network Stats Action
45
+ export const fetchNetworkStatsAction = networkStatePart.createAction(async (statePartArg) => {
46
+ const context = getActionContext();
47
+ const currentState = statePartArg.getState();
48
+ if (!context.identity)
49
+ return currentState;
50
+ try {
51
+ // Get network stats for throughput and IP data
52
+ const networkStatsRequest = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'getNetworkStats');
53
+ const networkStatsResponse = await networkStatsRequest.fire({
54
+ identity: context.identity,
55
+ });
56
+ // Use the connections data for the connection list
57
+ // and network stats for throughput and IP analytics
58
+ const connectionsByIP = {};
59
+ const throughputByIP = new Map();
60
+ for (const item of networkStatsResponse.throughputByIP || []) {
61
+ throughputByIP.set(item.ip, { in: item.in, out: item.out });
62
+ }
63
+ // Build connectionsByIP from network stats if available
64
+ if (networkStatsResponse.connectionsByIP && Array.isArray(networkStatsResponse.connectionsByIP)) {
65
+ networkStatsResponse.connectionsByIP.forEach((item) => {
66
+ connectionsByIP[item.ip] = item.count;
67
+ });
68
+ }
69
+ const connections = Object.entries(connectionsByIP).map(([ip, count]) => {
70
+ const tp = throughputByIP.get(ip);
71
+ return {
72
+ id: `ip-${ip}`,
73
+ remoteAddress: ip,
74
+ localAddress: 'server',
75
+ startTime: 0,
76
+ protocol: 'https',
77
+ state: 'connected',
78
+ bytesReceived: tp?.in || 0,
79
+ bytesSent: tp?.out || 0,
80
+ connectionCount: count,
81
+ };
82
+ });
83
+ refreshNetworkIpIntelligence(context.identity, [
84
+ ...Object.keys(connectionsByIP),
85
+ ...(networkStatsResponse.topIPs || []).map((item) => item.ip),
86
+ ...(networkStatsResponse.topIPsByBandwidth || []).map((item) => item.ip),
87
+ ]);
88
+ return {
89
+ connections,
90
+ connectionsByIP,
91
+ throughputRate: networkStatsResponse.throughputRate || { bytesInPerSecond: 0, bytesOutPerSecond: 0 },
92
+ totalBytes: networkStatsResponse.totalDataTransferred
93
+ ? { in: networkStatsResponse.totalDataTransferred.bytesIn, out: networkStatsResponse.totalDataTransferred.bytesOut }
94
+ : { in: 0, out: 0 },
95
+ topIPs: networkStatsResponse.topIPs || [],
96
+ topIPsByBandwidth: networkStatsResponse.topIPsByBandwidth || [],
97
+ topASNs: networkStatsResponse.topASNs || [],
98
+ throughputByIP: networkStatsResponse.throughputByIP || [],
99
+ ipIntelligence: currentState.ipIntelligence,
100
+ domainActivity: networkStatsResponse.domainActivity || [],
101
+ throughputHistory: networkStatsResponse.throughputHistory || [],
102
+ requestsPerSecond: networkStatsResponse.requestsPerSecond || 0,
103
+ requestsTotal: networkStatsResponse.requestsTotal || 0,
104
+ backends: networkStatsResponse.backends || [],
105
+ frontendProtocols: networkStatsResponse.frontendProtocols || null,
106
+ backendProtocols: networkStatsResponse.backendProtocols || null,
107
+ lastUpdated: Date.now(),
108
+ isLoading: false,
109
+ error: null,
110
+ };
111
+ }
112
+ catch (error) {
113
+ console.error('Failed to fetch network stats:', error);
114
+ return {
115
+ ...currentState,
116
+ isLoading: false,
117
+ error: error instanceof Error ? error.message : 'Failed to fetch network stats',
118
+ };
119
+ }
120
+ });
121
+ // ============================================================================
122
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV0d29yay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3RzX3dlYi9hcHBzdGF0ZS9uZXR3b3JrLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sS0FBSyxVQUFVLE1BQU0sOEJBQThCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN2QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDOUMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBd0JuRCxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxNQUFNLFFBQVEsQ0FBQyxZQUFZLENBQ3pELFNBQVMsRUFDVDtJQUNFLFdBQVcsRUFBRSxFQUFFO0lBQ2YsZUFBZSxFQUFFLEVBQUU7SUFDbkIsY0FBYyxFQUFFLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxFQUFFLGlCQUFpQixFQUFFLENBQUMsRUFBRTtJQUM3RCxVQUFVLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUU7SUFDN0IsTUFBTSxFQUFFLEVBQUU7SUFDVixpQkFBaUIsRUFBRSxFQUFFO0lBQ3JCLE9BQU8sRUFBRSxFQUFFO0lBQ1gsY0FBYyxFQUFFLEVBQUU7SUFDbEIsY0FBYyxFQUFFLEVBQUU7SUFDbEIsY0FBYyxFQUFFLEVBQUU7SUFDbEIsaUJBQWlCLEVBQUUsRUFBRTtJQUNyQixpQkFBaUIsRUFBRSxDQUFDO0lBQ3BCLGFBQWEsRUFBRSxDQUFDO0lBQ2hCLFFBQVEsRUFBRSxFQUFFO0lBQ1osaUJBQWlCLEVBQUUsSUFBSTtJQUN2QixnQkFBZ0IsRUFBRSxJQUFJO0lBQ3RCLFdBQVcsRUFBRSxDQUFDO0lBQ2QsU0FBUyxFQUFFLEtBQUs7SUFDaEIsS0FBSyxFQUFFLElBQUk7Q0FDWixFQUNELE1BQU0sQ0FDUCxD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
@@ -0,0 +1,45 @@
1
+ import * as plugins from '../plugins.js';
2
+ import * as interfaces from '../../dist_ts_interfaces/index.js';
3
+ export interface IProfilesTargetsState {
4
+ profiles: interfaces.data.ISourceProfile[];
5
+ targets: interfaces.data.INetworkTarget[];
6
+ isLoading: boolean;
7
+ error: string | null;
8
+ lastUpdated: number;
9
+ }
10
+ export declare const profilesTargetsStatePart: plugins.deesElement.domtools.plugins.smartstate.StatePart<string, IProfilesTargetsState>;
11
+ export declare const fetchProfilesAndTargetsAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IProfilesTargetsState, unknown>;
12
+ export declare const createProfileAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IProfilesTargetsState, {
13
+ name: string;
14
+ description?: string;
15
+ security: any;
16
+ extendsProfiles?: string[];
17
+ }>;
18
+ export declare const updateProfileAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IProfilesTargetsState, {
19
+ id: string;
20
+ name?: string;
21
+ description?: string;
22
+ security?: any;
23
+ extendsProfiles?: string[];
24
+ }>;
25
+ export declare const deleteProfileAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IProfilesTargetsState, {
26
+ id: string;
27
+ force?: boolean;
28
+ }>;
29
+ export declare const createTargetAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IProfilesTargetsState, {
30
+ name: string;
31
+ description?: string;
32
+ host: string | string[];
33
+ port: number;
34
+ }>;
35
+ export declare const updateTargetAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IProfilesTargetsState, {
36
+ id: string;
37
+ name?: string;
38
+ description?: string;
39
+ host?: string | string[];
40
+ port?: number;
41
+ }>;
42
+ export declare const deleteTargetAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IProfilesTargetsState, {
43
+ id: string;
44
+ force?: boolean;
45
+ }>;
@@ -0,0 +1,173 @@
1
+ import * as plugins from '../plugins.js';
2
+ import * as interfaces from '../../dist_ts_interfaces/index.js';
3
+ import { appState } from './shared.js';
4
+ import { getActionContext } from './login.js';
5
+ export const profilesTargetsStatePart = await appState.getStatePart('profilesTargets', {
6
+ profiles: [],
7
+ targets: [],
8
+ isLoading: false,
9
+ error: null,
10
+ lastUpdated: 0,
11
+ }, 'soft');
12
+ // ============================================================================
13
+ // Source Profiles & Network Targets Actions
14
+ // ============================================================================
15
+ export const fetchProfilesAndTargetsAction = profilesTargetsStatePart.createAction(async (statePartArg) => {
16
+ const context = getActionContext();
17
+ const currentState = statePartArg.getState();
18
+ if (!context.identity)
19
+ return currentState;
20
+ try {
21
+ const profilesRequest = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'getSourceProfiles');
22
+ const targetsRequest = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'getNetworkTargets');
23
+ const [profilesResponse, targetsResponse] = await Promise.all([
24
+ profilesRequest.fire({ identity: context.identity }),
25
+ targetsRequest.fire({ identity: context.identity }),
26
+ ]);
27
+ return {
28
+ profiles: profilesResponse.profiles,
29
+ targets: targetsResponse.targets,
30
+ isLoading: false,
31
+ error: null,
32
+ lastUpdated: Date.now(),
33
+ };
34
+ }
35
+ catch (error) {
36
+ return {
37
+ ...currentState,
38
+ isLoading: false,
39
+ error: error instanceof Error ? error.message : 'Failed to fetch profiles/targets',
40
+ };
41
+ }
42
+ });
43
+ export const createProfileAction = profilesTargetsStatePart.createAction(async (statePartArg, dataArg, actionContext) => {
44
+ const context = getActionContext();
45
+ try {
46
+ const request = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'createSourceProfile');
47
+ await request.fire({
48
+ identity: context.identity,
49
+ name: dataArg.name,
50
+ description: dataArg.description,
51
+ security: dataArg.security,
52
+ extendsProfiles: dataArg.extendsProfiles,
53
+ });
54
+ return await actionContext.dispatch(fetchProfilesAndTargetsAction, null);
55
+ }
56
+ catch (error) {
57
+ return {
58
+ ...statePartArg.getState(),
59
+ error: error instanceof Error ? error.message : 'Failed to create profile',
60
+ };
61
+ }
62
+ });
63
+ export const updateProfileAction = profilesTargetsStatePart.createAction(async (statePartArg, dataArg, actionContext) => {
64
+ const context = getActionContext();
65
+ try {
66
+ const request = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'updateSourceProfile');
67
+ await request.fire({
68
+ identity: context.identity,
69
+ id: dataArg.id,
70
+ name: dataArg.name,
71
+ description: dataArg.description,
72
+ security: dataArg.security,
73
+ extendsProfiles: dataArg.extendsProfiles,
74
+ });
75
+ return await actionContext.dispatch(fetchProfilesAndTargetsAction, null);
76
+ }
77
+ catch (error) {
78
+ return {
79
+ ...statePartArg.getState(),
80
+ error: error instanceof Error ? error.message : 'Failed to update profile',
81
+ };
82
+ }
83
+ });
84
+ export const deleteProfileAction = profilesTargetsStatePart.createAction(async (statePartArg, dataArg, actionContext) => {
85
+ const context = getActionContext();
86
+ try {
87
+ const request = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'deleteSourceProfile');
88
+ const response = await request.fire({
89
+ identity: context.identity,
90
+ id: dataArg.id,
91
+ force: dataArg.force,
92
+ });
93
+ if (!response.success) {
94
+ return {
95
+ ...statePartArg.getState(),
96
+ error: response.message || 'Failed to delete profile',
97
+ };
98
+ }
99
+ return await actionContext.dispatch(fetchProfilesAndTargetsAction, null);
100
+ }
101
+ catch (error) {
102
+ return {
103
+ ...statePartArg.getState(),
104
+ error: error instanceof Error ? error.message : 'Failed to delete profile',
105
+ };
106
+ }
107
+ });
108
+ export const createTargetAction = profilesTargetsStatePart.createAction(async (statePartArg, dataArg, actionContext) => {
109
+ const context = getActionContext();
110
+ try {
111
+ const request = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'createNetworkTarget');
112
+ await request.fire({
113
+ identity: context.identity,
114
+ name: dataArg.name,
115
+ description: dataArg.description,
116
+ host: dataArg.host,
117
+ port: dataArg.port,
118
+ });
119
+ return await actionContext.dispatch(fetchProfilesAndTargetsAction, null);
120
+ }
121
+ catch (error) {
122
+ return {
123
+ ...statePartArg.getState(),
124
+ error: error instanceof Error ? error.message : 'Failed to create target',
125
+ };
126
+ }
127
+ });
128
+ export const updateTargetAction = profilesTargetsStatePart.createAction(async (statePartArg, dataArg, actionContext) => {
129
+ const context = getActionContext();
130
+ try {
131
+ const request = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'updateNetworkTarget');
132
+ await request.fire({
133
+ identity: context.identity,
134
+ id: dataArg.id,
135
+ name: dataArg.name,
136
+ description: dataArg.description,
137
+ host: dataArg.host,
138
+ port: dataArg.port,
139
+ });
140
+ return await actionContext.dispatch(fetchProfilesAndTargetsAction, null);
141
+ }
142
+ catch (error) {
143
+ return {
144
+ ...statePartArg.getState(),
145
+ error: error instanceof Error ? error.message : 'Failed to update target',
146
+ };
147
+ }
148
+ });
149
+ export const deleteTargetAction = profilesTargetsStatePart.createAction(async (statePartArg, dataArg, actionContext) => {
150
+ const context = getActionContext();
151
+ try {
152
+ const request = new plugins.domtools.plugins.typedrequest.TypedRequest('/typedrequest', 'deleteNetworkTarget');
153
+ const response = await request.fire({
154
+ identity: context.identity,
155
+ id: dataArg.id,
156
+ force: dataArg.force,
157
+ });
158
+ if (!response.success) {
159
+ return {
160
+ ...statePartArg.getState(),
161
+ error: response.message || 'Failed to delete target',
162
+ };
163
+ }
164
+ return await actionContext.dispatch(fetchProfilesAndTargetsAction, null);
165
+ }
166
+ catch (error) {
167
+ return {
168
+ ...statePartArg.getState(),
169
+ error: error instanceof Error ? error.message : 'Failed to delete target',
170
+ };
171
+ }
172
+ });
173
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZmlsZXMtdGFyZ2V0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3RzX3dlYi9hcHBzdGF0ZS9wcm9maWxlcy10YXJnZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sS0FBSyxVQUFVLE1BQU0sOEJBQThCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN2QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFjOUMsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcsTUFBTSxRQUFRLENBQUMsWUFBWSxDQUNqRSxpQkFBaUIsRUFDakI7SUFDRSxRQUFRLEVBQUUsRUFBRTtJQUNaLE9BQU8sRUFBRSxFQUFFO0lBQ1gsU0FBUyxFQUFFLEtBQUs7SUFDaEIsS0FBSyxFQUFFLElBQUk7SUFDWCxXQUFXLEVBQUUsQ0FBQztDQUNmLEVBQ0QsTUFBTSxDQUNQLENBQUM7QUFFRiwrRUFBK0U7QUFDL0UsNENBQTRDO0FBQzVDLCtFQUErRTtBQUUvRSxNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBRyx3QkFBd0IsQ0FBQyxZQUFZLENBQ2hGLEtBQUssRUFBRSxZQUFZLEVBQWtDLEVBQUU7SUFDckQsTUFBTSxPQUFPLEdBQUcsZ0JBQWdCLEVBQUUsQ0FBQztJQUNuQyxNQUFNLFlBQVksR0FBRyxZQUFZLENBQUMsUUFBUSxFQUFHLENBQUM7SUFDOUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRO1FBQUUsT0FBTyxZQUFZLENBQUM7SUFFM0MsSUFBSSxDQUFDO1FBQ0gsTUFBTSxlQUFlLEdBQUcsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUMsWUFBWSxDQUU1RSxlQUFlLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztRQUV4QyxNQUFNLGNBQWMsR0FBRyxJQUFJLE9BQU8s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
@@ -0,0 +1,47 @@
1
+ import * as plugins from '../plugins.js';
2
+ import * as interfaces from '../../dist_ts_interfaces/index.js';
3
+ export interface IRemoteIngressState {
4
+ edges: interfaces.data.IRemoteIngress[];
5
+ statuses: interfaces.data.IRemoteIngressStatus[];
6
+ hubSettings: interfaces.data.IRemoteIngressHubSettings | null;
7
+ selectedEdgeId: string | null;
8
+ newEdgeId: string | null;
9
+ isLoading: boolean;
10
+ error: string | null;
11
+ lastUpdated: number;
12
+ }
13
+ export declare const remoteIngressStatePart: plugins.deesElement.domtools.plugins.smartstate.StatePart<string, IRemoteIngressState>;
14
+ export declare function fetchConnectionToken(edgeId: string): Promise<{
15
+ success: boolean;
16
+ token?: string;
17
+ message?: string;
18
+ }>;
19
+ export declare const fetchRemoteIngressAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IRemoteIngressState, unknown>;
20
+ export declare const createRemoteIngressAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IRemoteIngressState, {
21
+ name: string;
22
+ listenPorts?: number[];
23
+ autoDerivePorts?: boolean;
24
+ performance?: interfaces.data.IRemoteIngressPerformanceConfig;
25
+ tags?: string[];
26
+ }>;
27
+ export declare const deleteRemoteIngressAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IRemoteIngressState, string>;
28
+ export declare const updateRemoteIngressAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IRemoteIngressState, {
29
+ id: string;
30
+ name?: string;
31
+ listenPorts?: number[];
32
+ autoDerivePorts?: boolean;
33
+ performance?: interfaces.data.IRemoteIngressPerformanceConfig;
34
+ tags?: string[];
35
+ }>;
36
+ export declare const updateRemoteIngressHubSettingsAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IRemoteIngressState, {
37
+ enabled?: boolean;
38
+ tunnelPort?: number;
39
+ hubDomain?: string | null;
40
+ performance?: interfaces.data.IRemoteIngressPerformanceConfig | null;
41
+ }>;
42
+ export declare const regenerateRemoteIngressSecretAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IRemoteIngressState, string>;
43
+ export declare const clearNewEdgeIdAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IRemoteIngressState, unknown>;
44
+ export declare const toggleRemoteIngressAction: plugins.deesElement.domtools.plugins.smartstate.StateAction<IRemoteIngressState, {
45
+ id: string;
46
+ enabled: boolean;
47
+ }>;