cleaned up files and ebuild; added another rake task (is that called so?)
This commit is contained in:
		
							parent
							
								
									c9e66709aa
								
							
						
					
					
						commit
						b47c56ab34
					
				
					 19 changed files with 12 additions and 1262 deletions
				
			
		|  | @ -1,24 +1,11 @@ | |||
| AUX config.ssh 245 SHA256 5bf5d5a357e88b71e14a12bb28ea68d0286ed29118045aa944484b84b6fa5e4b SHA512 52dbec481cd45136e72370713ab20a41616dccb252e75b884b66e2494aaefe7795719169906dcad5030dcbe33201d021bdad1f7a99120ac40a64611290ff8759 WHIRLPOOL 9b991ad20787e0e7274136ddb8e22e1082360d580f8576feb722730b5c3f3fa22992f671f7916e191052a78d8d688d32044b39059dc7146d14c2da57fa891214 | ||||
| AUX gitlab-sidekiq.init 979 SHA256 f9bc02031b0418e4c765fae37bb40cd9e16dbe5b1a7f5c105a2d7ba3568b0195 SHA512 e3311f1110fca02a378a9f74704d9241884a1973e90be1dbd663809b524528eda25e3ad0ac5d20737f6ccd78343582557ac579adb976473f8aabc0320172921f WHIRLPOOL 365d539cceacb5ff9171aa7316ac061ef4b4a8d63e6d4a26395afb841878a08bdd1b9bf2709602dc90f15a1ed5ff8566a0e8239e8ab9184e84814a16993f3aeb | ||||
| AUX gitlab-support.init 1188 SHA256 09059c391a5d5a8856030b4a50a9c8bb7d8fdb8f7ab75c1a869015bbff6a3a32 SHA512 25fe623e1d506a750897b4e100fcaddc654997a7cf23b7f1a6b4c3b77907cbe8af669cc38da86753696861e4fd14415ea7bc1decb0fdb500de1ef8a3e845860c WHIRLPOOL 169fab28b013762d3eaac4d8a37ded0ba6dedd9ebcd9fdd55347409f279d332a8d0326ec6eb66255c6f1d488c856c7135c60f3069972a7a07e55453e55bbe969 | ||||
| AUX gitlab-unicorn-6.init 1663 SHA256 ba211c63d559cbca510483d5536d28131e08f67dc8914444a2c85b27c7a92b60 SHA512 a574b3bb5b9af3e3a707045ac6d783bab73bab1db033d07999b3d06789da0853bc3de0bba39a3c154e5b1ab385926ee3ec4487f4c797708a318fa5df22827069 WHIRLPOOL 497cf52ebb4b33cc6bbd81e53d4961878b2ea9dc42bacabf7a32686e52a54c22eed73836705e80714d7b759cfd2ee1929e6aa12083435f265c472270e158f72a | ||||
| AUX gitlab-unicorn.init 1874 SHA256 8bede14eb7beaba955e64d0ff2928324992522e22e777aab33bf51d743c7ba4e SHA512 a8595a623cd724a3d2e3b95ea7216e2574d0beea75369a46dfd6c5483310675a827d08cda516dec0df7ccbff399d27e3dde0e0fae07d11eed6412b0d3f9ca8d9 WHIRLPOOL c619180431ee27b5fe724aaf6ed31bb9fcf8db3779d7879e79c7a04927ea7d4efcd363d5cc44184917bd4de8292267e93136de849e8892ffc1e2891aacb5f51c | ||||
| AUX gitlab.logrotate 191 SHA256 9c02c26f5faa443cd576599462c6a8206d62495ab9671098a5f0e379f216541b SHA512 2212a8e5f2d4704256d5abb92b5a1201b20f82b04610758e734d163792a60b78f482017510169666a70ed9352b171177d05237ffe87988cacb764c5ef7ba5443 WHIRLPOOL f61297015311316554e63af4822b8d274f5a2378e829e5c14bb22e642b0d83023446acff45a13aa354f127543ce1552c99488b92ed8f39d86959343c7e67bbee | ||||
| AUX gitlabhq-4.0.0-fix-checks-gentoo.patch 1936 SHA256 d1775b91fa55f3706793771fd98564a06322e3dfc07970a6fd3497709507f527 SHA512 45e1e55fc9ed514e1cb18c5d4bc8b514fb995035e1ff9cf58b6bc238271bd3468fad1af23f53035b7c43a1a7becf51234522953064eefedcae8b507e5b7cfd7a WHIRLPOOL b18cc3df85b6251b823219657397ea89f9f08c67b57b64e09bfedfa341a04aa6910acb4876c2bcca2b853e27bf5ee43a1f2237625b84f183edab134cf08fa17a | ||||
| AUX gitlabhq-4.0.0-fix-gemfile.patch 1736 SHA256 b37a447b38e5303e94205fda9ce131f5c8828c323974e9ed30253d53938d7640 SHA512 6e5e875a53bb2efda1153c6ef8275f93cd8b9eb8d936b34a6df6f0db3bc577099fbc22f2e6c844ee8629af13c4d4fed968b0c5d3360ebdcee1136010a04be34e WHIRLPOOL 1f24e69f52df32d75863295378a781da4ff6df22699a77d1b9f53a98c78df81a1cd0136b60695fe28ff904dcb32c87b6e67b4ae324c070c873bfefc3bd3d6c2e | ||||
| AUX gitlabhq-4.0.0-fix-passenger.patch 1156 SHA256 f2ccaad4e349cb8c965ed46607a78f7d738ed434565fc7d80b15ac92121a29a0 SHA512 31906f2a8831ce0484279bbac68d9935dca52e831cf8c473746a51d1b2de4077f40726544a09b10b80890c72b9028bda7b294fb19ccec5df5a312f5a2ce3d1aa WHIRLPOOL 384912fc1c1ae5da05e98525b435417f6488d3927e285fd16d3cf7659bc376bf5e801e3bc3be7f4de480c7302cc1d7edc3fa88825e82836dbaf0606f8218e662 | ||||
| AUX gitlabhq-4.0.0-fix-resque-pg.patch 415 SHA256 c1b764777a0089020893f05649b6d15cf8c60611e90d9d0b3e74ee29bcb57614 SHA512 83639200bbc49350ab9bfc033c0a5401967ad2ab6b23bbdcd948c09dc5e2c05b7b17ae144751b410b9d67e2c3cc76a7b268dcfc0381ce9385bc5c3e8507f969e WHIRLPOOL 2fd974d4a2db04de2b1c6dbef320319dc33be553faf3dd7a40e5af20d2aecd245da35354fc6568f98e8fbb40da1e11eda41e60d6353c32664132fdd6a478e56d | ||||
| AUX gitlabhq-4.0.0-fix-wiki-pg.patch 2871 SHA256 c27f7ebd8614d217d824782dd65f9e2e12c7bc507a3eb01339a8a962279483f0 SHA512 6f86728574e495ab9604855be43a3739194b0f81ba9dd9dd3fdb76ca950400d1068119be4190612030cfe8e2c59cb771cc434dbe9cc0ad55329953178fe6d8fb WHIRLPOOL 4bb437cc63ad721a3826da4d796d2d79a79f140fa02a18b1d36cfa5b1caaea082888bd950ead666f24d5951ddbc9f81ef0d4914aae61dd262eae6e31dcb501ac | ||||
| AUX gitlabhq-4.0.0-google-analytics.patch 3490 SHA256 52eb67c29fa6f41e8776ce2ba8d86c098fa2583a827541aae7ffe5c496da42d7 SHA512 7a4d551e69d15dcd7f180c34381f98f80b76d6a0fa0b8d702d74bf0f6178b80bb6c9595e8d9ab3b56e4ede249532294adb8727c7bebb73fddf67e71e88117e8b WHIRLPOOL 85a62da7088c5e11d5a727ecf2057c831a4f3c8c42cc8a69c5d8778dfda495b351d72c45e73ced2e7876c7cb56a37eefaab125f32ca48fde3078c7e92e7a31fb | ||||
| AUX gitlabhq-4.0.0-performance.patch 6391 SHA256 7857a5f3c0789680cd3be2bfdea5981a97521726aac49430cbf9ef21069113a4 SHA512 573fb038c91eb7749f4fca50f8ef51f70895e5b695eabeb59553831850fe957c130f8e32aa3e866133d10ee3129b39e8fcfb7b6200b8f058a98989d8c1bfaec8 WHIRLPOOL 2f37d70ba9295bd38399e7411162ec339854ae283129df7e743054363eb4f7c130c1bd3cf1f93ccc97ab416bed1f9a86abcb398c2b979eada0cff89554ede96c | ||||
| AUX gitlabhq-4.0.0-public-projects.patch 5611 SHA256 e006809ab10496e31432496504f720a78a9cffc00f49f1b3ba267f323e0dc674 SHA512 d0e39b502504cd2d76419f57c1ea4061b8f9166317f11c1690df1c1bc41f278efbcd11a3762990a18a2141088c14c7446697559a95c1c5214487f179be099370 WHIRLPOOL 6d10625a101a8839f27be2dd9813126b9cee6f38267c345199ff51800c7c2e711add38c0d51667c80df68c5489d2c8404722ad69f0748d9ef86e25103a3aea51 | ||||
| AUX gitlabhq-4.0.0-r1-fix-gemfile.patch 3189 SHA256 f6efec5d8ed7533adade361efcbd0d485d5b7ca9d9dd9f4b4d3a30264804fcca SHA512 fbf4685db1501fc85d0dc16bbae614ebe21b4546dbde8cd52a0ca8b0be0b818c4737835d833e09cfc621edc70583bb7c8f002f28734ced3ffd0c8ae906467f44 WHIRLPOOL b92a8c3e7df5b97ffe21aad1ec4ceaf4a0904e5d758f8994b771e51218f0998fa8043d654d6a5cabfd0d2d82da9481caf640baf5e1f25395a7c7156798095320 | ||||
| AUX gitlabhq-6.0.2-r2-fix-gemfile.patch 2103 SHA256 f4d07fd2a8b59a7a89f3b522324f059ce00ce4292d1647d161d64d3c8fc27995 SHA512 dbd439d2338240622cd63e09703035bd676266edf1ceba90b402e78f500d3a80ef32a63ef1a178d12b0ca9f9e60e250b3c3e287772a6cba25d2371372b1e02af WHIRLPOOL 4fb037080c5d4051c9f38c2f3d32521ee5241cab6348ffabd9c8c606413526fc127a71e70079e296aaf34b055cdb874879cf46e1378617ac393669fbb5da90b8 | ||||
| AUX gitlabhq-6.0.2-r2-fix-project-name-regex.patch 1203 SHA256 9ffa0c164384c00de3953a57c1f3984fe08cfcd996216ea7fece0ffa70ea91d6 SHA512 04bc0d2940f551d8b8c283b402cfb992dcd34900154d15a9372c4b560d0d07900923268a24785cfa647894f6a3ade8a0db3f84075d1365387dd2ef6a2cf11bec WHIRLPOOL 21250714ea6e273e0133673171812b1725228a60c616eece52c7feaf1a475c40a633f96d25d7e7089f6a6670ad21eae85d4bdc8728c63b483eb6b813381606be | ||||
| AUX gitlabhq-6.0.2-r2-fix-sendmail-config.patch 731 SHA256 51f0d0af2a7c048d7cff56cf27955632f340ca67f9d460af840cf34ed60ca574 SHA512 b10d5b8d89927404d25345e17ba37ca4e7848b04c2ca20c5eef14eaac43d9ba14b62ae4c0d532eefaf6f9a2944578e84eb65a3420335d32495855c4807eec356 WHIRLPOOL 66f6443f311f2355ffd4efaea914f462816a1966a715b3b5ffaaa26b41bdced928b9905b8606f06fac3c2ccf20741553cfed2615430287bede01cf376aae2a60 | ||||
| AUX gitlabhq-6.0.2-r2-ldap-user-mapping.patch 7176 SHA256 202c21c2cc2ca26cabf648ba61d0269a73ea12dd8ea67f07c003c911620d4205 SHA512 40644e71f2977ef5fa26b260c151b96589ab57e5fbef5403614e22da0475f211f01569fe54865ea0ffb944431843dac02db997a5d5d64733dda3a878c9b09b97 WHIRLPOOL 7889c3052a370849b0a329dc8fa745e6f61754578807b2527312b3d09b34ec3c6c4bfc7a85315aff9e56488f6c66661ef025d5b2510e010266e935080214a0f4 | ||||
| AUX gitlabhq-6.4.3-fix-gemfile.patch 2168 SHA256 dafa8390b1b3421d174a4f3f4e1f4fcb65be4c972aae89c4cc0f61c8492a136c SHA512 123a8f2d893159f7da235a3b7c8913686bace04eb36dbee110ebddbfbc2c4a166338e41a030f86d4b5ae7e86fdb367035b3612e62a668e365ecde1ce2e16c39a WHIRLPOOL 2ee7c88d42273d1547cdb1f27c1fe550fe29003d5f308c61d57457723658675b7cfd91fdd37a095a30810e3e55cadc1ba1b080b679875ee4bf618fd563d8dfcc | ||||
| AUX gitlabhq-6.4.3-fix-project-name-regex.patch 1143 SHA256 6f12268ae65ea0fbb80a8eed0740f7270d22d2b17f7768d5d2f0feddf38301ea SHA512 3d70766c0cb0fda5f57235424633d507f30005edbf569b03af99965e26d758e7ecd3669f20c7f06350b277529f5be63e99814eed5ac74eacaec5a1f85199a25f WHIRLPOOL d2acb2ea30f44166e6164913d7345366ed9ff5646832240c6287745c1c86915b5661eaea68a3d842a363fff8301a4bcdaf71563d1c768d30c163fd396757f833 | ||||
| AUX gitlabhq-6.4.3-fix-sendmail-config.patch 731 SHA256 51f0d0af2a7c048d7cff56cf27955632f340ca67f9d460af840cf34ed60ca574 SHA512 b10d5b8d89927404d25345e17ba37ca4e7848b04c2ca20c5eef14eaac43d9ba14b62ae4c0d532eefaf6f9a2944578e84eb65a3420335d32495855c4807eec356 WHIRLPOOL 66f6443f311f2355ffd4efaea914f462816a1966a715b3b5ffaaa26b41bdced928b9905b8606f06fac3c2ccf20741553cfed2615430287bede01cf376aae2a60 | ||||
| AUX old/config.ssh 245 SHA256 5bf5d5a357e88b71e14a12bb28ea68d0286ed29118045aa944484b84b6fa5e4b SHA512 52dbec481cd45136e72370713ab20a41616dccb252e75b884b66e2494aaefe7795719169906dcad5030dcbe33201d021bdad1f7a99120ac40a64611290ff8759 WHIRLPOOL 9b991ad20787e0e7274136ddb8e22e1082360d580f8576feb722730b5c3f3fa22992f671f7916e191052a78d8d688d32044b39059dc7146d14c2da57fa891214 | ||||
| AUX old/gitlab-support.init 1188 SHA256 09059c391a5d5a8856030b4a50a9c8bb7d8fdb8f7ab75c1a869015bbff6a3a32 SHA512 25fe623e1d506a750897b4e100fcaddc654997a7cf23b7f1a6b4c3b77907cbe8af669cc38da86753696861e4fd14415ea7bc1decb0fdb500de1ef8a3e845860c WHIRLPOOL 169fab28b013762d3eaac4d8a37ded0ba6dedd9ebcd9fdd55347409f279d332a8d0326ec6eb66255c6f1d488c856c7135c60f3069972a7a07e55453e55bbe969 | ||||
| AUX old/gitlab-unicorn.init 1874 SHA256 8bede14eb7beaba955e64d0ff2928324992522e22e777aab33bf51d743c7ba4e SHA512 a8595a623cd724a3d2e3b95ea7216e2574d0beea75369a46dfd6c5483310675a827d08cda516dec0df7ccbff399d27e3dde0e0fae07d11eed6412b0d3f9ca8d9 WHIRLPOOL c619180431ee27b5fe724aaf6ed31bb9fcf8db3779d7879e79c7a04927ea7d4efcd363d5cc44184917bd4de8292267e93136de849e8892ffc1e2891aacb5f51c | ||||
| AUX old/gitlab.logrotate 191 SHA256 9c02c26f5faa443cd576599462c6a8206d62495ab9671098a5f0e379f216541b SHA512 2212a8e5f2d4704256d5abb92b5a1201b20f82b04610758e734d163792a60b78f482017510169666a70ed9352b171177d05237ffe87988cacb764c5ef7ba5443 WHIRLPOOL f61297015311316554e63af4822b8d274f5a2378e829e5c14bb22e642b0d83023446acff45a13aa354f127543ce1552c99488b92ed8f39d86959343c7e67bbee | ||||
| DIST gitlabhq-6.4.3.tar.gz 10979694 SHA256 a2df6ec3de927a45fdaec70b806f731d66694db54dc674cd8b3378703d28114b SHA512 df06c07434ca45273e4988827d11a287249f2f3baddd799c45fafc56661ba4e1d872536f233eac7ac5aa704ddae0bcc92850af926a07f42f399873e1eda4e8f7 WHIRLPOOL 33e6199f2955fcbe65177c4f0520ceeaed82b9c1df94721048eeb8cefc798b9c83beb66f8ddec3cc91a848ba056f39e633ffba2f588880828bcae4a52d560dbc | ||||
| EBUILD gitlabhq-6.4.3.ebuild 10556 SHA256 8384cc16e62d6cab2879a312bf185b686396c93ab16e04f5e2ce05a12a6d27e0 SHA512 e0858059f1421f4c55da91309184fb67087b5de06528dd5829d5c1c657b26bb96535d06860a067e182b2487602cfa17b7a4615d57512bd49d0e4dfa441b23c15 WHIRLPOOL 61e49b460c9254388353593101d26686c16f2d230828e8970e5384533a226e9e80033bf258badb0eca1b4c0e677b4405e693bb2f277f5eb9a53995f6a6101b47 | ||||
| EBUILD gitlabhq-6.4.3.ebuild 10673 SHA256 6856eeb5a2e778bc80237443fc997efd93c1ff60eda1ce6319a88298012c7eaf SHA512 130eb1b15eab517a5b80acfb51b888b4eb7fbe335c037df41b74dddd4f3d9d93f55aa0adb893b54f8f1e4e4f950fbcc278d2a5f142d76bea8535f78fd2f1f9d6 WHIRLPOOL 9531f4978c72c4a172c2fa6dd790c37e285169d2763e5d9da5b97755c4a9cb9710e45ff745ab4540873cbf7d591e538b14ebf1eb54469c57742f3c0935a976eb | ||||
|  |  | |||
|  | @ -1,10 +0,0 @@ | |||
| Host localhost | ||||
|   StrictHostKeyChecking no | ||||
|   UserKnownHostsFile=/dev/null | ||||
|   BatchMode yes | ||||
|   CheckHostIP no | ||||
|   AddressFamily inet | ||||
|   PreferredAuthentications publickey | ||||
|   ControlMaster auto | ||||
|   ControlPath ~/.ssh/ssh-%r-%h:%p.sock | ||||
|   ControlPersist 24h | ||||
|  | @ -1,50 +0,0 @@ | |||
| #!/sbin/runscript | ||||
| 
 | ||||
