Spaces:
				
			
			
	
			
			
		Paused
		
	
	
	
			
			
	
	
	
	
		
		
		Paused
		
	Merge pull request #2 from ramonvc/sourcery/main
Browse files- g4f/Provider/Providers/Aws.py +1 -1
- g4f/Provider/Providers/Bard.py +16 -12
- g4f/Provider/Providers/Forefront.py +1 -2
- g4f/Provider/Providers/Phind.py +1 -3
- g4f/Provider/Providers/Pierangelo.py +6 -5
- g4f/Provider/Providers/Vercel.py +4 -7
- g4f/Provider/Providers/Yqcloud.py +2 -2
- g4f/Provider/Providers/helpers/bing.py +24 -38
- g4f/__init__.py +3 -3
- g4f/typing.py +5 -5
- g4f/utils.py +18 -27
- server/auto_proxy.py +7 -9
- server/backend.py +4 -17
- server/website.py +2 -2
    	
        g4f/Provider/Providers/Aws.py
    CHANGED
    
    | @@ -12,7 +12,7 @@ class Auth(requests.auth.AuthBase): | |
| 12 | 
             
                    self.token = 'sk-1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKL'
         | 
| 13 |  | 
| 14 | 
             
                def __call__(self, r):
         | 
| 15 | 
            -
                    r.headers["authorization"] = "Bearer  | 
| 16 | 
             
                    return r
         | 
| 17 |  | 
| 18 | 
             
            def _create_completion(model: str, messages: list, stream: bool, **kwargs):
         | 
|  | |
| 12 | 
             
                    self.token = 'sk-1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKL'
         | 
| 13 |  | 
| 14 | 
             
                def __call__(self, r):
         | 
| 15 | 
            +
                    r.headers["authorization"] = f"Bearer {self.token}"
         | 
| 16 | 
             
                    return r
         | 
| 17 |  | 
| 18 | 
             
            def _create_completion(model: str, messages: list, stream: bool, **kwargs):
         | 
    	
        g4f/Provider/Providers/Bard.py
    CHANGED
    
    | @@ -10,17 +10,17 @@ supports_stream = False | |
| 10 | 
             
            def _create_completion(model: str, messages: list, stream: bool, **kwargs):
         | 
| 11 | 
             
                psid = {cookie.name: cookie.value for cookie in browser_cookie3.chrome(
         | 
| 12 | 
             
                    domain_name='.google.com')}['__Secure-1PSID']
         | 
| 13 | 
            -
             | 
| 14 | 
            -
                formatted = '\n'.join( | 
| 15 | 
            -
                     | 
| 16 | 
            -
                 | 
| 17 | 
             
                prompt = f'{formatted}\nAssistant:'
         | 
| 18 |  | 
| 19 | 
             
                proxy = None
         | 
| 20 | 
            -
             | 
| 21 | 
            -
                if proxy  | 
| 22 | 
             
                    raise Exception('Proxy is required for Bard (set in g4f/Provider/Providers/Bard.py line 18)')
         | 
| 23 | 
            -
             | 
| 24 | 
             
                snlm0e = False
         | 
| 25 | 
             
                conversation_id = None
         | 
| 26 | 
             
                response_id = None
         | 
| @@ -41,8 +41,13 @@ def _create_completion(model: str, messages: list, stream: bool, **kwargs): | |
| 41 | 
             
                    'cookie': f'__Secure-1PSID={psid}'
         | 
| 42 | 
             
                }
         | 
| 43 |  | 
| 44 | 
            -
                snlm0e =  | 
| 45 | 
            -
             | 
|  | |
|  | |
|  | |
|  | |
|  | |
| 46 |  | 
| 47 | 
             
                params = {
         | 
| 48 | 
             
                    'bl': 'boq_assistant-bard-web-server_20230326.21_p0',
         | 
| @@ -63,12 +68,11 @@ def _create_completion(model: str, messages: list, stream: bool, **kwargs): | |
| 63 | 
             
                response = client.post(f'https://bard.google.com/_/BardChatUi/data/{intents}/StreamGenerate',
         | 
| 64 | 
             
                                    data=data, params=params)
         | 
| 65 |  | 
| 66 | 
            -
                chat_data  | 
| 67 | 
            -
                if chat_data:
         | 
| 68 | 
             
                    json_chat_data = json.loads(chat_data)
         | 
| 69 |  | 
| 70 | 
             
                    yield json_chat_data[0][0]
         | 
| 71 | 
            -
             | 
| 72 | 
             
                else:
         | 
| 73 | 
             
                    yield 'error'
         | 
| 74 |  | 
|  | |
| 10 | 
             
            def _create_completion(model: str, messages: list, stream: bool, **kwargs):
         | 
| 11 | 
             
                psid = {cookie.name: cookie.value for cookie in browser_cookie3.chrome(
         | 
| 12 | 
             
                    domain_name='.google.com')}['__Secure-1PSID']
         | 
| 13 | 
            +
             | 
| 14 | 
            +
                formatted = '\n'.join(
         | 
| 15 | 
            +
                    [f"{message['role']}: {message['content']}" for message in messages]
         | 
| 16 | 
            +
                )
         | 
| 17 | 
             
                prompt = f'{formatted}\nAssistant:'
         | 
| 18 |  | 
| 19 | 
             
                proxy = None
         | 
| 20 | 
            +
             | 
| 21 | 
            +
                if proxy is None:
         | 
| 22 | 
             
                    raise Exception('Proxy is required for Bard (set in g4f/Provider/Providers/Bard.py line 18)')
         | 
| 23 | 
            +
             | 
| 24 | 
             
                snlm0e = False
         | 
| 25 | 
             
                conversation_id = None
         | 
| 26 | 
             
                response_id = None
         | 
|  | |
| 41 | 
             
                    'cookie': f'__Secure-1PSID={psid}'
         | 
| 42 | 
             
                }
         | 
| 43 |  | 
| 44 | 
            +
                snlm0e = (
         | 
| 45 | 
            +
                    re.search(
         | 
| 46 | 
            +
                        r'SNlM0e\":\"(.*?)\"', client.get('https://bard.google.com/').text
         | 
| 47 | 
            +
                    )[1]
         | 
| 48 | 
            +
                    if not snlm0e
         | 
| 49 | 
            +
                    else snlm0e
         | 
| 50 | 
            +
                )
         | 
| 51 |  | 
| 52 | 
             
                params = {
         | 
| 53 | 
             
                    'bl': 'boq_assistant-bard-web-server_20230326.21_p0',
         | 
|  | |
| 68 | 
             
                response = client.post(f'https://bard.google.com/_/BardChatUi/data/{intents}/StreamGenerate',
         | 
| 69 | 
             
                                    data=data, params=params)
         | 
| 70 |  | 
| 71 | 
            +
                if chat_data := json.loads(response.content.splitlines()[3])[0][2]:
         | 
|  | |
| 72 | 
             
                    json_chat_data = json.loads(chat_data)
         | 
| 73 |  | 
| 74 | 
             
                    yield json_chat_data[0][0]
         | 
| 75 | 
            +
             | 
| 76 | 
             
                else:
         | 
| 77 | 
             
                    yield 'error'
         | 
| 78 |  | 
    	
        g4f/Provider/Providers/Forefront.py
    CHANGED
    
    | @@ -26,8 +26,7 @@ def _create_completion(model: str, messages: list, stream: bool, **kwargs): | |
| 26 |  | 
| 27 | 
             
                for token in response.iter_lines():
         | 
| 28 | 
             
                    if b'delta' in token:
         | 
| 29 | 
            -
                         | 
| 30 | 
            -
                        yield (token)
         | 
| 31 |  | 
| 32 |  | 
| 33 | 
             
            params = f'g4f.Providers.{os.path.basename(__file__)[:-3]} supports: ' + \
         | 
|  | |
| 26 |  | 
| 27 | 
             
                for token in response.iter_lines():
         | 
| 28 | 
             
                    if b'delta' in token:
         | 
| 29 | 
            +
                        yield json.loads(token.decode().split('data: ')[1])['delta']
         | 
|  | |
| 30 |  | 
| 31 |  | 
| 32 | 
             
            params = f'g4f.Providers.{os.path.basename(__file__)[:-3]} supports: ' + \
         | 
    	
        g4f/Provider/Providers/Phind.py
    CHANGED
    
    | @@ -33,9 +33,7 @@ def _create_completion(model: str, messages: list, stream: bool, **kwargs): | |
| 33 | 
             
                        yield 'Clouflare error, please try again...'
         | 
| 34 | 
             
                        os._exit(0)
         | 
| 35 |  | 
| 36 | 
            -
                     | 
| 37 | 
            -
                        if b'ping - 2023-' in line:
         | 
| 38 | 
            -
                            continue
         | 
| 39 | 
             
                        yield line.decode('utf-8', errors='ignore')  # [:-1]
         | 
| 40 |  | 
| 41 |  | 
|  | |
| 33 | 
             
                        yield 'Clouflare error, please try again...'
         | 
| 34 | 
             
                        os._exit(0)
         | 
| 35 |  | 
| 36 | 
            +
                    elif b'ping - 2023-' not in line:
         | 
|  | |
|  | |
| 37 | 
             
                        yield line.decode('utf-8', errors='ignore')  # [:-1]
         | 
| 38 |  | 
| 39 |  | 
    	
        g4f/Provider/Providers/Pierangelo.py
    CHANGED
    
    | @@ -45,11 +45,12 @@ def _create_completion(model: str, messages: list, stream: bool, **kwargs): | |
| 45 | 
             
                    'temperature': 0.7
         | 
| 46 | 
             
                }
         | 
| 47 |  | 
| 48 | 
            -
                 | 
| 49 | 
            -
             | 
| 50 | 
            -
             | 
| 51 | 
            -
             | 
| 52 | 
            -
                     | 
|  | |
| 53 |  | 
| 54 | 
             
            params = f'g4f.Providers.{os.path.basename(__file__)[:-3]} supports: ' + \
         | 
| 55 | 
             
                '(%s)' % ', '.join([f'{name}: {get_type_hints(_create_completion)[name].__name__}' for name in _create_completion.__code__.co_varnames[:_create_completion.__code__.co_argcount]])
         | 
|  | |
| 45 | 
             
                    'temperature': 0.7
         | 
| 46 | 
             
                }
         | 
| 47 |  | 
| 48 | 
            +
                yield from requests.post(
         | 
| 49 | 
            +
                    'https://chat.pierangelo.info/api/chat',
         | 
| 50 | 
            +
                    headers=headers,
         | 
| 51 | 
            +
                    json=json_data,
         | 
| 52 | 
            +
                    stream=True,
         | 
| 53 | 
            +
                )
         | 
| 54 |  | 
| 55 | 
             
            params = f'g4f.Providers.{os.path.basename(__file__)[:-3]} supports: ' + \
         | 
| 56 | 
             
                '(%s)' % ', '.join([f'{name}: {get_type_hints(_create_completion)[name].__name__}' for name in _create_completion.__code__.co_varnames[:_create_completion.__code__.co_argcount]])
         | 
    	
        g4f/Provider/Providers/Vercel.py
    CHANGED
    
    | @@ -72,7 +72,7 @@ class Client: | |
| 72 | 
             
                    return {key: param['value'] for key, param in vercel_models[model_id]['parameters'].items()}
         | 
| 73 |  | 
| 74 | 
             
                def generate(self, model_id: str, prompt: str, params: dict = {}):
         | 
| 75 | 
            -
                    if  | 
| 76 | 
             
                        model_id = models[model_id]
         | 
| 77 |  | 
| 78 | 
             
                    defaults = self.get_default_params(model_id)
         | 
| @@ -145,16 +145,13 @@ class Client: | |
| 145 |  | 
| 146 | 
             
            def _create_completion(model: str, messages: list, stream: bool, **kwargs):
         | 
| 147 | 
             
                conversation = 'This is a conversation between a human and a language model, respond to the last message accordingly, referring to the past history of messages if needed.\n'
         | 
| 148 | 
            -
             | 
| 149 | 
             
                for message in messages:
         | 
| 150 | 
             
                    conversation += '%s: %s\n' % (message['role'], message['content'])
         | 
| 151 | 
            -
             | 
| 152 | 
             
                conversation += 'assistant: '
         | 
| 153 | 
            -
                
         | 
| 154 | 
            -
                completion = Client().generate(model, conversation)
         | 
| 155 |  | 
| 156 | 
            -
                 | 
| 157 | 
            -
                    yield token
         | 
| 158 |  | 
| 159 | 
             
            params = f'g4f.Providers.{os.path.basename(__file__)[:-3]} supports: ' + \
         | 
| 160 | 
             
                '(%s)' % ', '.join([f"{name}: {get_type_hints(_create_completion)[name].__name__}" for name in _create_completion.__code__.co_varnames[:_create_completion.__code__.co_argcount]])
         | 
|  | |
| 72 | 
             
                    return {key: param['value'] for key, param in vercel_models[model_id]['parameters'].items()}
         | 
| 73 |  | 
| 74 | 
             
                def generate(self, model_id: str, prompt: str, params: dict = {}):
         | 
| 75 | 
            +
                    if ':' not in model_id:
         | 
| 76 | 
             
                        model_id = models[model_id]
         | 
| 77 |  | 
| 78 | 
             
                    defaults = self.get_default_params(model_id)
         | 
|  | |
| 145 |  | 
| 146 | 
             
            def _create_completion(model: str, messages: list, stream: bool, **kwargs):
         | 
| 147 | 
             
                conversation = 'This is a conversation between a human and a language model, respond to the last message accordingly, referring to the past history of messages if needed.\n'
         | 
| 148 | 
            +
             | 
| 149 | 
             
                for message in messages:
         | 
| 150 | 
             
                    conversation += '%s: %s\n' % (message['role'], message['content'])
         | 
| 151 | 
            +
             | 
| 152 | 
             
                conversation += 'assistant: '
         | 
|  | |
|  | |
| 153 |  | 
| 154 | 
            +
                yield from Client().generate(model, conversation)
         | 
|  | |
| 155 |  | 
| 156 | 
             
            params = f'g4f.Providers.{os.path.basename(__file__)[:-3]} supports: ' + \
         | 
| 157 | 
             
                '(%s)' % ', '.join([f"{name}: {get_type_hints(_create_completion)[name].__name__}" for name in _create_completion.__code__.co_varnames[:_create_completion.__code__.co_argcount]])
         | 
    	
        g4f/Provider/Providers/Yqcloud.py
    CHANGED
    
    | @@ -15,7 +15,7 @@ def _create_completion(model: str, messages: list, stream: bool, **kwargs): | |
| 15 | 
             
                }
         | 
| 16 |  | 
| 17 | 
             
                json_data = {
         | 
| 18 | 
            -
                    'prompt':  | 
| 19 | 
             
                    'userId': f'#/chat/{int(time.time() * 1000)}',
         | 
| 20 | 
             
                    'network': True,
         | 
| 21 | 
             
                    'apikey': '',
         | 
| @@ -25,7 +25,7 @@ def _create_completion(model: str, messages: list, stream: bool, **kwargs): | |
| 25 |  | 
| 26 | 
             
                response = requests.post('https://api.aichatos.cloud/api/generateStream', headers=headers, json=json_data, stream=True)
         | 
| 27 | 
             
                for token in response.iter_content(chunk_size=2046):
         | 
| 28 | 
            -
                    if  | 
| 29 | 
             
                        yield (token.decode('utf-8'))
         | 
| 30 |  | 
| 31 | 
             
            params = f'g4f.Providers.{os.path.basename(__file__)[:-3]} supports: ' + \
         | 
|  | |
| 15 | 
             
                }
         | 
| 16 |  | 
| 17 | 
             
                json_data = {
         | 
| 18 | 
            +
                    'prompt': f"{messages[-1]['content']}",
         | 
| 19 | 
             
                    'userId': f'#/chat/{int(time.time() * 1000)}',
         | 
| 20 | 
             
                    'network': True,
         | 
| 21 | 
             
                    'apikey': '',
         | 
|  | |
| 25 |  | 
| 26 | 
             
                response = requests.post('https://api.aichatos.cloud/api/generateStream', headers=headers, json=json_data, stream=True)
         | 
| 27 | 
             
                for token in response.iter_content(chunk_size=2046):
         | 
| 28 | 
            +
                    if b'always respond in english' not in token:
         | 
| 29 | 
             
                        yield (token.decode('utf-8'))
         | 
| 30 |  | 
| 31 | 
             
            params = f'g4f.Providers.{os.path.basename(__file__)[:-3]} supports: ' + \
         | 
    	
        g4f/Provider/Providers/helpers/bing.py
    CHANGED
    
    | @@ -76,19 +76,9 @@ def format(msg: dict) -> str: | |
| 76 |  | 
| 77 | 
             
            def get_token():
         | 
| 78 | 
             
                return
         | 
| 79 | 
            -
                
         | 
| 80 | 
            -
                try:
         | 
| 81 | 
            -
                    cookies = {c.name: c.value for c in browser_cookie3.edge(domain_name='bing.com')}
         | 
| 82 | 
            -
                    return cookies['_U']
         | 
| 83 | 
            -
                except:
         | 
| 84 | 
            -
                    print('Error: could not find bing _U cookie in edge browser.')
         | 
| 85 | 
            -
                    exit(1)
         | 
| 86 |  | 
| 87 | 
             
            class AsyncCompletion:
         | 
| 88 | 
            -
                async def create(
         | 
| 89 | 
            -
                    prompt     : str = None,
         | 
| 90 | 
            -
                    optionSets : list = None,
         | 
| 91 | 
            -
                    token     : str = None): # No auth required anymore
         | 
| 92 |  | 
| 93 | 
             
                    create = None
         | 
| 94 | 
             
                    for _ in range(5):
         | 
| @@ -128,9 +118,7 @@ class AsyncCompletion: | |
| 128 |  | 
| 129 | 
             
                        except Exception as e:
         | 
| 130 | 
             
                            time.sleep(0.5)
         | 
| 131 | 
            -
             | 
| 132 | 
            -
                    
         | 
| 133 | 
            -
                    if create == None: raise Exception('Failed to create conversation.')
         | 
| 134 |  | 
| 135 | 
             
                    wss: websockets.WebSocketClientProtocol or None = None
         | 
| 136 |  | 
| @@ -165,48 +153,46 @@ class AsyncCompletion: | |
| 165 | 
             
                    struct = {
         | 
| 166 | 
             
                        'arguments': [
         | 
| 167 | 
             
                            {
         | 
| 168 | 
            -
                                'source': 'cib', | 
| 169 | 
            -
                                'optionsSets': optionSets, | 
| 170 | 
            -
                                'isStartOfSession': True, | 
| 171 | 
             
                                'message': {
         | 
| 172 | 
            -
                                    'author': 'user', | 
| 173 | 
            -
                                    'inputMethod': 'Keyboard', | 
| 174 | 
            -
                                    'text':  | 
| 175 | 
            -
                                    'messageType': 'Chat'
         | 
| 176 | 
            -
                                }, | 
| 177 | 
            -
                                'conversationSignature': conversationSignature, | 
| 178 | 
            -
                                'participant': {
         | 
| 179 | 
            -
             | 
| 180 | 
            -
                                }, 
         | 
| 181 | 
            -
                                'conversationId': conversationId
         | 
| 182 | 
             
                            }
         | 
| 183 | 
            -
                        ], | 
| 184 | 
            -
                        'invocationId': '0', | 
| 185 | 
            -
                        'target': 'chat', | 
| 186 | 
            -
                        'type': 4
         | 
| 187 | 
             
                    }
         | 
| 188 | 
            -
             | 
| 189 | 
             
                    await wss.send(format(struct))
         | 
| 190 | 
            -
             | 
| 191 | 
             
                    base_string = ''
         | 
| 192 | 
            -
             | 
| 193 | 
             
                    final = False
         | 
| 194 | 
             
                    while not final:
         | 
| 195 | 
             
                        objects = str(await wss.recv()).split('\x1e')
         | 
| 196 | 
             
                        for obj in objects:
         | 
| 197 | 
             
                            if obj is None or obj == '':
         | 
| 198 | 
             
                                continue
         | 
| 199 | 
            -
             | 
| 200 | 
             
                            response = json.loads(obj)
         | 
| 201 | 
             
                            if response.get('type') == 1 and response['arguments'][0].get('messages',):
         | 
| 202 | 
             
                                response_text = response['arguments'][0]['messages'][0]['adaptiveCards'][0]['body'][0].get('text')
         | 
| 203 | 
            -
             | 
| 204 | 
             
                                yield (response_text.replace(base_string, ''))
         | 
| 205 | 
             
                                base_string = response_text
         | 
| 206 | 
            -
             | 
| 207 | 
             
                            elif response.get('type') == 2:
         | 
| 208 | 
             
                                final = True
         | 
| 209 | 
            -
             | 
| 210 | 
             
                    await wss.close()
         | 
| 211 |  | 
| 212 | 
             
            async def run(optionSets, messages):
         | 
|  | |
| 76 |  | 
| 77 | 
             
            def get_token():
         | 
| 78 | 
             
                return
         | 
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
| 79 |  | 
| 80 | 
             
            class AsyncCompletion:
         | 
| 81 | 
            +
                async def create(self, optionSets : list = None, token     : str = None): # No auth required anymore
         | 
|  | |
|  | |
|  | |
| 82 |  | 
| 83 | 
             
                    create = None
         | 
| 84 | 
             
                    for _ in range(5):
         | 
|  | |
| 118 |  | 
| 119 | 
             
                        except Exception as e:
         | 
| 120 | 
             
                            time.sleep(0.5)
         | 
| 121 | 
            +
                    if create is None: raise Exception('Failed to create conversation.')
         | 
|  | |
|  | |
| 122 |  | 
| 123 | 
             
                    wss: websockets.WebSocketClientProtocol or None = None
         | 
| 124 |  | 
|  | |
| 153 | 
             
                    struct = {
         | 
| 154 | 
             
                        'arguments': [
         | 
| 155 | 
             
                            {
         | 
| 156 | 
            +
                                'source': 'cib',
         | 
| 157 | 
            +
                                'optionsSets': optionSets,
         | 
| 158 | 
            +
                                'isStartOfSession': True,
         | 
| 159 | 
             
                                'message': {
         | 
| 160 | 
            +
                                    'author': 'user',
         | 
| 161 | 
            +
                                    'inputMethod': 'Keyboard',
         | 
| 162 | 
            +
                                    'text': self,
         | 
| 163 | 
            +
                                    'messageType': 'Chat',
         | 
| 164 | 
            +
                                },
         | 
| 165 | 
            +
                                'conversationSignature': conversationSignature,
         | 
| 166 | 
            +
                                'participant': {'id': clientId},
         | 
| 167 | 
            +
                                'conversationId': conversationId,
         | 
|  | |
|  | |
| 168 | 
             
                            }
         | 
| 169 | 
            +
                        ],
         | 
| 170 | 
            +
                        'invocationId': '0',
         | 
| 171 | 
            +
                        'target': 'chat',
         | 
| 172 | 
            +
                        'type': 4,
         | 
| 173 | 
             
                    }
         | 
| 174 | 
            +
             | 
| 175 | 
             
                    await wss.send(format(struct))
         | 
| 176 | 
            +
             | 
| 177 | 
             
                    base_string = ''
         | 
| 178 | 
            +
             | 
| 179 | 
             
                    final = False
         | 
| 180 | 
             
                    while not final:
         | 
| 181 | 
             
                        objects = str(await wss.recv()).split('\x1e')
         | 
| 182 | 
             
                        for obj in objects:
         | 
| 183 | 
             
                            if obj is None or obj == '':
         | 
| 184 | 
             
                                continue
         | 
| 185 | 
            +
             | 
| 186 | 
             
                            response = json.loads(obj)
         | 
| 187 | 
             
                            if response.get('type') == 1 and response['arguments'][0].get('messages',):
         | 
| 188 | 
             
                                response_text = response['arguments'][0]['messages'][0]['adaptiveCards'][0]['body'][0].get('text')
         | 
| 189 | 
            +
             | 
| 190 | 
             
                                yield (response_text.replace(base_string, ''))
         | 
| 191 | 
             
                                base_string = response_text
         | 
| 192 | 
            +
             | 
| 193 | 
             
                            elif response.get('type') == 2:
         | 
| 194 | 
             
                                final = True
         | 
| 195 | 
            +
             | 
| 196 | 
             
                    await wss.close()
         | 
| 197 |  | 
| 198 | 
             
            async def run(optionSets, messages):
         | 
    	
        g4f/__init__.py
    CHANGED
    
    | @@ -37,13 +37,13 @@ class ChatCompletion: | |
| 37 | 
             
                    try:
         | 
| 38 | 
             
                        if isinstance(model, str):
         | 
| 39 | 
             
                            model = Utils.convert[model]
         | 
| 40 | 
            -
             | 
| 41 | 
             
                        engine = model.best_site if not provider else provider
         | 
| 42 | 
            -
                        if not engine.supports_stream and stream | 
| 43 | 
             
                            print(
         | 
| 44 | 
             
                                f"ValueError: {engine.__name__} does not support 'stream' argument", file=sys.stderr)
         | 
| 45 | 
             
                            sys.exit(1)
         | 
| 46 | 
            -
             | 
| 47 | 
             
                        return (engine._create_completion(model.name, messages, stream, **kwargs)
         | 
| 48 | 
             
                                if stream else ''.join(engine._create_completion(model.name, messages, stream, **kwargs)))
         | 
| 49 |  | 
|  | |
| 37 | 
             
                    try:
         | 
| 38 | 
             
                        if isinstance(model, str):
         | 
| 39 | 
             
                            model = Utils.convert[model]
         | 
| 40 | 
            +
             | 
| 41 | 
             
                        engine = model.best_site if not provider else provider
         | 
| 42 | 
            +
                        if not engine.supports_stream and stream:
         | 
| 43 | 
             
                            print(
         | 
| 44 | 
             
                                f"ValueError: {engine.__name__} does not support 'stream' argument", file=sys.stderr)
         | 
| 45 | 
             
                            sys.exit(1)
         | 
| 46 | 
            +
             | 
| 47 | 
             
                        return (engine._create_completion(model.name, messages, stream, **kwargs)
         | 
| 48 | 
             
                                if stream else ''.join(engine._create_completion(model.name, messages, stream, **kwargs)))
         | 
| 49 |  | 
    	
        g4f/typing.py
    CHANGED
    
    | @@ -3,13 +3,13 @@ from typing import Dict, NewType, Union, Optional, List, get_type_hints | |
| 3 | 
             
            sha256 = NewType('sha_256_hash', str)
         | 
| 4 |  | 
| 5 | 
             
            class MetaModels(type):
         | 
| 6 | 
            -
                def __str__( | 
| 7 | 
             
                    output: List = [
         | 
| 8 | 
             
                        f'class Engines:\n',
         | 
| 9 | 
            -
                        f'  class { | 
|  | |
|  | |
| 10 | 
             
                        '    ...',
         | 
| 11 | 
            -
                        f'  class {cls.gpt_4.__name__}:',
         | 
| 12 | 
            -
                        '    ...'
         | 
| 13 | 
             
                    ]
         | 
| 14 | 
            -
             | 
| 15 | 
             
                    return '\n'.join(output)
         | 
|  | |
| 3 | 
             
            sha256 = NewType('sha_256_hash', str)
         | 
| 4 |  | 
| 5 | 
             
            class MetaModels(type):
         | 
| 6 | 
            +
                def __str__(self):
         | 
| 7 | 
             
                    output: List = [
         | 
| 8 | 
             
                        f'class Engines:\n',
         | 
| 9 | 
            +
                        f'  class {self.gpt_35_turbo.__name__}:',
         | 
| 10 | 
            +
                        '    ...',
         | 
| 11 | 
            +
                        f'  class {self.gpt_4.__name__}:',
         | 
| 12 | 
             
                        '    ...',
         | 
|  | |
|  | |
| 13 | 
             
                    ]
         | 
| 14 | 
            +
             | 
| 15 | 
             
                    return '\n'.join(output)
         | 
    	
        g4f/utils.py
    CHANGED
    
    | @@ -12,37 +12,28 @@ class Utils: | |
| 12 | 
             
                    browser_cookie3.vivaldi,  #  0.32% market share
         | 
| 13 | 
             
                ]
         | 
| 14 |  | 
| 15 | 
            -
                def get_cookies( | 
| 16 | 
             
                    cookies = {}
         | 
| 17 | 
            -
             | 
| 18 | 
            -
                     | 
| 19 | 
            -
                         | 
| 20 | 
            -
                             | 
| 21 | 
            -
             | 
| 22 | 
            -
             | 
| 23 | 
            -
             | 
| 24 | 
            -
                                            cookies = cookies | {c.name: c.value} 
         | 
| 25 | 
            -
                                
         | 
| 26 | 
            -
                                except Exception as e:
         | 
| 27 | 
            -
                                    pass
         | 
| 28 | 
            -
                    
         | 
| 29 | 
            -
                    else:
         | 
| 30 | 
            -
                        for browser in Utils.browsers:
         | 
| 31 | 
             
                            try:
         | 
| 32 | 
            -
                                for c in browser(domain_name= | 
| 33 | 
             
                                    if c.name not in cookies:
         | 
| 34 | 
             
                                        cookies = cookies | {c.name: c.value} 
         | 
| 35 | 
            -
             | 
| 36 | 
             
                            except Exception as e:
         | 
| 37 | 
             
                                pass
         | 
| 38 | 
            -
             | 
| 39 | 
            -
                    if setName:
         | 
| 40 | 
            -
                        try:
         | 
| 41 | 
            -
                            return {setName: cookies[setName]}
         | 
| 42 | 
            -
                        
         | 
| 43 | 
            -
                        except ValueError:
         | 
| 44 | 
            -
                            print(f'Error: could not find {setName} cookie in any browser.')
         | 
| 45 | 
            -
                            exit(1)
         | 
| 46 | 
            -
                    
         | 
| 47 | 
            -
                    else:
         | 
| 48 | 
             
                        return cookies
         | 
|  | |
|  | |
|  | |
|  | |
|  | |
|  | 
|  | |
| 12 | 
             
                    browser_cookie3.vivaldi,  #  0.32% market share
         | 
| 13 | 
             
                ]
         | 
| 14 |  | 
| 15 | 
            +
                def get_cookies(self, setName: str = None, setBrowser: str = False) -> dict:
         | 
| 16 | 
             
                    cookies = {}
         | 
| 17 | 
            +
             | 
| 18 | 
            +
                    for browser in Utils.browsers:
         | 
| 19 | 
            +
                        if (
         | 
| 20 | 
            +
                            setBrowser != False
         | 
| 21 | 
            +
                            and browser.__name__ == setBrowser
         | 
| 22 | 
            +
                            or setBrowser == False
         | 
| 23 | 
            +
                        ):
         | 
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
| 24 | 
             
                            try:
         | 
| 25 | 
            +
                                for c in browser(domain_name=self):
         | 
| 26 | 
             
                                    if c.name not in cookies:
         | 
| 27 | 
             
                                        cookies = cookies | {c.name: c.value} 
         | 
| 28 | 
            +
             | 
| 29 | 
             
                            except Exception as e:
         | 
| 30 | 
             
                                pass
         | 
| 31 | 
            +
             | 
| 32 | 
            +
                    if not setName:
         | 
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
| 33 | 
             
                        return cookies
         | 
| 34 | 
            +
                    try:
         | 
| 35 | 
            +
                        return {setName: cookies[setName]}
         | 
| 36 | 
            +
             | 
| 37 | 
            +
                    except ValueError:
         | 
| 38 | 
            +
                        print(f'Error: could not find {setName} cookie in any browser.')
         | 
| 39 | 
            +
                        exit(1)
         | 
    	
        server/auto_proxy.py
    CHANGED
    
    | @@ -4,20 +4,18 @@ import time | |
| 4 | 
             
            import threading  
         | 
| 5 |  | 
| 6 |  | 
| 7 | 
            -
            def fetch_proxies(): | 
| 8 | 
             
                """Fetch a list of proxy servers from proxyscrape.com.  
         | 
| 9 |  | 
| 10 | 
             
                Returns:  
         | 
| 11 | 
             
                    list: A list of proxy servers in the format "IP:Port".  
         | 
| 12 | 
             
                """  
         | 
| 13 | 
            -
                url = "https://api.proxyscrape.com/v2/?request=displayproxies&protocol=http&timeout=10000&country=all&ssl=all&anonymity=all" | 
| 14 | 
            -
                response = requests.get(url) | 
| 15 | 
            -
                if response.status_code == 200: | 
| 16 | 
            -
                     | 
| 17 | 
            -
             | 
| 18 | 
            -
                 | 
| 19 | 
            -
                    print(f"Error fetching proxies: {response.status_code}")  
         | 
| 20 | 
            -
                    return []  
         | 
| 21 |  | 
| 22 |  | 
| 23 | 
             
            def test_proxy(proxy, prompt, timeout):  
         | 
|  | |
| 4 | 
             
            import threading  
         | 
| 5 |  | 
| 6 |  | 
| 7 | 
            +
            def fetch_proxies():
         | 
| 8 | 
             
                """Fetch a list of proxy servers from proxyscrape.com.  
         | 
| 9 |  | 
| 10 | 
             
                Returns:  
         | 
| 11 | 
             
                    list: A list of proxy servers in the format "IP:Port".  
         | 
| 12 | 
             
                """  
         | 
| 13 | 
            +
                url = "https://api.proxyscrape.com/v2/?request=displayproxies&protocol=http&timeout=10000&country=all&ssl=all&anonymity=all"
         | 
| 14 | 
            +
                response = requests.get(url)
         | 
| 15 | 
            +
                if response.status_code == 200:
         | 
| 16 | 
            +
                    return response.text.split("\r\n")[:-1]
         | 
| 17 | 
            +
                print(f"Error fetching proxies: {response.status_code}")
         | 
| 18 | 
            +
                return []  
         | 
|  | |
|  | |
| 19 |  | 
| 20 |  | 
| 21 | 
             
            def test_proxy(proxy, prompt, timeout):  
         | 
    	
        server/backend.py
    CHANGED
    
    | @@ -79,20 +79,14 @@ def build_messages(jailbreak): | |
| 79 | 
             
                    f'{set_response_language(prompt)}'
         | 
| 80 | 
             
                )
         | 
| 81 |  | 
| 82 | 
            -
                 | 
| 83 | 
            -
                extra = []
         | 
| 84 | 
            -
                if internet_access:
         | 
| 85 | 
            -
                    extra = fetch_search_results(prompt["content"])
         | 
| 86 | 
            -
             | 
| 87 | 
             
                # Initialize the conversation with the system message
         | 
| 88 | 
             
                conversation = [{'role': 'system', 'content': system_message}]
         | 
| 89 |  | 
| 90 | 
             
                # Add extra results
         | 
| 91 | 
             
                conversation += extra
         | 
| 92 |  | 
| 93 | 
            -
                 | 
| 94 | 
            -
                jailbreak_instructions = isJailbreak(jailbreak)
         | 
| 95 | 
            -
                if jailbreak_instructions:
         | 
| 96 | 
             
                    conversation += jailbreak_instructions
         | 
| 97 |  | 
| 98 | 
             
                # Add the existing conversation and the prompt
         | 
| @@ -143,8 +137,7 @@ def generate_stream(response, jailbreak): | |
| 143 | 
             
                            yield "Error: jailbreak failed. Try again."
         | 
| 144 | 
             
                            break
         | 
| 145 | 
             
                else:
         | 
| 146 | 
            -
                     | 
| 147 | 
            -
                        yield message
         | 
| 148 |  | 
| 149 |  | 
| 150 | 
             
            def response_jailbroken_success(response: str) -> bool:
         | 
| @@ -164,13 +157,7 @@ def response_jailbroken_failed(response): | |
| 164 | 
             
                :param response: Response string  
         | 
| 165 | 
             
                :return: Boolean indicating if the response has not been jailbroken  
         | 
| 166 | 
             
                """
         | 
| 167 | 
            -
                if len(response) < 4:
         | 
| 168 | 
            -
                    return False
         | 
| 169 | 
            -
             | 
| 170 | 
            -
                if not response.startswith("GPT:"):
         | 
| 171 | 
            -
                    return True
         | 
| 172 | 
            -
                else:
         | 
| 173 | 
            -
                    return False
         | 
| 174 |  | 
| 175 |  | 
| 176 | 
             
            def set_response_language(prompt):
         | 
|  | |
| 79 | 
             
                    f'{set_response_language(prompt)}'
         | 
| 80 | 
             
                )
         | 
| 81 |  | 
| 82 | 
            +
                extra = fetch_search_results(prompt["content"]) if internet_access else []
         | 
|  | |
|  | |
|  | |
|  | |
| 83 | 
             
                # Initialize the conversation with the system message
         | 
| 84 | 
             
                conversation = [{'role': 'system', 'content': system_message}]
         | 
| 85 |  | 
| 86 | 
             
                # Add extra results
         | 
| 87 | 
             
                conversation += extra
         | 
| 88 |  | 
| 89 | 
            +
                if jailbreak_instructions := isJailbreak(jailbreak):
         | 
|  | |
|  | |
| 90 | 
             
                    conversation += jailbreak_instructions
         | 
| 91 |  | 
| 92 | 
             
                # Add the existing conversation and the prompt
         | 
|  | |
| 137 | 
             
                            yield "Error: jailbreak failed. Try again."
         | 
| 138 | 
             
                            break
         | 
| 139 | 
             
                else:
         | 
| 140 | 
            +
                    yield from response
         | 
|  | |
| 141 |  | 
| 142 |  | 
| 143 | 
             
            def response_jailbroken_success(response: str) -> bool:
         | 
|  | |
| 157 | 
             
                :param response: Response string  
         | 
| 158 | 
             
                :return: Boolean indicating if the response has not been jailbroken  
         | 
| 159 | 
             
                """
         | 
| 160 | 
            +
                return False if len(response) < 4 else not response.startswith("GPT:")
         | 
|  | |
|  | |
|  | |
|  | |
|  | |
|  | |
| 161 |  | 
| 162 |  | 
| 163 | 
             
            def set_response_language(prompt):
         | 
    	
        server/website.py
    CHANGED
    
    | @@ -26,8 +26,8 @@ class Website: | |
| 26 | 
             
                    }
         | 
| 27 |  | 
| 28 | 
             
                def _chat(self, conversation_id):
         | 
| 29 | 
            -
                    if  | 
| 30 | 
            -
                        return redirect( | 
| 31 |  | 
| 32 | 
             
                    return render_template('index.html', chat_id=conversation_id)
         | 
| 33 |  | 
|  | |
| 26 | 
             
                    }
         | 
| 27 |  | 
| 28 | 
             
                def _chat(self, conversation_id):
         | 
| 29 | 
            +
                    if '-' not in conversation_id:
         | 
| 30 | 
            +
                        return redirect('/chat')
         | 
| 31 |  | 
| 32 | 
             
                    return render_template('index.html', chat_id=conversation_id)
         | 
| 33 |  | 
