Added run-scm for fedora-hosted stuff

This commit is contained in:
Mike McGrath 2008-01-03 12:46:37 -06:00
parent d60c65ede0
commit 24c60d483a
4 changed files with 68 additions and 0 deletions

5
scripts/run-scm/run-bzr Executable file
View file

@ -0,0 +1,5 @@
#!/bin/sh
umask 0002
exec /usr/bin/bzr "$@"

54
scripts/run-scm/run-git Executable file
View file

@ -0,0 +1,54 @@
#!/usr/bin/python -tt
import sys, os
commands = {
"git-receive-pack": "/usr/bin/git-receive-pack",
"git-upload-pack": "/usr/bin/git-upload-pack",
"bzr": "/usr/bin/run-bzr",
"hg": "/usr/bin/run-hg",
"svnserve": "/usr/bin/run-svnserve",
"scp": "/usr/bin/scp",
}
if __name__ == '__main__':
orig_cmd = os.environ.get('SSH_ORIGINAL_COMMAND')
if not orig_cmd:
print "Need a command"
sys.exit(1)
allargs = orig_cmd.split()
try:
basecmd = os.path.basename(allargs[0])
cmd = commands[basecmd]
except:
sys.stderr.write("Invalid command %s\n" % orig_cmd)
sys.exit(2)
if basecmd in ('git-receive-pack', 'git-upload-pack'):
# git repositories need to be parsed specially
thearg = ' '.join(allargs[1:])
if thearg[0] == "'" and thearg[-1] == "'":
thearg = thearg.replace("'","")
thearg = thearg.replace("\\'", "")
if thearg[:len('/git/')] != '/git/' or not os.path.isdir(thearg):
print "Invalid repository %s" % thearg
sys.exit(3)
allargs = [thearg]
elif basecmd in ('scp'):
thearg = ' '.join(allargs[1:])
if thearg.find('/') != -1:
print "scp yourfile-1.2.tar.gz scm.fedorahosted.org:$YOURPROJECT # No trailing /"
sys.exit(4)
else:
newargs = []
newargs.append(allargs[0])
newargs.append(allargs[1])
newargs.append("/srv/web/releases/%s/" % allargs[2])
os.execv(cmd, [cmd] + newargs[1:])
sys.exit(1)
else:
allargs = allargs[1:]
os.execv(cmd, [cmd] + allargs)
sys.exit(1)

5
scripts/run-scm/run-hg Executable file
View file

@ -0,0 +1,5 @@
#!/bin/sh
umask 0002
exec /usr/bin/hg "$@"

4
scripts/run-scm/run-svnserve Executable file
View file

@ -0,0 +1,4 @@
#!/bin/bash
umask 0002
exec /usr/bin/svnserve -t