Commit 4a907356c1a49f191427928bec0617a67670c2f9
1 parent
fd31cbb7
Exists in
move_out_plugins
Remove gitlab from colab.plugins
Signed-off-by: Gustavo Jaruga <darksshades@gmail.com> Signed-off-by: Alexandre Barbosa <alexandreab@live.com>
Showing
15 changed files
with
0 additions
and
853 deletions
Show diff stats
colab/plugins/gitlab/__init__.py
colab/plugins/gitlab/apps.py
| ... | ... | @@ -1,25 +0,0 @@ |
| 1 | - | |
| 2 | -from django.utils.translation import ugettext_lazy as _ | |
| 3 | - | |
| 4 | -from ..utils.apps import ColabProxiedAppConfig | |
| 5 | - | |
| 6 | - | |
| 7 | -class ProxyGitlabAppConfig(ColabProxiedAppConfig): | |
| 8 | - name = 'colab.plugins.gitlab' | |
| 9 | - verbose_name = 'Gitlab Proxy' | |
| 10 | - | |
| 11 | - menu = { | |
| 12 | - 'title': _('Code'), | |
| 13 | - 'links': ( | |
| 14 | - (_('Public Projects'), 'public/projects'), | |
| 15 | - ), | |
| 16 | - 'auth_links': ( | |
| 17 | - (_('Profile'), 'profile'), | |
| 18 | - (_('New Project'), 'projects/new'), | |
| 19 | - (_('Projects'), 'dashboard/projects'), | |
| 20 | - (_('Groups'), 'profile/groups'), | |
| 21 | - (_('Issues'), 'dashboard/issues'), | |
| 22 | - (_('Merge Requests'), 'dashboard/merge_requests'), | |
| 23 | - | |
| 24 | - ), | |
| 25 | - } |
colab/plugins/gitlab/data_api.py
| ... | ... | @@ -1,205 +0,0 @@ |
| 1 | -import json | |
| 2 | -import urllib | |
| 3 | -import urllib2 | |
| 4 | -import logging | |
| 5 | - | |
| 6 | -from dateutil.parser import parse | |
| 7 | - | |
| 8 | -from django.conf import settings | |
| 9 | -from django.db.models.fields import DateTimeField | |
| 10 | - | |
| 11 | -from colab.plugins.gitlab.models import (GitlabProject, GitlabMergeRequest, | |
| 12 | - GitlabComment, GitlabIssue) | |
| 13 | -from colab.plugins.utils.proxy_data_api import ProxyDataAPI | |
| 14 | - | |
| 15 | -LOGGER = logging.getLogger('colab.plugin.gitlab') | |
| 16 | - | |
| 17 | - | |
| 18 | -class GitlabDataAPI(ProxyDataAPI): | |
| 19 | - | |
| 20 | - def get_request_url(self, path, **kwargs): | |
| 21 | - proxy_config = settings.PROXIED_APPS.get(self.app_label, {}) | |
| 22 | - | |
| 23 | - upstream = proxy_config.get('upstream') | |
| 24 | - kwargs['private_token'] = proxy_config.get('private_token') | |
| 25 | - params = urllib.urlencode(kwargs) | |
| 26 | - | |
| 27 | - if upstream[-1] == '/': | |
| 28 | - upstream = upstream[:-1] | |
| 29 | - | |
| 30 | - return u'{}{}?{}'.format(upstream, path, params) | |
| 31 | - | |
| 32 | - def get_json_data(self, api_url, page, pages=1000): | |
| 33 | - url = self.get_request_url(api_url, per_page=pages, | |
| 34 | - page=page) | |
| 35 | - | |
| 36 | - try: | |
| 37 | - data = urllib2.urlopen(url, timeout=10) | |
| 38 | - json_data = json.load(data) | |
| 39 | - except urllib2.URLError: | |
| 40 | - LOGGER.exception("Connection timeout: " + url) | |
| 41 | - json_data = [] | |
| 42 | - | |
| 43 | - return json_data | |
| 44 | - | |
| 45 | - def fill_object_data(self, element, _object): | |
| 46 | - for field in _object._meta.fields: | |
| 47 | - try: | |
| 48 | - if field.name == "user": | |
| 49 | - _object.update_user( | |
| 50 | - element["author"]["username"]) | |
| 51 | - continue | |
| 52 | - if field.name == "project": | |
| 53 | - _object.project_id = element["project_id"] | |
| 54 | - continue | |
| 55 | - | |
| 56 | - if isinstance(field, DateTimeField): | |
| 57 | - value = parse(element[field.name]) | |
| 58 | - else: | |
| 59 | - value = element[field.name] | |
| 60 | - | |
| 61 | - setattr(_object, field.name, value) | |
| 62 | - except KeyError: | |
| 63 | - continue | |
| 64 | - | |
| 65 | - return _object | |
| 66 | - | |
| 67 | - def fetch_projects(self): | |
| 68 | - page = 1 | |
| 69 | - projects = [] | |
| 70 | - | |
| 71 | - while True: | |
| 72 | - json_data = self.get_json_data('/api/v3/projects/all', page) | |
| 73 | - page = page + 1 | |
| 74 | - | |
| 75 | - if not len(json_data): | |
| 76 | - break | |
| 77 | - | |
| 78 | - for element in json_data: | |
| 79 | - project = GitlabProject() | |
| 80 | - self.fill_object_data(element, project) | |
| 81 | - projects.append(project) | |
| 82 | - | |
| 83 | - return projects | |
| 84 | - | |
| 85 | - def fetch_merge_request(self, projects): | |
| 86 | - all_merge_request = [] | |
| 87 | - | |
| 88 | - for project in projects: | |
| 89 | - page = 1 | |
| 90 | - while True: | |
| 91 | - url = '/api/v3/projects/{}/merge_requests'.format(project.id) | |
| 92 | - json_data_mr = self.get_json_data(url, page) | |
| 93 | - page = page + 1 | |
| 94 | - | |
| 95 | - if len(json_data_mr) == 0: | |
| 96 | - break | |
| 97 | - | |
| 98 | - for element in json_data_mr: | |
| 99 | - single_merge_request = GitlabMergeRequest() | |
| 100 | - self.fill_object_data(element, single_merge_request) | |
| 101 | - all_merge_request.append(single_merge_request) | |
| 102 | - | |
| 103 | - return all_merge_request | |
| 104 | - | |
| 105 | - def fetch_issue(self, projects): | |
| 106 | - all_issues = [] | |
| 107 | - | |
| 108 | - for project in projects: | |
| 109 | - page = 1 | |
| 110 | - while True: | |
| 111 | - url = '/api/v3/projects/{}/issues'.format(project.id) | |
| 112 | - json_data_issue = self.get_json_data(url, page) | |
| 113 | - page = page + 1 | |
| 114 | - | |
| 115 | - if len(json_data_issue) == 0: | |
| 116 | - break | |
| 117 | - | |
| 118 | - for element in json_data_issue: | |
| 119 | - single_issue = GitlabIssue() | |
| 120 | - self.fill_object_data(element, single_issue) | |
| 121 | - all_issues.append(single_issue) | |
| 122 | - | |
| 123 | - return all_issues | |
| 124 | - | |
| 125 | - def fetch_comments(self): | |
| 126 | - all_comments = [] | |
| 127 | - all_comments.extend(self.fetch_comments_MR()) | |
| 128 | - all_comments.extend(self.fetch_comments_issues()) | |
| 129 | - | |
| 130 | - return all_comments | |
| 131 | - | |
| 132 | - def fetch_comments_MR(self): | |
| 133 | - all_comments = [] | |
| 134 | - all_merge_requests = GitlabMergeRequest.objects.all() | |
| 135 | - | |
| 136 | - for merge_request in all_merge_requests: | |
| 137 | - page = 1 | |
| 138 | - while True: | |
| 139 | - url = '/api/v3/projects/{}/merge_requests/{}/notes'.format( | |
| 140 | - merge_request.project_id, merge_request.id) | |
| 141 | - json_data_mr = self.get_json_data(url, page) | |
| 142 | - page = page + 1 | |
| 143 | - | |
| 144 | - if len(json_data_mr) == 0: | |
| 145 | - break | |
| 146 | - | |
| 147 | - for element in json_data_mr: | |
| 148 | - single_comment = GitlabComment() | |
| 149 | - self.fill_object_data(element, single_comment) | |
| 150 | - single_comment.project = merge_request.project | |
| 151 | - single_comment.issue_comment = False | |
| 152 | - single_comment.parent_id = merge_request.id | |
| 153 | - all_comments.append(single_comment) | |
| 154 | - | |
| 155 | - return all_comments | |
| 156 | - | |
| 157 | - def fetch_comments_issues(self): | |
| 158 | - all_comments = [] | |
| 159 | - all_issues = GitlabIssue.objects.all() | |
| 160 | - | |
| 161 | - for issue in all_issues: | |
| 162 | - page = 1 | |
| 163 | - while True: | |
| 164 | - url = '/api/v3/projects/{}/issues/{}/notes'.format( | |
| 165 | - issue.project_id, issue.id) | |
| 166 | - json_data_mr = self.get_json_data(url, page) | |
| 167 | - page = page + 1 | |
| 168 | - | |
| 169 | - if len(json_data_mr) == 0: | |
| 170 | - break | |
| 171 | - | |
| 172 | - for element in json_data_mr: | |
| 173 | - single_comment = GitlabComment() | |
| 174 | - self.fill_object_data(element, single_comment) | |
| 175 | - single_comment.project = issue.project | |
| 176 | - single_comment.issue_comment = True | |
| 177 | - single_comment.parent_id = issue.id | |
| 178 | - all_comments.append(single_comment) | |
| 179 | - | |
| 180 | - return all_comments | |
| 181 | - | |
| 182 | - def fetch_data(self): | |
| 183 | - LOGGER.info("Importing Projects") | |
| 184 | - projects = self.fetch_projects() | |
| 185 | - for datum in projects: | |
| 186 | - datum.save() | |
| 187 | - | |
| 188 | - LOGGER.info("Importing Merge Requests") | |
| 189 | - merge_request_list = self.fetch_merge_request(projects) | |
| 190 | - for datum in merge_request_list: | |
| 191 | - datum.save() | |
| 192 | - | |
| 193 | - LOGGER.info("Importing Issues") | |
| 194 | - issue_list = self.fetch_issue(projects) | |
| 195 | - for datum in issue_list: | |
| 196 | - datum.save() | |
| 197 | - | |
| 198 | - LOGGER.info("Importing Comments") | |
| 199 | - comments_list = self.fetch_comments() | |
| 200 | - for datum in comments_list: | |
| 201 | - datum.save() | |
| 202 | - | |
| 203 | - @property | |
| 204 | - def app_label(self): | |
| 205 | - return 'gitlab' |
colab/plugins/gitlab/diazo.xml
| ... | ... | @@ -1,18 +0,0 @@ |
| 1 | -<rules | |
| 2 | - xmlns="http://namespaces.plone.org/diazo" | |
| 3 | - xmlns:css="http://namespaces.plone.org/diazo/css" | |
| 4 | - xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> | |
| 5 | - | |
| 6 | - <before theme-children="/html/head" content-children="/html/head" /> | |
| 7 | - <before css:theme-children="#main-content" css:content-children="body" /> | |
| 8 | - | |
| 9 | - <merge attributes="class" css:theme="body" css:content="body" /> | |
| 10 | - | |
| 11 | - <!-- Add gitlab properties --> | |
| 12 | - <merge attributes="data-page" css:theme="body" css:content="body" /> | |
| 13 | - <merge attributes="data-project-id" css:theme="body" css:content="body" /> | |
| 14 | - | |
| 15 | - <drop css:content="#top-panel" /> | |
| 16 | - <drop css:content=".navbar-gitlab" /> | |
| 17 | - <drop css:content=".git-clone-holder .btn:contains('HTTPS')" /> | |
| 18 | -</rules> |
colab/plugins/gitlab/migrations/0001_initial.py
| ... | ... | @@ -1,28 +0,0 @@ |
| 1 | -# -*- coding: utf-8 -*- | |
| 2 | -from __future__ import unicode_literals | |
| 3 | - | |
| 4 | -from django.db import models, migrations | |
| 5 | - | |
| 6 | - | |
| 7 | -class Migration(migrations.Migration): | |
| 8 | - | |
| 9 | - dependencies = [ | |
| 10 | - ] | |
| 11 | - | |
| 12 | - operations = [ | |
| 13 | - migrations.CreateModel( | |
| 14 | - name='GitlabProject', | |
| 15 | - fields=[ | |
| 16 | - ('id', models.IntegerField(serialize=False, primary_key=True)), | |
| 17 | - ('description', models.TextField()), | |
| 18 | - ('public', models.BooleanField(default=True)), | |
| 19 | - ('name', models.TextField()), | |
| 20 | - ('name_with_namespace', models.TextField()), | |
| 21 | - ('created_at', models.DateTimeField(blank=True)), | |
| 22 | - ('last_activity_at', models.DateTimeField(blank=True)), | |
| 23 | - ], | |
| 24 | - options={ | |
| 25 | - }, | |
| 26 | - bases=(models.Model,), | |
| 27 | - ), | |
| 28 | - ] |
colab/plugins/gitlab/migrations/0002_auto_20150205_1220.py
| ... | ... | @@ -1,69 +0,0 @@ |
| 1 | -# -*- coding: utf-8 -*- | |
| 2 | -from __future__ import unicode_literals | |
| 3 | - | |
| 4 | -from django.db import models, migrations | |
| 5 | -import django.db.models.deletion | |
| 6 | -from django.conf import settings | |
| 7 | - | |
| 8 | - | |
| 9 | -class Migration(migrations.Migration): | |
| 10 | - | |
| 11 | - dependencies = [ | |
| 12 | - migrations.swappable_dependency(settings.AUTH_USER_MODEL), | |
| 13 | - ('gitlab', '0001_initial'), | |
| 14 | - ] | |
| 15 | - | |
| 16 | - operations = [ | |
| 17 | - migrations.CreateModel( | |
| 18 | - name='GitlabComment', | |
| 19 | - fields=[ | |
| 20 | - ('id', models.IntegerField(serialize=False, primary_key=True)), | |
| 21 | - ('body', models.TextField()), | |
| 22 | - ('created_at', models.DateTimeField(blank=True)), | |
| 23 | - ('user', models.ForeignKey(on_delete=django.db.models.deletion.SET_NULL, to=settings.AUTH_USER_MODEL, null=True)), | |
| 24 | - ], | |
| 25 | - options={ | |
| 26 | - 'verbose_name': 'Gitlab Comments', | |
| 27 | - 'verbose_name_plural': 'Gitlab Comments', | |
| 28 | - }, | |
| 29 | - bases=(models.Model,), | |
| 30 | - ), | |
| 31 | - migrations.CreateModel( | |
| 32 | - name='GitlabIssue', | |
| 33 | - fields=[ | |
| 34 | - ('id', models.IntegerField(serialize=False, primary_key=True)), | |
| 35 | - ('title', models.TextField()), | |
| 36 | - ('description', models.TextField()), | |
| 37 | - ('state', models.TextField()), | |
| 38 | - ('project', models.ForeignKey(on_delete=django.db.models.deletion.SET_NULL, to='gitlab.GitlabProject', null=True)), | |
| 39 | - ('user', models.ForeignKey(on_delete=django.db.models.deletion.SET_NULL, to=settings.AUTH_USER_MODEL, null=True)), | |
| 40 | - ], | |
| 41 | - options={ | |
| 42 | - 'verbose_name': 'Gitlab Collaboration', | |
| 43 | - 'verbose_name_plural': 'Gitlab Collaborations', | |
| 44 | - }, | |
| 45 | - bases=(models.Model,), | |
| 46 | - ), | |
| 47 | - migrations.CreateModel( | |
| 48 | - name='GitlabMergeRequest', | |
| 49 | - fields=[ | |
| 50 | - ('id', models.IntegerField(serialize=False, primary_key=True)), | |
| 51 | - ('target_branch', models.TextField()), | |
| 52 | - ('source_branch', models.TextField()), | |
| 53 | - ('description', models.TextField()), | |
| 54 | - ('title', models.TextField()), | |
| 55 | - ('state', models.TextField()), | |
| 56 | - ('project', models.ForeignKey(on_delete=django.db.models.deletion.SET_NULL, to='gitlab.GitlabProject', null=True)), | |
| 57 | - ('user', models.ForeignKey(on_delete=django.db.models.deletion.SET_NULL, to=settings.AUTH_USER_MODEL, null=True)), | |
| 58 | - ], | |
| 59 | - options={ | |
| 60 | - 'verbose_name': 'Gitlab Merge Request', | |
| 61 | - 'verbose_name_plural': 'Gitlab Merge Requests', | |
| 62 | - }, | |
| 63 | - bases=(models.Model,), | |
| 64 | - ), | |
| 65 | - migrations.AlterModelOptions( | |
| 66 | - name='gitlabproject', | |
| 67 | - options={'verbose_name': 'Gitlab Project', 'verbose_name_plural': 'Gitlab Projects'}, | |
| 68 | - ), | |
| 69 | - ] |
colab/plugins/gitlab/migrations/0003_auto_20150211_1203.py
| ... | ... | @@ -1,61 +0,0 @@ |
| 1 | -# -*- coding: utf-8 -*- | |
| 2 | -from __future__ import unicode_literals | |
| 3 | - | |
| 4 | -from django.db import models, migrations | |
| 5 | -import django.db.models.deletion | |
| 6 | - | |
| 7 | - | |
| 8 | -class Migration(migrations.Migration): | |
| 9 | - | |
| 10 | - dependencies = [ | |
| 11 | - ('gitlab', '0002_auto_20150205_1220'), | |
| 12 | - ] | |
| 13 | - | |
| 14 | - operations = [ | |
| 15 | - migrations.AlterModelOptions( | |
| 16 | - name='gitlabissue', | |
| 17 | - options={'verbose_name': 'Gitlab Issue', 'verbose_name_plural': 'Gitlab Issues'}, | |
| 18 | - ), | |
| 19 | - migrations.AddField( | |
| 20 | - model_name='gitlabcomment', | |
| 21 | - name='issue_comment', | |
| 22 | - field=models.BooleanField(default=True), | |
| 23 | - preserve_default=True, | |
| 24 | - ), | |
| 25 | - migrations.AddField( | |
| 26 | - model_name='gitlabcomment', | |
| 27 | - name='parent_id', | |
| 28 | - field=models.IntegerField(null=True), | |
| 29 | - preserve_default=True, | |
| 30 | - ), | |
| 31 | - migrations.AddField( | |
| 32 | - model_name='gitlabcomment', | |
| 33 | - name='project', | |
| 34 | - field=models.ForeignKey(on_delete=django.db.models.deletion.SET_NULL, to='gitlab.GitlabProject', null=True), | |
| 35 | - preserve_default=True, | |
| 36 | - ), | |
| 37 | - migrations.AddField( | |
| 38 | - model_name='gitlabissue', | |
| 39 | - name='created_at', | |
| 40 | - field=models.DateTimeField(null=True, blank=True), | |
| 41 | - preserve_default=True, | |
| 42 | - ), | |
| 43 | - migrations.AddField( | |
| 44 | - model_name='gitlabmergerequest', | |
| 45 | - name='created_at', | |
| 46 | - field=models.DateTimeField(null=True, blank=True), | |
| 47 | - preserve_default=True, | |
| 48 | - ), | |
| 49 | - migrations.AddField( | |
| 50 | - model_name='gitlabproject', | |
| 51 | - name='path_with_namespace', | |
| 52 | - field=models.TextField(null=True, blank=True), | |
| 53 | - preserve_default=True, | |
| 54 | - ), | |
| 55 | - migrations.AlterField( | |
| 56 | - model_name='gitlabcomment', | |
| 57 | - name='created_at', | |
| 58 | - field=models.DateTimeField(null=True, blank=True), | |
| 59 | - preserve_default=True, | |
| 60 | - ), | |
| 61 | - ] |
colab/plugins/gitlab/migrations/__init__.py
colab/plugins/gitlab/models.py
| ... | ... | @@ -1,143 +0,0 @@ |
| 1 | -from django.db import models | |
| 2 | -from django.utils.translation import ugettext_lazy as _ | |
| 3 | -from colab.plugins.utils.models import Collaboration | |
| 4 | -from hitcounter.models import HitCounterModelMixin | |
| 5 | - | |
| 6 | - | |
| 7 | -class GitlabProject(models.Model, HitCounterModelMixin): | |
| 8 | - | |
| 9 | - id = models.IntegerField(primary_key=True) | |
| 10 | - description = models.TextField() | |
| 11 | - public = models.BooleanField(default=True) | |
| 12 | - name = models.TextField() | |
| 13 | - name_with_namespace = models.TextField() | |
| 14 | - created_at = models.DateTimeField(blank=True) | |
| 15 | - last_activity_at = models.DateTimeField(blank=True) | |
| 16 | - path_with_namespace = models.TextField(blank=True, null=True) | |
| 17 | - | |
| 18 | - @property | |
| 19 | - def url(self): | |
| 20 | - return u'/gitlab/{}'.format(self.path_with_namespace) | |
| 21 | - | |
| 22 | - class Meta: | |
| 23 | - verbose_name = _('Gitlab Project') | |
| 24 | - verbose_name_plural = _('Gitlab Projects') | |
| 25 | - | |
| 26 | - | |
| 27 | -class GitlabMergeRequest(Collaboration): | |
| 28 | - | |
| 29 | - id = models.IntegerField(primary_key=True) | |
| 30 | - target_branch = models.TextField() | |
| 31 | - source_branch = models.TextField() | |
| 32 | - project = models.ForeignKey(GitlabProject, null=True, | |
| 33 | - on_delete=models.SET_NULL) | |
| 34 | - description = models.TextField() | |
| 35 | - title = models.TextField() | |
| 36 | - state = models.TextField() | |
| 37 | - created_at = models.DateTimeField(blank=True, null=True) | |
| 38 | - | |
| 39 | - @property | |
| 40 | - def modified(self): | |
| 41 | - return self.created_at | |
| 42 | - | |
| 43 | - @property | |
| 44 | - def tag(self): | |
| 45 | - return self.state | |
| 46 | - | |
| 47 | - type = u'merge_request' | |
| 48 | - icon_name = u'file' | |
| 49 | - | |
| 50 | - @property | |
| 51 | - def url(self): | |
| 52 | - return u'/gitlab/{}/merge_requests/{}'.format( | |
| 53 | - self.project.path_with_namespace, self.id) | |
| 54 | - | |
| 55 | - def get_author(self): | |
| 56 | - return self.user | |
| 57 | - | |
| 58 | - class Meta: | |
| 59 | - verbose_name = _('Gitlab Merge Request') | |
| 60 | - verbose_name_plural = _('Gitlab Merge Requests') | |
| 61 | - | |
| 62 | - | |
| 63 | -class GitlabIssue(Collaboration): | |
| 64 | - | |
| 65 | - id = models.IntegerField(primary_key=True) | |
| 66 | - project = models.ForeignKey(GitlabProject, null=True, | |
| 67 | - on_delete=models.SET_NULL) | |
| 68 | - title = models.TextField() | |
| 69 | - description = models.TextField() | |
| 70 | - | |
| 71 | - state = models.TextField() | |
| 72 | - created_at = models.DateTimeField(blank=True, null=True) | |
| 73 | - | |
| 74 | - icon_name = u'align-right' | |
| 75 | - type = u'gitlab_issue' | |
| 76 | - | |
| 77 | - @property | |
| 78 | - def modified(self): | |
| 79 | - return self.created_at | |
| 80 | - | |
| 81 | - @property | |
| 82 | - def url(self): | |
| 83 | - return u'/gitlab/{}/issues/{}'.format( | |
| 84 | - self.project.path_with_namespace, self.id) | |
| 85 | - | |
| 86 | - class Meta: | |
| 87 | - verbose_name = _('Gitlab Issue') | |
| 88 | - verbose_name_plural = _('Gitlab Issues') | |
| 89 | - | |
| 90 | - | |
| 91 | -class GitlabComment(Collaboration): | |
| 92 | - | |
| 93 | - id = models.IntegerField(primary_key=True) | |
| 94 | - body = models.TextField() | |
| 95 | - created_at = models.DateTimeField(blank=True, null=True) | |
| 96 | - issue_comment = models.BooleanField(default=True) | |
| 97 | - | |
| 98 | - project = models.ForeignKey(GitlabProject, null=True, | |
| 99 | - on_delete=models.SET_NULL) | |
| 100 | - | |
| 101 | - parent_id = models.IntegerField(null=True) | |
| 102 | - type = u'comment' | |
| 103 | - | |
| 104 | - @property | |
| 105 | - def modified(self): | |
| 106 | - return self.created_at | |
| 107 | - | |
| 108 | - @property | |
| 109 | - def title(self): | |
| 110 | - if self.issue_comment: | |
| 111 | - issue = GitlabIssue.objects.get(id=self.parent_id) | |
| 112 | - return issue.title | |
| 113 | - else: | |
| 114 | - merge_request = GitlabMergeRequest.objects.get(id=self.parent_id) | |
| 115 | - return merge_request.title | |
| 116 | - | |
| 117 | - icon_name = u'align-right' | |
| 118 | - | |
| 119 | - @property | |
| 120 | - def description(self): | |
| 121 | - return self.body | |
| 122 | - | |
| 123 | - @property | |
| 124 | - def tag(self): | |
| 125 | - if self.issue_comment: | |
| 126 | - issue = GitlabIssue.objects.get(id=self.parent_id) | |
| 127 | - return issue.state | |
| 128 | - else: | |
| 129 | - merge_request = GitlabMergeRequest.objects.get(id=self.parent_id) | |
| 130 | - return merge_request.state | |
| 131 | - | |
| 132 | - @property | |
| 133 | - def url(self): | |
| 134 | - if self.issue_comment: | |
| 135 | - return u'/gitlab/{}/issues/{}#notes_{}'.format( | |
| 136 | - self.project.path_with_namespace, self.parent_id, self.id) | |
| 137 | - else: | |
| 138 | - return u'/gitlab/{}/merge_requests/{}#notes_{}'.format( | |
| 139 | - self.project.path_with_namespace, self.parent_id, self.id) | |
| 140 | - | |
| 141 | - class Meta: | |
| 142 | - verbose_name = _('Gitlab Comments') | |
| 143 | - verbose_name_plural = _('Gitlab Comments') |
colab/plugins/gitlab/search_indexes.py
| ... | ... | @@ -1,120 +0,0 @@ |
| 1 | -# -*- coding: utf-8 -*- | |
| 2 | - | |
| 3 | -import string | |
| 4 | - | |
| 5 | -from haystack import indexes | |
| 6 | -from haystack.utils import log as logging | |
| 7 | - | |
| 8 | -from .models import (GitlabProject, GitlabMergeRequest, | |
| 9 | - GitlabIssue, GitlabComment) | |
| 10 | - | |
| 11 | - | |
| 12 | -logger = logging.getLogger('haystack') | |
| 13 | - | |
| 14 | -# The string maketrans always return a string encoded with latin1 | |
| 15 | -# http://stackoverflow.com/questions/1324067/how-do-i-get-str-translate-to-work-with-unicode-strings | |
| 16 | -table = string.maketrans( | |
| 17 | - string.punctuation, | |
| 18 | - '.' * len(string.punctuation) | |
| 19 | -).decode('latin1') | |
| 20 | - | |
| 21 | - | |
| 22 | -class GitlabProjectIndex(indexes.SearchIndex, indexes.Indexable): | |
| 23 | - text = indexes.CharField(document=True, use_template=False, stored=False) | |
| 24 | - title = indexes.CharField(model_attr='name') | |
| 25 | - description = indexes.CharField(model_attr='description', null=True) | |
| 26 | - tag = indexes.CharField() | |
| 27 | - url = indexes.CharField(model_attr='url', indexed=False) | |
| 28 | - icon_name = indexes.CharField() | |
| 29 | - type = indexes.CharField() | |
| 30 | - created = indexes.DateTimeField(model_attr='created_at', null=True) | |
| 31 | - | |
| 32 | - def prepare_tag(self, obj): | |
| 33 | - return "{}".format(obj.name_with_namespace.split('/')[0].strip()) | |
| 34 | - | |
| 35 | - def prepare_icon_name(self, obj): | |
| 36 | - return u'file' | |
| 37 | - | |
| 38 | - def get_ful_name(self): | |
| 39 | - self.objs.name | |
| 40 | - | |
| 41 | - def get_model(self): | |
| 42 | - return GitlabProject | |
| 43 | - | |
| 44 | - def prepare_type(self, obj): | |
| 45 | - return u'gitlab' | |
| 46 | - | |
| 47 | - | |
| 48 | -class GitlabMergeRequestIndex(indexes.SearchIndex, indexes.Indexable): | |
| 49 | - | |
| 50 | - text = indexes.CharField(document=True, use_template=False, stored=False) | |
| 51 | - title = indexes.CharField(model_attr='title') | |
| 52 | - description = indexes.CharField(model_attr='description') | |
| 53 | - tag = indexes.CharField(model_attr='state') | |
| 54 | - url = indexes.CharField(model_attr='url', indexed=False) | |
| 55 | - icon_name = indexes.CharField() | |
| 56 | - type = indexes.CharField(model_attr='type') | |
| 57 | - | |
| 58 | - modified_by = indexes.CharField(model_attr='modified_by', null=True) | |
| 59 | - modified_by_url = indexes.CharField(model_attr='modified_by_url', | |
| 60 | - null=True) | |
| 61 | - modified = indexes.DateTimeField(model_attr='created_at', null=True) | |
| 62 | - | |
| 63 | - def get_model(self): | |
| 64 | - return GitlabMergeRequest | |
| 65 | - | |
| 66 | - def prepare_icon_name(self, obj): | |
| 67 | - return u'file' | |
| 68 | - | |
| 69 | - def prepare_type(self, obj): | |
| 70 | - return u'merge_request' | |
| 71 | - | |
| 72 | - | |
| 73 | -class GitlabIssueIndex(indexes.SearchIndex, indexes.Indexable): | |
| 74 | - | |
| 75 | - text = indexes.CharField(document=True, use_template=False, stored=False) | |
| 76 | - title = indexes.CharField(model_attr='title') | |
| 77 | - description = indexes.CharField(model_attr='description') | |
| 78 | - tag = indexes.CharField(model_attr='state') | |
| 79 | - url = indexes.CharField(model_attr='url', indexed=False) | |
| 80 | - icon_name = indexes.CharField() | |
| 81 | - type = indexes.CharField(model_attr='type') | |
| 82 | - | |
| 83 | - modified_by = indexes.CharField(model_attr='modified_by', null=True) | |
| 84 | - modified_by_url = indexes.CharField(model_attr='modified_by_url', | |
| 85 | - null=True) | |
| 86 | - modified = indexes.DateTimeField(model_attr='created_at', null=True) | |
| 87 | - | |
| 88 | - def get_model(self): | |
| 89 | - return GitlabIssue | |
| 90 | - | |
| 91 | - def prepare_icon_name(self, obj): | |
| 92 | - return u'align-right' | |
| 93 | - | |
| 94 | - def prepare_type(self, obj): | |
| 95 | - return u'merge_request' | |
| 96 | - | |
| 97 | - | |
| 98 | -class GitlabCommentIndex(indexes.SearchIndex, indexes.Indexable): | |
| 99 | - | |
| 100 | - text = indexes.CharField(document=True, use_template=False, stored=False) | |
| 101 | - title = indexes.CharField(model_attr='title') | |
| 102 | - description = indexes.CharField(model_attr='description') | |
| 103 | - tag = indexes.CharField() | |
| 104 | - url = indexes.CharField(model_attr='url', indexed=False) | |
| 105 | - icon_name = indexes.CharField() | |
| 106 | - type = indexes.CharField(model_attr='type') | |
| 107 | - | |
| 108 | - modified_by = indexes.CharField(model_attr='modified_by', null=True) | |
| 109 | - modified_by_url = indexes.CharField(model_attr='modified_by_url', | |
| 110 | - null=True) | |
| 111 | - modified = indexes.DateTimeField(model_attr='created_at', null=True) | |
| 112 | - | |
| 113 | - def get_model(self): | |
| 114 | - return GitlabComment | |
| 115 | - | |
| 116 | - def prepare_icon_name(self, obj): | |
| 117 | - return u'align-right' | |
| 118 | - | |
| 119 | - def prepare_tag(self, obj): | |
| 120 | - return obj.tag |
colab/plugins/gitlab/templates/proxy/gitlab.html
| ... | ... | @@ -1,51 +0,0 @@ |
| 1 | -{% extends 'base.html' %} | |
| 2 | -{% load static from staticfiles %} | |
| 3 | - | |
| 4 | -{% block head_css %} | |
| 5 | -<style> | |
| 6 | - /* Reset left and with for .modal-dialog style (like gitlab does), | |
| 7 | - the bootstrap.css one makes it small */ | |
| 8 | - @media screen and (min-width: 768px) { | |
| 9 | - .modal-dialog { | |
| 10 | - left: auto; | |
| 11 | - width: auto; | |
| 12 | - } | |
| 13 | - } | |
| 14 | - div#main-content { | |
| 15 | - margin-top: 65px; | |
| 16 | - } | |
| 17 | - | |
| 18 | - div#main-content div.container { | |
| 19 | - width: 1110px; | |
| 20 | - } | |
| 21 | - div#main-content div.flash-container{ | |
| 22 | - width: 85%; | |
| 23 | - } | |
| 24 | - #breadcrumbs { | |
| 25 | - border: 0 !important; | |
| 26 | - } | |
| 27 | - | |
| 28 | - #right-top-nav { | |
| 29 | - margin-right: 5em !important; | |
| 30 | - } | |
| 31 | -</style> | |
| 32 | -{% endblock %} | |
| 33 | - | |
| 34 | -{% block head_js %} | |
| 35 | -<script type="text/javascript"> | |
| 36 | - jQuery(function(){ | |
| 37 | - // bootstrap.css forces .hide {display:none!important}, and this makes | |
| 38 | - // gitlab .hide elements NEVER have a display:block, so | |
| 39 | - // instead of editing bootstrap.css, we just removed '.hide' css class and | |
| 40 | - // toggled | |
| 41 | - jQuery('.hide').removeClass('hide').css('display', 'none'); | |
| 42 | - | |
| 43 | - // Hit the SSH clone button to select it by default | |
| 44 | - jQuery(".git-clone-holder .btn:contains('SSH')").click() | |
| 45 | - | |
| 46 | - }); | |
| 47 | -</script> | |
| 48 | -<script type="text/javascript" src="{% static 'third-party/bootstrap/js/bootstrap.min.js' %}"></script> | |
| 49 | -<script type="text/javascript" src="{% static 'third-party/jquery.cookie.js' %}"></script> | |
| 50 | -<script>jQuery.noConflict();</script> | |
| 51 | -{% endblock %} |
colab/plugins/gitlab/tests/__init__.py
colab/plugins/gitlab/tests/test_gitlab.py
| ... | ... | @@ -1,114 +0,0 @@ |
| 1 | -""" | |
| 2 | -Test User class. | |
| 3 | -Objective: Test parameters, and behavior. | |
| 4 | -""" | |
| 5 | -from datetime import datetime | |
| 6 | - | |
| 7 | - | |
| 8 | -from django.test import TestCase, Client | |
| 9 | -from colab.accounts.models import User | |
| 10 | -from colab.plugins.gitlab.models import GitlabProject, \ | |
| 11 | - GitlabIssue, GitlabComment, GitlabMergeRequest | |
| 12 | - | |
| 13 | - | |
| 14 | -class GitlabTest(TestCase): | |
| 15 | - | |
| 16 | - def setUp(self): | |
| 17 | - self.user = self.create_user() | |
| 18 | - self.client = Client() | |
| 19 | - self.create_gitlab_data() | |
| 20 | - | |
| 21 | - super(GitlabTest, self).setUp() | |
| 22 | - | |
| 23 | - def tearDown(self): | |
| 24 | - pass | |
| 25 | - | |
| 26 | - def test_data_integrity(self): | |
| 27 | - self.assertEqual(GitlabProject.objects.all().count(), 1) | |
| 28 | - self.assertEqual(GitlabMergeRequest.objects.all().count(), 1) | |
| 29 | - self.assertEqual(GitlabIssue.objects.all().count(), 1) | |
| 30 | - self.assertEqual(GitlabComment.objects.all().count(), 2) | |
| 31 | - | |
| 32 | - def test_project_url(self): | |
| 33 | - self.assertEqual(GitlabProject.objects.get(id=1).url, | |
| 34 | - '/gitlab/softwarepublico/colab') | |
| 35 | - | |
| 36 | - def test_merge_request_url(self): | |
| 37 | - self.assertEqual(GitlabMergeRequest.objects.get(id=1).url, | |
| 38 | - '/gitlab/softwarepublico/colab/merge_requests/1') | |
| 39 | - | |
| 40 | - def test_issue_url(self): | |
| 41 | - self.assertEqual(GitlabIssue.objects.get(id=1).url, | |
| 42 | - '/gitlab/softwarepublico/colab/issues/1') | |
| 43 | - | |
| 44 | - def test_comment_on_mr_url(self): | |
| 45 | - url = '/gitlab/softwarepublico/colab/merge_requests/1#notes_1' | |
| 46 | - self.assertEqual(GitlabComment.objects.get(id=1).url, url) | |
| 47 | - | |
| 48 | - def test_comment_on_issue_url(self): | |
| 49 | - self.assertEqual(GitlabComment.objects.get(id=2).url, | |
| 50 | - '/gitlab/softwarepublico/colab/issues/1#notes_2') | |
| 51 | - | |
| 52 | - def create_gitlab_data(self): | |
| 53 | - g = GitlabProject() | |
| 54 | - g.id = 1 | |
| 55 | - g.name = "colab" | |
| 56 | - g.name_with_namespace = "Software Public / Colab" | |
| 57 | - g.path_with_namespace = "softwarepublico/colab" | |
| 58 | - g.created_at = datetime.now() | |
| 59 | - g.last_activity_at = datetime.now() | |
| 60 | - g.save() | |
| 61 | - | |
| 62 | - mr = GitlabMergeRequest() | |
| 63 | - mr.id = 1 | |
| 64 | - mr.project = g | |
| 65 | - mr.title = "Include plugin support" | |
| 66 | - mr.description = "Merge request for plugin support" | |
| 67 | - mr.state = "Closed" | |
| 68 | - mr.created_at = datetime.now() | |
| 69 | - mr.update_user(self.user.username) | |
| 70 | - mr.save() | |
| 71 | - | |
| 72 | - i = GitlabIssue() | |
| 73 | - i.id = 1 | |
| 74 | - i.project = g | |
| 75 | - i.title = "Issue for colab" | |
| 76 | - i.description = "Issue reported to colab" | |
| 77 | - i.created_at = datetime.now() | |
| 78 | - i.state = "Open" | |
| 79 | - i.update_user(self.user.username) | |
| 80 | - i.save() | |
| 81 | - | |
| 82 | - c1 = GitlabComment() | |
| 83 | - c1.id = 1 | |
| 84 | - c1.parent_id = mr.id | |
| 85 | - c1.project = g | |
| 86 | - c1.body = "Comment to merge request" | |
| 87 | - c1.created_at = datetime.now() | |
| 88 | - c1.issue_comment = False | |
| 89 | - c1.update_user(self.user.username) | |
| 90 | - c1.save() | |
| 91 | - | |
| 92 | - c2 = GitlabComment() | |
| 93 | - c2.id = 2 | |
| 94 | - c2.parent_id = i.id | |
| 95 | - c2.project = g | |
| 96 | - c2.body = "Comment to issue" | |
| 97 | - c2.created_at = datetime.now() | |
| 98 | - c2.issue_comment = True | |
| 99 | - c2.update_user(self.user.username) | |
| 100 | - c2.save() | |
| 101 | - | |
| 102 | - def create_user(self): | |
| 103 | - user = User() | |
| 104 | - user.username = "USERtestCoLaB" | |
| 105 | - user.set_password("123colab4") | |
| 106 | - user.email = "usertest@colab.com.br" | |
| 107 | - user.id = 1 | |
| 108 | - user.twitter = "usertestcolab" | |
| 109 | - user.facebook = "usertestcolab" | |
| 110 | - user.first_name = "USERtestCoLaB" | |
| 111 | - user.last_name = "COLAB" | |
| 112 | - user.save() | |
| 113 | - | |
| 114 | - return user |
colab/plugins/gitlab/urls.py