summaryrefslogtreecommitdiff
path: root/git-shell-commands/change-owner
diff options
context:
space:
mode:
authorParabola git <git@parabola.nu>2016-07-07 22:31:39 +0000
committerParabola git <git@parabola.nu>2016-07-07 22:31:39 +0000
commit0c774a11d390fba141a39a4ec96557015d29626d (patch)
treeb5691b89681a4c1f24882c62b33f858c57199d4b /git-shell-commands/change-owner
parentd8dbd10192041d5638987fb279a2e452ce5adcfb (diff)
parentf985decc7edecd2376a4d08cdc29bbf42f18da12 (diff)
Merge remote-tracking branch 'hackers/lukeshu/tmp'
Diffstat (limited to 'git-shell-commands/change-owner')
-rwxr-xr-xgit-shell-commands/change-owner19
1 files changed, 19 insertions, 0 deletions
diff --git a/git-shell-commands/change-owner b/git-shell-commands/change-owner
new file mode 100755
index 0000000..6b6f353
--- /dev/null
+++ b/git-shell-commands/change-owner
@@ -0,0 +1,19 @@
+#!/bin/bash
+# * change-owner
+# Define quiƩn manda
+# ssh git@host change-owner repo "Hacklab"
+
+set -e
+
+repo=$1; shift
+
+repo="$(sed -r 's,^/*,,' <<<"$repo")"
+_repo="$(sed -r -e '/(^|\/)\.\.($|\/)/d' -e "s,[^A-Za-z0-9\./_~-],,g" <<<"$repo")"
+test "$repo" = "$_repo" || { printf 'Illegal name: %s\n' "${repo}"; exit 1; }
+
+if test -d "${repo}".git; then
+ git config -f "${repo}.git/config" "gitweb.owner" "${*}"
+else
+ printf 'Does not exist: %s\n' "${repo}"
+ exit 1
+fi