summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJames Moger <james.moger@gitblit.com>2013-10-25 15:25:02 -0400
committerJames Moger <james.moger@gitblit.com>2013-10-25 18:32:13 -0400
commit6c4be170559efa112bb92cd1676543e86850e976 (patch)
treec919d115bae4e1a801e545009e1f17fd6f6f7e40 /src
parent3079105705d76ff0fbfcc755825aa75b0b6ef01a (diff)
downloadgitblit-6c4be170559efa112bb92cd1676543e86850e976.tar.gz
gitblit-6c4be170559efa112bb92cd1676543e86850e976.zip
Documentation
Change-Id: I717e13d1f852a4adf50b547f4769dd62da2384ce
Diffstat (limited to 'src')
-rw-r--r--src/main/resources/gitblit.css6
-rw-r--r--src/site/administration.mkd8
-rw-r--r--src/site/faq.mkd10
-rw-r--r--src/site/federation.mkd7
-rw-r--r--src/site/rpc.mkd28
-rw-r--r--src/site/setup_client.mkd5
-rw-r--r--src/site/setup_clientmenus.mkd5
-rw-r--r--src/site/setup_go.mkd18
-rw-r--r--src/site/setup_hooks.mkd4
-rw-r--r--src/site/setup_proxy.mkd17
-rw-r--r--src/site/setup_war.mkd2
-rw-r--r--src/site/upgrade_go.mkd4
-rw-r--r--src/site/upgrade_war.mkd2
13 files changed, 67 insertions, 49 deletions
diff --git a/src/main/resources/gitblit.css b/src/main/resources/gitblit.css
index 90badd2c..91bd4aa0 100644
--- a/src/main/resources/gitblit.css
+++ b/src/main/resources/gitblit.css
@@ -1512,13 +1512,13 @@ div.markdown {
}
div.markdown pre {
- background-color: rgb(251, 251, 251);
+ background-color: rgb(250, 250, 250);
border: 1px solid rgb(221, 221, 221);
border-radius: 4px 4px 4px 4px;
display: block;
font-size: 12px;
line-height: 18px;
- margin: 0 0 9px;
+ margin: 9px 0;
padding: 8.5px;
white-space: pre-wrap;
}
@@ -1530,7 +1530,7 @@ div.markdown pre code {
}
div.markdown code {
- background-color: rgb(251, 251, 251);
+ background-color: rgb(250, 250, 250);
border: 1px solid rgb(221, 221, 221);
border-radius: 3px;
padding: 0 0.2em;
diff --git a/src/site/administration.mkd b/src/site/administration.mkd
index 7ed40ebe..dad4f414 100644
--- a/src/site/administration.mkd
+++ b/src/site/administration.mkd
@@ -95,15 +95,15 @@ You may optionally enable committer verification which requires that each commit
**How is this enforced?**
Bob must set his *user.name* and *user.email* values for the repository to match his Gitblit user account **BEFORE** committing to his repository.
-<pre>
+
+```
[user "bob"]
displayName = Bob Jones
emailAddress = bob@somewhere.com
-</pre>
-<pre>
+```
+
git config user.name "Bob Jones"
git config user.email bob@somewhere.com
-</pre>
or
git config user.name bob
diff --git a/src/site/faq.mkd b/src/site/faq.mkd
index bf8055d3..6537f1b4 100644
--- a/src/site/faq.mkd
+++ b/src/site/faq.mkd
@@ -99,12 +99,12 @@ Small workgroups that require centralized repositories.
Gitblit is not meant to be a social coding resource like [Github](http://github.com) or [Bitbucket](http://bitbucket.com) with 100s or 1000s of users. Gitblit is designed to fulfill the same function as your centralized Subversion or CVS server.
### Why does Gitblit exist when there is Git and Gitweb?
-As a Java developer I prefer that as much of my tooling as possible is Java.<br/>
+As a Java developer I prefer that as much of my tooling as possible is Java.
Originally, I was going to use [Mercurial](http://mercurial.selenic.com) but...
-- MercurialEclipse [shells to Python, writes to System.out, and captures System.in](http://mercurial.808500.n3.nabble.com/Hg4J-Mercurial-pure-Java-library-tp2693090p2694555.html)<br/>
+- MercurialEclipse [shells to Python, writes to System.out, and captures System.in](http://mercurial.808500.n3.nabble.com/Hg4J-Mercurial-pure-Java-library-tp2693090p2694555.html)
Parsing command-line output is fragile and suboptimal.<br/>Unfortunately this is necessary because Mercurial is an application, not a library.
-- Mercurial HTTP/HTTPS needs to run as CGI through Apache/IIS/etc, as mod_python through Apache, or served with a built-in http server.<br/>
+- Mercurial HTTP/HTTPS needs to run as CGI through Apache/IIS/etc, as mod_python through Apache, or served with a built-in http server.
This requires setup and maintenance of multiple, mixed 3rd party components.
Gitblit eliminates all that complication with its 100% Java stack and simple single configuration file.
@@ -112,7 +112,7 @@ Gitblit eliminates all that complication with its 100% Java stack and simple sin
Additionally, Git and Gitweb do not offer repository creation or user management.
### Do I need real Git?
-No (mostly). Gitblit is based on [JGit][jgit] which is a pure Java implementation of the [Git version control system][git].<br/>
+No (mostly). Gitblit is based on [JGit][jgit] which is a pure Java implementation of the [Git version control system][git].
Everything you need for Gitblit (except Java) is either bundled in the distribution file or automatically downloaded on execution.
#### mostly
@@ -155,7 +155,7 @@ You might consider running [Gerrit](http://gerrit.googlecode.org) which does int
As of 0.9.0, Gitblit supports Lucene-based searching.
-If Lucene indexing is disabled, Gitblit falls back to brute-force commit-traversal search. Commit-traversal search supports case-insensitive searching of *commit message* (default), *author*, and *committer*.<br/>
+If Lucene indexing is disabled, Gitblit falls back to brute-force commit-traversal search. Commit-traversal search supports case-insensitive searching of *commit message* (default), *author*, and *committer*.
To search by *author* or *committer* use the following syntax in the search box:
diff --git a/src/site/federation.mkd b/src/site/federation.mkd
index 756d3fcd..7574a321 100644
--- a/src/site/federation.mkd
+++ b/src/site/federation.mkd
@@ -48,12 +48,13 @@ Changing your *federation.passphrase* will break any registrations you have esta
If you want your repositories (and optionally users accounts and settings) to be pulled by another Gitblit instance, you need to register your origin Gitblit instance with a pulling Gitblit instance by providing the url of your Gitblit instance and a federation token.
Gitblit generates the following standard federation tokens:
----JAVA---
+
+```java
String allToken = SHA1(passphrase + "-ALL");
String usersAndRepositoriesToken = SHA1(passphrase + "-USERS_AND_REPOSITORIES");
String repositoriesToken = SHA1(passphrase + "-REPOSITORIES");
----JAVA---
-
+```
+
The *ALL* token allows another Gitblit instance to pull all your repositories, user accounts, server settings, and referenced push scripts.
The *USERS_AND_REPOSITORIES* token allows another Gitblit instance to pull all your repositories and user accounts.
The *REPOSITORIES* token only allows pulling of the repositories.
diff --git a/src/site/rpc.mkd b/src/site/rpc.mkd
index 8f562296..6fa9ba5a 100644
--- a/src/site/rpc.mkd
+++ b/src/site/rpc.mkd
@@ -58,6 +58,7 @@ The Gitblit API includes methods for retrieving and interpreting RSS feeds. The
## JSON Remote Procedure Call (RPC) Interface
### RPC Protocol Versions
+
<table class="table">
<tbody>
<tr><th>Release</th><th>Protocol Version</th></tr>
@@ -78,6 +79,7 @@ Use *SET_REPOSITORY_MEMBER_PERMISSIONS* instead.
Use *SET_REPOSITORY_TEAM_PERMISSIONS* instead.
### RPC Request and Response Types
+
<table class="table">
<tr><th colspan='2'>url parameters</th><th rowspan='2'>required<br/>user<br/>permission</th><th rowspan='2'>protocol<br/>version</th><th colspan='2'>json</th></tr>
<tr><th>req=</th><th>name=</th><th>post body</th><th>response body</th></tr>
@@ -120,6 +122,7 @@ Use *SET_REPOSITORY_TEAM_PERMISSIONS* instead.
</table>
### RPC/HTTP Response Codes
+
<table class="table">
<tr><th>code</th><th>name</th><th>description</th></tr>
<tr><td>200</td><td>success</td><td>Gitblit processed the request successfully</td></tr>
@@ -134,7 +137,8 @@ Use *SET_REPOSITORY_TEAM_PERMISSIONS* instead.
**url**: https://localhost/rpc?req=LIST_REPOSITORIES
**response body**: Map&lt;String, RepositoryModel&gt; where the map key is the clone url of the repository
-<pre>
+
+```json
{
"https://localhost/git/libraries/xmlapache.git": {
"name": "libraries/xmlapache.git",
@@ -177,7 +181,7 @@ Use *SET_REPOSITORY_TEAM_PERMISSIONS* instead.
"size": "4.8 MB"
}
}
-</pre>
+```
### Example: EDIT_REPOSITORY (rename)
@@ -185,7 +189,8 @@ The original repository name is specified in the *name* url parameter. The new
**url**: https://localhost/rpc?req=EDIT_REPOSITORY&name=libraries/xmlapache.git
**post body**: RepositoryModel
-<pre>
+
+```json
{
"name": "libraries/xmlapache-renamed.git",
"description": "apache xmlrpc client and server",
@@ -207,12 +212,13 @@ The original repository name is specified in the *name* url parameter. The new
"skipSummaryMetrics": false,
"size": "102 KB"
}
-</pre>
+```
### Example: LIST_USERS
**url**: https://localhost/rpc?req=LIST_USERS
**response body**: List&lt;UserModel&gt;
-<pre>
+
+```json
[
{
"username": "admin",
@@ -232,12 +238,13 @@ The original repository name is specified in the *name* url parameter. The new
]
}
]
-</pre>
+```
### Example: LIST_SETTINGS
**url**: https://localhost/rpc?req=LIST_SETTINGS
**response body**: ServerSettings
-<pre>
+
+```json
{
"settings": {
"web.siteName": {
@@ -262,12 +269,13 @@ The original repository name is specified in the *name* url parameter. The new
}
}
}
-</pre>
+```
### Example: LIST_STATUS
**url**: https://localhost/rpc?req=LIST_STATUS
**response body**: ServerStatus
-<pre>
+
+```json
{
"bootDate": "2011-10-22T12:13:00Z",
"version": "0.7.0-SNAPSHOT",
@@ -294,4 +302,4 @@ The original repository name is specified in the *name* url parameter. The new
"heapSize": 1899560960,
"servletContainer": "jetty/7.4.3.v20110701"
}
-</pre> \ No newline at end of file
+``` \ No newline at end of file
diff --git a/src/site/setup_client.mkd b/src/site/setup_client.mkd
index e72751a1..d8fc7d14 100644
--- a/src/site/setup_client.mkd
+++ b/src/site/setup_client.mkd
@@ -35,11 +35,12 @@ For Eclipse, you can append `-Djsse.enableSNIExtension=false` to your *eclipse.i
#### Native Clients
Native clients may display an error when attempting to clone or push that looks like this:
----FIXED---
+
+```
C:\projects\git\gitblit>git push rhcloud master
error: error:14077458:SSL routines:SSL23_GET_SERVER_HELLO:reason(1112) while accessing https://demo-gitblit.rhcloud.com/git/gitblit.git/info/refs?service=git-receive-pack
fatal: HTTP request failed
----FIXED---
+```
### Cloning a Repository
diff --git a/src/site/setup_clientmenus.mkd b/src/site/setup_clientmenus.mkd
index c40c3b29..324df692 100644
--- a/src/site/setup_clientmenus.mkd
+++ b/src/site/setup_clientmenus.mkd
@@ -7,7 +7,8 @@ Gitblit supports defining menus for native platform git client clone urls. By d
You can define new client integrations and deactivate/remove the default integrations by creating a file *$(baseFolder}/clientapps.json*.
### Example definitions
----JSON---
+
+```json
[
{
"name": "SmartGit/Hg",
@@ -45,4 +46,4 @@ You can define new client integrations and deactivate/remove the default integra
"isActive": false
}
]
----JSON--- \ No newline at end of file
+```
diff --git a/src/site/setup_go.mkd b/src/site/setup_go.mkd
index 6625baa8..839fd2c8 100644
--- a/src/site/setup_go.mkd
+++ b/src/site/setup_go.mkd
@@ -2,7 +2,7 @@
1. Download and unzip Gitblit GO [${project.releaseVersion} (Windows)](%GCURL%gitblit-${project.releaseVersion}.zip) or [${project.releaseVersion} (Linux/OSX)](%GCURL%gitblit-${project.releaseVersion}.tar.gz).
*Its best to eliminate spaces in the path name.*
-2. The server itself is configured through a simple text file.<br/>
+2. The server itself is configured through a simple text file.
Open `data/gitblit.properties` in your favorite text editor and make sure to review and set:
- *server.httpPort* and *server.httpsPort*
- *server.httpBindInterface* and *server.httpsBindInterface*
@@ -10,10 +10,12 @@ Open `data/gitblit.properties` in your favorite text editor and make sure to rev
**https** is strongly recommended because passwords are insecurely transmitted form your browser/git client using Basic authentication!
- *git.packedGitLimit* (set larger than the size of your largest repository)
- *git.streamFileThreshold* (set larger than the size of your largest committed file)
-3. Execute `authority.cmd` or `java -cp gitblit.jar com.gitblit.authority.Launcher --baseFolder data` from a command-line<br/>**NOTE:** The Authority is a Swing GUI application. Use of this tool is not required as Gitblit GO will startup and create SSL certificates itself, BUT use of this tool allows you to control the identification metadata used in the generated certificates. Skipping this step will result in certificates with default metadata.
+3. Execute `authority.cmd` or `java -cp gitblit.jar com.gitblit.authority.Launcher --baseFolder data` from a command-line
+**NOTE:** The Authority is a Swing GUI application. Use of this tool is not required as Gitblit GO will startup and create SSL certificates itself, BUT use of this tool allows you to control the identification metadata used in the generated certificates. Skipping this step will result in certificates with default metadata.
1. fill out the fields in the *new certificate defaults* dialog
2. enter the store password used in *server.storePassword* when prompted. This generates an SSL certificate for **localhost**.
- 3. you may want to generate an SSL certificate for the hostname or ip address hostnames you are serving from<br/>**NOTE:** You can only have **one** SSL certificate specified for a port.
+ 3. you may want to generate an SSL certificate for the hostname or ip address hostnames you are serving from
+ **NOTE:** You can only have **one** SSL certificate specified for a port.
5. exit the authority app
4. Execute `gitblit.cmd` or `java -jar gitblit.jar --baseFolder data` from a command-line
5. Open your browser to <http://localhost:8080> or <https://localhost:8443> depending on your chosen configuration.
@@ -94,20 +96,20 @@ Gitblit uses [Apache Commons Daemon](http://commons.apache.org/daemon) to instal
3. Add any necessary *--StartParams* as enumerated below in **Command-Line Parameters**.
4. Execute the script.
-After service installation you can use the `gitblitw.exe` utility to control and modify the runtime settings of the service.<br/>
+After service installation you can use the `gitblitw.exe` utility to control and modify the runtime settings of the service.
Additional service definition options and runtime capabilities of `gitblitw.exe` (prunmgr.exe) are documented [here](http://commons.apache.org/daemon/procrun.html).
-**NOTE:**<br/>
+**NOTE:**
If you change the name of the service from *gitblit* you must also change the name of `gitblitw.exe` to match the new service name otherwise the connection between the service and the utility is lost, at least to double-click execution.
#### VM Considerations
-By default, the service installation script configures your Windows service to use your default JVM. This setup usually defaults to a client VM.<br/>
+By default, the service installation script configures your Windows service to use your default JVM. This setup usually defaults to a client VM.
If you have installed a JDK, you might consider using the `gitblitw.exe` utility to manually specify the *server* VM.
1. Execute `gitblitw.exe`
2. On the *Java* tab uncheck *Use default*.
-3. Manually navigate your filesystem and specify the server VM with the `...` button<br/><pre>
-Java Virtual Machine:
+3. Manually navigate your filesystem and specify the server VM with the `...` button
+<pre>Java Virtual Machine:
C:\Program Files\Java\jre6\bin\server\jvm.dll</pre>
#### Command-Line Parameters
diff --git a/src/site/setup_hooks.mkd b/src/site/setup_hooks.mkd
index b3cb9c03..aae56623 100644
--- a/src/site/setup_hooks.mkd
+++ b/src/site/setup_hooks.mkd
@@ -31,7 +31,7 @@ Hook contributions and improvements are welcome.
<blockquote>Grape (The Groovy Adaptable Packaging Engine or Groovy Advanced Packaging Engine) is the infrastructure enabling the grab() calls in Groovy, a set of classes leveraging <a href="http://ant.apache.org/ivy">Ivy</a> to allow for a repository driven module system for Groovy. This allows a developer to write a script with an essentially arbitrary library requirement, and ship just the script. Grape will, at runtime, download as needed and link the named libraries and all dependencies forming a transitive closure when the script is run from existing repositories such as Ibiblio, Codehaus, and java.net.</blockquote>
----JAVA---
+```java
// create and use a primitive array
import org.apache.commons.collections.primitives.ArrayIntList
@@ -42,7 +42,7 @@ def ints = createEmptyInts()
ints.add(0, 42)
assert ints.size() == 1
assert ints.get(0) == 42
----JAVA---
+```
### Custom Fields
diff --git a/src/site/setup_proxy.mkd b/src/site/setup_proxy.mkd
index b169cefa..f1435f12 100644
--- a/src/site/setup_proxy.mkd
+++ b/src/site/setup_proxy.mkd
@@ -5,17 +5,21 @@ Gitblit runs fine behind Apache. You may use either *mod_proxy* (GO or WAR) or
Each Linux distribution may vary on the exact configuration of Apache 2.2.
Here is a sample configuration that works on Debian 7.0 (Wheezy), your distribution may be different.
-1. First we need to make sure we have Apache's proxy modules available.
----FIXED---
+### Make sure we have Apache's proxy modules
+
+```
sudo su
cd /etc/apache2/mods-enabled
ln -s ../mods-available/proxy.load proxy.load
ln -s ../mods-available/proxy_balancer.load proxy_balancer.load
ln -s ../mods-available/proxy_http.load proxy_http.load
ln -s ../mods-available/proxy_ajp.load proxy_ajp.load
----FIXED---
-2. Then we need to make sure we are configuring Apache to use the proxy modules and to setup the proxied connection from Apache to Gitblit GO or from Apache to your chosen servlet container. The following snippet is stored as `/etc/apache2/conf.d/gitblit`.
----FIXED---
+```
+### Configuring Apache to use the proxy modules
+
+Now we must configure Apache to use the proxy modules and the proxied connection from Apache to Gitblit GO or from Apache to your chosen servlet container. The following snippet is stored as `/etc/apache2/conf.d/gitblit`.
+
+```
# Turn off support for true Proxy behaviour as we are acting as
# a transparent proxy
ProxyRequests Off
@@ -55,7 +59,8 @@ ProxyPreserveHost On
#RequestHeader set X-Forwarded-Context /
#ProxyPass /gitblit ajp://localhost:8009/gitblit
----FIXED---
+```
+
**Please** make sure to:
1. Review the security of these settings as appropriate for your deployment
2. Uncomment the *ProxyPass* setting for whichever connection you prefer (http/ajp)
diff --git a/src/site/setup_war.mkd b/src/site/setup_war.mkd
index 18a0799c..3d28ee67 100644
--- a/src/site/setup_war.mkd
+++ b/src/site/setup_war.mkd
@@ -2,7 +2,7 @@
1. Download Gitblit WAR [${project.releaseVersion}](%GCURL%gitblit-${project.releaseVersion}.war) to the webapps folder of your servlet container.
2. You may have to manually extract the WAR (zip file) to a folder within your webapps folder.
-3. By default, the Gitblit webapp is configured through `WEB-INF/data/gitblit.properties`.<br/>
+3. By default, the Gitblit webapp is configured through `WEB-INF/data/gitblit.properties`.
Open `WEB-INF/data/gitblit.properties` in your favorite text editor and make sure to review and set:
- &lt;context-parameter&gt; *git.packedGitLimit* (set larger than the size of your largest repository)
- &lt;context-parameter&gt; *git.streamFileThreshold* (set larger than the size of your largest committed file)
diff --git a/src/site/upgrade_go.mkd b/src/site/upgrade_go.mkd
index cd516015..54d7ab59 100644
--- a/src/site/upgrade_go.mkd
+++ b/src/site/upgrade_go.mkd
@@ -9,12 +9,12 @@ All platforms support the *--baseFolder* command-line argument.
## Upgrading Gitblit GO (pre-1.2.1)
1. Create a `data` folder and copy the following files and folders to it:
- - **users.conf*
+ - **users.conf**
- **projects.conf** *(if you have one)*
- **gitblit.properties**
- **serverKeystore.jks**
- **serverTrustStore.jks**
- - *certs** folder
+ - **certs** folder
- **git** folder
- **groovy** folder
- **proposals** folder
diff --git a/src/site/upgrade_war.mkd b/src/site/upgrade_war.mkd
index dd9ba648..23003bed 100644
--- a/src/site/upgrade_war.mkd
+++ b/src/site/upgrade_war.mkd
@@ -1,5 +1,5 @@
## Upgrading Gitblit WAR (1.2.1+)
-1. Make sure your `WEB-INF/web.xml` *baseFolder* context parameter is not `${contextFolder}/WEB-INF/data`!<br/>
+1. Make sure your `WEB-INF/web.xml` *baseFolder* context parameter is not `${contextFolder}/WEB-INF/data`!
If it is, move your `WEB-INF/data` folder to a location writeable by your servlet container.
2. Deploy new WAR
3. Edit the new WAR's `WEB-INF/web.xml` file and set the *baseFolder* context parameter to your external baseFolder.