Skip to content

Latest commit

 

History

History
83 lines (59 loc) · 7.79 KB

setting-up-a-template-repository-for-github-codespaces.md

File metadata and controls

83 lines (59 loc) · 7.79 KB
title shortTitle intro versions type topics redirect_from
Setting up a template repository for GitHub Codespaces
Set up a template repo
You can help people get started with a project by setting up a template repository for use with {% data variables.product.prodname_github_codespaces %}.
fpt ghec
*
*
how_to
Codespaces
Set up
/codespaces/setting-up-your-project-for-codespaces/setting-up-a-template-repository-for-github-codespaces

Introduction

By setting up a template repository, you can help people get started with your framework, library, or other project in {% data variables.product.prodname_github_codespaces %}. Users will be able to start working with your template files immediately in a cloud-based development environment, without having to worry about cloning your repository or installing tools or other dependencies. With some configuration, you will be able to set users up in a codespace with important files already open for editing, and with an application already running in a preview browser tab within the {% data variables.product.prodname_vscode_shortname %} web editor.

Anyone with read access to your template repository can create a codespace from the repository's page on {% data variables.product.product_name %}. You can turn any existing repository into a template, and you do not have to change any settings to allow users to create a codespace from your template repository. For more information on turning a repository into a template, see "AUTOTITLE."

To help users find your template and get started quickly, you can share a link to the codespace creation page for the template. For example, you could provide this link in a tutorial for getting started with your framework. You can use the "share a deep link" option and select Quick start to build a link that takes users to a page where they can quickly create a new codespace or resume a recent one. For more information, see "AUTOTITLE."

When someone creates a codespace from your template, the contents of your template repository will be cloned into their codespace. When the user is ready, they will be able to publish their work to a new repository on {% data variables.product.product_name %} belonging to their personal account. For more information, see "AUTOTITLE."

Organizations can pay for members of the organization and outside collaborators to use {% data variables.product.prodname_github_codespaces %} at the organization's expense. This includes codespaces created from template repositories owned by the organization. However, if a user publishes a codespace created from a template to their personal account, ownership and billing of the codespace transfers to the user who created the codespace. For more information, see "AUTOTITLE."

Describe your template

If you don't have one, create a README for your template repository to describe the purpose of your template and how to get started with it. For more information, see "AUTOTITLE."

You can also provide a short description of your project by navigating to the repository's page and clicking {% octicon "gear" aria-label="Edit repository metadata" %} next to the About section on the right of the page.

Screenshot of the "About" section on a repository page. The settings button (a gear symbol) is highlighted with a dark orange outline.

Add starter files

Template repositories typically contain starter files with boilerplate code so users can quickly get started with a library, framework, or other technology.

For guidance on the kinds of files to include, you can look at the starter files included in the official {% data variables.product.company_short %} templates for {% data variables.product.prodname_github_codespaces %}, as follows.

{% data reusables.codespaces.your-codespaces-procedure-step %} {% data reusables.codespaces.view-all-templates-step %}

  1. To view the template repository that contains the files for the template, click the name of the template.

    Screenshot of the "Explore quick start templates" section of the codespaces page. The names of the templates are highlighted with orange outlines.

Configure the dev container

You can add dev container configuration files to your template repository to customize the development environment for people using your template with {% data variables.product.prodname_github_codespaces %}. You can choose from a list of predefined configuration settings in {% data variables.product.prodname_vscode %}, or you can create a custom configuration by writing your own devcontainer.json file. If you don't add configuration files, the default container image will be used. For more information, see "AUTOTITLE" and "AUTOTITLE."

Note

{% data reusables.codespaces.configuration-choice-templates %}

You should configure your dev container with the tools and customization to give users the best experience with your template. For example, in your devcontainer.json file:

  • You can use the openFiles property to define a list of files to be opened automatically in the {% data variables.product.prodname_vscode_shortname %} web client when a codespace is created from your template.
  • If users need to provide personal secrets such as API keys to run the application in your template, you can prompt them to provide these secrets. For more information, see "AUTOTITLE."
  • If your template contains files for a web application, you can make the application run automatically in the user's codespace. You can do this by using the postAttachCommand property to run a script that starts the application on a local server as soon as the {% data variables.product.prodname_vscode_shortname %} web client connects to the codespace, and by setting the onAutoForward property of a port to openPreview to display the application running on that port in a simple browser embedded in the {% data variables.product.prodname_vscode_shortname %} web client.

The following configuration settings for a React template will open the app.js file in the user's editor, run npm start (defined in a package.json file) to start a local server, and forward port 3000 to a preview browser tab in the codespace.

{
    "postAttachCommand": {
      "server": "npm start"
    },

    "portsAttributes": {
      "3000": {
        "label": "Application",
        "onAutoForward": "openPreview"
      }
    },

    "customizations": {
      "codespaces": {
        "openFiles": ["src/App.js"]
      }
    }
}

For more information, see "AUTOTITLE" and the dev containers specification on the Development Containers website.