| name="GitLab support" | ||||
| description="Support for GitLab @SLOT@" | ||||
| 
 | ||||
| : ${gitlab_user:=@USER@} | ||||
| : ${gitlab_group:=@GROUP@} | ||||
| : ${gitlab_home:="@GITLAB_HOME@"} | ||||
| 
 | ||||
| : ${resque_pidfile:="/run/gitlab/resque_worker.pid"} | ||||
| : ${resque_log:="@LOG_DIR@/resque.log"} | ||||
| 
 | ||||
| : ${resque_queue:="@RESQUE_QUEUE@"} | ||||
| : ${rails_env:=production} | ||||
| 
 | ||||
| resque_command="/usr/bin/bundle" | ||||
| resque_command_args="exec rake environment resque:work QUEUE=${resque_queue} RAILS_ENV=${rails_env}" | ||||
| 
 | ||||
| if [ ${rails_env} = development ]; then | ||||
| 	resque_command_args+=" VVERBOSE=1" | ||||
| fi | ||||
| 
 | ||||
| depend() { | ||||
| 	provide gitlab | ||||
| 	need redis | ||||
| 	use net | ||||
| } | ||||
| 
 | ||||
| start() { | ||||
| 	ebegin "Starting GitLab @SLOT@ Resque worker" | ||||
| 
 | ||||
| 	checkpath -d -o "${gitlab_user}:${gitlab_group}" -m750 "$(dirname "${resque_pidfile}")" | ||||
| 
 | ||||
| 	start-stop-daemon --start \ | ||||
| 		--background --quiet \ | ||||
| 		--chdir "${gitlab_home}" \ | ||||
| 		--user="${gitlab_user}:${gitlab_group}" \ | ||||
| 		--make-pidfile --pidfile=${resque_pidfile} \ | ||||
| 		--stdout "${resque_log}" --stderr "${resque_log}" \ | ||||
| 		--exec ${resque_command} -- ${resque_command_args} | ||||
| 	eend $? | ||||
| } | ||||
| 
 | ||||
| stop() { | ||||
| 	ebegin "Stopping GitLab @SLOT@ Resque worker" | ||||
| 	start-stop-daemon --stop \ | ||||
| 		--pidfile=${resque_pidfile} \ | ||||
| 		--exec ${resque_command} | ||||
| 	eend $? | ||||
| } | ||||
|  | @ -1,69 +0,0 @@ | |||
| #!/sbin/runscript | ||||
| 
 | ||||
| name="GitLab" | ||||
| description="GitLab @SLOT@ on Unicorns" | ||||
| 
 | ||||
| : ${gitlab_user:=@USER@} | ||||
| : ${gitlab_group:=@GROUP@} | ||||
| : ${gitlab_home:="@GITLAB_HOME@"} | ||||
| 
 | ||||
| : ${server_pidfile:="/run/gitlab/unicorn.pid"} | ||||
| : ${rails_env:=production} | ||||
| 
 | ||||
| : ${resque_pidfile:="/run/gitlab/resque_worker.pid"} | ||||
| : ${resque_log:="/var/log/gitlab-4.0/resque.log"} | ||||
| : ${resque_queue:=@RESQUE_QUEUE@} | ||||
| 
 | ||||
| server_command="/usr/bin/bundle" | ||||
| server_command_args="exec unicorn_rails -c ${gitlab_home}/config/unicorn.rb -E ${rails_env} -D" | ||||
| resque_command="/usr/bin/bundle" | ||||
| resque_command_args="exec rake environment resque:work QUEUE=${resque_queue} RAILS_ENV=${rails_env}" | ||||
| 
 | ||||
| if [ ${rails_env} = development ]; then | ||||
| 	resque_command_args+=" VVERBOSE=1" | ||||
| fi | ||||
| 
 | ||||
| depend() { | ||||
| 	provide gitlab | ||||
| 	need redis | ||||
| 	use net | ||||
| } | ||||
| 
 | ||||
| start() { | ||||
| 	ebegin "Starting GitLab @SLOT@ Unicorn servers" | ||||
| 
 | ||||
| 	checkpath -d -o "${gitlab_user}:${gitlab_group}" -m750 "$(dirname "${server_pidfile}")" | ||||
| 	checkpath -d -o "${gitlab_user}:${gitlab_group}" -m750 "$(dirname "${resque_pidfile}")" | ||||
| 
 | ||||
| 	start-stop-daemon --start \ | ||||
| 		--chdir "${gitlab_home}" \ | ||||
| 		--user="${gitlab_user}:${gitlab_group}" \ | ||||
| 		--pidfile="${server_pidfile}" \ | ||||
| 		--exec ${server_command} -- ${server_command_args} | ||||
| 	eend $? | ||||
| 
 | ||||
| 	ebegin "Starting GitLab @SLOT@ Resque worker" | ||||
| 
 | ||||
| 	start-stop-daemon --start \ | ||||
| 		--background --quiet \ | ||||
| 		--chdir "${gitlab_home}" \ | ||||
| 		--user="${gitlab_user}:${gitlab_group}" \ | ||||
| 		--make-pidfile --pidfile=${resque_pidfile} \ | ||||
| 		--stdout "${resque_log}" --stderr "${resque_log}" \ | ||||
| 		--exec ${resque_command} -- ${resque_command_args} | ||||
| 	eend $? | ||||
| } | ||||
| 
 | ||||
| stop() { | ||||
| 	ebegin "Stopping GitLab @SLOT@ Resque worker" | ||||
| 	start-stop-daemon --stop \ | ||||
| 		--pidfile=${resque_pidfile} \ | ||||
| 		--exec ${resque_command} | ||||
| 	eend $? | ||||
| 
 | ||||
| 	ebegin "Stopping GitLab @SLOT@ Unicorn servers" | ||||
| 	start-stop-daemon --stop \ | ||||
| 		--pidfile=${server_pidfile} \ | ||||
| 		--exec ${server_command} -- ${server_command_args} | ||||
| 	eend $? | ||||
| } | ||||
|  | @ -1,10 +0,0 @@ | |||
| # Copyright 1999-2012 Gentoo Foundation | ||||
| # Distributed under the terms of the GNU General Public License v2 | ||||
| # $Header: $ | ||||
| 
 | ||||
