James Moger
2013-06-19 724da52635fbcc7c80cd0b7932f8b0d1cff6cb73
commit | author | age
f6b200 1 #
JM 2 # ${project.version}
3 #
4 r17: {
5     title: Gitblit ${project.version} Released
6     id: ${project.version}
7     date: ${project.buildDate}
0f3cb2 8     security:
JM 9     - Raw servlet was insecure. If someone knew the exact repository name and path to a file, the raw blob could be retrieved bypassing security constraints. (issue 198)
f6b200 10     fixes:
JM 11      - Could not reset settings with $ or { characters through Gitblit Manager because they are not properly escaped
ed9d67 12      - Added more error checking to blob page and blame page
dc6ac4 13      - Disable SNI extensions for client SSL connections
08649e 14      - Fixed prettify language extension loading
e14d3e 15      - Fixed index out of bounds exceptions when generating client certificates for a user when the user's table has been filtered
JM 16      - Fixed AddindexedBranch tool when specifying the non-default branch. 
6d19db 17      - Use bash instead of sh in Linux/OSX shell scripts (issue 154)
c14ba7 18      - Fix NPE when getting user's fork without repository list caching (issue 182)
66a8db 19      - Fix internal error on folder history links (issue 192)
9e7041 20      - Fix NPEs when initializing the context on a servlet containers which returns a null contextFolder (issue 199)
a9e6d5 21      - Fixed incorrect icon file name for .doc files (issue 200)
4aeec8 22      - Do not queue emails with no recipients (issue 201)
59f09b 23      - Disable view and blame links for deleted blobs (issue 216)
ea4769 24      - Fixed 1.2.x regression with individually symlinked repositories (issue 217)
ffe9bd 25      - Fixed UTF-8 encoding errors in email notifications (issue 218)
e5c14e 26      - Fixed NPE in 1.2.1 Federation Client (issue 219)
0ac531 27      - Fixed extracting Groovy scripts on Express installs (issue 220)
70a0c7 28      - Ensure Redmine url is properly formatted (issue 223)
1f596c 29      - Use standard ServletRequestWrapper instead of custom wrapper (issue 224)
bca8c5 30      - Switch commit message back to a pre and ensure that it is properly escaped when combined with commit message regex substitution (issue 242)
0078c2 31      - Fixed AddIndexedBranch tool --branch parameter (issue 247)  
978820 32      - Improve NPE handling for hook script enumeration (issue-253)
0078c2 33      - Workaround missing commit information in blame page (JGit bug 374382, issue-254) 
f2c4fa 34      - Ignore orphan ".git" folder in the repositories root folder (issue-256)
f6b200 35
4addb8 36     changes:
9e7041 37      - Improved error logging for servlet containers which provide a null contextFolder (issue 199)
8c9255 38      - Improved the repository url display.  This display now indicates your repository access permission, per-protocol.
342a05 39      - Improve Gerrit change ref decoration in the refs panel (issue 206)
843c42 40       - Disable Gson's pretty printing which has a huge performance gain
JM 41      - Properly set application/json content-type on api calls
1a8eb1 42      - Make days back filter choices a setting
JM 43      - Changed default days back filter setting to 7 days
6c5885 44      - Improved page title
4addb8 45      - Updated Polish translation
2a0933 46      - Updated Japanese translation
4addb8 47      
f6b200 48     additions: 
cedf13 49      - Global and per-repository setting to exclude authors from metrics (issue-251)
ffe737 50      - Added SalesForce.com user service
79d324 51      - Added simple star/unstar function to flag or bookmark interesting repositories
cf17b2 52      - Added Dashboard page which shows a news feed for starred repositories and offers a filterable list of repositories you care about
0eb562 53      - Added a ui for the push log introduced in 1.2.1 (issue-177)
724da5 54      - Added client application menus for Git, SmartGit/Hg, SourceTree, Tower, GitHub for Windows, GitHub for Mac, and SparkleShare
8c9255 55      - Added GO http/https connector thread pool size setting
48d475 56      - Added a server setting to force a particular translation/Locale for all sessions
724da5 57      - Added smart Git Daemon serving.  If enabled, git:// access will be offered for any repository which permits anonymous access.  If the repository permits anonymous cloning, anonymous git:// clone will be permitted while anonmymous git:// pushes will be rejected.
0f47b2 58      - Option to automatically tag branch tips on each push with an incremental revision number
JM 59      - Implemented multiple repository owners
f6b200 60      - Optional periodic LDAP user and team pre-fetching & synchronization
635ef9 61      - Added config setting to use SMTPS
e14d3e 62      - Added option to index all local branches in AddIndexedBranches tool
f6b200 63      - Display name and version in Tomcat Manager
JM 64      - FogBugz post-receive hook script
65      - Chinese translation
0f47b2 66      - Support --baseFolder parameter in Federation Client
70a0c7 67      - Added weblogic.xml to WAR for deployment on WebLogic (issue 199)
d37bce 68      - Support username substitution in web.otherUrls (issue 213)
70a0c7 69      - Option to force client-side basic authentication instead of form-based authentication if web.authenticateViewPages=true (issue 222)
9b5492 70      - Setting to automatically create an user account based on an authenticated user principal from the servlet container (issue-246)
f6b200 71
JM 72     contributors:
70a0c7 73     - Bandarupalli Satyanarayana
6c5885 74     - Chad H.
c14ba7 75     - Christian Aistleitner
843c42 76     - David Ostrovsky
70a0c7 77     - Egbert Teeselink
JM 78     - Hige Maniya
635ef9 79     - Hirotaka Honma
70a0c7 80     - Ikslawek
d9c9fe 81     - Jay Meyer
70a0c7 82     - John Crygier
2a0933 83     - Kensuke Matsuzaki
70a0c7 84     - Laurens Vrijnsen
1e9dda 85     - Lee Grofit
4addb8 86     - Lukasz Jader
70a0c7 87     - Martijn Laan
9e7041 88     - Matthias Bauer
0078c2 89     - Micha�l Pailloncy
70a0c7 90     - Michael Schaefers
9b5492 91     - Oliver Doepner
70a0c7 92     - Philip Boutros
JM 93     - Rafael Cavazin
94     - Ryan Schneider
6d19db 95     - Sakurai Youhei
70a0c7 96     - Sarah Haselbauer
a9e6d5 97     - Slawomir Bochenski
70a0c7 98     - Stardrad Yin
JM 99     - Thomas Pummer
ffe737 100     - William Whittle
c5d052 101     - Yukihiko Sawanobori
724da5 102         - github/akquinet
JM 103         - github/dapengme
ffe9bd 104     
JM 105     dependencyChanges:
843c42 106     - JGit 3.0.0-SNAPSHOT
325310 107     - Iconic font
cf17b2 108     - AngularJS 1.0.7
724da5 109         - FreeMarker 2.3.19
0f47b2 110     
JM 111     settings:
75bca8 112     - { name: 'git.daemonBindInterface', defaultValue: 'localhost' }
bf822e 113     - { name: 'git.daemonPort', defaultValue: 0 }
724da5 114         - { name: 'git.defaultIncrementalPushTagPrefix', defaultValue: 'r' }
JM 115     - { name: 'mail.smtps', defaultValue: 'false' }
9b5492 116     - { name: 'realm.container.autoCreateAccounts', defaultValue: 'false' }
90fe56 117     - { name: 'realm.salesforce.backingUserService', defaultValue: 'users.conf' }
JM 118     - { name: 'realm.salesforce.orgId', defaultValue: 0 }
1a8eb1 119     - { name: 'web.activityDurationChoices', defaultValue: '7 14 28 60 90 180' }
724da5 120     - { name: 'web.allowAppCloneLinks', defaultValue: 'true' }
48d475 121     - { name: 'web.forceDefaultLocale', defaultValue: ' ' }
cedf13 122     - { name: 'web.metricAuthorExclusions', defaultValue: ' ' }
0eb562 123     - { name: 'web.overviewPushCount', defaultValue: 5 }
JM 124     - { name: 'web.pushesPerPage', defaultValue: 10 }
8c9255 125     - { name: 'server.nioThreadPoolSize', defaultValue: 50 }
f6b200 126 }
JM 127
128 #
129 # 1.2.1
130 #
131 r16: {
132     title: Gitblit 1.2.1 Released
133     id: 1.2.1
134     date: 2013-01-15
135     note: ''
136           Because there are now several types of files and folders that must be considered Gitblit data, the default location for data has changed.
137           
138           You will need to move a few files around when upgrading.  Please see the Upgrading section of the <a href="setup.html">setup</a> page for details.
139
140           <b>Express Users</b> make sure to update your web.xml file with the ${baseFolder} values!
141           ''
142     fixes:
143     - Fixed nullpointer on recursively calculating folder sizes when there is a named pipe or symlink in the hierarchy
144     - Added nullchecking when concurrently forking a repository and trying to display the fork network (issue-187)
145     - Fixed bug where permission changes were not visible in the web ui to a logged-in user until the user logged-out and then logged back in again (issue-186)
146     - Fixed nullpointer on creating a repository with mixed case (issue 185)
147     - Include missing model classes in api library (issue-184)
148     - Fixed nullpointer when using *web.allowForking = true* && *git.cacheRepositoryList = false* (issue 182)
149     - Likely fix for commit and commitdiff page failures when a submodule reference changes (issue 178)
150     - Build project models from the repository model cache, when possible, to reduce page load time (issue 172)
151     - Fixed loading of Brazilian Portuguese translation from *nix server
152
153     additions:
154     - ''Fanout PubSub service for self-hosted [Sparkleshare](http://sparkleshare.org) notifications.
155       This service is disabled by default.''
156     - ''Implemented a simple push log based on a hidden, orphan branch refs/gitblit/pushes (issue 177)
157       The push log is not currently visible in the ui, but the data will be collected and it will be exposed to the ui in the next release.''
158     - Support for locally and remotely authenticated accounts in LdapUserService and RedmineUserService (issue 183)
159     - Added Dutch translation
160
161     changes:
162     - ''Gitblit GO and Gitblit WAR are now both configured by `gitblit.properties`. WAR is no longer configured by `web.xml`.
163       However, Express for OpenShift continues to be configured by `web.xml`.''
164     - Support for a *--baseFolder* command-line argument for Gitblit GO and Gitblit Certificate Authority
165     - Support for specifying a *${baseFolder}* parameter in `gitblit.properties` and `web.xml` for several settings
166     - Improve history display of a submodule link
167     - Updated Korean translation
168     - Updated checkstyle definition
169     
170     settings:
171     - { name: fanout.bindInterface, defaultValue: localhost }
172     - { name: fanout.port, defaultValue: 0 }
173     - { name: fanout.useNio, defaultValue: 'true' }
174     - { name: fanout.connectionLimit, defaultValue: 0 }
175
176     contributors:
177     - github/mystygage
178     - github/ds5apn
179     - github/kwoot
180     - github/inaiat
181 }
182
183 #
184 # 1.2.0
185 #
186 r15: {
187     title: Gitblit 1.2.0 Released
188     id: 1.2.0
189     date: 2012-12-31
190     note: ''
191           The permissions model has changed in the 1.2.0 release.
192           If you are updating your server, you must also update any Gitblit Manager and Federation Client installs to 1.2.0 as well.  The data model used by the RPC mechanism has changed slightly for the new permissions infrastructure.
193           ''
194     fixes:
195     - Fixed regression in *isFrozen* (issue 181)
196     - Author metrics can be broken by newlines in email addresses from converted repositories (issue 176)
197     - Set subjectAlternativeName on generated SSL cert if CN is an ip address (issue 170)
198     - Fixed incorrect links on history page for files not in the current/active commit (issue 166)
199     - Empty repository page failed to handle missing repository (issue 160)
200     - Fixed broken ticgit urls (issue 157)
201     - Exclude submodules from zip downloads (issue 151)
202     - Fixed bug where repository ownership was not updated on rename user
203     - Fixed bug in create/rename repository if you explicitly specified the alias for the root group (e.g. main/myrepo) (issue 143)
204     - Wrapped Markdown parser with improved exception handler (issue 142)
205     - Fixed duplicate entries in repository cache (issue 140)
206     - Fixed connection leak in LDAPUserService (issue 139)
207     - Fixed bug in commit page where changes to a submodule threw a null pointer exception (issue 132)
208     - Fixed bug in the diff view for filenames that have non-ASCII characters (issue 128)
209
210     additions:
211     - ''
212       Implemented discrete repository permissions (issue 36)
213       
214         - V (view in web ui, RSS feeds, download zip)
215         - R (clone)
216         - RW (clone and push)
217         - RWC (clone and push with ref creation)
218         - RWD (clone and push with ref creation, deletion)
219         - RW+ (clone and push with ref creation, deletion, rewind)
220         
221       While not as sophisticated as Gitolite, this does give finer access controls.  These permissions fit in cleanly with the existing users.conf and users.properties files.  In Gitblit <= 1.1.0, all your existing user accounts have RW+ access.   If you are upgrading to 1.2.0, the RW+ access is *preserved* and you will have to lower/adjust accordingly.
222       ''
223     - ''Implemented *case-insensitive* regex repository permission matching (issue 36)
224
225       This allows you to specify a permission like `RW:mygroup/.*` to grant push privileges to all repositories within the *mygroup* project/folder.''
226     - Added DELETE, CREATE, and NON-FAST-FORWARD ref change logging
227     - ''Added support for personal repositories.
228       Personal repositories can be created by accounts with the *create* permission and are stored in *git.repositoriesFolder/~username*.  Each user with personal repositories will have a user page, something like the GitHub profile page.  Personal repositories have all the same features as common repositories, except personal repositories can be renamed by their owner.''
229     - ''Added support for server-side forking of a repository to a personal repository (issue 137)
230       In order to fork a repository, the user account must have the *fork* permission **and** the repository must *allow forks*.  The clone inherits the access list of its origin.  i.e. if Team A has clone access to the origin repository, then by default Team A also has clone access to the fork.  This is to facilitate collaboration.  The fork owner may change access to the fork and add/remove users/teams, etc as required <u>however</u> it should be noted that all personal forks will be enumerated in the fork network regardless of access view restrictions.  If you really must have an invisible fork, the clone it locally, create a new repository for your invisible fork, and push it back to Gitblit.''
231     - Added optional *create-on-push* support
232     - Added **experimental** JGit-based garbage collection service.  This service is disabled by default.
233     - ''Added support for X509 client certificate authentication.  (issue 106)
234       You can require all git servlet access be authenticated by a client certificate.  You may also specify the OID fingerprint to use for mapping a certificate to a username.  It should be noted that the user account MUST already exist in Gitblit for this authentication mechanism to work; this mechanism can not be used to automatically create user accounts from a certificate.''
235     - Revised clean install certificate generation to create a Gitblit GO Certificate Authority certificate; an SSL certificate signed by the CA certificate; and to create distinct server key and server trust stores.  <u>The store files have been renamed!</u>
236     - Added support for Gitblit GO to require usage of client certificates to access the entire server.
237     - Added **Gitblit Certificate Authority**, an x509 PKI management tool for Gitblit GO to encourage use of x509 client certificate authentication.
238     - Added web.shortCommitId setting to control length of shortened commit ids
239     - Added alternate compressed download formats: tar.gz, tar.xz, tar.bzip2 (issue 174)
240     - Added simple project pages.  A project is a subfolder off the *git.repositoriesFolder*.
241     - Added support for X-Forwarded-Context for Apache subdomain proxy configurations (issue 135)
242     - Delete branch feature (issue 121)
243     - Added line links to blob view (issue 130)
244     - Added HTML sendmail hook script and Gitblit.sendHtmlMail method
245     - Added RedmineUserService
246     - Support for committer verification.  Requires use of *--no-ff* when merging branches or pull requests.  See setup page for details.
247     - Added Brazilian Portuguese translation
248
249     changes:
250     - Added server setting to specify keystore alias for ssl certificate (issue 98)
251     - Added optional global and per-repository activity page commit contribution throttle to help tame *really* active repositories (issue 173)
252     - Added support for symlinks in tree page and commit page (issue 171)
253     - All access restricted servlets (e.g. DownloadZip, RSS, etc) will try to authenticate using X509 certificates, container principals, cookies, and BASIC headers, in that order.
254     - Added *groovy* and *scala* to *web.prettyPrintExtensions*
255     - Added short commit id column to log and history tables (issue 168)
256     - Teams can now specify the *admin*, *create*, and *fork* roles to simplify user administration
257     - Use https Gravatar urls to avoid browser complaints
258     - Added frm to default pretty print extensions (issue 156)
259     - Expose ReceivePack to Groovy push hooks (issue 125)
260     - Redirect to summary page when refreshing the empty repository page on a repository that is not empty (issue 129)
261     - Emit a warning in the log file if running on a Tomcat-based servlet container which is unfriendly to %2F forward-slash url encoding AND Gitblit is configured to mount parameters with %2F forward-slash url encoding (issue 126)
262     - ''LDAP admin attribute setting is now consistent with LDAP teams setting and admin teams list.
263       If *realm.ldap.maintainTeams==true* **AND** *realm.ldap.admins* is not empty, then User.canAdmin() is controlled by LDAP administrative team membership.  Otherwise, User.canAdmin() is controlled by Gitblit.''
264     - Support servlet container authentication for existing UserModels (issue 68)
265
266     settings:
267     - { name: web.allowForking, defaultValue: 'true' }
268     - { name: git.allowCreateOnPush, defaultValue: 'true' }
269     - { name: git.allowGarbageCollection, defaultValue: 'false' }
270     - { name: git.garbageCollectionHour, defaultValue: 0 }
271     - { name: git.defaultGarbageCollectionThreshold, defaultValue: 500k }
272     - { name: git.defaultGarbageCollectionPeriod, defaultValue: 7 days }
273     - { name: git.requireClientCertificates, defaultValue: 'false' }
274     - { name: git.enforceCertificateValidity, defaultValue: 'true' }
275     - { name: git.certificateUsernameOIDs, defaultValue: CN }
276     - { name: web.shortCommitIdLength, defaultValue: 8 }
277     - { name: web.compressedDownloads, defaultValue: zip gz }
278     - { name: server.requireClientCertificates, defaultValue: 'false' }
279
280     dependencyChanges:
281     - Jetty 7.6.8
282     - JGit 2.2.0.201212191850-r
283     - Groovy 1.8.8
284     - Wicket 1.4.21
285     - Lucene 3.6.1
286     - BouncyCastle 1.47
287     - MarkdownPapers 1.3.2
288     - JCalendar 1.3.2
289     - Commons-Compress 1.4.1
290     - XZ for Java 1.0
291
292     contributors:
293     - github/rafaelcavazin
294     - github/mallowlabs
295     - github/sauthieg
296     - github/ajermakovics
297     - github/kevinanderson1
298     - github/jpyeron
299 }
300
301 #
302 # 1.1.0
303 #
304 r14: {
305     title: Gitblit 1.1.0 Released
306     id: 1.1.0
307     date: 2012-08-25
308     note: If you are updating from an earlier release AND you have indexed branches with the Lucene indexing feature, you need to be aware that this release will completely re-index your repositories.  Please be sure to provide ample heap resources as appropriate for your installation.
309
310     fixes:
311     - Bypass Wicket's inability to handle direct url addressing of a view-restricted, grouped repository for new, unauthenticated sessions (e.g. click link from email or rss feed without having an active Wicket session)
312     - Fixed MailExecutor's failure to cope with mail server connection troubles resulting in 100% CPU usage
313     - Fixed generated urls in Groovy *sendmail* hook script for grouped repositories
314     - Fixed generated urls in RSS feeds for grouped repositories
315     - Fixed nullpointer exception in git servlet security filter (issue 123)
316     - Eliminated an unnecessary repository enumeration call on the root page which should result in faster page loads (issue 103)
317     - Gitblit could not delete a Lucene index in a working copy on index upgrade
318     - Do not index submodule links (issue 119)
319     - Restore original user or team object on failure to update (issue 118)
320     - Fixes to relative path determination in repository search algorithm for symlinks (issue 116)
321     - Fix to GitServlet to allow pushing to symlinked repositories (issue 116)
322     - Repository URL now uses `X-Forwarded-Proto` and `X-Forwarded-Port`, if available, for reverse proxy configurations (issue 115)
323     - Output real RAW content, not simulated RAW content (issue 114)
324     - Fixed Lucene charset encoding bug when reindexing a repository (issue 112)
325     - Fixed search box linking to Lucene page for grouped repository on Tomcat (issue 111)
326     - Fixed null pointer in LdapUserSerivce if account has a null email address (issue 110)
327     - Really fixed failure to update a GO setting from the manager (issue 85)
328
329     additions:
330     - Identified repository list is now cached by default to reduce disk io and to improve performance (issue 103)
331     - Preliminary bare repository submodule support
332     - ''
333       *git.submoduleUrlPatterns* is a space-delimited list of regular expressions for extracting a repository name from a submodule url.
334       For example, `git.submoduleUrlPatterns = .*?://github.com/(.*)` would extract *gitblit/gitblit.git* from *git://github.git/gitblit/gitblit.git*
335       **Note:** You may not need this control to work with submodules, but it is there if you do.
336         - If there are no matches from *git.submoduleUrlPatterns* then the repository name is assumed to be whatever comes after the last `/` character *(e.g. gitblit.git)*
337         - Gitblit will try to locate this repository relative to the current repository *(e.g. myfolder/myrepo.git, myfolder/mysubmodule.git)* and then at the root level *(mysubmodule.git)* if that fails.
338         - Submodule references in a working copy will be properly identified as gitlinks, but Gitblit will not traverse into the working copy submodule repository.
339       ''
340     - ''
341       Added a repository setting to control authorization as AUTHENTICATED or NAMED. (issue 117)
342
343       NAMED is the original behavior for authorizing against a list of permitted users or permitted teams.
344       AUTHENTICATED allows restricted access for any authenticated user.  This is a looser authorization control.
345       ''
346     - Added default authorization control setting (AUTHENTICATED or NAMED)
347     - Added setting to control how deep Gitblit will recurse into *git.repositoriesFolder* looking for repositories (issue 103)
348     - Added setting to specify regex exclusions for repositories (issue 103)
349     - Blob page now supports displaying images (issue 6)
350     - Non-image binary files can now be downloaded using the RAW link
351     - Support StartTLS in LdapUserService (issue 122)
352     - Added Korean translation
353
354     changes:
355     - Line breaks inserted for readability in raw Markdown content display in the event of a parsing/transformation error.  An error message is now displayed prepended to the raw content.
356     - Improve UTF-8 reading for Markdown files
357     - Updated Polish translation
358     - Updated Japanese translation
359     - Updated Spanish translation
360     
361     settings:
362     - { name: git.cacheRepositoryList, defaultValue: 'true' }
363     - { name: git.submoduleUrlPatterns, defaultValue: * }
364     - { name: git.searchExclusions, defaultValue: * }
365     - { name: git.searchRecursionDepth, defaultValue: -1 }
366     - { name: git.defaultAuthorizationControl, defaultValue: NAMED }
367
368     contributors:
369     - Steffen Gebert
370 }
371
372 #
373 # 1.0.0
374 #
375 r13: {
376     title: Gitblit 1.0.0 Released
377     id: 1.0.0
378     date: 2012-07-14
379
380     fixes:
381     - Fixed bug in Lucene search where old/stale blobs were never properly deleted during incremental updates.  This resulted in duplicate blob entries in the index.
382     - Fixed intermittent bug in identifying line numbers in Lucene search (issue 105)
383     - Adjust repository identification algorithm to handle the scenario where a repository name collides with a group/folder name (e.g. foo.git and foo/bar.git) (issue 104)
384     - Fixed bug where a repository set as *authenticated push* did not have anonymous clone access (issue 96)
385     - Fixed bug in Basic authentication if passwords had a colon
386     - Fixed bug where the Gitblit Manager could not update a setting that was not referenced in reference.properties (issue 85)
387
388     changes:
389     - ''**Updated Lucene index version which will force a rebuild of ALL your Lucene indexes**
390       Make sure to properly set *web.blobEncodings* before starting Gitblit if you are updating!  (issue 97)''
391     - Changed default layout for web ui from Fixed-Width layout to Responsive layout (issue 101)
392     - ''IUserService interface has changed to better accomodate custom authentication and/or custom authorization<
393       The default `users.conf` now supports persisting display names and email addresses.''
394     - Updated Japanese translation
395
396     additions:
397     - Added setting to allow specification of a robots.txt file (issue 99)
398     - ''Added setting to control Responsive layout or Fixed-Width layout (issue 101)
399       Responsive layout is now the default.  This layout gracefully scales the web ui from a desktop layout to a mobile layout by hiding page components.  It is easy to try, just resize your browser or point your Android/iOS device to the url of your Gitblit install.''
400     - Added setting to control charsets for blob string decoding.  Default encodings are UTF-8, ISO-8859-1, and the server default charset. (issue 97)      
401     - ''Exposed JGit internal configuration settings in gitblit.properties/web.xml (issue 93)
402       Review your `gitblit.properties` or `web.xml` for detailed explanations of these settings.''
403     - Added default access restriction.  Applies to new repositories and repositories that have not been configured with Gitblit. (issue 88)
404     - Added Ivy 2.2.0 dependency which enables Groovy Grapes, a mechanism to resolve and retrieve library dependencies from a Maven 2 repository within a Groovy push hook script
405     - ''Added setting to control Groovy Grape root folder (location where resolved dependencies are stored)
406       [Grape](http://groovy.codehaus.org/Grape) allows you to add Maven dependencies to your pre-/post-receive hook script classpath.''
407     - Added LDAP User Service with many new *realm.ldap* keys
408     - ''Added support for custom repository properties for Groovy hooks
409       Custom repository properties complement hook scripts by providing text field prompts in the web ui and the Gitblit Manager for the defined properties.  This allows your push hooks to be parameterized.''
410     - Added script to facilitate proxy environment setup on Linux
411     - Added Polish translation
412     - Added Spanish translation
413
414     settings:
415     - { name: groovy.grapeFolder, defaultValue: groovy/grape }
416     - { name: web.robots.txt, defaultValue: }
417     - { name: web.useResponsiveLayout, defaultValue: 'true' }
418     - { name: web.blobEncodings, defaultValue: UTF-8 ISO-8859-1 }
419     - { name: git.defaultAccessRestriction, defaultValue: NONE }
420     - { name: git.packedGitWindowSize, defaultValue: 8k }
421     - { name: git.packedGitLimit, defaultValue: 10m }
422     - { name: git.deltaBaseCacheLimit, defaultValue: 10m }
423     - { name: git.packedGitOpenFiles, defaultValue: 128 }
424     - { name: git.streamFileThreshold, defaultValue: 50m }
425     - { name: git.packedGitMmap, defaultValue: 'false' }
426
427     dependencyChanges:
428     - Bootstrap 2.0.4
429     - JGit 2.0.0.201206130900-r
430     - Groovy 1.8.6
431     - Gson 1.7.2
432     - Log4J 1.2.17
433     - SLF4J 1.6.6
434     - Apache Commons Daemon 1.0.10
435     - Ivy 2.2.0
436
437     contributors:
438     - Eduardo Guervos Narvaez
439     - Lukasz Jader
440     - github/mragab
441     - github/jcrygier
442     - github/zakki
443     - github/peterloron
444 }
445
446 #
447 # 0.9.3
448 #
449 r12: {
450     title: Gitblit 0.9.3 Released
451     id: 0.9.3
452     date: 2012-04-11
453
454     fixes:
455     - Fixed bug where you could not remove all selections from a RepositoryModel list (permitted users, permitted teams, hook scripts, federation sets, etc) (issue 81)
456     - Automatically set *java.awt.headless=true* for Gitblit GO
457 }
458
459 #
460 # 0.9.2
461 #
462 r11: {
463     title: Gitblit 0.9.2 Released
464     id: 0.9.2
465     date: 2012-04-04
466     
467     changes:
468     - Added *clientLogger* bound variable to Groovy hook mechanism to allow custom info and error messages to be returned to the client
469
470    fixes:
471     - Fixed absolute path/canonical path discrepancy between Gitblit and JGit regarding use of symlinks (issue 78)
472     - Fixed row layout on activity page (issue 79)
473     - Fixed Centos service script
474     - Fixed EditRepositoryPage for IE8; missing save button (issue 80)
475
476     contributors:
477     - github/jonnybbb
478     - github/mohamedmansour
479     - github/jcrygier
480 }
481
482 #
483 # 0.9.1
484 #
485 r10: {
486     title: Gitblit 0.9.1 Released
487     id: 0.9.1
488     date: 2012-03-27
489
490     fixes:
491     - Lucene folder was stored in working copy instead of in .git folder
492 }
493
494 #
495 # 0.9.0
496 #
497 r9: {
498     title: Gitblit 0.9.0 Released
499     id: 0.9.0
500     date: 2012-03-27
501
502     security:
503     - Fixed session fixation vulnerability where the session identifier was not reset during the login process (issue 62)
504
505     changes:
506     - Reject pushes to a repository with a working copy (i.e. non-bare repository) (issue-49)
507     - Changed default web.datetimestampLongFormat from *EEEE, MMMM d, yyyy h:mm a z* to *EEEE, MMMM d, yyyy HH:mm Z* (issue 50)
508     - Expanded commit age coloring from 2 days to 30 days (issue 57)
509
510     additions:
511     - ''Added optional Lucene branch indexing (issue 16)
512       Repository branches may be optionally indexed by Lucene for improved searching.  To use this feature you must specify which branches to index within the *Edit Repository* page; _no repositories are automatically indexed_.  Gitblit will build or incrementally update enrolled repositories on a 2 minute cycle. (i.e you will have to wait 2-3 minutes after respecifying indexed branches or pushing new commits before Gitblit will build/update the repository Lucene index.)
513       If a repository has Lucene-indexed branches the *search* form on the repository pages will redirect to the root-level Lucene search page and only the content of those branches can be searched.<br/>
514       If the repository does not specify any indexed branches then repository commit-traversal search is used.
515
516       **Note:** Initial indexing of an existing repository can be memory-exhaustive. Be sure to provide your Gitblit server adequate heap space to index your repositories (e.g. -Xmx1024M).<br/>
517       See the [setup](setup.html) page for additional details.''
518     - Allow specifying timezone to use for Gitblit which is independent of both the JVM and the system timezone (issue 54)
519     - Added a built-in AJP connector for integrating Gitblit GO into an Apache mod_proxy setup (issue 59)
520     - ''On the Repositories page show a bang *!* character in the color swatch of a repository with a working copy (issue 49)
521       Push requests to these repositories will be rejected.''
522     - On all non-bare Repository pages show *WORKING COPY* in the upper right corner (issue 49)
523     - New setting to prevent display/serving non-bare repositories
524     - Added *protect-refs.groovy*
525     - Allow setting default branch (relinking HEAD) to a branch or a tag
526     - Added Ubuntu service init script (issue 72)
527     - Added partial Japanese translation
528
529     fixes:
530     - Ensure that Welcome message is parsed using UTF-8 encoding (issue 74)
531     - Activity page chart layout broken by Google (issue 73)
532     - Uppercase repositories not selectable in edit palettes (issue 71)
533     - Not all git notes were properly displayed on the commit page (issue 70)
534     - Activity page now displays all local branches (issue 65)
535     - Fixed (harmless) nullpointer on pushing to an empty repository (issue 69)
536     - Fixed possible nullpointer from the servlet container on startup (issue 67)
537     - Fixed UTF-8 encoding bug on diff page (issue 66)
538     - Fixed timezone bugs on the activity page (issue 54)
539     - Prevent add/edit team with no selected repositories (issue 56)
540     - Disallow browser autocomplete on add/edit user/team/repository pages
541     - Fixed username case-sensitivity issues (issue 43)
542     - Disregard searching a subfolder if Gitblit does not have filesystem permissions (issue 51)
543
544     settings:
545     - { name: web.allowLuceneIndexing, defaultValue: 'true' }
546     - { name: web.luceneIgnoreExtensions, defaultValue: 7z arc arj bin bmp dll doc docx exe gif gz jar jpg lib lzh odg odf odt pdf ppt png so swf xcf xls xlsx zip }
547     - { name: web.timezone, defaultValue: }
548     - { name: server.ajpPort, defaultValue: 0 }
549     - { name: server.ajpBindInterface, defaultValue: localhost }
550     - { name: git.onlyAccessBareRepositories, defaultValue: 'false' }
551
552     dependencyChanges:
553     - Bootstrap 2.0.2
554     - MarkdownPapers 1.2.7
555     - JGit 1.3.0.201202151440-r
556     - Wicket 1.4.20
557
558     contributors:
559     - github/lemval
560     - github/zakki
561     - github/plm
562 }
563
564 #
565 # 0.8.2
566 #
567 r8: {
568     title: Gitblit 0.8.2 Released
569     id: 0.8.2
570     date: 2012-01-13
571
572     fixes:
573     - Fixed bug when upgrading from users.properties to users.conf (issue 41)
574 }
575
576 #
577 # 0.8.1
578 #
579 r7: {
580     title: Gitblit 0.8.1 Released
581     id: 0.8.1
582     date: 2012-01-11
583
584     fixes:
585     - Include missing icon resource for the manager (issue 40)
586     - Fixed sendmail.groovy message content with incorrect tag/branch labels
587 }
588
589 #
590 # 0.8.0
591 #
592 r6: {
593     title: Gitblit 0.8.0 Released
594     id: 0.8.0
595     date: 2012-01-11
596
597     additions:
598     - ''Platform-independent, Groovy push hook script mechanism.
599       Hook scripts can be set per-repository, per-team, or globally for all repositories.''
600     - ''*sendmail.groovy* for optional email notifications on push.
601       You must properly configure your SMTP server settings in `gitblit.properties` or `web.xml` to use *sendmail.groovy*.''
602     - New global key for mailing lists.  This is used in conjunction with the *sendmail.groovy* hook script.  All repositories that use the *sendmail.groovy* script will include these addresses in the notification process.  Please see the Setup page for more details about configuring sendmail.
603     - *com.gitblit.GitblitUserService*.  This is a wrapper object for the built-in user service implementations.  For those wanting to only implement custom authentication it is recommended to subclass GitblitUserService and override the appropriate methods.  Going forward, this will help insulate custom authentication from new IUserService API and/or changes in model classes.
604     - ''New default user service implementation: *com.gitblit.ConfigUserService* (`users.conf`)
605       This user service implementation allows for serialization and deserialization of more sophisticated Gitblit User objects without requiring the encoding trickery now present in FileUserService (users.properties).  This will open the door for more advanced Gitblit features.
606       For those upgrading from an earlier Gitblit version, a `users.conf` file will automatically be created for you from your existing `users.properties` file on your first launch of Gitblit <u>however</u> you will have to manually set *realm.userService=users.conf* to switch to the new user service.
607       The original `users.properties` file and the corresponding implementation are **deprecated**.''
608     - Teams for specifying user-repository access in bulk.  Teams may also specify mailing lists addresses and pre- & post- receive hook scripts.
609     - Gravatar integration
610     - Activity page for aggregated repository activity.  This is a timeline of commit activity over the last N days for one or more repositories.
611     - *Filters* menu for the Repositories page and Activity page.  You can filter by federation set, team, and simple custom regular expressions.  Custom expressions can be stored in `gitblit.properties` or `web.xml` or directly defined in your url (issue 27)
612     - Flash-based 1-step *copy to clipboard* of the primary repository url based on Clippy
613     - JavaScript-based 3-step (click, ctrl+c, enter) *copy to clipboard* of the primary repository url in the event that you do not want to use Flash on your installation
614     - Empty repositories now link to an *empty repository* page which gives some direction to the user for the next step in using Gitblit.  This page displays the primary push/clone url of the repository and gives sample syntax for the git command-line client. (issue 31)
615     - Repositories with a *gh-pages* branch will now have a *pages* link which will serve the content of this branch.  All resource requests are against the repository, Gitblit does not checkout/export this branch to a temporary filesystem.  Jekyll templating is not supported.
616     - Gitblit Express bundle to get started running Gitblit on RedHat OpenShift cloud <span class="label label-warning">BETA</span>
617
618     changes:
619     - Dropped display of trailing .git from repository names
620     - ''Gitblit GO is now monolithic like the WAR build. (issue 30)
621       This change helps adoption of GO in environments without an internet connection or with a restricted connection.''
622     - Unit testing framework has been migrated to JUnit4 syntax and the test suite has been redesigned to run all unit tests, including rpc, federation, and git push/clone tests
623
624     fixes:
625     - Several a bugs in FileUserService related to cleaning up old repository permissions on a rename or delete
626     - Renaming a repository into a new subfolder failed (issue 33)
627
628     settings:
629     - { name: groovy.scriptsFolder, defaultValue: groovy }
630     - { name: groovy.preReceiveScripts, defaultValue: }
631     - { name: groovy.postReceiveScripts, defaultValue: }
632     - { name: mail.mailingLists, defaultValue: }
633     - { name: realm.userService, defaultValue: users.conf }
634     - { name: web.allowGravatar, defaultValue: 'true' }
635     - { name: web.activityDuration, defaultValue: 14 }
636     - { name: web.timeFormat, defaultValue: HH:mm }
637     - { name: web.datestampLongFormat, defaultValue: "EEEE, MMMM d, yyyy" }
638     - { name: web.customFilters, defaultValue: }
639     - { name: web.allowFlashCopyToClipboard, defaultValue: 'true' }
640
641     dependencyChanges:
642     - JGit 1.2.0
643     - Groovy 1.8.5
644     - Clippy
645 }
646
647 #
648 # 0.7.0
649 #
650 r5: {
651     title: Gitblit 0.7.0 Released
652     id: 0.7.0
653     date: 2011-11-11
654
655     security:
656     - fixed security hole when cloning clone-restricted repository with TortoiseGit (issue 28)
657
658     fixes:
659     - ''federation protocol timestamps.  dates are now serialized to the [iso8601](http://en.wikipedia.org/wiki/ISO_8601) standard.
660       **This breaks 0.6.0 federation clients/servers.**''
661     - collision on rename for repositories and users
662     - Gitblit can now browse the Linux kernel repository (issue 25)
663     - Gitblit now runs on Servlet 3.0 webservers (e.g. Tomcat 7, Jetty 8) (issue 23)
664     - Set the RSS content type of syndication feeds for Firefox 4 (issue 22)
665     - RSS feeds are now properly encoded to UTF-8
666     - RSS feeds now properly generate parameterized links if *web.mountParameters=false*
667     - Null pointer exception if did not set federation strategy (issue 20)
668     - Gitblit GO allows SSL renegotiation if running on Java 1.6.0_22 or later
669         
670     changes:
671     - updated ui with Twitter Bootstrap CSS toolkit
672     - repositories list performance by caching repository sizes (issue 27)
673     - summary page performance by caching metric calculations (issue 25)
674     
675     additions:
676     - authenticated JSON RPC mechanism
677     - Gitblit API RSS/JSON RPC library
678     - Gitblit Manager (Java/Swing Application) for remote administration of a Gitblit server.
679     - per-repository setting to skip size calculation (faster repositories page loading)
680     - per-repository setting to skip summary metrics calculation (faster summary page loading)
681     - IUserService.setup(IStoredSettings) for custom user service implementations
682     - setting to control Gitblit GO context path for proxy setups
683     - *combined-md5* password storage option which stores the hash of username+password as the password
684     - repository owners are automatically granted access for git, feeds, and zip downloads without explicitly selecting them
685     - RSS feeds now include regex substitutions on commit messages for bug trackers, etc
686     
687     settings:
688     - { name: web.loginMessage, defaultValue: gitblit }
689     - { name: web.enableRpcServlet, defaultValue: 'true' }
690     - { name: web.enableRpcManagement, defaultValue: 'false' }
691     - { name: web.enableRpcAdministration, defaultValue: 'false' }
692     - { name: server.contextPath, defaultValue: / }
693     
694     dependencyChanges:
695     - MarkdownPapers 1.2.5
696     - Wicket 1.4.19
697
698     contributors:
699     - github/dadalar
700     - github/alyandon
701     - github/trygvis
702 }
703
704 #
705 # 0.6.0
706 #
707 r4: {
708     title: Gitblit 0.6.0 Released
709     id: 0.6.0
710     date: 2011-09-27
711
712     fixes:
713     - syndication urls for WAR deployments
714     - authentication for zip downloads
715
716     additions:
717     - federation feature to allow gitblit instances (or gitblit federation clients) to pull repositories and, optionally, settings and accounts from other gitblit instances.  This is something like [svn-sync](http://svnbook.red-bean.com/en/1.5/svn.ref.svnsync.html) for gitblit.
718     - user role *#notfederated* to prevent a user account from being pulled by a federated Gitblit instance
719
720     settings:
721     - { name: federation.name, defaultValue: }
722     - { name: federation.passphrase, defaultValue: }
723     - { name: federation.allowProposals, defaultValue: 'false' }
724     - { name: federation.proposalsFolder, defaultValue: proposals }
725     - { name: federation.defaultFrequency, defaultValue: 60 mins }
726     - { name: federation.sets, defaultValue: }
727     - { name: "mail.*", defaultValue: }
728         
729     dependencyChanges:
730     - MarkdownPapers 1.1.1
731     - Wicket 1.4.18
732     - JGit 1.1.0
733     - google-gson
734     - javamail
735 }
736
737 #
738 # 0.5.2
739 #
740 r3: {
741     title: Gitblit 0.5.2 Released
742     id: 0.5.2
743     date: 2011-07-27
744
745     fixes:
746     - active repositories with a HEAD that pointed to an empty branch caused internal errors (issue 14)
747     - bare-cloned repositories were listed as (empty) and were not clickable (issue 13)
748     - default port for Gitblit GO is now 8443 to be more linux/os x friendly (issue 12)
749     - repositories can now be reliably deleted and renamed (issue 10)
750     - users can now change their passwords (issue 1)
751     - always show root repository group first, i.e. do not sort root group with other groups
752     - tone-down repository group header color
753     
754     additions:
755     - optionally display repository on-disk size on repositories page
756     - forward-slashes ('/', %2F) can be encoded using a custom character to workaround some servlet container default security measures for proxy servers
757     
758     settings:
759     - { name: web.showRepositorySizes, defaultValue: 'true' }
760     - { name: web.forwardSlashCharacter, defaultValue: / }
761     
762     dependencyChanges:
763     - MarkdownPapers 1.1.0
764     - Jetty 7.4.3
765 }
766
767 #
768 # 0.5.1
769 #
770 r2: {
771     title: Gitblit 0.5.1 Released
772     id: 0.5.1
773     date: 2011-06-28
774
775     changes:
776     - clarified SSL certificate generation and configuration for both server-side and client-side
777     - added some more troubleshooting information to documentation
778     - replaced JavaService with Apache Commons Daemon
779 }
780
781 #
782 # 0.5.0
783 #
784 r1: {
785     title: Gitblit 0.5.0 Released
786     id: 0.5.0
787     date: 2011-06-26
788     text: initial release
789 }
790
791 snapshot: &r17
792 release: &r16
793 releases: &r[1..16]