diff --git a/net/gitolite/Makefile b/net/gitolite/Makefile new file mode 100644 index 0000000000..0d7011d8a2 --- /dev/null +++ b/net/gitolite/Makefile @@ -0,0 +1,61 @@ +# +# Copyright (C) 2009-2016 OpenWrt.org +# +# This is free software, licensed under the GNU General Public License v2. +# See /LICENSE for more information. +# + +include $(TOPDIR)/rules.mk + +PKG_NAME:=gitolite +PKG_VERSION:=3.6.6 +PKG_RELEASE:=1 + +PKG_SOURCE_PROTO:=git +PKG_SOURCE:=$(PKG_NAME)-v$(PKG_VERSION).tar.xz +PKG_SOURCE_URL:=https://github.com/sitaramc/gitolite.git +PKG_SOURCE_VERSION:=908f8c6f3b8ef5b95829be7155be2557e71f4579 +PKG_SOURCE_SUBDIR:=$(PKG_NAME)-$(PKG_VERSION) +PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_SOURCE_SUBDIR) + +include $(INCLUDE_DIR)/package.mk + +define Package/gitolite + SECTION:=net + CATEGORY:=Network + SUBMENU:=Version Control Systems + DEPENDS:=+perlbase-essential +perlbase-sys +perlbase-data +perlbase-digest +perlbase-env +perlbase-time +git +perlbase-findbin +perlbase-storable +perlbase-text +perlbase-getopt +perlbase-utf8 +openssh-keygen +openssh-server +openssh-moduli perl + TITLE:=Easy administration of git repositories + URL:=http://gitolite.com/gitlolite + MAINTAINER:=Daniel Dickinson + USERID:=git=382:git=382 +endef + +define Package/gitolite/description + Gitolite is a system for managing access to git repositories. Note you will need to make + sure dropbear does not interfere with OpenSSH as gitolite depends on feature not in + dropbear (to my knowledge). +endef + +define Package/gitolite/postinst +sed -i -e 's,/var/run/git,/srv/git,' $${IPKG_INSTROOT}/etc/passwd +sed -i -e 's,git:\(.*\):/bin/false,git:\1:/bin/ash,' $${IPKG_INSTROOT}/etc/passwd +endef + +define Build/Configure + true +endef + +define Build/Compile + mkdir -p $(PKG_INSTALL_DIR)/usr/libexec/gitolite + $(PKG_BUILD_DIR)/install -to $(PKG_INSTALL_DIR)/usr/libexec/gitolite + mkdir -p $(PKG_INSTALL_DIR)/usr/bin + ln -sf /usr/libexec/gitolite/gitolite $(PKG_INSTALL_DIR)/usr/bin/gitolite +endef + +define Package/gitolite/install + $(INSTALL_DIR) $(1) + $(CP) $(PKG_INSTALL_DIR)/* $(1)/ +endef + +$(eval $(call BuildPackage,gitolite)) diff --git a/net/gitolite/patches/100-fix-missing-hooks-dir.patch b/net/gitolite/patches/100-fix-missing-hooks-dir.patch new file mode 100644 index 0000000000..6f7ee53ac6 --- /dev/null +++ b/net/gitolite/patches/100-fix-missing-hooks-dir.patch @@ -0,0 +1,27 @@ +From d0409ae1164030913801d37ce5425ed93529c69d Mon Sep 17 00:00:00 2001 +From: Daniel Dickinson +Date: Fri, 1 Jul 2016 00:37:23 -0400 +Subject: [PATCH] Conf::Store: Fix missing hooks dir for symlink + +At least when doing 'gitolite setup -pk user.pub', the +symlinking of hooks fails because the hooks directory +does not exist. Make sure we create it if it's missing. +--- + src/lib/Gitolite/Conf/Store.pm | 1 + + 1 file changed, 1 insertion(+) + +diff --git a/src/lib/Gitolite/Conf/Store.pm b/src/lib/Gitolite/Conf/Store.pm +index 5568b3f..aac90d4 100644 +--- a/src/lib/Gitolite/Conf/Store.pm ++++ b/src/lib/Gitolite/Conf/Store.pm +@@ -363,6 +363,7 @@ sub store_common { + chmod 0755, "$rc{GL_ADMIN_BASE}/hooks/gitolite-admin/post-update"; + $hook_reset++; + } ++ _mkdir("$repo.git/hooks"); + + # propagate user-defined (custom) hooks to all repos + ln_sf( "$rc{LOCAL_CODE}/hooks/common", "*", "$repo.git/hooks" ) if $rc{LOCAL_CODE}; +-- +2.7.4 +