| @LOG_DIR@/*.log { | ||||
| 	missingok | ||||
| 	delaycompress | ||||
| 	compress | ||||
| 	copytruncate | ||||
| } | ||||
|  | @ -1,58 +0,0 @@ | |||
| --- a/lib/tasks/gitlab/info.rake	2012-12-25 00:33:12.066872526 +0100
 | ||||
| +++ b/lib/tasks/gitlab/info.rake	2012-12-25 00:33:55.682878240 +0100
 | ||||
| @@ -12,6 +12,9 @@
 | ||||
|                      debian_version = File.read('/etc/debian_version') | ||||
|                      "Debian #{debian_version}" | ||||
|                    end | ||||
| +      os_name ||= if File.readable?('/etc/gentoo-release')
 | ||||
| +                    File.read('/etc/gentoo-release')
 | ||||
| +                  end
 | ||||
|        os_name.squish! | ||||
|   | ||||
|        # check if there is an RVM environment | ||||
| --- a/lib/tasks/gitlab/check.rake	2012-12-25 01:47:35.162380668 +0100
 | ||||
| +++ b/lib/tasks/gitlab/check.rake	2012-12-25 01:49:49.006346565 +0100
 | ||||
| @@ -20,8 +20,8 @@
 | ||||
|        check_gitlab_config_not_outdated | ||||
|        check_log_writable | ||||
|        check_tmp_writable | ||||
| -      check_init_script_exists
 | ||||
| -      check_init_script_up_to_date
 | ||||
| +#      check_init_script_exists
 | ||||
| +#      check_init_script_up_to_date
 | ||||
|        check_satellites_exist | ||||
|   | ||||
|        finished_checking "GitLab" | ||||
| @@ -254,7 +254,7 @@
 | ||||
|        start_checking "Environment" | ||||
|   | ||||
|        check_gitlab_in_git_group | ||||
| -      check_issue_1056_shell_profile_error
 | ||||
| +#      check_issue_1056_shell_profile_error --don't need on Gentoo
 | ||||
|        check_gitlab_git_config | ||||
|        check_python2_exists | ||||
|        check_python2_version | ||||
| @@ -542,7 +542,7 @@
 | ||||
|   | ||||
|      def check_gitolite_is_up_to_date | ||||
|        print "Using recommended version ... " | ||||
| -      if gitolite_version.try(:start_with?, "v3.04")
 | ||||
| +      if gitolite_version.try(:start_with?, "3.2")
 | ||||
|          puts "yes".green | ||||
|        else | ||||
|          puts "no".red | ||||
| @@ -838,11 +838,13 @@
 | ||||
|        gitolite_version_file = "#{gitolite_home}/gitolite/src/VERSION" | ||||
|        if File.readable?(gitolite_version_file) | ||||
|          File.read(gitolite_version_file) | ||||
| +      else
 | ||||
| +        run("equery -q list -F '$version' 'gitolite'")
 | ||||
|        end | ||||
|      end | ||||
|   | ||||
|      def has_gitolite3? | ||||
| -      gitolite_version.try(:start_with?, "v3.")
 | ||||
| +      gitolite_version.try(:start_with?, "3.")
 | ||||
|      end | ||||
|    end | ||||
|   | ||||
|  | @ -1,48 +0,0 @@ | |||
| diff --git a/Gemfile b/Gemfile
 | ||||
| index 49fbcad04fcdbb0d9a46c79e9185e10013c00f33..14b3553ffb8ae9bcb88c55b2d2772a926771cc55 100644
 | ||||
| --- a/Gemfile
 | ||||
| +++ b/Gemfile
 | ||||
| @@ -28,6 +28,9 @@ gem 'yaml_db',       git: "https://github.com/gitlabhq/yaml_db.git",        ref:
 | ||||
|  gem 'grack',         git: "https://github.com/gitlabhq/grack.git",          ref: 'ba46f3b0845c6a09d488ae6abdce6ede37e227e8' | ||||
|  gem 'grit_ext',      git: "https://github.com/gitlabhq/grit_ext.git",       ref: '8e6afc2da821354774aa4d1ee8a1aa2082f84a3e' | ||||
|   | ||||
| +# Patched to fix issues with compiling on Gentoo
 | ||||
| +gem "charlock_holmes", git: "https://github.com/ISSIntel/charlock_holmes.git", ref: '994dcf37aba066250750866e13bb51e3d5e72898'
 | ||||
| +
 | ||||
|  # Gitolite client (for work with gitolite-admin repo) | ||||
|  gem "gitolite", '1.1.0' | ||||
|   | ||||
| diff --git a/Gemfile.lock b/Gemfile.lock
 | ||||
| index d8be14ba80ab191d6001e601026d27cdfa8fbb54..60f98ef22a8daf77ef08b58c52fab8f0cf560b51 100644
 | ||||
| --- a/Gemfile.lock
 | ||||
| +++ b/Gemfile.lock
 | ||||
| @@ -6,6 +6,13 @@ GIT
 | ||||
|      database_cleaner (0.9.1) | ||||
|   | ||||
|  GIT | ||||
| +  remote: https://github.com/ISSIntel/charlock_holmes.git
 | ||||
| +  revision: 994dcf37aba066250750866e13bb51e3d5e72898
 | ||||
| +  ref: 994dcf37aba066250750866e13bb51e3d5e72898
 | ||||
| +  specs:
 | ||||
| +    charlock_holmes (0.6.9)
 | ||||
| +
 | ||||
| +GIT
 | ||||
|    remote: https://github.com/ctran/annotate_models.git | ||||
|    revision: be4e26825b521f0b2d86b181e2dff89901aa9b1e | ||||
|    specs: | ||||
| @@ -129,7 +136,6 @@ GEM
 | ||||
|      carrierwave (0.7.1) | ||||
|        activemodel (>= 3.2.0) | ||||
|        activesupport (>= 3.2.0) | ||||
| -    charlock_holmes (0.6.9)
 | ||||
|      childprocess (0.3.6) | ||||
|        ffi (~> 1.0, >= 1.0.6) | ||||
|      chosen-rails (0.9.8) | ||||
| @@ -461,6 +467,7 @@ DEPENDENCIES
 | ||||
|    bootstrap-sass (= 2.2.1.1) | ||||
|    capybara | ||||
|    carrierwave (~> 0.7.1) | ||||
| +  charlock_holmes!
 | ||||
|    chosen-rails (= 0.9.8) | ||||
|    coffee-rails (~> 3.2.2) | ||||
|    colored | ||||
|  | @ -1,29 +0,0 @@ | |||
| --- /dev/null	2012-12-22 21:17:05.856026005 +0100
 | ||||
| +++ /config/initializers/passenger_fix.rb	2013-01-01 23:11:18.717833817 +0100
 | ||||
| @@ -0,0 +1,26 @@
 | ||||
| +if defined?(PhusionPassenger)
 | ||||
| +
 | ||||
| +  # When you're using Passenger with smart-lv2 (default) or smart spawn method,
 | ||||
| +  # Resque doesn't recognize that it has been forked and should re-establish
 | ||||
| +  # Redis connection. You can see this error message in log:
 | ||||
| +  #   Redis::InheritedError, Tried to use a connection from a child process 
 | ||||
| +  #   without reconnecting. You need to reconnect to Redis after forking.
 | ||||
| +  # 
 | ||||
| +  # This solution is based on 
 | ||||
| +  # https://github.com/redis/redis-rb/wiki/redis-rb-on-Phusion-Passenger
 | ||||
| +  #
 | ||||
| +  PhusionPassenger.on_event(:starting_worker_process) do |forked|
 | ||||
| +    # do nothing if we're not in smart spawning mode
 | ||||
| +    return unless forked
 | ||||
| +
 | ||||
| +    # reconnect to Redis
 | ||||
| +    Resque.redis.client.reconnect
 | ||||
| +
 | ||||
| +    # reconnect to cache store unless :memory_store or :null_store is used
 | ||||
| +    unless [ActiveSupport::Cache::MemoryStore,
 | ||||
| +            ActiveSupport::Cache::NullStore].include? Rails.cache.class
 | ||||
| +      Rails.cache.instance_variable_get(:@data).reset
 | ||||
| +    end
 | ||||
| +  end
 | ||||
| +end
 | ||||
| +
 | ||||
|  | @ -1,13 +0,0 @@ | |||
| --- a/lib/tasks/resque.rake	2012-12-25 14:39:00.679594127 +0100
 | ||||
| +++ b/lib/tasks/resque.rake	2012-12-25 14:40:14.003591438 +0100
 | ||||
| @@ -3,6 +3,10 @@
 | ||||
|  task "resque:setup" => :environment do | ||||
|    Resque.after_fork do | ||||
|      Resque.redis.client.reconnect | ||||
| +
 | ||||
| +    # Without that you will see exception:
 | ||||
| +    #   'PGError: ERROR: prepared statement "a1" already exists'
 | ||||
| +    ActiveRecord::Base.establish_connection
 | ||||
|    end | ||||
|  end | ||||
|   | ||||
|  | @ -1,93 +0,0 @@ | |||
| diff --git a/app/controllers/wikis_controller.rb b/app/controllers/wikis_controller.rb
 | ||||
| index a93afe114df68c026716911fa49963a0c77db016..0be71d465a28779db3ed646df9ac116fea73e49a 100644
 | ||||
| --- a/app/controllers/wikis_controller.rb
 | ||||
| +++ b/app/controllers/wikis_controller.rb
 | ||||
| @@ -2,9 +2,9 @@ class WikisController < ProjectResourceController
 | ||||
|    before_filter :authorize_read_wiki! | ||||
|    before_filter :authorize_write_wiki!, only: [:edit, :create, :history] | ||||
|    before_filter :authorize_admin_wiki!, only: :destroy | ||||
| -  
 | ||||
| +
 | ||||
|    def pages | ||||
| -    @wikis = @project.wikis.group(:slug).order("created_at")
 | ||||
| +    @wikis = @project.wikis.last_revisions.order("created_at")
 | ||||
|    end | ||||
|   | ||||
|    def show | ||||
| @@ -49,7 +49,7 @@ class WikisController < ProjectResourceController
 | ||||
|    def history | ||||
|      @wikis = @project.wikis.where(slug: params[:id]).order("created_at") | ||||
|    end | ||||
| -  
 | ||||
| +
 | ||||
|    def destroy | ||||
|      @wikis = @project.wikis.where(slug: params[:id]).delete_all | ||||
|   | ||||
| diff --git a/app/models/wiki.rb b/app/models/wiki.rb
 | ||||
| index 252a97e8cca647dda190cec95f3a9bbe8129181e..53d52ec2a19760a7e6d37e38e8858c1ed92433cc 100644
 | ||||
| --- a/app/models/wiki.rb
 | ||||
| +++ b/app/models/wiki.rb
 | ||||
| @@ -47,6 +47,19 @@ class Wiki < ActiveRecord::Base
 | ||||
|      new_wiki | ||||
|    end | ||||
|   | ||||
| +  # Scope with last revisions of pages (i.e. newest page per project_id
 | ||||
| +  # and slug).
 | ||||
| +  #
 | ||||
| +  # return:
 | ||||
| +  # ActiveRecord::Relation
 | ||||
| +  #
 | ||||
| +  def self.last_revisions
 | ||||
| +    t1 = arel_table.alias(table_name + '1')
 | ||||
| +    where(
 | ||||
| +      id: from(t1).select(t1[:id].maximum).where(project_id: t1[:project_id], slug: t1[:slug])
 | ||||
| +    )
 | ||||
| +  end
 | ||||
| +
 | ||||
|    def set_slug | ||||
|      self.slug = self.title.parameterize | ||||
|    end | ||||
| diff --git a/spec/factories.rb b/spec/factories.rb
 | ||||
| index abc0d37470176e57eb8006e0af64dbb4fbbebb02..8357fe2127f358c3e82f06b9cc3c575e5d9ae6b2 100644
 | ||||
| --- a/spec/factories.rb
 | ||||
| +++ b/spec/factories.rb
 | ||||
| @@ -138,9 +138,10 @@ FactoryGirl.define do
 | ||||
|    end | ||||
|   | ||||
|    factory :wiki do | ||||
| -    title
 | ||||
| -    content
 | ||||
| +    sequence(:title) { |n| "wiki#{n}" }
 | ||||
| +    content "Content"
 | ||||
|      user | ||||
| +    project
 | ||||
|    end | ||||
|   | ||||
|    factory :snippet do | ||||
| diff --git a/spec/models/wiki_spec.rb b/spec/models/wiki_spec.rb
 | ||||
| index 9750b81d303ecd1105a6c2bbe2d6b76aa79edd5b..a8967e95b200f45e26374be419f90375870c8d4a 100644
 | ||||
| --- a/spec/models/wiki_spec.rb
 | ||||
| +++ b/spec/models/wiki_spec.rb
 | ||||
| @@ -32,4 +32,22 @@ describe Wiki do
 | ||||
|      it { should validate_presence_of(:content) } | ||||
|      it { should validate_presence_of(:user) } | ||||
|    end | ||||
| +
 | ||||
| +  describe "#last_revisions" do
 | ||||
| +    let(:project) { create(:project) }
 | ||||
| +    before do
 | ||||
| +      %w(p1 p2).each do |title|
 | ||||
| +        %w(old new).each do |content|
 | ||||
| +          create(:wiki, title: title, slug: title, project: project, content: content)
 | ||||
| +        end
 | ||||
| +      end
 | ||||
| +    end
 | ||||
| +    subject(:last_revisions) { project.wikis.last_revisions.all }
 | ||||
| +
 | ||||
| +    its(:count) { should == 2 }
 | ||||
| +    it "should return each page once" do
 | ||||
| +      last_revisions.map(&:title).should =~ %w(p1 p2)
 | ||||
| +    end
 | ||||
| +  end
 | ||||
| +
 | ||||
|  end | ||||
|  | @ -1,81 +0,0 @@ | |||
| diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb
 | ||||
| index 52715a265bd49e0cc54a0f524351c15a70ea3c66..359d5cdaef52cd27322c9dfd71890c46c9f16bc7 100644
 | ||||
| --- a/app/helpers/application_helper.rb
 | ||||
| +++ b/app/helpers/application_helper.rb
 | ||||
| @@ -160,4 +160,8 @@ module ApplicationHelper
 | ||||
|      image_tag("authbuttons/#{file_name}", | ||||
|                alt: "Sign in with #{provider.to_s.titleize}") | ||||
|    end | ||||
| +
 | ||||
| +  def analytics_enable?
 | ||||
| +    Gitlab.config.analytics.enabled and Rails.env.production?
 | ||||
| +  end
 | ||||
|  end | ||||
| diff --git a/app/views/layouts/_head.html.haml b/app/views/layouts/_head.html.haml
 | ||||
| index 4a0f60d36c26b5f5eb3a02d44a7da39bacaae04b..013ff6d15e02ea1e0c08b06b391fe865e7ba94f5 100644
 | ||||
| --- a/app/views/layouts/_head.html.haml
 | ||||
| +++ b/app/views/layouts/_head.html.haml
 | ||||
| @@ -15,3 +15,4 @@
 | ||||
|      - if current_controller?(:issues) | ||||
|        = auto_discovery_link_tag(:atom, project_issues_url(@project, :atom, private_token: current_user.private_token), title: "#{@project.name} issues") | ||||
|    = csrf_meta_tags | ||||
| +  = render "shared/google_analytics" if analytics_enable?
 | ||||
| diff --git a/app/views/shared/_google_analytics.html.haml b/app/views/shared/_google_analytics.html.haml
 | ||||
| new file mode 100644 | ||||
| index 0000000000000000000000000000000000000000..e8d4b9146680fb4da666d1462881f991bb1661fe
 | ||||
| --- /dev/null
 | ||||
| +++ b/app/views/shared/_google_analytics.html.haml
 | ||||
| @@ -0,0 +1,9 @@
 | ||||
| +:javascript
 | ||||
| +  var _gaq = _gaq || [];
 | ||||
| +  _gaq.push(['_setAccount', '#{ Gitlab.config.analytics.tracking_id }']);
 | ||||
| +  _gaq.push(['_trackPageview']);
 | ||||
| +  (function() {
 | ||||
| +    var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
 | ||||
| +    ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
 | ||||
| +    var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
 | ||||
| +  })();
 | ||||
| diff --git a/config/gitlab.yml.example b/config/gitlab.yml.example
 | ||||
| index f47625eb132ab304a71e35bf2ccf998fbe413c1f..3a603159cfab83ce078f839cf8c14ddf934dd837 100644
 | ||||
| --- a/config/gitlab.yml.example
 | ||||
| +++ b/config/gitlab.yml.example
 | ||||
| @@ -1,4 +1,4 @@
 | ||||
| -# # # # # # # # # # # # # # # # # # 
 | ||||
| +# # # # # # # # # # # # # # # # # #
 | ||||
|  # Gitlab application config file  # | ||||
|  # # # # # # # # # # # # # # # # # # | ||||
|  # | ||||
| @@ -109,3 +109,13 @@ git:
 | ||||
|    max_size: 5242880 # 5.megabytes | ||||
|    # Git timeout to read commit, in seconds | ||||
|    timeout: 10 | ||||
| +  git_timeout: 10
 | ||||
| +
 | ||||
| +#
 | ||||
| +# 4. Other settings:
 | ||||
| +# ==========================
 | ||||
| +
 | ||||
| +# Google Analytics
 | ||||
| +analytics:
 | ||||
| +  enabled: false
 | ||||
| +  tracking_id: '_your_tracking_id'
 | ||||
| diff --git a/config/initializers/1_settings.rb b/config/initializers/1_settings.rb
 | ||||
| index 4fe3ced4d8d1f7021a4e8cc8064a1ceaf74d65bc..6699c7f896781da77ecc4e525a7acf53b12c80cb 100644
 | ||||
| --- a/config/initializers/1_settings.rb
 | ||||
| +++ b/config/initializers/1_settings.rb
 | ||||
| @@ -266,8 +266,6 @@ class Settings < Settingslogic
 | ||||
|        app['gravatar_ssl_url'] || 'https://secure.gravatar.com/avatar/%{hash}?s=%{size}&d=mm' | ||||
|      end | ||||
|   | ||||
| -
 | ||||
| -
 | ||||
|      def gitlab_on_non_standard_port? | ||||
|        ![443, 80].include?(gitlab.port.to_i) | ||||
|      end | ||||
| @@ -350,3 +348,6 @@ Settings.git['max_size']  ||= Settings.pre_40_config ? Settings.git_max_size : 5
 | ||||
|  Settings.git['bin_path']  ||= Settings.pre_40_config ? Settings.git_bin_path : '/usr/bin/git' | ||||
|  Settings.git['timeout']   ||= Settings.pre_40_config ? Settings.git_timeout : 10 | ||||
|  Settings.git['path']      ||= Settings.git.bin_path # FIXME: Deprecated: remove for 4.1 | ||||
| +
 | ||||
| +Settings['analytics'] ||= Settingslogic.new({})
 | ||||
| +Settings.analytics['enabled'] ||= false
 | ||||
|  | @ -1,190 +0,0 @@ | |||
| diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb
 | ||||
| --- a/app/helpers/application_helper.rb
 | ||||
| +++ b/app/helpers/application_helper.rb
 | ||||
| @@ -147,9 +147,8 @@ module ApplicationHelper
 | ||||
|    end | ||||
|   | ||||
|    def project_last_activity project | ||||
| -    activity = project.last_activity
 | ||||
| -    if activity && activity.created_at
 | ||||
| -      time_ago_in_words(activity.created_at) + " ago"
 | ||||
| +    if project.last_activity_date != project.created_at
 | ||||
| +      time_ago_in_words(project.last_activity_date) + " ago"
 | ||||
|      else | ||||
|        "Never" | ||||
|      end | ||||
| diff --git a/app/models/event.rb b/app/models/event.rb
 | ||||
| --- a/app/models/event.rb
 | ||||
| +++ b/app/models/event.rb
 | ||||
| @@ -38,7 +38,7 @@ class Event < ActiveRecord::Base
 | ||||
|    delegate :title, to: :merge_request, prefix: true, allow_nil: true | ||||
|   | ||||
|    belongs_to :author, class_name: "User" | ||||
| -  belongs_to :project
 | ||||
| +  belongs_to :project, touch: true
 | ||||
|    belongs_to :target, polymorphic: true | ||||
|   | ||||
|    # For Hash only | ||||
| diff --git a/app/models/project.rb b/app/models/project.rb
 | ||||
| --- a/app/models/project.rb
 | ||||
| +++ b/app/models/project.rb
 | ||||
| @@ -227,7 +227,8 @@ class Project < ActiveRecord::Base
 | ||||
|    end | ||||
|   | ||||
|    def last_activity_date | ||||
| -    last_event.try(:created_at) || updated_at
 | ||||
| +    # touched when any associated event is saved
 | ||||
| +    updated_at
 | ||||
|    end | ||||
|   | ||||
|    def project_id | ||||
| diff --git a/db/migrate/20121227190440_touch_projects_last_activity.rb b/db/migrate/20121227190440_touch_projects_last_activity.rb
 | ||||
| --- /dev/null
 | ||||
| +++ b/db/migrate/20121227190440_touch_projects_last_activity.rb
 | ||||
| @@ -0,0 +1,18 @@
 | ||||
| +class TouchProjectsLastActivity < ActiveRecord::Migration
 | ||||
| +  def up
 | ||||
| +    Project.record_timestamps = false
 | ||||
| +
 | ||||
| +    Project.find_each do |project|
 | ||||
| +      last_event = project.events.order(:created_at).last
 | ||||
| +      if last_event and last_event.created_at > project.updated_at
 | ||||
| +        project.update_attribute(:updated_at, last_event.created_at)
 | ||||
| +      end
 | ||||
| +    end
 | ||||
| +
 | ||||
| +    Project.record_timestamps = true
 | ||||
| +  end
 | ||||
| +
 | ||||
| +  def down
 | ||||
| +    raise ActiveRecord::IrreversibleMigration
 | ||||
| +  end
 | ||||
| +end
 | ||||
| diff --git a/db/schema.rb b/db/schema.rb
 | ||||
| --- a/db/schema.rb
 | ||||
| +++ b/db/schema.rb
 | ||||
| @@ -11,7 +11,7 @@
 | ||||
|  # | ||||
|  # It's strongly recommended to check this file into your version control system. | ||||
|   | ||||
| -ActiveRecord::Schema.define(:version => 20121219095402) do
 | ||||
| +ActiveRecord::Schema.define(:version => 20121227190440) do
 | ||||
|   | ||||
|    create_table "events", :force => true do |t| | ||||
|      t.string   "target_type" | ||||
| diff --git a/spec/models/event_spec.rb b/spec/models/event_spec.rb
 | ||||
| --- a/spec/models/event_spec.rb
 | ||||
| +++ b/spec/models/event_spec.rb
 | ||||
| @@ -30,6 +30,17 @@ describe Event do
 | ||||
|      it { should respond_to(:commits) } | ||||
|    end | ||||
|   | ||||
| +  describe "Save" do
 | ||||
| +    let(:event) { create(:event) }
 | ||||
| +    let(:project) { create(:project) }
 | ||||
| +
 | ||||
| +    it "should touch associated project" do
 | ||||
| +      event.stub(project: project)
 | ||||
| +      event.project.should_receive(:touch)
 | ||||
| +      event.save!
 | ||||
| +    end
 | ||||
| +  end
 | ||||
| +
 | ||||
|    describe "Push event" do | ||||
|      before do | ||||
|        project = create(:project) | ||||
| diff --git a/spec/models/project_spec.rb b/spec/models/project_spec.rb
 | ||||
| --- a/spec/models/project_spec.rb
 | ||||
| +++ b/spec/models/project_spec.rb
 | ||||
| @@ -163,22 +163,18 @@ describe Project do
 | ||||
|   | ||||
|    describe "last_activity methods" do | ||||
|      let(:project)    { create(:project) } | ||||
| -    let(:last_event) { double(created_at: Time.now) }
 | ||||
| +    let(:last_event) { create(:event) }
 | ||||
|   | ||||
|      describe "last_activity" do | ||||
| -      it "should alias last_activity to last_event"do
 | ||||
| +      it "should alias last_activity to last_event" do
 | ||||
|          project.stub(last_event: last_event) | ||||
|          project.last_activity.should == last_event | ||||
|        end | ||||
|      end | ||||
|   | ||||
| -    describe 'last_activity_date' do
 | ||||
| -      it 'returns the creation date of the project\'s last event if present' do
 | ||||
| -        project.stub(last_event: last_event)
 | ||||
| -        project.last_activity_date.should == last_event.created_at
 | ||||
| -      end
 | ||||
| -
 | ||||
| -      it 'returns the project\'s last update date if it has no events' do
 | ||||
| +    describe "last_activity_date" do
 | ||||
| +      it "should alias last_activity_date to updated_at" do
 | ||||
| +        project.stub(updated_at: Time.now)
 | ||||
|          project.last_activity_date.should == project.updated_at | ||||
|        end | ||||
|      end | ||||
| diff --git a/app/roles/authority.rb b/app/roles/authority.rb
 | ||||
| --- a/app/roles/authority.rb
 | ||||
| +++ b/app/roles/authority.rb
 | ||||
| @@ -19,21 +19,25 @@ module Authority
 | ||||
|    end | ||||
|   | ||||
|    def repository_readers | ||||
| -    keys = Key.joins({user: :users_projects}).
 | ||||
| -      where("users_projects.project_id = ? AND users_projects.project_access = ?", id, UsersProject::REPORTER)
 | ||||
| -    keys.map(&:identifier) + deploy_keys.map(&:identifier)
 | ||||
| +    repository_members[UsersProject::REPORTER]
 | ||||
|    end | ||||
|   | ||||
|    def repository_writers | ||||
| -    keys = Key.joins({user: :users_projects}).
 | ||||
| -      where("users_projects.project_id = ? AND users_projects.project_access = ?", id, UsersProject::DEVELOPER)
 | ||||
| -    keys.map(&:identifier)
 | ||||
| +    repository_members[UsersProject::DEVELOPER]
 | ||||
|    end | ||||
|   | ||||
|    def repository_masters | ||||
| -    keys = Key.joins({user: :users_projects}).
 | ||||
| -      where("users_projects.project_id = ? AND users_projects.project_access = ?", id, UsersProject::MASTER)
 | ||||
| -    keys.map(&:identifier)
 | ||||
| +    repository_members[UsersProject::MASTER]
 | ||||
| +  end
 | ||||
| +
 | ||||
| +  def repository_members
 | ||||
| +    keys = Hash.new {|h,k| h[k] = [] }
 | ||||
| +    UsersProject.select("keys.identifier, project_access").
 | ||||
| +        joins(user: :keys).where(project_id: id).
 | ||||
| +        each {|row| keys[row.project_access] << [row.identifier] }
 | ||||
| +
 | ||||
| +    keys[UsersProject::REPORTER] += deploy_keys.pluck(:identifier)
 | ||||
| +    keys
 | ||||
|    end | ||||
|   | ||||
|    def allow_read_for?(user) | ||||
| diff --git a/app/views/events/_event.html.haml b/app/views/events/_event.html.haml
 | ||||
| --- a/app/views/events/_event.html.haml
 | ||||
| +++ b/app/views/events/_event.html.haml
 | ||||
| @@ -2,14 +2,14 @@
 | ||||
|    %div.event-item | ||||
|      %span.cgray.right | ||||
|        #{time_ago_in_words(event.created_at)} ago. | ||||
| +    - cache event do
 | ||||
| +      = image_tag gravatar_icon(event.author_email), class: "avatar s24"
 | ||||
|   | ||||
| -    = image_tag gravatar_icon(event.author_email), class: "avatar s24"
 | ||||
| -
 | ||||
| -    - if event.push?
 | ||||
| -      = render "events/event/push", event: event
 | ||||
| -      .clearfix
 | ||||
| -    - elsif event.note?
 | ||||
| -      = render "events/event/note", event: event
 | ||||
| -    - else
 | ||||
| -      = render "events/event/common", event: event
 | ||||
| +      - if event.push?
 | ||||
| +        = render "events/event/push", event: event
 | ||||
| +        .clearfix
 | ||||
| +      - elsif event.note?
 | ||||
| +        = render "events/event/note", event: event
 | ||||
| +      - else
 | ||||
| +        = render "events/event/common", event: event
 | ||||
|  | @ -1,141 +0,0 @@ | |||
| diff --git a/app/controllers/dashboard_controller.rb b/app/controllers/dashboard_controller.rb
 | ||||
| index 1fcadbfefbaf4d015d68ab7bc349f67becb717df..9d6a9449fcdcfbd138c7f8d4feb1e6b0e5a11926 100644
 | ||||
| --- a/app/controllers/dashboard_controller.rb
 | ||||
| +++ b/app/controllers/dashboard_controller.rb
 | ||||
| @@ -14,6 +14,8 @@ class DashboardController < ApplicationController
 | ||||
|                    @projects.personal(current_user) | ||||
|                  when 'joined' then | ||||
|                    @projects.joined(current_user) | ||||
| +                when 'public' then
 | ||||
| +                  @projects.public_only
 | ||||
|                  else | ||||
|                    @projects | ||||
|                  end | ||||
| diff --git a/app/models/ability.rb b/app/models/ability.rb
 | ||||
| index 2d80c6720b79da74ae9e4d20d816b2433f3082a8..946ec1e1128da3f55ac9b7198b6c0fbdc1d4aba7 100644
 | ||||
| --- a/app/models/ability.rb
 | ||||
| +++ b/app/models/ability.rb
 | ||||
| @@ -27,6 +27,8 @@ class Ability
 | ||||
|   | ||||
|        elsif project.guest_access_for?(user) | ||||
|          rules << project_guest_rules | ||||
| +      elsif project.public?
 | ||||
| +        rules << project_public_rules
 | ||||
|        end | ||||
|   | ||||
|        if project.namespace | ||||
| @@ -104,6 +106,10 @@ class Ability
 | ||||
|        ] | ||||
|      end | ||||
|   | ||||
| +    def project_public_rules
 | ||||
| +      project_report_rules
 | ||||
| +    end
 | ||||
| +
 | ||||
|      def group_abilities user, group | ||||
|        rules = [] | ||||
|   | ||||
| diff --git a/app/models/project.rb b/app/models/project.rb
 | ||||
| index 3e5c912e0b47a22cc5489b9cbfb1dd53da5095e9..f10a6afde27ce4226677c0aa28aabd7497fb4a9d 100644
 | ||||
| --- a/app/models/project.rb
 | ||||
| +++ b/app/models/project.rb
 | ||||
| @@ -30,7 +30,7 @@ class Project < ActiveRecord::Base
 | ||||
|    class TransferError < StandardError; end | ||||
|   | ||||
|    attr_accessible :name, :path, :description, :default_branch, :issues_enabled, | ||||
| -                  :wall_enabled, :merge_requests_enabled, :wiki_enabled, as: [:default, :admin]
 | ||||
| +                  :wall_enabled, :merge_requests_enabled, :wiki_enabled, :private_flag, as: [:default, :admin]
 | ||||
|   | ||||
|    attr_accessible :namespace_id, :owner_id, as: :admin | ||||
|   | ||||
| @@ -87,7 +87,7 @@ class Project < ActiveRecord::Base
 | ||||
|    class << self | ||||
|      def authorized_for user | ||||
|        projects = includes(:users_projects, :namespace) | ||||
| -      projects = projects.where("users_projects.user_id = :user_id or projects.owner_id = :user_id or namespaces.owner_id = :user_id", user_id: user.id)
 | ||||
| +      projects = projects.where("users_projects.user_id = :user_id or projects.owner_id = :user_id or namespaces.owner_id = :user_id or projects.private_flag = false", user_id: user.id)
 | ||||
|      end | ||||
|   | ||||
|      def active | ||||
| diff --git a/app/roles/authority.rb b/app/roles/authority.rb
 | ||||
| --- a/app/roles/authority.rb
 | ||||
| +++ b/app/roles/authority.rb
 | ||||
| @@ -20,2 +20,3 @@ module Authority
 | ||||
|   | ||||
|    def repository_readers | ||||
| +    return ['@all'] if public?
 | ||||
| diff --git a/app/views/admin/projects/_form.html.haml b/app/views/admin/projects/_form.html.haml
 | ||||
| index 27c22872d501456bc4b7fd4bfd2a31c45b0a0a53..793f6a22ac3a96540c4f18e518d2197de51482bf 100644
 | ||||
| --- a/app/views/admin/projects/_form.html.haml
 | ||||
| +++ b/app/views/admin/projects/_form.html.haml
 | ||||
| @@ -24,6 +24,10 @@
 | ||||
|          = f.label :default_branch, "Default Branch" | ||||
|          .input= f.select(:default_branch, project.heads.map(&:name), {}, style: "width:210px;") | ||||
|   | ||||
| +    .clearfix
 | ||||
| +      = f.label :private_flag, "Private"
 | ||||
| +      .input= f.check_box :private_flag
 | ||||
| +
 | ||||
|    %fieldset.adv_settings | ||||
|      %legend Features: | ||||
|   | ||||
| diff --git a/app/views/admin/projects/show.html.haml b/app/views/admin/projects/show.html.haml
 | ||||
| index 634b1836754a026cd26a32a30e4b0745629fc1e5..7bcedf6156e341ce7be48bee56cf1087ba63ccdb 100644
 | ||||
| --- a/app/views/admin/projects/show.html.haml
 | ||||
| +++ b/app/views/admin/projects/show.html.haml
 | ||||
| @@ -102,6 +102,13 @@
 | ||||
|      %td | ||||
|        = check_box_tag :post_receive_file, 1, @project.has_post_receive_file?, disabled: true | ||||
|   | ||||
| +  %tr
 | ||||
| +    %td
 | ||||
| +      %b
 | ||||
| +        Private:
 | ||||
| +    %td
 | ||||
| +      = check_box_tag :private_flag, 1, @project.private?, disabled: true
 | ||||
| +
 | ||||
|  %br | ||||
|  %h5 | ||||
|    Team | ||||
| diff --git a/app/views/dashboard/_projects.html.haml b/app/views/dashboard/_projects.html.haml
 | ||||
| index cffafb5445c2b476018974c500f3e924dd8ee9c7..058e13f1741a52aedf7632052f745bf52ee00bbe 100644
 | ||||
| --- a/app/views/dashboard/_projects.html.haml
 | ||||
| +++ b/app/views/dashboard/_projects.html.haml
 | ||||
| @@ -15,6 +15,8 @@
 | ||||
|        = link_to "Personal", dashboard_path(scope: 'personal') | ||||
|      = nav_tab :scope, 'joined' do | ||||
|        = link_to "Joined", dashboard_path(scope: 'joined') | ||||
| +    = nav_tab :scope, 'public' do
 | ||||
| +      = link_to "Public", dashboard_path(scope: 'public')
 | ||||
|   | ||||
|    %ul.well-list | ||||
|      - projects.each do |project| | ||||
| diff --git a/app/views/projects/_form.html.haml b/app/views/projects/_form.html.haml
 | ||||
| index 7044d1f20be1183c446de80268903f3018b7646e..2073b78d0606b688ffda69209130a4fb9f6d513c 100644
 | ||||
| --- a/app/views/projects/_form.html.haml
 | ||||
| +++ b/app/views/projects/_form.html.haml
 | ||||
| @@ -23,6 +23,11 @@
 | ||||
|          = f.label :default_branch, "Default Branch" | ||||
|          .input= f.select(:default_branch, @project.heads.map(&:name), {}, style: "width:210px;") | ||||
|   | ||||
| +    .control-group
 | ||||
| +      = f.label :private_flag, "Private"
 | ||||
| +      .controls
 | ||||
| +        = f.check_box :private_flag
 | ||||
| +
 | ||||
|    %fieldset.features | ||||
|      %legend Features: | ||||
|   | ||||
| diff --git a/spec/models/project_spec.rb b/spec/models/project_spec.rb
 | ||||
| index 83a769760987b719e10892723c78ae797bed01d0..31ce053a7657d3d834a99d33faa5c6ebdfa03fbe 100644
 | ||||
| --- a/spec/models/project_spec.rb
 | ||||
| +++ b/spec/models/project_spec.rb
 | ||||
| @@ -42,7 +42,7 @@ describe Project do
 | ||||
|    describe "Mass assignment" do | ||||
|      it { should_not allow_mass_assignment_of(:namespace_id) } | ||||
|      it { should_not allow_mass_assignment_of(:owner_id) } | ||||
| -    it { should_not allow_mass_assignment_of(:private_flag) }
 | ||||
| +    it { should allow_mass_assignment_of(:private_flag) }
 | ||||
|    end | ||||
|   | ||||
|    describe "Validation" do | ||||
|  | @ -1,105 +0,0 @@ | |||
| --- a/Gemfile	2012-12-23 12:58:41.000000000 +0100
 | ||||
| +++ b/Gemfile	2013-01-02 01:05:20.267204968 +0100
 | ||||
| @@ -14,6 +14,9 @@
 | ||||
|  gem "mysql2", group: :mysql | ||||
|  gem "pg", group: :postgres | ||||
|   | ||||
| +# Cache store adapter for Memcached
 | ||||
| +gem "dalli", group: :memcached
 | ||||
| +
 | ||||
|  # Auth | ||||
|  gem "devise", "~> 2.1.0" | ||||
|  gem 'omniauth', "~> 1.1.1" | ||||
| @@ -28,8 +31,12 @@
 | ||||
|  gem 'grack',         git: "https://github.com/gitlabhq/grack.git",          ref: 'ba46f3b0845c6a09d488ae6abdce6ede37e227e8' | ||||
|  gem 'grit_ext',      git: "https://github.com/gitlabhq/grit_ext.git",       ref: '8e6afc2da821354774aa4d1ee8a1aa2082f84a3e' | ||||
|   | ||||
| +# Patched to fix issues with compiling on Gentoo
 | ||||
| +gem "charlock_holmes", git: "https://github.com/ISSIntel/charlock_holmes.git", ref: '994dcf37aba066250750866e13bb51e3d5e72898'
 | ||||
| +
 | ||||
|  # Gitolite client (for work with gitolite-admin repo) | ||||
| -gem "gitolite", '1.1.0'
 | ||||
| +# Forked version with important performance patch (will be merged to upstream soon)
 | ||||
| +gem "gitolite",      git: "git://github.com/jirutka/gitolite.git",          ref: '75d64ea15aa51557034fae44c578438f85249f1e'
 | ||||
|   | ||||
|  # Syntax highlighter | ||||
|  gem "pygments.rb",  git: "https://github.com/gitlabhq/pygments.rb.git", branch: "master" | ||||
| --- a/Gemfile.lock	2012-12-23 12:58:41.000000000 +0100
 | ||||
| +++ b/Gemfile.lock	2013-01-02 01:05:20.271204975 +0100
 | ||||
| @@ -1,4 +1,14 @@
 | ||||
|  GIT | ||||
| +  remote: git://github.com/jirutka/gitolite.git
 | ||||
| +  revision: 75d64ea15aa51557034fae44c578438f85249f1e
 | ||||
| +  ref: 75d64ea15aa51557034fae44c578438f85249f1e
 | ||||
| +  specs:
 | ||||
| +    gitolite (1.1.0)
 | ||||
| +      gratr19 (~> 0.4.4.1)
 | ||||
| +      grit (~> 2.5.0)
 | ||||
| +      hashery (~> 1.5.0)
 | ||||
| +
 | ||||
| +GIT
 | ||||
|    remote: https://github.com/bmabey/database_cleaner.git | ||||
|    revision: f89c34300e114be99532f14c115b2799a3380ac6 | ||||
|    ref: f89c34300e114be99532f14c115b2799a3380ac6 | ||||
| @@ -6,6 +16,13 @@
 | ||||
|      database_cleaner (0.9.1) | ||||
|   | ||||
|  GIT | ||||
| +  remote: https://github.com/ISSIntel/charlock_holmes.git
 | ||||
| +  revision: 994dcf37aba066250750866e13bb51e3d5e72898
 | ||||
| +  ref: 994dcf37aba066250750866e13bb51e3d5e72898
 | ||||
| +  specs:
 | ||||
| +    charlock_holmes (0.6.9)
 | ||||
| +
 | ||||
| +GIT
 | ||||
|    remote: https://github.com/ctran/annotate_models.git | ||||
|    revision: be4e26825b521f0b2d86b181e2dff89901aa9b1e | ||||
|    specs: | ||||
| @@ -129,7 +146,6 @@
 | ||||
|      carrierwave (0.7.1) | ||||
|        activemodel (>= 3.2.0) | ||||
|        activesupport (>= 3.2.0) | ||||
| -    charlock_holmes (0.6.9)
 | ||||
|      childprocess (0.3.6) | ||||
|        ffi (~> 1.0, >= 1.0.6) | ||||
|      chosen-rails (0.9.8) | ||||
| @@ -147,6 +163,7 @@
 | ||||
|      colorize (0.5.8) | ||||
|      crack (0.3.1) | ||||
|      daemons (1.1.9) | ||||
| +    dalli (2.6.0)
 | ||||
|      devise (2.1.2) | ||||
|        bcrypt-ruby (~> 3.0) | ||||
|        orm_adapter (~> 0.1) | ||||
| @@ -190,10 +207,6 @@
 | ||||
|        pygments.rb (>= 0.2.13) | ||||
|      github-markup (0.7.4) | ||||
|      gitlab_meta (4.0) | ||||
| -    gitolite (1.1.0)
 | ||||
| -      gratr19 (~> 0.4.4.1)
 | ||||
| -      grit (~> 2.5.0)
 | ||||
| -      hashery (~> 1.5.0)
 | ||||
|      grape (0.2.2) | ||||
|        activesupport | ||||
|        hashie (~> 1.2) | ||||
| @@ -461,9 +474,11 @@
 | ||||
|    bootstrap-sass (= 2.2.1.1) | ||||
|    capybara | ||||
|    carrierwave (~> 0.7.1) | ||||
| +  charlock_holmes!
 | ||||
|    chosen-rails (= 0.9.8) | ||||
|    coffee-rails (~> 3.2.2) | ||||
|    colored | ||||
| +  dalli
 | ||||
|    database_cleaner! | ||||
|    devise (~> 2.1.0) | ||||
|    draper (~> 0.18.0) | ||||
| @@ -477,7 +492,7 @@
 | ||||
|    github-linguist (~> 2.3.4) | ||||
|    github-markup (~> 0.7.4) | ||||
|    gitlab_meta (= 4.0) | ||||
| -  gitolite (= 1.1.0)
 | ||||
| +  gitolite!
 | ||||
|    grack! | ||||
|    grape (~> 0.2.1) | ||||
|    grit! | ||||
|  | @ -1,82 +0,0 @@ | |||
| --- a/Gemfile	2013-09-10 00:16:33.951426871 +0200
 | ||||
| +++ b/Gemfile	2013-09-10 01:02:00.745109650 +0200
 | ||||
| @@ -120,11 +120,14 @@
 | ||||
|  # Sanitize user input | ||||
|  gem "sanitize" | ||||
|   | ||||
| +# The newer revision of charlock_holmes that is finally fixed to 
 | ||||
| +# be compatible with Gentoo
 | ||||
| +gem "charlock_holmes", git: "https://github.com/brianmario/charlock_holmes.git", ref: "dde194609b3513b0d2369ce8f916ae52566154b4"
 | ||||
| +
 | ||||
|  group :assets do | ||||
|    gem "sass-rails" | ||||
|    gem "coffee-rails" | ||||
|    gem "uglifier" | ||||
| -  gem "therubyracer"
 | ||||
|    gem 'turbolinks' | ||||
|    gem 'jquery-turbolinks' | ||||
|   | ||||
| --- a/Gemfile.lock	2013-09-10 00:16:40.079441559 +0200
 | ||||
| +++ b/Gemfile.lock	2013-09-10 01:03:51.837297421 +0200
 | ||||
| @@ -1,4 +1,11 @@
 | ||||
|  GIT | ||||
| +  remote: https://github.com/brianmario/charlock_holmes.git
 | ||||
| +  revision: dde194609b3513b0d2369ce8f916ae52566154b4
 | ||||
| +  ref: dde194609b3513b0d2369ce8f916ae52566154b4
 | ||||
| +  specs:
 | ||||
| +    charlock_holmes (0.6.9.4)
 | ||||
| +
 | ||||
| +GIT
 | ||||
|    remote: https://github.com/ctran/annotate_models.git | ||||
|    revision: 18a4e2eb77c8f3ef695b563e4a7ca45dfede819b | ||||
|    specs: | ||||
| @@ -69,7 +76,6 @@
 | ||||
|        activesupport (>= 3.2.0) | ||||
|      celluloid (0.14.1) | ||||
|        timers (>= 1.0.0) | ||||
| -    charlock_holmes (0.6.9.4)
 | ||||
|      childprocess (0.3.9) | ||||
|        ffi (~> 1.0, >= 1.0.11) | ||||
|      chosen-rails (1.0.0) | ||||
| @@ -271,7 +277,6 @@
 | ||||
|        addressable (~> 2.3) | ||||
|      letter_opener (1.1.1) | ||||
|        launchy (~> 2.2) | ||||
| -    libv8 (3.11.8.17)
 | ||||
|      listen (1.2.2) | ||||
|        rb-fsevent (>= 0.9.3) | ||||
|        rb-inotify (>= 0.9) | ||||
| @@ -407,7 +412,6 @@
 | ||||
|        redis-store (~> 1.1.0) | ||||
|      redis-store (1.1.3) | ||||
|        redis (>= 2.2.0) | ||||
| -    ref (1.0.5)
 | ||||
|      rest-client (1.6.7) | ||||
|        mime-types (>= 1.16) | ||||
|      rspec (2.13.0) | ||||
| @@ -493,9 +497,6 @@
 | ||||
|      stringex (1.5.1) | ||||
|      temple (0.6.5) | ||||
|      test_after_commit (0.2.0) | ||||
| -    therubyracer (0.11.4)
 | ||||
| -      libv8 (~> 3.11.8.12)
 | ||||
| -      ref
 | ||||
|      thin (1.5.1) | ||||
|        daemons (>= 1.0.9) | ||||
|        eventmachine (>= 0.12.6) | ||||
| @@ -556,6 +557,7 @@
 | ||||
|    bootstrap-sass | ||||
|    capybara | ||||
|    carrierwave | ||||
| +  charlock_holmes!
 | ||||
|    chosen-rails (= 1.0.0) | ||||
|    coffee-rails | ||||
|    colored | ||||
| @@ -634,7 +636,6 @@
 | ||||
|    stamp | ||||
|    state_machine | ||||
|    test_after_commit | ||||
| -  therubyracer
 | ||||
|    thin | ||||
|    tinder (~> 1.9.2) | ||||
|    turbolinks | ||||
|  | @ -1,32 +0,0 @@ | |||
| diff --git a/lib/gitlab/regex.rb b/lib/gitlab/regex.rb
 | ||||
| index b4be46d..2120f5a 100644
 | ||||
| --- a/lib/gitlab/regex.rb
 | ||||
| +++ b/lib/gitlab/regex.rb
 | ||||
| @@ -1,3 +1,5 @@
 | ||||
| +# encoding: utf-8
 | ||||
| +
 | ||||
|  module Gitlab | ||||
|    module Regex | ||||
|      extend self | ||||
| @@ -7,7 +9,7 @@ module Gitlab
 | ||||
|      end | ||||
|   | ||||
|      def project_name_regex | ||||
| -      /\A[a-zA-Z0-9][a-zA-Z0-9_\-\. ]*\z/
 | ||||
| +      /\A\p{Word}[\p{Word}\-:\. ]*\z/
 | ||||
|      end | ||||
|   | ||||
|      def name_regex | ||||
| diff --git a/app/models/project.rb b/app/models/project.rb
 | ||||
| index d8fa6cb..c4e5427 100644
 | ||||
| --- a/app/models/project.rb
 | ||||
| +++ b/app/models/project.rb
 | ||||
| @@ -73,7 +73,7 @@ class Project < ActiveRecord::Base
 | ||||
|    validates :description, length: { within: 0..2000 } | ||||
|    validates :name, presence: true, length: { within: 0..255 }, | ||||
|              format: { with: Gitlab::Regex.project_name_regex, | ||||
| -                      message: "only letters, digits, spaces & '_' '-' '.' allowed. Letter or digit should be first" }
 | ||||
| +                      message: "only letters, digits, spaces & '_' '-' '.' ':' allowed. Letter or digit should be first" }
 | ||||
|    validates :path, presence: true, length: { within: 0..255 }, | ||||
|              exclusion: { in: Gitlab::Blacklist.path }, | ||||
|              format: { with: Gitlab::Regex.path_regex, | ||||
|  | @ -1,20 +0,0 @@ | |||
| diff --git a/config/environments/production.rb b/gitlab-6/environments/production.rb
 | ||||
| index 82eb250..10e25e5 100644
 | ||||
| --- a/config/environments/production.rb
 | ||||
| +++ b/config/environments/production.rb
 | ||||
| @@ -73,11 +73,10 @@ Gitlab::Application.configure do
 | ||||
|    # config.active_record.auto_explain_threshold_in_seconds = 0.5 | ||||
|   | ||||
|    config.action_mailer.delivery_method = :sendmail | ||||
| -  # Defaults to:
 | ||||
| -  # # config.action_mailer.sendmail_settings = {
 | ||||
| -  # #   location: '/usr/sbin/sendmail',
 | ||||
| -  # #   arguments: '-i -t'
 | ||||
| -  # # }
 | ||||
| +  config.action_mailer.sendmail_settings = {
 | ||||
| +    location: '/usr/sbin/sendmail',
 | ||||
| +    arguments: '-i'
 | ||||
| +  }
 | ||||
|    config.action_mailer.perform_deliveries = true | ||||
|    config.action_mailer.raise_delivery_errors = true | ||||
|  end | ||||
|  | @ -1,207 +0,0 @@ | |||
| diff --git a/config/gitlab.yml.example b/config/gitlab.yml.example
 | ||||
| index 59a4d1f..e48dfe7 100644
 | ||||
| --- a/config/gitlab.yml.example
 | ||||
| +++ b/config/gitlab.yml.example
 | ||||
| @@ -103,6 +103,10 @@ production: &base
 | ||||
|      bind_dn: '_the_full_dn_of_the_user_you_will_bind_with' | ||||
|      password: '_the_password_of_the_bind_user' | ||||
|      allow_username_or_email_login: true | ||||
| +    mapping:
 | ||||
| +      name: 'cn'
 | ||||
| +      username: 'uid'
 | ||||
| +      email: 'mail'
 | ||||
|   | ||||
|    ## OmniAuth settings | ||||
|    omniauth: | ||||
| @@ -131,7 +135,14 @@ production: &base
 | ||||
|        # - { name: 'github', app_id: 'YOUR APP ID', | ||||
|        #     app_secret: 'YOUR APP SECRET' } | ||||
|   | ||||
| -
 | ||||
| +  ## User Mapping Procs
 | ||||
| +  # These procs allow for custom mapping of user information from LDAP / Omniauth
 | ||||
| +  # onto your user model.
 | ||||
| +  #
 | ||||
| +  # user_mapping:
 | ||||
| +  #  name: ->(auth) { auth.info.name.to_s }
 | ||||
| +  #  username: ->(auth) { auth.info.email.to_s.downcase.match(/^[^@]*/)[0] }
 | ||||
