Commit 8fb8052b authored by Marcia Ramos's avatar Marcia Ramos

Merge branch 'docs/instance-template-refactor' into 'master'

Refactor the instance-wide custom templates docs

See merge request gitlab-org/gitlab-ee!7459
parents e7e8d6d8 5e7abc46
...@@ -13,6 +13,7 @@ include: ...@@ -13,6 +13,7 @@ include:
- [Third party offers](third_party_offers.md) - [Third party offers](third_party_offers.md)
- [Usage statistics](usage_statistics.md) - [Usage statistics](usage_statistics.md)
- [Visibility and access controls](visibility_and_access_controls.md) - [Visibility and access controls](visibility_and_access_controls.md)
- [Custom templates repository](instance_template_repository.md)
## GitLab.com admin area settings ## GitLab.com admin area settings
......
# Instance-level Template Repository # Instance-level template repository **[PREMIUM ONLY]**
> [Introduced](https://gitlab.com/gitlab-org/gitlab-ee/issues/5986) in > [Introduced](https://gitlab.com/gitlab-org/gitlab-ee/issues/5986) in
> [GitLab Premium](https://about.gitlab.com/pricing) 11.3. > [GitLab Premium](https://about.gitlab.com/pricing) 11.3.
...@@ -7,35 +7,35 @@ ...@@ -7,35 +7,35 @@
In hosted systems, enterprises often have a need to share their own templates In hosted systems, enterprises often have a need to share their own templates
across teams. This feature allows an administrator to pick a project to be the across teams. This feature allows an administrator to pick a project to be the
instance-wide collection of templates. These templates are then exposed to all instance-wide collection of file templates. These templates are then exposed to
users while the project remains secure. Currently supported templates: Licenses. all users [via the web editor](../../project/repository/web_editor.md#template-dropdowns)
while the project remains secure.
## Configuration ## Configuration
An administrator can choose any project to be the template repository. This is As an administrator, navigate to **Admin area > Settings > Templates** and
done through the `Settings` page in the `Admin Area` or through the API. On the select the project to serve as the custom template repository.
`Settings` page, there is a `Templates` section with a selection box for
choosing a project:
![](img/file_template_admin_area.png) ![File templates in the admin area](img/file_template_admin_area.png)
Once a project has been selected, you can add custom templates to the repository,
and they will appear in the appropriate places in the
[frontend](../../project/repository/web_editor.md#template-dropdowns) and
[API](../../../api/settings.md).
Once a project has been selected you can add custom templates to the repository,
and they will appear in the appropriate places in the frontend and API.
Templates must be added to a specific subdirectory in the repository, Templates must be added to a specific subdirectory in the repository,
corresponding to the kind of template. They must also have the correct extension corresponding to the kind of template. The following types of custom templates
for the template type. are supported:
Currently, the following types of custom template are supported: | Type | Directory | Extension |
| :---------------: | :-----------: | :-----------: |
| `Dockerfile` | `Dockerfile` | `.dockerfile` |
| `.gitignore` | `gitignore` | `.gitignore` |
| `.gitlab-ci.yml` | `gitlab-ci` | `.yml` |
| `LICENSE` | `LICENSE` | `.txt` |
* `Dockerfile`: `Dockerfile` directory, `.dockerfile` extension Each template must go in its respective subdirectory, have the correct
* `.gitignore`: `gitignore` directory, `.gitignore` extension extension and not be empty. So, the hierarchy should look like this:
* `.gitlab-ci.yml`: `gitlab-ci` directory, `.yml` extension
* `LICENSE`: `LICENSE` directory, `.txt` extension
Each template must go in its respective subdirectory and have the correct
extension. So, the hierarchy
should look like this:
```text ```text
|-- README.md |-- README.md
...@@ -53,11 +53,11 @@ should look like this: ...@@ -53,11 +53,11 @@ should look like this:
|-- another_license.txt |-- another_license.txt
``` ```
Once this is established, the list of `Custom` licenses will be included when Once this is established, the list of custom templates will be included when
creating a new file and the file type is `License`. These will appear at the creating a new file and the template type is selected. These will appear at the
bottom of the list: top of the list.
![](img/file_template_user_dropdown.png) ![Custom template dropdown menu](img/file_template_user_dropdown.png)
If this feature has been disabled or no licenses are present, then there will be If this feature is disabled or no templates are present, there will be
no `Custom` section in the selection dropdown. no "Custom" section in the selection dropdown.
...@@ -33,13 +33,13 @@ easy for you. ...@@ -33,13 +33,13 @@ easy for you.
![First file for your project](img/web_editor_template_dropdown_first_file.png) ![First file for your project](img/web_editor_template_dropdown_first_file.png)
When clicking on either `LICENSE` or `.gitignore`, a dropdown will be displayed When clicking on either `LICENSE` or `.gitignore`, etc., a dropdown will be displayed
to provide you with a template which might be suitable for your project. to provide you with a template which might be suitable for your project.
![MIT license selected](img/web_editor_template_dropdown_mit_license.png) ![MIT license selected](img/web_editor_template_dropdown_mit_license.png)
The license, changelog, contribution guide, or `.gitlab-ci.yml` file could also The license, changelog, contribution guide, or `.gitlab-ci.yml` file could also
be added through a button on the project page. In the example below the license be added through a button on the project page. In the example below, the license
has already been created, which creates a link to the license itself. has already been created, which creates a link to the license itself.
![New file button](img/web_editor_template_dropdown_buttons.png) ![New file button](img/web_editor_template_dropdown_buttons.png)
......
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
= f.label :file_template_project_id, class: 'label-light' do = f.label :file_template_project_id, class: 'label-light' do
.form-text.text-muted .form-text.text-muted
Select a Select a
= link_to 'template repository', help_page_path("user/admin_area/settings/instance_template_repository", anchor: "version-check") = link_to 'template repository', help_page_path("user/admin_area/settings/instance_template_repository")
= project_select_tag('application_setting[file_template_project_id]', class: 'project-item-select hidden-filter-value', toggle_class: 'js-project-search js-project-filter js-filter-submit', dropdown_class: 'dropdown-menu-selectable dropdown-menu-project js-filter-submit', = project_select_tag('application_setting[file_template_project_id]', class: 'project-item-select hidden-filter-value', toggle_class: 'js-project-search js-project-filter js-filter-submit', dropdown_class: 'dropdown-menu-selectable dropdown-menu-project js-filter-submit',
placeholder: admin_project_dropdown_label('Search projects'), idAttribute: 'id', data: { order_by: 'last_activity_at', idattribute: 'id', all_projects: 'true', simple_filter: true, allow_clear: true}, value: @application_setting.file_template_project_id) placeholder: admin_project_dropdown_label('Search projects'), idAttribute: 'id', data: { order_by: 'last_activity_at', idattribute: 'id', all_projects: 'true', simple_filter: true, allow_clear: true}, value: @application_setting.file_template_project_id)
= f.submit 'Save changes', class: "btn btn-success" = f.submit 'Save changes', class: "btn btn-success"
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment