mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
* feat: initiate integrations * feat: initiate github integration create models for the same * feat: github integration views * fix: update workspace integration view to create bot users * refactor: rename repository model * refactor: update github repo sync endpoint to create repo and sync in one go * refactor: update issue activities to post the updates to segway hook * refactor: update endpoints to get project id and add actor as a member of project in repo sync * fix: make is bot as a read only field * fix: remove github repo imports * fix: url mapping * feat: repo views * refactor: update webhook request endpoint * refactor: rename repositories table to github_repositories * fix: workpace integration actor * feat: label for github integration * refactor: issue activity on create issue * refactor: repo create endpoint and add db constraints for repo sync and issues * feat: create api token on workpsace integration and avatar_url for integrations * refactor: add uuid primary key for Audit model * refactor: remove id from auditfield to maintain integrity and make avatar blank if none supplied * feat: track comments on an issue * feat: comment syncing from plane to github * fix: prevent activities created by bot to be sent to webhook * feat: github app installation id retrieve * feat: github app installation id saved into db * feat: installation_id for the github integragation and unique provider and project base integration for repo * refactor: remove actor logic from activity task * feat: saving github metadata using installation id in workspace integration table * feat: github repositories endpoint * feat: github and project repos synchronisation * feat: delete issue and delete comment activity * refactor: remove print logs * FIX: reading env names for github app while installation * refactor: update bot user firstname with title * fix: add is_bot value in field --------- Co-authored-by: venplane <venkatesh@plane.so>
146 lines
4.9 KiB
Python
146 lines
4.9 KiB
Python
# Third party imports
|
|
from rest_framework import status
|
|
from rest_framework.response import Response
|
|
from sentry_sdk import capture_exception
|
|
|
|
# Module imports
|
|
from plane.api.views import BaseViewSet, BaseAPIView
|
|
from plane.db.models import (
|
|
GithubIssueSync,
|
|
GithubRepositorySync,
|
|
GithubRepository,
|
|
WorkspaceIntegration,
|
|
ProjectMember,
|
|
Label,
|
|
GithubCommentSync,
|
|
)
|
|
from plane.api.serializers import (
|
|
GithubIssueSyncSerializer,
|
|
GithubRepositorySyncSerializer,
|
|
GithubCommentSyncSerializer,
|
|
)
|
|
from plane.utils.integrations.github import get_github_repos
|
|
|
|
|
|
class GithubRepositoriesEndpoint(BaseAPIView):
|
|
def get(self, request, slug, workspace_integration_id):
|
|
try:
|
|
workspace_integration = WorkspaceIntegration.objects.get(
|
|
workspace__slug=slug, pk=workspace_integration_id
|
|
)
|
|
access_tokens_url = workspace_integration.metadata["access_tokens_url"]
|
|
repositories_url = workspace_integration.metadata["repositories_url"]
|
|
repositories = get_github_repos(access_tokens_url, repositories_url)
|
|
return Response(repositories, status=status.HTTP_200_OK)
|
|
except WorkspaceIntegration.DoesNotExist:
|
|
return Response(
|
|
{"error": "Workspace Integration Does not exists"},
|
|
status=status.HTTP_400_BAD_REQUEST,
|
|
)
|
|
|
|
|
|
class GithubRepositorySyncViewSet(BaseViewSet):
|
|
serializer_class = GithubRepositorySyncSerializer
|
|
model = GithubRepositorySync
|
|
|
|
def perform_create(self, serializer):
|
|
serializer.save(project_id=self.kwargs.get("project_id"))
|
|
|
|
def create(self, request, slug, project_id, workspace_integration_id):
|
|
try:
|
|
name = request.data.get("name", False)
|
|
url = request.data.get("url", False)
|
|
config = request.data.get("config", {})
|
|
repository_id = request.data.get("repository_id", False)
|
|
owner = request.data.get("owner", False)
|
|
|
|
if not name or not url or not repository_id or not owner:
|
|
return Response(
|
|
{"error": "Name, url, repository_id and owner are required"},
|
|
status=status.HTTP_400_BAD_REQUEST,
|
|
)
|
|
|
|
# Create repository
|
|
repo = GithubRepository.objects.create(
|
|
name=name,
|
|
url=url,
|
|
config=config,
|
|
repository_id=repository_id,
|
|
owner=owner,
|
|
project_id=project_id,
|
|
)
|
|
|
|
# Get the workspace integration
|
|
workspace_integration = WorkspaceIntegration.objects.get(
|
|
pk=workspace_integration_id
|
|
)
|
|
|
|
# Create a Label for github
|
|
label = Label.objects.filter(
|
|
name="GitHub",
|
|
project_id=project_id,
|
|
).first()
|
|
|
|
if label is None:
|
|
label = Label.objects.create(
|
|
name="GitHub",
|
|
project_id=project_id,
|
|
description="Label to sync Plane issues with GitHub issues",
|
|
color="#003773",
|
|
)
|
|
|
|
# Create repo sync
|
|
repo_sync = GithubRepositorySync.objects.create(
|
|
repository=repo,
|
|
workspace_integration=workspace_integration,
|
|
actor=workspace_integration.actor,
|
|
credentials=request.data.get("credentials", {}),
|
|
project_id=project_id,
|
|
label=label,
|
|
)
|
|
|
|
# Add bot as a member in the project
|
|
_ = ProjectMember.objects.create(
|
|
member=workspace_integration.actor, role=20, project_id=project_id
|
|
)
|
|
|
|
# Return Response
|
|
return Response(
|
|
GithubRepositorySyncSerializer(repo_sync).data,
|
|
status=status.HTTP_201_CREATED,
|
|
)
|
|
|
|
except WorkspaceIntegration.DoesNotExist:
|
|
return Response(
|
|
{"error": "Workspace Integration does not exist"},
|
|
status=status.HTTP_404_NOT_FOUND,
|
|
)
|
|
except Exception as e:
|
|
capture_exception(e)
|
|
return Response(
|
|
{"error": "Something went wrong please try again later"},
|
|
status=status.HTTP_400_BAD_REQUEST,
|
|
)
|
|
|
|
|
|
class GithubIssueSyncViewSet(BaseViewSet):
|
|
serializer_class = GithubIssueSyncSerializer
|
|
model = GithubIssueSync
|
|
|
|
def perform_create(self, serializer):
|
|
serializer.save(
|
|
project_id=self.kwargs.get("project_id"),
|
|
repository_sync_id=self.kwargs.get("repo_sync_id"),
|
|
)
|
|
|
|
|
|
class GithubCommentSyncViewSet(BaseViewSet):
|
|
serializer_class = GithubCommentSyncSerializer
|
|
model = GithubCommentSync
|
|
|
|
def perform_create(self, serializer):
|
|
serializer.save(
|
|
project_id=self.kwargs.get("project_id"),
|
|
issue_sync_id=self.kwargs.get("issue_sync_id"),
|
|
)
|