| +  #  email: ->(auth) { auth.info.email.to_s.downcase }
 | ||||
|   | ||||
|    # | ||||
|    # 3. Advanced settings | ||||
| diff --git a/config/initializers/1_settings.rb b/config/initializers/1_settings.rb
 | ||||
| index e0207c6..c079cc4 100644
 | ||||
| --- a/config/initializers/1_settings.rb
 | ||||
| +++ b/config/initializers/1_settings.rb
 | ||||
| @@ -36,6 +36,7 @@ end
 | ||||
|   | ||||
|  # Default settings | ||||
|  Settings['ldap'] ||= Settingslogic.new({}) | ||||
| +Settings.ldap['mapping'] ||= Settingslogic.new({})
 | ||||
|  Settings.ldap['enabled'] = false if Settings.ldap['enabled'].nil? | ||||
|  Settings.ldap['allow_username_or_email_login'] = false if Settings.ldap['allow_username_or_email_login'].nil? | ||||
|   | ||||
| diff --git a/lib/gitlab/auth.rb b/lib/gitlab/auth.rb
 | ||||
| index de70c5c..bea8191 100644
 | ||||
| --- a/lib/gitlab/auth.rb
 | ||||
| +++ b/lib/gitlab/auth.rb
 | ||||
| @@ -33,13 +33,14 @@ module Gitlab
 | ||||
