Embedding in an Iframe

Kasm Workspaces can be embedded in an iframe. This guide will walk through setting up a single server Kasm instance embedded in a simple iframe. We’ll assume a Kasm instance at 10.10.0.10 with the hostname kasm.example.com and a Nginx server hosting the iframe webpage located at 10.10.0.11 with hostname app.example.com.

Cookies

There are two cookies that have to be set during the Kasm authentication request, the username cookie and token cookie when connecting to a running Kasm session. When that session is running inside an iframe those cookies will be blocked by default.

Using Sibling Domains

The best way to handle cookie management between Kasm in the iframe and the parent page is to have the parent page and Kasm be sibling domains (domains that are at the same level with respect to the parent domain) such as:

  • app.example.com (For the application that will have the iframe containing kasm)

  • kasm.example.com (For Kasm itself)

Configure your webserver (in this example Nginx) to host your website on the new domain name for example app.example.com.

Use the hostname for your Kasm instance for this guide, we will use kasm.example.com for this guide.

Using Sub-Domains

You can also use subdomains for cookie management. Such as:

  • app.example.com (For the application that will have the iframe containing kasm)

  • kasm.app.example.com (For Kasm itself)

This should work for all browsers.

However, if there is more than one level separating the two domains, some browsers most notably Safari will not work, for instance:

  • example.com (For the application that will have the iframe containing kasm)

  • kasm.app.example.com (For Kasm itself) This is likely to break since Kasm is two levels down from the domain hosting the iframe.

Example Webpage With Kasm in Iframe

Let’s start with a simple HTML page that hosts an iframe pointing to Kasm.

<!DOCTYPE html>
<html>
<head>
</head>
<body>
<h1>Embedded Kasm</h1>
<iframe src="https://kasm.example.com" height= "1000" width= "1500"></iframe>
</body>
</html>

After saving this HTML file into the root of the webserver (Nginx) and browsing to it, you should see the login page to the Kasm instance. You can log in and browse the instance, but if you try to launch a Workspaces image the connection to the session will fail, and you will be returned to the Workspaces dashboard. This is because Kasm is unable to set the username and token cookies after authentication. We will solve this issue in the next step.

Note

If you don’t see the Kasm login screen it could be because you are using self-signed certs for your Kasm instance and will need to accept the cert in your browser by browsing directly to the instance and accepting the certificates before using the iframe.

We strongly recommend using valid trusted certificates for all Kasm deployments

Now if you browse to the test page you will see the Kasm instance rendered in the iframe, be able to log in, and launch a Kasm session.

Iframe Permissions

Now that the connection goes through when launching a Kasm session you will notice that several things are not working as expected. For instance the microphone may be inaccessible, and Kasm’s seamless clipboard experience may not function as expected. This is because the iframe must explicitly be granted the permissions needed for this functionality.

Several things must be added to the allow attribute for the iframe:

  • autoplay

    • This allows the audio from a Kasm session to start playing without any interaction from the user. Without this permission the user must interact with the iframe before audio will play.

  • microphone

    • Without this the browser will not allow Kasm within the iframe to request the microphone permission so microphone capability will be unusable.

  • clipboard-read

    • Allows Kasm to read text from the client clipboard.

  • clipboard-write

    • Allows Kasm to write text to the client clipboard.

  • self

    • Allows the previous permissions to be passed to iframes within the iframe its set on. This matters because the Kasm session connection is an iframe within the Kasm Web App.

  • https://kasm.example.com

<!DOCTYPE html>
<html>
<head>
</head>
<body>
<h1>Embedded Kasm</h1>
<iframe src="https://kasm.example.com" height= "1000" width= "1500" allow="autoplay; microphone; clipboard-read; clipboard-write; self; https://kasm.example.com"></iframe>
</body>
</html>

Now when browsing to the site and using Kasm in an iframe you will have the full set of capabilities for your Kasm session.