Select pass candidates for the fully-qualified domain name first, then for the registered domain and finally the IPv4 address if that is what the URL was

This commit is contained in:
cryzed 2017-11-03 02:43:33 +01:00
parent 16fefc1c7b
commit 78eb7b5da8

View File

@ -50,11 +50,10 @@ stderr = functools.partial(print, file=sys.stderr)
class ExitCodes(enum.IntEnum): class ExitCodes(enum.IntEnum):
SUCCESS = 0 SUCCESS = 0
COULD_NOT_DETERMINE_URL = 1 # 1 is reserved for general script errors
COULD_NOT_DETERMINE_DOMAIN = 2 NO_PASS_CANDIDATES = 2
NO_PASS_CANDIDATES = 3 COULD_NOT_MATCH_USERNAME = 3
COULD_NOT_MATCH_USERNAME = 4 COULD_NOT_MATCH_PASSWORD = 4
COULD_NOT_MATCH_PASSWORD = 5
def qute_command(command): def qute_command(command):
@ -88,20 +87,19 @@ def dmenu(items, invocation, encoding):
def main(arguments): def main(arguments):
# Domain wasn't overriden using CLI argument or found in qutebrowser environment variable domain = tldextract.extract(arguments.url)
if not arguments.url:
stderr('Could not determine URL!')
return ExitCodes.COULD_NOT_DETERMINE_URL
domain = tldextract.extract(arguments.url).registered_domain
if not domain:
stderr('Could not determine domain from URL: {!r}!'.format(arguments.url))
return ExitCodes.COULD_NOT_DETERMINE_DOMAIN
# Expand potential ~ in paths, since this script won't be called from a shell that does it for us # Expand potential ~ in paths, since this script won't be called from a shell that does it for us
candidates = find_pass_candidates(domain, os.path.expanduser(arguments.password_store)) password_store_path = os.path.expanduser(arguments.password_store)
if not candidates:
stderr('No candidates for domain {!r} found!'.format(domain)) # Try to find candidates using targets in the following order: fully qualified domain (including subdomains),
# registered domain and finally the IPv4 address if that's what the URL was
for target in filter(None, [domain.fqdn, domain.registered_domain, domain.ipv4]):
candidates = find_pass_candidates(target, password_store_path)
if candidates:
break
else:
stderr('No pass candidates for URL {!r} found!'.format(arguments.url))
return ExitCodes.NO_PASS_CANDIDATES return ExitCodes.NO_PASS_CANDIDATES
selection = candidates[0] if len(candidates) == 1 else dmenu(candidates, arguments.dmenu_invocation, selection = candidates[0] if len(candidates) == 1 else dmenu(candidates, arguments.dmenu_invocation,