mirror of
https://codeberg.org/Codeberg/Documentation.git
synced 2026-06-16 05:13:54 -07:00
closes #238 Co-authored-by: pat-s <patrick.schratz@gmail.com> Co-authored-by: Patrick Schratz <pat-s@noreply.codeberg.org> Reviewed-on: https://codeberg.org/Codeberg/Documentation/pulls/377 Co-authored-by: crapStone <crapstone01@gmail.com> Co-committed-by: crapStone <crapstone01@gmail.com>
152 lines
7.9 KiB
Markdown
152 lines
7.9 KiB
Markdown
---
|
|
eleventyNavigation:
|
|
key: RepositoryPermissions
|
|
title: Repository Permissions
|
|
parent: Collaborating
|
|
order: 50
|
|
---
|
|
|
|
When you invite collaborators to join your repository (see [Invite Collaborators](/collaborating/invite-collaborators)) or when you create teams for your organization (see [Create and Manage an Organization](/collaborating/create-organization)), you have to decide what each collaborator/team is allowed to do.
|
|
|
|
You can assign teams different levels of permission for each unit (e.g. issues, PRs, wiki).
|
|
|
|
## Profile and Visibility
|
|
|
|
The visibility of your repositories will depend on the visibility of your profile, as well as whether you have marked a repository as private. Let's break down what this means:
|
|
|
|
- If your profile's visibility is set to "Limited", _all_ of your non-private repositories will only be visible to logged in users.
|
|
- If your profile's visibility is set to "Public", _all_ of your non-private repositories will be shown to everyone.
|
|
- If you do not want anyone (apart from [your fellow collaborators](https://docs.codeberg.org/collaborating/invite-collaborators/)) to see your repositories, mark your repository as "Private".
|
|
|
|
The visibility of your profile can be changed in the [Privacy settings](https://codeberg.org/user/settings). Be careful when you set your profile's visibility to "Limited"; Even if a repository is public, users that are _not logged in_ will get a [404 error](https://en.wikipedia.org/wiki/HTTP_404) if they try to access your repository — it will seem as if it does not exist at all!
|
|
|
|
<picture>
|
|
<source srcset="/assets/images/collaborating/repo-permissions/user-settings-privacy-limited.webp" type="image/webp">
|
|
<img src="/assets/images/collaborating/repo-permissions/user-settings-privacy-limited.jpg" alt="Privacy Settings in Codeberg's User Settings" width="50%">
|
|
</picture>
|
|
|
|
## Collaborators
|
|
|
|
There are four permission levels: **Read**, **Write**, **Administrator** and **Owner**.
|
|
|
|
By default, the person who creates a repository is an **_Owner_**.
|
|
|
|
The table below gives an overview of what collaborators are allowed to do when granted each of these permission levels:
|
|
|
|
<table class="table">
|
|
<thead>
|
|
<tr>
|
|
<th> Task </th>
|
|
<th> Read </th>
|
|
<th> Write</th>
|
|
<th> Admin </th>
|
|
<th> Owner </th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<tr>
|
|
<td> View, clone and pull repository </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
</tr>
|
|
<tr>
|
|
<td> Contribute pull requests </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
</tr>
|
|
<tr>
|
|
<td> Push to/update contributed pull requests </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
</tr>
|
|
<tr>
|
|
<td> Push directly to repository </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
</tr>
|
|
<tr>
|
|
<td> Merge pull requests </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
</tr>
|
|
<tr>
|
|
<td> Moderate/delete issues and comments </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
</tr>
|
|
<tr>
|
|
<td> Force-push/rewrite history (if enabled) </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
</tr>
|
|
<tr>
|
|
<td> Add/remove collaborators to repository </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
</tr>
|
|
<tr>
|
|
<td> Configure branch settings (protect/unprotect, enable force-push) </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<tr>
|
|
<td> Configure repository settings (enable wiki, issues, PRs, update profile) </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
</tr>
|
|
<tr>
|
|
<td> Configure repository settings in the danger zone (transfer ownership, delete wiki data / repository, archive repository) </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: red">{% fas_icon "times" %}</span> </td>
|
|
<td> <span style="color: green">{% fas_icon "check" %}</span> </td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
|
|
## Teams
|
|
|
|
The permissions for teams are quite configurable. You can specify which repositories a team has access to; therefore, you can specify for each unit (Code Access, Issues, Releases) a different permission level.
|
|
|
|
Each unit is configured to have one of these 3 permission levels:
|
|
|
|
- No Access: Members cannot view or take any other action on this unit.
|
|
- Read: Members can view the unit, and do standard actions for that unit (See the Read column under [Collaborators](#collaborators)).
|
|
- Write: Members can view the unit, and execute write actions that unit (See the Write column under [Collaborators](#collaborators)).
|
|
|
|
When a team is configured to have administrator access, when this is specified, you cannot change units. The team will have admin permissions (See the Admin column under [Collaborators](#collaborators)).
|
|
|
|
Currently, there are six units that can be configured:
|
|
|
|
- Code: access source code, files, commits, and branches.
|
|
- Issues: organize bug reports, tasks, and milestones.
|
|
- Pull Requests: access pull requests, and code reviews.
|
|
- Releases: track the project versions and downloads.
|
|
- Wiki: access and write documentation.
|
|
- Projects: access and manage issues and pull requests in project boards.
|
|
|
|
There are also two units which can be toggled:
|
|
|
|
- External Wiki: access to external wiki.
|
|
- External Issues: access to the external issue tracker.
|
|
|
|
A team can be given the permission to create new repositories. When a member of such team creates a new repository, they will get administrator access to the repository.
|