Github: readonly access to a private repo

GitGithubCollaborationReadonlyPublic Key

Git Problem Overview


I am developing some private projects on Github, and I would like to add nightly cronjobs to my deployments servers to pull the latest version from github. I am currently doing this by generating keypairs on every deployment server and adding the public key to the github project as 'Deployment key'.

However, I recently found out that these deployment keys actually do have write access to the project. Hence, every of the server administrators could potentially start editing. Furthermore I can add every deployment key to only one repository, whereas I would like to be able to deploy multiple repositories on one and the same deployment server.

Is there a way to provide read-only access for private repositories to selected users on Github?

Git Solutions


Solution 1 - Git

I have it on good authority that the (relatively new) "Organizations" feature allows you to add people with read-only access to a private repository.

Solution 2 - Git

For anyone else finding this question, know that nowadays you can in fact create read-only deploy keys:

https://github.com/blog/2024-read-only-deploy-keys

You can still create deploy keys with write access, but have to explicitly grant that permission when adding the key.

Solution 3 - Git

I know that the questions is about github but maybe for some readers it would be nice to know that this is possible in gitlab and for free. Check https://gitlab.com/help/user/permissions. I spend some time using github without fully serving my purposes. If I knew then I would have started this particular project with gitlab.

Solution 4 - Git

For Organizations: I suggest creating a new team specifically for the user. This team can then grant read-only access to the repositories you specify. I hope this helps!

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionJeroen OomsView Question on Stackoverflow
Solution 1 - GitpmdjView Answer on Stackoverflow
Solution 2 - GitAdam ReisView Answer on Stackoverflow
Solution 3 - GitguizoView Answer on Stackoverflow
Solution 4 - GitchainworkView Answer on Stackoverflow