mirror of
https://github.com/abhinavxd/libredesk.git
synced 2025-11-02 13:03:35 +00:00
WIP: MVP with shadcn sidebar
- csat - SLA - email notification templates
This commit is contained in:
234
schema.sql
234
schema.sql
@@ -4,34 +4,79 @@ DROP TYPE IF EXISTS "message_type" CASCADE; CREATE TYPE "message_type" AS ENUM (
|
||||
DROP TYPE IF EXISTS "message_sender_type" CASCADE; CREATE TYPE "message_sender_type" AS ENUM ('user','contact');
|
||||
DROP TYPE IF EXISTS "message_status" CASCADE; CREATE TYPE "message_status" AS ENUM ('received','sent','failed','pending');
|
||||
DROP TYPE IF EXISTS "content_type" CASCADE; CREATE TYPE "content_type" AS ENUM ('text','html');
|
||||
DROP TYPE IF EXISTS "sla_status" CASCADE; CREATE TYPE "sla_status" AS ENUM ('active','missed');
|
||||
DROP TYPE IF EXISTS "conversation_assignment_type" CASCADE; CREATE TYPE "conversation_assignment_type" AS ENUM ('Round robin','Manual');
|
||||
DROP TYPE IF EXISTS "sla_type" CASCADE; CREATE TYPE "sla_type" AS ENUM ('first_response','resolution');
|
||||
DROP TYPE IF EXISTS "template_type" CASCADE; CREATE TYPE "template_type" AS ENUM ('email_outgoing', 'email_notification');
|
||||
DROP TYPE IF EXISTS "user_type" CASCADE; CREATE TYPE "user_type" AS ENUM ('agent', 'contact');
|
||||
|
||||
DROP TABLE IF EXISTS conversation_slas CASCADE;
|
||||
CREATE TABLE conversation_slas (
|
||||
id SERIAL PRIMARY KEY,
|
||||
created_at TIMESTAMPTZ DEFAULT NOW() NOT NULL,
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW() NOT NULL,
|
||||
conversation_id BIGINT NOT NULL REFERENCES conversations(id),
|
||||
sla_policy_id INT NOT NULL REFERENCES sla_policies(id),
|
||||
sla_type sla_type NOT NULL,
|
||||
due_at TIMESTAMPTZ NULL,
|
||||
met_at TIMESTAMPTZ NULL,
|
||||
breached_at TIMESTAMPTZ NULL,
|
||||
CONSTRAINT constraint_conversation_slas_unique UNIQUE (sla_policy_id, conversation_id, sla_type)
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS teams CASCADE;
|
||||
CREATE TABLE teams (
|
||||
id SERIAL PRIMARY KEY,
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
"name" VARCHAR(140) NOT NULL,
|
||||
"name" TEXT NOT NULL,
|
||||
emoji TEXT NULL,
|
||||
disabled bool DEFAULT false NOT NULL,
|
||||
auto_assign_conversations bool DEFAULT false NOT NULL,
|
||||
conversation_assignment_type conversation_assignment_type NOT NULL,
|
||||
business_hours_id INT REFERENCES business_hours(id) ON DELETE SET NULL ON UPDATE CASCADE NOT NULL,
|
||||
timezone TEXT NULL,
|
||||
CONSTRAINT constraint_teams_on_emoji CHECK (length(emoji) <= 1),
|
||||
CONSTRAINT constraint_teams_on_name CHECK (length("name") <= 140),
|
||||
CONSTRAINT constraint_teams_on_timezone CHECK (length(timezone) <= 50),
|
||||
CONSTRAINT constraint_teams_on_name_unique UNIQUE ("name")
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS users CASCADE;
|
||||
CREATE TABLE users (
|
||||
id SERIAL PRIMARY KEY,
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
type user_type NOT NULL,
|
||||
deleted_at TIMESTAMPTZ NULL,
|
||||
disabled bool DEFAULT false NOT NULL,
|
||||
email TEXT NULL,
|
||||
first_name TEXT NOT NULL,
|
||||
last_name TEXT NULL,
|
||||
phone_number TEXT NULL,
|
||||
country TEXT NULL,
|
||||
"password" VARCHAR(150) NULL,
|
||||
avatar_url TEXT NULL,
|
||||
roles TEXT[] DEFAULT '{}'::TEXT[] NULL,
|
||||
reset_password_token TEXT NULL,
|
||||
reset_password_token_expiry TIMESTAMPTZ NULL,
|
||||
CONSTRAINT constraint_users_on_email_unique UNIQUE (email),
|
||||
CONSTRAINT constraint_users_on_country CHECK (length(country) <= 140),
|
||||
CONSTRAINT constraint_users_on_phone_number CHECK (length(phone_number) <= 20),
|
||||
CONSTRAINT constraint_users_on_email_length CHECK (length(email) <= 320),
|
||||
CONSTRAINT constraint_users_on_first_name CHECK (length(first_name) <= 140),
|
||||
CONSTRAINT constraint_users_on_last_name CHECK (length(last_name) <= 140)
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS contact_channels CASCADE;
|
||||
CREATE TABLE contact_channels (
|
||||
id SERIAL PRIMARY KEY,
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
deleted_at TIMESTAMPTZ NULL,
|
||||
disabled bool DEFAULT false NOT NULL,
|
||||
email VARCHAR(254) NOT NULL,
|
||||
first_name VARCHAR(100) NOT NULL,
|
||||
last_name VARCHAR(100) NULL,
|
||||
"password" VARCHAR(150) NULL,
|
||||
avatar_url TEXT NULL,
|
||||
roles _text DEFAULT '{}'::text [] NOT NULL,
|
||||
reset_password_token TEXT NULL,
|
||||
reset_password_token_expiry TIMESTAMPTZ NULL,
|
||||
CONSTRAINT constraint_users_on_email_unique UNIQUE (email)
|
||||
contact_id INT NOT NULL REFERENCES users(id) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||
inbox_id INT NOT NULL REFERENCES inboxes(id) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||
identifier TEXT NOT NULL,
|
||||
CONSTRAINT constraint_contact_channels_on_identifier CHECK (length(identifier) <= 1000),
|
||||
CONSTRAINT constraint_contact_channels_on_inbox_id_and_contact_id_unique UNIQUE (inbox_id, contact_id)
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS conversation_statuses CASCADE;
|
||||
@@ -58,18 +103,26 @@ CREATE TABLE conversations (
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
"uuid" UUID DEFAULT gen_random_uuid() NOT NULL,
|
||||
reference_number TEXT UNIQUE NOT NULL,
|
||||
reference_number BIGSERIAL UNIQUE,
|
||||
contact_id BIGINT NOT NULL,
|
||||
contact_channel_id INT REFERENCES contact_channels(id) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||
assigned_user_id INT REFERENCES users(id) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||
assigned_team_id INT REFERENCES teams(id) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||
inbox_id INT NOT NULL,
|
||||
meta JSONB DEFAULT '{}'::JSON NOT NULL,
|
||||
meta JSONB DEFAULT '{}'::jsonb NOT NULL,
|
||||
custom_attributes JSONB DEFAULT '{}'::jsonb NOT NULL,
|
||||
assignee_last_seen_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
first_reply_at TIMESTAMPTZ NULL,
|
||||
closed_at TIMESTAMPTZ NULL,
|
||||
resolved_at TIMESTAMPTZ NULL,
|
||||
status_id INT REFERENCES conversation_statuses(id),
|
||||
priority_id INT REFERENCES conversation_priorities(id)
|
||||
priority_id INT REFERENCES conversation_priorities(id),
|
||||
sla_policy_id INT REFERENCES sla_policies(id) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||
"subject" TEXT NULL,
|
||||
last_message_at TIMESTAMPTZ NULL,
|
||||
last_message TEXT NULL,
|
||||
next_sla_deadline_at TIMESTAMPTZ NULL,
|
||||
snoozed_until TIMESTAMPTZ NULL
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS conversation_messages CASCADE;
|
||||
@@ -85,7 +138,7 @@ CREATE TABLE conversation_messages (
|
||||
content_type content_type NULL,
|
||||
"content" TEXT NULL,
|
||||
source_id TEXT NULL,
|
||||
sender_id INT NULL,
|
||||
sender_id INT REFERENCES users(id) NULL,
|
||||
sender_type message_sender_type NOT NULL,
|
||||
meta JSONB DEFAULT '{}'::JSONB NULL
|
||||
);
|
||||
@@ -95,13 +148,13 @@ CREATE TABLE automation_rules (
|
||||
id SERIAL PRIMARY KEY,
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
"name" VARCHAR(255) NOT NULL,
|
||||
"name" TEXT NOT NULL,
|
||||
description TEXT NULL,
|
||||
"type" VARCHAR NOT NULL,
|
||||
rules JSONB NULL,
|
||||
events TEXT[] NULL,
|
||||
events TEXT[] DEFAULT '{}'::TEXT[] NOT NULL,
|
||||
disabled BOOL DEFAULT false NOT NULL,
|
||||
CONSTRAINT constraint_automation_rules_on_name CHECK (length("name") <= 100),
|
||||
CONSTRAINT constraint_automation_rules_on_name CHECK (length("name") <= 140),
|
||||
CONSTRAINT constraint_automation_rules_on_description CHECK (length(description) <= 300)
|
||||
);
|
||||
|
||||
@@ -112,36 +165,16 @@ CREATE TABLE canned_responses (
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
title TEXT NOT NULL,
|
||||
"content" TEXT NOT NULL,
|
||||
CONSTRAINT constraint_canned_responses_on_title CHECK (length(title) <= 100),
|
||||
CONSTRAINT constraint_canned_responses_on_title CHECK (length(title) <= 140),
|
||||
CONSTRAINT constraint_canned_responses_on_content CHECK (length("content") <= 5000)
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS contacts CASCADE;
|
||||
CREATE TABLE contacts (
|
||||
id BIGSERIAL PRIMARY KEY,
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
first_name TEXT NULL,
|
||||
last_name TEXT NULL,
|
||||
email VARCHAR(254) NULL,
|
||||
phone_number TEXT NULL,
|
||||
avatar_url TEXT NULL,
|
||||
inbox_id INT NULL,
|
||||
source_id TEXT NULL,
|
||||
CONSTRAINT constraint_contacts_on_first_name CHECK (length(first_name) <= 100),
|
||||
CONSTRAINT constraint_contacts_on_last_name CHECK (length(last_name) <= 100),
|
||||
CONSTRAINT constraint_contacts_on_email CHECK (length(email) <= 254),
|
||||
CONSTRAINT constraint_contacts_on_phone_number CHECK (length(phone_number) <= 50),
|
||||
CONSTRAINT constraint_contacts_on_avatar_url CHECK (length(avatar_url) <= 1000),
|
||||
CONSTRAINT constraint_contacts_on_source_id CHECK (length(source_id) <= 5000)
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS conversation_participants CASCADE;
|
||||
CREATE TABLE conversation_participants (
|
||||
id BIGSERIAL PRIMARY KEY,
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
user_id INT NOT NULL,
|
||||
user_id INT REFERENCES users(id) ON DELETE CASCADE ON UPDATE CASCADE NOT NULL,
|
||||
conversation_id BIGINT REFERENCES conversations(id) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||
CONSTRAINT constraint_conversation_participants_conversation_id_and_user_id_unique UNIQUE (conversation_id, user_id)
|
||||
);
|
||||
@@ -175,7 +208,7 @@ CREATE TABLE media (
|
||||
"size" INT NULL,
|
||||
meta jsonb DEFAULT '{}'::jsonb NOT NULL,
|
||||
CONSTRAINT constraint_media_on_filename CHECK (length(filename) <= 1000),
|
||||
CONSTRAINT constraint_media_on_content_id CHECK (length(content_id) <= 100)
|
||||
CONSTRAINT constraint_media_on_content_id CHECK (length(content_id) <= 300)
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS oidc CASCADE;
|
||||
@@ -201,14 +234,6 @@ CREATE TABLE roles (
|
||||
description TEXT NULL
|
||||
);
|
||||
|
||||
-- Roles.
|
||||
INSERT INTO roles
|
||||
(permissions, "name", description)
|
||||
VALUES('{conversations:read,conversations:read_unassigned,conversations:read_assigned,conversations:update_user_assignee,conversations:update_team_assignee,conversations:update_priority,conversations:update_status,conversations:update_tags,messages:read,messages:write}', 'Agent', 'Role for all agents with limited access to conversations.');
|
||||
INSERT INTO roles
|
||||
(permissions, "name", description)
|
||||
VALUES('{conversations:read_unassigned,teams:delete,users:delete,conversations:read_all,conversations:read,conversations:read_assigned,conversations:update_user_assignee,conversations:update_team_assignee,conversations:update_priority,conversations:update_status,conversations:update_tags,messages:read,messages:write,templates:write,templates:read,roles:delete,roles:write,roles:read,inboxes:delete,inboxes:write,inboxes:read,automations:write,automations:delete,automations:read,teams:write,teams:read,users:write,users:read,dashboard_global:read,canned_responses:delete,tags:delete,canned_responses:write,tags:write,status:delete,status:write,status:read,oidc:delete,oidc:read,oidc:write,settings_notifications:read,settings_notifications:write,settings_general:write,templates:delete,admin:read}', 'Admin', 'Role for users who have complete access to everything.');
|
||||
|
||||
DROP TABLE IF EXISTS settings CASCADE;
|
||||
CREATE TABLE settings (
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
@@ -233,8 +258,10 @@ CREATE TABLE team_members (
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
team_id INT REFERENCES teams(id) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||
user_id INT NOT NULL,
|
||||
CONSTRAINT constraint_team_members_on_team_id_and_user_id_unique UNIQUE (team_id, user_id)
|
||||
user_id INT REFERENCES users(id) ON DELETE CASCADE ON UPDATE CASCADE NOT NULL,
|
||||
emoji TEXT NULL,
|
||||
CONSTRAINT constraint_team_members_on_team_id_and_user_id_unique UNIQUE (team_id, user_id),
|
||||
CONSTRAINT constraint_team_members_on_emoji CHECK (length(emoji) <= 1)
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS templates CASCADE;
|
||||
@@ -242,25 +269,18 @@ CREATE TABLE templates (
|
||||
id SERIAL PRIMARY KEY,
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
type template_type NOT NULL,
|
||||
body TEXT NOT NULL,
|
||||
is_default bool DEFAULT false NOT NULL,
|
||||
"name" TEXT NULL
|
||||
"name" TEXT NOT NULL,
|
||||
subject TEXT NULL,
|
||||
is_builtin bool DEFAULT false NOT NULL,
|
||||
CONSTRAINT constraint_templates_on_name CHECK (length("name") <= 140),
|
||||
CONSTRAINT constraint_templates_on_subject CHECK (length(subject) <= 1000)
|
||||
);
|
||||
CREATE UNIQUE INDEX unique_index_templates_on_is_default_when_is_default_is_true ON templates USING btree (is_default)
|
||||
WHERE (is_default = true);
|
||||
|
||||
DROP TABLE IF EXISTS contact_methods CASCADE;
|
||||
CREATE TABLE contact_methods (
|
||||
id BIGSERIAL PRIMARY KEY,
|
||||
contact_id BIGINT REFERENCES contacts(id) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||
"source" TEXT NOT NULL,
|
||||
source_id TEXT NOT NULL,
|
||||
inbox_id INT NULL,
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
CONSTRAINT constraint_contact_methods_on_source_and_source_id_unique UNIQUE (contact_id, source_id)
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS conversation_tags CASCADE;
|
||||
CREATE TABLE conversation_tags (
|
||||
id BIGSERIAL PRIMARY KEY,
|
||||
@@ -271,29 +291,85 @@ CREATE TABLE conversation_tags (
|
||||
CONSTRAINT constraint_conversation_tags_on_conversation_id_and_tag_id_unique UNIQUE (conversation_id, tag_id)
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS csat_responses CASCADE;
|
||||
CREATE TABLE csat_responses (
|
||||
id SERIAL PRIMARY KEY,
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
uuid UUID DEFAULT gen_random_uuid(),
|
||||
conversation_id BIGSERIAL REFERENCES conversations(id) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||
assigned_agent_id INT REFERENCES users(id) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||
rating INT DEFAULT 0 NOT NULL,
|
||||
feedback TEXT NULL,
|
||||
response_timestamp TIMESTAMPTZ NULL,
|
||||
CONSTRAINT constraint_csat_responses_on_rating CHECK (rating >= 0 AND rating <= 5),
|
||||
CONSTRAINT constraint_csat_responses_on_feedback CHECK (length(feedback) <= 1000),
|
||||
CONSTRAINT constraint_csat_responses_conversation_and_assigned_agent_unique UNIQUE (conversation_id, assigned_agent_id)
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS business_hours CASCADE;
|
||||
CREATE TABLE business_hours (
|
||||
id SERIAL PRIMARY KEY,
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
name TEXT NOT NULL,
|
||||
description TEXT NULL,
|
||||
is_always_open BOOL DEFAULT false NOT NULL,
|
||||
hours JSONB NOT NULL,
|
||||
holidays JSONB DEFAULT '{}'::jsonb NOT NULL,
|
||||
CONSTRAINT constraint_business_hours_on_name CHECK (length(name) <= 140)
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS sla_policies CASCADE;
|
||||
CREATE TABLE sla_policies (
|
||||
id SERIAL PRIMARY KEY,
|
||||
created_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
||||
name TEXT NOT NULL,
|
||||
description TEXT NULL,
|
||||
first_response_time TEXT NOT NULL,
|
||||
resolution_time TEXT NOT NULL,
|
||||
CONSTRAINT constraint_sla_policies_on_name CHECK (length(name) <= 140)
|
||||
);
|
||||
|
||||
DROP TABLE IF EXISTS views CASCADE;
|
||||
CREATE TABLE views (
|
||||
id SERIAL PRIMARY KEY,
|
||||
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
||||
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
||||
inbox_type TEXT NOT NULL,
|
||||
name TEXT NOT NULL,
|
||||
filters JSONB NOT NULL,
|
||||
user_id INT NOT NULL REFERENCES users (id) ON DELETE CASCADE,
|
||||
CONSTRAINT constraint_views_on_name CHECK (length(name) <= 140),
|
||||
CONSTRAINT constraint_views_on_inbox_type CHECK (length(inbox_type) <= 140)
|
||||
);
|
||||
|
||||
-- Default settings
|
||||
INSERT INTO settings ("key", value)
|
||||
VALUES
|
||||
('app.lang', '"en"'::jsonb),
|
||||
('app.root_url', '"http://localhost:9000"'::jsonb),
|
||||
('app.logo_url', '""'::jsonb),
|
||||
('app.logo_url', '"http://localhost:9000/logo.png"'::jsonb),
|
||||
('app.site_name', '"Helpdesk"'::jsonb),
|
||||
('app.favicon_url', '"http://localhost:9000/favicon.ico"'::jsonb),
|
||||
('app.max_file_upload_size', '20'::jsonb),
|
||||
('app.allowed_file_upload_extensions', '["*"]'::jsonb),
|
||||
('app.timezone', '"Asia/Calcutta"'::jsonb),
|
||||
('app.business_hours_id', '""'::jsonb),
|
||||
('notification.email.username', '"admin@yourcompany.com"'::jsonb),
|
||||
('notification.email.host', '""'::jsonb),
|
||||
('notification.email.host', '"smtp.google.com"'::jsonb),
|
||||
('notification.email.port', '587'::jsonb),
|
||||
('notification.email.password', '""'::jsonb),
|
||||
('notification.email.max_conns', '1'::jsonb),
|
||||
('notification.email.idle_timeout', '"5s"'::jsonb),
|
||||
('notification.email.wait_timeout', '"5s"'::jsonb),
|
||||
('notification.email.auth_protocol', '"Plain"'::jsonb),
|
||||
('notification.email.email_address', '""'::jsonb),
|
||||
('notification.email.auth_protocol', '"plain"'::jsonb),
|
||||
('notification.email.email_address', '"admin@yourcompany.com"'::jsonb),
|
||||
('notification.email.max_msg_retries', '3'::jsonb),
|
||||
('notification.email.enabled', 'false'::jsonb);
|
||||
|
||||
|
||||
-- Default conversation priorities
|
||||
INSERT INTO conversation_priorities
|
||||
("name")
|
||||
VALUES('Low');
|
||||
@@ -304,6 +380,8 @@ INSERT INTO conversation_priorities
|
||||
("name")
|
||||
VALUES('High');
|
||||
|
||||
|
||||
-- Default conversation statuses
|
||||
INSERT INTO conversation_statuses
|
||||
("name")
|
||||
VALUES('Open');
|
||||
@@ -315,4 +393,16 @@ INSERT INTO conversation_statuses
|
||||
VALUES('Resolved');
|
||||
INSERT INTO conversation_statuses
|
||||
("name")
|
||||
VALUES('Closed');
|
||||
VALUES('Closed');
|
||||
INSERT INTO conversation_statuses
|
||||
("name")
|
||||
VALUES('Snoozed');
|
||||
|
||||
-- Default roles
|
||||
INSERT INTO roles
|
||||
(permissions, "name", description)
|
||||
VALUES('{conversations:read,conversations:read_unassigned,conversations:read_assigned,conversations:update_user_assignee,conversations:update_team_assignee,conversations:update_priority,conversations:update_status,conversations:update_tags,messages:read,messages:write}', 'Agent', 'Role for all agents with limited access to conversations.');
|
||||
|
||||
INSERT INTO roles
|
||||
(permissions, "name", description)
|
||||
VALUES('{conversations:read_unassigned,teams:delete,users:delete,conversations:read_all,conversations:read,conversations:read_assigned,conversations:update_user_assignee,conversations:update_team_assignee,conversations:update_priority,conversations:update_status,conversations:update_tags,messages:read,messages:write,templates:write,templates:read,roles:delete,roles:write,roles:read,inboxes:delete,inboxes:write,inboxes:read,automations:write,automations:delete,automations:read,teams:write,teams:read,users:write,users:read,dashboard_global:read,canned_responses:delete,tags:delete,canned_responses:write,tags:write,status:delete,status:write,status:read,oidc:delete,oidc:read,oidc:write,settings_notifications:read,settings_notifications:write,settings_general:write,templates:delete,admin:read}', 'Admin', 'Role for users who have complete access to everything.');
|
||||
Reference in New Issue
Block a user