##// END OF EJS Templates
ini: added new key
ini: added new key

File last commit:

r112:998f0d14
r129:489ce37b
Show More
github.py
122 lines | 4.8 KiB | text/x-python | PythonLexer
# -*- coding: utf-8 -*-
# Copyright 2010 - 2017 RhodeCode GmbH and the AppEnlight project authors
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from appenlight.models import DBSession
from appenlight.models.integrations.github import GithubIntegration, \
IntegrationException
from appenlight.models.report_comment import ReportComment
from appenlight.models.services.report_group import ReportGroupService
from pyramid.view import view_config
from appenlight import forms
import logging
from datetime import datetime
from pyramid.httpexceptions import HTTPFound, HTTPUnprocessableEntity
from webob.multidict import MultiDict
log = logging.getLogger(__name__)
from . import IntegrationView
class GithubView(IntegrationView):
@view_config(route_name='integrations_id',
match_param=['action=info', 'integration=github'],
renderer='json')
def get_github_info(self):
"""
Grab information about possible priority statuses and assignable users
"""
try:
client = GithubIntegration.create_client(
self.request,
self.integration.config['user_name'],
self.integration.config['repo_name'])
except IntegrationException as e:
self.request.response.status_code = 503
return {'error_messages': [str(e)]}
try:
assignees = client.get_assignees()
statuses = client.get_statuses()
except IntegrationException as e:
return {'error_messages': [str(e)]}
return {'assignees': assignees,
'statuses': statuses}
@view_config(route_name='integrations_id',
match_param=['action=create-issue', 'integration=github'],
renderer='json')
def create_issue(self):
"""
Creates a new issue in github issue tracker from report group
"""
report = ReportGroupService.by_id(
self.request.unsafe_json_body['group_id'])
form_data = {
'title': self.request.unsafe_json_body.get('title',
'Unknown Title'),
'content': self.request.unsafe_json_body.get('content'),
'kind': [self.request.unsafe_json_body['status']],
'responsible': self.request.unsafe_json_body['responsible']['user']
}
try:
client = GithubIntegration.create_client(
self.request,
self.integration.config['user_name'],
self.integration.config['repo_name'])
issue = client.create_issue(form_data)
except IntegrationException as e:
self.request.response.status_code = 503
return {'error_messages': [str(e)]}
comment_body = 'Github issue created: %s ' % issue['web_url']
comment = ReportComment(owner_id=self.request.user.id,
report_time=report.first_timestamp,
body=comment_body)
report.comments.append(comment)
return True
@view_config(route_name='integrations_id',
match_param=['action=setup', 'integration=github'],
renderer='json',
permission='edit')
def setup(self):
"""
Validates and creates integration between application and github
"""
resource = self.request.context.resource
form = forms.IntegrationGithubForm(
MultiDict(self.request.safe_json_body or {}),
csrf_context=self.request,
**self.integration_config)
if self.request.method == 'POST' and form.validate():
integration_config = {
'repo_name': form.repo_name.data,
'user_name': form.user_name.data,
'host_name': 'https://api.github.com'
}
if not self.integration:
self.integration = GithubIntegration(
modified_date=datetime.utcnow(),
)
self.integration.config = integration_config
resource.integrations.append(self.integration)
self.request.session.flash('Integration updated')
return integration_config
elif self.request.method == 'POST':
return HTTPUnprocessableEntity(body=form.errors_json)
return self.integration_config