gengineapi 0.2.1__tar.gz → 0.2.2__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {gengineapi-0.2.1/src/gengineapi.egg-info → gengineapi-0.2.2}/PKG-INFO +42 -1
- gengineapi-0.2.1/PKG-INFO → gengineapi-0.2.2/README.md +311 -280
- {gengineapi-0.2.1 → gengineapi-0.2.2}/pyproject.toml +1 -1
- gengineapi-0.2.1/README.md → gengineapi-0.2.2/src/gengineapi.egg-info/PKG-INFO +321 -270
- {gengineapi-0.2.1 → gengineapi-0.2.2}/setup.cfg +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/__init__.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/client.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/config.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/exceptions.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/farm.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/http.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/modules/__init__.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/modules/auth.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/modules/base.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/modules/currencies.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/modules/finances.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/modules/payments.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/modules/transactions.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi/modules/users.py +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi.egg-info/SOURCES.txt +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi.egg-info/dependency_links.txt +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi.egg-info/requires.txt +0 -0
- {gengineapi-0.2.1 → gengineapi-0.2.2}/src/gengineapi.egg-info/top_level.txt +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.4
|
2
2
|
Name: gengineapi
|
3
|
-
Version: 0.2.
|
3
|
+
Version: 0.2.2
|
4
4
|
Summary: G-Engine API Client
|
5
5
|
Requires-Python: >=3.13
|
6
6
|
Description-Content-Type: text/markdown
|
@@ -39,6 +39,47 @@ pip install aiohttp-socks
|
|
39
39
|
|
40
40
|
## Использование
|
41
41
|
|
42
|
+
### Быстрый старт
|
43
|
+
|
44
|
+
```python
|
45
|
+
import os
|
46
|
+
import asyncio
|
47
|
+
import logging
|
48
|
+
from gengineapi import ClientFarm
|
49
|
+
from dotenv import load_dotenv
|
50
|
+
|
51
|
+
load_dotenv()
|
52
|
+
|
53
|
+
GTOKEN = os.getenv("GTOKEN")
|
54
|
+
|
55
|
+
# Настройка логирования
|
56
|
+
logging.basicConfig(
|
57
|
+
level=logging.INFO,
|
58
|
+
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s'
|
59
|
+
)
|
60
|
+
logger = logging.getLogger("gengine")
|
61
|
+
|
62
|
+
gfarm = ClientFarm(logger=logger)
|
63
|
+
|
64
|
+
gfarm.create_config(name="base",
|
65
|
+
base_url="https://b2b-api.ggsel.com/api/v2",
|
66
|
+
jwt_token=GTOKEN,
|
67
|
+
timeout=60,
|
68
|
+
max_retries=5,
|
69
|
+
proxy="socks5://username:password@host:port") # Прокси опциональные
|
70
|
+
|
71
|
+
async def main():
|
72
|
+
client = await gfarm.get_client("base")
|
73
|
+
|
74
|
+
async with client:
|
75
|
+
me = await client.users.get_me()
|
76
|
+
|
77
|
+
logger.info(me)
|
78
|
+
|
79
|
+
|
80
|
+
if __name__ == "__main__":
|
81
|
+
asyncio.run(main())
|
82
|
+
```
|
42
83
|
### Инициализация с существующим токеном
|
43
84
|
|
44
85
|
```python
|
@@ -1,280 +1,311 @@
|
|
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
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
#
|
114
|
-
|
115
|
-
print(f"
|
116
|
-
|
117
|
-
#
|
118
|
-
client.
|
119
|
-
|
120
|
-
#
|
121
|
-
client.
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
#
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
)
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
|
205
|
-
|
206
|
-
|
207
|
-
|
208
|
-
|
209
|
-
|
210
|
-
|
211
|
-
#
|
212
|
-
|
213
|
-
|
214
|
-
|
215
|
-
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
|
253
|
-
|
254
|
-
|
255
|
-
asyncio
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
|
263
|
-
-
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
274
|
-
|
275
|
-
|
276
|
-
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
1
|
+
# GEngineAPI
|
2
|
+
|
3
|
+
Асинхронный модульный клиент для взаимодействия с API G-Engine.
|
4
|
+
|
5
|
+
## Особенности
|
6
|
+
|
7
|
+
- Полностью асинхронный интерфейс на базе `aiohttp` и `asyncio`
|
8
|
+
- Модульная структура с разделением по доменам API
|
9
|
+
- Детальная обработка ошибок и исключений
|
10
|
+
- Автоматические повторные попытки для временных ошибок
|
11
|
+
- Поддержка JWT-аутентификации
|
12
|
+
- Поддержка прокси, включая SOCKS5
|
13
|
+
- Ферма клиентов с балансировкой нагрузки и стратегиями ротации
|
14
|
+
- Подробное логирование
|
15
|
+
- Строгая типизация с помощью аннотаций типов
|
16
|
+
- Класс-конфигурация для централизованной настройки и повторного использования
|
17
|
+
|
18
|
+
## Установка
|
19
|
+
|
20
|
+
```bash
|
21
|
+
pip install gengineapi
|
22
|
+
```
|
23
|
+
|
24
|
+
Для поддержки SOCKS5 прокси убедитесь, что установлен пакет `aiohttp-socks`:
|
25
|
+
|
26
|
+
```bash
|
27
|
+
pip install aiohttp-socks
|
28
|
+
```
|
29
|
+
|
30
|
+
## Использование
|
31
|
+
|
32
|
+
### Быстрый старт
|
33
|
+
|
34
|
+
```python
|
35
|
+
import os
|
36
|
+
import asyncio
|
37
|
+
import logging
|
38
|
+
from gengineapi import ClientFarm
|
39
|
+
from dotenv import load_dotenv
|
40
|
+
|
41
|
+
load_dotenv()
|
42
|
+
|
43
|
+
GTOKEN = os.getenv("GTOKEN")
|
44
|
+
|
45
|
+
# Настройка логирования
|
46
|
+
logging.basicConfig(
|
47
|
+
level=logging.INFO,
|
48
|
+
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s'
|
49
|
+
)
|
50
|
+
logger = logging.getLogger("gengine")
|
51
|
+
|
52
|
+
gfarm = ClientFarm(logger=logger)
|
53
|
+
|
54
|
+
gfarm.create_config(name="base",
|
55
|
+
base_url="https://b2b-api.ggsel.com/api/v2",
|
56
|
+
jwt_token=GTOKEN,
|
57
|
+
timeout=60,
|
58
|
+
max_retries=5,
|
59
|
+
proxy="socks5://username:password@host:port") # Прокси опциональные
|
60
|
+
|
61
|
+
async def main():
|
62
|
+
client = await gfarm.get_client("base")
|
63
|
+
|
64
|
+
async with client:
|
65
|
+
me = await client.users.get_me()
|
66
|
+
|
67
|
+
logger.info(me)
|
68
|
+
|
69
|
+
|
70
|
+
if __name__ == "__main__":
|
71
|
+
asyncio.run(main())
|
72
|
+
```
|
73
|
+
### Инициализация с существующим токеном
|
74
|
+
|
75
|
+
```python
|
76
|
+
import asyncio
|
77
|
+
from gengineapi import GEngineClient
|
78
|
+
|
79
|
+
async def main():
|
80
|
+
# Создаем клиент с существующим токеном
|
81
|
+
async with GEngineClient(
|
82
|
+
base_url="https://api.example.com/api/v2",
|
83
|
+
jwt_token="your-jwt-token",
|
84
|
+
timeout=30,
|
85
|
+
max_retries=3
|
86
|
+
) as client:
|
87
|
+
# Используем API
|
88
|
+
user_info = await client.users.get_me()
|
89
|
+
print(f"Текущий пользователь: {user_info['login']}")
|
90
|
+
|
91
|
+
asyncio.run(main())
|
92
|
+
```
|
93
|
+
|
94
|
+
### Получение нового токена
|
95
|
+
|
96
|
+
```python
|
97
|
+
import asyncio
|
98
|
+
from gengineapi import GEngineClient
|
99
|
+
|
100
|
+
async def main():
|
101
|
+
# Создаем клиент без токена
|
102
|
+
async with GEngineClient(
|
103
|
+
base_url="https://api.example.com/api/v2",
|
104
|
+
timeout=30,
|
105
|
+
max_retries=3
|
106
|
+
) as client:
|
107
|
+
# Аутентифицируемся и получаем токен
|
108
|
+
token_info = await client.auth.login(
|
109
|
+
login="user@example.com",
|
110
|
+
password="secure_password"
|
111
|
+
)
|
112
|
+
|
113
|
+
# Получаем токен
|
114
|
+
token = token_info["access_token"]
|
115
|
+
print(f"Получен токен: {token}")
|
116
|
+
|
117
|
+
# Обновляем токен в клиенте
|
118
|
+
client.update_token(token)
|
119
|
+
|
120
|
+
# Используем API
|
121
|
+
user_info = await client.users.get_me()
|
122
|
+
print(f"Текущий пользователь: {user_info['login']}")
|
123
|
+
|
124
|
+
asyncio.run(main())
|
125
|
+
```
|
126
|
+
|
127
|
+
### Использование прокси
|
128
|
+
|
129
|
+
Клиент поддерживает работу через прокси, включая SOCKS5:
|
130
|
+
|
131
|
+
```python
|
132
|
+
import asyncio
|
133
|
+
from gengineapi import GEngineClient
|
134
|
+
|
135
|
+
async def main():
|
136
|
+
# Создаем клиент с использованием SOCKS5 прокси
|
137
|
+
async with GEngineClient(
|
138
|
+
base_url="https://api.example.com/api/v2",
|
139
|
+
jwt_token="your-jwt-token",
|
140
|
+
timeout=60, # Увеличиваем таймаут для прокси
|
141
|
+
max_retries=5, # Увеличиваем количество повторных попыток
|
142
|
+
proxy="socks5://user:pass@host:port" # Адрес SOCKS5 прокси
|
143
|
+
) as client:
|
144
|
+
# Используем API через прокси
|
145
|
+
user_info = await client.users.get_me()
|
146
|
+
print(f"Текущий пользователь: {user_info['login']}")
|
147
|
+
|
148
|
+
# Можно изменить настройки прокси на лету
|
149
|
+
client.update_proxy("socks5://another-host:port")
|
150
|
+
|
151
|
+
# Или отключить прокси
|
152
|
+
client.update_proxy(None)
|
153
|
+
|
154
|
+
asyncio.run(main())
|
155
|
+
```
|
156
|
+
|
157
|
+
### Использование класса-конфигурации
|
158
|
+
|
159
|
+
Класс-конфигурация позволяет настроить параметры клиента один раз и затем использовать их многократно:
|
160
|
+
|
161
|
+
```python
|
162
|
+
import asyncio
|
163
|
+
from gengineapi import GEngineConfig
|
164
|
+
|
165
|
+
async def main():
|
166
|
+
# Настройка параметров клиента
|
167
|
+
GEngineConfig.setup(
|
168
|
+
base_url="https://api.example.com/api/v2",
|
169
|
+
jwt_token="your-jwt-token",
|
170
|
+
timeout=30,
|
171
|
+
max_retries=3,
|
172
|
+
proxy="socks5://127.0.0.1:9050" # Опционально - прокси
|
173
|
+
)
|
174
|
+
|
175
|
+
# Получение глобального экземпляра клиента
|
176
|
+
client = await GEngineConfig.get_client()
|
177
|
+
|
178
|
+
# Использование клиента
|
179
|
+
user_info = await client.users.get_me()
|
180
|
+
print(f"Текущий пользователь: {user_info['login']}")
|
181
|
+
|
182
|
+
# Не нужно закрывать клиент при каждом использовании,
|
183
|
+
# так как он хранится глобально
|
184
|
+
|
185
|
+
# В другой части приложения
|
186
|
+
# Получение того же экземпляра клиента
|
187
|
+
client = await GEngineConfig.get_client()
|
188
|
+
|
189
|
+
# Использование клиента
|
190
|
+
balance = await client.users.get_balance()
|
191
|
+
print(f"Баланс: {balance['balance']} {balance['currency']}")
|
192
|
+
|
193
|
+
# Обновление настройки прокси в конфигурации
|
194
|
+
await GEngineConfig.update_proxy(None) # Отключение прокси
|
195
|
+
|
196
|
+
# При завершении приложения
|
197
|
+
await GEngineConfig.reset() # Закрывает глобальный клиент
|
198
|
+
|
199
|
+
asyncio.run(main())
|
200
|
+
```
|
201
|
+
|
202
|
+
### Использование фермы клиентов
|
203
|
+
|
204
|
+
Ферма клиентов позволяет управлять множеством клиентов с разными конфигурациями и стратегиями ротации:
|
205
|
+
|
206
|
+
```python
|
207
|
+
import asyncio
|
208
|
+
from gengineapi import ClientFarm
|
209
|
+
|
210
|
+
async def main():
|
211
|
+
# Создаем ферму клиентов
|
212
|
+
farm = ClientFarm()
|
213
|
+
|
214
|
+
# Добавляем несколько конфигураций с разными прокси
|
215
|
+
farm.create_config(
|
216
|
+
name="client1",
|
217
|
+
base_url="https://api.example.com/api/v2",
|
218
|
+
jwt_token="token1",
|
219
|
+
proxy="socks5://user1:pass1@host1:port1",
|
220
|
+
tags=["group1", "production"]
|
221
|
+
)
|
222
|
+
|
223
|
+
farm.create_config(
|
224
|
+
name="client2",
|
225
|
+
base_url="https://api.example.com/api/v2",
|
226
|
+
jwt_token="token2",
|
227
|
+
proxy="socks5://user2:pass2@host2:port2",
|
228
|
+
tags=["group1", "backup"]
|
229
|
+
)
|
230
|
+
|
231
|
+
# Устанавливаем стратегию выбора клиента
|
232
|
+
farm.set_selection_strategy("round_robin") # или "random", "least_errors", "least_recently_used"
|
233
|
+
|
234
|
+
# Получаем клиент по имени
|
235
|
+
client1 = await farm.get_client("client1")
|
236
|
+
await client1.users.get_me()
|
237
|
+
|
238
|
+
# Получаем следующий клиент согласно стратегии
|
239
|
+
client = await farm.get_next_client()
|
240
|
+
await client.currencies.get_rate(source="cb_rf", pair="USD:RUB")
|
241
|
+
|
242
|
+
# Получаем клиент по тегу
|
243
|
+
client = await farm.get_next_client(tag="production")
|
244
|
+
await client.transactions.get_transactions(limit=5)
|
245
|
+
|
246
|
+
# При завершении работы закрываем все клиенты
|
247
|
+
await farm.close_all()
|
248
|
+
|
249
|
+
asyncio.run(main())
|
250
|
+
```
|
251
|
+
|
252
|
+
### Работа с платежами
|
253
|
+
|
254
|
+
```python
|
255
|
+
import asyncio
|
256
|
+
import uuid
|
257
|
+
from decimal import Decimal
|
258
|
+
from gengineapi import GEngineClient
|
259
|
+
|
260
|
+
async def main():
|
261
|
+
async with GEngineClient(
|
262
|
+
base_url="https://api.example.com/api/v2",
|
263
|
+
jwt_token="your-jwt-token"
|
264
|
+
) as client:
|
265
|
+
# Генерируем уникальный идентификатор транзакции
|
266
|
+
transaction_id = str(uuid.uuid4())
|
267
|
+
|
268
|
+
# Создаем и верифицируем платеж
|
269
|
+
payment = await client.payments.verify(
|
270
|
+
transaction_id=transaction_id,
|
271
|
+
service_id=1,
|
272
|
+
account="user123",
|
273
|
+
amount=Decimal("10.99"),
|
274
|
+
currency="USD"
|
275
|
+
)
|
276
|
+
print(f"Создан платеж: {payment['transaction_id']}")
|
277
|
+
|
278
|
+
# Выполняем платеж
|
279
|
+
result = await client.payments.execute(transaction_id=transaction_id)
|
280
|
+
print(f"Статус платежа: {result['status_code']}")
|
281
|
+
|
282
|
+
# Получаем статус платежа
|
283
|
+
status = await client.payments.get_status(transaction_id=transaction_id)
|
284
|
+
print(f"Текущий статус платежа: {status['status_code']}")
|
285
|
+
|
286
|
+
asyncio.run(main())
|
287
|
+
```
|
288
|
+
|
289
|
+
## Доступные модули API
|
290
|
+
|
291
|
+
- `payments` - создание и выполнение платежей
|
292
|
+
- `finances` - работа с финансовыми данными
|
293
|
+
- `auth` - аутентификация и управление токенами
|
294
|
+
- `users` - работа с пользователями и их балансами
|
295
|
+
- `transactions` - работа с транзакциями
|
296
|
+
- `currencies` - работа с курсами валют
|
297
|
+
|
298
|
+
## Дополнительная документация
|
299
|
+
|
300
|
+
Ручки, которые дергаем - https://b2b-api.ggsel.com/api/v2/docs#
|
301
|
+
|
302
|
+
## Зависимости
|
303
|
+
|
304
|
+
- Python 3.7+
|
305
|
+
- aiohttp >= 3.8.0
|
306
|
+
- typing-extensions >= 4.0.0
|
307
|
+
- aiohttp-socks >= 0.7.1 (опционально, для поддержки SOCKS5 прокси)
|
308
|
+
|
309
|
+
## Лицензия
|
310
|
+
|
311
|
+
MIT
|