diff --git a/.gitignore b/.gitignore index f06c797..1e6bc4d 100644 --- a/.gitignore +++ b/.gitignore @@ -127,3 +127,7 @@ SpotifyAccountCreator_v1.0.1.zip SpotifyAccountCreator_v1.0.1/SpotifyAccountCreator.exe hits.txt detailed_hits.txt +output/SpotifyAccountCreator.exe +SpotifyAccountCreator.zip +SpotifyAccountCreator/proxies.txt +SpotifyAccountCreator/SpotifyAccountCreator.exe diff --git a/README.md b/README.md index 7c77903..a8719cb 100644 --- a/README.md +++ b/README.md @@ -2,14 +2,13 @@ Creates Spotify accounts for you. # Tool -![](https://i.ibb.co/G0BFypG/example2.png) +![](https://i.ibb.co/kx5jyL8/tool.png) # Example -![](https://i.ibb.co/pnNBzxb/example.png) +![](https://i.ibb.co/mXx45jP/example.png) - # Legal - This was merely a speedrun to demonstrate how account creators work.
+ This was merely a speedrun to demonstrate how account checkers work.
This is illegal if you use this without the consent of the owners (in this case, the Spotify team).
The software designed to perform website security testing.
The author is not responsible for any illegal use of these programs.
diff --git a/main.py b/main.py index 5a42a5c..ae1cbb6 100644 --- a/main.py +++ b/main.py @@ -7,156 +7,183 @@ from colorama import init,Fore from bs4 import BeautifulSoup from fake_useragent import UserAgent -from threading import Thread, Lock - -init() -ua = UserAgent() - -def clear(): - if os.name == 'posix': - os.system('clear') - elif os.name in ('ce', 'nt', 'dos'): - os.system('cls') - else: - print("\n") * 120 - -def SetTitle(title_name:str): - os.system("title {0}".format(title_name)) - -def ReadFile(filename,method): - with open(filename,method) as f: - content = [line.strip('\n') for line in f] - return content - -def PrintText(info_name,text,info_color:Fore,text_color:Fore): - lock = Lock() - lock.acquire() - sys.stdout.flush() - text = text.encode('ascii','replace').decode() - sys.stdout.write(f'[{info_color+info_name+Fore.RESET}] '+text_color+f'{text}\n') - lock.release() - - -SetTitle('One Man Builds Spotify Account Creator Tool') -clear() -birth_year_start = int(input('Enter the birth year start: ')) -birth_year_end = int(input('Enter the birth year end: ')) -method = int(input('[1] Valid credentails lookalike [2] Random strings (faster): ')) - - -def AddRandomDomain(username): - email_providers = ['gmail.com', 'yahoo.com', 'hotmail.com', 'hotmail.co.uk', 'hotmail.fr', 'outlook.com', 'icloud.com', 'mail.com', 'live.com', 'yahoo.it', 'yahoo.ca', 'yahoo.in', 'live.se', 'orange.fr', 'msn.com', 'mail.ru', 'mac.com'] - return username+'@'+random.choice(email_providers) - -def GenUsername(gender): - country_codes = ['ru','en','it','fr','uk','hu','pl','cz'] - - country = random.choice(country_codes) - - URL = "https://fakenamegenerator.com/gen-{0}-{1}-{2}.php".format(gender,country,country) - - headers = { - 'User-Agent': ua.random - } - - response = requests.get(URL,headers=headers).text - soup = BeautifulSoup(response,"html.parser") - fullname = soup.find('div',{'class':'address'}).h3.text - uname_characters = string.ascii_letters + string.digits + '_' - valid_username = fullname.lower().replace(' ','') - characters = ''.join(random.choice(uname_characters) for i in range(random.randint(1,6))) - return valid_username+characters - - -def GenCredentailsMethod1(): - credentails = {} - credentails['gender'] = random.choice(['male', 'female']) - credentails['birth_year'] = random.randint(birth_year_start,birth_year_end) - credentails['birth_month'] = random.randint(1,12) - credentails['birth_day'] = random.randint(1,28) - password_characters = string.ascii_letters + string.digits - password_characters = ''.join(random.choice(password_characters) for i in range(random.randint(8,15))) - credentails['password'] = password_characters - username = GenUsername(credentails['gender']) - credentails['username'] = username - email = AddRandomDomain(username) - credentails['email'] = email - return credentails - -def GenCredentailsMethod2(): - credentails = {} - credentails['gender'] = random.choice(['male', 'female']) - credentails['birth_year'] = random.randint(birth_year_start,birth_year_end) - credentails['birth_month'] = random.randint(1,12) - credentails['birth_day'] = random.randint(1,28) - password_characters = string.ascii_letters + string.digits - password_characters = ''.join(random.choice(password_characters) for i in range(random.randint(8,15))) - credentails['password'] = password_characters - username = string.ascii_letters + string.digits - username = ''.join(random.choice(username) for i in range(random.randint(7,11))) - credentails['username'] = username - email = AddRandomDomain(username) - credentails['email'] = email - return credentails - - - - -def SpotifyCreator(method): - - create_headers = { - 'User-agent': 'S4A/2.0.15 (com.spotify.s4a; build:201500080; iOS 13.4.0) Alamofire/4.9.0', - 'Content-Type': 'application/x-www-form-urlencoded; charset=utf-8', - 'Accept': 'application/json, text/plain;q=0.2, */*;q=0.1', - 'App-Platform': 'IOS', - 'Spotify-App': 'S4A', - 'Accept-Language': 'en-TZ;q=1.0', - 'Accept-Encoding': 'gzip;q=1.0, compress;q=0.5', - 'Spotify-App-Version': '2.0.15' - } - - create_response = '' - - create_url = 'https://spclient.wg.spotify.com/signup/public/v1/account' - - credentails = '' - - if method == 1: - credentails = GenCredentailsMethod1() - else: - credentails = GenCredentailsMethod2() - - payload = 'creation_point=lite_7e7cf598605d47caba394c628e2735a2&password_repeat={0}&platform=Android-ARM&iagree=true&password={1}&gender={2}&key=a2d4b979dc624757b4fb47de483f3505&birth_day={3}&birth_month={4}&email={5}&birth_year={6}'.format(credentails['password'],credentails['password'],credentails['gender'],credentails['birth_day'],credentails['birth_month'],credentails['email'],credentails['birth_year']) - try: - - create_response = requests.post(create_url, data=payload, headers=create_headers) - - json_data = json.loads(create_response.text) - - if 'status' in json_data: - if json_data['status'] == 1: - username = json_data['username'] - if username != '': - PrintText('CREATED','{0}:{1} -> {2}:{3}/{4}/{5}/{6}'.format(credentails['email'],credentails['password'],credentails['username'],credentails['gender'],credentails['birth_year'],credentails['birth_month'],credentails['birth_day']),Fore.GREEN,Fore.WHITE) - with open('hits.txt','a') as f: - f.write('{0}:{1}\n'.format(credentails['email'],credentails['password'])) - with open('detailed_hits.txt','a') as f: - f.write('{0}:{1} -> {2}:{3}/{4}/{5}/{6}\n'.format(credentails['email'],credentails['password'],credentails['username'],credentails['gender'],credentails['birth_year'],credentails['birth_month'],credentails['birth_day'])) +from threading import Thread, Lock,active_count + +class Main: + + def clear(self): + if os.name == 'posix': + os.system('clear') + elif os.name in ('ce', 'nt', 'dos'): + os.system('cls') + else: + print("\n") * 120 + + def SetTitle(self,title_name:str): + os.system("title {0}".format(title_name)) + + def ReadFile(self,filename,method): + with open(filename,method) as f: + content = [line.strip('\n') for line in f] + return content + + def GetRandomProxy(self): + proxies_file = self.ReadFile('proxies.txt','r') + proxies = { + "http":"http://{0}".format(random.choice(proxies_file)), + "https":"https://{0}".format(random.choice(proxies_file)) + } + return proxies + + def __init__(self): + init(convert=True) + self.SetTitle('One Man Builds Spotify Account Creator Tool') + self.clear() + title = Fore.YELLOW+""" + + ____ ___ ____ ___ _ ____ _ _ ____ ____ ____ ____ _ _ _ _ ___ + [__ |__] | | | | |___ \_/ |__| | | | | | | |\ | | + ___] | |__| | | | | | | |___ |___ |__| |__| | \| | + + ____ ____ ____ ____ ___ ____ ____ + | |__/ |___ |__| | | | |__/ + |___ | \ |___ | | | |__| | \ + + + """ + print(title) + self.method = int(input(Fore.YELLOW+'['+Fore.WHITE+'>'+Fore.YELLOW+'] [1]Valid Credentails Lookalike [0]Random Strings: ')) + self.use_proxy = int(input(Fore.YELLOW+'['+Fore.WHITE+'>'+Fore.YELLOW+'] Would you like to use proxies [1]yes [0]no: ')) + self.threads = int(input(Fore.YELLOW+'['+Fore.WHITE+'>'+Fore.YELLOW+'] Threads: ')) + self.birth_year_start = int(input(Fore.YELLOW+'['+Fore.WHITE+'>'+Fore.YELLOW+'] Enter the birth year start: ')) + self.birth_year_end = int(input(Fore.YELLOW+'['+Fore.WHITE+'>'+Fore.YELLOW+'] Enter the birth year end: ')) + self.ua = UserAgent() + self.lock = Lock() + print('') + + def PrintText(self,info_name,text,info_color:Fore,text_color:Fore): + self.lock.acquire() + sys.stdout.flush() + text = text.encode('ascii','replace').decode() + sys.stdout.write(f'[{info_color+info_name+Fore.RESET}] '+text_color+f'{text}\n') + self.lock.release() + + def AddRandomDomain(self,username): + email_providers = ['gmail.com', 'yahoo.com', 'hotmail.com', 'hotmail.co.uk', 'hotmail.fr', 'outlook.com', 'icloud.com', 'mail.com', 'live.com', 'yahoo.it', 'yahoo.ca', 'yahoo.in', 'live.se', 'orange.fr', 'msn.com', 'mail.ru', 'mac.com'] + return username+'@'+random.choice(email_providers) + + def GenUsername(self,gender): + country_codes = ['ru','en','it','fr','uk','hu','pl','cz'] + + country = random.choice(country_codes) + + URL = "https://fakenamegenerator.com/gen-{0}-{1}-{2}.php".format(gender,country,country) + + headers = { + 'User-Agent': self.ua.random + } + + response = requests.get(URL,headers=headers).text + soup = BeautifulSoup(response,"html.parser") + fullname = soup.find('div',{'class':'address'}).h3.text + uname_characters = string.ascii_letters + string.digits + '_' + valid_username = fullname.lower().replace(' ','') + characters = ''.join(random.choice(uname_characters) for i in range(random.randint(1,6))) + return valid_username+characters + + + def GenCredentailsMethod1(self): + credentails = {} + credentails['gender'] = random.choice(['male', 'female']) + credentails['birth_year'] = random.randint(self.birth_year_start,self.birth_year_end) + credentails['birth_month'] = random.randint(1,12) + credentails['birth_day'] = random.randint(1,28) + password_characters = string.ascii_letters + string.digits + password_characters = ''.join(random.choice(password_characters) for i in range(random.randint(8,15))) + credentails['password'] = password_characters + username = self.GenUsername(credentails['gender']) + credentails['username'] = username + email = self.AddRandomDomain(username) + credentails['email'] = email + return credentails + + def GenCredentailsMethod2(self): + credentails = {} + credentails['gender'] = random.choice(['male', 'female']) + credentails['birth_year'] = random.randint(self.birth_year_start,self.birth_year_end) + credentails['birth_month'] = random.randint(1,12) + credentails['birth_day'] = random.randint(1,28) + password_characters = string.ascii_letters + string.digits + password_characters = ''.join(random.choice(password_characters) for i in range(random.randint(8,15))) + credentails['password'] = password_characters + username = string.ascii_letters + string.digits + username = ''.join(random.choice(username) for i in range(random.randint(7,11))) + credentails['username'] = username + email = self.AddRandomDomain(username) + credentails['email'] = email + return credentails + + def SpotifyCreator(self): + try: + create_headers = { + 'User-agent': 'S4A/2.0.15 (com.spotify.s4a; build:201500080; iOS 13.4.0) Alamofire/4.9.0', + 'Content-Type': 'application/x-www-form-urlencoded; charset=utf-8', + 'Accept': 'application/json, text/plain;q=0.2, */*;q=0.1', + 'App-Platform': 'IOS', + 'Spotify-App': 'S4A', + 'Accept-Language': 'en-TZ;q=1.0', + 'Accept-Encoding': 'gzip;q=1.0, compress;q=0.5', + 'Spotify-App-Version': '2.0.15' + } + + create_response = '' + + create_url = 'https://spclient.wg.spotify.com/signup/public/v1/account' + + credentails = '' + + if self.method == 1: + credentails = self.GenCredentailsMethod1() + else: + credentails = self.GenCredentailsMethod2() + + payload = 'creation_point=lite_7e7cf598605d47caba394c628e2735a2&password_repeat={0}&platform=Android-ARM&iagree=true&password={1}&gender={2}&key=a2d4b979dc624757b4fb47de483f3505&birth_day={3}&birth_month={4}&email={5}&birth_year={6}'.format(credentails['password'],credentails['password'],credentails['gender'],credentails['birth_day'],credentails['birth_month'],credentails['email'],credentails['birth_year']) + + create_response = '' + + if self.use_proxy == 1: + create_response = requests.post(create_url, data=payload, headers=create_headers,proxies=self.GetRandomProxy(),timeout=5) + else: + create_response = requests.post(create_url, data=payload, headers=create_headers) + + json_data = json.loads(create_response.text) + #print(json_data) + + if 'status' in json_data: + if json_data['status'] == 1: + username = json_data['username'] + if username != '': + self.PrintText('CREATED','{0}:{1} | {2} | {3} | {4}/{5}/{6}'.format(credentails['email'],credentails['password'],credentails['username'],credentails['gender'],credentails['birth_year'],credentails['birth_month'],credentails['birth_day']),Fore.GREEN,Fore.WHITE) + with open('hits.txt','a') as f: + f.write('{0}:{1}\n'.format(credentails['email'],credentails['password'])) + with open('detailed_hits.txt','a') as f: + f.write('{0}:{1} | {2} | {3} | {4}/{5}/{6}\n'.format(credentails['email'],credentails['password'],credentails['username'],credentails['gender'],credentails['birth_year'],credentails['birth_month'],credentails['birth_day'])) + else: + self.SpotifyCreator() else: - SpotifyCreator(method) + self.SpotifyCreator() else: - SpotifyCreator(method) - else: - SpotifyCreator(method) - except: - SpotifyCreator(method) + self.SpotifyCreator() + except: + self.SpotifyCreator() + def Start(self): + while True: + if active_count()<=self.threads: + Thread(target=self.SpotifyCreator).start() if __name__ == "__main__": - print('') - lock = Lock() - while True: - lock.acquire() - Thread(target=SpotifyCreator(method)).start() - lock.release() \ No newline at end of file + main = Main() + main.Start() + \ No newline at end of file diff --git a/proxies.txt b/proxies.txt new file mode 100644 index 0000000..e69de29