Difference between revisions of "Git and Gitweb"
| (4 intermediate revisions by the same user not shown) | |||
| Line 1: | Line 1: | ||
| + | {{NeedsUpdate}} | ||
| + | |||
| + | |||
| + | '''NOTE:''' There is a [http://www.amahi.org/apps/gitweb one-click app] currently in ALPHA being tested. | ||
| + | |||
[http://git-scm.com/ Git] is a free & open source, distributed version control system designed to handle everything from small to very large projects with speed and efficiency. Every Git clone is a full-fledged repository with complete history and full revision tracking capabilities, not dependent on network access or a central server. Branching and merging are fast and easy to do. Coupled with [http://sourceforge.net/apps/trac/sourceforge/wiki/GitWeb%20repository%20browser Gitweb], provides a web interface for browsing your project. | [http://git-scm.com/ Git] is a free & open source, distributed version control system designed to handle everything from small to very large projects with speed and efficiency. Every Git clone is a full-fledged repository with complete history and full revision tracking capabilities, not dependent on network access or a central server. Branching and merging are fast and easy to do. Coupled with [http://sourceforge.net/apps/trac/sourceforge/wiki/GitWeb%20repository%20browser Gitweb], provides a web interface for browsing your project. | ||
| − | This tutorial will show you how to install, create a repo, and browse that repo on your HDA. | + | This tutorial will show you how to install, create a repo, and browse that repo on your HDA. |
| Line 17: | Line 22: | ||
<li>[[Open_Terminal_as_root|Open a terminal as root]] user and do the following: | <li>[[Open_Terminal_as_root|Open a terminal as root]] user and do the following: | ||
<li>Install dependencies | <li>Install dependencies | ||
| − | + | <pre>yum -y install git git-daemon gitweb</pre></li> | |
<li>Look for the ''####-gitweb.conf'' in '''/etc/httpd/conf.d''' (#### is some number, i.e. 1000) file and open it in your favorite editor. Add text after '''ServerAlias''' line | <li>Look for the ''####-gitweb.conf'' in '''/etc/httpd/conf.d''' (#### is some number, i.e. 1000) file and open it in your favorite editor. Add text after '''ServerAlias''' line | ||
| − | + | <pre>Text=Alias /git /var/hda/web-apps/gitweb/html | |
RewriteEngine On | RewriteEngine On | ||
RewriteRule ^git$ git/ [R] | RewriteRule ^git$ git/ [R] | ||
DirectoryIndex gitweb.cgi | DirectoryIndex gitweb.cgi | ||
SetEnv GITWEB_CONFIG "/etc/gitweb.conf" | SetEnv GITWEB_CONFIG "/etc/gitweb.conf" | ||
| − | AddHandler cgi-script .cgi | + | AddHandler cgi-script .cgi</pre></li> |
<li>Create web page to browse repository</li> | <li>Create web page to browse repository</li> | ||
| − | + | <pre>cd /var/hda/web-apps/gitweb | |
echo '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> | echo '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> | ||
<html> | <html> | ||
| Line 36: | Line 41: | ||
</BODY> | </BODY> | ||
</HTML>' > html/index.html | </HTML>' > html/index.html | ||
| − | chown apache.users html/index.html | + | chown apache.users html/index.html</pre></li> |
</ol> | </ol> | ||
<li>Add user | <li>Add user | ||
| − | + | <pre>useradd -U -d /var/cache/git -s /usr/libexec/git-core/git-shell git</pre></li> | |
<li>Set directory permissions | <li>Set directory permissions | ||
| − | + | <pre>cd /var/cache | |
chown -R git:git git | chown -R git:git git | ||
| − | chmod 755 git/ | + | chmod 755 git/</pre></li> |
<li>Create '''/etc/init.d/git''' file and add the following | <li>Create '''/etc/init.d/git''' file and add the following | ||
| − | + | <pre>#!/bin/sh | |
<nowiki>#</nowiki> | <nowiki>#</nowiki> | ||
<nowiki>#</nowiki> Startup/shutdown script for Git Daemon | <nowiki>#</nowiki> Startup/shutdown script for Git Daemon | ||
| Line 106: | Line 111: | ||
esac | esac | ||
| − | exit $RETVAL | + | exit $RETVAL</pre></li> |
<li>Set init script to run | <li>Set init script to run | ||
| − | + | <pre>chmod 755 /etc/init.d/git; | |
/etc/init.d/git start | /etc/init.d/git start | ||
| − | /sbin/chkconfig git on | + | /sbin/chkconfig git on</pre></li> |
<li>Set User information (change '''user.name''' and '''user.email''' accordingly) | <li>Set User information (change '''user.name''' and '''user.email''' accordingly) | ||
| − | + | <pre>git config --global user.name "MyHDA" | |
| − | git config --global user.email myhda@localhost | + | git config --global user.email myhda@localhost</pre></li> |
<li>Create temporary repository | <li>Create temporary repository | ||
| − | + | <pre>cd /var/cache/git/ | |
git init test | git init test | ||
| − | cd test | + | cd test</pre></li> |
<li>Add test file and a short description | <li>Add test file and a short description | ||
| − | + | <pre>echo 'test' > README | |
git add README | git add README | ||
| − | git commit -a -m "initial README file" | + | git commit -a -m "initial README file"</pre></li> |
<li>Create local repository | <li>Create local repository | ||
| − | + | <pre>cd /var/cache/git/ | |
git clone test test.git | git clone test test.git | ||
cd test.git | cd test.git | ||
| − | git push origin master | + | git push origin master</pre></li> |
<li>Edit '''/var/cache/git/test/.git/config''' and add the following at the bottom (change '''MyHDA''' as desired) | <li>Edit '''/var/cache/git/test/.git/config''' and add the following at the bottom (change '''MyHDA''' as desired) | ||
| − | + | <pre>[gitweb] | |
| − | owner = MyHDA | + | owner = MyHDA</pre></li> |
<li>Add to bottom of '''/etc/gitweb.conf''' file | <li>Add to bottom of '''/etc/gitweb.conf''' file | ||
| − | + | <pre>$feature{'blame'}{'default'} = [undef]; | |
$feature{'pickaxe'}{'default'} = [undef]; | $feature{'pickaxe'}{'default'} = [undef]; | ||
$feature{'search'}{'default'} = [undef]; | $feature{'search'}{'default'} = [undef]; | ||
| Line 150: | Line 155: | ||
$feature{'pathinfo'}{'default'} = [1]; | $feature{'pathinfo'}{'default'} = [1]; | ||
$my_uri = "http://gitweb/git/"; | $my_uri = "http://gitweb/git/"; | ||
| − | $home_link = "http://gitweb/git/;" | + | $home_link = "http://gitweb/git/;"</pre></li> |
<li>Copy web files and set permissions | <li>Copy web files and set permissions | ||
| − | + | <pre>d /var/hda/web-apps/gitweb | |
cp -r /var/www/git/* html | cp -r /var/www/git/* html | ||
| − | chown -R apache:users html/ | + | chown -R apache:users html/</pre></li> |
<li>Update local repository description | <li>Update local repository description | ||
| − | + | <pre>cd /var/cache/git | |
sed -i '1d' test.git/.git/description | sed -i '1d' test.git/.git/description | ||
| − | echo 'Test Repo' >> test.git/.git/description | + | echo 'Test Repo' >> test.git/.git/description</pre></li> |
<li>Edit '''/etc/httpd/conf.d/git.conf''' and replace with this text | <li>Edit '''/etc/httpd/conf.d/git.conf''' and replace with this text | ||
| − | + | <pre><Directory /var/hda/web-apps/gitweb/html> | |
RewriteEngine On | RewriteEngine On | ||
RewriteBase /git/ | RewriteBase /git/ | ||
| Line 167: | Line 172: | ||
RewriteCond %{REQUEST_FILENAME} !-d | RewriteCond %{REQUEST_FILENAME} !-d | ||
RewriteRule (.*) gitweb.cgi/$1 [QSA,L] | RewriteRule (.*) gitweb.cgi/$1 [QSA,L] | ||
| − | </Directory> | + | </Directory></pre></li> |
<li>Update permissions, remove temporary repository, and restart web server | <li>Update permissions, remove temporary repository, and restart web server | ||
| − | + | <pre>chown -R git.git /var/cache/git | |
rm -rf /var/cache/git/test | rm -rf /var/cache/git/test | ||
| − | /etc/init.d/httpd restart | + | /etc/init.d/httpd restart</pre></li> |
</ul> | </ul> | ||
| Line 179: | Line 184: | ||
==Optional== | ==Optional== | ||
You can add the Amahi repo by doing the following: | You can add the Amahi repo by doing the following: | ||
| − | + | <pre>cd /var/cache/git | |
| − | git clone git://git.amahi.org/amahi.git | + | git clone git://git.amahi.org/amahi.git</pre> |
==References== | ==References== | ||
Latest revision as of 17:00, 9 January 2021
| Update Needed | |
|---|---|
| The contents of this page have become outdated or irrelevant. Please consider updating it. |
NOTE: There is a one-click app currently in ALPHA being tested.
Git is a free & open source, distributed version control system designed to handle everything from small to very large projects with speed and efficiency. Every Git clone is a full-fledged repository with complete history and full revision tracking capabilities, not dependent on network access or a central server. Branching and merging are fast and easy to do. Coupled with Gitweb, provides a web interface for browsing your project.
This tutorial will show you how to install, create a repo, and browse that repo on your HDA.
NOTE: Tested on Fedora 14.
Contents
Setup
- Create web app (Advanced Settings must be enabled on HDA)
- From the Dashboard main page, select Apps at the top.
- Choose Webapps
- Select New Web App button at the bottom
- Enter gitweb for the Name (ensure the path reflects the name correctly)
- Choose Create
- Open a terminal as root user and do the following:
- Install dependencies
yum -y install git git-daemon gitweb
- Look for the ####-gitweb.conf in /etc/httpd/conf.d (#### is some number, i.e. 1000) file and open it in your favorite editor. Add text after ServerAlias line
Text=Alias /git /var/hda/web-apps/gitweb/html RewriteEngine On RewriteRule ^git$ git/ [R] DirectoryIndex gitweb.cgi SetEnv GITWEB_CONFIG "/etc/gitweb.conf" AddHandler cgi-script .cgi
- Create web page to browse repository
cd /var/hda/web-apps/gitweb echo '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <title>Your Page Title</title> <meta http-equiv="REFRESH" content="0;url=http://gitweb/git/"></HEAD> <BODY> Optional page text here. </BODY> </HTML>' > html/index.html chown apache.users html/index.html
useradd -U -d /var/cache/git -s /usr/libexec/git-core/git-shell git
cd /var/cache chown -R git:git git chmod 755 git/
#!/bin/sh
#
# Startup/shutdown script for Git Daemon
#
# Linux chkconfig stuff:
#
# chkconfig: 345 56 10
# description: Startup/shutdown script for Git Daemon
#
. /etc/init.d/functions
DAEMON=/usr/libexec/git-core/git-daemon
ARGS='--base-path=/var/cache/git --detach --syslog --export-all --user=git --group=git'
prog=git-daemon
start () {
echo -n $"Starting $prog: "
# start daemon
daemon $DAEMON $ARGS
RETVAL=$?
echo
[ $RETVAL = 0 ] && touch /var/lock/git-daemon
return $RETVAL
}
stop () {
# stop daemon
echo -n $"Stopping $prog: "
killproc $DAEMON
RETVAL=$?
echo
[ $RETVAL = 0 ] && rm -f /var/lock/git-daemon
}
restart() {
stop
start
}
case $1 in
start)
start
;;
stop)
stop
;;
restart)
restart
;;
status)
status $DAEMON
RETVAL=$?
;;
*)
echo $"Usage: $prog {start|stop|restart|status}"
exit 3
esac
exit $RETVALchmod 755 /etc/init.d/git; /etc/init.d/git start /sbin/chkconfig git on
git config --global user.name "MyHDA" git config --global user.email myhda@localhost
cd /var/cache/git/ git init test cd test
echo 'test' > README git add README git commit -a -m "initial README file"
cd /var/cache/git/ git clone test test.git cd test.git git push origin master
[gitweb]
owner = MyHDA$feature{'blame'}{'default'} = [undef];
$feature{'pickaxe'}{'default'} = [undef];
$feature{'search'}{'default'} = [undef];
$feature{'grep'}{'default'} = 1;
$feature{'snapshot'}{'default'} = ['tgz', 'gzip', 'zip'];
$feature{'snapshot'}{'override'} = 1;
$site_name = "HDA Git";
$projectroot = '/var/cache/git/';
$projects_list_description_width = 50;
$git_temp = "/tmp";
$home_text = "indextext.html";
$site_footer = "indexfooter.html";
$projects_list = $projectroot;
$home_link_str = "http://gitweb / git ";
$stylesheet = "/git/static/gitweb.css";
$logo = "/git/static/git-logo.png";
$favicon = "/git/static/git-favicon.png";
$feature{'pathinfo'}{'default'} = [1];
$my_uri = "http://gitweb/git/";
$home_link = "http://gitweb/git/;"d /var/hda/web-apps/gitweb cp -r /var/www/git/* html chown -R apache:users html/
cd /var/cache/git sed -i '1d' test.git/.git/description echo 'Test Repo' >> test.git/.git/description
<Directory /var/hda/web-apps/gitweb/html>
RewriteEngine On
RewriteBase /git/
RewriteRule ^$ gitweb.cgi [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule (.*) gitweb.cgi/$1 [QSA,L]
</Directory>chown -R git.git /var/cache/git rm -rf /var/cache/git/test /etc/init.d/httpd restart
Complete
That is it. Navigate to http://gitweb/git to browse the newly created repository.
Optional
You can add the Amahi repo by doing the following:
cd /var/cache/git git clone git://git.amahi.org/amahi.git
