litellm-proxy-extras 0.1.2__tar.gz → 0.1.5__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.

Potentially problematic release.


This version of litellm-proxy-extras might be problematic. Click here for more details.

Files changed (15) hide show
  1. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/PKG-INFO +3 -2
  2. litellm_proxy_extras-0.1.5/litellm_proxy_extras/migrations/20250408142118_add_team_member_permissions/migration.sql +411 -0
  3. litellm_proxy_extras-0.1.5/litellm_proxy_extras/schema.prisma +357 -0
  4. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/litellm_proxy_extras/utils.py +6 -3
  5. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/pyproject.toml +2 -2
  6. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/LICENSE +0 -0
  7. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/README.md +0 -0
  8. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/litellm_proxy_extras/__init__.py +0 -0
  9. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/litellm_proxy_extras/_logging.py +0 -0
  10. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/litellm_proxy_extras/migrations/20250326162113_baseline/migration.sql +0 -0
  11. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/litellm_proxy_extras/migrations/20250326171002_add_daily_user_table/migration.sql +0 -0
  12. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/litellm_proxy_extras/migrations/20250327180120_add_api_requests_to_daily_user_table/migration.sql +0 -0
  13. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/litellm_proxy_extras/migrations/20250329084805_new_cron_job_table/migration.sql +0 -0
  14. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/litellm_proxy_extras/migrations/20250331215456_track_success_and_failed_requests_daily_agg_table/migration.sql +0 -0
  15. {litellm_proxy_extras-0.1.2 → litellm_proxy_extras-0.1.5}/litellm_proxy_extras/migrations/migration_lock.toml +0 -0
@@ -1,6 +1,6 @@
1
- Metadata-Version: 2.1
1
+ Metadata-Version: 2.3
2
2
  Name: litellm-proxy-extras
3
- Version: 0.1.2
3
+ Version: 0.1.5
4
4
  Summary: Additional files for the LiteLLM Proxy. Reduces the size of the main litellm package.
5
5
  Author: BerriAI
6
6
  Requires-Python: >=3.8, !=2.7.*, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, !=3.5.*, !=3.6.*, !=3.7.*
@@ -9,6 +9,7 @@ Classifier: Programming Language :: Python :: 3.9
9
9
  Classifier: Programming Language :: Python :: 3.10
10
10
  Classifier: Programming Language :: Python :: 3.11
11
11
  Classifier: Programming Language :: Python :: 3.12
12
+ Classifier: Programming Language :: Python :: 3.13
12
13
  Project-URL: Documentation, https://docs.litellm.ai
13
14
  Project-URL: Homepage, https://litellm.ai
14
15
  Project-URL: Repository, https://github.com/BerriAI/litellm
