# -*- encoding: utf-8 -*-

import glob
import io
import logging
import re

from odoo.addons.runbot.models.build import runbot_job
from odoo import models

_logger = logging.getLogger(__name__)


class runbot_build(models.Model):
    _inherit = "runbot.build"

    @runbot_job('testing')
    def _job_05_check_cla(self, build, log_path):
        cla_glob = glob.glob(build._path("doc/cla/*/*.md"))
        if cla_glob:
            description = "%s Odoo CLA signature check" % build.author
            mo = re.search('[^ <@]+@[^ @>]+', build.author_email or '')
            state = "failure"
            if mo:
                email = mo.group(0).lower()
                if re.match('.*@(odoo|openerp|tinyerp)\.com$', email):
                    state = "success"
                else:
                    try:
                        cla = ''.join(io.open(f,encoding='utf-8').read() for f in cla_glob)
                        if cla.lower().find(email) != -1:
                            state = "success"
                    except UnicodeDecodeError:
                        description = 'Invalid CLA encoding (must be utf-8)'
                    _logger.info('CLA build:%s email:%s result:%s', build.dest, email, state)
            status = {
                "state": state,
                "target_url": "https://www.odoo.com/sign-cla",
                "description": description,
                "context": "legal/cla"
            }
            build._log('check_cla', 'CLA %s' % state)
            build._github_status_notify_all(status)
        # 0 is myself, -1 is everybody else, -2 nothing
        return -2