|      def create_from_omniauth(auth, ldap = false) | ||||
|        provider = auth.provider | ||||
|        uid = auth.info.uid || auth.uid | ||||
| -      uid = uid.to_s.force_encoding("utf-8")
 | ||||
| -      name = auth.info.name.to_s.force_encoding("utf-8")
 | ||||
| -      email = auth.info.email.to_s.downcase unless auth.info.email.nil?
 | ||||
| +      uid = uid.to_s.force_encoding('utf-8')
 | ||||
| +      name = extract(:name, auth, ldap).force_encoding('utf-8')
 | ||||
| +      username = extract(:username, auth, ldap).force_encoding('utf-8')
 | ||||
| +      email = extract(:email, auth, ldap).force_encoding('utf-8')
 | ||||
|   | ||||
|        ldap_prefix = ldap ? '(LDAP) ' : '' | ||||
|        raise OmniAuth::Error, "#{ldap_prefix}#{provider} does not provide an email"\ | ||||
| -        " address" if auth.info.email.blank?
 | ||||
| +        " address" if email.blank?
 | ||||
|   | ||||
|        log.info "#{ldap_prefix}Creating user from #{provider} login"\ | ||||
|          " {uid => #{uid}, name => #{name}, email => #{email}}" | ||||
| @@ -48,7 +49,7 @@ module Gitlab
 | ||||
