feat(api): implement secure API key management with encryption and CRUD operations
This commit is contained in:
@@ -14,64 +14,68 @@ from dotenv import load_dotenv
|
||||
from src.models.models import Tool
|
||||
|
||||
# Configure logging
|
||||
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
|
||||
logging.basicConfig(
|
||||
level=logging.INFO, format="%(asctime)s - %(levelname)s - %(message)s"
|
||||
)
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
def create_tools():
|
||||
"""Cria ferramentas padrão no sistema"""
|
||||
"""Create default tools in the system"""
|
||||
try:
|
||||
# Load environment variables
|
||||
load_dotenv()
|
||||
|
||||
|
||||
# Get database settings
|
||||
db_url = os.getenv("POSTGRES_CONNECTION_STRING")
|
||||
if not db_url:
|
||||
logger.error("Environment variable POSTGRES_CONNECTION_STRING not defined")
|
||||
return False
|
||||
|
||||
|
||||
# Connect to the database
|
||||
engine = create_engine(db_url)
|
||||
Session = sessionmaker(bind=engine)
|
||||
session = Session()
|
||||
|
||||
|
||||
try:
|
||||
# Check if there are already tools
|
||||
existing_tools = session.query(Tool).all()
|
||||
if existing_tools:
|
||||
logger.info(f"There are already {len(existing_tools)} tools registered")
|
||||
return True
|
||||
|
||||
|
||||
# Tools definitions
|
||||
tools = []
|
||||
|
||||
|
||||
# Create the tools
|
||||
for tool_data in tools:
|
||||
|
||||
|
||||
tool = Tool(
|
||||
name=tool_data["name"],
|
||||
description=tool_data["description"],
|
||||
config_json=tool_data["config_json"],
|
||||
environments=tool_data["environments"]
|
||||
environments=tool_data["environments"],
|
||||
)
|
||||
|
||||
|
||||
session.add(tool)
|
||||
logger.info(f"Tool '{tool_data['name']}' created successfully")
|
||||
|
||||
|
||||
session.commit()
|
||||
logger.info("All tools were created successfully")
|
||||
return True
|
||||
|
||||
|
||||
except SQLAlchemyError as e:
|
||||
session.rollback()
|
||||
logger.error(f"Database error when creating tools: {str(e)}")
|
||||
return False
|
||||
|
||||
|
||||
except Exception as e:
|
||||
logger.error(f"Error when creating tools: {str(e)}")
|
||||
return False
|
||||
finally:
|
||||
session.close()
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
success = create_tools()
|
||||
sys.exit(0 if success else 1)
|
||||
sys.exit(0 if success else 1)
|
||||
|
||||
Reference in New Issue
Block a user