smart-bot-factory 0.3.2__py3-none-any.whl → 0.3.3__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 smart-bot-factory might be problematic. Click here for more details.

@@ -1,1094 +0,0 @@
1
-
2
- \restrict WBtltrfyEEoF24oRSfGBapNcgKliB6xSV8AgT2uO2cKxNSkoUuc9InlJ2lBPCQx
3
-
4
-
5
- SET statement_timeout = 0;
6
- SET lock_timeout = 0;
7
- SET idle_in_transaction_session_timeout = 0;
8
- SET client_encoding = 'UTF8';
9
- SET standard_conforming_strings = on;
10
- SELECT pg_catalog.set_config('search_path', '', false);
11
- SET check_function_bodies = false;
12
- SET xmloption = content;
13
- SET client_min_messages = warning;
14
- SET row_security = off;
15
-
16
-
17
- COMMENT ON SCHEMA "public" IS 'standard public schema';
18
-
19
-
20
-
21
- CREATE EXTENSION IF NOT EXISTS "pg_graphql" WITH SCHEMA "graphql";
22
-
23
-
24
-
25
-
26
-
27
-
28
- CREATE EXTENSION IF NOT EXISTS "pg_stat_statements" WITH SCHEMA "extensions";
29
-
30
-
31
-
32
-
33
-
34
-
35
- CREATE EXTENSION IF NOT EXISTS "pgcrypto" WITH SCHEMA "extensions";
36
-
37
-
38
-
39
-
40
-
41
-
42
- CREATE EXTENSION IF NOT EXISTS "supabase_vault" WITH SCHEMA "vault";
43
-
44
-
45
-
46
-
47
-
48
-
49
- CREATE EXTENSION IF NOT EXISTS "uuid-ossp" WITH SCHEMA "extensions";
50
-
51
-
52
-
53
-
54
-
55
-
56
- CREATE OR REPLACE FUNCTION "public"."cleanup_old_messages"("days_to_keep" integer DEFAULT 30) RETURNS integer
57
- LANGUAGE "plpgsql"
58
- AS $$
59
- DECLARE
60
- deleted_count INTEGER;
61
- BEGIN
62
- DELETE FROM sales_messages
63
- WHERE created_at < NOW() - INTERVAL '1 day' * days_to_keep
64
- AND session_id IN (
65
- SELECT id FROM sales_chat_sessions WHERE status = 'archived'
66
- );
67
-
68
- GET DIAGNOSTICS deleted_count = ROW_COUNT;
69
- RETURN deleted_count;
70
- END;
71
- $$;
72
-
73
-
74
- ALTER FUNCTION "public"."cleanup_old_messages"("days_to_keep" integer) OWNER TO "postgres";
75
-
76
-
77
- CREATE OR REPLACE FUNCTION "public"."end_expired_admin_conversations"() RETURNS integer
78
- LANGUAGE "plpgsql"
79
- AS $$
80
- DECLARE
81
- ended_count INTEGER;
82
- BEGIN
83
- UPDATE admin_user_conversations
84
- SET status = 'completed', ended_at = NOW()
85
- WHERE status = 'active' AND auto_end_at < NOW();
86
-
87
- GET DIAGNOSTICS ended_count = ROW_COUNT;
88
- RETURN ended_count;
89
- END;
90
- $$;
91
-
92
-
93
- ALTER FUNCTION "public"."end_expired_admin_conversations"() OWNER TO "postgres";
94
-
95
-
96
- CREATE OR REPLACE FUNCTION "public"."update_updated_at_column"() RETURNS "trigger"
97
- LANGUAGE "plpgsql"
98
- AS $$
99
- BEGIN
100
- NEW.updated_at = NOW();
101
- RETURN NEW;
102
- END;
103
- $$;
104
-
105
-
106
- ALTER FUNCTION "public"."update_updated_at_column"() OWNER TO "postgres";
107
-
108
-
109
- CREATE OR REPLACE FUNCTION "public"."validate_bot_id"() RETURNS "trigger"
110
- LANGUAGE "plpgsql"
111
- AS $_$
112
- BEGIN
113
- -- Проверяем, что bot_id не пустой
114
- IF NEW.bot_id IS NULL OR trim(NEW.bot_id) = '' THEN
115
- RAISE EXCEPTION 'bot_id не может быть пустым';
116
- END IF;
117
-
118
- -- Проверяем формат bot_id (только латиница, цифры и дефисы)
119
- IF NEW.bot_id !~ '^[a-z0-9\-]+$' THEN
120
- RAISE EXCEPTION 'bot_id должен содержать только латинские буквы, цифры и дефисы';
121
- END IF;
122
-
123
- RETURN NEW;
124
- END;
125
- $_$;
126
-
127
-
128
- ALTER FUNCTION "public"."validate_bot_id"() OWNER TO "postgres";
129
-
130
- SET default_tablespace = '';
131
-
132
- SET default_table_access_method = "heap";
133
-
134
-
135
- CREATE TABLE IF NOT EXISTS "public"."admin_user_conversations" (
136
- "id" "uuid" DEFAULT "gen_random_uuid"() NOT NULL,
137
- "admin_id" bigint,
138
- "user_id" bigint,
139
- "session_id" "uuid",
140
- "status" "text" DEFAULT 'active'::"text",
141
- "started_at" timestamp with time zone DEFAULT "now"(),
142
- "ended_at" timestamp with time zone,
143
- "auto_end_at" timestamp with time zone DEFAULT ("now"() + '00:30:00'::interval),
144
- CONSTRAINT "admin_user_conversations_status_check" CHECK (("status" = ANY (ARRAY['active'::"text", 'completed'::"text"])))
145
- );
146
-
147
-
148
- ALTER TABLE "public"."admin_user_conversations" OWNER TO "postgres";
149
-
150
-
151
- COMMENT ON TABLE "public"."admin_user_conversations" IS 'Активные диалоги админов с пользователями';
152
-
153
-
154
-
155
- CREATE TABLE IF NOT EXISTS "public"."session_events" (
156
- "id" bigint NOT NULL,
157
- "session_id" "uuid",
158
- "event_type" "text" NOT NULL,
159
- "event_info" "text",
160
- "created_at" timestamp with time zone DEFAULT "now"(),
161
- "notified_admins" bigint[] DEFAULT '{}'::bigint[]
162
- );
163
-
164
-
165
- ALTER TABLE "public"."session_events" OWNER TO "postgres";
166
-
167
-
168
- COMMENT ON TABLE "public"."session_events" IS 'События из ответов ИИ для уведомлений';
169
-
170
-
171
-
172
- CREATE OR REPLACE VIEW "public"."daily_events" AS
173
- SELECT "date"("created_at") AS "event_date",
174
- "event_type",
175
- "count"(*) AS "count"
176
- FROM "public"."session_events"
177
- WHERE ("created_at" > ("now"() - '30 days'::interval))
178
- GROUP BY ("date"("created_at")), "event_type"
179
- ORDER BY ("date"("created_at")) DESC, "event_type";
180
-
181
-
182
- ALTER VIEW "public"."daily_events" OWNER TO "postgres";
183
-
184
-
185
- CREATE TABLE IF NOT EXISTS "public"."sales_chat_sessions" (
186
- "id" "uuid" DEFAULT "gen_random_uuid"() NOT NULL,
187
- "user_id" bigint NOT NULL,
188
- "system_prompt" "text" NOT NULL,
189
- "status" "text" DEFAULT 'active'::"text",
190
- "created_at" timestamp with time zone DEFAULT "now"(),
191
- "updated_at" timestamp with time zone DEFAULT "now"(),
192
- "metadata" "jsonb" DEFAULT '{}'::"jsonb",
193
- "bot_id" "text" DEFAULT 'growthmed-october-14'::"text" NOT NULL,
194
- "current_stage" "text",
195
- "lead_quality_score" integer,
196
- CONSTRAINT "sales_chat_sessions_status_check" CHECK (("status" = ANY (ARRAY['active'::"text", 'completed'::"text", 'archived'::"text"])))
197
- );
198
-
199
-
200
- ALTER TABLE "public"."sales_chat_sessions" OWNER TO "postgres";
201
-
202
-
203
- COMMENT ON TABLE "public"."sales_chat_sessions" IS 'Сессии диалогов с пользователями';
204
-
205
-
206
-
207
- COMMENT ON COLUMN "public"."sales_chat_sessions"."system_prompt" IS 'Системный промпт для данной сессии';
208
-
209
-
210
-
211
- COMMENT ON COLUMN "public"."sales_chat_sessions"."status" IS 'Статус сессии: active, completed, archived';
212
-
213
-
214
-
215
- COMMENT ON COLUMN "public"."sales_chat_sessions"."bot_id" IS 'ID бота, обязательное поле для разделения данных между ботами';
216
-
217
-
218
-
219
- CREATE OR REPLACE VIEW "public"."funnel_stats" AS
220
- SELECT "current_stage",
221
- "count"(*) AS "count",
222
- "avg"("lead_quality_score") AS "avg_quality",
223
- "round"(((("count"(*))::numeric * 100.0) / NULLIF("sum"("count"(*)) OVER (), (0)::numeric)), 1) AS "percentage"
224
- FROM "public"."sales_chat_sessions"
225
- WHERE (("created_at" > ("now"() - '7 days'::interval)) AND ("current_stage" IS NOT NULL))
226
- GROUP BY "current_stage";
227
-
228
-
229
- ALTER VIEW "public"."funnel_stats" OWNER TO "postgres";
230
-
231
-
232
- CREATE TABLE IF NOT EXISTS "public"."sales_admins" (
233
- "id" bigint NOT NULL,
234
- "telegram_id" bigint NOT NULL,
235
- "username" "text",
236
- "first_name" "text",
237
- "last_name" "text",
238
- "role" "text" DEFAULT 'admin'::"text",
239
- "is_active" boolean DEFAULT true,
240
- "created_at" timestamp with time zone DEFAULT "now"(),
241
- "updated_at" timestamp with time zone DEFAULT "now"()
242
- );
243
-
244
-
245
- ALTER TABLE "public"."sales_admins" OWNER TO "postgres";
246
-
247
-
248
- COMMENT ON TABLE "public"."sales_admins" IS 'Администраторы бота';
249
-
250
-
251
-
252
- CREATE SEQUENCE IF NOT EXISTS "public"."sales_admins_id_seq"
253
- START WITH 1
254
- INCREMENT BY 1
255
- NO MINVALUE
256
- NO MAXVALUE
257
- CACHE 1;
258
-
259
-
260
- ALTER SEQUENCE "public"."sales_admins_id_seq" OWNER TO "postgres";
261
-
262
-
263
- ALTER SEQUENCE "public"."sales_admins_id_seq" OWNED BY "public"."sales_admins"."id";
264
-
265
-
266
-
267
- CREATE TABLE IF NOT EXISTS "public"."sales_messages" (
268
- "id" bigint NOT NULL,
269
- "session_id" "uuid" NOT NULL,
270
- "role" "text" NOT NULL,
271
- "content" "text" NOT NULL,
272
- "message_type" "text" DEFAULT 'text'::"text",
273
- "tokens_used" integer DEFAULT 0,
274
- "processing_time_ms" integer DEFAULT 0,
275
- "created_at" timestamp with time zone DEFAULT "now"(),
276
- "metadata" "jsonb" DEFAULT '{}'::"jsonb",
277
- "ai_metadata" "jsonb" DEFAULT '{}'::"jsonb",
278
- CONSTRAINT "sales_messages_message_type_check" CHECK (("message_type" = ANY (ARRAY['text'::"text", 'image'::"text", 'document'::"text", 'audio'::"text"]))),
279
- CONSTRAINT "sales_messages_role_check" CHECK (("role" = ANY (ARRAY['system'::"text", 'user'::"text", 'assistant'::"text"])))
280
- );
281
-
282
-
283
- ALTER TABLE "public"."sales_messages" OWNER TO "postgres";
284
-
285
-
286
- COMMENT ON TABLE "public"."sales_messages" IS 'Сообщения в диалогах';
287
-
288
-
289
-
290
- COMMENT ON COLUMN "public"."sales_messages"."role" IS 'Роль отправителя: system, user, assistant';
291
-
292
-
293
-
294
- COMMENT ON COLUMN "public"."sales_messages"."tokens_used" IS 'Количество токенов использованных для обработки сообщения';
295
-
296
-
297
-
298
- CREATE SEQUENCE IF NOT EXISTS "public"."sales_messages_id_seq"
299
- START WITH 1
300
- INCREMENT BY 1
301
- NO MINVALUE
302
- NO MAXVALUE
303
- CACHE 1;
304
-
305
-
306
- ALTER SEQUENCE "public"."sales_messages_id_seq" OWNER TO "postgres";
307
-
308
-
309
- ALTER SEQUENCE "public"."sales_messages_id_seq" OWNED BY "public"."sales_messages"."id";
310
-
311
-
312
-
313
- CREATE TABLE IF NOT EXISTS "public"."sales_session_analytics" (
314
- "id" bigint NOT NULL,
315
- "session_id" "uuid" NOT NULL,
316
- "total_messages" integer DEFAULT 0,
317
- "total_tokens" integer DEFAULT 0,
318
- "average_response_time_ms" integer DEFAULT 0,
319
- "conversion_stage" "text",
320
- "lead_quality_score" integer,
321
- "created_at" timestamp with time zone DEFAULT "now"(),
322
- "updated_at" timestamp with time zone DEFAULT "now"(),
323
- CONSTRAINT "sales_session_analytics_lead_quality_score_check" CHECK ((("lead_quality_score" >= 1) AND ("lead_quality_score" <= 10)))
324
- );
325
-
326
-
327
- ALTER TABLE "public"."sales_session_analytics" OWNER TO "postgres";
328
-
329
-
330
- COMMENT ON TABLE "public"."sales_session_analytics" IS 'Аналитика по сессиям для оценки качества лидов';
331
-
332
-
333
-
334
- COMMENT ON COLUMN "public"."sales_session_analytics"."conversion_stage" IS 'Этап воронки продаж';
335
-
336
-
337
-
338
- COMMENT ON COLUMN "public"."sales_session_analytics"."lead_quality_score" IS 'Оценка качества лида от 1 до 10';
339
-
340
-
341
-
342
- CREATE SEQUENCE IF NOT EXISTS "public"."sales_session_analytics_id_seq"
343
- START WITH 1
344
- INCREMENT BY 1
345
- NO MINVALUE
346
- NO MAXVALUE
347
- CACHE 1;
348
-
349
-
350
- ALTER SEQUENCE "public"."sales_session_analytics_id_seq" OWNER TO "postgres";
351
-
352
-
353
- ALTER SEQUENCE "public"."sales_session_analytics_id_seq" OWNED BY "public"."sales_session_analytics"."id";
354
-
355
-
356
-
357
- CREATE TABLE IF NOT EXISTS "public"."sales_users" (
358
- "id" bigint NOT NULL,
359
- "telegram_id" bigint NOT NULL,
360
- "username" "text",
361
- "first_name" "text",
362
- "last_name" "text",
363
- "language_code" "text",
364
- "created_at" timestamp with time zone DEFAULT "now"(),
365
- "updated_at" timestamp with time zone DEFAULT "now"(),
366
- "is_active" boolean DEFAULT true,
367
- "bot_id" "text" DEFAULT 'growthmed-october-14'::"text" NOT NULL
368
- );
369
-
370
-
371
- ALTER TABLE "public"."sales_users" OWNER TO "postgres";
372
-
373
-
374
- COMMENT ON TABLE "public"."sales_users" IS 'Информация о пользователях Telegram';
375
-
376
-
377
-
378
- COMMENT ON COLUMN "public"."sales_users"."telegram_id" IS 'Уникальный ID пользователя в Telegram';
379
-
380
-
381
-
382
- COMMENT ON COLUMN "public"."sales_users"."bot_id" IS 'ID бота, обязательное поле для разделения данных между ботами';
383
-
384
-
385
-
386
- CREATE SEQUENCE IF NOT EXISTS "public"."sales_users_id_seq"
387
- START WITH 1
388
- INCREMENT BY 1
389
- NO MINVALUE
390
- NO MAXVALUE
391
- CACHE 1;
392
-
393
-
394
- ALTER SEQUENCE "public"."sales_users_id_seq" OWNER TO "postgres";
395
-
396
-
397
- ALTER SEQUENCE "public"."sales_users_id_seq" OWNED BY "public"."sales_users"."id";
398
-
399
-
400
-
401
- CREATE SEQUENCE IF NOT EXISTS "public"."session_events_id_seq"
402
- START WITH 1
403
- INCREMENT BY 1
404
- NO MINVALUE
405
- NO MAXVALUE
406
- CACHE 1;
407
-
408
-
409
- ALTER SEQUENCE "public"."session_events_id_seq" OWNER TO "postgres";
410
-
411
-
412
- ALTER SEQUENCE "public"."session_events_id_seq" OWNED BY "public"."session_events"."id";
413
-
414
-
415
-
416
- CREATE TABLE IF NOT EXISTS "public"."user_profiles" (
417
- "id" bigint NOT NULL,
418
- "created_at" timestamp with time zone DEFAULT "now"() NOT NULL,
419
- "name" "text" NOT NULL,
420
- "role" "text" NOT NULL,
421
- "company" "text" NOT NULL,
422
- "geo" "text",
423
- "goals" "text" NOT NULL,
424
- "telegram_id" "text" NOT NULL,
425
- "username" "text",
426
- "company_business" "text",
427
- "company_type" smallint NOT NULL
428
- );
429
-
430
-
431
- ALTER TABLE "public"."user_profiles" OWNER TO "postgres";
432
-
433
-
434
- ALTER TABLE "public"."user_profiles" ALTER COLUMN "id" ADD GENERATED BY DEFAULT AS IDENTITY (
435
- SEQUENCE NAME "public"."user_profiles_id_seq"
436
- START WITH 1
437
- INCREMENT BY 1
438
- NO MINVALUE
439
- NO MAXVALUE
440
- CACHE 1
441
- );
442
-
443
-
444
-
445
- ALTER TABLE ONLY "public"."sales_admins" ALTER COLUMN "id" SET DEFAULT "nextval"('"public"."sales_admins_id_seq"'::"regclass");
446
-
447
-
448
-
449
- ALTER TABLE ONLY "public"."sales_messages" ALTER COLUMN "id" SET DEFAULT "nextval"('"public"."sales_messages_id_seq"'::"regclass");
450
-
451
-
452
-
453
- ALTER TABLE ONLY "public"."sales_session_analytics" ALTER COLUMN "id" SET DEFAULT "nextval"('"public"."sales_session_analytics_id_seq"'::"regclass");
454
-
455
-
456
-
457
- ALTER TABLE ONLY "public"."sales_users" ALTER COLUMN "id" SET DEFAULT "nextval"('"public"."sales_users_id_seq"'::"regclass");
458
-
459
-
460
-
461
- ALTER TABLE ONLY "public"."session_events" ALTER COLUMN "id" SET DEFAULT "nextval"('"public"."session_events_id_seq"'::"regclass");
462
-
463
-
464
-
465
- ALTER TABLE ONLY "public"."admin_user_conversations"
466
- ADD CONSTRAINT "admin_user_conversations_pkey" PRIMARY KEY ("id");
467
-
468
-
469
-
470
- ALTER TABLE ONLY "public"."sales_admins"
471
- ADD CONSTRAINT "sales_admins_pkey" PRIMARY KEY ("id");
472
-
473
-
474
-
475
- ALTER TABLE ONLY "public"."sales_admins"
476
- ADD CONSTRAINT "sales_admins_telegram_id_key" UNIQUE ("telegram_id");
477
-
478
-
479
-
480
- ALTER TABLE ONLY "public"."sales_chat_sessions"
481
- ADD CONSTRAINT "sales_chat_sessions_pkey" PRIMARY KEY ("id");
482
-
483
-
484
-
485
- ALTER TABLE ONLY "public"."sales_messages"
486
- ADD CONSTRAINT "sales_messages_pkey" PRIMARY KEY ("id");
487
-
488
-
489
-
490
- ALTER TABLE ONLY "public"."sales_session_analytics"
491
- ADD CONSTRAINT "sales_session_analytics_pkey" PRIMARY KEY ("id");
492
-
493
-
494
-
495
- ALTER TABLE ONLY "public"."sales_users"
496
- ADD CONSTRAINT "sales_users_pkey" PRIMARY KEY ("id");
497
-
498
-
499
-
500
- ALTER TABLE ONLY "public"."sales_users"
501
- ADD CONSTRAINT "sales_users_telegram_id_bot_id_key" UNIQUE ("telegram_id", "bot_id");
502
-
503
-
504
-
505
- ALTER TABLE ONLY "public"."sales_users"
506
- ADD CONSTRAINT "sales_users_telegram_id_unique" UNIQUE ("telegram_id");
507
-
508
-
509
-
510
- ALTER TABLE ONLY "public"."session_events"
511
- ADD CONSTRAINT "session_events_pkey" PRIMARY KEY ("id");
512
-
513
-
514
-
515
- ALTER TABLE ONLY "public"."user_profiles"
516
- ADD CONSTRAINT "user_profiles_pkey" PRIMARY KEY ("telegram_id");
517
-
518
-
519
-
520
- ALTER TABLE ONLY "public"."user_profiles"
521
- ADD CONSTRAINT "user_profiles_telegram_id_key" UNIQUE ("telegram_id");
522
-
523
-
524
-
525
- CREATE INDEX "idx_admin_conversations_admin" ON "public"."admin_user_conversations" USING "btree" ("admin_id");
526
-
527
-
528
-
529
- CREATE INDEX "idx_admin_conversations_status" ON "public"."admin_user_conversations" USING "btree" ("status");
530
-
531
-
532
-
533
- CREATE INDEX "idx_admin_conversations_user" ON "public"."admin_user_conversations" USING "btree" ("user_id");
534
-
535
-
536
-
537
- CREATE INDEX "idx_sales_admins_telegram_id" ON "public"."sales_admins" USING "btree" ("telegram_id");
538
-
539
-
540
-
541
- CREATE INDEX "idx_sales_chat_sessions_bot_id" ON "public"."sales_chat_sessions" USING "btree" ("bot_id");
542
-
543
-
544
-
545
- CREATE INDEX "idx_sales_chat_sessions_bot_status" ON "public"."sales_chat_sessions" USING "btree" ("bot_id", "status");
546
-
547
-
548
-
549
- CREATE INDEX "idx_sales_chat_sessions_stage" ON "public"."sales_chat_sessions" USING "btree" ("current_stage");
550
-
551
-
552
-
553
- CREATE INDEX "idx_sales_chat_sessions_status" ON "public"."sales_chat_sessions" USING "btree" ("status");
554
-
555
-
556
-
557
- CREATE INDEX "idx_sales_chat_sessions_user_bot" ON "public"."sales_chat_sessions" USING "btree" ("user_id", "bot_id");
558
-
559
-
560
-
561
- CREATE INDEX "idx_sales_chat_sessions_user_id" ON "public"."sales_chat_sessions" USING "btree" ("user_id");
562
-
563
-
564
-
565
- CREATE INDEX "idx_sales_messages_created_at" ON "public"."sales_messages" USING "btree" ("created_at");
566
-
567
-
568
-
569
- CREATE INDEX "idx_sales_messages_metadata" ON "public"."sales_messages" USING "gin" ("ai_metadata");
570
-
571
-
572
-
573
- CREATE INDEX "idx_sales_messages_role" ON "public"."sales_messages" USING "btree" ("role");
574
-
575
-
576
-
577
- CREATE INDEX "idx_sales_messages_session_id" ON "public"."sales_messages" USING "btree" ("session_id");
578
-
579
-
580
-
581
- CREATE INDEX "idx_sales_session_analytics_session_id" ON "public"."sales_session_analytics" USING "btree" ("session_id");
582
-
583
-
584
-
585
- CREATE INDEX "idx_sales_users_bot_id" ON "public"."sales_users" USING "btree" ("bot_id");
586
-
587
-
588
-
589
- CREATE INDEX "idx_sales_users_telegram_bot" ON "public"."sales_users" USING "btree" ("telegram_id", "bot_id");
590
-
591
-
592
-
593
- CREATE INDEX "idx_session_events_session" ON "public"."session_events" USING "btree" ("session_id");
594
-
595
-
596
-
597
- CREATE INDEX "idx_session_events_type" ON "public"."session_events" USING "btree" ("event_type");
598
-
599
-
600
-
601
- CREATE OR REPLACE TRIGGER "update_sales_admins_updated_at" BEFORE UPDATE ON "public"."sales_admins" FOR EACH ROW EXECUTE FUNCTION "public"."update_updated_at_column"();
602
-
603
-
604
-
605
- CREATE OR REPLACE TRIGGER "update_sales_chat_sessions_updated_at" BEFORE UPDATE ON "public"."sales_chat_sessions" FOR EACH ROW EXECUTE FUNCTION "public"."update_updated_at_column"();
606
-
607
-
608
-
609
- CREATE OR REPLACE TRIGGER "update_sales_session_analytics_updated_at" BEFORE UPDATE ON "public"."sales_session_analytics" FOR EACH ROW EXECUTE FUNCTION "public"."update_updated_at_column"();
610
-
611
-
612
-
613
- CREATE OR REPLACE TRIGGER "update_sales_users_updated_at" BEFORE UPDATE ON "public"."sales_users" FOR EACH ROW EXECUTE FUNCTION "public"."update_updated_at_column"();
614
-
615
-
616
-
617
- CREATE OR REPLACE TRIGGER "validate_sessions_bot_id" BEFORE INSERT OR UPDATE ON "public"."sales_chat_sessions" FOR EACH ROW EXECUTE FUNCTION "public"."validate_bot_id"();
618
-
619
-
620
-
621
- CREATE OR REPLACE TRIGGER "validate_users_bot_id" BEFORE INSERT OR UPDATE ON "public"."sales_users" FOR EACH ROW EXECUTE FUNCTION "public"."validate_bot_id"();
622
-
623
-
624
-
625
- ALTER TABLE ONLY "public"."admin_user_conversations"
626
- ADD CONSTRAINT "admin_user_conversations_admin_id_fkey" FOREIGN KEY ("admin_id") REFERENCES "public"."sales_admins"("telegram_id") ON DELETE CASCADE;
627
-
628
-
629
-
630
- ALTER TABLE ONLY "public"."admin_user_conversations"
631
- ADD CONSTRAINT "admin_user_conversations_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "public"."sales_chat_sessions"("id") ON DELETE CASCADE;
632
-
633
-
634
-
635
- ALTER TABLE ONLY "public"."admin_user_conversations"
636
- ADD CONSTRAINT "admin_user_conversations_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "public"."sales_users"("telegram_id") ON DELETE CASCADE;
637
-
638
-
639
-
640
- ALTER TABLE ONLY "public"."sales_messages"
641
- ADD CONSTRAINT "sales_messages_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "public"."sales_chat_sessions"("id") ON DELETE CASCADE;
642
-
643
-
644
-
645
- ALTER TABLE ONLY "public"."sales_session_analytics"
646
- ADD CONSTRAINT "sales_session_analytics_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "public"."sales_chat_sessions"("id") ON DELETE CASCADE;
647
-
648
-
649
-
650
- ALTER TABLE ONLY "public"."session_events"
651
- ADD CONSTRAINT "session_events_session_id_fkey" FOREIGN KEY ("session_id") REFERENCES "public"."sales_chat_sessions"("id") ON DELETE CASCADE;
652
-
653
-
654
-
655
- CREATE POLICY "Enable insert for authenticated users only" ON "public"."user_profiles" FOR INSERT TO "authenticated" WITH CHECK (true);
656
-
657
-
658
-
659
- CREATE POLICY "Enable users to view their own data only" ON "public"."sales_users" FOR SELECT TO "authenticated" USING (("telegram_id" = ("current_setting"('app.current_user_id'::"text"))::bigint));
660
-
661
-
662
-
663
- CREATE POLICY "Service role can manage all admins" ON "public"."sales_admins" USING (("current_setting"('role'::"text") = 'service_role'::"text"));
664
-
665
-
666
-
667
- CREATE POLICY "Service role can manage all analytics" ON "public"."sales_session_analytics" USING (("current_setting"('role'::"text", true) = 'service_role'::"text"));
668
-
669
-
670
-
671
- CREATE POLICY "Service role can manage all conversations" ON "public"."admin_user_conversations" USING (("current_setting"('role'::"text") = 'service_role'::"text"));
672
-
673
-
674
-
675
- CREATE POLICY "Service role can manage all events" ON "public"."session_events" USING (("current_setting"('role'::"text") = 'service_role'::"text"));
676
-
677
-
678
-
679
- CREATE POLICY "Service role can manage all messages" ON "public"."sales_messages" USING (("current_setting"('role'::"text", true) = 'service_role'::"text"));
680
-
681
-
682
-
683
- CREATE POLICY "Service role can manage all sessions" ON "public"."sales_chat_sessions" USING (("current_setting"('role'::"text") = 'service_role'::"text"));
684
-
685
-
686
-
687
- CREATE POLICY "Service role can manage all users" ON "public"."sales_users" USING (("current_setting"('role'::"text") = 'service_role'::"text"));
688
-
689
-
690
-
691
- CREATE POLICY "Users can view analytics for their sessions" ON "public"."sales_session_analytics" FOR SELECT USING (("session_id" IN ( SELECT "sales_chat_sessions"."id"
692
- FROM "public"."sales_chat_sessions"
693
- WHERE (("sales_chat_sessions"."user_id" = ("current_setting"('app.current_user_id'::"text", true))::bigint) AND ("sales_chat_sessions"."bot_id" = "current_setting"('app.current_bot_id'::"text", true))))));
694
-
695
-
696
-
697
- CREATE POLICY "Users can view messages from their sessions" ON "public"."sales_messages" FOR SELECT USING (("session_id" IN ( SELECT "sales_chat_sessions"."id"
698
- FROM "public"."sales_chat_sessions"
699
- WHERE (("sales_chat_sessions"."user_id" = ("current_setting"('app.current_user_id'::"text"))::bigint) AND ("sales_chat_sessions"."bot_id" = "current_setting"('app.current_bot_id'::"text", true))))));
700
-
701
-
702
-
703
- CREATE POLICY "Users can view their own data" ON "public"."sales_users" FOR SELECT USING ((("telegram_id" = ("current_setting"('app.current_user_id'::"text"))::bigint) AND ("bot_id" = "current_setting"('app.current_bot_id'::"text", true))));
704
-
705
-
706
-
707
- CREATE POLICY "Users can view their own sessions" ON "public"."sales_chat_sessions" FOR SELECT USING ((("user_id" = ("current_setting"('app.current_user_id'::"text"))::bigint) AND ("bot_id" = "current_setting"('app.current_bot_id'::"text", true))));
708
-
709
-
710
-
711
- ALTER TABLE "public"."admin_user_conversations" ENABLE ROW LEVEL SECURITY;
712
-
713
-
714
- ALTER TABLE "public"."sales_admins" ENABLE ROW LEVEL SECURITY;
715
-
716
-
717
- ALTER TABLE "public"."sales_chat_sessions" ENABLE ROW LEVEL SECURITY;
718
-
719
-
720
- ALTER TABLE "public"."sales_messages" ENABLE ROW LEVEL SECURITY;
721
-
722
-
723
- ALTER TABLE "public"."sales_session_analytics" ENABLE ROW LEVEL SECURITY;
724
-
725
-
726
- ALTER TABLE "public"."sales_users" ENABLE ROW LEVEL SECURITY;
727
-
728
-
729
- ALTER TABLE "public"."session_events" ENABLE ROW LEVEL SECURITY;
730
-
731
-
732
- ALTER TABLE "public"."user_profiles" ENABLE ROW LEVEL SECURITY;
733
-
734
-
735
-
736
-
737
- ALTER PUBLICATION "supabase_realtime" OWNER TO "postgres";
738
-
739
-
740
- GRANT USAGE ON SCHEMA "public" TO "postgres";
741
- GRANT USAGE ON SCHEMA "public" TO "anon";
742
- GRANT USAGE ON SCHEMA "public" TO "authenticated";
743
- GRANT USAGE ON SCHEMA "public" TO "service_role";
744
-
745
-
746
-
747
-
748
-
749
-
750
-
751
-
752
-
753
-
754
-
755
-
756
-
757
-
758
-
759
-
760
-
761
-
762
-
763
-
764
-
765
-
766
-
767
-
768
-
769
-
770
-
771
-
772
-
773
-
774
-
775
-
776
-
777
-
778
-
779
-
780
-
781
-
782
-
783
-
784
-
785
-
786
-
787
-
788
-
789
-
790
-
791
-
792
-
793
-
794
-
795
-
796
-
797
-
798
-
799
-
800
-
801
-
802
-
803
-
804
-
805
-
806
-
807
-
808
-
809
-
810
-
811
-
812
-
813
-
814
-
815
-
816
-
817
-
818
-
819
-
820
-
821
-
822
-
823
-
824
-
825
-
826
-
827
-
828
-
829
-
830
-
831
-
832
-
833
-
834
-
835
-
836
-
837
-
838
-
839
-
840
-
841
-
842
-
843
-
844
-
845
-
846
-
847
-
848
-
849
-
850
-
851
-
852
-
853
-
854
-
855
-
856
-
857
-
858
-
859
-
860
-
861
-
862
-
863
-
864
-
865
-
866
-
867
-
868
-
869
-
870
-
871
-
872
-
873
-
874
-
875
-
876
-
877
-
878
-
879
-
880
-
881
-
882
-
883
-
884
-
885
-
886
-
887
-
888
-
889
-
890
-
891
-
892
-
893
-
894
-
895
-
896
-
897
- GRANT ALL ON FUNCTION "public"."cleanup_old_messages"("days_to_keep" integer) TO "anon";
898
- GRANT ALL ON FUNCTION "public"."cleanup_old_messages"("days_to_keep" integer) TO "authenticated";
899
- GRANT ALL ON FUNCTION "public"."cleanup_old_messages"("days_to_keep" integer) TO "service_role";
900
-
901
-
902
-
903
- GRANT ALL ON FUNCTION "public"."end_expired_admin_conversations"() TO "anon";
904
- GRANT ALL ON FUNCTION "public"."end_expired_admin_conversations"() TO "authenticated";
905
- GRANT ALL ON FUNCTION "public"."end_expired_admin_conversations"() TO "service_role";
906
-
907
-
908
-
909
- GRANT ALL ON FUNCTION "public"."update_updated_at_column"() TO "anon";
910
- GRANT ALL ON FUNCTION "public"."update_updated_at_column"() TO "authenticated";
911
- GRANT ALL ON FUNCTION "public"."update_updated_at_column"() TO "service_role";
912
-
913
-
914
-
915
- GRANT ALL ON FUNCTION "public"."validate_bot_id"() TO "anon";
916
- GRANT ALL ON FUNCTION "public"."validate_bot_id"() TO "authenticated";
917
- GRANT ALL ON FUNCTION "public"."validate_bot_id"() TO "service_role";
918
-
919
-
920
-
921
-
922
-
923
-
924
-
925
-
926
-
927
-
928
-
929
-
930
-
931
-
932
-
933
-
934
-
935
-
936
- GRANT ALL ON TABLE "public"."admin_user_conversations" TO "anon";
937
- GRANT ALL ON TABLE "public"."admin_user_conversations" TO "authenticated";
938
- GRANT ALL ON TABLE "public"."admin_user_conversations" TO "service_role";
939
-
940
-
941
-
942
- GRANT ALL ON TABLE "public"."session_events" TO "anon";
943
- GRANT ALL ON TABLE "public"."session_events" TO "authenticated";
944
- GRANT ALL ON TABLE "public"."session_events" TO "service_role";
945
-
946
-
947
-
948
- GRANT ALL ON TABLE "public"."daily_events" TO "anon";
949
- GRANT ALL ON TABLE "public"."daily_events" TO "authenticated";
950
- GRANT ALL ON TABLE "public"."daily_events" TO "service_role";
951
-
952
-
953
-
954
- GRANT ALL ON TABLE "public"."sales_chat_sessions" TO "anon";
955
- GRANT ALL ON TABLE "public"."sales_chat_sessions" TO "authenticated";
956
- GRANT ALL ON TABLE "public"."sales_chat_sessions" TO "service_role";
957
-
958
-
959
-
960
- GRANT ALL ON TABLE "public"."funnel_stats" TO "anon";
961
- GRANT ALL ON TABLE "public"."funnel_stats" TO "authenticated";
962
- GRANT ALL ON TABLE "public"."funnel_stats" TO "service_role";
963
-
964
-
965
-
966
- GRANT ALL ON TABLE "public"."sales_admins" TO "anon";
967
- GRANT ALL ON TABLE "public"."sales_admins" TO "authenticated";
968
- GRANT ALL ON TABLE "public"."sales_admins" TO "service_role";
969
-
970
-
971
-
972
- GRANT ALL ON SEQUENCE "public"."sales_admins_id_seq" TO "anon";
973
- GRANT ALL ON SEQUENCE "public"."sales_admins_id_seq" TO "authenticated";
974
- GRANT ALL ON SEQUENCE "public"."sales_admins_id_seq" TO "service_role";
975
-
976
-
977
-
978
- GRANT ALL ON TABLE "public"."sales_messages" TO "anon";
979
- GRANT ALL ON TABLE "public"."sales_messages" TO "authenticated";
980
- GRANT ALL ON TABLE "public"."sales_messages" TO "service_role";
981
-
982
-
983
-
984
- GRANT ALL ON SEQUENCE "public"."sales_messages_id_seq" TO "anon";
985
- GRANT ALL ON SEQUENCE "public"."sales_messages_id_seq" TO "authenticated";
986
- GRANT ALL ON SEQUENCE "public"."sales_messages_id_seq" TO "service_role";
987
-
988
-
989
-
990
- GRANT ALL ON TABLE "public"."sales_session_analytics" TO "anon";
991
- GRANT ALL ON TABLE "public"."sales_session_analytics" TO "authenticated";
992
- GRANT ALL ON TABLE "public"."sales_session_analytics" TO "service_role";
993
-
994
-
995
-
996
- GRANT ALL ON SEQUENCE "public"."sales_session_analytics_id_seq" TO "anon";
997
- GRANT ALL ON SEQUENCE "public"."sales_session_analytics_id_seq" TO "authenticated";
998
- GRANT ALL ON SEQUENCE "public"."sales_session_analytics_id_seq" TO "service_role";
999
-
1000
-
1001
-
1002
- GRANT ALL ON TABLE "public"."sales_users" TO "anon";
1003
- GRANT ALL ON TABLE "public"."sales_users" TO "authenticated";
1004
- GRANT ALL ON TABLE "public"."sales_users" TO "service_role";
1005
-
1006
-
1007
-
1008
- GRANT ALL ON SEQUENCE "public"."sales_users_id_seq" TO "anon";
1009
- GRANT ALL ON SEQUENCE "public"."sales_users_id_seq" TO "authenticated";
1010
- GRANT ALL ON SEQUENCE "public"."sales_users_id_seq" TO "service_role";
1011
-
1012
-
1013
-
1014
- GRANT ALL ON SEQUENCE "public"."session_events_id_seq" TO "anon";
1015
- GRANT ALL ON SEQUENCE "public"."session_events_id_seq" TO "authenticated";
1016
- GRANT ALL ON SEQUENCE "public"."session_events_id_seq" TO "service_role";
1017
-
1018
-
1019
-
1020
- GRANT ALL ON TABLE "public"."user_profiles" TO "anon";
1021
- GRANT ALL ON TABLE "public"."user_profiles" TO "authenticated";
1022
- GRANT ALL ON TABLE "public"."user_profiles" TO "service_role";
1023
-
1024
-
1025
-
1026
- GRANT ALL ON SEQUENCE "public"."user_profiles_id_seq" TO "anon";
1027
- GRANT ALL ON SEQUENCE "public"."user_profiles_id_seq" TO "authenticated";
1028
- GRANT ALL ON SEQUENCE "public"."user_profiles_id_seq" TO "service_role";
1029
-
1030
-
1031
-
1032
-
1033
-
1034
-
1035
-
1036
-
1037
-
1038
- ALTER DEFAULT PRIVILEGES FOR ROLE "postgres" IN SCHEMA "public" GRANT ALL ON SEQUENCES TO "postgres";
1039
- ALTER DEFAULT PRIVILEGES FOR ROLE "postgres" IN SCHEMA "public" GRANT ALL ON SEQUENCES TO "anon";
1040
- ALTER DEFAULT PRIVILEGES FOR ROLE "postgres" IN SCHEMA "public" GRANT ALL ON SEQUENCES TO "authenticated";
1041
- ALTER DEFAULT PRIVILEGES FOR ROLE "postgres" IN SCHEMA "public" GRANT ALL ON SEQUENCES TO "service_role";
1042
-
1043
-
1044
-
1045
-
1046
-
1047
-
1048
- ALTER DEFAULT PRIVILEGES FOR ROLE "postgres" IN SCHEMA "public" GRANT ALL ON FUNCTIONS TO "postgres";
1049
- ALTER DEFAULT PRIVILEGES FOR ROLE "postgres" IN SCHEMA "public" GRANT ALL ON FUNCTIONS TO "anon";
1050
- ALTER DEFAULT PRIVILEGES FOR ROLE "postgres" IN SCHEMA "public" GRANT ALL ON FUNCTIONS TO "authenticated";
1051
- ALTER DEFAULT PRIVILEGES FOR ROLE "postgres" IN SCHEMA "public" GRANT ALL ON FUNCTIONS TO "service_role";
1052
-
1053
-
1054
-
1055
-
1056
-
1057
-
1058
- ALTER DEFAULT PRIVILEGES FOR ROLE "postgres" IN SCHEMA "public" GRANT ALL ON TABLES TO "postgres";
1059
- ALTER DEFAULT PRIVILEGES FOR ROLE "postgres" IN SCHEMA "public" GRANT ALL ON TABLES TO "anon";
1060
- ALTER DEFAULT PRIVILEGES FOR ROLE "postgres" IN SCHEMA "public" GRANT ALL ON TABLES TO "authenticated";
1061
- ALTER DEFAULT PRIVILEGES FOR ROLE "postgres" IN SCHEMA "public" GRANT ALL ON TABLES TO "service_role";
1062
-
1063
-
1064
-
1065
-
1066
-
1067
-
1068
-
1069
-
1070
-
1071
-
1072
-
1073
-
1074
-
1075
-
1076
-
1077
-
1078
-
1079
-
1080
-
1081
-
1082
-
1083
-
1084
-
1085
-
1086
-
1087
-
1088
-
1089
-
1090
-
1091
-
1092
- \unrestrict WBtltrfyEEoF24oRSfGBapNcgKliB6xSV8AgT2uO2cKxNSkoUuc9InlJ2lBPCQx
1093
-
1094
- RESET ALL;