Commit Graph

97 Commits

Author SHA1 Message Date
5a91d86b39 fixed typo 2024-08-01 21:23:41 +02:00
7f5768a1e1 dockerfile now also runs templ 2024-08-01 21:21:31 +02:00
b49a4e7613 remark about tcptows 2024-08-01 21:01:27 +02:00
0d60b70ada Updated documentation:
* remote shell usage for linux, cmd, and powershell
* help of wsproxy.
2024-08-01 20:53:52 +02:00
ff97c1ccd2 Now by default wsproxy uses a specific protocol to establish connections to the server. It does this by adding the ?wsproxy query parameter.
The server then sends it the protocol version and the client connection info describing whether an agent was found or not. This improves usability for users.

With the --raw option it bypasses this query parameter and wsproxy then works in the old way as a simple stdio-websocket connector. It then still works with converge server but can also be used for simple websocket troubleshooting.
2024-08-01 20:22:41 +02:00
5c251daa47 Using # instead of id in the sessions page to avoid confusion with the term id used in the docs. 2024-08-01 19:21:39 +02:00
Erik Brakkee
2e12d0a9fd Now displaying agent number instead of id.
Passing timezone to server side for rendering of time stamps
Configuration of preferred shells.
2024-08-01 19:16:00 +02:00
4c52fb0f12 Rendering status as HTML tables. 2024-07-31 21:12:09 +02:00
885b7790d7 doing the same thing as before but now rendering the
status using a template.
2024-07-31 19:52:01 +02:00
Erik Brakkee
f0dd810541 many small changes
* removed the Async utility
* now using Ping message to webclient for keep alive instaed of actual content
* added remote shell to AgentInfo
* retry of connections to the agent
* better logging for SynchronizeStreams
2024-07-31 19:30:38 +02:00
658aaf3880 typo in usage.html 2024-07-30 23:55:09 +02:00
01c9cdd60a usage fix (agent was renamed by intellij to session)
Now using embedded timezone database by go so setting the TZ variable will work.
2024-07-30 23:48:52 +02:00
9a3618f06b Live updates of the sessions.
V1 in ascii-art. To be improved.
2024-07-30 21:51:30 +02:00
f382c02b41 restructuring 2024-07-30 19:59:13 +02:00
367043e0c5 When a duplicate id is requested the server now allocates a new unique id so that the session can be handled anyway. 2024-07-30 19:45:25 +02:00
c1e91f0aba Adding rm/del instruction for agents. 2024-07-30 19:04:46 +02:00
bf5120aa5b refactoring towards being able to send events from Admin to UI (websocket) without exposing connection info but only metadata. 2024-07-30 19:03:21 +02:00
5533b04a5e removed hardcoded host used for testing. 2024-07-30 00:02:52 +02:00
9a10182f76 missing files checked in:
htmx + websocket extension
render.sh script for generating html of the webinterface for quickly
seeing results after modifying templates.
.gitignore file for ignoring generated stuff.
2024-07-29 23:58:48 +02:00
39cf088a41 basic htmx with server sending content to the client over a websocket is now working. This only worked when text message where being sent so the websocket handling had to be made configurable with a 'text' boolean field. 2024-07-29 23:56:44 +02:00
77cffde408 tabbed interface. 2024-07-29 21:05:14 +02:00
68056b0b77 split up in separate pages. 2024-07-29 20:02:08 +02:00
f5135aecdc docs page now working again. 2024-07-29 19:49:47 +02:00
fb8ed0622b extracted basepage. 2024-07-29 19:23:01 +02:00
92504f4130 Split up the main page into different parts. 2024-07-29 19:16:48 +02:00
a4d5060163 Split up the main page into different parts. 2024-07-29 19:02:50 +02:00
f7e94c21f9 Fixed typo: continous continuous. 2024-07-29 18:32:11 +02:00
c8d328dc75 downgrading to alpine 3.19.3 so that we get go 1.21 (same as in dev env). This makes troubleshooting easier. 2024-07-29 18:30:58 +02:00
b1f7304eeb Now rendering the index.html using the Templ library.
This is in preparation for:
1. creating a base page
2. using tabs: Home, Using, Downloads, Status
3. htmx
2024-07-28 21:31:17 +02:00
d17ad9bc3e Added pprof to convergeserver and optionally to
the agent if PPROF_PORT is set.

