The following instructions can be used to provide write access to a shared repo. These instructions are written using a private repo as an example, but they work equally well on public repos.

Here’s how, described as both a list of steps, and a list of images. In this example:

These are the steps Alex should take to invite Chris as a collaborator:

  1. Navigate to the repo page, and click on Settings for the repo

    spis16-lab02-Alex-Chris-repo-page-50.png

  2. Select Collaborators & Teams from the menu at the left side of the page.

    spis16-lab02-Alex-Chris-repo-settings-50.png

  3. On the lower half of the page, in the “Add Collaborator” section, start typing in the github id of the pair partner that you want to add as a collaborator.

    Click the github id when it appears. BE SURE IT IS ACCURATE. Otherwise, you’ll be sharing your repo with some perfect stranger. That would be very bad. So don’t do that please.

    Note: in some browsers, you have to actually click on the name that pops up—it is not sufficient to simply type in the full name. Your experience may vary.

    start-typing-chrislajol-then-name-will-pop-up-click-on-it-50.png

  4. When inviting a user to be a collaborator, the default permission level is Write. If you are working with a pair partner, you should probably change that to Admin.

    The following image indicates how to do that. If you accidentally omit this step, then the user you are inviting will not have access to the Settings menu for the repo. (If that happens, there is information later on this page about how to fix that.)

    change-permission-level-to-admin-50.png

Accepting the invitation to Collaborate

Suppose Alex has created the repo using the atriton account, and has invited chrislajolla as a collaborator.

This is not sufficient for Chris to immediately have access. Chris must first accept the invitation.

Since the repo in question is a private repo, it will not automatically appear as a repo that Chris has access to under Chris’ github account.

Instead, when Alex invited Chris as a collaborator, an email similar to the following was generated and send to whatever email Chris verified for Chris’ github account. The email contains a link that Chris can click to review the invitation.

atriton-invites-chrislajolla-to-lab02-repo-50.png

At that URL, Chris should see something like this, where Chris can click to accept the invitation.

atriton-invited-you-to-collaborate-30.png

Chris should be redirected to the repo page, with the level of access to the repo authorized by Alex as shown in the image below.

Note that if Alex provided Admin access, Chris will have full privileges over the repo. If Alex only provided Write access (as in the example shown below), Chris’s repo page will not have the Setting page. To fix that, see the section “Changing access levels for collaborators”, later on this page.

you-now-have-access-to-the-spis16-lab02-Alex-Chris-repo-50.png

What if Chris doesn’t get an invitation email?

It isn’t strictly necessary for Chris to find the invitation email. Instead, Alex can simply provide Chris with invitation url.

There is a place to copy the invitation url on the repo’s settings page, under Collaborators and Teams, as shown here:

copy-invite-link-30.png

Changing Access Levels for Collaborators

Invitations can be issued for different levels of access.

If you’ve been invited to a repo, you can check your level of access:

Here are some examples of what it looks like to invite a user with various kinds of access. These examples are found on the repository settings page under Collaborators & teams.

Here, atriton has invited chrislajolla with admin access:

atriton-has-invited-chrislajolla-with-admin-40.png

By contrast, here, atriton has invited chrislajolla with write access:

atriton-has-invited-chrislajolla-with-write-access-40.png

Here, atriton has a settings menu, indicating that atriton has admin access.

atriton-has-settings-menu-40.png

If chrislajolla has already accepted an invitation from atriton and has only Write access, atriton can change that by simply selecting a different level of access on the Collaborators & teams tab on the repo settings page as shown below:

change-chrislajolla-to-have-admin-access-40.png