2018-09-17 00:27:00 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
"""
|
|
|
|
Website property.
|
|
|
|
"""
|
|
|
|
from pkg_resources import resource_stream # @UnresolvedImport
|
|
|
|
from rebulk.remodule import re
|
|
|
|
|
|
|
|
from rebulk import Rebulk, Rule, RemoveMatch
|
|
|
|
from ..common import seps
|
|
|
|
from ..common.formatters import cleanup
|
2020-05-20 15:29:39 +00:00
|
|
|
from ..common.pattern import is_disabled
|
2018-09-17 00:27:00 +00:00
|
|
|
from ..common.validators import seps_surround
|
|
|
|
from ...reutils import build_or_pattern
|
|
|
|
|
|
|
|
|
2020-05-20 15:29:39 +00:00
|
|
|
def website(config):
|
2018-09-17 00:27:00 +00:00
|
|
|
"""
|
|
|
|
Builder for rebulk object.
|
2020-05-20 15:29:39 +00:00
|
|
|
|
|
|
|
:param config: rule configuration
|
|
|
|
:type config: dict
|
2018-09-17 00:27:00 +00:00
|
|
|
:return: Created Rebulk object
|
|
|
|
:rtype: Rebulk
|
|
|
|
"""
|
2020-05-20 15:29:39 +00:00
|
|
|
rebulk = Rebulk(disabled=lambda context: is_disabled(context, 'website'))
|
|
|
|
rebulk = rebulk.regex_defaults(flags=re.IGNORECASE).string_defaults(ignore_case=True)
|
2018-09-17 00:27:00 +00:00
|
|
|
rebulk.defaults(name="website")
|
|
|
|
|
2020-05-20 15:29:39 +00:00
|
|
|
with resource_stream('guessit', 'tlds-alpha-by-domain.txt') as tld_file:
|
|
|
|
tlds = [
|
|
|
|
tld.strip().decode('utf-8')
|
|
|
|
for tld in tld_file.readlines()
|
|
|
|
if b'--' not in tld
|
|
|
|
][1:] # All registered domain extension
|
2018-10-06 17:18:55 +00:00
|
|
|
|
2020-05-20 15:29:39 +00:00
|
|
|
safe_tlds = config['safe_tlds'] # For sure a website extension
|
|
|
|
safe_subdomains = config['safe_subdomains'] # For sure a website subdomain
|
|
|
|
safe_prefix = config['safe_prefixes'] # Those words before a tlds are sure
|
|
|
|
website_prefixes = config['prefixes']
|
2018-09-17 00:27:00 +00:00
|
|
|
|
|
|
|
rebulk.regex(r'(?:[^a-z0-9]|^)((?:'+build_or_pattern(safe_subdomains) +
|
|
|
|
r'\.)+(?:[a-z-]+\.)+(?:'+build_or_pattern(tlds) +
|
|
|
|
r'))(?:[^a-z0-9]|$)',
|
|
|
|
children=True)
|
|
|
|
rebulk.regex(r'(?:[^a-z0-9]|^)((?:'+build_or_pattern(safe_subdomains) +
|
|
|
|
r'\.)*[a-z-]+\.(?:'+build_or_pattern(safe_tlds) +
|
|
|
|
r'))(?:[^a-z0-9]|$)',
|
|
|
|
safe_subdomains=safe_subdomains, safe_tlds=safe_tlds, children=True)
|
|
|
|
rebulk.regex(r'(?:[^a-z0-9]|^)((?:'+build_or_pattern(safe_subdomains) +
|
|
|
|
r'\.)*[a-z-]+\.(?:'+build_or_pattern(safe_prefix) +
|
|
|
|
r'\.)+(?:'+build_or_pattern(tlds) +
|
|
|
|
r'))(?:[^a-z0-9]|$)',
|
|
|
|
safe_subdomains=safe_subdomains, safe_prefix=safe_prefix, tlds=tlds, children=True)
|
|
|
|
|
|
|
|
rebulk.string(*website_prefixes,
|
|
|
|
validator=seps_surround, private=True, tags=['website.prefix'])
|
|
|
|
|
|
|
|
class PreferTitleOverWebsite(Rule):
|
|
|
|
"""
|
|
|
|
If found match is more likely a title, remove website.
|
|
|
|
"""
|
|
|
|
consequence = RemoveMatch
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def valid_followers(match):
|
|
|
|
"""
|
|
|
|
Validator for next website matches
|
|
|
|
"""
|
2020-05-20 15:29:39 +00:00
|
|
|
return match.named('season', 'episode', 'year')
|
2018-09-17 00:27:00 +00:00
|
|
|
|
|
|
|
def when(self, matches, context):
|
|
|
|
to_remove = []
|
|
|
|
for website_match in matches.named('website'):
|
|
|
|
safe = False
|
|
|
|
for safe_start in safe_subdomains + safe_prefix:
|
|
|
|
if website_match.value.lower().startswith(safe_start):
|
|
|
|
safe = True
|
|
|
|
break
|
|
|
|
if not safe:
|
|
|
|
suffix = matches.next(website_match, PreferTitleOverWebsite.valid_followers, 0)
|
|
|
|
if suffix:
|
2020-05-20 15:29:39 +00:00
|
|
|
group = matches.markers.at_match(website_match, lambda marker: marker.name == 'group', 0)
|
|
|
|
if not group:
|
|
|
|
to_remove.append(website_match)
|
2018-09-17 00:27:00 +00:00
|
|
|
return to_remove
|
|
|
|
|
|
|
|
rebulk.rules(PreferTitleOverWebsite, ValidateWebsitePrefix)
|
|
|
|
|
|
|
|
return rebulk
|
|
|
|
|
|
|
|
|
|
|
|
class ValidateWebsitePrefix(Rule):
|
|
|
|
"""
|
|
|
|
Validate website prefixes
|
|
|
|
"""
|
|
|
|
priority = 64
|
|
|
|
consequence = RemoveMatch
|
|
|
|
|
|
|
|
def when(self, matches, context):
|
|
|
|
to_remove = []
|
|
|
|
for prefix in matches.tagged('website.prefix'):
|
|
|
|
website_match = matches.next(prefix, predicate=lambda match: match.name == 'website', index=0)
|
|
|
|
if (not website_match or
|
|
|
|
matches.holes(prefix.end, website_match.start,
|
|
|
|
formatter=cleanup, seps=seps, predicate=lambda match: match.value)):
|
|
|
|
to_remove.append(prefix)
|
|
|
|
return to_remove
|