akra35567 commited on
Commit
ef8f81a
·
1 Parent(s): 085955a

Update modules/config.py

Browse files
Files changed (1) hide show
  1. modules/config.py +26 -16
modules/config.py CHANGED
@@ -1,8 +1,7 @@
1
  """
2
  Configuração central da Akira IA
3
  ================================
4
- CHAVES DIRETAS NO CÓDIGO (para Hugging Face Spaces)
5
- SEM LIXO DE LOG → NUNCA MAIS SyntaxError
6
  """
7
  import os
8
  from typing import Optional, List
@@ -12,10 +11,10 @@ from loguru import logger
12
  # CHAVES DE API (SUBSTITUA PELAS SUAS CHAVES REAIS)
13
  # ============================================================================
14
 
15
- MISTRAL_API_KEY: str = "jy0tmu2iAbPyhEFJORCECxEg7hh0pd3a" # COLOQUE CHAVE VÁLIDA (começa com 'm-')
16
- GEMINI_API_KEY: str = "AIzaSyBcX3wqmEDYTrggNNbv31-A2QG2A7IssRc" # COLOQUE CHAVE VÁLIDA (começa com 'AIzaSy')
17
  SERPAPI_KEY: Optional[str] = "d81753b2909eb4746e1e0c92e052d6588ab725cf46f89fd9182c3da5daa477a5"
18
- HF_TOKEN: Optional[str] = None # opcional
19
 
20
  # ============================================================================
21
  # MODELOS
@@ -81,26 +80,37 @@ PRIVILEGED_USERS: List[str] = [
81
  ]
82
 
83
  # ============================================================================
84
- # VALIDAÇÃO + BANCO
85
  # ============================================================================
86
 
87
  def validate_config() -> None:
88
- missing = []
89
-
90
- if not MISTRAL_API_KEY or not MISTRAL_API_KEY.startswith('m-'):
91
- missing.append("MISTRAL_API_KEY")
 
 
 
 
92
  else:
93
  logger.info("MISTRAL_API_KEY OK")
94
 
95
- if not GEMINI_API_KEY or not GEMINI_API_KEY.startswith('AIza'):
96
- missing.append("GEMINI_API_KEY")
 
 
 
 
97
  else:
98
  logger.info("GEMINI_API_KEY OK")
99
 
100
- if missing:
101
- logger.error(f"ERRO: {', '.join(missing)}")
102
- raise EnvironmentError("Chaves inválidas em config.py")
 
 
103
 
 
104
  os.makedirs(os.path.dirname(DB_PATH), exist_ok=True)
105
  _init_db()
106
 
@@ -125,5 +135,5 @@ def _init_db() -> None:
125
  logger.error(f"Erro ao criar banco: {e}")
126
  raise
127
 
128
- # EXECUTA VALIDAÇÃO NA IMPORTAÇÃO
129
  validate_config()
 
1
  """
2
  Configuração central da Akira IA
3
  ================================
4
+ CHAVES DIRETAS + VALIDAÇÃO FLEXÍVEL (NÃO BLOQUEIA SE CHAVE INVÁLIDA)
 
5
  """
6
  import os
7
  from typing import Optional, List
 
11
  # CHAVES DE API (SUBSTITUA PELAS SUAS CHAVES REAIS)
12
  # ============================================================================
13
 
14
+ MISTRAL_API_KEY: str = "jy0tmu2iAbPyhEFJORCECxEg7hh0pd3a" # COLOQUE CHAVE VÁLIDA (m-...)
15
+ GEMINI_API_KEY: str = "AIzaSyBcX3wqmEDYTrggNNbv31-A2QG2A7IssRc" # COLOQUE CHAVE VÁLIDA (AIzaSy...)
16
  SERPAPI_KEY: Optional[str] = "d81753b2909eb4746e1e0c92e052d6588ab725cf46f89fd9182c3da5daa477a5"
17
+ HF_TOKEN: Optional[str] = None
18
 
19
  # ============================================================================
20
  # MODELOS
 
80
  ]
81
 
82
  # ============================================================================
83
+ # VALIDAÇÃO FLEXÍVEL (NÃO BLOQUEIA O APP)
84
  # ============================================================================
85
 
86
  def validate_config() -> None:
87
+ warnings = []
88
+
89
+ if not MISTRAL_API_KEY or len(MISTRAL_API_KEY.strip()) < 20:
90
+ warnings.append("MISTRAL_API_KEY (inválida ou ausente)")
91
+ logger.warning("MISTRAL_API_KEY inválida → API principal DESATIVADA")
92
+ elif not MISTRAL_API_KEY.strip().startswith('m-'):
93
+ warnings.append("MISTRAL_API_KEY (não começa com 'm-')")
94
+ logger.warning("MISTRAL_API_KEY inválida (deve começar com 'm-') → DESATIVADA")
95
  else:
96
  logger.info("MISTRAL_API_KEY OK")
97
 
98
+ if not GEMINI_API_KEY or len(GEMINI_API_KEY.strip()) < 30:
99
+ warnings.append("GEMINI_API_KEY (inválida ou ausente)")
100
+ logger.warning("GEMINI_API_KEY inválida → fallback DESATIVADO")
101
+ elif not GEMINI_API_KEY.strip().startswith('AIza'):
102
+ warnings.append("GEMINI_API_KEY (não começa com 'AIza')")
103
+ logger.warning("GEMINI_API_KEY inválida (deve começar com 'AIza') → DESATIVADA")
104
  else:
105
  logger.info("GEMINI_API_KEY OK")
106
 
107
+ if warnings:
108
+ logger.warning(f"AVISOS: {', '.join(warnings)}")
109
+ logger.warning("App vai rodar com fallbacks limitados")
110
+ else:
111
+ logger.info("Todas as chaves OK")
112
 
113
+ # Sempre cria banco
114
  os.makedirs(os.path.dirname(DB_PATH), exist_ok=True)
115
  _init_db()
116
 
 
135
  logger.error(f"Erro ao criar banco: {e}")
136
  raise
137
 
138
+ # EXECUTA VALIDAÇÃO (NÃO BLOQUEIA)
139
  validate_config()