-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathagents-docker.py
76 lines (63 loc) · 2.39 KB
/
agents-docker.py
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
import json
import requests
import logging
import os
from datetime import datetime
from typing import Dict, Any
logging.basicConfig(
level=logging.INFO,
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s'
)
logger = logging.getLogger(__name__)
class APIRunner:
def __init__(self, api_config: Dict[str, Any]):
self.api_config = api_config
self.name = api_config['name']
self.url = api_config['url']
self.method = api_config['method']
self.headers = api_config.get('headers', {})
self.port = api_config.get('port', 8000)
def call_api(self) -> Dict[str, Any]:
try:
logger.info(f"Calling {self.name} on port {self.port}")
request_func = getattr(requests, self.method.lower())
response = request_func(self.url, headers=self.headers)
result = {
'api_name': self.name,
'port': self.port,
'status_code': response.status_code,
'timestamp': datetime.now().isoformat(),
'response': response.json()
}
logger.info(f"{self.name} response status: {response.status_code}")
return result
except Exception as e:
logger.error(f"Error in {self.name}: {str(e)}")
return {
'api_name': self.name,
'port': self.port,
'error': str(e),
'timestamp': datetime.now().isoformat()
}
def load_api_config() -> Dict[str, Any]:
api_id = int(os.environ.get('API_ID', 1))
with open('db.json', 'r') as f:
apis = json.load(f)['apis']
return next(api for api in apis if api['id'] == api_id)
def save_response(response: Dict[str, Any]) -> None:
filename = f"responses/{response['api_name']}.json"
os.makedirs('responses', exist_ok=True)
with open(filename, 'w') as f:
json.dump(response, f, indent=2)
logger.info(f"Saved response to {filename}")
def main():
try:
api_config = load_api_config()
runner = APIRunner(api_config)
response = runner.call_api()
save_response(response)
except Exception as e:
logger.error(f"Fatal error: {str(e)}")
raise
if __name__ == "__main__":
main()