|          extern_uid: uid, | ||||
|          provider: provider, | ||||
|          name: name, | ||||
| -        username: email.match(/^[^@]*/)[0],
 | ||||
| +        username: username,
 | ||||
|          email: email, | ||||
|          password: password, | ||||
|          password_confirmation: password, | ||||
| @@ -101,5 +102,31 @@ module Gitlab
 | ||||
|      def ldap_conf | ||||
|        @ldap_conf ||= Gitlab.config.ldap | ||||
|      end | ||||
| +
 | ||||
| +    private
 | ||||
| +
 | ||||
| +    def extract(field_name, auth, ldap = false)
 | ||||
| +      @ldap_mapper ||= Gitlab.config.ldap.mapping rescue Hash.new
 | ||||
| +      @mapper ||= begin
 | ||||
| +        defaults = {
 | ||||
| +          name: ->(auth) { auth.info.name.to_s },
 | ||||
| +          username: ->(auth) { auth.info.email.to_s.downcase.match(/^[^@]*/)[0] },
 | ||||
| +          email: ->(auth) { auth.info.email.to_s.downcase },
 | ||||
| +        }
 | ||||
| +        extras = Gitlab.config.user_mapping rescue Hash.new
 | ||||
| +        defaults.merge(extras)
 | ||||
