Difference between revisions of "Hallcgit.jlab.org"
(First edit) |
|||
(5 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
+ | |||
+ | [[category:12GeV Software]] | ||
+ | |||
+ | '''NOTE: The hallcgit.jlab.org service has been superseded by https://code.jlab.org''' . | ||
+ | Existing repositories can be migrated to the new service in the usual git fashion. | ||
+ | [https://github.com/rndstr/gitolite-to-gitlab Tools also exist] to simplify this export, but know what you are doing first. | ||
+ | |||
+ | |||
+ | ---- | ||
+ | |||
+ | |||
Hall C has established a server, hallcgit.jlab.org, to host Hall C software projects being managed with git. The server uses the [http://sitaramc.github.com/gitolite/ gitolite] package to administer git repositories and access to those repositories. | Hall C has established a server, hallcgit.jlab.org, to host Hall C software projects being managed with git. The server uses the [http://sitaramc.github.com/gitolite/ gitolite] package to administer git repositories and access to those repositories. | ||
Line 9: | Line 20: | ||
As users often find themselves working from multiple machines, it is recommended to create a custom ssh key for hallcgit access. To do this, do: | As users often find themselves working from multiple machines, it is recommended to create a custom ssh key for hallcgit access. To do this, do: | ||
− | ssh-keygen -t | + | ssh-keygen -t rsa -f ~/.ssh/id_rsa_hallcgit |
− | Supply the file ~/.ssh/ | + | Supply the file ~/.ssh/id_rsa_hallcgit.pub to the hallcgit maintainer. |
Then edit ~/.ssh/config, adding the following lines | Then edit ~/.ssh/config, adding the following lines | ||
Line 18: | Line 29: | ||
Hostname hallcgit.jlab.org | Hostname hallcgit.jlab.org | ||
User git | User git | ||
− | IdentityFile /home/YOURUSERNAME/.ssh/ | + | IdentityFile /home/YOURUSERNAME/.ssh/id_rsa_hallcgit |
When constructing URL to use with git, use only "hallcgit", not "hallcgit.jlab.org". (E.g. "git@hallcgit:hcana.git") | When constructing URL to use with git, use only "hallcgit", not "hallcgit.jlab.org". (E.g. "git@hallcgit:hcana.git") | ||
− | To access hallcgit from a different computer, copy | + | To access hallcgit from a different computer, copy id_rsa_hallcgit and id_rsa_hallcgit.pub to the .ssh directory on the new computer and copy the new config lines to the .ssh/config file on that computer. |
= Creating personal repositories = | = Creating personal repositories = | ||
− | Normally, a new git repository on hallcgit can only be created by the hallcgit maintainer. However, hallcgit users can request the ability to create [http://sitaramc.github.com/gitolite/wild.html "wildcard"] repositories. | + | Normally, a new git repository on hallcgit can only be created by the hallcgit maintainer. However, hallcgit users can request the ability to create [http://sitaramc.github.com/gitolite/wild.html "wildcard"] repositories. If you wish to create such a repo for a new project, do: |
+ | |||
+ | git clone git@hallcgit:YOURUSERNAME/YOURPROJECTNAME.git | ||
+ | |||
+ | which will create a blank repository on hallcgit and clone it to your machine. (Use hallcgit.jlab.org instead of hallcgit if offsite and not using a custom key as described above.) | ||
+ | |||
+ | If you already have a project under git and wish to push it to hallcgit, then do | ||
+ | |||
+ | git remote add origin git@hallcgit:YOURUSERNAME/YOURPROJECTNAME.git | ||
+ | git push origin master | ||
+ | |||
+ | Repositories created this way will initially only be accessible by the creator. To add a user, do either: ( Remember that the YOURPROJECTNAME does NOT include ".git" extension) | ||
+ | |||
+ | ssh git@hallcgit perms YOURUSERNAME/YOURPROJECTNAME + READERS OTHERUSER | ||
+ | or | ||
+ | ssh git@hallcgit perms YOURUSERNAME/YOURPROJECTNAME + WRITERS OTHERUSER | ||
+ | |||
+ | depending on if you want to grant read or read/write access. (Use "-" to remove a user). Usernames on hallcgit are usually the same as JLab CUE usernames. | ||
+ | |||
+ | To make your repo show up on [https://hallcweb.jlab.org/git/ https://hallcweb.jlab.org/git/], give the user "daemon" read permission. | ||
+ | |||
+ | ssh git@hallcgit perms YOURUSERNAME/YOURPROJECTNAME + READERS daemon |
Latest revision as of 10:12, 3 May 2024
NOTE: The hallcgit.jlab.org service has been superseded by https://code.jlab.org . Existing repositories can be migrated to the new service in the usual git fashion. Tools also exist to simplify this export, but know what you are doing first.
Hall C has established a server, hallcgit.jlab.org, to host Hall C software projects being managed with git. The server uses the gitolite package to administer git repositories and access to those repositories.
Viewing git repositories with the web
Repositories that have been marked by their owner as public, can be browsed at https://hallcweb.jlab.org/git/. This site, using the simple Gitweb interface, allows users to browse source code and changes and allows one to download tarballs of projects. It can not be used to anonymously clone a repository. To clone git repositories from hallcgit, one needs to establish access to hallcgit and request read or read/write access to the repositories of interest.
Obtaining access
In order obtain access to hallcgit, you need to give your public ssh key to the hallcgit maintainer, Steve Wood, saw@jlab.org. When sending the key, please also specify which software projects you wish to access.
As users often find themselves working from multiple machines, it is recommended to create a custom ssh key for hallcgit access. To do this, do:
ssh-keygen -t rsa -f ~/.ssh/id_rsa_hallcgit
Supply the file ~/.ssh/id_rsa_hallcgit.pub to the hallcgit maintainer.
Then edit ~/.ssh/config, adding the following lines
Host hallcgit Hostname hallcgit.jlab.org User git IdentityFile /home/YOURUSERNAME/.ssh/id_rsa_hallcgit
When constructing URL to use with git, use only "hallcgit", not "hallcgit.jlab.org". (E.g. "git@hallcgit:hcana.git")
To access hallcgit from a different computer, copy id_rsa_hallcgit and id_rsa_hallcgit.pub to the .ssh directory on the new computer and copy the new config lines to the .ssh/config file on that computer.
Creating personal repositories
Normally, a new git repository on hallcgit can only be created by the hallcgit maintainer. However, hallcgit users can request the ability to create "wildcard" repositories. If you wish to create such a repo for a new project, do:
git clone git@hallcgit:YOURUSERNAME/YOURPROJECTNAME.git
which will create a blank repository on hallcgit and clone it to your machine. (Use hallcgit.jlab.org instead of hallcgit if offsite and not using a custom key as described above.)
If you already have a project under git and wish to push it to hallcgit, then do
git remote add origin git@hallcgit:YOURUSERNAME/YOURPROJECTNAME.git git push origin master
Repositories created this way will initially only be accessible by the creator. To add a user, do either: ( Remember that the YOURPROJECTNAME does NOT include ".git" extension)
ssh git@hallcgit perms YOURUSERNAME/YOURPROJECTNAME + READERS OTHERUSER
or
ssh git@hallcgit perms YOURUSERNAME/YOURPROJECTNAME + WRITERS OTHERUSER
depending on if you want to grant read or read/write access. (Use "-" to remove a user). Usernames on hallcgit are usually the same as JLab CUE usernames.
To make your repo show up on https://hallcweb.jlab.org/git/, give the user "daemon" read permission.
ssh git@hallcgit perms YOURUSERNAME/YOURPROJECTNAME + READERS daemon