コード例 #1
0
    def GetTemplate(self):
        """Parse the EZT template, or return an already parsed one."""
        # We don't operate directly on self.template to avoid races.
        template = self.template

        if template is None or settings.local_mode:
            start = time.time()
            template = ezt.Template(
                fname=self.template_path,
                compress_whitespace=self.compress_whitespace,
                base_format=self.base_format)
            logging.info('parsed in %dms', int((time.time() - start) * 1000))
            self.template = template

        return template
コード例 #2
0
ファイル: main.py プロジェクト: xinghun61/infra
  def get(self):
    uas = self.request.headers['User-Agent']
    role = self.request.get('role')
    continue_url = self.request.get('continue')
    token = self.request.get('token')

    self.response.headers.add(
        'Strict-Transport-Security',
        'max-age=31536000; includeSubDomains; preload')

    if continue_url and not token:
      logging.info('Missing token')
      self.response.out.write(MISSING_TOKEN_HTML)
      return

    if not continue_url:
      continue_url = 'https://bugs.chromium.org/p/chromium/issues/entry.do'

    parsed = urlparse.urlparse(continue_url)
    scheme_is_allowed = parsed.scheme in ALLOWED_CONTINUE_SCHEMES
    domain_is_allowed = any(
        regex.match(parsed.netloc) for regex in ALLOWED_CONTINUE_DOMAINS)
    continue_is_allowed = scheme_is_allowed and domain_is_allowed
    if not continue_is_allowed:
      logging.info('Bad continue param: %r', continue_url)
      self.response.out.write(INVALID_CONTINUE_HTML)
      return

    validate_url = continue_url.split('?')[0]

    if not validate_url.endswith('.do'):
      logging.info('validate_url does not end in .do: %r', validate_url)
      self.response.out.write(
        'Malformed "continue" query string parameter: %r' %
        urllib.quote(validate_url))
      return

    issue_entry_page_url = validate_url[:-3]

    user = users.get_current_user()
    if role or (user and re.match(
        r".*?@chromium\.org\Z", user.email(), re.DOTALL | re.IGNORECASE)):
      logging.info('Redirecting because you have a role or @chromium.org acct')
      logging.info('role = %r', role)
      logging.info('email = %r', user and user.email())
      self.redirect(issue_entry_page_url.encode('utf8'))
      return

    ua = httpagentparser.detect(uas)
    name = ''
    os_version = ''
    browser = None
    browser_version = None
    chrome_version = "<Copy from: 'about:version'>"
    chrome_ua = ""
    template_name = DEFAULT_BUG_TEMPLATE_NAME
    # Mac
    # {'flavor': {'version': 'X 10.6.6', 'name': 'MacOS'},
    #  'os': {'name': 'Macintosh'},
    #  'browser': {'version': '11.0.696.16', 'name': 'Chrome'}}

    # Win
    # {'os': {'version': 'NT 6.1', 'name': 'Windows'},
    # 'browser': {'version': '11.0.696.16', 'name': 'Chrome'}}

    if ua:
      if ua.has_key('os') and ua['os'].has_key('name'):
        name = ua['os']['name']
        if name == 'Windows':
          if 'version' in ua['os']:
            os_version = ua['os']['version']
          else:
            os_version = 'Unknown'

          match = re.search(
            r"(\d+\.\d+)", os_version, re.DOTALL | re.IGNORECASE)
          if match:
            version = match.group(1)
          else:
            version = ''
          if version == '6.2':
            os_version += ' (Windows 8)'
          elif version == '6.1':
            os_version += ' (Windows 7, Windows Server 2008 R2)'
          elif version == '6.0':
            os_version += ' (Windows Vista, Windows Server 2008)'
          elif version == '5.2':
            os_version += ' (Windows Server 2003, Windows XP 64)'
          elif version == '5.1':
            os_version += ' (Windows XP)'
          elif version == '5.0':
            os_version += ' (Windows 2000)'

          template_name = WINDOWS_BUG_TEMPLATE_NAME
        elif name == 'Macintosh':
          template_name = MAC_BUG_TEMPLATE_NAME
          if ua.has_key('flavor') and ua['flavor'].has_key('version'):
            os_version = ua['flavor']['version']
        elif name == 'Linux':
          template_name = LINUX_BUG_TEMPLATE_NAME
        # We might be able to do flavors
        elif name == 'ChromeOS':
          template_name = CHROME_OS_BUG_TEMPLATE_NAME
          os_version = ua['os']['version']

      if ua.has_key('browser'):
        browser = ua['browser']['name']
        browser_version = ua['browser']['version']
        if browser == "Chrome":
          chrome_version = browser_version
          chrome_ua = '\nUserAgentString: %s\n' % uas

    if not token or self.ShouldDoLegacyBehavior(browser, browser_version):
      # Allow us to measure number of users who came through new.crbug.com
      # by putting in a phrase that we can query for: "instead of that".
      # Also, when bugs.chromium.org is in a scheduled read-only period, direct
      # users straight to the classic issue entry page.
      detectable_phrase = '' if token else ' of that'
      comment = legacy_template % (
        chrome_version, os_version, detectable_phrase, chrome_ua)
      url = (issue_entry_page_url + '?template=' + template_name + '&' +
             urllib.urlencode({'comment': comment}))
      self.redirect(url.encode('utf8'))
      return

    channel_guess_os_name = {
        'macintosh': 'mac',
        'windows': 'win',
        'linux': 'linux',
        'ios': 'ios',
        'chromeos': 'cros',
        # Android cannot be guessed.
        }.get(name.lower(), name.lower())

    app_version = os.environ.get('CURRENT_VERSION_ID')
    page_data = {
        'app_version': app_version,
        'chrome_version': chrome_version,
        'channel_guess_os_name': channel_guess_os_name,
        'os_name': name,
        'os_version': os_version,
        'chrome_ua': chrome_ua,
        'issue_entry_page_url': issue_entry_page_url,
        'continue_url': continue_url,
        'token': token,
        }
    # TODO(jrobbins): Use WIZARD_HTML_TEMPLATE for speed.
    ezt.Template(WIZARD_TEMPLATE_PATH, base_format=ezt.FORMAT_HTML).generate(
      self.response.out, page_data)
