litellm-proxy-extras 0.1.14__py3-none-any.whl → 0.2.0__py3-none-any.whl

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.

@@ -0,0 +1,17 @@
1
+ -- CreateTable
2
+ CREATE TABLE "LiteLLM_MCPServerTable" (
3
+ "server_id" TEXT NOT NULL,
4
+ "alias" TEXT,
5
+ "description" TEXT,
6
+ "url" TEXT NOT NULL,
7
+ "transport" TEXT NOT NULL DEFAULT 'sse',
8
+ "spec_version" TEXT NOT NULL DEFAULT '2025-03-26',
9
+ "auth_type" TEXT,
10
+ "created_at" TIMESTAMP(3) DEFAULT CURRENT_TIMESTAMP,
11
+ "created_by" TEXT,
12
+ "updated_at" TIMESTAMP(3) DEFAULT CURRENT_TIMESTAMP,
13
+ "updated_by" TEXT,
14
+
15
+ CONSTRAINT "LiteLLM_MCPServerTable_pkey" PRIMARY KEY ("server_id")
16
+ );
17
+
@@ -0,0 +1,32 @@
1
+ -- AlterTable
2
+ ALTER TABLE "LiteLLM_OrganizationTable" ADD COLUMN "object_permission_id" TEXT;
3
+
4
+ -- AlterTable
5
+ ALTER TABLE "LiteLLM_TeamTable" ADD COLUMN "object_permission_id" TEXT;
6
+
7
+ -- AlterTable
8
+ ALTER TABLE "LiteLLM_UserTable" ADD COLUMN "object_permission_id" TEXT;
9
+
10
+ -- AlterTable
11
+ ALTER TABLE "LiteLLM_VerificationToken" ADD COLUMN "object_permission_id" TEXT;
12
+
13
+ -- CreateTable
14
+ CREATE TABLE "LiteLLM_ObjectPermissionTable" (
15
+ "object_permission_id" TEXT NOT NULL,
16
+ "mcp_servers" TEXT[] DEFAULT ARRAY[]::TEXT[],
17
+
18
+ CONSTRAINT "LiteLLM_ObjectPermissionTable_pkey" PRIMARY KEY ("object_permission_id")
19
+ );
20
+
21
+ -- AddForeignKey
22
+ ALTER TABLE "LiteLLM_OrganizationTable" ADD CONSTRAINT "LiteLLM_OrganizationTable_object_permission_id_fkey" FOREIGN KEY ("object_permission_id") REFERENCES "LiteLLM_ObjectPermissionTable"("object_permission_id") ON DELETE SET NULL ON UPDATE CASCADE;
23
+
24
+ -- AddForeignKey
25
+ ALTER TABLE "LiteLLM_TeamTable" ADD CONSTRAINT "LiteLLM_TeamTable_object_permission_id_fkey" FOREIGN KEY ("object_permission_id") REFERENCES "LiteLLM_ObjectPermissionTable"("object_permission_id") ON DELETE SET NULL ON UPDATE CASCADE;
26
+
27
+ -- AddForeignKey
28
+ ALTER TABLE "LiteLLM_UserTable" ADD CONSTRAINT "LiteLLM_UserTable_object_permission_id_fkey" FOREIGN KEY ("object_permission_id") REFERENCES "LiteLLM_ObjectPermissionTable"("object_permission_id") ON DELETE SET NULL ON UPDATE CASCADE;
29
+
30
+ -- AddForeignKey
31
+ ALTER TABLE "LiteLLM_VerificationToken" ADD CONSTRAINT "LiteLLM_VerificationToken_object_permission_id_fkey" FOREIGN KEY ("object_permission_id") REFERENCES "LiteLLM_ObjectPermissionTable"("object_permission_id") ON DELETE SET NULL ON UPDATE CASCADE;
32
+
@@ -0,0 +1,3 @@
1
+ -- AlterTable
2
+ ALTER TABLE "LiteLLM_SpendLogs" ADD COLUMN "status" TEXT;
3
+
@@ -0,0 +1,27 @@
1
+ -- AlterTable
2
+ ALTER TABLE "LiteLLM_DailyTagSpend" ALTER COLUMN "prompt_tokens" SET DATA TYPE BIGINT,
3
+ ALTER COLUMN "completion_tokens" SET DATA TYPE BIGINT,
4
+ ALTER COLUMN "cache_read_input_tokens" SET DATA TYPE BIGINT,
5
+ ALTER COLUMN "cache_creation_input_tokens" SET DATA TYPE BIGINT,
6
+ ALTER COLUMN "api_requests" SET DATA TYPE BIGINT,
7
+ ALTER COLUMN "successful_requests" SET DATA TYPE BIGINT,
8
+ ALTER COLUMN "failed_requests" SET DATA TYPE BIGINT;
9
+
10
+ -- AlterTable
11
+ ALTER TABLE "LiteLLM_DailyTeamSpend" ALTER COLUMN "prompt_tokens" SET DATA TYPE BIGINT,
12
+ ALTER COLUMN "completion_tokens" SET DATA TYPE BIGINT,
13
+ ALTER COLUMN "api_requests" SET DATA TYPE BIGINT,
14
+ ALTER COLUMN "successful_requests" SET DATA TYPE BIGINT,
15
+ ALTER COLUMN "failed_requests" SET DATA TYPE BIGINT,
16
+ ALTER COLUMN "cache_creation_input_tokens" SET DATA TYPE BIGINT,
17
+ ALTER COLUMN "cache_read_input_tokens" SET DATA TYPE BIGINT;
18
+
19
+ -- AlterTable
20
+ ALTER TABLE "LiteLLM_DailyUserSpend" ALTER COLUMN "prompt_tokens" SET DATA TYPE BIGINT,
21
+ ALTER COLUMN "completion_tokens" SET DATA TYPE BIGINT,
22
+ ALTER COLUMN "api_requests" SET DATA TYPE BIGINT,
23
+ ALTER COLUMN "failed_requests" SET DATA TYPE BIGINT,
24
+ ALTER COLUMN "successful_requests" SET DATA TYPE BIGINT,
25
+ ALTER COLUMN "cache_creation_input_tokens" SET DATA TYPE BIGINT,
26
+ ALTER COLUMN "cache_read_input_tokens" SET DATA TYPE BIGINT;
27
+
@@ -0,0 +1,3 @@
1
+ -- CreateIndex
2
+ CREATE INDEX "LiteLLM_SpendLogs_session_id_idx" ON "LiteLLM_SpendLogs"("session_id");
3
+
@@ -0,0 +1,15 @@
1
+ -- CreateTable
2
+ CREATE TABLE "LiteLLM_GuardrailsTable" (
3
+ "guardrail_id" TEXT NOT NULL,
4
+ "guardrail_name" TEXT NOT NULL,
5
+ "litellm_params" JSONB NOT NULL,
6
+ "guardrail_info" JSONB,
7
+ "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
8
+ "updated_at" TIMESTAMP(3) NOT NULL,
9
+
10
+ CONSTRAINT "LiteLLM_GuardrailsTable_pkey" PRIMARY KEY ("guardrail_id")
11
+ );
12
+
13
+ -- CreateIndex
14
+ CREATE UNIQUE INDEX "LiteLLM_GuardrailsTable_guardrail_name_key" ON "LiteLLM_GuardrailsTable"("guardrail_name");
15
+
@@ -0,0 +1,32 @@
1
+ -- AlterTable
2
+ ALTER TABLE "LiteLLM_ManagedFileTable" ADD COLUMN "created_by" TEXT,
3
+ ADD COLUMN "flat_model_file_ids" TEXT[] DEFAULT ARRAY[]::TEXT[],
4
+ ADD COLUMN "updated_by" TEXT;
5
+
6
+ -- CreateTable
7
+ CREATE TABLE "LiteLLM_ManagedObjectTable" (
8
+ "id" TEXT NOT NULL,
9
+ "unified_object_id" TEXT NOT NULL,
10
+ "model_object_id" TEXT NOT NULL,
11
+ "file_object" JSONB NOT NULL,
12
+ "file_purpose" TEXT NOT NULL,
13
+ "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
14
+ "created_by" TEXT,
15
+ "updated_at" TIMESTAMP(3) NOT NULL,
16
+ "updated_by" TEXT,
17
+
18
+ CONSTRAINT "LiteLLM_ManagedObjectTable_pkey" PRIMARY KEY ("id")
19
+ );
20
+
21
+ -- CreateIndex
22
+ CREATE UNIQUE INDEX "LiteLLM_ManagedObjectTable_unified_object_id_key" ON "LiteLLM_ManagedObjectTable"("unified_object_id");
23
+
24
+ -- CreateIndex
25
+ CREATE UNIQUE INDEX "LiteLLM_ManagedObjectTable_model_object_id_key" ON "LiteLLM_ManagedObjectTable"("model_object_id");
26
+
27
+ -- CreateIndex
28
+ CREATE INDEX "LiteLLM_ManagedObjectTable_unified_object_id_idx" ON "LiteLLM_ManagedObjectTable"("unified_object_id");
29
+
30
+ -- CreateIndex
31
+ CREATE INDEX "LiteLLM_ManagedObjectTable_model_object_id_idx" ON "LiteLLM_ManagedObjectTable"("model_object_id");
32
+
@@ -61,6 +61,7 @@ model LiteLLM_OrganizationTable {
61
61
  models String[]
62
62
  spend Float @default(0.0)
63
63
  model_spend Json @default("{}")
64
+ object_permission_id String?
64
65
  created_at DateTime @default(now()) @map("created_at")
65
66
  created_by String
66
67
  updated_at DateTime @default(now()) @updatedAt @map("updated_at")
@@ -70,6 +71,7 @@ model LiteLLM_OrganizationTable {
70
71
  users LiteLLM_UserTable[]
71
72
  keys LiteLLM_VerificationToken[]
72
73
  members LiteLLM_OrganizationMembership[] @relation("OrganizationToMembership")
74
+ object_permission LiteLLM_ObjectPermissionTable? @relation(fields: [object_permission_id], references: [object_permission_id])
73
75
  }
74
76
 
75
77
  // Model info for teams, just has model aliases for now.
@@ -89,6 +91,7 @@ model LiteLLM_TeamTable {
89
91
  team_id String @id @default(uuid())
90
92
  team_alias String?
91
93
  organization_id String?
94
+ object_permission_id String?
92
95
  admins String[]
93
96
  members String[]
94
97
  members_with_roles Json @default("{}")
@@ -110,6 +113,7 @@ model LiteLLM_TeamTable {
110
113
  model_id Int? @unique // id for LiteLLM_ModelTable -> stores team-level model aliases
111
114
  litellm_organization_table LiteLLM_OrganizationTable? @relation(fields: [organization_id], references: [organization_id])
112
115
  litellm_model_table LiteLLM_ModelTable? @relation(fields: [model_id], references: [id])
116
+ object_permission LiteLLM_ObjectPermissionTable? @relation(fields: [object_permission_id], references: [object_permission_id])
113
117
  }
114
118
 
115
119
  // Track spend, rate limit, budget Users
@@ -119,6 +123,7 @@ model LiteLLM_UserTable {
119
123
  team_id String?
120
124
  sso_user_id String? @unique
121
125
  organization_id String?
126
+ object_permission_id String?
122
127
  password String?
123
128
  teams String[] @default([])
124
129
  user_role String?
@@ -144,6 +149,32 @@ model LiteLLM_UserTable {
144
149
  invitations_created LiteLLM_InvitationLink[] @relation("CreatedBy")
145
150
  invitations_updated LiteLLM_InvitationLink[] @relation("UpdatedBy")
146
151
  invitations_user LiteLLM_InvitationLink[] @relation("UserId")
152
+ object_permission LiteLLM_ObjectPermissionTable? @relation(fields: [object_permission_id], references: [object_permission_id])
153
+ }
154
+
155
+ model LiteLLM_ObjectPermissionTable {
156
+ object_permission_id String @id @default(uuid())
157
+ mcp_servers String[] @default([])
158
+
159
+ teams LiteLLM_TeamTable[]
160
+ verification_tokens LiteLLM_VerificationToken[]
161
+ organizations LiteLLM_OrganizationTable[]
162
+ users LiteLLM_UserTable[]
163
+ }
164
+
165
+ // Holds the MCP server configuration
166
+ model LiteLLM_MCPServerTable {
167
+ server_id String @id @default(uuid())
168
+ alias String?
169
+ description String?
170
+ url String
171
+ transport String @default("sse")
172
+ spec_version String @default("2025-03-26")
173
+ auth_type String?
174
+ created_at DateTime? @default(now()) @map("created_at")
175
+ created_by String?
176
+ updated_at DateTime? @default(now()) @updatedAt @map("updated_at")
177
+ updated_by String?
147
178
  }
148
179
 
149
180
  // Generate Tokens for Proxy
@@ -174,12 +205,14 @@ model LiteLLM_VerificationToken {
174
205
  model_max_budget Json @default("{}")
175
206
  budget_id String?
176
207
  organization_id String?
208
+ object_permission_id String?
177
209
  created_at DateTime? @default(now()) @map("created_at")
178
210
  created_by String?
179
211
  updated_at DateTime? @default(now()) @updatedAt @map("updated_at")
180
212
  updated_by String?
181
213
  litellm_budget_table LiteLLM_BudgetTable? @relation(fields: [budget_id], references: [budget_id])
182
214
  litellm_organization_table LiteLLM_OrganizationTable? @relation(fields: [organization_id], references: [organization_id])
215
+ object_permission LiteLLM_ObjectPermissionTable? @relation(fields: [object_permission_id], references: [object_permission_id])
183
216
  }
184
217
 
185
218
  model LiteLLM_EndUserTable {
@@ -227,9 +260,11 @@ model LiteLLM_SpendLogs {
227
260
  messages Json? @default("{}")
228
261
  response Json? @default("{}")
229
262
  session_id String?
263
+ status String?
230
264
  proxy_server_request Json? @default("{}")
231
265
  @@index([startTime])
232
266
  @@index([end_user])
267
+ @@index([session_id])
233
268
  }
234
269
 
235
270
  // View spend, model, api_key per request
@@ -327,14 +362,14 @@ model LiteLLM_DailyUserSpend {
327
362
  model String
328
363
  model_group String?
329
364
  custom_llm_provider String?
330
- prompt_tokens Int @default(0)
331
- completion_tokens Int @default(0)
332
- cache_read_input_tokens Int @default(0)
333
- cache_creation_input_tokens Int @default(0)
365
+ prompt_tokens BigInt @default(0)
366
+ completion_tokens BigInt @default(0)
367
+ cache_read_input_tokens BigInt @default(0)
368
+ cache_creation_input_tokens BigInt @default(0)
334
369
  spend Float @default(0.0)
335
- api_requests Int @default(0)
336
- successful_requests Int @default(0)
337
- failed_requests Int @default(0)
370
+ api_requests BigInt @default(0)
371
+ successful_requests BigInt @default(0)
372
+ failed_requests BigInt @default(0)
338
373
  created_at DateTime @default(now())
339
374
  updated_at DateTime @updatedAt
340
375
 
@@ -354,14 +389,14 @@ model LiteLLM_DailyTeamSpend {
354
389
  model String
355
390
  model_group String?
356
391
  custom_llm_provider String?
357
- prompt_tokens Int @default(0)
358
- completion_tokens Int @default(0)
359
- cache_read_input_tokens Int @default(0)
360
- cache_creation_input_tokens Int @default(0)
392
+ prompt_tokens BigInt @default(0)
393
+ completion_tokens BigInt @default(0)
394
+ cache_read_input_tokens BigInt @default(0)
395
+ cache_creation_input_tokens BigInt @default(0)
361
396
  spend Float @default(0.0)
362
- api_requests Int @default(0)
363
- successful_requests Int @default(0)
364
- failed_requests Int @default(0)
397
+ api_requests BigInt @default(0)
398
+ successful_requests BigInt @default(0)
399
+ failed_requests BigInt @default(0)
365
400
  created_at DateTime @default(now())
366
401
  updated_at DateTime @updatedAt
367
402
 
@@ -381,14 +416,14 @@ model LiteLLM_DailyTagSpend {
381
416
  model String
382
417
  model_group String?
383
418
  custom_llm_provider String?
384
- prompt_tokens Int @default(0)
385
- completion_tokens Int @default(0)
386
- cache_read_input_tokens Int @default(0)
387
- cache_creation_input_tokens Int @default(0)
419
+ prompt_tokens BigInt @default(0)
420
+ completion_tokens BigInt @default(0)
421
+ cache_read_input_tokens BigInt @default(0)
422
+ cache_creation_input_tokens BigInt @default(0)
388
423
  spend Float @default(0.0)
389
- api_requests Int @default(0)
390
- successful_requests Int @default(0)
391
- failed_requests Int @default(0)
424
+ api_requests BigInt @default(0)
425
+ successful_requests BigInt @default(0)
426
+ failed_requests BigInt @default(0)
392
427
  created_at DateTime @default(now())
393
428
  updated_at DateTime @updatedAt
394
429
 
@@ -418,13 +453,30 @@ model LiteLLM_ManagedFileTable {
418
453
  id String @id @default(uuid())
419
454
  unified_file_id String @unique // The base64 encoded unified file ID
420
455
  file_object Json // Stores the OpenAIFileObject
421
- model_mappings Json // Stores the mapping of model_id -> provider_file_id
456
+ model_mappings Json
457
+ flat_model_file_ids String[] @default([]) // Flat list of model file id's - for faster querying of model id -> unified file id
422
458
  created_at DateTime @default(now())
459
+ created_by String?
423
460
  updated_at DateTime @updatedAt
461
+ updated_by String?
424
462
 
425
463
  @@index([unified_file_id])
426
464
  }
427
465
 
466
+ model LiteLLM_ManagedObjectTable { // for batches or finetuning jobs which use the
467
+ id String @id @default(uuid())
468
+ unified_object_id String @unique // The base64 encoded unified file ID
469
+ model_object_id String @unique // the id returned by the backend API provider
470
+ file_object Json // Stores the OpenAIFileObject
471
+ file_purpose String // either 'batch' or 'fine-tune'
472
+ created_at DateTime @default(now())
473
+ created_by String?
474
+ updated_at DateTime @updatedAt
475
+ updated_by String?
476
+
477
+ @@index([unified_object_id])
478
+ @@index([model_object_id])
479
+ }
428
480
 
429
481
  model LiteLLM_ManagedVectorStoresTable {
430
482
  vector_store_id String @id
@@ -435,4 +487,14 @@ model LiteLLM_ManagedVectorStoresTable {
435
487
  created_at DateTime @default(now())
436
488
  updated_at DateTime @updatedAt
437
489
  litellm_credential_name String?
490
+ }
491
+
492
+ // Guardrails table for storing guardrail configurations
493
+ model LiteLLM_GuardrailsTable {
494
+ guardrail_id String @id @default(uuid())
495
+ guardrail_name String @unique
496
+ litellm_params Json
497
+ guardrail_info Json?
498
+ created_at DateTime @default(now())
499
+ updated_at DateTime @updatedAt
438
500
  }
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: litellm-proxy-extras
3
- Version: 0.1.14
3
+ Version: 0.2.0
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.*
@@ -29,7 +29,7 @@ pip install litellm-proxy-extras
29
29
  OR
30
30
 
31
31
  ```bash
32
- pip install litellm[proxy] # installs litellm-proxy-extras and other proxy dependencies.
32
+ pip install litellm[proxy] # installs litellm-proxy-extras and other proxy dependencies
33
33
  ```
34
34
 
35
35
  To use the migrations, run:
@@ -14,10 +14,17 @@ litellm_proxy_extras/migrations/20250416151339_drop_tag_uniqueness_requirement/m
14
14
  litellm_proxy_extras/migrations/20250416185146_add_allowed_routes_litellm_verification_token/migration.sql,sha256=XGyDLGakqBt30xuGS-RT5tWhk_Ki7teenxpvKDkIo2E,119
15
15
  litellm_proxy_extras/migrations/20250425182129_add_session_id/migration.sql,sha256=dSjU5QavHMM60siy6f_69DZpFCA4lUfWDL0AUEPEt2g,139
16
16
  litellm_proxy_extras/migrations/20250430193429_add_managed_vector_stores/migration.sql,sha256=SmXedKWYWwYAZjg-usw-905nXxyU9SOws9teFATezUA,479
17
+ litellm_proxy_extras/migrations/20250507161526_add_mcp_table_to_db/migration.sql,sha256=C_0iU6F-XUST0BekRSrFGMW69_pwBLSS7Pu5HvGNJ7c,511
18
+ litellm_proxy_extras/migrations/20250507184818_add_mcp_key_team_permission_mgmt/migration.sql,sha256=G2NONS9XAMDdkH-0tpaPimK4ezs94hkwteRK1m7oA1Y,1672
19
+ litellm_proxy_extras/migrations/20250508072103_add_status_to_spendlogs/migration.sql,sha256=V4mIhoi3n8sUzV8_YY9AA_wkgvk65m5ZOAU3_DtoUo8,77
20
+ litellm_proxy_extras/migrations/20250509141545_use_big_int_for_daily_spend_tables/migration.sql,sha256=UPaAXsryGvVZT_SnOf-1yHu5bKPTVr2gP3zY64FKR7o,1331
21
+ litellm_proxy_extras/migrations/20250510142544_add_session_id_index_spend_logs/migration.sql,sha256=M_y4xLnlGApiUIovLv0xA7lL5gJBZWrcFe7b5MSUOik,102
22
+ litellm_proxy_extras/migrations/20250514142245_add_guardrails_table/migration.sql,sha256=mxBhXoedxkabrkn7YPiKn-OVmoXh6RsSEXY9a0-FkQk,506
23
+ litellm_proxy_extras/migrations/20250522223020_managed_object_table/migration.sql,sha256=SbchBsESJa8M5O4R1iqvfgssX5StSrL85Umd2Drns_Y,1185
17
24
  litellm_proxy_extras/migrations/migration_lock.toml,sha256=HbF6jQUaoTYRBzZ1LF4fi37ZK26o6AMRL7viSXBHwhA,24
18
- litellm_proxy_extras/schema.prisma,sha256=feIdet6dXSzmxzipML2aoPY1VlPFkxQCA66BOknqcv8,16935
25
+ litellm_proxy_extras/schema.prisma,sha256=AyzMzVmvCBs6XjbdjyDTazdAqVGVG1SzZFmhIvOxBZg,19530
19
26
  litellm_proxy_extras/utils.py,sha256=QImDkrfX_NGCp0tJ4T9IZpmXyzVZqey4jnVVEO0Hcrs,15050
20
- litellm_proxy_extras-0.1.14.dist-info/LICENSE,sha256=sXDWv46INd01fgEWgdsCj01R4vsOqJIFj1bgH7ObgnM,1419
21
- litellm_proxy_extras-0.1.14.dist-info/METADATA,sha256=R9to4bsFJjyfg4-tKRjo9D6lbnrKG091PSikK20_7Y8,1268
22
- litellm_proxy_extras-0.1.14.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
23
- litellm_proxy_extras-0.1.14.dist-info/RECORD,,
27
+ litellm_proxy_extras-0.2.0.dist-info/LICENSE,sha256=sXDWv46INd01fgEWgdsCj01R4vsOqJIFj1bgH7ObgnM,1419
28
+ litellm_proxy_extras-0.2.0.dist-info/METADATA,sha256=joZBCZ2gDwvwwlLiTz_m0-hDKVYe8hDp5lgGDtQCMpQ,1266
29
+ litellm_proxy_extras-0.2.0.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
30
+ litellm_proxy_extras-0.2.0.dist-info/RECORD,,