import flask

from nyaa import db, forms, models

bp = flask.Blueprint('admin', __name__)


@bp.route('/adminlog', endpoint='log', methods=['GET'])
def view_adminlog():
    if not flask.g.user or not flask.g.user.is_moderator:
        flask.abort(403)

    page = flask.request.args.get('p', flask.request.args.get('offset', 1, int), int)
    logs = models.AdminLog.all_logs() \
        .order_by(models.AdminLog.created_time.desc()) \
        .paginate(page=page, per_page=20)

    return flask.render_template('adminlog.html',
                                 adminlog=logs)


@bp.route('/reports', endpoint='reports', methods=['GET', 'POST'])
def view_reports():
    if not flask.g.user or not flask.g.user.is_moderator:
        flask.abort(403)

    page = flask.request.args.get('p', flask.request.args.get('offset', 1, int), int)
    reports = models.Report.not_reviewed(page)
    report_action = forms.ReportActionForm(flask.request.form)

    if flask.request.method == 'POST' and report_action.validate():
        action = report_action.action.data
        torrent_id = report_action.torrent.data
        report_id = report_action.report.data
        torrent = models.Torrent.by_id(torrent_id)
        report = models.Report.by_id(report_id)
        report_user = models.User.by_id(report.user_id)

        if not torrent or not report or report.status != 0:
            flask.abort(404)
        else:
            log = "Report #{}: {} [#{}]({}), reported by [{}]({})"
            if action == 'delete':
                torrent.deleted = True
                report.status = 1
                log = log.format(report_id, 'Deleted', torrent_id,
                                 flask.url_for('torrents.view', torrent_id=torrent_id),
                                 report_user.username,
                                 flask.url_for('users.view_user', user_name=report_user.username))
            elif action == 'hide':
                log = log.format(report_id, 'Hid', torrent_id,
                                 flask.url_for('torrents.view', torrent_id=torrent_id),
                                 report_user.username,
                                 flask.url_for('users.view_user', user_name=report_user.username))
                torrent.hidden = True
                report.status = 1
            else:
                log = log.format(report_id, 'Closed', torrent_id,
                                 flask.url_for('torrents.view', torrent_id=torrent_id),
                                 report_user.username,
                                 flask.url_for('users.view_user', user_name=report_user.username))
                report.status = 2

            adminlog = models.AdminLog(log=log, admin_id=flask.g.user.id)
            db.session.add(adminlog)

            models.Report.remove_reviewed(torrent_id)
            db.session.commit()
            flask.flash('Closed report #{}'.format(report.id), 'success')
            return flask.redirect(flask.url_for('admin.reports'))

    return flask.render_template('reports.html',
                                 reports=reports,
                                 report_action=report_action)