@@ -0,0 +1,411 @@
1
+ -- CreateEnum
2
+ CREATE TYPE "JobStatus" AS ENUM ('ACTIVE', 'INACTIVE');
3
+
4
+ -- CreateTable
5
+ CREATE TABLE "LiteLLM_BudgetTable" (
6
+ "budget_id" TEXT NOT NULL,
7
+ "max_budget" DOUBLE PRECISION,
8
+ "soft_budget" DOUBLE PRECISION,
9
+ "max_parallel_requests" INTEGER,
10
+ "tpm_limit" BIGINT,
11
+ "rpm_limit" BIGINT,
12
+ "model_max_budget" JSONB,
13
+ "budget_duration" TEXT,
14
+ "budget_reset_at" TIMESTAMP(3),
15
+ "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
16
+ "created_by" TEXT NOT NULL,
17
+ "updated_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
18
+ "updated_by" TEXT NOT NULL,
19
+
20
+ CONSTRAINT "LiteLLM_BudgetTable_pkey" PRIMARY KEY ("budget_id")
21
+ );
22
+
23
+ -- CreateTable
24
+ CREATE TABLE "LiteLLM_CredentialsTable" (
25
+ "credential_id" TEXT NOT NULL,
26
+ "credential_name" TEXT NOT NULL,
27
+ "credential_values" JSONB NOT NULL,
28
+ "credential_info" JSONB,
29
+ "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
30
+ "created_by" TEXT NOT NULL,
31
+ "updated_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
32
+ "updated_by" TEXT NOT NULL,
33
+
34
+ CONSTRAINT "LiteLLM_CredentialsTable_pkey" PRIMARY KEY ("credential_id")
35
+ );
36
+
37
+ -- CreateTable
38
+ CREATE TABLE "LiteLLM_ProxyModelTable" (
39
+ "model_id" TEXT NOT NULL,
40
+ "model_name" TEXT NOT NULL,
41
+ "litellm_params" JSONB NOT NULL,
42
+ "model_info" JSONB,
43
+ "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
44
+ "created_by" TEXT NOT NULL,
45
+ "updated_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
46
+ "updated_by" TEXT NOT NULL,
47
+
48
+ CONSTRAINT "LiteLLM_ProxyModelTable_pkey" PRIMARY KEY ("model_id")
49
+ );
50
+
51
+ -- CreateTable
52
+ CREATE TABLE "LiteLLM_OrganizationTable" (
53
+ "organization_id" TEXT NOT NULL,
54
+ "organization_alias" TEXT NOT NULL,
55
+ "budget_id" TEXT NOT NULL,
56
+ "metadata" JSONB NOT NULL DEFAULT '{}',
57
+ "models" TEXT[],
58
+ "spend" DOUBLE PRECISION NOT NULL DEFAULT 0.0,
59
+ "model_spend" JSONB NOT NULL DEFAULT '{}',
60
+ "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
61
+ "created_by" TEXT NOT NULL,
62
+ "updated_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
63
+ "updated_by" TEXT NOT NULL,
64
+
65
+ CONSTRAINT "LiteLLM_OrganizationTable_pkey" PRIMARY KEY ("organization_id")
66
+ );
67
+
68
+ -- CreateTable
69
+ CREATE TABLE "LiteLLM_ModelTable" (
70
+ "id" SERIAL NOT NULL,
71
+ "aliases" JSONB,
72
+ "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
73
+ "created_by" TEXT NOT NULL,
74
+ "updated_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
75
+ "updated_by" TEXT NOT NULL,
76
+
77
+ CONSTRAINT "LiteLLM_ModelTable_pkey" PRIMARY KEY ("id")
78
+ );
79
+
80
+ -- CreateTable
81
+ CREATE TABLE "LiteLLM_TeamTable" (
82
+ "team_id" TEXT NOT NULL,
83
+ "team_alias" TEXT,
84
+ "organization_id" TEXT,
85
+ "admins" TEXT[],
86
+ "members" TEXT[],
87
+ "members_with_roles" JSONB NOT NULL DEFAULT '{}',
88
+ "metadata" JSONB NOT NULL DEFAULT '{}',
89
+ "max_budget" DOUBLE PRECISION,
90
+ "spend" DOUBLE PRECISION NOT NULL DEFAULT 0.0,
91
+ "models" TEXT[],
92
+ "max_parallel_requests" INTEGER,
93
+ "tpm_limit" BIGINT,
94
+ "rpm_limit" BIGINT,
95
+ "budget_duration" TEXT,
96
+ "budget_reset_at" TIMESTAMP(3),
97
+ "blocked" BOOLEAN NOT NULL DEFAULT false,
98
+ "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
99
+ "updated_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
100
+ "model_spend" JSONB NOT NULL DEFAULT '{}',
101
+ "model_max_budget" JSONB NOT NULL DEFAULT '{}',
102
+ "model_id" INTEGER,
103
+ "team_member_permissions" TEXT[] DEFAULT ARRAY[]::TEXT[],
104
+
105
+ CONSTRAINT "LiteLLM_TeamTable_pkey" PRIMARY KEY ("team_id")
106
+ );
107
+
108
+ -- CreateTable
109
+ CREATE TABLE "LiteLLM_UserTable" (
110
+ "user_id" TEXT NOT NULL,
111
+ "user_alias" TEXT,
112
+ "team_id" TEXT,
113
+ "sso_user_id" TEXT,
114
+ "organization_id" TEXT,
115
+ "password" TEXT,
116
+ "teams" TEXT[] DEFAULT ARRAY[]::TEXT[],
117
+ "user_role" TEXT,
118
+ "max_budget" DOUBLE PRECISION,
119
+ "spend" DOUBLE PRECISION NOT NULL DEFAULT 0.0,
120
+ "user_email" TEXT,
121
+ "models" TEXT[],
122
+ "metadata" JSONB NOT NULL DEFAULT '{}',
123
+ "max_parallel_requests" INTEGER,
124
+ "tpm_limit" BIGINT,
125
+ "rpm_limit" BIGINT,
126
+ "budget_duration" TEXT,
127
+ "budget_reset_at" TIMESTAMP(3),
128
+ "allowed_cache_controls" TEXT[] DEFAULT ARRAY[]::TEXT[],
129
+ "model_spend" JSONB NOT NULL DEFAULT '{}',
130
+ "model_max_budget" JSONB NOT NULL DEFAULT '{}',
131
+ "created_at" TIMESTAMP(3) DEFAULT CURRENT_TIMESTAMP,
132
+ "updated_at" TIMESTAMP(3) DEFAULT CURRENT_TIMESTAMP,
133
+
134
+ CONSTRAINT "LiteLLM_UserTable_pkey" PRIMARY KEY ("user_id")
135
+ );
136
+
137
+ -- CreateTable
138
+ CREATE TABLE "LiteLLM_VerificationToken" (
139
+ "token" TEXT NOT NULL,
140
+ "key_name" TEXT,
141
+ "key_alias" TEXT,
142
+ "soft_budget_cooldown" BOOLEAN NOT NULL DEFAULT false,
143
+ "spend" DOUBLE PRECISION NOT NULL DEFAULT 0.0,
144
+ "expires" TIMESTAMP(3),
145
+ "models" TEXT[],
146
+ "aliases" JSONB NOT NULL DEFAULT '{}',
147
+ "config" JSONB NOT NULL DEFAULT '{}',
148
+ "user_id" TEXT,
149
+ "team_id" TEXT,
150
+ "permissions" JSONB NOT NULL DEFAULT '{}',
151
+ "max_parallel_requests" INTEGER,
152
+ "metadata" JSONB NOT NULL DEFAULT '{}',
153
+ "blocked" BOOLEAN,
154
+ "tpm_limit" BIGINT,
155
+ "rpm_limit" BIGINT,
156
+ "max_budget" DOUBLE PRECISION,
157
+ "budget_duration" TEXT,
158
+ "budget_reset_at" TIMESTAMP(3),
159
+ "allowed_cache_controls" TEXT[] DEFAULT ARRAY[]::TEXT[],
160
+ "model_spend" JSONB NOT NULL DEFAULT '{}',
161
+ "model_max_budget" JSONB NOT NULL DEFAULT '{}',
162
+ "budget_id" TEXT,
163
+ "organization_id" TEXT,
164
+ "created_at" TIMESTAMP(3) DEFAULT CURRENT_TIMESTAMP,
165
+ "created_by" TEXT,
166
+ "updated_at" TIMESTAMP(3) DEFAULT CURRENT_TIMESTAMP,
167
+ "updated_by" TEXT,
168
+
169
+ CONSTRAINT "LiteLLM_VerificationToken_pkey" PRIMARY KEY ("token")
170
+ );
171
+
172
+ -- CreateTable
173
+ CREATE TABLE "LiteLLM_EndUserTable" (
174
+ "user_id" TEXT NOT NULL,
175
+ "alias" TEXT,
176
+ "spend" DOUBLE PRECISION NOT NULL DEFAULT 0.0,
177
+ "allowed_model_region" TEXT,
178
+ "default_model" TEXT,
179
+ "budget_id" TEXT,
180
+ "blocked" BOOLEAN NOT NULL DEFAULT false,
181
+
182
+ CONSTRAINT "LiteLLM_EndUserTable_pkey" PRIMARY KEY ("user_id")
183
+ );
184
+
185
+ -- CreateTable
186
+ CREATE TABLE "LiteLLM_Config" (
187
+ "param_name" TEXT NOT NULL,
188
+ "param_value" JSONB,
189
+
190
+ CONSTRAINT "LiteLLM_Config_pkey" PRIMARY KEY ("param_name")
191
+ );
192
+
193
+ -- CreateTable
194
+ CREATE TABLE "LiteLLM_SpendLogs" (
195
+ "request_id" TEXT NOT NULL,
196
+ "call_type" TEXT NOT NULL,
197
+ "api_key" TEXT NOT NULL DEFAULT '',
198
+ "spend" DOUBLE PRECISION NOT NULL DEFAULT 0.0,
199
+ "total_tokens" INTEGER NOT NULL DEFAULT 0,
200
+ "prompt_tokens" INTEGER NOT NULL DEFAULT 0,
201
+ "completion_tokens" INTEGER NOT NULL DEFAULT 0,
202
+ "startTime" TIMESTAMP(3) NOT NULL,
203
+ "endTime" TIMESTAMP(3) NOT NULL,
204
+ "completionStartTime" TIMESTAMP(3),
205
+ "model" TEXT NOT NULL DEFAULT '',
206
+ "model_id" TEXT DEFAULT '',
207
+ "model_group" TEXT DEFAULT '',
208
+ "custom_llm_provider" TEXT DEFAULT '',
209
+ "api_base" TEXT DEFAULT '',
210
+ "user" TEXT DEFAULT '',
211
+ "metadata" JSONB DEFAULT '{}',
212
+ "cache_hit" TEXT DEFAULT '',
213
+ "cache_key" TEXT DEFAULT '',
214
+ "request_tags" JSONB DEFAULT '[]',
215
+ "team_id" TEXT,
216
+ "end_user" TEXT,
217
+ "requester_ip_address" TEXT,
218
+ "messages" JSONB DEFAULT '{}',
219
+ "response" JSONB DEFAULT '{}',
220
+
221
+ CONSTRAINT "LiteLLM_SpendLogs_pkey" PRIMARY KEY ("request_id")
222
+ );
223
+
224
+ -- CreateTable
225
+ CREATE TABLE "LiteLLM_ErrorLogs" (
226
+ "request_id" TEXT NOT NULL,
227
+ "startTime" TIMESTAMP(3) NOT NULL,
228
+ "endTime" TIMESTAMP(3) NOT NULL,
229
+ "api_base" TEXT NOT NULL DEFAULT '',
230
+ "model_group" TEXT NOT NULL DEFAULT '',
231
+ "litellm_model_name" TEXT NOT NULL DEFAULT '',
232
+ "model_id" TEXT NOT NULL DEFAULT '',
233
+ "request_kwargs" JSONB NOT NULL DEFAULT '{}',
234
+ "exception_type" TEXT NOT NULL DEFAULT '',
235
+ "exception_string" TEXT NOT NULL DEFAULT '',
236
+ "status_code" TEXT NOT NULL DEFAULT '',
237
+
238
+ CONSTRAINT "LiteLLM_ErrorLogs_pkey" PRIMARY KEY ("request_id")
239
+ );
240
+
241
+ -- CreateTable
242
+ CREATE TABLE "LiteLLM_UserNotifications" (
243
+ "request_id" TEXT NOT NULL,
244
+ "user_id" TEXT NOT NULL,
245
+ "models" TEXT[],
246
+ "justification" TEXT NOT NULL,
247
+ "status" TEXT NOT NULL,
248
+
249
+ CONSTRAINT "LiteLLM_UserNotifications_pkey" PRIMARY KEY ("request_id")
250
+ );
251
+
252
+ -- CreateTable
253
+ CREATE TABLE "LiteLLM_TeamMembership" (
254
+ "user_id" TEXT NOT NULL,
255
+ "team_id" TEXT NOT NULL,
256
+ "spend" DOUBLE PRECISION NOT NULL DEFAULT 0.0,
257
+ "budget_id" TEXT,
258
+
259
+ CONSTRAINT "LiteLLM_TeamMembership_pkey" PRIMARY KEY ("user_id","team_id")
260
+ );
261
+
262
+ -- CreateTable
263
+ CREATE TABLE "LiteLLM_OrganizationMembership" (
264
+ "user_id" TEXT NOT NULL,
265
+ "organization_id" TEXT NOT NULL,
266
+ "user_role" TEXT,
267
+ "spend" DOUBLE PRECISION DEFAULT 0.0,
268
+ "budget_id" TEXT,
269
+ "created_at" TIMESTAMP(3) DEFAULT CURRENT_TIMESTAMP,
270
+ "updated_at" TIMESTAMP(3) DEFAULT CURRENT_TIMESTAMP,
271
+
272
+ CONSTRAINT "LiteLLM_OrganizationMembership_pkey" PRIMARY KEY ("user_id","organization_id")
273
+ );
274
+
275
+ -- CreateTable
276
+ CREATE TABLE "LiteLLM_InvitationLink" (
277
+ "id" TEXT NOT NULL,
278
+ "user_id" TEXT NOT NULL,
279
+ "is_accepted" BOOLEAN NOT NULL DEFAULT false,
280
+ "accepted_at" TIMESTAMP(3),
281
+ "expires_at" TIMESTAMP(3) NOT NULL,
282
+ "created_at" TIMESTAMP(3) NOT NULL,
283
+ "created_by" TEXT NOT NULL,
284
+ "updated_at" TIMESTAMP(3) NOT NULL,
285
+ "updated_by" TEXT NOT NULL,
286
+
287
+ CONSTRAINT "LiteLLM_InvitationLink_pkey" PRIMARY KEY ("id")
288
+ );
289
+
290
+ -- CreateTable
291
+ CREATE TABLE "LiteLLM_AuditLog" (
292
+ "id" TEXT NOT NULL,
293
+ "updated_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
294
+ "changed_by" TEXT NOT NULL DEFAULT '',
295
+ "changed_by_api_key" TEXT NOT NULL DEFAULT '',
296
+ "action" TEXT NOT NULL,
297
+ "table_name" TEXT NOT NULL,
298
+ "object_id" TEXT NOT NULL,
299
+ "before_value" JSONB,
300
+ "updated_values" JSONB,
301
+
302
+ CONSTRAINT "LiteLLM_AuditLog_pkey" PRIMARY KEY ("id")
303
+ );
304
+
305
+ -- CreateTable
306
+ CREATE TABLE "LiteLLM_DailyUserSpend" (
307
+ "id" TEXT NOT NULL,
308
+ "user_id" TEXT NOT NULL,
309
+ "date" TEXT NOT NULL,
310
+ "api_key" TEXT NOT NULL,
311
+ "model" TEXT NOT NULL,
312
+ "model_group" TEXT,
313
+ "custom_llm_provider" TEXT,
314
+ "prompt_tokens" INTEGER NOT NULL DEFAULT 0,
315
+ "completion_tokens" INTEGER NOT NULL DEFAULT 0,
316
+ "spend" DOUBLE PRECISION NOT NULL DEFAULT 0.0,
317
+ "api_requests" INTEGER NOT NULL DEFAULT 0,
318
+ "successful_requests" INTEGER NOT NULL DEFAULT 0,
319
+ "failed_requests" INTEGER NOT NULL DEFAULT 0,
320
+ "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
321
+ "updated_at" TIMESTAMP(3) NOT NULL,
322
+
323
+ CONSTRAINT "LiteLLM_DailyUserSpend_pkey" PRIMARY KEY ("id")
324
+ );
325
+
326
+ -- CreateTable
327
+ CREATE TABLE "LiteLLM_CronJob" (
328
+ "cronjob_id" TEXT NOT NULL,
329
+ "pod_id" TEXT NOT NULL,
330
+ "status" "JobStatus" NOT NULL DEFAULT 'INACTIVE',
331
+ "last_updated" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
332
+ "ttl" TIMESTAMP(3) NOT NULL,
333
+
334
+ CONSTRAINT "LiteLLM_CronJob_pkey" PRIMARY KEY ("cronjob_id")
335
+ );
336
+
337
+ -- CreateIndex
338
+ CREATE UNIQUE INDEX "LiteLLM_CredentialsTable_credential_name_key" ON "LiteLLM_CredentialsTable"("credential_name");
339
+
340
+ -- CreateIndex
341
+ CREATE UNIQUE INDEX "LiteLLM_TeamTable_model_id_key" ON "LiteLLM_TeamTable"("model_id");
342
+
343
+ -- CreateIndex
344
+ CREATE UNIQUE INDEX "LiteLLM_UserTable_sso_user_id_key" ON "LiteLLM_UserTable"("sso_user_id");
345
+
346
+ -- CreateIndex
347
+ CREATE INDEX "LiteLLM_SpendLogs_startTime_idx" ON "LiteLLM_SpendLogs"("startTime");
348
+
349
+ -- CreateIndex
350
+ CREATE INDEX "LiteLLM_SpendLogs_end_user_idx" ON "LiteLLM_SpendLogs"("end_user");
351
+
352
+ -- CreateIndex
353
+ CREATE UNIQUE INDEX "LiteLLM_OrganizationMembership_user_id_organization_id_key" ON "LiteLLM_OrganizationMembership"("user_id", "organization_id");
354
+
355
+ -- CreateIndex
356
+ CREATE INDEX "LiteLLM_DailyUserSpend_date_idx" ON "LiteLLM_DailyUserSpend"("date");
357
+
358
+ -- CreateIndex
359
+ CREATE INDEX "LiteLLM_DailyUserSpend_user_id_idx" ON "LiteLLM_DailyUserSpend"("user_id");
360
+
361
+ -- CreateIndex
362
+ CREATE INDEX "LiteLLM_DailyUserSpend_api_key_idx" ON "LiteLLM_DailyUserSpend"("api_key");
363
+
364
+ -- CreateIndex
365
+ CREATE INDEX "LiteLLM_DailyUserSpend_model_idx" ON "LiteLLM_DailyUserSpend"("model");
366
+
367
+ -- CreateIndex
368
+ CREATE UNIQUE INDEX "LiteLLM_DailyUserSpend_user_id_date_api_key_model_custom_ll_key" ON "LiteLLM_DailyUserSpend"("user_id", "date", "api_key", "model", "custom_llm_provider");
369
+
370
+ -- AddForeignKey
371
+ ALTER TABLE "LiteLLM_OrganizationTable" ADD CONSTRAINT "LiteLLM_OrganizationTable_budget_id_fkey" FOREIGN KEY ("budget_id") REFERENCES "LiteLLM_BudgetTable"("budget_id") ON DELETE RESTRICT ON UPDATE CASCADE;
372
+
373
+ -- AddForeignKey
374
+ ALTER TABLE "LiteLLM_TeamTable" ADD CONSTRAINT "LiteLLM_TeamTable_organization_id_fkey" FOREIGN KEY ("organization_id") REFERENCES "LiteLLM_OrganizationTable"("organization_id") ON DELETE SET NULL ON UPDATE CASCADE;
375
+
376
+ -- AddForeignKey
377
+ ALTER TABLE "LiteLLM_TeamTable" ADD CONSTRAINT "LiteLLM_TeamTable_model_id_fkey" FOREIGN KEY ("model_id") REFERENCES "LiteLLM_ModelTable"("id") ON DELETE SET NULL ON UPDATE CASCADE;
378
+
379
+ -- AddForeignKey
380
+ ALTER TABLE "LiteLLM_UserTable" ADD CONSTRAINT "LiteLLM_UserTable_organization_id_fkey" FOREIGN KEY ("organization_id") REFERENCES "LiteLLM_OrganizationTable"("organization_id") ON DELETE SET NULL ON UPDATE CASCADE;
381
+
382
+ -- AddForeignKey
383
+ ALTER TABLE "LiteLLM_VerificationToken" ADD CONSTRAINT "LiteLLM_VerificationToken_budget_id_fkey" FOREIGN KEY ("budget_id") REFERENCES "LiteLLM_BudgetTable"("budget_id") ON DELETE SET NULL ON UPDATE CASCADE;
384
+
385
+ -- AddForeignKey
386
+ ALTER TABLE "LiteLLM_VerificationToken" ADD CONSTRAINT "LiteLLM_VerificationToken_organization_id_fkey" FOREIGN KEY ("organization_id") REFERENCES "LiteLLM_OrganizationTable"("organization_id") ON DELETE SET NULL ON UPDATE CASCADE;
387
+
388
+ -- AddForeignKey
389
+ ALTER TABLE "LiteLLM_EndUserTable" ADD CONSTRAINT "LiteLLM_EndUserTable_budget_id_fkey" FOREIGN KEY ("budget_id") REFERENCES "LiteLLM_BudgetTable"("budget_id") ON DELETE SET NULL ON UPDATE CASCADE;
390
+
391
+ -- AddForeignKey
392
+ ALTER TABLE "LiteLLM_TeamMembership" ADD CONSTRAINT "LiteLLM_TeamMembership_budget_id_fkey" FOREIGN KEY ("budget_id") REFERENCES "LiteLLM_BudgetTable"("budget_id") ON DELETE SET NULL ON UPDATE CASCADE;
393
+
394
+ -- AddForeignKey
395
+ ALTER TABLE "LiteLLM_OrganizationMembership" ADD CONSTRAINT "LiteLLM_OrganizationMembership_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "LiteLLM_UserTable"("user_id") ON DELETE RESTRICT ON UPDATE CASCADE;
396
+
397
+ -- AddForeignKey
398
+ ALTER TABLE "LiteLLM_OrganizationMembership" ADD CONSTRAINT "LiteLLM_OrganizationMembership_organization_id_fkey" FOREIGN KEY ("organization_id") REFERENCES "LiteLLM_OrganizationTable"("organization_id") ON DELETE RESTRICT ON UPDATE CASCADE;
399
+
400
+ -- AddForeignKey
401
+ ALTER TABLE "LiteLLM_OrganizationMembership" ADD CONSTRAINT "LiteLLM_OrganizationMembership_budget_id_fkey" FOREIGN KEY ("budget_id") REFERENCES "LiteLLM_BudgetTable"("budget_id") ON DELETE SET NULL ON UPDATE CASCADE;
402
+
403
+ -- AddForeignKey
404
+ ALTER TABLE "LiteLLM_InvitationLink" ADD CONSTRAINT "LiteLLM_InvitationLink_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "LiteLLM_UserTable"("user_id") ON DELETE RESTRICT ON UPDATE CASCADE;
405
+
406
+ -- AddForeignKey
407
+ ALTER TABLE "LiteLLM_InvitationLink" ADD CONSTRAINT "LiteLLM_InvitationLink_created_by_fkey" FOREIGN KEY ("created_by") REFERENCES "LiteLLM_UserTable"("user_id") ON DELETE RESTRICT ON UPDATE CASCADE;
408
+
409
+ -- AddForeignKey
410
+ ALTER TABLE "LiteLLM_InvitationLink" ADD CONSTRAINT "LiteLLM_InvitationLink_updated_by_fkey" FOREIGN KEY ("updated_by") REFERENCES "LiteLLM_UserTable"("user_id") ON DELETE RESTRICT ON UPDATE CASCADE;
411
+
@@ -0,0 +1,357 @@
1
+ datasource client {
2
+ provider = "postgresql"
3
+ url = env("DATABASE_URL")
4
+ }
5
+
6
+ generator client {
7
+ provider = "prisma-client-py"
8
+ }
9
+
10
+ // Budget / Rate Limits for an org
11
+ model LiteLLM_BudgetTable {
12
+ budget_id String @id @default(uuid())
13
+ max_budget Float?
14
+ soft_budget Float?
15
+ max_parallel_requests Int?
16
+ tpm_limit BigInt?
17
+ rpm_limit BigInt?
18
+ model_max_budget Json?
19
+ budget_duration String?
20
+ budget_reset_at DateTime?
21
+ created_at DateTime @default(now()) @map("created_at")
22
+ created_by String
23
+ updated_at DateTime @default(now()) @updatedAt @map("updated_at")
24
+ updated_by String
25
+ organization LiteLLM_OrganizationTable[] // multiple orgs can have the same budget
26
+ keys LiteLLM_VerificationToken[] // multiple keys can have the same budget
27
+ end_users LiteLLM_EndUserTable[] // multiple end-users can have the same budget
28
+ team_membership LiteLLM_TeamMembership[] // budgets of Users within a Team
29
+ organization_membership LiteLLM_OrganizationMembership[] // budgets of Users within a Organization
30
+ }
31
+
32
+ // Models on proxy
33
+ model LiteLLM_CredentialsTable {
34
+ credential_id String @id @default(uuid())
35
+ credential_name String @unique
36
+ credential_values Json
37
+ credential_info Json?
38
+ created_at DateTime @default(now()) @map("created_at")
39
+ created_by String
40
+ updated_at DateTime @default(now()) @updatedAt @map("updated_at")
41
+ updated_by String
42
+ }
43
+
44
+ // Models on proxy
45
+ model LiteLLM_ProxyModelTable {
46
+ model_id String @id @default(uuid())
47
+ model_name String
48
+ litellm_params Json
49
+ model_info Json?
50
+ created_at DateTime @default(now()) @map("created_at")
51
+ created_by String
52
+ updated_at DateTime @default(now()) @updatedAt @map("updated_at")
53
+ updated_by String
54
+ }
55
+
56
+ model LiteLLM_OrganizationTable {
57
+ organization_id String @id @default(uuid())
58
+ organization_alias String
59
+ budget_id String
60
+ metadata Json @default("{}")
61
+ models String[]
62
+ spend Float @default(0.0)
63
+ model_spend Json @default("{}")
64
+ created_at DateTime @default(now()) @map("created_at")
65
+ created_by String
66
+ updated_at DateTime @default(now()) @updatedAt @map("updated_at")
67
+ updated_by String
68
+ litellm_budget_table LiteLLM_BudgetTable? @relation(fields: [budget_id], references: [budget_id])
69
+ teams LiteLLM_TeamTable[]
70
+ users LiteLLM_UserTable[]
71
+ keys LiteLLM_VerificationToken[]
72
+ members LiteLLM_OrganizationMembership[] @relation("OrganizationToMembership")
73
+ }
74
+
75
+ // Model info for teams, just has model aliases for now.
76
+ model LiteLLM_ModelTable {
77
+ id Int @id @default(autoincrement())
78
+ model_aliases Json? @map("aliases")
79
+ created_at DateTime @default(now()) @map("created_at")
80
+ created_by String
81
+ updated_at DateTime @default(now()) @updatedAt @map("updated_at")
82
+ updated_by String
83
+ team LiteLLM_TeamTable?
84
+ }
85
+
86
+
87
+ // Assign prod keys to groups, not individuals
88
+ model LiteLLM_TeamTable {
89
+ team_id String @id @default(uuid())
90
+ team_alias String?
91
+ organization_id String?
92
+ admins String[]
93
+ members String[]
94
+ members_with_roles Json @default("{}")
95
+ metadata Json @default("{}")
96
+ max_budget Float?
97
+ spend Float @default(0.0)
98
+ models String[]
99
+ max_parallel_requests Int?
100
+ tpm_limit BigInt?
101
+ rpm_limit BigInt?
102
+ budget_duration String?
103
+ budget_reset_at DateTime?
104
+ blocked Boolean @default(false)
105
+ created_at DateTime @default(now()) @map("created_at")
106
+ updated_at DateTime @default(now()) @updatedAt @map("updated_at")
107
+ model_spend Json @default("{}")
108
+ model_max_budget Json @default("{}")
109
+ model_id Int? @unique // id for LiteLLM_ModelTable -> stores team-level model aliases
110
+ team_member_permissions String[]@default([])
111
+ litellm_organization_table LiteLLM_OrganizationTable? @relation(fields: [organization_id], references: [organization_id])
112
+ litellm_model_table LiteLLM_ModelTable? @relation(fields: [model_id], references: [id])
113
+ }
114
+
115
+ // Track spend, rate limit, budget Users
116
+ model LiteLLM_UserTable {
117
+ user_id String @id
118
+ user_alias String?
119
+ team_id String?
120
+ sso_user_id String? @unique
121
+ organization_id String?
122
+ password String?
123
+ teams String[] @default([])
124
+ user_role String?
125
+ max_budget Float?
126
+ spend Float @default(0.0)
127
+ user_email String?
128
+ models String[]
129
+ metadata Json @default("{}")
130
+ max_parallel_requests Int?
131
+ tpm_limit BigInt?
132
+ rpm_limit BigInt?
133
+ budget_duration String?
134
+ budget_reset_at DateTime?
135
+ allowed_cache_controls String[] @default([])
136
+ model_spend Json @default("{}")
137
+ model_max_budget Json @default("{}")
138
+ created_at DateTime? @default(now()) @map("created_at")
139
+ updated_at DateTime? @default(now()) @updatedAt @map("updated_at")
140
+
141
+ // relations
142
+ litellm_organization_table LiteLLM_OrganizationTable? @relation(fields: [organization_id], references: [organization_id])
143
+ organization_memberships LiteLLM_OrganizationMembership[]
144
+ invitations_created LiteLLM_InvitationLink[] @relation("CreatedBy")
145
+ invitations_updated LiteLLM_InvitationLink[] @relation("UpdatedBy")
146
+ invitations_user LiteLLM_InvitationLink[] @relation("UserId")
147
+ }
148
+
149
+ // Generate Tokens for Proxy
150
+ model LiteLLM_VerificationToken {
151
+ token String @id
152
+ key_name String?
153
+ key_alias String?
154
+ soft_budget_cooldown Boolean @default(false) // key-level state on if budget alerts need to be cooled down
155
+ spend Float @default(0.0)
156
+ expires DateTime?
157
+ models String[]
158
+ aliases Json @default("{}")
159
+ config Json @default("{}")
160
+ user_id String?
161
+ team_id String?
162
+ permissions Json @default("{}")
163
+ max_parallel_requests Int?
164
+ metadata Json @default("{}")
165
+ blocked Boolean?
166
+ tpm_limit BigInt?
167
+ rpm_limit BigInt?
168
+ max_budget Float?
169
+ budget_duration String?
170
+ budget_reset_at DateTime?
171
+ allowed_cache_controls String[] @default([])
172
+ model_spend Json @default("{}")
173
+ model_max_budget Json @default("{}")
174
+ budget_id String?
175
+ organization_id String?
176
+ created_at DateTime? @default(now()) @map("created_at")
177
+ created_by String?
178
+ updated_at DateTime? @default(now()) @updatedAt @map("updated_at")
179
+ updated_by String?
180
+ litellm_budget_table LiteLLM_BudgetTable? @relation(fields: [budget_id], references: [budget_id])
181
+ litellm_organization_table LiteLLM_OrganizationTable? @relation(fields: [organization_id], references: [organization_id])
182
+ }
183
+
184
+ model LiteLLM_EndUserTable {
185
+ user_id String @id
186
+ alias String? // admin-facing alias
187
+ spend Float @default(0.0)
188
+ allowed_model_region String? // require all user requests to use models in this specific region
189
+ default_model String? // use along with 'allowed_model_region'. if no available model in region, default to this model.
190
+ budget_id String?
191
+ litellm_budget_table LiteLLM_BudgetTable? @relation(fields: [budget_id], references: [budget_id])
192
+ blocked Boolean @default(false)
193
+ }
194
+
195
+ // store proxy config.yaml
196
+ model LiteLLM_Config {
197
+ param_name String @id
198
+ param_value Json?
199
+ }
200
+
201
+ // View spend, model, api_key per request
202
+ model LiteLLM_SpendLogs {
203
+ request_id String @id
204
+ call_type String
205
+ api_key String @default ("") // Hashed API Token. Not the actual Virtual Key. Equivalent to 'token' column in LiteLLM_VerificationToken
206
+ spend Float @default(0.0)
207
+ total_tokens Int @default(0)
208
+ prompt_tokens Int @default(0)
209
+ completion_tokens Int @default(0)
210
+ startTime DateTime // Assuming start_time is a DateTime field
211
+ endTime DateTime // Assuming end_time is a DateTime field
212
+ completionStartTime DateTime? // Assuming completionStartTime is a DateTime field
213
+ model String @default("")
214
+ model_id String? @default("") // the model id stored in proxy model db
215
+ model_group String? @default("") // public model_name / model_group
216
+ custom_llm_provider String? @default("") // litellm used custom_llm_provider
217
+ api_base String? @default("")
218
+ user String? @default("")
219
+ metadata Json? @default("{}")
220
+ cache_hit String? @default("")
221
+ cache_key String? @default("")
222
+ request_tags Json? @default("[]")
223
+ team_id String?
224
+ end_user String?
225
+ requester_ip_address String?
226
+ messages Json? @default("{}")
227
+ response Json? @default("{}")
228
+ @@index([startTime])
229
+ @@index([end_user])
230
+ }
231
+
232
+ // View spend, model, api_key per request
233
+ model LiteLLM_ErrorLogs {
234
+ request_id String @id @default(uuid())
235
+ startTime DateTime // Assuming start_time is a DateTime field
236
+ endTime DateTime // Assuming end_time is a DateTime field
237
+ api_base String @default("")
238
+ model_group String @default("") // public model_name / model_group
239
+ litellm_model_name String @default("") // model passed to litellm
240
+ model_id String @default("") // ID of model in ProxyModelTable
241
+ request_kwargs Json @default("{}")
242
+ exception_type String @default("")
243
+ exception_string String @default("")
244
+ status_code String @default("")
245
+ }
246
+
247
+ // Beta - allow team members to request access to a model
248
+ model LiteLLM_UserNotifications {
249
+ request_id String @id
250
+ user_id String
251
+ models String[]
252
+ justification String
253
+ status String // approved, disapproved, pending
254
+ }
255
+
256
+ model LiteLLM_TeamMembership {
257
+ // Use this table to track the Internal User's Spend within a Team + Set Budgets, rpm limits for the user within the team
258
+ user_id String
259
+ team_id String
260
+ spend Float @default(0.0)
261
+ budget_id String?
262
+ litellm_budget_table LiteLLM_BudgetTable? @relation(fields: [budget_id], references: [budget_id])
263
+ @@id([user_id, team_id])
264
+ }
265
+
266
+ model LiteLLM_OrganizationMembership {
267
+ // Use this table to track Internal User and Organization membership. Helps tracking a users role within an Organization
268
+ user_id String
269
+ organization_id String
270
+ user_role String?
271
+ spend Float? @default(0.0)
272
+ budget_id String?
273
+ created_at DateTime? @default(now()) @map("created_at")
274
+ updated_at DateTime? @default(now()) @updatedAt @map("updated_at")
275
+
276
+ // relations
277
+ user LiteLLM_UserTable @relation(fields: [user_id], references: [user_id])
278
+ organization LiteLLM_OrganizationTable @relation("OrganizationToMembership", fields: [organization_id], references: [organization_id])
279
+ litellm_budget_table LiteLLM_BudgetTable? @relation(fields: [budget_id], references: [budget_id])
280
+
281
+
282
+
283
+ @@id([user_id, organization_id])
284
+ @@unique([user_id, organization_id])
285
+ }
286
+
287
+ model LiteLLM_InvitationLink {
288
+ // use this table to track invite links sent by admin for people to join the proxy
289
+ id String @id @default(uuid())
290
+ user_id String
291
+ is_accepted Boolean @default(false)
292
+ accepted_at DateTime? // when link is claimed (user successfully onboards via link)
293
+ expires_at DateTime // till when is link valid
294
+ created_at DateTime // when did admin create the link
295
+ created_by String // who created the link
296
+ updated_at DateTime // when was invite status updated
297
+ updated_by String // who updated the status (admin/user who accepted invite)
298
+
299
+ // Relations
300
+ liteLLM_user_table_user LiteLLM_UserTable @relation("UserId", fields: [user_id], references: [user_id])
301
+ liteLLM_user_table_created LiteLLM_UserTable @relation("CreatedBy", fields: [created_by], references: [user_id])
302
+ liteLLM_user_table_updated LiteLLM_UserTable @relation("UpdatedBy", fields: [updated_by], references: [user_id])
303
+ }
304
+
305
+
306
+ model LiteLLM_AuditLog {
307
+ id String @id @default(uuid())
308
+ updated_at DateTime @default(now())
309
+ changed_by String @default("") // user or system that performed the action
310
+ changed_by_api_key String @default("") // api key hash that performed the action
311
+ action String // create, update, delete
312
+ table_name String // on of LitellmTableNames.TEAM_TABLE_NAME, LitellmTableNames.USER_TABLE_NAME, LitellmTableNames.PROXY_MODEL_TABLE_NAME,
313
+ object_id String // id of the object being audited. This can be the key id, team id, user id, model id
314
+ before_value Json? // value of the row
315
+ updated_values Json? // value of the row after change
316
+ }
317
+
318
+ // Track daily user spend metrics per model and key
319
+ model LiteLLM_DailyUserSpend {
320
+ id String @id @default(uuid())
321
+ user_id String
322
+ date String
323
+ api_key String
324
+ model String
325
+ model_group String?
326
+ custom_llm_provider String?
327
+ prompt_tokens Int @default(0)
328
+ completion_tokens Int @default(0)
329
+ spend Float @default(0.0)
330
+ api_requests Int @default(0)
331
+ successful_requests Int @default(0)
332
+ failed_requests Int @default(0)
333
+ created_at DateTime @default(now())
334
+ updated_at DateTime @updatedAt
335
+
336
+ @@unique([user_id, date, api_key, model, custom_llm_provider])
337
+ @@index([date])
338
+ @@index([user_id])
339
+ @@index([api_key])
340
+ @@index([model])
341
+ }
342
+
343
+
344
+ // Track the status of cron jobs running. Only allow one pod to run the job at a time
345
+ model LiteLLM_CronJob {
346
+ cronjob_id String @id @default(cuid()) // Unique ID for the record
347
+ pod_id String // Unique identifier for the pod acting as the leader
348
+ status JobStatus @default(INACTIVE) // Status of the cron job (active or inactive)
349
+ last_updated DateTime @default(now()) // Timestamp for the last update of the cron job record
350
+ ttl DateTime // Time when the leader's lease expires
351
+ }
352
+
353
+ enum JobStatus {
354
+ ACTIVE
355
+ INACTIVE
356
+ }
357
+
@@ -30,21 +30,23 @@ class ProxyExtrasDBManager:
30
30
  use_migrate = str_to_bool(os.getenv("USE_PRISMA_MIGRATE")) or use_migrate
