James Moger
2014-06-12 b1dad726772a277924ff7ced0e26dc443962edcf
commit | author | age
37dc9d 1 #
ec8bd6 2 # ${project.version} release
JM 3 #
4 r24: {
5     title: ${project.name} ${project.version} released
6     id: ${project.version}
7     date: ${project.buildDate}
8     note: ~
9     html: ~
10     text: ~
11     security: ~
12     fixes: ~
13     changes: ~
14     additions: ~
15     dependencyChanges: ~
16     contributors: ~
17 }
18
19 #
8db2b5 20 # 1.5.1 release
1fbc2c 21 #
JM 22 r23: {
8db2b5 23     title: Gitblit 1.5.1 released
JM 24     id: 1.5.1
25     date: 2014-05-07
1fbc2c 26     note: ~
JM 27     html: ~
28     text: ~
29     security: ~
ddaed9 30     fixes:
JM 31     - Fix subdirectory links in pages servlet (issue-411)
a1e346 32     - Fix subdirectory navigation in pages servlet (issue-412)
039686 33     - Fix bug in adding invalid or empty SSH keys (ticket-50)
a8100b 34     - Fix forcing default locale to en or LANG_CC for web ui (ticket-51)
16ef06 35     - Fix inconsistency with repository ownership permission checking (ticket-52)
JM 36     - Prevent submission from New|Edit ticket page with empty titles (ticket-53)
ce07c4 37     - Ensure the repository model ref list is refreshed on ref creation or deletion (ticket-54)
4a2752 38     - Fix case-sensitivity error in determining fork network (issue-420, ticket-62)
b016de 39     - Fix transport determination for SSH urls served on port 22 (issue-421, ticket-63)
e22185 40     changes:
JM 41     - improve French translation (pr-176)
67278f 42     - simplify current plugin release detection and ignore the currentRelease registry field 
a341a5 43     additions:
JM 44     - added TortoiseGit client app menu (pr-182)
646133 45     dependencyChanges:
JM 46     - update to Apache MINA/SSHD 0.11.0 (issue-410)
47     contributors:
48     - James Moger
e22185 49     - Julien Kirch
646133 50     - Ralph Hoffman
ddaed9 51     - Olivier Rouits
039686 52     - Owen Nelson
55dc95 53     - Alexander Zabluda
a341a5 54     - Philipp Beckmann
b016de 55     - Jakob Boysen
1fbc2c 56 }
JM 57
58 #
e2a915 59 # 1.5.0 release
5754cd 60 #
JM 61 r22: {
e2a915 62     title: Gitblit 1.5.0 released
JM 63     id: 1.5.0
64     date: 2014-04-17
cff7cc 65     note: Gitblit now requires Java 7 for build & runtime.
5754cd 66     html: ~
a57d0c 67     text: ''
JM 68           MAJOR Release.
69
70           * Integrated SSH daemon based on Apache Mina/SSHD and Gerrit
71           * Basic plugin management framework and plugin registry, limited extension points
72           * Replace GoogleCharts with a self-hosted copy of the flotr2 charting library
73           * Move to Java 7, some dependencies require this
74           * Move to Jetty 9, dropped AJP feature because it was removed upstream
75           ''
5754cd 76     security: ~
fcaeaa 77     fixes:
478ba8 78     - Repository mailing lists could not be reset from the Edit Repository page (issue-399)
4263c2 79     - Fix intermittent NPE in determining commit date in RefModel (issue-401)
ee4ef4 80     - Fix closing ticket on push by parsing commit messages for closes|fixes (issue-404)
f254ee 81     - Fix diffstat display for a ticket with a pending submodule change (issue-407)
fcaeaa 82     - Ensure the Lucene ticket index is updated on repository deletion.
4d537b 83     - Fixed failure to properly determine hasTicket in RedisTicketService
f254ee 84     - Fixed handling of pushing ticket branch deletions
e4b0ae 85     changes:
679a44 86     - Switch from GoogleCharts to self-hosted flotr2 charts (issue-283, ticket-43, pr-166)
eb9318 87     - Specify the --dailyLogFile option for the Ubuntu and CentOS service scripts (issue-348)
ef4c45 88     - Improve logging for missing LDAP uid attribute when synchronizing (issue-394)
beb021 89     - The ticket close-on-push commit message regular expression is now configurable by a setting (issue-404)
7febf5 90     - Redirect to summary page on edit repository (issue-405)
eb9318 91     - Option to allow LDAP users to directly authenticate without performing LDAP searches (pr-162)
50380b 92     - Replace JCommander with args4j to be consistent with other tools (ticket-28)
e9872c 93     - Sort repository urls by descending permissions and by transport security within equal permissions
9ef027 94     - Move to Java 7 & updated to Jetty 9.1.4
JM 95     - dropped AJP support because it has been removed from upstream Jetty
96     - dropped settings: server.useNio, server.ajpPort, server.ajpBindInterface
97     - dropped GO parameters: --ajpPort, --useNio
21be4b 98     additions:
bfa998 99     - Added an SSH daemon with public key authentication (issue-369, ticket-6)
JM 100     - Added beginnings of a plugin framework for extending Gitblit (issue-381, ticket-23)
50380b 101     - Added a French translation (pr-163)
e9872c 102     - Added a setting to control what transports may be used for pushes
7baf2e 103     - Expose JGit 3.x receive pack settings (issue-408)
50380b 104     dependencyChanges:
cff7cc 105     - Java 7
9ef027 106     - Jetty 9.1.4
50380b 107     - args4j 2.0.26
a0cefe 108     - JGit 3.3.1
8ec063 109     - Mina SSHD 0.10.1
2d73a0 110     - pf4j 0.8.0
a4f7cc 111     - SLF4J 1.7.5
21be4b 112     contributors:
50380b 113     - James Moger
JM 114     - David Ostrovsky
21be4b 115     - Johann Ollivier-Lapeyre
e4b0ae 116     - Jeremie Brebec
679a44 117     - Tim Ryan
70aece 118     - Decebal Suiu
2d73a0 119     - Eric Myrhe
84f435 120     - Kevin Walter
e4b0ae 121     settings:
J 122     - { name: 'realm.ldap.bindpattern', defaultValue: ' ' }
beb021 123     - { name: 'tickets.closeOnPushCommitMessageRegex', defaultValue: '(?:fixes|closes)[\\s-]+#?(\\d+)' }
e9872c 124     - { name: 'git.acceptedPushTransports', defaultValue: ' ' }
7baf2e 125     - { name: 'git.checkReceivedObjects', defaultValue: 'true' }
JM 126     - { name: 'git.checkReferencedObjectsAreReachable', defaultValue: 'true' }
127     - { name: 'git.maxObjectSizeLimit', defaultValue: '0' }
128     - { name: 'git.maxPackSizeLimit', defaultValue: '-1' }
bfa998 129     - { name: 'git.sshPort', defaultValue: '29418' }
JM 130     - { name: 'git.sshBindInterface', defaultValue: ' ' }
131     - { name: 'git.sshKeysManager', defaultValue: 'com.gitblit.transport.ssh.FileKeyManager' }
132     - { name: 'git.sshKeysFolder', defaultValue: '${baseFolder}/ssh' }
133     - { name: 'git.sshBackend', defaultValue: 'NIO2' }
134     - { name: 'git.sshCommandStartThreads', defaultValue: '2' }
135     - { name: 'plugins.folder', defaultValue: '${baseFolder}/plugins' }
a57d0c 136     - { name: 'plugins.registry', defaultValue: 'http://plugins.gitblit.com/plugins.json' }
5754cd 137 }
JM 138
139 #
593a6f 140 # 1.4.1 release
19b98b 141 #
JM 142 r21: {
593a6f 143     title: Gitblit 1.4.1 released
JM 144     id: 1.4.1
145     date: 2014-03-18
af2c4a 146     note: "The default access restriction has been elevated from NONE to PUSH and anonymous push access has been disabled by default."
19b98b 147     html: ~
af2c4a 148     text: ''
JM 149           !! IMPORTANT BUG FIX FOR EXTERNAL AUTHENTICATION (1.4.1) !!
150           
151           This is a MAJOR release (1.4.0).
152           
153           The entire core has been refactored to be more modular.  Authentication providers have all been refactored to be simpler.  Both of these were precursor requirements for landing the Tickets feature -- issue tracker & branch-based pull requests.
154           
155           Markup rendering has been improved and expanded to several additional formats.  A repository mirroring service  has been added to allow you to automatically track public repositories.  Commit pages now indicate diffstat information and many bug fixes and smaller features have been introduced.
156           
157           The groundwork has also been laid for SSH support which will be in the focal point for the next major release (ticket-6).
158           
159           Due to the enormity of these changes, please make a backup copy of users.conf before updating.''
160     security:
161     - Fix major authentication security hole when using external authentication providers (issue-387, ticket-35)
3be8f9 162     fixes:
af2c4a 163     - Fixed incorrect branch ref in Ticket page for symlinks (issue-383, ticket-32)
JM 164     - Fix NPE in FileTicketService (issue-386, ticket-34)
165     - Watch list push parameters were now always honored (ticket-30)
166     - Watch list push parameters were not always validated (ticket-29)
167     - Truncated tag messages in the tag panel did not have proper tooltips (ticket-31)
168     - Fix merging GO runtime settings with command-line override settings (ticket-33)
169     - Fix ticket page IOBE on Ticket page when Gitblit is not serving repositories (ticket-27)
170     - Exclude ticket branches when forking a repository (ticket-26)
171     - Workaround pegdown bug and improve relative image path processing (ticket-24)
3be8f9 172     - Disable Ticket review functions in read-only repositories (mirror, frozen, etc)
JM 173     - Fix incorrect git fetch instructions in Ticket email notifications
174     - Fix Ticket email notification recipients to include repository owners
175     - Fix Ticket propose instructions to branch from origin/{integrationBranch}
af2c4a 176     changes:
JM 177     - Add closed status for milestones and abandoned status for tickets (ticket-25)
19b98b 178     additions: ~
JM 179     dependencyChanges: ~
3be8f9 180     contributors:
JM 181     - James Moger
182     - David Ostrovsky
183     - Liyu Wang
19b98b 184 }
JM 185
186 #
6196cb 187 # 1.4.0 release
6b80a2 188 #
JM 189 r20: {
6196cb 190     title: Gitblit 1.4.0 released
JM 191     id: 1.4.0
192     date: 2014-03-09
d02011 193     note: "The default access restriction has been elevated from NONE to PUSH and anonymous push access has been disabled by default."
6b80a2 194     html: ~
d02011 195     text: ''
cb7e37 196           This is a MAJOR release.
d02011 197           
cb7e37 198           The entire core has been refactored to be more modular.  Authentication providers have all been refactored to be simpler.  Both of these were precursor requirements for landing the Tickets feature -- issue tracker & branch-based pull requests.
JM 199           
200           Markup rendering has been improved and expanded to several additional formats.  A repository mirroring service  has been added to allow you to automatically track public repositories.  Commit pages now indicate diffstat information and many bug fixes and smaller features have been introduced.
201           
202           The groundwork has also been laid for SSH support which will be in the focal point for the next major release (ticket-6).
203           
204           Due to the enormity of these changes, please make a backup copy of users.conf before updating.''
7ab32b 205     security:
d02011 206     - issue-361: Cookies were not reset on administrative password change of a user account. This allowed accounts with changed passwords to continue authenticating. Cookies are now reset on password changes, they are validated on each page request, AND they will now expire 7 days after generation.
bb6b14 207     fixes:
5131d6 208     - Fixed incorrect tagger attribution in the dashboard (issue-276)
2a8ea0 209     - Fixed support for implied SSH urls in web.otherUrls (issue-311)
ba2f9a 210     - Fixed injection of unnecessary explicit CLONE permissions for a fork when users or teams already had implied regex permissions (issue-320)
237fae 211     - Bind LDAP connection after establishing TLS initialization (issue-343)
67389b 212     - Fixed NPE when attempting to add a permission without a registrant (issue-344)
381137 213     - Invalidate all cached repository data on "clear cache" (issue-346)
09bcb2 214     - Fix chart failures when an apostrophe is in a user display name (issue-350, pr-128)
b23b67 215     - Fix exception in create repository when not selecting a garbage collection period (issue-366)
9fcd4f 216     - Stop setting admin permission based on undocumented Redmine REST API behavior (issue-368)
eb0f7e 217     - Fix compage page failure when a submodule is changed in the commit range (issue-375)
158242 218     - Fix support url decoding with non-ascii characters (pr-136)
bb6b14 219     - Fix potential NPE on removing uncached repository from cache
557a1f 220     - Ignore the default contents of .git/description file
e19089 221     - Fix error on generating activity page when there is no activity
9996f7 222     - Fix raw page content type of binaries when running behind a reverse proxy
4fb2c0 223     - Fix author search links from compare pages
bb6b14 224     changes:
d02011 225     - Gitblit now rejects pushes to identified mirror repositories (issue-5)
bb6b14 226     - Personal repository prefix (~) is now configurable (issue-265)
04a985 227     - Refactored user services and separated authentication into providers (issue-281)
4f0f65 228     - Reversed line links in blob view (issue-309)
cbe684 229     - Dashboard and Activity pages now obey the web.generateActivityGraph setting (issue-310)
7535eb 230     - Do not log passwords on failed authentication attempts (issue-316)
6659fa 231     - LDAP synchronization is now scheduled rather than on-demand (issue-336)
37d5b7 232     - Show displayname and username in palettes (issue-364)
bb6b14 233     - Updated default binary and Lucene ignore extensions
06718b 234     - Change the WAR baseFolder context parameter to a JNDI env-entry to improve enterprise deployments
b4f946 235     - Removed internal Gitblit ref exclusions in the upload pack
90d5e0 236     - Removed "show readme" setting in favor of automatic detection
d02011 237     - README files are not shown on the summary page by default, this can be restored with web.summaryShowReadme
c44dd0 238     - Support plain text, markdown, confluence, mediawiki, textile, tracwiki, or twiki "readme" files
ab1e11 239     - Determine best commit id (e.g. "master") for the tree and docs pages and use that in links
c44dd0 240     - By default GO will now bind to all interfaces for both http and https connectors.  This simplifies setup for first-time users.    
064857 241     - Removed docs indicator on the repositories page
445b72 242     - Removed the repository setting to enable Markdown document enumeration, this is now automatic and expanded
e1b00b 243     - Retrieve LDAP groups with dereferencing aliases (pr-122)
f19b78 244     - Revised committer verification to require a matching displayname or account name AND the email address
c5069a 245     - Serve repositories on both /r and /git, displaying /r because it is shorter
1f3dff 246     - Eliminate HEAD from the blob, blame, and tree pages. That assumed a resource was available in HEAD and it may not be.
94e12c 247     - Eliminate Gravatar profile linking.
c134a0 248     - Moved Gitblit reflog from refs/gitblit/reflog to refs/meta/gitblit/reflog
3dfe07 249     - Updated Spanish translation
JM 250     - Updated Simplified Chinese translation
251     - Updated Dutch translation
252     - Updated Korean translation
9ae71a 253     additions:
e3733c 254     - Added color modes for the blame page (issue-2)
d02011 255     - Added an optional MirrorService which will periodically fetch ref updates from source repositories for mirrors (issue-5).  Repositories must be manually cloned using native git and "--mirror".
f084f4 256     - Added branch graph image servlet based on EGit's branch graph renderer (issue-194)
91d3b0 257     - Added option to render Markdown commit messages (issue-203)
5e3521 258     - Added Ticket tracker and Patchset collaboration feature (issue-215) 
9ae71a 259     - Added setting to control creating a repository as --shared on Unix servers (issue-263)
307910 260     - Set Link: <url>; rel="canonical" http header for SEO (issue-304)
c95e30 261     - Added raw links to the commit, commitdiff, and compare pages (issue-319)
a7317a 262     - Support intradocument linking in Markdown content using [[WikiLinks]] syntax (issue-324)
0c0bb9 263     - Support Markdown image links relative to the repository root (issue-324)
aa61fc 264     - Added filesystem write permission check (issue-345)
JM 265     - Added GO launch parameter for redirecting logging to a rolling, daily log file (issue-348)
fa38a1 266     - Added settings to Windows authentication provider to permit/prohibit BUILTIN\Administrators from being Gitblit Admins (issue-354)
d02011 267     - Added canonical url setting for email notifications and web display
c05da6 268     - Support rendering confluence, mediawiki, textile, tracwiki, and twiki markup documents
629806 269     - Added setting to globally disable anonymous pushes in the receive pack
319342 270     - Added a normalized diffstat display to the commit, commitdiff, and compare pages
9c7bb3 271     - Added GO setting to automatically redirect all http requests to the secure https connector
e13171 272     - Automatically display common repository root documents as tabs on the docs page
d02011 273     - Support bugtraq configuration in collaboration with Syntevo,  the regex.* config keys are now DEPRECATED
158242 274     - Added FishEye hook script (pr-137)
0dfb98 275     - Added Redmine Fetch hook script (issue-359)
f6a8cf 276     - Added Subgit hook contributed by TMate Software
9aa119 277     - Added function to retain a user account but prohibit authentication. This is an alternative to deleting a user account.
5ec752 278     - Added setting to hide the top-level navigation header to facilitate embedding Gitblit in something else.
3dfe07 279     - Added RPC request to reindex tickets
3462cf 280     dependencyChanges:
d65a6b 281     - updated to Jetty 8.1.13
f0950d 282     - updated to JGit 3.3.0
db9832 283     - updated to Lucene 4.6.0
644667 284     - updated to BouncyCastle 1.49
0c0bb9 285     - replaced MarkdownPapers with pegdown 1.4.2
65d5bb 286     - added Dagger 1.1.0
c05da6 287     - added Eclipse WikiText libraries for processing confluence, mediawiki, textile, tracwiki, and twiki
1ea553 288     - added FontAwesome 4.0.3
5e3521 289     - added Jedis 2.3.1
9ae71a 290     settings:
JM 291     - { name: 'git.createRepositoriesShared', defaultValue: 'false' }
b32502 292     - { name: 'git.allowAnonymousPushes', defaultValue: 'false' }
JM 293     - { name: 'git.defaultAccessRestriction', defaultValue: 'PUSH' }
d02011 294     - { name: 'git.enableMirroring', defaultValue: 'false' }
c44dd0 295     - { name: 'git.mirrorPeriod', defaultValue: '30 mins' }
d02011 296     - { name: 'git.userRepositoryPrefix', defaultValue: '~' }
04a985 297     - { name: 'realm.authenticationProviders', defaultValue: ' ' }
6659fa 298     - { name: 'realm.ldap.groupEmptyMemberPattern', defaultValue: '(&(objectClass=group)(!(member=*)))' }
JM 299     - { name: 'realm.ldap.synchronize', defaultValue: 'false' }
300     - { name: 'realm.ldap.syncPeriod', defaultValue: '5 MINUTES' }
301     - { name: 'realm.ldap.removeDeletedUsers', defaultValue: 'true' }
fa38a1 302     - { name: 'realm.windows.permitBuiltInAdministrators', defaultValue: 'true' }
d02011 303     - { name: 'web.canonicalUrl', defaultValue: ' ' }
91d3b0 304     - { name: 'web.commitMessageRenderer', defaultValue: 'plain' }
e13171 305     - { name: 'web.documents', defaultValue: 'readme home index changelog contributing submitting_patches copying license notice authors' }
5ec752 306     - { name: 'web.hideHeader', defaultValue: 'false' }
f084f4 307     - { name: 'web.showBranchGraph', defaultValue: 'true' }
fab099 308     - { name: 'web.summaryShowReadme', defaultValue: 'false' }
04a985 309     - { name: 'server.redirectToHttpsPort', defaultValue: 'false' }
5e3521 310     - { name: 'tickets.service', defaultValue: ' ' }
JM 311     - { name: 'tickets.acceptNewTickets', defaultValue: 'true' }
312     - { name: 'tickets.acceptNewPatchsets', defaultValue: 'true' }
313     - { name: 'tickets.requireApproval', defaultValue: 'false' }
bb6b14 314     contributors:
JM 315     - James Moger
316     - Robin Rosenberg
317     - Klaus Nuber
318     - Florian Zschocke
91d3b0 319     - Bret Ikehara
2a8ea0 320     - Chad Horohoe
JM 321     - Domingo Oropeza
06718b 322     - Chris Graham
237fae 323     - Guenter Dressel
67389b 324     - fpeters.fae
db9832 325     - David Ostrovsky
e3733c 326     - Alex Lewis
c6f3d0 327     - Marc Strapetz
21ca9d 328     - Benjamin Asbach
JM 329     - Alfred Schmid
5131d6 330     - Gareth Collins
21ca9d 331     - Martijn van der Kleijn
0dfb98 332     - Berke Viktor
158242 333     - Vitaly Litvak
JM 334     - Matthias Cullman
eb0f7e 335     - Eduardo Guervós Narvaez
058ed1 336     - Stardrad Yin
JM 337     - Markus Foempe
338     - Nasrollah Kavian
339     - M. Holmquist
340     - Stephan Krull
341     - Duncan Jauncey
342     - Rhys Evans
343     - Michael Wowro
344     - I. Tagliani
345     - Rick Sladkey
346     - Matthias Cullman
347     - Johann Fischer
348     - Tamás Papp
3dfe07 349     - Liyu Wang
JM 350     - Jeroen Baten
351     - Dongsu, KIM
6b80a2 352 }
JM 353
354 #
8eaf84 355 # 1.3.2 release
f1e5dc 356 #
JM 357 r19: {
8eaf84 358     title: Gitblit 1.3.2 released
JM 359     id: 1.3.2
360     date: 2013-08-22
f1e5dc 361     note: ~
JM 362     html: ~
363     text: ~
364     security: ~
e523d7 365     fixes:
JM 366     - Fixed Gitblit Authority startup failures when using alternate user services (issue-280)
367     - Manually redirect after branch deletion (issue 282)
005a65 368     - Simplify when repository size is calculated to ensure we have one IF we want one (issue-295)
7d2240 369     - Fixed anonymous LDAP connections (issue-297)
88ec32 370     - Improved branch deletion-reflog interaction
c1aa59 371     - Encode page url parameters as UTF-8
JM 372     - Encode filename for binary files on RawPage according to browser
373     - Added pptx extension for tree page icon lookup
bba300 374     - Fixed project links on dashboard page when web.mountParameters=false
f1e5dc 375     changes: ~
da7151 376     additions:
OL 377     - Add setting for maximum number of days of activity to that may be requested
a0c34e 378     - Added HtpasswdUserService to authenticate users against an htpasswd file
7838fc 379     - Automatically maintain the .git/description file used by some other tooling
a0c34e 380     dependencyChanges:
FZ 381     - Added commons-codec 1.7
c1aa59 382     contributors:
JM 383     - github/guriguri
bba300 384     - Doug Ayers
da7151 385     - Ori Livneh
a0c34e 386     - Florian Zschocke
7d2240 387     - Tito Nobre
005a65 388     - Hugo Questroy
da7151 389     settings:
OL 390     - { name: 'web.activityDurationMaximum', defaultValue: 30 }
a0c34e 391     - { name: 'realm.htpasswd.userFile', defaultValue: '${baseFolder}/htpasswd' }
FZ 392     - { name: 'realm.htpasswd.overrideLocalAuthentication', defaultValue: 'false' }
f1e5dc 393 }
JM 394
395 #
e05f22 396 # 1.3.1 release
da34e5 397 #
JM 398 r18: {
e05f22 399     title: Gitblit 1.3.1 released
JM 400     id: 1.3.1
401     date: 2013-07-24
515b6d 402     note: ''
JM 403           If you have forked repositories and your are upgrading from 1.2.x to 1.3.x, please DO NOT RELOCATE your repositories folder when running 1.3.x the first time.  Gitblit will update forked repository configs on the first execution and it is critical that ${git.repositoriesFolder} points to the same location used by 1.2.x.
404           ''
da34e5 405     html: ~
JM 406     text: ~
407     security: ~
8f6e67 408     fixes:
JM 409     - Gitblit-as-viewer with no repository urls failed to display summary page (issue 269)
d22773 410     - Fixed incorrect tagger in the dashboard pages (issue-276)
JM 411     - Automatically decode %7E in repository names from git clients that encode ~ (issue-278)
adc821 412     - Fixed missing Keys class in WAR and Express builds
c8e08d 413     - Fixed missing model class dependencies in Gitblit Manager build
009656 414     - Fix for IE10 compatibility mode
f01bc5 415     - Reset dashboard and activity commit cache on branch REWIND or DELETE
34d1fd 416     - Fixed bug with adding new local users with external authentication
009656 417     - Fixed missing clone url on the empty repository page
5392d7 418     - Fixed Ubuntu service script for LSB compliance
JM 419     - Inserted "sleep 5" in Ubuntu & Centos bash script for service restart
420     changes:    
271a68 421     - Use trash icon in Gitblit Reflog for branch and tag deletion
JM 422     - Update Gitblit Reflog on branch deletion from web UI
adc821 423     - Updated Chinese translation
JM 424     - Updated Dutch translation
425     - Updated Spanish translation
426     - Updated Korean translation
427     - Updated Brazilian Portuguese translation
a7db57 428     additions:
adc821 429     - Added optional browser-side page caching using Last-Modified and Cache-Control for the dashboard, activity, project, and several repository pages (issue-274)
a5ae3d 430     - Added a GET_USER request type for the RPC mechanism (issue-275)
2659e7 431     - Added PAMUserService to authenticate against a local Linux/Unix/MacOSX server
7ad6d3 432     dependencyChanges:
adc821 433     - Added libpam4j 1.7
a7db57 434     settings:
JM 435     - { name: 'web.pageCacheExpires', defaultValue: 0 }
2659e7 436     - { name: 'realm.pam.backingUserService', defaultValue: 'users.conf' }
JM 437     - { name: 'realm.pam.serviceName', defaultValue: 'system-auth' }
f10286 438     contributors:
JM 439     - Rainer Alföldi 
440     - Liyu Wang
58708c 441     - Jeroen Baten
f10286 442     - James Moger
88889c 443     - Stardrad Yin
a7db57 444     - Chad Horohoe
009656 445     - Eduardo Guervós Narvaez
JM 446     - Dongsu, KIM
9051a6 447     - Gareth Collins
f86d1d 448     - Rafael Cavazin
5392d7 449     - Tamás Papp
JM 450     - Florian Zschocke
a5ae3d 451     - Amélie Benoit
fd9086 452     - Gustavo Henrique
da34e5 453 }
JM 454
455 #
37dc9d 456 # 1.3.0
JM 457 #
458 r17: {
459     title: Gitblit 1.3.0 Released
460     id: 1.3.0
461     date: 2013-07-14
462     html: ''
463           Release highlights include:
464           <ul>
465           <li>integrated git daemon</li>
466           <li>compare refs or commits page</li>
467           <li>completed the Gitblit reflog (formerly pushlog) introduced in 1.2.1</li>
468           <li>added new dashboard pages</li>
469           <li>added a stars feature</li>
470           <li>improved the repository url panel to show your access permission and to offer native app clone links</li>
471           <li>improved navigation and theme</li>
472           <li>customizable page header colors and logo</li>
473           <li>recent activity commit caching to improve performance of dashboard and activity pages</li>
474           <li>Windows authentication</li>
475           <li>Salesforce.com authentication</li>
476           <li>lots of bug fixes</li>
477           </ul>
478           <p> </p>
479           Thank you to <a href="http://syntevo.com">syntevo</a>, <a href="http://atlassian.com">Atlassian</a>, <a href="http://fournova.com">fournova</a>, and <a href="http://github.com">Github</a> for their permission and use of their artwork for the native app clone menus.
480           ''
481     note: ''
482           If you have forked repositories and your are upgrading to 1.3.0, please DO NOT RELOCATE your repositories folder when running 1.3.0 the first time.  Gitblit will update forked repository configs on the first execution and it is critical that ${git.repositoriesFolder} points to the same location used by 1.2.x.
483           ''
484     security:
485     - 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)
486     fixes:
487      - Use bash instead of sh in Linux/OSX shell scripts (issue 154)
488      - Fix NPE when getting user's fork without repository list caching (issue 182)
489      - Fix internal error on folder history links (issue 192)
490      - Fix NPE in repositories panel when viewing a federation proposal (issue 195)
491      - Fix NPEs when initializing the context on a servlet containers which returns a null contextFolder (issue 199)
492      - Fixed incorrect icon file name for .doc files (issue 200)
493      - Do not queue emails with no recipients (issue 201)
494      - Disable view and blame links for deleted blobs (issue 216)
495      - Fixed 1.2.x regression with individually symlinked repositories (issue 217)
496      - Fixed UTF-8 encoding errors in email notifications (issue 218)
497      - Fixed NPE in 1.2.1 Federation Client (issue 219)
498      - Fixed extracting Groovy scripts on Express installs (issue 220)
499      - Ensure Redmine url is properly formatted (issue 223)
500      - Use standard ServletRequestWrapper instead of custom wrapper (issue 224)
501      - Switch commit message back to a pre and ensure that it is properly escaped when combined with commit message regex substitution (issue 242)
502      - Fixed AddIndexedBranch tool --branch parameter (issue 247)  
503      - Improve NPE handling for hook script enumeration (issue-253)
504      - Workaround missing commit information in blame page (JGit bug 374382, issue-254) 
505      - Ignore orphan ".git" folder in the repositories root folder (issue-256)
506      - Fixed bug where a null permission was added to a user model on a repository rename when the permission had really been inherited from a team membership (issue-259)
507      - Fixed committer verification with merge commits (issue-264)
508      - Fixed bug in submodule repository linking (issue-266)
509      - Could not reset settings with $ or { characters through Gitblit Manager because they are not properly escaped
510      - Added more error checking to blob page and blame page
511      - Disable SNI extensions for client SSL connections
512      - Fixed prettify language extension loading
513      - Fixed index out of bounds exceptions when generating client certificates for a user when the user's table has been filtered
514      - Fixed AddindexedBranch tool when specifying the non-default branch.
515      - Fixed submodule diff display
516
517     changes:
518      - Retrieve summary and metric graphs from Google over https (issue-61)
519      - Persist originRepository (for forks) in the repository config instead of relying on parsing origin urls which are susceptible to filesystem relocation (issue 190) 
520      - Improved error logging for servlet containers which provide a null contextFolder (issue 199)
521      - Improve Gerrit change ref decoration in the refs panel (issue 206)
522      - Display full commit message on commitdiff page (issue-258)
523      - Improved the repository url display.  This display now indicates your repository access permission, per-protocol.
524      - Automatically encode/decode usernames for urls using %XX notation on space, @, and \
525       - Disable Gson's pretty printing which has a huge performance gain
526      - Properly set application/json content-type on api calls
527      - Make days back filter choices a setting
528      - Changed default days back filter setting to 7 days
529      - Set rel="nofollow" on compressed download links
530      - Improved page title
531      - Updated Polish translation
532      - Updated Japanese translation
533      
534     additions: 
535      - Added a ui for the ref log introduced in 1.2.1 (issue-177)
536      - Added weblogic.xml to WAR for deployment on WebLogic (issue 199)
537      - Support setting a custom header logo (issue 208)
538      - Support header color customizations (issue 209)
539      - Support username substitution in web.otherUrls (issue 213)
540      - Option to force client-side basic authentication instead of form-based authentication if web.authenticateViewPages=true (issue 222)
541      - Set author as tooltip of last change column in the repositories panel (issue-238)
542      - Setting to automatically create an user account based on an authenticated user principal from the servlet container (issue-246)
543      - Added WindowsUserService to authenticate users against Windows accounts (issue-250)
544      - Global and per-repository setting to exclude authors from metrics (issue-251)
545      - Added commit cache to improve Activity, Dashboard, and Project page generation times
546      - Added SalesForce.com user service
547      - Added simple star/unstar function to flag or bookmark interesting repositories
548      - Added Dashboard page which shows a news feed for starred repositories and offers a filterable list of repositories you care about
549      - Added client application menus for Git, SmartGit/Hg, SourceTree, Tower, GitHub for Windows, and GitHub for Mac
550      - Added GO http/https connector thread pool size setting
551      - Added a server setting to force a particular translation/Locale for all sessions
552      - 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.
553      - Option to automatically tag branch tips on each push with an incremental revision number
554      - Implemented multiple repository owners
555      - Optional periodic LDAP user and team pre-fetching & synchronization
556      - Added config setting to use SMTPS
557      - Added option to index all local branches in AddIndexedBranches tool
558      - Display name and version in Tomcat Manager
559      - FogBugz post-receive hook script
560      - Chinese translation
561      - Support --baseFolder parameter in Federation Client
562
563     contributors:
564     - James Moger
565     - Bandarupalli Satyanarayana
566     - Chad Horohoe
567     - Christian Aistleitner
568     - Colin Bowern
569     - David Ostrovsky
570     - Egbert Teeselink
571     - Hige Maniya
572     - Hirotaka Honma
573     - Ikslawek
574     - Jay Meyer
575     - John Crygier
576     - Kensuke Matsuzaki
577     - Laurens Vrijnsen
578     - Lee Grofit
579     - Lukasz Jader
580     - Martijn Laan
581     - Matthias Bauer
582     - Michael Pailloncy
583     - Michael Schaefers
584     - Oliver Doepner
585     - Philip Boutros
586     - Rafael Cavazin
587     - Ryan Schneider
588     - Sakurai Youhei
589     - Sarah Haselbauer
590     - Slawomir Bochenski
591     - Stardrad Yin
592     - Thomas Pummer
593     - William Whittle
594     - Yukihiko Sawanobori
595     - github/akquinet
596     - github/dapengme
597     
598     dependencyChanges:
599     - JGit 3.0.0.201306101825-r
600     - Iconic font
601     - AngularJS 1.0.7
602     - FreeMarker 2.3.19
603     - Waffle 1.5
604     - JNA 3.5.0
605     - Guava 13.0.1
606     
607     settings:
608     - { name: 'git.daemonBindInterface', defaultValue: 'localhost' }
609     - { name: 'git.daemonPort', defaultValue: 0 }
610     - { name: 'git.defaultIncrementalPushTagPrefix', defaultValue: 'r' }
611     - { name: 'mail.smtps', defaultValue: 'false' }
612     - { name: 'realm.container.autoCreateAccounts', defaultValue: 'false' }
613     - { name: 'realm.salesforce.backingUserService', defaultValue: 'users.conf' }
614     - { name: 'realm.salesforce.orgId', defaultValue: 0 }
615     - { name: 'realm.windows.defaultDomain', defaultValue: ' ' }
616     - { name: 'realm.windows.backingUserService', defaultValue: 'users.conf' }
617     - { name: 'web.activityDuration', defaultValue: 7 }
618     - { name: 'web.activityDurationChoices', defaultValue: '1 3 7 14 21 28' }
619     - { name: 'web.activityCacheDays', defaultValue: 14 }
620     - { name: 'web.allowAppCloneLinks', defaultValue: 'true' }
621     - { name: 'web.forceDefaultLocale', defaultValue: ' ' }
622     - { name: 'web.headerLogo', defaultValue: '${baseFolder}/logo.png' }
623     - { name: 'web.headerBackgroundColor', defaultValue: ' ' }
624     - { name: 'web.headerForegroundColor', defaultValue: ' ' }
625     - { name: 'web.headerHoverColor', defaultValue: ' ' }
626     - { name: 'web.headerBorderColor', defaultValue: ' ' }
627     - { name: 'web.headerBorderFocusColor', defaultValue: ' ' }
628     - { name: 'web.metricAuthorExclusions', defaultValue: ' ' }
629     - { name: 'web.overviewReflogCount', defaultValue: 5 }
630     - { name: 'web.reflogChangesPerPage', defaultValue: 10 }
631     - { name: 'server.nioThreadPoolSize', defaultValue: 50 }
632 }
633
634 #
635 # 1.2.1
636 #
637 r16: {
638     title: Gitblit 1.2.1 Released
639     id: 1.2.1
640     date: 2013-01-15
641     html: ''
642           Because there are now several types of files and folders that must be considered Gitblit data, the default location for data has changed.
643           <p />
644           You will need to move a few files around when upgrading.  Please review the <a href="upgrade_go.html">upgrading GO</a> or <a href="upgrade_war.html">upgrading WAR</a> page for details.
645           <p />
646           <b>Express Users</b> make sure to update your web.xml file with the ${baseFolder} values!          
647           ''
648     fixes:
649     - Fixed nullpointer on recursively calculating folder sizes when there is a named pipe or symlink in the hierarchy
650     - Added nullchecking when concurrently forking a repository and trying to display the fork network (issue-187)
651     - 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)
652     - Fixed nullpointer on creating a repository with mixed case (issue 185)
653     - Include missing model classes in api library (issue-184)
654     - Fixed nullpointer when using *web.allowForking = true* && *git.cacheRepositoryList = false* (issue 182)
655     - Likely fix for commit and commitdiff page failures when a submodule reference changes (issue 178)
656     - Build project models from the repository model cache, when possible, to reduce page load time (issue 172)
657     - Fixed loading of Brazilian Portuguese translation from *nix server
658
659     additions:
660     - ''Fanout PubSub service for self-hosted [Sparkleshare](http://sparkleshare.org) notifications.
661       This service is disabled by default.''
662     - ''Implemented a simple push log based on a hidden, orphan branch refs/gitblit/pushes (issue 177)
663       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.''
664     - Support for locally and remotely authenticated accounts in LdapUserService and RedmineUserService (issue 183)
665     - Added Dutch translation
666
667     changes:
668     - ''Gitblit GO and Gitblit WAR are now both configured by `gitblit.properties`. WAR is no longer configured by `web.xml`.
669       However, Express for OpenShift continues to be configured by `web.xml`.''
670     - Support for a *--baseFolder* command-line argument for Gitblit GO and Gitblit Certificate Authority
671     - Support for specifying a *${baseFolder}* parameter in `gitblit.properties` and `web.xml` for several settings
672     - Improve history display of a submodule link
673     - Updated Korean translation
674     - Updated checkstyle definition
675     
676     settings:
677     - { name: fanout.bindInterface, defaultValue: localhost }
678     - { name: fanout.port, defaultValue: 0 }
679     - { name: fanout.useNio, defaultValue: 'true' }
680     - { name: fanout.connectionLimit, defaultValue: 0 }
681
682     contributors:
683     - James Moger
684     - github/mystygage
009656 685     - Dongsu, KIM
JM 686     - Jeroen Baten
37dc9d 687     - github/inaiat
JM 688 }
689
690 #
691 # 1.2.0
692 #
693 r15: {
694     title: Gitblit 1.2.0 Released
695     id: 1.2.0
696     date: 2012-12-31
697     note: ''
698           The permissions model has changed in the 1.2.0 release.
699           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.
700           ''
701     fixes:
702     - Fixed regression in *isFrozen* (issue 181)
703     - Author metrics can be broken by newlines in email addresses from converted repositories (issue 176)
704     - Set subjectAlternativeName on generated SSL cert if CN is an ip address (issue 170)
705     - Fixed incorrect links on history page for files not in the current/active commit (issue 166)
706     - Empty repository page failed to handle missing repository (issue 160)
707     - Fixed broken ticgit urls (issue 157)
708     - Exclude submodules from zip downloads (issue 151)
709     - Fixed bug where repository ownership was not updated on rename user
710     - Fixed bug in create/rename repository if you explicitly specified the alias for the root group (e.g. main/myrepo) (issue 143)
711     - Wrapped Markdown parser with improved exception handler (issue 142)
712     - Fixed duplicate entries in repository cache (issue 140)
713     - Fixed connection leak in LDAPUserService (issue 139)
714     - Fixed bug in commit page where changes to a submodule threw a null pointer exception (issue 132)
715     - Fixed bug in the diff view for filenames that have non-ASCII characters (issue 128)
716
717     additions:
718     - ''
719       Implemented discrete repository permissions (issue 36)
720       
721         - V (view in web ui, RSS feeds, download zip)
722         - R (clone)
723         - RW (clone and push)
724         - RWC (clone and push with ref creation)
725         - RWD (clone and push with ref creation, deletion)
726         - RW+ (clone and push with ref creation, deletion, rewind)
727         
728       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.
729       ''
730     - ''Implemented *case-insensitive* regex repository permission matching (issue 36)
731
732       This allows you to specify a permission like `RW:mygroup/.*` to grant push privileges to all repositories within the *mygroup* project/folder.''
733     - Added DELETE, CREATE, and NON-FAST-FORWARD ref change logging
734     - ''Added support for personal repositories.
735       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.''
736     - ''Added support for server-side forking of a repository to a personal repository (issue 137)
737       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.''
738     - Added optional *create-on-push* support
739     - Added **experimental** JGit-based garbage collection service.  This service is disabled by default.
740     - ''Added support for X509 client certificate authentication.  (issue 106)
741       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.''
742     - 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>
743     - Added support for Gitblit GO to require usage of client certificates to access the entire server.
744     - Added **Gitblit Certificate Authority**, an x509 PKI management tool for Gitblit GO to encourage use of x509 client certificate authentication.
745     - Added web.shortCommitId setting to control length of shortened commit ids
746     - Added alternate compressed download formats: tar.gz, tar.xz, tar.bzip2 (issue 174)
747     - Added simple project pages.  A project is a subfolder off the *git.repositoriesFolder*.
748     - Added support for X-Forwarded-Context for Apache subdomain proxy configurations (issue 135)
749     - Delete branch feature (issue 121)
750     - Added line links to blob view (issue 130)
751     - Added HTML sendmail hook script and Gitblit.sendHtmlMail method
752     - Added RedmineUserService
753     - Support for committer verification.  Requires use of *--no-ff* when merging branches or pull requests.  See setup page for details.
754     - Added Brazilian Portuguese translation
755
756     changes:
757     - Added server setting to specify keystore alias for ssl certificate (issue 98)
758     - Added optional global and per-repository activity page commit contribution throttle to help tame *really* active repositories (issue 173)
759     - Added support for symlinks in tree page and commit page (issue 171)
760     - 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.
761     - Added *groovy* and *scala* to *web.prettyPrintExtensions*
762     - Added short commit id column to log and history tables (issue 168)
763     - Teams can now specify the *admin*, *create*, and *fork* roles to simplify user administration
764     - Use https Gravatar urls to avoid browser complaints
765     - Added frm to default pretty print extensions (issue 156)
766     - Expose ReceivePack to Groovy push hooks (issue 125)
767     - Redirect to summary page when refreshing the empty repository page on a repository that is not empty (issue 129)
768     - 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)
769     - ''LDAP admin attribute setting is now consistent with LDAP teams setting and admin teams list.
770       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.''
771     - Support servlet container authentication for existing UserModels (issue 68)
772
773     settings:
774     - { name: web.allowForking, defaultValue: 'true' }
775     - { name: git.allowCreateOnPush, defaultValue: 'true' }
776     - { name: git.allowGarbageCollection, defaultValue: 'false' }
777     - { name: git.garbageCollectionHour, defaultValue: 0 }
778     - { name: git.defaultGarbageCollectionThreshold, defaultValue: 500k }
779     - { name: git.defaultGarbageCollectionPeriod, defaultValue: 7 days }
780     - { name: git.requireClientCertificates, defaultValue: 'false' }
781     - { name: git.enforceCertificateValidity, defaultValue: 'true' }
782     - { name: git.certificateUsernameOIDs, defaultValue: CN }
783     - { name: web.shortCommitIdLength, defaultValue: 8 }
784     - { name: web.compressedDownloads, defaultValue: zip gz }
785     - { name: server.requireClientCertificates, defaultValue: 'false' }
786
787     dependencyChanges:
788     - Jetty 7.6.8
789     - JGit 2.2.0.201212191850-r
790     - Groovy 1.8.8
791     - Wicket 1.4.21
792     - Lucene 3.6.1
793     - BouncyCastle 1.47
794     - MarkdownPapers 1.3.2
795     - JCalendar 1.3.2
796     - Commons-Compress 1.4.1
797     - XZ for Java 1.0
798
799     contributors:
800     - James Moger
801     - github/rafaelcavazin
802     - github/mallowlabs
803     - github/sauthieg
804     - github/ajermakovics
805     - github/kevinanderson1
806     - github/jpyeron
807 }
808
809 #
810 # 1.1.0
811 #
812 r14: {
813     title: Gitblit 1.1.0 Released
814     id: 1.1.0
815     date: 2012-08-25
816     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.
817
818     fixes:
819     - 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)
820     - Fixed MailExecutor's failure to cope with mail server connection troubles resulting in 100% CPU usage
821     - Fixed generated urls in Groovy *sendmail* hook script for grouped repositories
822     - Fixed generated urls in RSS feeds for grouped repositories
823     - Fixed nullpointer exception in git servlet security filter (issue 123)
824     - Eliminated an unnecessary repository enumeration call on the root page which should result in faster page loads (issue 103)
825     - Gitblit could not delete a Lucene index in a working copy on index upgrade
826     - Do not index submodule links (issue 119)
827     - Restore original user or team object on failure to update (issue 118)
828     - Fixes to relative path determination in repository search algorithm for symlinks (issue 116)
829     - Fix to GitServlet to allow pushing to symlinked repositories (issue 116)
830     - Repository URL now uses `X-Forwarded-Proto` and `X-Forwarded-Port`, if available, for reverse proxy configurations (issue 115)
831     - Output real RAW content, not simulated RAW content (issue 114)
832     - Fixed Lucene charset encoding bug when reindexing a repository (issue 112)
833     - Fixed search box linking to Lucene page for grouped repository on Tomcat (issue 111)
834     - Fixed null pointer in LdapUserSerivce if account has a null email address (issue 110)
835     - Really fixed failure to update a GO setting from the manager (issue 85)
836
837     additions:
838     - Identified repository list is now cached by default to reduce disk io and to improve performance (issue 103)
839     - Preliminary bare repository submodule support
840     - ''
841       *git.submoduleUrlPatterns* is a space-delimited list of regular expressions for extracting a repository name from a submodule url.
842       For example, `git.submoduleUrlPatterns = .*?://github.com/(.*)` would extract *gitblit/gitblit.git* from *git://github.git/gitblit/gitblit.git*
843       **Note:** You may not need this control to work with submodules, but it is there if you do.
844         - 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)*
845         - 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.
846         - Submodule references in a working copy will be properly identified as gitlinks, but Gitblit will not traverse into the working copy submodule repository.
847       ''
848     - ''
849       Added a repository setting to control authorization as AUTHENTICATED or NAMED. (issue 117)
850
851       NAMED is the original behavior for authorizing against a list of permitted users or permitted teams.
852       AUTHENTICATED allows restricted access for any authenticated user.  This is a looser authorization control.
853       ''
854     - Added default authorization control setting (AUTHENTICATED or NAMED)
855     - Added setting to control how deep Gitblit will recurse into *git.repositoriesFolder* looking for repositories (issue 103)
856     - Added setting to specify regex exclusions for repositories (issue 103)
857     - Blob page now supports displaying images (issue 6)
858     - Non-image binary files can now be downloaded using the RAW link
859     - Support StartTLS in LdapUserService (issue 122)
860     - Added Korean translation
861
862     changes:
863     - 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.
864     - Improve UTF-8 reading for Markdown files
865     - Updated Polish translation
866     - Updated Japanese translation
867     - Updated Spanish translation
868     
869     settings:
870     - { name: git.cacheRepositoryList, defaultValue: 'true' }
871     - { name: git.submoduleUrlPatterns, defaultValue: * }
872     - { name: git.searchExclusions, defaultValue: * }
873     - { name: git.searchRecursionDepth, defaultValue: -1 }
874     - { name: git.defaultAuthorizationControl, defaultValue: NAMED }
875
876     contributors:
877     - James Moger
878     - Steffen Gebert
879 }
880
881 #
882 # 1.0.0
883 #
884 r13: {
885     title: Gitblit 1.0.0 Released
886     id: 1.0.0
887     date: 2012-07-14
888
889     fixes:
890     - 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.
891     - Fixed intermittent bug in identifying line numbers in Lucene search (issue 105)
892     - 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)
893     - Fixed bug where a repository set as *authenticated push* did not have anonymous clone access (issue 96)
894     - Fixed bug in Basic authentication if passwords had a colon
895     - Fixed bug where the Gitblit Manager could not update a setting that was not referenced in reference.properties (issue 85)
896
897     changes:
898     - ''**Updated Lucene index version which will force a rebuild of ALL your Lucene indexes**
899       Make sure to properly set *web.blobEncodings* before starting Gitblit if you are updating!  (issue 97)''
900     - Changed default layout for web ui from Fixed-Width layout to Responsive layout (issue 101)
901     - ''IUserService interface has changed to better accomodate custom authentication and/or custom authorization<
902       The default `users.conf` now supports persisting display names and email addresses.''
903     - Updated Japanese translation
904
905     additions:
906     - Added setting to allow specification of a robots.txt file (issue 99)
907     - ''Added setting to control Responsive layout or Fixed-Width layout (issue 101)
908       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.''
909     - Added setting to control charsets for blob string decoding.  Default encodings are UTF-8, ISO-8859-1, and the server default charset. (issue 97)      
910     - ''Exposed JGit internal configuration settings in gitblit.properties/web.xml (issue 93)
911       Review your `gitblit.properties` or `web.xml` for detailed explanations of these settings.''
912     - Added default access restriction.  Applies to new repositories and repositories that have not been configured with Gitblit. (issue 88)
913     - 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
914     - ''Added setting to control Groovy Grape root folder (location where resolved dependencies are stored)
915       [Grape](http://groovy.codehaus.org/Grape) allows you to add Maven dependencies to your pre-/post-receive hook script classpath.''
916     - Added LDAP User Service with many new *realm.ldap* keys
917     - ''Added support for custom repository properties for Groovy hooks
918       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.''
919     - Added script to facilitate proxy environment setup on Linux
920     - Added Polish translation
921     - Added Spanish translation
922
923     settings:
924     - { name: groovy.grapeFolder, defaultValue: groovy/grape }
925     - { name: web.robots.txt, defaultValue: }
926     - { name: web.useResponsiveLayout, defaultValue: 'true' }
927     - { name: web.blobEncodings, defaultValue: UTF-8 ISO-8859-1 }
928     - { name: git.defaultAccessRestriction, defaultValue: NONE }
929     - { name: git.packedGitWindowSize, defaultValue: 8k }
930     - { name: git.packedGitLimit, defaultValue: 10m }
931     - { name: git.deltaBaseCacheLimit, defaultValue: 10m }
932     - { name: git.packedGitOpenFiles, defaultValue: 128 }
933     - { name: git.streamFileThreshold, defaultValue: 50m }
934     - { name: git.packedGitMmap, defaultValue: 'false' }
935
936     dependencyChanges:
937     - Bootstrap 2.0.4
938     - JGit 2.0.0.201206130900-r
939     - Groovy 1.8.6
940     - Gson 1.7.2
941     - Log4J 1.2.17
942     - SLF4J 1.6.6
943     - Apache Commons Daemon 1.0.10
944     - Ivy 2.2.0
945
946     contributors:
947     - James Moger
948     - Eduardo Guervos Narvaez
949     - Lukasz Jader
950     - github/mragab
951     - github/jcrygier
952     - github/zakki
953     - github/peterloron
954 }
955
956 #
957 # 0.9.3
958 #
959 r12: {
960     title: Gitblit 0.9.3 Released
961     id: 0.9.3
962     date: 2012-04-11
963
964     fixes:
965     - Fixed bug where you could not remove all selections from a RepositoryModel list (permitted users, permitted teams, hook scripts, federation sets, etc) (issue 81)
966     - Automatically set *java.awt.headless=true* for Gitblit GO
967
968     contributors:
969     - James Moger
970 }
971
972 #
973 # 0.9.2
974 #
975 r11: {
976     title: Gitblit 0.9.2 Released
977     id: 0.9.2
978     date: 2012-04-04
979     
980     changes:
981     - Added *clientLogger* bound variable to Groovy hook mechanism to allow custom info and error messages to be returned to the client
982
983    fixes:
984     - Fixed absolute path/canonical path discrepancy between Gitblit and JGit regarding use of symlinks (issue 78)
985     - Fixed row layout on activity page (issue 79)
986     - Fixed Centos service script
987     - Fixed EditRepositoryPage for IE8; missing save button (issue 80)
988
989     contributors:
990     - James Moger
991     - github/jonnybbb
992     - github/mohamedmansour
993     - github/jcrygier
994 }
995
996 #
997 # 0.9.1
998 #
999 r10: {
1000     title: Gitblit 0.9.1 Released
1001     id: 0.9.1
1002     date: 2012-03-27
1003
1004     fixes:
1005     - Lucene folder was stored in working copy instead of in .git folder
1006
1007     contributors:
1008     - James Moger
1009 }
1010
1011 #
1012 # 0.9.0
1013 #
1014 r9: {
1015     title: Gitblit 0.9.0 Released
1016     id: 0.9.0
1017     date: 2012-03-27
1018
1019     security:
1020     - Fixed session fixation vulnerability where the session identifier was not reset during the login process (issue 62)
1021
1022     changes:
1023     - Reject pushes to a repository with a working copy (i.e. non-bare repository) (issue-49)
1024     - Changed default web.datetimestampLongFormat from *EEEE, MMMM d, yyyy h:mm a z* to *EEEE, MMMM d, yyyy HH:mm Z* (issue 50)
1025     - Expanded commit age coloring from 2 days to 30 days (issue 57)
1026
1027     additions:
1028     - ''Added optional Lucene branch indexing (issue 16)
1029       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.)
1030       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/>
1031       If the repository does not specify any indexed branches then repository commit-traversal search is used.
1032
1033       **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/>
1034       See the [setup](setup.html) page for additional details.''
1035     - Allow specifying timezone to use for Gitblit which is independent of both the JVM and the system timezone (issue 54)
1036     - Added a built-in AJP connector for integrating Gitblit GO into an Apache mod_proxy setup (issue 59)
1037     - ''On the Repositories page show a bang *!* character in the color swatch of a repository with a working copy (issue 49)
1038       Push requests to these repositories will be rejected.''
1039     - On all non-bare Repository pages show *WORKING COPY* in the upper right corner (issue 49)
1040     - New setting to prevent display/serving non-bare repositories
1041     - Added *protect-refs.groovy*
1042     - Allow setting default branch (relinking HEAD) to a branch or a tag
1043     - Added Ubuntu service init script (issue 72)
1044     - Added partial Japanese translation
1045
1046     fixes:
1047     - Ensure that Welcome message is parsed using UTF-8 encoding (issue 74)
1048     - Activity page chart layout broken by Google (issue 73)
1049     - Uppercase repositories not selectable in edit palettes (issue 71)
1050     - Not all git notes were properly displayed on the commit page (issue 70)
1051     - Activity page now displays all local branches (issue 65)
1052     - Fixed (harmless) nullpointer on pushing to an empty repository (issue 69)
1053     - Fixed possible nullpointer from the servlet container on startup (issue 67)
1054     - Fixed UTF-8 encoding bug on diff page (issue 66)
1055     - Fixed timezone bugs on the activity page (issue 54)
1056     - Prevent add/edit team with no selected repositories (issue 56)
1057     - Disallow browser autocomplete on add/edit user/team/repository pages
1058     - Fixed username case-sensitivity issues (issue 43)
1059     - Disregard searching a subfolder if Gitblit does not have filesystem permissions (issue 51)
1060
1061     settings:
1062     - { name: web.allowLuceneIndexing, defaultValue: 'true' }
1063     - { 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 }
1064     - { name: web.timezone, defaultValue: }
1065     - { name: server.ajpPort, defaultValue: 0 }
1066     - { name: server.ajpBindInterface, defaultValue: localhost }
1067     - { name: git.onlyAccessBareRepositories, defaultValue: 'false' }
1068
1069     dependencyChanges:
1070     - Bootstrap 2.0.2
1071     - MarkdownPapers 1.2.7
1072     - JGit 1.3.0.201202151440-r
1073     - Wicket 1.4.20
1074
1075     contributors:
1076     - James Moger
1077     - github/lemval
1078     - github/zakki
1079     - github/plm
1080 }
1081
1082 #
1083 # 0.8.2
1084 #
1085 r8: {
1086     title: Gitblit 0.8.2 Released
1087     id: 0.8.2
1088     date: 2012-01-13
1089
1090     fixes:
1091     - Fixed bug when upgrading from users.properties to users.conf (issue 41)
1092
1093     contributors:
1094     - James Moger
1095 }
1096
1097 #
1098 # 0.8.1
1099 #
1100 r7: {
1101     title: Gitblit 0.8.1 Released
1102     id: 0.8.1
1103     date: 2012-01-11
1104
1105     fixes:
1106     - Include missing icon resource for the manager (issue 40)
1107     - Fixed sendmail.groovy message content with incorrect tag/branch labels
1108
1109     contributors:
1110     - James Moger
1111 }
1112
1113 #
1114 # 0.8.0
1115 #
1116 r6: {
1117     title: Gitblit 0.8.0 Released
1118     id: 0.8.0
1119     date: 2012-01-11
1120
1121     additions:
1122     - ''Platform-independent, Groovy push hook script mechanism.
1123       Hook scripts can be set per-repository, per-team, or globally for all repositories.''
1124     - ''*sendmail.groovy* for optional email notifications on push.
1125       You must properly configure your SMTP server settings in `gitblit.properties` or `web.xml` to use *sendmail.groovy*.''
1126     - 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.
1127     - *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.
1128     - ''New default user service implementation: *com.gitblit.ConfigUserService* (`users.conf`)
1129       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.
1130       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.
1131       The original `users.properties` file and the corresponding implementation are **deprecated**.''
1132     - Teams for specifying user-repository access in bulk.  Teams may also specify mailing lists addresses and pre- & post- receive hook scripts.
1133     - Gravatar integration
1134     - Activity page for aggregated repository activity.  This is a timeline of commit activity over the last N days for one or more repositories.
1135     - *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)
1136     - Flash-based 1-step *copy to clipboard* of the primary repository url based on Clippy
1137     - 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
1138     - 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)
1139     - 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.
1140     - Gitblit Express bundle to get started running Gitblit on RedHat OpenShift cloud <span class="label label-warning">BETA</span>
1141
1142     changes:
1143     - Dropped display of trailing .git from repository names
1144     - ''Gitblit GO is now monolithic like the WAR build. (issue 30)
1145       This change helps adoption of GO in environments without an internet connection or with a restricted connection.''
1146     - 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
1147
1148     fixes:
1149     - Several a bugs in FileUserService related to cleaning up old repository permissions on a rename or delete
1150     - Renaming a repository into a new subfolder failed (issue 33)
1151
1152     settings:
1153     - { name: groovy.scriptsFolder, defaultValue: groovy }
1154     - { name: groovy.preReceiveScripts, defaultValue: }
1155     - { name: groovy.postReceiveScripts, defaultValue: }
1156     - { name: mail.mailingLists, defaultValue: }
1157     - { name: realm.userService, defaultValue: users.conf }
1158     - { name: web.allowGravatar, defaultValue: 'true' }
1159     - { name: web.activityDuration, defaultValue: 14 }
1160     - { name: web.timeFormat, defaultValue: HH:mm }
1161     - { name: web.datestampLongFormat, defaultValue: "EEEE, MMMM d, yyyy" }
1162     - { name: web.customFilters, defaultValue: }
1163     - { name: web.allowFlashCopyToClipboard, defaultValue: 'true' }
1164
1165     dependencyChanges:
1166     - JGit 1.2.0
1167     - Groovy 1.8.5
1168     - Clippy
1169
1170     contributors:
1171     - James Moger
1172 }
1173
1174 #
1175 # 0.7.0
1176 #
1177 r5: {
1178     title: Gitblit 0.7.0 Released
1179     id: 0.7.0
1180     date: 2011-11-11
1181
1182     security:
1183     - fixed security hole when cloning clone-restricted repository with TortoiseGit (issue 28)
1184
1185     fixes:
1186     - ''federation protocol timestamps.  dates are now serialized to the [iso8601](http://en.wikipedia.org/wiki/ISO_8601) standard.
1187       **This breaks 0.6.0 federation clients/servers.**''
1188     - collision on rename for repositories and users
1189     - Gitblit can now browse the Linux kernel repository (issue 25)
1190     - Gitblit now runs on Servlet 3.0 webservers (e.g. Tomcat 7, Jetty 8) (issue 23)
1191     - Set the RSS content type of syndication feeds for Firefox 4 (issue 22)
1192     - RSS feeds are now properly encoded to UTF-8
1193     - RSS feeds now properly generate parameterized links if *web.mountParameters=false*
1194     - Null pointer exception if did not set federation strategy (issue 20)
1195     - Gitblit GO allows SSL renegotiation if running on Java 1.6.0_22 or later
1196         
1197     changes:
1198     - updated ui with Twitter Bootstrap CSS toolkit
1199     - repositories list performance by caching repository sizes (issue 27)
1200     - summary page performance by caching metric calculations (issue 25)
1201     
1202     additions:
1203     - authenticated JSON RPC mechanism
1204     - Gitblit API RSS/JSON RPC library
1205     - Gitblit Manager (Java/Swing Application) for remote administration of a Gitblit server.
1206     - per-repository setting to skip size calculation (faster repositories page loading)
1207     - per-repository setting to skip summary metrics calculation (faster summary page loading)
1208     - IUserService.setup(IStoredSettings) for custom user service implementations
1209     - setting to control Gitblit GO context path for proxy setups
1210     - *combined-md5* password storage option which stores the hash of username+password as the password
1211     - repository owners are automatically granted access for git, feeds, and zip downloads without explicitly selecting them
1212     - RSS feeds now include regex substitutions on commit messages for bug trackers, etc
1213     
1214     settings:
1215     - { name: web.loginMessage, defaultValue: gitblit }
1216     - { name: web.enableRpcServlet, defaultValue: 'true' }
1217     - { name: web.enableRpcManagement, defaultValue: 'false' }
1218     - { name: web.enableRpcAdministration, defaultValue: 'false' }
1219     - { name: server.contextPath, defaultValue: / }
1220     
1221     dependencyChanges:
1222     - MarkdownPapers 1.2.5
1223     - Wicket 1.4.19
1224
1225     contributors:
1226     - James Moger
1227     - github/dadalar
1228     - github/alyandon
1229     - github/trygvis
1230 }
1231
1232 #
1233 # 0.6.0
1234 #
1235 r4: {
1236     title: Gitblit 0.6.0 Released
1237     id: 0.6.0
1238     date: 2011-09-27
1239
1240     fixes:
1241     - syndication urls for WAR deployments
1242     - authentication for zip downloads
1243
1244     additions:
1245     - 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.
1246     - user role *#notfederated* to prevent a user account from being pulled by a federated Gitblit instance
1247
1248     settings:
1249     - { name: federation.name, defaultValue: }
1250     - { name: federation.passphrase, defaultValue: }
1251     - { name: federation.allowProposals, defaultValue: 'false' }
1252     - { name: federation.proposalsFolder, defaultValue: proposals }
1253     - { name: federation.defaultFrequency, defaultValue: 60 mins }
1254     - { name: federation.sets, defaultValue: }
1255     - { name: "mail.*", defaultValue: }
1256         
1257     dependencyChanges:
1258     - MarkdownPapers 1.1.1
1259     - Wicket 1.4.18
1260     - JGit 1.1.0
1261     - google-gson
1262     - javamail
1263
1264     contributors:
1265     - James Moger
1266 }
1267
1268 #
1269 # 0.5.2
1270 #
1271 r3: {
1272     title: Gitblit 0.5.2 Released
1273     id: 0.5.2
1274     date: 2011-07-27
1275
1276     fixes:
1277     - active repositories with a HEAD that pointed to an empty branch caused internal errors (issue 14)
1278     - bare-cloned repositories were listed as (empty) and were not clickable (issue 13)
1279     - default port for Gitblit GO is now 8443 to be more linux/os x friendly (issue 12)
1280     - repositories can now be reliably deleted and renamed (issue 10)
1281     - users can now change their passwords (issue 1)
1282     - always show root repository group first, i.e. do not sort root group with other groups
1283     - tone-down repository group header color
1284     
1285     additions:
1286     - optionally display repository on-disk size on repositories page
1287     - forward-slashes ('/', %2F) can be encoded using a custom character to workaround some servlet container default security measures for proxy servers
1288     
1289     settings:
1290     - { name: web.showRepositorySizes, defaultValue: 'true' }
1291     - { name: web.forwardSlashCharacter, defaultValue: / }
1292     
1293     dependencyChanges:
1294     - MarkdownPapers 1.1.0
1295     - Jetty 7.4.3
1296
1297     contributors:
1298     - James Moger
1299 }
1300
1301 #
1302 # 0.5.1
1303 #
1304 r2: {
1305     title: Gitblit 0.5.1 Released
1306     id: 0.5.1
1307     date: 2011-06-28
1308
1309     changes:
1310     - clarified SSL certificate generation and configuration for both server-side and client-side
1311     - added some more troubleshooting information to documentation
1312     - replaced JavaService with Apache Commons Daemon
1313
1314     contributors:
1315     - James Moger
1316 }
1317
1318 #
1319 # 0.5.0
1320 #
1321 r1: {
1322     title: Gitblit 0.5.0 Released
1323     id: 0.5.0
1324     date: 2011-06-26
1325     text: initial release
1326
1327     contributors:
1328     - James Moger
1329 }
1330
ec8bd6 1331 snapshot: &r24
8db2b5 1332 release: &r23
JM 1333 releases: &r[1..23]