Difference between revisions of "Gitolite"
From Fixme.ch
(→How to) |
|||
| Line 4: | Line 4: | ||
* https://github.com/sitaramc/gitolite/wiki | * https://github.com/sitaramc/gitolite/wiki | ||
| − | == | + | == Usage == |
| + | * Access a repository like this: | ||
| + | git clone ssh://gitolite@git.fixme.ch:1337/$example | ||
| + | * List repositories you can access | ||
| + | ssh gitolite@foo.fixme.ch -p 1337 | ||
| + | |||
| + | == Administration == | ||
* Ask The following people to access the gitolite admin : | * Ask The following people to access the gitolite admin : | ||
RW = nemen | RW = nemen | ||
| Line 14: | Line 20: | ||
RW = prosouth | RW = prosouth | ||
RW = artphi | RW = artphi | ||
| − | + | === Create a repo === | |
| − | == | + | * Get the gitolite admin |
| − | * | + | |
git clone ssh://gitolite@git.fixme.ch:1337/gitolite-admin | git clone ssh://gitolite@git.fixme.ch:1337/gitolite-admin | ||
| − | + | * Edit conf/gitolite.conf, add your repo and permissions | |
| − | * | + | repo MySuperProject |
| − | + | R = @all #pull | |
| − | * | + | RW = myuser #push |
| − | + | RW+ = myuser #rewrite history | |
| + | * Commit and push to foo | ||
| + | git commit -am "Add XXX repo" | ||
| + | git push origin master | ||
| + | |||
| + | === Add user === | ||
| + | * Ask the user to create an ssh key and to give the public key | ||
| + | ssh-keygen | ||
| + | cat ~/.ssh/id_rsa.pub | ||
| + | * Create a new file for the key in keydir | ||
| + | echo 'ssh-rsa AAA[...]' > keydir/name@machine.pub | ||
| + | git add keydir/name@machine.pub | ||
| + | git commit -am "new key for name" | ||
| + | git push origin master | ||
== Tip == | == Tip == | ||
Revision as of 09:36, 7 May 2013
Goal
- Provides GIT repositories to the members.
- https://github.com/sitaramc/gitolite/wiki
Usage
- Access a repository like this:
git clone ssh://gitolite@git.fixme.ch:1337/$example
- List repositories you can access
ssh gitolite@foo.fixme.ch -p 1337
Administration
- Ask The following people to access the gitolite admin :
RW = nemen
RW = malik
RW = rorist
RW = francois
RW = anael
RW = crazygolem
RW = prosouth
RW = artphi
Create a repo
- Get the gitolite admin
git clone ssh://gitolite@git.fixme.ch:1337/gitolite-admin
- Edit conf/gitolite.conf, add your repo and permissions
repo MySuperProject
R = @all #pull
RW = myuser #push
RW+ = myuser #rewrite history
- Commit and push to foo
git commit -am "Add XXX repo" git push origin master
Add user
- Ask the user to create an ssh key and to give the public key
ssh-keygen cat ~/.ssh/id_rsa.pub
- Create a new file for the key in keydir
echo 'ssh-rsa AAA[...]' > keydir/name@machine.pub git add keydir/name@machine.pub git commit -am "new key for name" git push origin master
Tip
If you don't want to specify the port every time you use ssh/git, you can add the host to your ~/.ssh/config:
Host git.fixme.ch
Port 1337
Deploy
- There is a git hook to publish the application in prod
- The deploy hook is located at
/home/git/hooks/deploy.shin the Internal_Server - You must add a
post-receivehook in your project in a file/home/git/repositories/yourproject/hooks/post-receivewith the following content:
DIR=/where/your/project/should/be/deployed #example: /var/www/foo/htdocs APP=user-to-chown-to #example: www-data /home/git/hooks/deploy.sh $APP $DIR