Template registry for creating third party workspace repositories
Go to file
2023-01-11 14:19:26 +00:00
.github/workflows Update build logic to dynamically set ref 2023-01-11 14:19:26 +00:00
apps Initial commit 2022-12-14 15:03:50 +00:00
processing Dynamic schema version 2023-01-11 08:40:42 +00:00
site Update correct repository 2023-01-10 18:40:10 +00:00
.gitignore Change output directory 2023-01-10 13:40:27 +00:00
README.md Update readme 2023-01-11 12:23:30 +00:00

THIS IS CURRENTLY IN DEVELOPMENT AND NOT READY FOR PRIME TIME YET, WE'LL ANNOUNCE WHEN IT'S INCLUDED IN BUILDS. FEEL FREE TO PLAY WITH IT THOUGH AND GIVE FEEDBACK.

Kasm Apps

This is a repository of the apps supported by Kasm. The apps list is automatically generated and can be used when creating new workspaces or using the 1 click installer

Create your own app store

We have tried to make it as simple as possible for people to create their own app stores that work with Kasm, the easiest way to do that is to follow these steps:

  1. Click on "Use this template", select Create a new repository
  2. Select a Repository name, you will need to use this name later in the process as well, tick the "Include all branches" checkbox, then click on the "Create repository from template" button
  3. Click on the actions tab and check whether workflows need enabling, if they do, enable them, otherwise you should be good to go.
  4. Go to /site/next.config.js and edit the env section with the relevant details.
    • name - The name you want to display
    • description - A short description to display when a store's information button is pressed.
    • icon - The image to display for your registry. You can upload an image to /site/public/ and reference that by https://domain.com/image.png or if you aren't using a {sub}domain by referencing it from https://username.github.io/repositoryname/image.png where image.png is the name of the image you uploaded.
    • listUrl - The link to the JSON. This will follow the same format as the icon above but ends in list.json, for example https://username.github.io/repositoryname/list.json
    • contactUrl - A link users can use to contact you on. If you are using a domain or a subdomain, you need to completely remove the basePath: 'kasm-app', line, otherwise change the value to match what you chose for the repository name in step 2.
  5. Upload your apps to the /apps folder
  6. Go to Settings then Pages and select Branch - gh-pages and click Save
  7. Check progress in Actions
  8. Once complete go back to Settings / Pages and you should have a live site. Click on the Visit Site button.
  9. You should now have a working site which includes any apps you added

New schema version

If a new schema version comes out, this is what you will need to do.

  1. Create a new branch with the schema version as the branch name (for example, 1.1)
  2. Open site/package.json and append the version to the output directory "deploy": "next build && next export -o ../public/1.1/ && touch ../public/.nojekyll",. It should NOT be added to the second one (touch ../public/.nojekyll") as the .nojekyll needs to be in the root to work
  3. Open processing/processjson.js and append the version number to the dir variable on line 6 var dir = "./public/1.1";
  4. Open site/next.config.js and change env.schema to match the version number, add the version number to the env.listUrl and append the version number to the basePath as well.

Discovery

The tag below will hopefully make it easier for people to find your App Registry by clicking on this github search link. If you want to make it harder to find your repository for some reason, just remove this section.

KASM-REGISTRY-DISCOVERY-IDENTIFIER