##// END OF EJS Templates
cached-commits: updated logic on cached commit updates....
cached-commits: updated logic on cached commit updates. - for repositories we ensure that damaged/empty repositories have initial data instead of now (bug) - for groups we only update based on first set of data inside a group without iterating to nested objects. This new logic goes in sync with new update task of groups with automation.

File last commit:

r3365:dcae2268 default
r4162:5cadc4f9 default
Show More
trigger_ci_call.py
37 lines | 1.3 KiB | text/x-python | PythonLexer
rcextensions: new builtin rcextensions....
r3133 # Example to trigger a CI call via an HTTP helper via post_push hook
@has_kwargs({
'server_url': 'url of instance that triggered this hook',
'config': 'path to .ini config used',
'scm': 'type of version control "git", "hg", "svn"',
'username': 'username of actor who triggered this event',
'ip': 'ip address of actor who triggered this hook',
'action': '',
'repository': 'repository name',
'repo_store_path': 'full path to where repositories are stored',
'commit_ids': '',
'hook_type': '',
'user_agent': '',
})
def _push_hook(*args, **kwargs):
"""
POST PUSH HOOK, this function will be executed after each push it's
executed after the build-in hook that RhodeCode uses for logging pushes
"""
from .helpers import http_call, extra_fields
# returns list of dicts with key-val fetched from extra fields
repo_extra_fields = extra_fields.run(**kwargs)
if repo_extra_fields.get('endpoint_url'):
rcextensions: updated examples, and made http_call util use the method parameter.
r3365 field_metadata = repo_extra_fields['endpoint_url']
endpoint = field_metadata['field_value']
rcextensions: new builtin rcextensions....
r3133 if endpoint:
data = {
'some_key': 'val'
}
response = http_call.run(url=endpoint, json_data=data)
return HookResponse(0, 'Called endpoint {}, with response {}'.format(endpoint, response))
return HookResponse(0, '')