| +      end
 | ||||
| +
 | ||||
| +      if ldap && !@ldap_mapper[field_name].nil?
 | ||||
| +        begin
 | ||||
| +          ldap_attr = @ldap_mapper[field_name].to_sym
 | ||||
| +          Array(auth.extra.raw_info[ldap_attr])[0]
 | ||||
| +        rescue
 | ||||
| +          raise "(LDAP) Failed to get '#{@ldap_mapper[field_name]}' for #{field_name} for #{auth.info.uid}"
 | ||||
| +        end
 | ||||
| +      else
 | ||||
| +        @mapper[field_name].call(auth)
 | ||||
| +      end
 | ||||
| +    end
 | ||||
|    end | ||||
|  end | ||||
| diff --git a/spec/lib/auth_spec.rb b/spec/lib/auth_spec.rb
 | ||||
| index 903d276..cf9e7b7 100644
 | ||||
| --- a/spec/lib/auth_spec.rb
 | ||||
| +++ b/spec/lib/auth_spec.rb
 | ||||
| @@ -4,7 +4,7 @@ describe Gitlab::Auth do
 | ||||
|    let(:gl_auth) { Gitlab::Auth.new } | ||||
|   | ||||
|    before do | ||||
| -    Gitlab.config.stub(omniauth: {})
 | ||||
| +    Gitlab.config.stub(omniauth: {}, ldap: {})
 | ||||
|   | ||||
|      @info = mock( | ||||
|        uid: '12djsak321', | ||||
| @@ -74,9 +74,22 @@ describe Gitlab::Auth do
 | ||||
|    end | ||||
|   | ||||
|    describe :create_from_omniauth do | ||||
| +    before do
 | ||||
| +      @raw_info = {
 | ||||
| +        cn: 'John Black',
 | ||||
| +        mail: [ 'john.black@email.com' ],
 | ||||
| +        nickname: 'jonny'
 | ||||
| +      }
 | ||||
| +
 | ||||
| +      @ldap_auth = mock(
 | ||||
| +        info: @info,
 | ||||
| +        extra: mock(raw_info: @raw_info),
 | ||||
| +        provider: 'ldap'
 | ||||
| +      )
 | ||||
| +    end
 | ||||
| +
 | ||||
|      it "should create user from LDAP" do | ||||
| -      @auth = mock(info: @info, provider: 'ldap')
 | ||||
| -      user = gl_auth.create_from_omniauth(@auth, true)
 | ||||
| +      user = gl_auth.create_from_omniauth(@ldap_auth, true)
 | ||||
|   | ||||
|        user.should be_valid | ||||
|        user.extern_uid.should == @info.uid | ||||
| @@ -92,9 +105,59 @@ describe Gitlab::Auth do
 | ||||
|        user.provider.should == 'twitter' | ||||
|      end | ||||
|   | ||||
| +    it "should still import without extra mapping" do
 | ||||
| +      Gitlab.config.stub(omniauth: {})
 | ||||
| +      user = gl_auth.create_from_omniauth(@ldap_auth, true)
 | ||||
| +
 | ||||
| +      user.should be_valid
 | ||||
| +      user.extern_uid.should == @info.uid
 | ||||
| +      user.provider.should == 'ldap'
 | ||||
| +    end
 | ||||
| +
 | ||||
| +    it "should have user details from procs" do
 | ||||
| +      Gitlab.config.stub(omniauth: {}, user_mapping: {})
 | ||||
| +      Gitlab.config.user_mapping[:name] = ->(auth) { 'TestName' }
 | ||||
| +      Gitlab.config.user_mapping[:email] = ->(auth) { 'email@somewhere.com' }
 | ||||
| +      Gitlab.config.user_mapping[:username] = ->(auth) { 'TestUsername' }
 | ||||
| +
 | ||||
| +      user = gl_auth.create_from_omniauth(@ldap_auth, true)
 | ||||
| +      user.should be_valid
 | ||||
| +      user.extern_uid.should == @info.uid
 | ||||
| +      user.name.should == 'TestName'
 | ||||
| +      user.email.should == 'email@somewhere.com'
 | ||||
| +      user.username.should == 'TestUsername'
 | ||||
| +    end
 | ||||
| +
 | ||||
| +    it "should modify value using proc" do
 | ||||
| +      Gitlab.config.stub(omniauth: {}, user_mapping: {})
 | ||||
| +      Gitlab.config.user_mapping[:username] = ->(auth) { auth.info.email.to_s.downcase.split('@').first }
 | ||||
| +
 | ||||
| +      user = gl_auth.create_from_omniauth(@ldap_auth, true)
 | ||||
| +      user.should be_valid
 | ||||
| +      user.extern_uid.should == @info.uid
 | ||||
| +      user.username.should == 'john'
 | ||||
| +    end
 | ||||
| +
 | ||||
| +    it "should be able to use raw ldap information through simple ldap mapping" do
 | ||||
| +      Gitlab.config.ldap.stub(mapping: { name: 'cn', email: 'mail' })
 | ||||
| +
 | ||||
| +      user = gl_auth.create_from_omniauth(@ldap_auth, true)
 | ||||
| +      user.should be_valid
 | ||||
| +      user.extern_uid.should == @info.uid
 | ||||
| +      user.name.should == 'John Black'
 | ||||
| +      user.email.should == 'john.black@email.com'
 | ||||
| +    end
 | ||||
| +
 | ||||
| +    it "should raise an error if an invalid field is in ldap mapping" do
 | ||||
| +      Gitlab.config.ldap.stub(mapping: { name: 'invalid' })
 | ||||
| +
 | ||||
| +      expect {
 | ||||
| +        gl_auth.create_from_omniauth(@ldap_auth, true)
 | ||||
| +      }.to raise_error
 | ||||
| +    end
 | ||||
| +
 | ||||
|      it "should apply defaults to user" do | ||||
| -      @auth = mock(info: @info, provider: 'ldap')
 | ||||
| -      user = gl_auth.create_from_omniauth(@auth, true)
 | ||||
| +      user = gl_auth.create_from_omniauth(@ldap_auth, true)
 | ||||
|   | ||||
|        user.should be_valid | ||||
|        user.projects_limit.should == Gitlab.config.gitlab.default_projects_limit | ||||
|  | @ -66,14 +66,10 @@ ruby_add_bdepend " | |||
| # fix-sendmail-config: | ||||
| #     Fix default settings to work with ssmtp that doesn't know '-t' argument. | ||||
| # | ||||
| # ldap-user-mapping: | ||||
| #     Updated and fixed patch from https://github.com/gitlabhq/gitlabhq/pull/3646. | ||||
| # | ||||
| RUBY_PATCHES=( | ||||
| 	"${P}-fix-gemfile.patch" | ||||
| 	"${P}-fix-project-name-regex.patch" | ||||
| 	"${P}-fix-sendmail-config.patch" | ||||
| #	"${P}-ldap-user-mapping.patch" | ||||
| ) | ||||
| 
 | ||||
| MY_NAME="gitlab" | ||||
|  | @ -86,6 +82,7 @@ TEMP_DIR="/var/tmp/${MY_NAME}" | |||
| 
 | ||||
| # When updating ebuild to newer version, check list of the queues in | ||||
| # https://github.com/gitlabhq/gitlabhq/blob/${PV}/lib/tasks/sidekiq.rake | ||||
| # TODO fritteli: I don't know what to look for in that file ... so I left this unchanged from gitlabhq-6.0.2-r2.ebuild | ||||
| SIDEKIQ_QUEUES="post_receive,mailer,system_hook,project_web_hook,gitlab_shell,common,default" | ||||
| 
 | ||||
| all_ruby_prepare() { | ||||
|  | @ -227,8 +224,8 @@ pkg_postinst() { | |||
| 	elog "2. Configure your database settings in ${CONF_DIR}/database.yml" | ||||
| 	elog "   for \"production\" environment." | ||||
| 	elog | ||||
| 	elog "3. Then you should create database for your GitLab instance, if you" | ||||
| 	elog "haven't it already." | ||||
| 	elog "3. Then you should create a database for your GitLab instance, if you" | ||||
| 	elog "haven't done so already." | ||||
| 	elog | ||||
| 	if use postgres; then | ||||
|         elog   "If you have local PostgreSQL running, just copy&run:" | ||||
|  | @ -329,6 +326,10 @@ pkg_config() { | |||
| 
 | ||||
| 		einfo "Cleaning cache ..." | ||||
| 		exec_rake cache:clear | ||||
| 
 | ||||
| 		# https://github.com/gitlabhq/gitlabhq/issues/5311#issuecomment-31656496 | ||||
| 		einfo "Migrating iids ..." | ||||
| 		exec_rake migrate_iids | ||||
| 	else | ||||
| 		einfo "Initializing database ..." | ||||
| 		exec_rake gitlab:setup | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue