Spaces:
Sleeping
Sleeping
File size: 3,518 Bytes
8d70bcd |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 |
import os,sys
import requests
import json
import random
import time
import string
# from ...typing import sha256, Dict, get_type_hints
url = "https://wewordle.org/gptapi/v1/android/turbo"
model = ['gpt-3.5-turbo']
supports_stream = False
needs_auth = False
def _create_completion(model: str, messages: list, stream: bool, **kwargs):
base = ''
for message in messages:
base += '%s: %s\n' % (message['role'], message['content'])
base += 'assistant:'
# randomize user id and app id
_user_id = ''.join(random.choices(f'{string.ascii_lowercase}{string.digits}', k=16))
_app_id = ''.join(random.choices(f'{string.ascii_lowercase}{string.digits}', k=31))
# make current date with format utc
_request_date = time.strftime("%Y-%m-%dT%H:%M:%S.000Z", time.gmtime())
headers = {
'accept': '*/*',
'pragma': 'no-cache',
'Content-Type': 'application/json',
'Connection':'keep-alive'
# user agent android client
# 'User-Agent': 'Dalvik/2.1.0 (Linux; U; Android 10; SM-G975F Build/QP1A.190711.020)',
}
data = {
"user": _user_id,
"messages": [
{"role": "user", "content": base}
],
"subscriber": {
"originalPurchaseDate": None,
"originalApplicationVersion": None,
"allPurchaseDatesMillis": {},
"entitlements": {
"active": {},
"all": {}
},
"allPurchaseDates": {},
"allExpirationDatesMillis": {},
"allExpirationDates": {},
"originalAppUserId": f"$RCAnonymousID:{_app_id}",
"latestExpirationDate": None,
"requestDate": _request_date,
"latestExpirationDateMillis": None,
"nonSubscriptionTransactions": [],
"originalPurchaseDateMillis": None,
"managementURL": None,
"allPurchasedProductIdentifiers": [],
"firstSeen": _request_date,
"activeSubscriptions": []
}
}
response = requests.post(url, headers=headers, data=json.dumps(data))
if response.status_code == 200:
_json = response.json()
if 'message' in _json:
yield _json['message']['content']
else:
print(f"Error Occurred::{response.status_code}")
return None
# params = f'g4f.Providers.{os.path.basename(__file__)[:-3]} supports: ' + \
# '(%s)' % ', '.join(
# [f"{name}: {get_type_hints(_create_completion)[name].__name__}" for name in _create_completion.__code__.co_varnames[:_create_completion.__code__.co_argcount]])
# Temporary For ChatCompletion Class
class ChatCompletion:
@staticmethod
def create(model: str, messages: list, provider: None or str, stream: bool = False, auth: str = False, **kwargs):
kwargs['auth'] = auth
if provider and needs_auth and not auth:
print(
f'ValueError: {provider} requires authentication (use auth="cookie or token or jwt ..." param)', file=sys.stderr)
sys.exit(1)
try:
return (_create_completion(model, messages, stream, **kwargs)
if stream else ''.join(_create_completion(model, messages, stream, **kwargs)))
except TypeError as e:
print(e)
arg: str = str(e).split("'")[1]
print(
f"ValueError: {provider} does not support '{arg}' argument", file=sys.stderr)
sys.exit(1)
|