31
31
  for attempt in range(4):
32
32
  original_dir = os.getcwd()
33
- schema_dir = os.path.dirname(schema_path)
34
- os.chdir(schema_dir)
33
+ migrations_dir = os.path.dirname(__file__)
34
+ os.chdir(migrations_dir)
35
35
 
36
36
  try:
37
37
  if use_migrate:
38
38
  logger.info("Running prisma migrate deploy")
39
39
  try:
40
40
  # Set migrations directory for Prisma
41
- subprocess.run(
41
+ result = subprocess.run(
42
42
  ["prisma", "migrate", "deploy"],
43
43
  timeout=60,
44
44
  check=True,
45
45
  capture_output=True,
46
46
  text=True,
47
47
  )
48
+ logger.info(f"prisma migrate deploy stdout: {result.stdout}")
49
+
48
50
  logger.info("prisma migrate deploy completed")
49
51
  return True
50
52
  except subprocess.CalledProcessError as e:
@@ -77,4 +79,5 @@ class ProxyExtrasDBManager:
77
79
  time.sleep(random.randrange(5, 15))
78
80
  finally:
79
81
  os.chdir(original_dir)
82
+ pass
80
83
  return False
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "litellm-proxy-extras"
3
- version = "0.1.2"
3
+ version = "0.1.5"
4
4
  description = "Additional files for the LiteLLM Proxy. Reduces the size of the main litellm package."
5
5
  authors = ["BerriAI"]
6
6
  readme = "README.md"
@@ -22,7 +22,7 @@ requires = ["poetry-core"]
22
22
  build-backend = "poetry.core.masonry.api"
23
23
 
24
24
  [tool.commitizen]
25
- version = "0.1.2"
25
+ version = "0.1.5"
26
26
  version_files = [
27
27
  "pyproject.toml:version",
28
28
  "../requirements.txt:litellm-proxy-extras==",