diff options
Diffstat (limited to 'forefront/__init__.py')
-rw-r--r-- | forefront/__init__.py | 145 |
1 files changed, 145 insertions, 0 deletions
diff --git a/forefront/__init__.py b/forefront/__init__.py new file mode 100644 index 00000000..b247503f --- /dev/null +++ b/forefront/__init__.py @@ -0,0 +1,145 @@ +from tls_client import Session +from forefront.mail import Mail +from time import time, sleep +from re import match +from forefront.typing import ForeFrontResponse +from uuid import uuid4 +from requests import post +from json import loads + + +class Account: + def create(proxy = None, logging = False): + + proxies = { + 'http': 'http://' + proxy, + 'https': 'http://' + proxy } if proxy else False + + start = time() + + mail = Mail(proxies) + mail_token = None + mail_adress = mail.get_mail() + + #print(mail_adress) + + client = Session(client_identifier='chrome110') + client.proxies = proxies + client.headers = { + "origin": "https://accounts.forefront.ai", + "user-agent" : "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36", + } + + response = client.post('https://clerk.forefront.ai/v1/client/sign_ups?_clerk_js_version=4.32.6', + data = { + "email_address": mail_adress + } + ) + + trace_token = response.json()['response']['id'] + if logging: print(trace_token) + + response = client.post(f"https://clerk.forefront.ai/v1/client/sign_ups/{trace_token}/prepare_verification?_clerk_js_version=4.32.6", + data = { + "strategy" : "email_code", + } + ) + + if logging: print(response.text) + + if not 'sign_up_attempt' in response.text: + return 'Failed to create account!' + + while True: + sleep(1) + for _ in mail.fetch_inbox(): + print(mail.get_message_content(_["id"])) + mail_token = match(r"(\d){5,6}", mail.get_message_content(_["id"])).group(0) + + if mail_token: + break + + if logging: print(mail_token) + + response = client.post(f'https://clerk.forefront.ai/v1/client/sign_ups/{trace_token}/attempt_verification?_clerk_js_version=4.38.4', data = { + 'code': mail_token, + 'strategy': 'email_code' + }) + + if logging: print(response.json()) + + token = response.json()['client']['sessions'][0]['last_active_token']['jwt'] + + with open('accounts.txt', 'a') as f: + f.write(f'{mail_adress}:{token}\n') + + if logging: print(time() - start) + + return token + + +class StreamingCompletion: + def create( + token = None, + chatId = None, + prompt = '', + actionType = 'new', + defaultPersona = '607e41fe-95be-497e-8e97-010a59b2e2c0', # default + model = 'gpt-4') -> ForeFrontResponse: + + if not token: raise Exception('Token is required!') + if not chatId: chatId = str(uuid4()) + + headers = { + 'authority' : 'chat-server.tenant-forefront-default.knative.chi.coreweave.com', + 'accept' : '*/*', + 'accept-language' : 'en,fr-FR;q=0.9,fr;q=0.8,es-ES;q=0.7,es;q=0.6,en-US;q=0.5,am;q=0.4,de;q=0.3', + 'authorization' : 'Bearer ' + token, + 'cache-control' : 'no-cache', + 'content-type' : 'application/json', + 'origin' : 'https://chat.forefront.ai', + 'pragma' : 'no-cache', + 'referer' : 'https://chat.forefront.ai/', + 'sec-ch-ua' : '"Chromium";v="112", "Google Chrome";v="112", "Not:A-Brand";v="99"', + 'sec-ch-ua-mobile' : '?0', + 'sec-ch-ua-platform': '"macOS"', + 'sec-fetch-dest' : 'empty', + 'sec-fetch-mode' : 'cors', + 'sec-fetch-site' : 'cross-site', + 'user-agent' : 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/112.0.0.0 Safari/537.36', + } + + json_data = { + 'text' : prompt, + 'action' : actionType, + 'parentId' : chatId, + 'workspaceId' : chatId, + 'messagePersona' : defaultPersona, + 'model' : model + } + + for chunk in post('https://chat-server.tenant-forefront-default.knative.chi.coreweave.com/chat', + headers=headers, json=json_data, stream=True).iter_lines(): + + if b'finish_reason":null' in chunk: + data = loads(chunk.decode('utf-8').split('data: ')[1]) + token = data['choices'][0]['delta'].get('content') + + if token != None: + yield ForeFrontResponse({ + 'id' : chatId, + 'object' : 'text_completion', + 'created': int(time()), + 'model' : model, + 'choices': [{ + 'text' : token, + 'index' : 0, + 'logprobs' : None, + 'finish_reason' : 'stop' + }], + 'usage': { + 'prompt_tokens' : len(prompt), + 'completion_tokens' : len(token), + 'total_tokens' : len(prompt) + len(token) + } + })
\ No newline at end of file |