Skip to content

subtata-emfluence/myrtille

 
 

Repository files navigation

Myrtille

Myrtille provides a simple and fast access to remote desktops and applications through a web browser, without any plugin, extension or configuration.

Technically, Myrtille is an HTTP(S) to RDP gateway.

How does it works?

It works by forwarding the user inputs (keyboard, mouse, touchscreen) from a web browser to an HTTP(S) gateway, then up to an RDP client which maintain a session with an RDP server.

The display resulting, or not, of such actions is streamed back to the browser, from the rdp client and through the gateway.

The implementation is quite straightforward in order to maintain the best speed and stability as possible. Some optimizations, such as inputs buffering and display quality tweaking, help to mitigate with latency and bandwidth issues.

More information into the DOCUMENTATION.md file.

Features

  • HTTP(S) to RDP gateway
  • File transfer (local and roaming accounts)
  • Remote clipboard support
  • WebP compression

Requirements

  • Browser: any HTML4 or HTML5 browser (starting from IE6!)
  • Gateway: IIS 7.0+, .NET 4.0+ and Microsoft Visual C++ 2015 redistributables (x86)
  • RDP server: any RDP enabled computer (preferably Windows Server but can also be Windows XP, 7, 8, 10)

Build

Microsoft Visual Studio 2015. See DOCUMENTATION.md.

Installation

All releases here: https://github.com/cedrozor/myrtille/releases

See DOCUMENTATION.md for more details.

Usage

Once Myrtille is installed on your server, you can use it at http://yourserver/myrtille. Set the rdp server address, user domain (if defined), name and password then click "Connect!" to log in. "Disconnect" to log out.

The installer creates a self-signed certificate for https://yourserver/myrtille. Like for all self-signed certificates, you will have to add a security exception into your browser (just ignore the warning message and proceed to the website). Of course, you can avoid that by installing a certificate provided by a trusted Certification Authority (see DOCUMENTATION.md).

If you want connection information, you can enable stat (displayed on screen or browser console). If you want debug information, you can enable debug (logs are saved under the Myrtille "log" folder).

You can also choose the rendering mode, HTML4 or HTML5 (HTML4 may be useful, for example, if websockets are blocked by a proxy or firewall).

On touchscreen devices, you can pop the device keyboard with the "Keyboard" button. Then enter some text and click "Send". This can be used, for example, to paste the local clipboard content and send it to the server (then it be copied from there, within the rdp session).

The remote clipboard content can also be retrieved locally with the "Clipboard" button (text format only).

You can upload/download file(s) to/from the user documents folder with the "My documents" button. Note that it requires the rdp server to be localhost (same machine as the http server) or a domain to be specified.

Third-party

Myrtille uses the following licensed software:

See DISCLAIMERS.md file.

The Myrtille code in FreeRDP is surrounded by region tags "#pragma region Myrtille" and "#pragma endregion".

libWebP are official Google's WebP precompiled binaries, and are left unmodified. Same for Fleck websockets.

License

Myrtille is licensed under Apache 2.0 license. See LICENSE file.

Author

Cedric Coste ([email protected]).

Contributors

  • Catalin Trifanescu (AppliKr developer: application server. Steemind cofounder)
  • Fabien Janvier (AppliKr developer: website css, clipping algorithm, websocket server)
  • UltraSam (AppliKr developer: rdp client, http gateway)

Resources

About

A native HTML4 / HTML5 Remote Desktop Protocol client

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C# 62.7%
  • JavaScript 31.9%
  • Classic ASP 4.6%
  • CSS 0.8%