This guide explains how to install a Discourse theme or theme component from a private GitHub repository.
Required user level: Administrator
Summary
This documentation covers the process of installing a Discourse theme or theme component from a private GitHub repository. It includes steps for generating and using SSH keys for secure access. You will need to have administrator access to both your Discourse instance and the GitHub repository you are installing. This is how you can use your own private themes and theme components on your forum.
Prerequisites
Before you begin, ensure you have:
- Administrator access to your Discourse instance
- A private Git repository containing your theme or component
- Access to add deploy keys to your Git repository (admin/owner level)
Step-by-step guide
- Go to your private GitHub repository and copy the SSH address from the Clone SSH tab.
2. Navigate to your Discourse admin panel.
3. In the admin sidebar, go to
Appearance - Themes or Component, (depending on which you are installing). If you are using the older style admin navigation bar - go to Customize - Themes or Components.4. Click on
Install and then select From a git repository.  5. Paste the SSH address you copied from the private repository in step 1. It should be in the format:
git@github.com:USERNAME/REPO-NAME.git. 
Make sure to use the clone with SSH link, not the one that starts with
https
6. An SSH key is automatically generated and displayed in a new text box.
7. Click the copy icon in the top right corner of that box to copy the new SSH key. Do not click install or close this modal yet.
8. Now go to your private GitHub repository settings (e.g., on GitHub, go to
Settings > Deploy keys)  9. Add a new deploy key. You will have to give it an appropriate title. Paste the SSH key you copied from Discourse into the deploy key field.
10. Click
Add key to save the deploy key in your Git repository settings.  11. Return to the Discourse theme installation modal and click the
Install button. You should now see your new theme or component settings page.  Best practices
- Always use the SSH URL for your repository, not the HTTPS URL.
- Keep your deploy keys secure and don’t share them publicly. If possible, store them in a password vault application.
- Regularly update your theme or components to ensure you have the latest features and security updates.
FAQs
Q: Can I use this method with Git providers other than GitHub?
 A: Yes, this method should work with any Git provider that supports deploy keys or SSH authentication.
Q: Will Discourse remember the SSH key for future updates?
 A: Yes, Discourse will store the generated private key and use it for future access to the Git repository.
Q: Can I change the private repository later?
 A: Yes, you can update the repository URL in the theme settings if needed.
Additional resources
*SSH keys used in this topic were only generated for this documentation
Last edited by @Lilly 2025-01-30T20:00:09Z
Last checked by @Lilly 2025-02-26T15:02:26Z
Check document
Perform check on document:






