Public GitLab is a fork of the official GitLab software. This fork allows you to host public repositories as long as official software does NOT support it (e.g. for Open Source projects). With this fork, I'm trying to reproduce Github behaviour.
So by public I mean:
- Allow anonymous users to browse your public repositories.
- Allow anonymous users to download your code (not only by
git clone
). - Allow anonymous users to register and report issues on public projects.
With these features, GitLab can be a self-hosted Github competitor.
You can browse a live example at http://git.hoa.ro (you won't be able to create projects).
Disclaimer: I do not provide any support on GitLab itself. I only contribute to the public part. Please refer to the official documentation for any help on GitLab itself.
You should also be aware that Public GitLab only applies to the latest stable release branch of GitLab. So, use the *-stable branches! The master
branch on this repo has a high chance to be broken.
- [2013-10-05] : Public GitLab supports GitLab 6.1 (stable) - Upgrade 6.0 to 6.1
- [2013-08-25] : Public GitLab supports GitLab 6.0 (stable) - Upgrade 5.4 to 6.0
Note: Follow @PGitLab to get news on the project (or RSS feed here).
- [2013-07-29] : Fixes 2 issues (more at #22)
- [2013-07-24] : Public GitLab supports GitLab 5.4 (stable) - Upgrade 5.3 to 5.4
- [2013-07-06] : New feature ! Added a different projects number limit per user for private and public projects. Thanks to Mike for the idea.
Please update your DB model to use it (
bundle exec rake db:migrate RAILS_ENV=production
). Warning: New option inconfig/gitlab.yml.example
(default_projects_limit_private
).
- [2013-06-30] : Public GitLab supports GitLab 5.3 (stable) - Upgrade 5.2 to 5.3
- [2013-05-29] : Public GitLab supports GitLab 5.2 (stable) - Upgrade 5.1 to 5.2
- [2013-05-03] : Bugfix (you need to update your DB triggers)
- [2013-04-25] : Public GitLab supports GitLab 5.1 (stable) - Upgrade 5.0 to 5.1
Warning: GitLab 5.1 does not work properly with old version of Git (ok on 1.7.10+). More here.
- [2013-04-11] : MySQL support
- [2013-04-01] : First commit for Public GitLab (only PostgreSQL)
During the official installation workflow, Public GitLab override part "6. GitLab - Clone the Source".
Warning: Remember that you need to use the latest stable branch, even if you want to download it from zip file.
Note: You can also use my GitLab install scripts for CentOS.
# Clone GitLab repository
sudo -u git -H git clone https://github.com/ArthurHoaro/Public-GitLab.git gitlab
# Go to gitlab dir
cd /home/git/gitlab
# Checkout to stable release
sudo -u git -H git checkout 6-1-stable
At this point, all of the GitLab components are installed. You still can't access GitLab though.
The SQL script below creates a default guest
user for anonymous access. It also creates a default team (pgl_reporters
), giving reporter
permission to all future users for all public projects.
Note that your DB user needs to have the TRIGGER permission on your database (this is specific to Public GitLab).
You have to patch your GitLab database with 2 SQL scripts:
cd /home/git/gitlab/pgl
psql -h host -U user database < pgl_pgsql_insert.sql
psql -h host -U user database < pgl_pgsql_trigger.sql
You have to patch your GitLab database with 2 SQL scripts:
cd /home/git/gitlab/pgl
mysql -hhost -uuser -p
use database
source pgl_mysql_insert.sql
source pgl_mysql_trigger.sql
In the file ~/gitlab/config/gitlab.yml, uncomment:
signup_enabled: true
Note: Keep in mind that if you do not allow signups, guests won't be able to report issues.
If you do not want guest users to create projects on your GitLab installation, set default_projects_limit: 0
in config/gitlab.yaml
.
Remember to restart GitLab after all these changes :
sudo /etc/init.d/gitlab restart
Then enjoy !
You need to refer to official update guides to upgrade GitLab version.
If the changelog on this README indicates any SQL update, you need to update your database :
PostgreSQL:
cd /home/git/gitlab/pgl
psql -h host -U user database < pgl_pgsql_trigger.sql
MySQL:
cd /home/git/gitlab/pgl
mysql -hhost -uuser -p
use database
source pgl_mysql_trigger.sql
See CONTRIBUTING.
If there is a new stable branch, please do not open an issue to ask for an update. Contact me instead.
The reporters team created by Public GitLab is owned by the root user (Administrator). If you delete this user, it will cause problems in your GitLab installation.
If you really need to remove root
, you need to change the pgl_reporters
team's owner in GitLab administration before deleting it.
If you have already deleted the root user, you have to manually change Public GitLab SQL insert
to :
INSERT INTO user_teams (name, path, owner_id, created_at, updated_at, description)
VALUES ('pgl_reporters', 'pgl_reporters', (SELECT id FROM users WHERE username = 'YOU_NEW_ADMIN_USERNAME'), now(), now(), 'Default new users team (reporter permission)');
Read more at issues #3 and #4.
I had an issue with styles while upgrading from 5.4 to 6.0, so if it can help, here is what to do :
- Stop your Public-GitLab instance.
- Execute :
RAILS_ENV=production bundle exec rake assets:clean
RAILS_ENV=production bundle exec rake assets:precompile
- Restart your Public-GitLab instance.
Public GitLab is provided and maintained by Arthur Hoaro.
Public GitLab is distributed under the same license as the original software.
This fork is based on cjdelisle work, from his original fork.