summaryrefslogtreecommitdiffstats
path: root/forefront/__init__.py
diff options
context:
space:
mode:
Diffstat (limited to 'forefront/__init__.py')
-rw-r--r--forefront/__init__.py187
1 files changed, 97 insertions, 90 deletions
diff --git a/forefront/__init__.py b/forefront/__init__.py
index b247503f..44f5d44d 100644
--- a/forefront/__init__.py
+++ b/forefront/__init__.py
@@ -1,50 +1,54 @@
-from tls_client import Session
-from forefront.mail import Mail
-from time import time, sleep
+from json import loads
from re import match
-from forefront.typing import ForeFrontResponse
+from time import time, sleep
from uuid import uuid4
+
from requests import post
-from json import loads
+from tls_client import Session
+
+from forefront.mail import Mail
+from forefront.typing import ForeFrontResponse
class Account:
- def create(proxy = None, logging = False):
-
+ @staticmethod
+ def create(proxy=None, logging=False):
+
proxies = {
'http': 'http://' + proxy,
- 'https': 'http://' + proxy } if proxy else False
-
+ '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')
+ 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",
+ "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
- }
- )
-
+
+ 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",
+ 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:
@@ -58,88 +62,91 @@ class Account:
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'
- })
-
+
+ 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']
-
+
+ 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:
+ @staticmethod
def create(
- token = None,
- chatId = None,
- prompt = '',
- actionType = 'new',
- defaultPersona = '607e41fe-95be-497e-8e97-010a59b2e2c0', # default
- model = 'gpt-4') -> ForeFrontResponse:
-
+ 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',
+ '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',
+ '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
+ '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():
-
+ 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])
+ 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
+ '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)
+ }
+ })