diff options
author | Parabola git <git@parabola.nu> | 2016-07-07 22:31:39 +0000 |
---|---|---|
committer | Parabola git <git@parabola.nu> | 2016-07-07 22:31:39 +0000 |
commit | 0c774a11d390fba141a39a4ec96557015d29626d (patch) | |
tree | b5691b89681a4c1f24882c62b33f858c57199d4b /git-shell-commands/create-bare-repo | |
parent | d8dbd10192041d5638987fb279a2e452ce5adcfb (diff) | |
parent | f985decc7edecd2376a4d08cdc29bbf42f18da12 (diff) |
Merge remote-tracking branch 'hackers/lukeshu/tmp'
Diffstat (limited to 'git-shell-commands/create-bare-repo')
-rwxr-xr-x | git-shell-commands/create-bare-repo | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/git-shell-commands/create-bare-repo b/git-shell-commands/create-bare-repo new file mode 100755 index 0000000..b4d2d5f --- /dev/null +++ b/git-shell-commands/create-bare-repo @@ -0,0 +1,18 @@ +#!/bin/bash +# * create-bare-repo +# Allows users to create repo.git +# ssh git@host create-bare-repo repo1 repo2 ... + +set -e + +for repo in "$@"; do + 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}"; continue; } + test -d "$repo".git && { printf 'Already exists: %s\n' "${repo}"; continue; } + + mkdir -p -- "$repo".git + pushd "$repo".git >/dev/null + git init --bare + popd >/dev/null +done |