# -*- coding: utf-8 -*-

# Copyright (C) 2011-2017 RhodeCode GmbH
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License, version 3
# (only), as published by the Free Software Foundation.
#
# 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 Affero General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
#
# This program is dual-licensed. If you wish to learn more about the
# RhodeCode Enterprise Edition, including its added features, Support services,
# and proprietary license terms, please see https://rhodecode.com/licenses/

import logging

from pyramid.view import view_config
from pyramid.httpexceptions import HTTPFound, HTTPNotFound

from rhodecode.apps._base import BaseAppView
from rhodecode.lib import helpers as h
from rhodecode.lib.auth import (NotAnonymous, HasRepoPermissionAny)
from rhodecode.model.db import Repository

log = logging.getLogger(__name__)


class RepoChecksView(BaseAppView):
    def load_default_context(self):
        c = self._get_local_tmpl_context()
        self._register_global_c(c)
        return c

    @NotAnonymous()
    @view_config(
        route_name='repo_creating', request_method='GET',
        renderer='rhodecode:templates/admin/repos/repo_creating.mako')
    def repo_creating(self):
        c = self.load_default_context()

        repo_name = self.request.matchdict['repo_name']
        db_repo = Repository.get_by_repo_name(repo_name)
        if not db_repo:
            raise HTTPNotFound()

        # check if maybe repo is already created
        if db_repo.repo_state in [Repository.STATE_CREATED]:
            # re-check permissions before redirecting to prevent resource
            # discovery by checking the 302 code
            perm_set = ['repository.read', 'repository.write', 'repository.admin']
            has_perm = HasRepoPermissionAny(*perm_set)(
                db_repo.repo_name, 'Repo Creating check')
            if not has_perm:
                raise HTTPNotFound()

            raise HTTPFound(h.route_path(
                'repo_summary', repo_name=db_repo.repo_name))

        c.task_id = self.request.GET.get('task_id')
        c.repo_name = repo_name

        return self._get_template_context(c)

    @NotAnonymous()
    @view_config(
        route_name='repo_creating_check', request_method='GET',
        renderer='json_ext')
    def repo_creating_check(self):
        _ = self.request.translate
        task_id = self.request.GET.get('task_id')
        self.load_default_context()

        repo_name = self.request.matchdict['repo_name']

        if task_id and task_id not in ['None']:
            import rhodecode
            from celery.result import AsyncResult
            if rhodecode.CELERY_ENABLED:
                task = AsyncResult(task_id)
                if task.failed():
                    msg = self._log_creation_exception(task.result, repo_name)
                    h.flash(msg, category='error')
                    raise HTTPFound(h.route_path('home'), code=501)

        db_repo = Repository.get_by_repo_name(repo_name)
        if db_repo and db_repo.repo_state == Repository.STATE_CREATED:
            if db_repo.clone_uri:
                clone_uri = db_repo.clone_uri_hidden
                h.flash(_('Created repository %s from %s')
                        % (db_repo.repo_name, clone_uri), category='success')
            else:
                repo_url = h.link_to(
                    db_repo.repo_name,
                    h.route_path('repo_summary', repo_name=db_repo.repo_name))
                fork = db_repo.fork
                if fork:
                    fork_name = fork.repo_name
                    h.flash(h.literal(_('Forked repository %s as %s')
                                      % (fork_name, repo_url)), category='success')
                else:
                    h.flash(h.literal(_('Created repository %s') % repo_url),
                            category='success')
            return {'result': True}
        return {'result': False}