mirror of https://github.com/sipwise/repoapi.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
171 lines
5.8 KiB
171 lines
5.8 KiB
# Copyright (C) 2015-2022 The Sipwise Team - http://sipwise.com
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify it
|
|
# under the terms of the GNU General Public License as published by the Free
|
|
# Software Foundation, either version 3 of the License, or (at your option)
|
|
# any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful, but WITHOUT
|
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
# more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along
|
|
# with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
import json
|
|
import uuid
|
|
|
|
import structlog
|
|
from django.contrib.auth.decorators import login_required
|
|
from django.http import HttpResponseNotFound
|
|
from django.http import HttpResponseRedirect
|
|
from django.http import JsonResponse
|
|
from django.shortcuts import render
|
|
from django.urls import reverse
|
|
from django.views.decorators.http import require_http_methods
|
|
|
|
from . import _projects_versions
|
|
from . import regex_hotfix
|
|
from ..conf import settings
|
|
from ..models import Project
|
|
from ..tasks import gerrit_fetch_all
|
|
from ..tasks import gerrit_fetch_info
|
|
from ..utils import build
|
|
from build.models import BuildRelease
|
|
from build.utils import ReleaseConfig
|
|
|
|
logger = structlog.get_logger(__name__)
|
|
|
|
|
|
@login_required
|
|
def index(request):
|
|
context = {
|
|
"releases": ReleaseConfig.supported_releases_dict(),
|
|
"builds": BuildRelease.objects.releases_with_builds(),
|
|
}
|
|
return render(
|
|
request, "release_dashboard/build_supported_releases.html", context
|
|
)
|
|
|
|
|
|
@login_required
|
|
def build_release(request, release):
|
|
release_config = ReleaseConfig(release)
|
|
if request.method == "POST":
|
|
release_uuid = uuid.uuid4()
|
|
BuildRelease.objects.create_build_release(release_uuid, release)
|
|
return HttpResponseRedirect(
|
|
reverse("panel:release-uuid", args=(release_uuid,))
|
|
)
|
|
else:
|
|
build_releases = BuildRelease.objects.release(
|
|
release_config.release, release_config.debian_release
|
|
).order_by("-start_date")
|
|
if build_releases.count() == 0:
|
|
done = True
|
|
else:
|
|
done = build_releases.first().done
|
|
context = {
|
|
"gerrit_url": settings.GERRIT_URL.format("gitweb?p="),
|
|
"config": release_config,
|
|
"build_releases": build_releases,
|
|
"build_deps": list(release_config.build_deps.keys()),
|
|
"done": done,
|
|
}
|
|
return render(request, "release_dashboard/build_release.html", context)
|
|
|
|
|
|
@login_required
|
|
@require_http_methods(["POST"])
|
|
def hotfix_build(request, branch, project):
|
|
if project not in settings.RELEASE_DASHBOARD_PROJECTS:
|
|
error = "repo:%s not valid" % project
|
|
logger.error(error)
|
|
return HttpResponseNotFound(error)
|
|
|
|
if not regex_hotfix.match(branch):
|
|
error = "branch:%s not valid. Not mrX.X.X format" % branch
|
|
logger.error(error)
|
|
return HttpResponseNotFound(error)
|
|
proj = Project.objects.get(name=project)
|
|
|
|
if branch not in proj.branches_mrXXX():
|
|
error = "branch:%s not valid" % branch
|
|
logger.error(error)
|
|
return HttpResponseNotFound(error)
|
|
|
|
json_data = json.loads(request.body.decode("utf-8"))
|
|
push = json_data.get("push", "no")
|
|
empty = json_data.get("empty", False)
|
|
if push == "no":
|
|
logger.warn("dry-run for %s:%s", project, branch)
|
|
urls = build.trigger_hotfix(project, branch, request.user, push, empty)
|
|
return JsonResponse({"urls": urls})
|
|
|
|
|
|
@login_required
|
|
def hotfix(request):
|
|
prj_list = _projects_versions(
|
|
settings.RELEASE_DASHBOARD_PROJECTS, regex_hotfix
|
|
)
|
|
context = {"projects": prj_list}
|
|
return render(request, "release_dashboard/hotfix.html", context)
|
|
|
|
|
|
@login_required
|
|
@require_http_methods(["POST"])
|
|
def hotfix_release_build(request, release, project):
|
|
release_config = ReleaseConfig(release)
|
|
if project not in release_config.projects:
|
|
error = f"project:{project} not in {release_config.release}"
|
|
logger.error(error)
|
|
return HttpResponseNotFound(error)
|
|
|
|
if not regex_hotfix.match(release_config.branch):
|
|
error = f"branch:{release_config.branch} not valid. Not mrX.X.X format"
|
|
logger.error(error)
|
|
return HttpResponseNotFound(error)
|
|
logger.debug(body=request.body)
|
|
json_data = json.loads(request.body.decode("utf-8"))
|
|
push = json_data.get("push", "no")
|
|
empty = json_data.get("empty", False)
|
|
if push == "no":
|
|
logger.warn(f"dry-run for {project}:{release_config.branch}")
|
|
urls = build.trigger_hotfix(
|
|
project, release_config.branch, request.user, push, empty
|
|
)
|
|
return JsonResponse({"urls": urls})
|
|
|
|
|
|
@login_required
|
|
def hotfix_release(request, release):
|
|
release_config = ReleaseConfig(release)
|
|
if not regex_hotfix.match(release_config.branch):
|
|
error = (
|
|
"branch:%s not valid. Not mrX.X.X format" % release_config.branch
|
|
)
|
|
logger.error(error)
|
|
return HttpResponseNotFound(error)
|
|
context = {"config": release_config}
|
|
return render(request, "release_dashboard/hotfix_release.html", context)
|
|
|
|
|
|
@login_required
|
|
def refresh_all(request):
|
|
if request.method == "POST":
|
|
res = gerrit_fetch_all.delay()
|
|
return JsonResponse({"url": "/flower/task/%s" % res.id})
|
|
else:
|
|
template = "release_dashboard/refresh.html"
|
|
projects = []
|
|
for project in settings.RELEASE_DASHBOARD_PROJECTS:
|
|
info = {"name": project, "tags": None}
|
|
projects.append(info)
|
|
return render(request, template, {"projects": projects})
|
|
|
|
|
|
@require_http_methods(["POST"])
|
|
def refresh(request, project):
|
|
res = gerrit_fetch_info.delay(project)
|
|
return JsonResponse({"url": "/flower/task/%s" % res.id})
|