コード例 #3
0
ファイル: main.py プロジェクト: xinghun61/infra
import webapp2

from google.appengine.api import users
from google.appengine.ext.webapp import util

# pylint warning disabled until httpagentparser can be added to the wheelhouse.
# http://crbug.com/410984
import httpagentparser # pylint: disable=F0401
import settings
from third_party import ezt

import gae_ts_mon


WIZARD_TEMPLATE_PATH = 'templates/wizard.ezt'
WIZARD_HTML_TEMPLATE = ezt.Template(WIZARD_TEMPLATE_PATH)

legacy_template = """Chrome Version       : %s
OS Version: %s
URLs (if applicable) :
Other browsers tested:
  Add OK or FAIL after other browsers where you have tested this issue:
     Safari:
    Firefox:
    IE/Edge:

What steps will reproduce the problem?
1.
2.
3.
コード例 #4
0
    def get(self):
        uas = self.request.headers['User-Agent']
        role = self.request.get('role')
        continue_url = self.request.get('continue')
        token = self.request.get('token')

        if continue_url and not token:
            self.response.out.write(MISSING_TOKEN_HTML)
            return

        if not continue_url:
            continue_url = 'http://code.google.com/p/chromium/issues/entry.do'

            # Special case, chromium-os issues are now being tracked in /p/chromium.
            if '//code.google.com/p/chromium-os/issues/entry.do' in continue_url:
                continue_url = 'http://code.google.com/p/chromium/issues/entry.do'

            if '?' in continue_url:
                # Codesite includes contextual parameters for search terms, etc.
                validate_url = continue_url.split('?')[0]
            else:
                validate_url = continue_url

            if (not validate_url.startswith('http')
                    or not validate_url.endswith('.do')):
                self.response.out.write(
                    'Malformed "continue" query string parameter: %r' %
                    urllib.quote(validate_url))
                return

            issue_entry_page_url = validate_url[:-3]

            user = users.get_current_user()
            if role or (user and re.match(r".*?@chromium\.org\Z", user.email(),
                                          re.DOTALL | re.IGNORECASE)):
                self.redirect(issue_entry_page_url)
                return

            ua = httpagentparser.detect(uas)
            name = ''
            os_version = ''
            browser = None
            browser_version = None
            chrome_version = "<Copy from: 'about:version'>"
            chrome_ua = ""
            template_name = DEFAULT_BUG_TEMPLATE_NAME
            # Mac
            # {'flavor': {'version': 'X 10.6.6', 'name': 'MacOS'},
            #  'os': {'name': 'Macintosh'},
            #  'browser': {'version': '11.0.696.16', 'name': 'Chrome'}}

            # Win
            # {'os': {'version': 'NT 6.1', 'name': 'Windows'},
            # 'browser': {'version': '11.0.696.16', 'name': 'Chrome'}}

            if ua:
                if ua.has_key('os') and ua['os'].has_key('name'):
                    name = ua['os']['name']
                    if name == 'Windows':
                        if 'version' in ua['os']:
                            os_version = ua['os']['version']
                        else:
                            os_version = 'Unknown'

                        match = re.search(r"(\d+\.\d+)", os_version,
                                          re.DOTALL | re.IGNORECASE)
                        if match:
                            version = match.group(1)
                        else:
                            version = ''
                        if version == '6.2':
                            os_version += ' (Windows 8)'
                        elif version == '6.1':
                            os_version += ' (Windows 7, Windows Server 2008 R2)'
                        elif version == '6.0':
                            os_version += ' (Windows Vista, Windows Server 2008)'
                        elif version == '5.2':
                            os_version += ' (Windows Server 2003, Windows XP 64)'
                        elif version == '5.1':
                            os_version += ' (Windows XP)'
                        elif version == '5.0':
                            os_version += ' (Windows 2000)'

                        template_name = WINDOWS_BUG_TEMPLATE_NAME
                    elif name == 'Macintosh':
                        template_name = MAC_BUG_TEMPLATE_NAME
                        if ua.has_key('flavor') and ua['flavor'].has_key(
                                'version'):
                            os_version = ua['flavor']['version']
                    elif name == 'Linux':
                        template_name = LINUX_BUG_TEMPLATE_NAME
                    # We might be able to do flavors
                    elif name == 'ChromeOS':
                        template_name = CHROME_OS_BUG_TEMPLATE_NAME
                        os_version = ua['os']['version']

                if ua.has_key('browser'):
                    browser = ua['browser']['name']
                    browser_version = ua['browser']['version']
                    if browser == "Chrome":
                        chrome_version = browser_version
                        chrome_ua = '\nUserAgentString: %s\n' % uas

            if not token or self.ShouldDoLegacyBehavior(
                    browser, browser_version):
                # Allow us to measure number of users who came through new.crbug.com
                # by putting in a phrase that we can query for: "instead of that".
                # Also, when code.google.com is in a scheduled read-only period, direct
                # users straight to the classic issue entry page.
                detectable_phrase = '' if token else ' of that'
                comment = legacy_template % (chrome_version, os_version,
                                             detectable_phrase, chrome_ua)
                url = (issue_entry_page_url + '?template=' + template_name +
                       '&' + urllib.urlencode({'comment': comment}))
                self.redirect(url)
                return

            channel_guess_os_name = {
                'macintosh': 'mac',
                'windows': 'win',
                'linux': 'linux',
                'ios': 'ios',
                'chromeframe': 'cf',
                'chromeos': 'cros',
                # Android cannot be guessed.
            }.get(name.lower(), name.lower())

            app_version = os.environ.get('CURRENT_VERSION_ID')
            page_data = {
                'app_version': app_version,
                'chrome_version': chrome_version,
                'channel_guess_os_name': channel_guess_os_name,
                'os_name': name,
                'os_version': os_version,
                'chrome_ua': chrome_ua,
                'continue_url': continue_url,
                'token': token,
            }
            # TODO(jrobbins): Use WIZARD_HTML_TEMPLATE for speed.
            ezt.Template(WIZARD_TEMPLATE_PATH,
                         base_format=ezt.FORMAT_HTML).generate(
                             self.response.out, page_data)