22986af20d
multiple clients and agents.
2024-08-24 21:17:56 +02:00
1b98b0fa90
now asserting succesful client creation after calling connectClient()
...
THis way conenctClient(0 can be used also for cases where client
connection
is not successful.
2024-08-24 20:44:12 +02:00
f16d228f6f
connectClient now returns an error when unsuccessful.
2024-08-24 20:43:20 +02:00
7e062f5777
reintroduced ClientInfo because it does appear to work.
...
Most likely some error elsewhere caused it not to work previously
2024-08-24 20:34:27 +02:00
d1f646e7eb
connectClient() extracted to make it easy to connect a client.
2024-08-24 19:57:02 +02:00
e1bf733ebb
changes for testing agent connect by returning a synchronizer() function
...
that must be called after connect to synchronize data.
2024-08-24 19:48:53 +02:00
ba8bd15cf7
work in progress for testing the matchmaker.
2024-08-23 21:10:01 +02:00
670a705326
test multiple clients now working with a fully concurrent registration
...
of clients.
2024-08-23 16:32:41 +02:00
538a697770
multiple clients connecting to multiple agents.
...
Clients cannot yet be started in parallel. due to subtle issue in test
setup with accept
2024-08-22 22:44:54 +02:00
8fcdf5711f
now also testing client removal.
2024-08-22 17:33:54 +02:00
4e2265c1b3
remove agent now also tested.
2024-08-22 17:28:10 +02:00
acd9f0441a
some refactoring inpraparation for multiple agents and clients.
2024-08-22 17:13:34 +02:00
b56950d4c8
test for unknown rendez-vous id.
2024-08-22 16:56:21 +02:00
496380156d
added leak detection using the goleak library
2024-08-22 16:38:37 +02:00
7d25f39f5b
test for connecting clients and bidirectional communication to agent.
...
Required lots of rework since the GOBChannel appeared to be reading
ahead of the data it actually needed. Now using more low-level IO
to send the clientId over to the agent instead.
2024-08-22 16:16:02 +02:00
c622caf7be
test for duplicate id and new id gene4ration done
2024-08-22 12:00:22 +02:00
433e65c924
agent registers with duplica id
2024-08-22 11:24:27 +02:00
ca3225563a
testing many agents registring
2024-08-22 11:05:45 +02:00
07a5454e88
prepare test for more agents and clietns.
2024-08-22 10:38:45 +02:00
25ba2cf464
test case for single agent registration.
2024-08-22 10:28:54 +02:00
53534af27c
test for ListenForAgentEvents implemented.
2024-08-21 17:48:47 +02:00
a62a513105
go conventions: context should be first argument.
2024-08-19 19:22:44 +02:00
57c77e7d07
initial state is now sent again when the websocket connection is
...
established.
Also throttling based on user input. When browser sends multiple
messages per second the user will still only get one notification per
second at most.
2024-08-18 11:44:16 +02:00
9a5aaf56eb
consistent casing in the titles (all lower case)
2024-08-18 01:19:46 +02:00
a3fe2fbcb6
hostkey is now sent from the server to the agent so that at a later
...
stage we can make the hostkey conrfigurable at the server level instead
of using a fixed hardcoded key.
2024-08-17 21:35:29 +02:00
2c42f89547
moved all ui stuff to the ui package.
...
The structure of converge server is now much more clear in the package
// structure below pkg/server.
2024-08-17 10:37:20 +02:00
2b9821f967
renamed templates package to ui
2024-08-17 10:22:03 +02:00
a12416cd21
moved prometheus to its own package.
2024-08-17 10:17:47 +02:00
7ab213c34e
removed unused field LocalShells of UsageInputs.
2024-08-17 10:14:22 +02:00
0077bdfbc5
introduced DownloadCommand and Shell types to improve type safety
2024-08-17 10:12:09 +02:00
9634cd29f2
about page vvarious fixes, typo's etc.
2024-08-16 08:33:32 +02:00
b6962e3cb6
Server side sorting for the websessions page. No longer using LinkedMap as a result.
2024-08-16 00:25:17 +02:00
deba6c7e91
Now using a map of ClientId to clientConnection which is more efficient for deleting clients.
2024-08-15 22:16:20 +02:00
cdfe7c2a47
Separated out the metadata about the agents and clients from the agentConnection and clientConnection objects. Now, the state does not need to be copied anymore when sending notifications.
...
The matchmaker uses copy on write every time a new agent or client connects or disconnects.
2024-08-15 22:08:24 +02:00
56ad9fbf03
concurrency for the expiry time
2024-08-15 21:25:30 +02:00
fd18a63360
now using maps of Guid to Agent/Client in the state, working towards the definitive solution.
...
Using LinkedMap that preserves insertion order for the implementation and also added unit tests for that.
2024-08-15 21:04:31 +02:00
98f6b414de
introdcution of typesafe ids.
2024-08-15 18:32:59 +02:00
fd064f249f
using unbuffered channels everywhere now. Only change required was to initialize prometeus and the websessions before the matchmaker. This is because at startup the matchmaker wants to write a notification when it starts up but then prometheus and the websessions would not be there to read them.
...
Alternative solution would be to run all initialization code in go routines to make it independent of initialization order but having a defined initialization order is much cleaner.
2024-08-13 21:33:29 +02:00
aa05e5819b
fixed typos
2024-08-13 19:21:19 +02:00
3bbebd0dda
timezone handling now moved to a separate script that does not leak any symbols.
2024-08-13 11:33:15 +02:00
00a9a91788
added a utility function for logging request data.
2024-08-13 11:32:51 +02:00
bac7a9a6f1
Much imporoved websocket connection closure will now detect closing of
...
websockets immediately.
2024-08-13 10:57:05 +02:00
cb03b79630
updated the about page
2024-08-13 00:50:54 +02:00
df9409fc75
now a single websocket is opened from the webui to converge.
...
The browser sends a hello message anytime the user switches to the
sessions page, upon which the server sends the current state back.
THis also improves the timeout handling of broken connecions.
2024-08-12 23:44:07 +02:00
dfdea81c20
renamed converge package to matchmaker.
2024-08-12 21:53:26 +02:00
54165f83c7
renamed modukle name so that pkgsite will work.
2024-08-12 21:31:15 +02:00
28b95ff5db
Addes agent address and client address to the client and agent info.
2024-08-12 15:23:07 +02:00
17f5e10547
ClientConnection no longer has public fields.
2024-08-11 19:01:39 +02:00
60e7cac61b
a lot of work to get prometheus monitoring better.
...
Now the duration is updated every second to get more accurate readings. Also, the time series are now cleaned up when they no longer exists. Previously, all time series were deleted and then everything was setup from scratch.
2024-08-11 17:49:52 +02:00
69a8a1aad3
much more clean handling of concurrency in the converge server by separating the administration from the matchmaking by putting admin in a separate package.
2024-08-11 16:17:11 +02:00