@andrebuzeli/git-mcp 2.28.1 → 2.28.2
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.
- package/dist/client.d.ts +306 -306
- package/dist/client.js +298 -298
- package/dist/config.d.ts +310 -310
- package/dist/config.js +392 -392
- package/dist/index.d.ts +22 -22
- package/dist/index.js +89 -89
- package/dist/providers/base-provider.d.ts +160 -160
- package/dist/providers/base-provider.js +274 -274
- package/dist/providers/error-handler.d.ts +50 -50
- package/dist/providers/error-handler.js +175 -175
- package/dist/providers/gitea-provider.d.ts +97 -97
- package/dist/providers/gitea-provider.d.ts.map +1 -1
- package/dist/providers/gitea-provider.js +1015 -1001
- package/dist/providers/gitea-provider.js.map +1 -1
- package/dist/providers/github-provider.d.ts +104 -104
- package/dist/providers/github-provider.d.ts.map +1 -1
- package/dist/providers/github-provider.js +1248 -1234
- package/dist/providers/github-provider.js.map +1 -1
- package/dist/providers/index.d.ts +12 -12
- package/dist/providers/index.js +40 -40
- package/dist/providers/provider-factory.d.ts +74 -74
- package/dist/providers/provider-factory.d.ts.map +1 -1
- package/dist/providers/provider-factory.js +318 -311
- package/dist/providers/provider-factory.js.map +1 -1
- package/dist/providers/types.d.ts +318 -318
- package/dist/providers/types.js +6 -6
- package/dist/server.d.ts +76 -76
- package/dist/server.js +306 -306
- package/dist/tools/git-archive.d.ts +165 -165
- package/dist/tools/git-archive.js +233 -233
- package/dist/tools/git-branches.d.ts +430 -430
- package/dist/tools/git-branches.js +627 -627
- package/dist/tools/git-commits.d.ts +485 -485
- package/dist/tools/git-commits.js +735 -735
- package/dist/tools/git-commits.js.map +1 -1
- package/dist/tools/git-config.d.ts +140 -140
- package/dist/tools/git-config.js +268 -268
- package/dist/tools/git-files.d.ts +486 -486
- package/dist/tools/git-files.js +607 -607
- package/dist/tools/git-files.js.map +1 -1
- package/dist/tools/git-issues.d.ts +574 -571
- package/dist/tools/git-issues.d.ts.map +1 -1
- package/dist/tools/git-issues.js +741 -740
- package/dist/tools/git-issues.js.map +1 -1
- package/dist/tools/git-pulls.d.ts +697 -694
- package/dist/tools/git-pulls.d.ts.map +1 -1
- package/dist/tools/git-pulls.js +733 -732
- package/dist/tools/git-pulls.js.map +1 -1
- package/dist/tools/git-releases.d.ts +490 -487
- package/dist/tools/git-releases.d.ts.map +1 -1
- package/dist/tools/git-releases.js +558 -557
- package/dist/tools/git-releases.js.map +1 -1
- package/dist/tools/git-remote.d.ts +138 -138
- package/dist/tools/git-remote.js +274 -274
- package/dist/tools/git-repositories.d.ts +483 -483
- package/dist/tools/git-repositories.js +640 -640
- package/dist/tools/git-repositories.js.map +1 -1
- package/dist/tools/git-reset.d.ts +130 -130
- package/dist/tools/git-reset.js +223 -223
- package/dist/tools/git-revert.d.ts +149 -149
- package/dist/tools/git-revert.js +198 -198
- package/dist/tools/git-stash.d.ts +140 -140
- package/dist/tools/git-stash.js +269 -269
- package/dist/tools/git-sync.d.ts +178 -178
- package/dist/tools/git-sync.js +312 -312
- package/dist/tools/git-tags.d.ts +414 -411
- package/dist/tools/git-tags.d.ts.map +1 -1
- package/dist/tools/git-tags.js +486 -485
- package/dist/tools/git-tags.js.map +1 -1
- package/dist/tools/git-webhooks.d.ts +473 -470
- package/dist/tools/git-webhooks.d.ts.map +1 -1
- package/dist/tools/git-webhooks.js +544 -543
- package/dist/tools/git-webhooks.js.map +1 -1
- package/dist/utils/terminal-controller.d.ts +80 -80
- package/dist/utils/terminal-controller.js +345 -345
- package/dist/utils/user-detection.d.ts +24 -24
- package/dist/utils/user-detection.js +53 -53
- package/package.json +2 -2
- package/dist/tools/gh-actions.d.ts +0 -253
- package/dist/tools/gh-actions.d.ts.map +0 -1
- package/dist/tools/gh-actions.js +0 -390
- package/dist/tools/gh-actions.js.map +0 -1
- package/dist/tools/gh-analytics.d.ts +0 -264
- package/dist/tools/gh-analytics.d.ts.map +0 -1
- package/dist/tools/gh-analytics.js +0 -402
- package/dist/tools/gh-analytics.js.map +0 -1
- package/dist/tools/gh-code-review.d.ts +0 -305
- package/dist/tools/gh-code-review.d.ts.map +0 -1
- package/dist/tools/gh-code-review.js +0 -513
- package/dist/tools/gh-code-review.js.map +0 -1
- package/dist/tools/gh-codespaces.d.ts +0 -139
- package/dist/tools/gh-codespaces.d.ts.map +0 -1
- package/dist/tools/gh-codespaces.js +0 -283
- package/dist/tools/gh-codespaces.js.map +0 -1
- package/dist/tools/gh-deployments.d.ts +0 -301
- package/dist/tools/gh-deployments.d.ts.map +0 -1
- package/dist/tools/gh-deployments.js +0 -368
- package/dist/tools/gh-deployments.js.map +0 -1
- package/dist/tools/gh-gists.d.ts +0 -175
- package/dist/tools/gh-gists.d.ts.map +0 -1
- package/dist/tools/gh-gists.js +0 -322
- package/dist/tools/gh-gists.js.map +0 -1
- package/dist/tools/gh-projects.d.ts +0 -206
- package/dist/tools/gh-projects.d.ts.map +0 -1
- package/dist/tools/gh-projects.js +0 -359
- package/dist/tools/gh-projects.js.map +0 -1
- package/dist/tools/gh-security.d.ts +0 -275
- package/dist/tools/gh-security.d.ts.map +0 -1
- package/dist/tools/gh-security.js +0 -396
- package/dist/tools/gh-security.js.map +0 -1
- package/dist/tools/gh-sync.d.ts +0 -214
- package/dist/tools/gh-sync.d.ts.map +0 -1
- package/dist/tools/gh-sync.js +0 -379
- package/dist/tools/gh-sync.js.map +0 -1
- package/dist/tools/gh-workflows.d.ts +0 -291
- package/dist/tools/gh-workflows.d.ts.map +0 -1
- package/dist/tools/gh-workflows.js +0 -433
- package/dist/tools/gh-workflows.js.map +0 -1
- package/dist/tools/git-bundle.d.ts +0 -172
- package/dist/tools/git-bundle.d.ts.map +0 -1
- package/dist/tools/git-bundle.js +0 -242
- package/dist/tools/git-bundle.js.map +0 -1
- package/dist/tools/git-cherry-pick.d.ts +0 -159
- package/dist/tools/git-cherry-pick.d.ts.map +0 -1
- package/dist/tools/git-cherry-pick.js +0 -225
- package/dist/tools/git-cherry-pick.js.map +0 -1
- package/dist/tools/git-rebase.d.ts +0 -138
- package/dist/tools/git-rebase.d.ts.map +0 -1
- package/dist/tools/git-rebase.js +0 -214
- package/dist/tools/git-rebase.js.map +0 -1
- package/dist/tools/git-submodule.d.ts +0 -153
- package/dist/tools/git-submodule.d.ts.map +0 -1
- package/dist/tools/git-submodule.js +0 -290
- package/dist/tools/git-submodule.js.map +0 -1
- package/dist/tools/git-worktree.d.ts +0 -160
- package/dist/tools/git-worktree.d.ts.map +0 -1
- package/dist/tools/git-worktree.js +0 -270
- package/dist/tools/git-worktree.js.map +0 -1
- package/dist/tools/repositories.d.ts +0 -406
- package/dist/tools/repositories.d.ts.map +0 -1
- package/dist/tools/repositories.js +0 -570
- package/dist/tools/repositories.js.map +0 -1
- package/dist/tools/users.d.ts +0 -373
- package/dist/tools/users.d.ts.map +0 -1
- package/dist/tools/users.js +0 -500
- package/dist/tools/users.js.map +0 -1
- package/dist/tools/validator.d.ts +0 -171
- package/dist/tools/validator.d.ts.map +0 -1
- package/dist/tools/validator.js +0 -195
- package/dist/tools/validator.js.map +0 -1
- package/dist/tools/version-control.d.ts +0 -137
- package/dist/tools/version-control.d.ts.map +0 -1
- package/dist/tools/version-control.js +0 -165
- package/dist/tools/version-control.js.map +0 -1
package/dist/config.d.ts
CHANGED
|
@@ -1,311 +1,311 @@
|
|
|
1
|
-
import { z } from 'zod';
|
|
2
|
-
/**
|
|
3
|
-
* Schema de validação para configuração do servidor MCP Gitea
|
|
4
|
-
*
|
|
5
|
-
* VALIDAÇÕES:
|
|
6
|
-
* - giteaUrl: Deve ser uma URL válida
|
|
7
|
-
* - giteaToken: Deve ter pelo menos 1 caractere
|
|
8
|
-
* - giteaUsername: Opcional
|
|
9
|
-
* - debug: Padrão false
|
|
10
|
-
* - timeout: Deve ser positivo, padrão 30000ms
|
|
11
|
-
*
|
|
12
|
-
* RECOMENDAÇÕES:
|
|
13
|
-
* - Use HTTPS para produção
|
|
14
|
-
* - Token deve ter permissões adequadas
|
|
15
|
-
* - Timeout deve considerar latência da rede
|
|
16
|
-
*/
|
|
17
|
-
declare const ConfigSchema: z.ZodEffects<z.ZodObject<{
|
|
18
|
-
giteaUrl: z.ZodOptional<z.ZodString>;
|
|
19
|
-
giteaToken: z.ZodOptional<z.ZodString>;
|
|
20
|
-
giteaUsername: z.ZodOptional<z.ZodString>;
|
|
21
|
-
githubToken: z.ZodOptional<z.ZodString>;
|
|
22
|
-
githubUsername: z.ZodOptional<z.ZodString>;
|
|
23
|
-
provider: z.ZodOptional<z.ZodEnum<["gitea", "github"]>>;
|
|
24
|
-
apiUrl: z.ZodOptional<z.ZodString>;
|
|
25
|
-
apiToken: z.ZodOptional<z.ZodString>;
|
|
26
|
-
defaultProvider: z.ZodOptional<z.ZodString>;
|
|
27
|
-
providersJson: z.ZodEffects<z.ZodOptional<z.ZodString>, any, string | undefined>;
|
|
28
|
-
debug: z.ZodDefault<z.ZodBoolean>;
|
|
29
|
-
timeout: z.ZodDefault<z.ZodNumber>;
|
|
30
|
-
}, "strip", z.ZodTypeAny, {
|
|
31
|
-
debug: boolean;
|
|
32
|
-
timeout: number;
|
|
33
|
-
giteaUrl?: string | undefined;
|
|
34
|
-
giteaToken?: string | undefined;
|
|
35
|
-
giteaUsername?: string | undefined;
|
|
36
|
-
githubToken?: string | undefined;
|
|
37
|
-
githubUsername?: string | undefined;
|
|
38
|
-
provider?: "gitea" | "github" | undefined;
|
|
39
|
-
apiUrl?: string | undefined;
|
|
40
|
-
apiToken?: string | undefined;
|
|
41
|
-
defaultProvider?: string | undefined;
|
|
42
|
-
providersJson?: any;
|
|
43
|
-
}, {
|
|
44
|
-
giteaUrl?: string | undefined;
|
|
45
|
-
giteaToken?: string | undefined;
|
|
46
|
-
giteaUsername?: string | undefined;
|
|
47
|
-
githubToken?: string | undefined;
|
|
48
|
-
githubUsername?: string | undefined;
|
|
49
|
-
provider?: "gitea" | "github" | undefined;
|
|
50
|
-
apiUrl?: string | undefined;
|
|
51
|
-
apiToken?: string | undefined;
|
|
52
|
-
defaultProvider?: string | undefined;
|
|
53
|
-
providersJson?: string | undefined;
|
|
54
|
-
debug?: boolean | undefined;
|
|
55
|
-
timeout?: number | undefined;
|
|
56
|
-
}>, {
|
|
57
|
-
debug: boolean;
|
|
58
|
-
timeout: number;
|
|
59
|
-
giteaUrl?: string | undefined;
|
|
60
|
-
giteaToken?: string | undefined;
|
|
61
|
-
giteaUsername?: string | undefined;
|
|
62
|
-
githubToken?: string | undefined;
|
|
63
|
-
githubUsername?: string | undefined;
|
|
64
|
-
provider?: "gitea" | "github" | undefined;
|
|
65
|
-
apiUrl?: string | undefined;
|
|
66
|
-
apiToken?: string | undefined;
|
|
67
|
-
defaultProvider?: string | undefined;
|
|
68
|
-
providersJson?: any;
|
|
69
|
-
}, {
|
|
70
|
-
giteaUrl?: string | undefined;
|
|
71
|
-
giteaToken?: string | undefined;
|
|
72
|
-
giteaUsername?: string | undefined;
|
|
73
|
-
githubToken?: string | undefined;
|
|
74
|
-
githubUsername?: string | undefined;
|
|
75
|
-
provider?: "gitea" | "github" | undefined;
|
|
76
|
-
apiUrl?: string | undefined;
|
|
77
|
-
apiToken?: string | undefined;
|
|
78
|
-
defaultProvider?: string | undefined;
|
|
79
|
-
providersJson?: string | undefined;
|
|
80
|
-
debug?: boolean | undefined;
|
|
81
|
-
timeout?: number | undefined;
|
|
82
|
-
}>;
|
|
83
|
-
export type Config = z.infer<typeof ConfigSchema>;
|
|
84
|
-
export interface ProviderConfig {
|
|
85
|
-
name: string;
|
|
86
|
-
type: 'gitea' | 'github';
|
|
87
|
-
apiUrl: string;
|
|
88
|
-
token: string;
|
|
89
|
-
username?: string;
|
|
90
|
-
}
|
|
91
|
-
export interface MultiProviderConfig {
|
|
92
|
-
defaultProvider: string;
|
|
93
|
-
providers: ProviderConfig[];
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Gerenciador de configuração usando padrão Singleton
|
|
97
|
-
*
|
|
98
|
-
* RESPONSABILIDADES:
|
|
99
|
-
* - Carregar configuração do ambiente
|
|
100
|
-
* - Validar parâmetros obrigatórios
|
|
101
|
-
* - Fornecer acesso centralizado à configuração
|
|
102
|
-
*
|
|
103
|
-
* USO:
|
|
104
|
-
* - const config = ConfigManager.getInstance();
|
|
105
|
-
* - const url = config.getGiteaUrl();
|
|
106
|
-
*
|
|
107
|
-
* RECOMENDAÇÕES:
|
|
108
|
-
* - Sempre use getInstance() para acessar
|
|
109
|
-
* - Configure variáveis de ambiente adequadamente
|
|
110
|
-
* - Valide configuração antes de usar
|
|
111
|
-
*/
|
|
112
|
-
export declare class ConfigManager {
|
|
113
|
-
private static instance;
|
|
114
|
-
private config;
|
|
115
|
-
private constructor();
|
|
116
|
-
/**
|
|
117
|
-
* Obtém a instância única do ConfigManager
|
|
118
|
-
*
|
|
119
|
-
* IMPLEMENTAÇÃO:
|
|
120
|
-
* - Singleton pattern para configuração global
|
|
121
|
-
* - Thread-safe para aplicações concorrentes
|
|
122
|
-
*
|
|
123
|
-
* RETORNO:
|
|
124
|
-
* - Instância única do ConfigManager
|
|
125
|
-
*/
|
|
126
|
-
static getInstance(): ConfigManager;
|
|
127
|
-
/**
|
|
128
|
-
* Carrega e valida a configuração do ambiente
|
|
129
|
-
*
|
|
130
|
-
* FONTES DE CONFIGURAÇÃO:
|
|
131
|
-
* - Variáveis de ambiente (prioridade alta)
|
|
132
|
-
* - Valores padrão (fallback)
|
|
133
|
-
*
|
|
134
|
-
* VALIDAÇÃO:
|
|
135
|
-
* - Schema Zod para validação rigorosa
|
|
136
|
-
* - Mensagens de erro descritivas
|
|
137
|
-
*
|
|
138
|
-
* ERROS:
|
|
139
|
-
* - Configuração inválida gera exceção
|
|
140
|
-
* - Token obrigatório deve ser fornecido
|
|
141
|
-
*/
|
|
142
|
-
private loadConfig;
|
|
143
|
-
/**
|
|
144
|
-
* Obtém a configuração completa validada
|
|
145
|
-
*
|
|
146
|
-
* RETORNO:
|
|
147
|
-
* - Objeto Config com todos os parâmetros
|
|
148
|
-
*
|
|
149
|
-
* USO:
|
|
150
|
-
* - Para acesso direto à configuração
|
|
151
|
-
* - Para validação de parâmetros
|
|
152
|
-
*/
|
|
153
|
-
getConfig(): Config;
|
|
154
|
-
/**
|
|
155
|
-
* Obtém a URL base do Gitea
|
|
156
|
-
*
|
|
157
|
-
* RETORNO:
|
|
158
|
-
* - URL completa do servidor Gitea
|
|
159
|
-
*
|
|
160
|
-
* EXEMPLO:
|
|
161
|
-
* - http://gitea.local:3000
|
|
162
|
-
* - https://gitea.company.com
|
|
163
|
-
*/
|
|
164
|
-
getGiteaUrl(): string | undefined;
|
|
165
|
-
/**
|
|
166
|
-
* Obtém o token de autenticação
|
|
167
|
-
*
|
|
168
|
-
* SEGURANÇA:
|
|
169
|
-
* - Token deve ser mantido seguro
|
|
170
|
-
* - Não logar em produção
|
|
171
|
-
* - Rotacionar periodicamente
|
|
172
|
-
*
|
|
173
|
-
* RETORNO:
|
|
174
|
-
* - Token de acesso pessoal
|
|
175
|
-
*/
|
|
176
|
-
getGiteaToken(): string | undefined;
|
|
177
|
-
/**
|
|
178
|
-
* Obtém o nome de usuário configurado
|
|
179
|
-
*
|
|
180
|
-
* RETORNO:
|
|
181
|
-
* - Nome de usuário ou undefined
|
|
182
|
-
*
|
|
183
|
-
* USO:
|
|
184
|
-
* - Para operações específicas do usuário
|
|
185
|
-
* - Para identificação em logs
|
|
186
|
-
*/
|
|
187
|
-
getGiteaUsername(): string | undefined;
|
|
188
|
-
/**
|
|
189
|
-
* Verifica se o modo debug está ativo
|
|
190
|
-
*
|
|
191
|
-
* RETORNO:
|
|
192
|
-
* - true se debug ativo, false caso contrário
|
|
193
|
-
*
|
|
194
|
-
* RECOMENDAÇÕES:
|
|
195
|
-
* - Use apenas em desenvolvimento
|
|
196
|
-
* - Desative em produção
|
|
197
|
-
* - Configure via DEBUG=true
|
|
198
|
-
*/
|
|
199
|
-
isDebug(): boolean;
|
|
200
|
-
/**
|
|
201
|
-
* Obtém o timeout das requisições HTTP
|
|
202
|
-
*
|
|
203
|
-
* RETORNO:
|
|
204
|
-
* - Timeout em milissegundos
|
|
205
|
-
*
|
|
206
|
-
* RECOMENDAÇÕES:
|
|
207
|
-
* - 30000ms para redes locais
|
|
208
|
-
* - 60000ms para redes com latência
|
|
209
|
-
* - Configure via TIMEOUT=60000
|
|
210
|
-
*/
|
|
211
|
-
getTimeout(): number;
|
|
212
|
-
/**
|
|
213
|
-
* Obtém o tipo de provider configurado
|
|
214
|
-
*
|
|
215
|
-
* RETORNO:
|
|
216
|
-
* - Tipo do provider ('gitea' ou 'github')
|
|
217
|
-
*/
|
|
218
|
-
getProvider(): 'gitea' | 'github' | undefined;
|
|
219
|
-
/**
|
|
220
|
-
* Obtém a URL da API genérica
|
|
221
|
-
*
|
|
222
|
-
* RETORNO:
|
|
223
|
-
* - URL da API ou undefined
|
|
224
|
-
*/
|
|
225
|
-
getApiUrl(): string | undefined;
|
|
226
|
-
/**
|
|
227
|
-
* Obtém o token da API genérica
|
|
228
|
-
*
|
|
229
|
-
* RETORNO:
|
|
230
|
-
* - Token da API ou undefined
|
|
231
|
-
*/
|
|
232
|
-
getApiToken(): string | undefined;
|
|
233
|
-
/**
|
|
234
|
-
* Obtém o token do GitHub
|
|
235
|
-
*
|
|
236
|
-
* RETORNO:
|
|
237
|
-
* - Token do GitHub ou undefined
|
|
238
|
-
*/
|
|
239
|
-
getGitHubToken(): string | undefined;
|
|
240
|
-
/**
|
|
241
|
-
* Obtém o nome de usuário do GitHub
|
|
242
|
-
*
|
|
243
|
-
* RETORNO:
|
|
244
|
-
* - Nome de usuário do GitHub ou undefined
|
|
245
|
-
*/
|
|
246
|
-
getGitHubUsername(): string | undefined;
|
|
247
|
-
/**
|
|
248
|
-
* Obtém o provider padrão configurado
|
|
249
|
-
*
|
|
250
|
-
* RETORNO:
|
|
251
|
-
* - Nome do provider padrão ou undefined
|
|
252
|
-
*/
|
|
253
|
-
getDefaultProvider(): string | undefined;
|
|
254
|
-
/**
|
|
255
|
-
* Obtém a configuração multi-provider
|
|
256
|
-
*
|
|
257
|
-
* RETORNO:
|
|
258
|
-
* - Configuração multi-provider parseada ou undefined
|
|
259
|
-
*/
|
|
260
|
-
getProvidersJson(): MultiProviderConfig | undefined;
|
|
261
|
-
/**
|
|
262
|
-
* Verifica se está usando configuração multi-provider
|
|
263
|
-
*
|
|
264
|
-
* RETORNO:
|
|
265
|
-
* - true se usando multi-provider, false caso contrário
|
|
266
|
-
*/
|
|
267
|
-
isMultiProvider(): boolean;
|
|
268
|
-
/**
|
|
269
|
-
* Verifica se está usando configuração genérica
|
|
270
|
-
*
|
|
271
|
-
* RETORNO:
|
|
272
|
-
* - true se usando configuração genérica, false caso contrário
|
|
273
|
-
*/
|
|
274
|
-
isGenericConfig(): boolean;
|
|
275
|
-
/**
|
|
276
|
-
* Verifica se está usando configuração legacy do Gitea
|
|
277
|
-
*
|
|
278
|
-
* RETORNO:
|
|
279
|
-
* - true se usando configuração legacy, false caso contrário
|
|
280
|
-
*/
|
|
281
|
-
isLegacyGitea(): boolean;
|
|
282
|
-
/**
|
|
283
|
-
* Verifica se está em modo demo
|
|
284
|
-
*
|
|
285
|
-
* RETORNO:
|
|
286
|
-
* - true se em modo demo, false caso contrário
|
|
287
|
-
*/
|
|
288
|
-
isDemoMode(): boolean;
|
|
289
|
-
/**
|
|
290
|
-
* Obtém configuração demo para testes
|
|
291
|
-
*
|
|
292
|
-
* RETORNO:
|
|
293
|
-
* - Configuração mock para modo demo
|
|
294
|
-
*/
|
|
295
|
-
getDemoConfig(): MultiProviderConfig;
|
|
296
|
-
}
|
|
297
|
-
/**
|
|
298
|
-
* Instância global do ConfigManager
|
|
299
|
-
*
|
|
300
|
-
* USO DIRETO:
|
|
301
|
-
* - import { config } from './config.js';
|
|
302
|
-
* - const url = config.getGiteaUrl();
|
|
303
|
-
*
|
|
304
|
-
* RECOMENDAÇÕES:
|
|
305
|
-
* - Use esta instância para acesso direto
|
|
306
|
-
* - Não crie novas instâncias
|
|
307
|
-
* - Configure antes de usar
|
|
308
|
-
*/
|
|
309
|
-
export declare const config: ConfigManager;
|
|
310
|
-
export {};
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
/**
|
|
3
|
+
* Schema de validação para configuração do servidor MCP Gitea
|
|
4
|
+
*
|
|
5
|
+
* VALIDAÇÕES:
|
|
6
|
+
* - giteaUrl: Deve ser uma URL válida
|
|
7
|
+
* - giteaToken: Deve ter pelo menos 1 caractere
|
|
8
|
+
* - giteaUsername: Opcional
|
|
9
|
+
* - debug: Padrão false
|
|
10
|
+
* - timeout: Deve ser positivo, padrão 30000ms
|
|
11
|
+
*
|
|
12
|
+
* RECOMENDAÇÕES:
|
|
13
|
+
* - Use HTTPS para produção
|
|
14
|
+
* - Token deve ter permissões adequadas
|
|
15
|
+
* - Timeout deve considerar latência da rede
|
|
16
|
+
*/
|
|
17
|
+
declare const ConfigSchema: z.ZodEffects<z.ZodObject<{
|
|
18
|
+
giteaUrl: z.ZodOptional<z.ZodString>;
|
|
19
|
+
giteaToken: z.ZodOptional<z.ZodString>;
|
|
20
|
+
giteaUsername: z.ZodOptional<z.ZodString>;
|
|
21
|
+
githubToken: z.ZodOptional<z.ZodString>;
|
|
22
|
+
githubUsername: z.ZodOptional<z.ZodString>;
|
|
23
|
+
provider: z.ZodOptional<z.ZodEnum<["gitea", "github"]>>;
|
|
24
|
+
apiUrl: z.ZodOptional<z.ZodString>;
|
|
25
|
+
apiToken: z.ZodOptional<z.ZodString>;
|
|
26
|
+
defaultProvider: z.ZodOptional<z.ZodString>;
|
|
27
|
+
providersJson: z.ZodEffects<z.ZodOptional<z.ZodString>, any, string | undefined>;
|
|
28
|
+
debug: z.ZodDefault<z.ZodBoolean>;
|
|
29
|
+
timeout: z.ZodDefault<z.ZodNumber>;
|
|
30
|
+
}, "strip", z.ZodTypeAny, {
|
|
31
|
+
debug: boolean;
|
|
32
|
+
timeout: number;
|
|
33
|
+
giteaUrl?: string | undefined;
|
|
34
|
+
giteaToken?: string | undefined;
|
|
35
|
+
giteaUsername?: string | undefined;
|
|
36
|
+
githubToken?: string | undefined;
|
|
37
|
+
githubUsername?: string | undefined;
|
|
38
|
+
provider?: "gitea" | "github" | undefined;
|
|
39
|
+
apiUrl?: string | undefined;
|
|
40
|
+
apiToken?: string | undefined;
|
|
41
|
+
defaultProvider?: string | undefined;
|
|
42
|
+
providersJson?: any;
|
|
43
|
+
}, {
|
|
44
|
+
giteaUrl?: string | undefined;
|
|
45
|
+
giteaToken?: string | undefined;
|
|
46
|
+
giteaUsername?: string | undefined;
|
|
47
|
+
githubToken?: string | undefined;
|
|
48
|
+
githubUsername?: string | undefined;
|
|
49
|
+
provider?: "gitea" | "github" | undefined;
|
|
50
|
+
apiUrl?: string | undefined;
|
|
51
|
+
apiToken?: string | undefined;
|
|
52
|
+
defaultProvider?: string | undefined;
|
|
53
|
+
providersJson?: string | undefined;
|
|
54
|
+
debug?: boolean | undefined;
|
|
55
|
+
timeout?: number | undefined;
|
|
56
|
+
}>, {
|
|
57
|
+
debug: boolean;
|
|
58
|
+
timeout: number;
|
|
59
|
+
giteaUrl?: string | undefined;
|
|
60
|
+
giteaToken?: string | undefined;
|
|
61
|
+
giteaUsername?: string | undefined;
|
|
62
|
+
githubToken?: string | undefined;
|
|
63
|
+
githubUsername?: string | undefined;
|
|
64
|
+
provider?: "gitea" | "github" | undefined;
|
|
65
|
+
apiUrl?: string | undefined;
|
|
66
|
+
apiToken?: string | undefined;
|
|
67
|
+
defaultProvider?: string | undefined;
|
|
68
|
+
providersJson?: any;
|
|
69
|
+
}, {
|
|
70
|
+
giteaUrl?: string | undefined;
|
|
71
|
+
giteaToken?: string | undefined;
|
|
72
|
+
giteaUsername?: string | undefined;
|
|
73
|
+
githubToken?: string | undefined;
|
|
74
|
+
githubUsername?: string | undefined;
|
|
75
|
+
provider?: "gitea" | "github" | undefined;
|
|
76
|
+
apiUrl?: string | undefined;
|
|
77
|
+
apiToken?: string | undefined;
|
|
78
|
+
defaultProvider?: string | undefined;
|
|
79
|
+
providersJson?: string | undefined;
|
|
80
|
+
debug?: boolean | undefined;
|
|
81
|
+
timeout?: number | undefined;
|
|
82
|
+
}>;
|
|
83
|
+
export type Config = z.infer<typeof ConfigSchema>;
|
|
84
|
+
export interface ProviderConfig {
|
|
85
|
+
name: string;
|
|
86
|
+
type: 'gitea' | 'github';
|
|
87
|
+
apiUrl: string;
|
|
88
|
+
token: string;
|
|
89
|
+
username?: string;
|
|
90
|
+
}
|
|
91
|
+
export interface MultiProviderConfig {
|
|
92
|
+
defaultProvider: string;
|
|
93
|
+
providers: ProviderConfig[];
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Gerenciador de configuração usando padrão Singleton
|
|
97
|
+
*
|
|
98
|
+
* RESPONSABILIDADES:
|
|
99
|
+
* - Carregar configuração do ambiente
|
|
100
|
+
* - Validar parâmetros obrigatórios
|
|
101
|
+
* - Fornecer acesso centralizado à configuração
|
|
102
|
+
*
|
|
103
|
+
* USO:
|
|
104
|
+
* - const config = ConfigManager.getInstance();
|
|
105
|
+
* - const url = config.getGiteaUrl();
|
|
106
|
+
*
|
|
107
|
+
* RECOMENDAÇÕES:
|
|
108
|
+
* - Sempre use getInstance() para acessar
|
|
109
|
+
* - Configure variáveis de ambiente adequadamente
|
|
110
|
+
* - Valide configuração antes de usar
|
|
111
|
+
*/
|
|
112
|
+
export declare class ConfigManager {
|
|
113
|
+
private static instance;
|
|
114
|
+
private config;
|
|
115
|
+
private constructor();
|
|
116
|
+
/**
|
|
117
|
+
* Obtém a instância única do ConfigManager
|
|
118
|
+
*
|
|
119
|
+
* IMPLEMENTAÇÃO:
|
|
120
|
+
* - Singleton pattern para configuração global
|
|
121
|
+
* - Thread-safe para aplicações concorrentes
|
|
122
|
+
*
|
|
123
|
+
* RETORNO:
|
|
124
|
+
* - Instância única do ConfigManager
|
|
125
|
+
*/
|
|
126
|
+
static getInstance(): ConfigManager;
|
|
127
|
+
/**
|
|
128
|
+
* Carrega e valida a configuração do ambiente
|
|
129
|
+
*
|
|
130
|
+
* FONTES DE CONFIGURAÇÃO:
|
|
131
|
+
* - Variáveis de ambiente (prioridade alta)
|
|
132
|
+
* - Valores padrão (fallback)
|
|
133
|
+
*
|
|
134
|
+
* VALIDAÇÃO:
|
|
135
|
+
* - Schema Zod para validação rigorosa
|
|
136
|
+
* - Mensagens de erro descritivas
|
|
137
|
+
*
|
|
138
|
+
* ERROS:
|
|
139
|
+
* - Configuração inválida gera exceção
|
|
140
|
+
* - Token obrigatório deve ser fornecido
|
|
141
|
+
*/
|
|
142
|
+
private loadConfig;
|
|
143
|
+
/**
|
|
144
|
+
* Obtém a configuração completa validada
|
|
145
|
+
*
|
|
146
|
+
* RETORNO:
|
|
147
|
+
* - Objeto Config com todos os parâmetros
|
|
148
|
+
*
|
|
149
|
+
* USO:
|
|
150
|
+
* - Para acesso direto à configuração
|
|
151
|
+
* - Para validação de parâmetros
|
|
152
|
+
*/
|
|
153
|
+
getConfig(): Config;
|
|
154
|
+
/**
|
|
155
|
+
* Obtém a URL base do Gitea
|
|
156
|
+
*
|
|
157
|
+
* RETORNO:
|
|
158
|
+
* - URL completa do servidor Gitea
|
|
159
|
+
*
|
|
160
|
+
* EXEMPLO:
|
|
161
|
+
* - http://gitea.local:3000
|
|
162
|
+
* - https://gitea.company.com
|
|
163
|
+
*/
|
|
164
|
+
getGiteaUrl(): string | undefined;
|
|
165
|
+
/**
|
|
166
|
+
* Obtém o token de autenticação
|
|
167
|
+
*
|
|
168
|
+
* SEGURANÇA:
|
|
169
|
+
* - Token deve ser mantido seguro
|
|
170
|
+
* - Não logar em produção
|
|
171
|
+
* - Rotacionar periodicamente
|
|
172
|
+
*
|
|
173
|
+
* RETORNO:
|
|
174
|
+
* - Token de acesso pessoal
|
|
175
|
+
*/
|
|
176
|
+
getGiteaToken(): string | undefined;
|
|
177
|
+
/**
|
|
178
|
+
* Obtém o nome de usuário configurado
|
|
179
|
+
*
|
|
180
|
+
* RETORNO:
|
|
181
|
+
* - Nome de usuário ou undefined
|
|
182
|
+
*
|
|
183
|
+
* USO:
|
|
184
|
+
* - Para operações específicas do usuário
|
|
185
|
+
* - Para identificação em logs
|
|
186
|
+
*/
|
|
187
|
+
getGiteaUsername(): string | undefined;
|
|
188
|
+
/**
|
|
189
|
+
* Verifica se o modo debug está ativo
|
|
190
|
+
*
|
|
191
|
+
* RETORNO:
|
|
192
|
+
* - true se debug ativo, false caso contrário
|
|
193
|
+
*
|
|
194
|
+
* RECOMENDAÇÕES:
|
|
195
|
+
* - Use apenas em desenvolvimento
|
|
196
|
+
* - Desative em produção
|
|
197
|
+
* - Configure via DEBUG=true
|
|
198
|
+
*/
|
|
199
|
+
isDebug(): boolean;
|
|
200
|
+
/**
|
|
201
|
+
* Obtém o timeout das requisições HTTP
|
|
202
|
+
*
|
|
203
|
+
* RETORNO:
|
|
204
|
+
* - Timeout em milissegundos
|
|
205
|
+
*
|
|
206
|
+
* RECOMENDAÇÕES:
|
|
207
|
+
* - 30000ms para redes locais
|
|
208
|
+
* - 60000ms para redes com latência
|
|
209
|
+
* - Configure via TIMEOUT=60000
|
|
210
|
+
*/
|
|
211
|
+
getTimeout(): number;
|
|
212
|
+
/**
|
|
213
|
+
* Obtém o tipo de provider configurado
|
|
214
|
+
*
|
|
215
|
+
* RETORNO:
|
|
216
|
+
* - Tipo do provider ('gitea' ou 'github')
|
|
217
|
+
*/
|
|
218
|
+
getProvider(): 'gitea' | 'github' | undefined;
|
|
219
|
+
/**
|
|
220
|
+
* Obtém a URL da API genérica
|
|
221
|
+
*
|
|
222
|
+
* RETORNO:
|
|
223
|
+
* - URL da API ou undefined
|
|
224
|
+
*/
|
|
225
|
+
getApiUrl(): string | undefined;
|
|
226
|
+
/**
|
|
227
|
+
* Obtém o token da API genérica
|
|
228
|
+
*
|
|
229
|
+
* RETORNO:
|
|
230
|
+
* - Token da API ou undefined
|
|
231
|
+
*/
|
|
232
|
+
getApiToken(): string | undefined;
|
|
233
|
+
/**
|
|
234
|
+
* Obtém o token do GitHub
|
|
235
|
+
*
|
|
236
|
+
* RETORNO:
|
|
237
|
+
* - Token do GitHub ou undefined
|
|
238
|
+
*/
|
|
239
|
+
getGitHubToken(): string | undefined;
|
|
240
|
+
/**
|
|
241
|
+
* Obtém o nome de usuário do GitHub
|
|
242
|
+
*
|
|
243
|
+
* RETORNO:
|
|
244
|
+
* - Nome de usuário do GitHub ou undefined
|
|
245
|
+
*/
|
|
246
|
+
getGitHubUsername(): string | undefined;
|
|
247
|
+
/**
|
|
248
|
+
* Obtém o provider padrão configurado
|
|
249
|
+
*
|
|
250
|
+
* RETORNO:
|
|
251
|
+
* - Nome do provider padrão ou undefined
|
|
252
|
+
*/
|
|
253
|
+
getDefaultProvider(): string | undefined;
|
|
254
|
+
/**
|
|
255
|
+
* Obtém a configuração multi-provider
|
|
256
|
+
*
|
|
257
|
+
* RETORNO:
|
|
258
|
+
* - Configuração multi-provider parseada ou undefined
|
|
259
|
+
*/
|
|
260
|
+
getProvidersJson(): MultiProviderConfig | undefined;
|
|
261
|
+
/**
|
|
262
|
+
* Verifica se está usando configuração multi-provider
|
|
263
|
+
*
|
|
264
|
+
* RETORNO:
|
|
265
|
+
* - true se usando multi-provider, false caso contrário
|
|
266
|
+
*/
|
|
267
|
+
isMultiProvider(): boolean;
|
|
268
|
+
/**
|
|
269
|
+
* Verifica se está usando configuração genérica
|
|
270
|
+
*
|
|
271
|
+
* RETORNO:
|
|
272
|
+
* - true se usando configuração genérica, false caso contrário
|
|
273
|
+
*/
|
|
274
|
+
isGenericConfig(): boolean;
|
|
275
|
+
/**
|
|
276
|
+
* Verifica se está usando configuração legacy do Gitea
|
|
277
|
+
*
|
|
278
|
+
* RETORNO:
|
|
279
|
+
* - true se usando configuração legacy, false caso contrário
|
|
280
|
+
*/
|
|
281
|
+
isLegacyGitea(): boolean;
|
|
282
|
+
/**
|
|
283
|
+
* Verifica se está em modo demo
|
|
284
|
+
*
|
|
285
|
+
* RETORNO:
|
|
286
|
+
* - true se em modo demo, false caso contrário
|
|
287
|
+
*/
|
|
288
|
+
isDemoMode(): boolean;
|
|
289
|
+
/**
|
|
290
|
+
* Obtém configuração demo para testes
|
|
291
|
+
*
|
|
292
|
+
* RETORNO:
|
|
293
|
+
* - Configuração mock para modo demo
|
|
294
|
+
*/
|
|
295
|
+
getDemoConfig(): MultiProviderConfig;
|
|
296
|
+
}
|
|
297
|
+
/**
|
|
298
|
+
* Instância global do ConfigManager
|
|
299
|
+
*
|
|
300
|
+
* USO DIRETO:
|
|
301
|
+
* - import { config } from './config.js';
|
|
302
|
+
* - const url = config.getGiteaUrl();
|
|
303
|
+
*
|
|
304
|
+
* RECOMENDAÇÕES:
|
|
305
|
+
* - Use esta instância para acesso direto
|
|
306
|
+
* - Não crie novas instâncias
|
|
307
|
+
* - Configure antes de usar
|
|
308
|
+
*/
|
|
309
|
+
export declare const config: ConfigManager;
|
|
310
|
+
export {};
|
|
311
311
|
//# sourceMappingURL=config.d.ts.map
|