крючки на стороне сервера git - PullRequest
0 голосов
/ 31 июля 2010

У меня проблема с запуском следующего скрипта python на сервере, который ищет информацию о коммите для push, убедившись, что он соответствует определенному синтаксису, я не могу получить ввод от пользователя, поэтому имя пользователя и парольжестко закодировано.Теперь я также не могу получить список сообщений о коммитах, которые произошли до этого конкретного нажатия.

#!/usr/bin/python

import SOAPpy 
import getpass 
import datetime
import sys
import re
import logging
import os


def login(x,y):
    try:
        auth = soap.login(x, y)
        return auth
    except:
          sys.exit( "Invalid username or password")

def getIssue(auth,issue):
    try:
        issue = soap.getIssue(auth, issue)
    except:
        sys.exit("No issue of that type found : Make sure all PRs are vaild jira PRs")

def git_get_commit_msg(commit_id):
    return get_shell_cmd_output("git rev-list --pretty --max-count=1 " + commit_id)

def git_get_last_commit_id():
    return get_shell_cmd_output("git log --pretty=format:%H -1")

def getCommitText():
    commit_msg_filename = sys.argv[1]
    try:
        commit_msg_text = open(commit_msg_filename).read()
        return commit_msg_text
    except:
        sys.exit("Could not read commit message")

def git_get_array_of_commit_ids(start_id, end_id):
    output = get_shell_cmd_output("git rev-list " + start_id + ".." + end_id)
    if output == "":
        return None
    commit_id_array = string.split(output, '\n')
    return commit_id_array

def get_shell_cmd_output(cmd):
    try:
        proc = subprocess.Popen(cmd, shell=True, stdout=subprocess.PIPE)
        return proc.stdout.read().rstrip('\n')
    except KeyboardInterrupt:
        logging.info("... interrupted")

    except Exception, e:
        logging.error("Failed trying to execute '%s'", cmd)

def findpattern(commit_msg):
    pattern = re.compile("\w\w*-\d\d*")
    group = pattern.findall(commit_msg)
    print group
    found = len(group)
    found =0
    issues = 0
    for match in group:
            auth = soap.login(jirauser,passwd)
            getIssue(auth,match)
            issues = issues + 1
            found+=1
    if found ==0:
        sys.exit("No issue patterns found.")

    print "Retrieved issues: " + str(issues)  

def update():
    print sys.argv[2]
    print sys.argv[3]
    old_commit_id = sys.argv[2]
    new_commit_id = sys.argv[3]
    commit_id_array = git_get_array_of_commit_ids(old_commit_id, new_commit_id)
    for commit_id in commit_id_array:
        commit_text = git_get_commit_msg(commit_id)
        findpattern(commit_text)

soap = SOAPpy.WSDL.Proxy('some url')
# this line if for repointing the input from dev/null
#sys.stdin = open('/dev/tty', 'r') # this fails horribly.
#ask user for input
#jirauser = raw_inp
#("Username for jira: ")
jirauser = "username"
passwd = "987654321"
#passwd = getpass.getpass("Password for %s: " % jirauser)
login(jirauser,passwd)
#commit_msg = getCommitText()
#findpattern(commit_msg)
update()

Предполагаемая цель этого кода - проверить коммиты, сделанные локально, и проанализировать их на предмет намеченногошаблон, а также проверка в Jira, если этот PR существует.это ловушка на стороне сервера, которая активируется при отправке в хранилище.

Буду признателен за любые советы по написанию ловушек Python.Пожалуйста и спасибо.

Ответы [ 2 ]

2 голосов
/ 04 августа 2010

Предлагаю вам взглянуть на gitorious (http://gitorious.org/gitorious). Они используют ssh для обработки аутентификации и управления правами (получение имени пользователя, заданного ssh). У них также есть несколько хуков на репозитории git. Я думаю, это может помочь увидеть, как они обрабатывают git-хуки, используя ruby.

1 голос
/ 06 августа 2010

К тому моменту, когда срабатывает ваша ловушка обновления, на сервере появляются новые коммиты: вопрос в том, позволит ли ваша ловушка пересылать данный реф. Какую информацию из локального (отправляющего) хранилища вы хотите?

Для решения проблемы с учетными данными направьте всех через одного пользователя. Например, GitHub делает это с пользователем git, поэтому его URL-адреса SSH начинаются с git@github.com:.... Затем в ~git/.ssh/authorized_keys свяжите имя пользователя с каждым ключом. Обратите внимание, что следующее должно быть в одной строке, но для целей презентации оно переносится.

no-agent-forwarding,no-port-forwarding,no-pty,no-X11-forwarding,
command="env myuser=gbgcoll /usr/bin/git-shell -c \"${SSH_ORIGINAL_COMMAND:-}\""
ssh-rsa AAAAB...

Теперь, чтобы узнать, кто пытается выполнить обновление, ваша ловушка проверяет переменную окружения $myuser.

Это не дает вам учетные данные Jira каждого пользователя. Чтобы решить эту проблему, создайте фиктивную учетную запись Jira, которая имеет доступ только для чтения ко всему, и жестко закодируйте , что учетные данные учетной записи Jira в вашем хуке. Это позволяет вам проверить, что данный PR существует.

...