Merge pull request #1298 from aristosgi/add_feature

Add feature
pull/1307/head
Yahya SayadArbabi 3 years ago committed by GitHub
commit dee7feb9b1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -250,6 +250,29 @@ class QueryNotifyPrint(QueryNotify):
return return
def finish(self, message="The processing has been finished."):
"""Notify Start.
Will print the last line to the standard output.
Keyword Arguments:
self -- This object.
message -- The last phrase.
Return Value:
Nothing.
"""
title = "End"
print('\r') # An empty line between last line of main output and last line(more clear output)
print(Style.BRIGHT + Fore.GREEN + "[" +
Fore.YELLOW + "!" +
Fore.GREEN + f"] {title}" +
Fore.GREEN + ": " +
Fore.WHITE + f" {message}" )
# An empty line between first line and the result(more clear output)
return
def __str__(self): def __str__(self):
"""Convert Object To String. """Convert Object To String.

@ -140,6 +140,24 @@ def interpolate_string(object, username):
return object return object
def CheckForParameter(username):
'''checks if {?} exists in the username
if exist it means that sherlock is looking for more multiple username'''
return("{?}" in username)
checksymbols = []
checksymbols = ["_", "-", "."]
def MultipleUsernames(username):
'''replace the parameter with with symbols and return a list of usernames'''
allUsernames = []
for i in checksymbols:
allUsernames.append(username.replace("{?}", i))
return allUsernames
def sherlock(username, site_data, query_notify, def sherlock(username, site_data, query_notify,
tor=False, unique_tor=False, tor=False, unique_tor=False,
proxy=None, timeout=None): proxy=None, timeout=None):
@ -176,7 +194,7 @@ def sherlock(username, site_data, query_notify,
# Notify caller that we are starting the query. # Notify caller that we are starting the query.
query_notify.start(username) query_notify.start(username)
print()
# Create session based on request methodology # Create session based on request methodology
if tor or unique_tor: if tor or unique_tor:
# Requests using Tor obfuscation # Requests using Tor obfuscation
@ -427,9 +445,6 @@ def sherlock(username, site_data, query_notify,
# Add this site's results into final dictionary with all of the other results. # Add this site's results into final dictionary with all of the other results.
results_total[social_network] = results_site results_total[social_network] = results_site
# Notify caller that all queries are finished.
query_notify.finish()
return results_total return results_total
@ -564,6 +579,7 @@ def main():
if args.tor or args.unique_tor: if args.tor or args.unique_tor:
print("Using Tor to make requests") print("Using Tor to make requests")
print( print(
"Warning: some websites might refuse connecting over Tor, so note that using this option might increase connection errors.") "Warning: some websites might refuse connecting over Tor, so note that using this option might increase connection errors.")
@ -631,7 +647,15 @@ def main():
print_all=args.print_all) print_all=args.print_all)
# Run report on all specified users. # Run report on all specified users.
all_usernames = []
for username in args.username: for username in args.username:
if(CheckForParameter(username)):
for name in MultipleUsernames(username):
all_usernames.append(name)
else:
all_usernames.append(username)
for username in all_usernames:
results = sherlock(username, results = sherlock(username,
site_data, site_data,
query_notify, query_notify,
@ -693,7 +717,9 @@ def main():
] ]
) )
print() print()
query_notify.finish()
if __name__ == "__main__": if __name__ == "__main__":
main() main()
# Notify caller that all queries are finished.

Loading…
Cancel
Save