smart-bot-factory 0.3.1__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.
- smart_bot_factory/admin/__init__.py +2 -0
- smart_bot_factory/admin/admin_events.py +757 -0
- smart_bot_factory/admin/admin_logic.py +54 -12
- smart_bot_factory/aiogram_calendar/__init__.py +6 -0
- smart_bot_factory/aiogram_calendar/common.py +70 -0
- smart_bot_factory/aiogram_calendar/dialog_calendar.py +197 -0
- smart_bot_factory/aiogram_calendar/schemas.py +78 -0
- smart_bot_factory/aiogram_calendar/simple_calendar.py +180 -0
- smart_bot_factory/analytics/analytics_manager.py +42 -5
- smart_bot_factory/cli.py +1 -1
- smart_bot_factory/core/bot_utils.py +17 -16
- smart_bot_factory/core/decorators.py +215 -4
- smart_bot_factory/core/states.py +12 -0
- smart_bot_factory/creation/bot_builder.py +54 -2
- smart_bot_factory/handlers/handlers.py +388 -4
- smart_bot_factory/integrations/openai_client.py +29 -1
- smart_bot_factory/integrations/supabase_client.py +413 -37
- smart_bot_factory/utm_link_generator.py +13 -3
- {smart_bot_factory-0.3.1.dist-info → smart_bot_factory-0.3.3.dist-info}/METADATA +26 -17
- {smart_bot_factory-0.3.1.dist-info → smart_bot_factory-0.3.3.dist-info}/RECORD +23 -19
- smart_bot_factory/table/database_structure.sql +0 -57
- smart_bot_factory/table/schema.sql +0 -1094
- {smart_bot_factory-0.3.1.dist-info → smart_bot_factory-0.3.3.dist-info}/WHEEL +0 -0
- {smart_bot_factory-0.3.1.dist-info → smart_bot_factory-0.3.3.dist-info}/entry_points.txt +0 -0
- {smart_bot_factory-0.3.1.dist-info → smart_bot_factory-0.3.3.dist-info}/licenses/LICENSE +0 -0
|
@@ -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;
|