Fixed issue with converge server not cleaning up goroutines because of blocking channel. Made sure to create channels with > 1 size everywhere it can be done. The blocking behavior of a default channel size is mostly in the way.

Known issue: Killing the SSH client will lead to the server side process not being terminated and some goroutines still running in the agent. This would require additional investigation to solve. The remote processes are still being cleaned up ok (at least on linux) when the agent exits.

This should not be an issue at all since the agent is a short-lived process and when running in a containerized environment with containers running on demand the cleanup will definitely work.
2024-07-28 11:48:31 +02:00
7a51e3ac45 Unique ids for clients generated by converge server and made available to the ssh session through a net.Conn extension that passes the ID to the SSH session through the LocalAddr(). 2024-07-27 22:37:40 +02:00
5a492f3855 initialization of username, password on client (from server) and initialization of agentinfo on server is now done as soon as the agent registered and not through a side channel.
Making use of some simple utilities for GOB to make it easy to send objects over the line.
2024-07-27 20:46:53 +02:00
621bbd8ca6 GOB channel for easily and asynchronously using GOB on a single network connection, also dealing with timeouts and errors in a good way.
Protocol version is now checked when the agent connects to the converge server.

Next up: sending connection metadata and username password from server to agent and sending environment information back to the server. This means then that the side channel will only be used for expiry time messages and session type with the client id passed in so the converge server can than correlate the results back to the correct channel.
2024-07-27 11:21:35 +02:00
f82601d07c Lots of refactoring.
Now hijacking the ssh connection setup in the listener to exchange some information before passing the connection on to the SSH server.

Next step is to do the full exchange of required information and to make it easy some simple Read and Write methods with timeouts are needed that use gob.
2024-07-26 22:40:56 +02:00
b7f3de88bb Updated deployment with username and password settings.
index.html template now also uses the configured password.
2024-07-26 21:11:40 +02:00
37bef8814c user security best practice of having no default passwords. 2024-07-26 20:57:04 +02:00
d02b7eade3 password of converge now configurable through
CONVERGE_USERNAME and CONVERGE_PASSWORD environment
variables.
2024-07-26 20:51:05 +02:00
514e57768f good url validation. 2024-07-26 20:40:01 +02:00
Erik Brakkee
c04ff547ad doc updates. 2024-07-25 21:47:51 +02:00
Erik Brakkee
4804bf4cd1 doc updates. 2024-07-25 21:46:52 +02:00
Erik Brakkee
a59011b00c Some cleanup in the agent code.
Now supporting authorized SSH keys in the
.authorized_keys file.
2024-07-25 21:40:51 +02:00
Erik Brakkee
2ed81c3174 communication between agent and server. Removed the flags libray for command-line parsing.
Heartbeat mechanism from client to server over the custom connection for sending events to guarantee that the connectoin stays up.
2024-07-25 19:51:11 +02:00
47754990a5 documentation updates. 2024-07-24 22:29:23 +02:00
d9f490a2b6 removed read and write dead lines. Appears to be still working. 2024-07-24 22:26:15 +02:00
78819f1ebe status update now reported to the server. More robustness needed. 2024-07-24 22:03:12 +02:00
459300b0d3 First version with basic communication from agent to server working. 2024-07-24 21:39:14 +02:00
5bd3795534 direct communication channel now setup between agent and converge server 2024-07-24 20:23:33 +02:00
20ce37a1cb Extraction of communication setup in separate entity with client and related server code close together to make the setup easier to understand. 2024-07-24 20:04:35 +02:00
3cd12f68f4 every user login resets agent expiry now. 2024-07-24 19:38:22 +02:00
689c8e63b4 clean solution for concurrence in session.go by serializing all external calls (apart from initialization) through a channel. 2024-07-24 19:23:51 +02:00