Skip to content

Commit

Permalink
Merge pull request #38 from webitel/v23.09
Browse files Browse the repository at this point in the history
V23.09
  • Loading branch information
navrotskyj authored Sep 29, 2023
2 parents 6952d91 + 7ed0265 commit 9557dd4
Show file tree
Hide file tree
Showing 2 changed files with 230 additions and 86 deletions.
87 changes: 1 addition & 86 deletions store/sqlstore/call_center-schema.sql
Original file line number Diff line number Diff line change
Expand Up @@ -1510,20 +1510,6 @@ end;
$$;


--
-- Name: cc_dev_debug(character varying); Type: FUNCTION; Schema: call_center; Owner: -
--

CREATE FUNCTION call_center.cc_dev_debug(arg1 character varying) RETURNS character varying
LANGUAGE plpgsql IMMUTABLE
AS $$
begin
raise warning '%', arg1;
return 'test' || arg1;
end;
$$;


--
-- Name: cc_distribute(boolean); Type: PROCEDURE; Schema: call_center; Owner: -
--
Expand Down Expand Up @@ -4547,8 +4533,7 @@ CREATE UNLOGGED TABLE call_center.cc_member_attempt (
form_fields jsonb,
form_view jsonb,
import_id character varying(120),
schema_processing boolean DEFAULT false,
reject_agent_ids integer[]
schema_processing boolean DEFAULT false
)
WITH (fillfactor='20', log_autovacuum_min_duration='0', autovacuum_analyze_scale_factor='0.05', autovacuum_enabled='1', autovacuum_vacuum_cost_delay='20', autovacuum_vacuum_threshold='100', autovacuum_vacuum_scale_factor='0.01');

Expand Down Expand Up @@ -4905,69 +4890,6 @@ CREATE VIEW call_center.cc_calls_history_list AS
LEFT JOIN directory.wbt_user arub ON ((arub.id = ar.created_by)));


--
-- Name: cc_calls_history_old; Type: TABLE; Schema: call_center; Owner: -
--

CREATE TABLE call_center.cc_calls_history_old (
id uuid,
direction character varying,
destination character varying,
parent_id uuid,
app_id character varying,
from_type character varying,
from_name character varying,
from_number character varying,
from_id character varying,
to_type character varying,
to_name character varying,
to_number character varying,
to_id character varying,
payload jsonb,
domain_id bigint,
hold_sec integer,
cause character varying,
sip_code integer,
bridged_id uuid,
gateway_id bigint,
user_id integer,
queue_id integer,
team_id integer,
agent_id integer,
attempt_id bigint,
member_id bigint,
duration integer,
description character varying,
tags character varying[],
answered_at timestamp with time zone,
bridged_at timestamp with time zone,
hangup_at timestamp with time zone,
created_at timestamp with time zone,
hangup_by character varying,
stored_at timestamp with time zone,
rating smallint,
notes text,
transfer_from uuid,
transfer_to uuid,
amd_result character varying,
amd_duration interval,
grantee_id bigint,
hold jsonb,
agent_ids integer[],
user_ids bigint[],
queue_ids integer[],
gateway_ids bigint[],
team_ids integer[],
params jsonb,
blind_transfer character varying,
talk_sec integer,
amd_ai_result character varying,
amd_ai_logs character varying[],
amd_ai_positive boolean,
contact_id bigint
);


--
-- Name: cc_calls_transcribe; Type: TABLE; Schema: call_center; Owner: -
--
Expand Down Expand Up @@ -8863,13 +8785,6 @@ CREATE INDEX cc_team_updated_by_index ON call_center.cc_team USING btree (update
CREATE INDEX cc_test_migration ON call_center.cc_calls_history USING btree (created_at, id);


--
-- Name: cc_test_migration_old; Type: INDEX; Schema: call_center; Owner: -
--

CREATE INDEX cc_test_migration_old ON call_center.cc_calls_history_old USING btree (created_at);


--
-- Name: cc_trigger_acl_grantor_idx; Type: INDEX; Schema: call_center; Owner: -
--
Expand Down
229 changes: 229 additions & 0 deletions store/sqlstore/migration/23.09/23.07-23.09.sql
Original file line number Diff line number Diff line change
Expand Up @@ -1456,3 +1456,232 @@ FROM (( SELECT call_center.cc_get_lookup((q_1.id)::bigint, q_1.name) AS queue,

ALTER TABLE ONLY call_center.system_settings
ADD CONSTRAINT systemc_settings_wbt_domain_dc_fk FOREIGN KEY (domain_id) REFERENCES directory.wbt_domain(dc) ON DELETE CASCADE;







drop view call_center.cc_calls_history_list;
create view call_center.cc_calls_history_list
as
SELECT c.id,
c.app_id,
'call'::character varying AS type,
c.parent_id,
c.transfer_from,
CASE
WHEN c.parent_id IS NOT NULL AND c.transfer_to IS NULL AND c.id::text <> lega.bridged_id::text
THEN lega.bridged_id
ELSE c.transfer_to
END AS transfer_to,
call_center.cc_get_lookup(u.id,
COALESCE(u.name, u.username::text)::character varying) AS "user",
CASE
WHEN cq.type = ANY (ARRAY [4, 5]) THEN cag.extension
ELSE u.extension
END AS extension,
call_center.cc_get_lookup(gw.id, gw.name) AS gateway,
c.direction,
c.destination,
json_build_object('type', COALESCE(c.from_type, ''::character varying), 'number',
COALESCE(c.from_number, ''::character varying), 'id',
COALESCE(c.from_id, ''::character varying), 'name',
COALESCE(c.from_name, ''::character varying)) AS "from",
json_build_object('type', COALESCE(c.to_type, ''::character varying), 'number',
COALESCE(c.to_number, ''::character varying), 'id', COALESCE(c.to_id, ''::character varying),
'name',
COALESCE(c.to_name, ''::character varying)) AS "to",
c.payload AS variables,
c.created_at,
c.answered_at,
c.bridged_at,
c.hangup_at,
c.stored_at,
COALESCE(c.hangup_by, ''::character varying) AS hangup_by,
c.cause,
date_part('epoch'::text, c.hangup_at - c.created_at)::bigint AS duration,
COALESCE(c.hold_sec, 0) AS hold_sec,
COALESCE(
CASE
WHEN c.answered_at IS NOT NULL THEN date_part('epoch'::text, c.answered_at - c.created_at)::bigint
ELSE date_part('epoch'::text, c.hangup_at - c.created_at)::bigint
END,
0::bigint) AS wait_sec,
CASE
WHEN c.answered_at IS NOT NULL THEN date_part('epoch'::text, c.hangup_at - c.answered_at)::bigint
ELSE 0::bigint
END AS bill_sec,
c.sip_code,
f.files,
call_center.cc_get_lookup(cq.id::bigint, cq.name) AS queue,
call_center.cc_get_lookup(cm.id::bigint, cm.name) AS member,
call_center.cc_get_lookup(ct.id, ct.name) AS team,
call_center.cc_get_lookup(aa.id::bigint,
COALESCE(cag.username, cag.name::name)::character varying) AS agent,
cma.joined_at,
cma.leaving_at,
cma.reporting_at,
cma.bridged_at AS queue_bridged_at,
CASE
WHEN cma.bridged_at IS NOT NULL THEN date_part('epoch'::text, cma.bridged_at - cma.joined_at)::integer
ELSE date_part('epoch'::text, cma.leaving_at - cma.joined_at)::integer
END AS queue_wait_sec,
date_part('epoch'::text, cma.leaving_at - cma.joined_at)::integer AS queue_duration_sec,
cma.result,
CASE
WHEN cma.reporting_at IS NOT NULL THEN date_part('epoch'::text, cma.reporting_at - cma.leaving_at)::integer
ELSE 0
END AS reporting_sec,
c.agent_id,
c.team_id,
c.user_id,
c.queue_id,
c.member_id,
c.attempt_id,
c.domain_id,
c.gateway_id,
c.from_number,
c.to_number,
c.tags,
cma.display,
(EXISTS(SELECT 1
FROM call_center.cc_calls_history hp
WHERE c.parent_id IS NULL
AND hp.parent_id = c.id)) AS has_children,
COALESCE(regexp_replace(cma.description::text, '^[\r\n\t ]*|[\r\n\t ]*$'::text, ''::text, 'g'::text),
''::character varying::text)::character varying AS agent_description,
c.grantee_id,
(SELECT jsonb_agg(x.hi ORDER BY (x.hi -> 'start'::text)) AS res
FROM (SELECT jsonb_array_elements(chh.hold) AS hi
FROM call_center.cc_calls_history chh
WHERE chh.parent_id = c.id
AND chh.hold IS NOT NULL
UNION
SELECT jsonb_array_elements(c.hold) AS jsonb_array_elements) x
WHERE x.hi IS NOT NULL) AS hold,
c.gateway_ids,
c.user_ids,
c.agent_ids,
c.queue_ids,
c.team_ids,
(SELECT json_agg(row_to_json(annotations.*)) AS json_agg
FROM (SELECT a.id,
a.call_id,
a.created_at,
call_center.cc_get_lookup(cc.id,
COALESCE(cc.name, cc.username::text)::character varying) AS created_by,
a.updated_at,
call_center.cc_get_lookup(uc.id,
COALESCE(uc.name, uc.username::text)::character varying) AS updated_by,
a.note,
a.start_sec,
a.end_sec
FROM call_center.cc_calls_annotation a
LEFT JOIN directory.wbt_user cc ON cc.id = a.created_by
LEFT JOIN directory.wbt_user uc ON uc.id = a.updated_by
WHERE a.call_id::text = c.id::text
ORDER BY a.created_at DESC) annotations) AS annotations,
COALESCE(c.amd_result, c.amd_ai_result) AS amd_result,
c.amd_duration,
c.amd_ai_result,
c.amd_ai_logs,
c.amd_ai_positive,
cq.type AS queue_type,
CASE
WHEN c.parent_id IS NOT NULL THEN ''::text
WHEN c.cause::text = ANY (ARRAY ['USER_BUSY'::character varying::text, 'NO_ANSWER'::character varying::text])
THEN 'not_answered'::text
WHEN c.cause::text = 'ORIGINATOR_CANCEL'::text OR c.cause::text = 'LOSE_RACE'::text AND cq.type = 4
THEN 'cancelled'::text
WHEN c.hangup_by::text = 'F'::text THEN 'ended'::text
WHEN c.cause::text = 'NORMAL_CLEARING'::text THEN
CASE
WHEN c.cause::text = 'NORMAL_CLEARING'::text AND c.direction::text = 'outbound'::text AND
c.hangup_by::text = 'A'::text AND c.user_id IS NOT NULL OR
c.direction::text = 'inbound'::text AND c.hangup_by::text = 'B'::text AND
c.bridged_at IS NOT NULL OR
c.direction::text = 'outbound'::text AND c.hangup_by::text = 'B'::text AND
(cq.type = ANY (ARRAY [4, 5, 1])) AND c.bridged_at IS NOT NULL THEN 'agent_dropped'::text
ELSE 'client_dropped'::text
END
ELSE 'error'::text
END AS hangup_disposition,
c.blind_transfer,
(SELECT jsonb_agg(json_build_object('id', j.id, 'created_at', call_center.cc_view_timestamp(j.created_at),
'action', j.action, 'file_id', j.file_id, 'state', j.state, 'error', j.error,
'updated_at', call_center.cc_view_timestamp(j.updated_at))) AS jsonb_agg
FROM storage.file_jobs j
WHERE j.file_id = ANY (f.file_ids)) AS files_job,
(SELECT json_agg(json_build_object('id', tr.id, 'locale', tr.locale, 'file_id', tr.file_id, 'file',
call_center.cc_get_lookup(ff.id, ff.name))) AS data
FROM storage.file_transcript tr
LEFT JOIN storage.files ff ON ff.id = tr.file_id
WHERE tr.uuid::text = c.id::text
GROUP BY (tr.uuid::text)) AS transcripts,
c.talk_sec,
call_center.cc_get_lookup(au.id, au.name::character varying) AS grantee,
ar.id AS rate_id,
call_center.cc_get_lookup(aru.id, COALESCE(aru.name::character varying,
aru.username::character varying)) AS rated_user,
call_center.cc_get_lookup(arub.id, COALESCE(arub.name::character varying,
arub.username::character varying)) AS rated_by,
ar.score_optional,
ar.score_required,
(EXISTS(SELECT 1
FROM call_center.cc_calls_history cr
WHERE cr.id = c.bridged_id
AND c.bridged_id IS NOT NULL
AND c.blind_transfer IS NULL
AND cr.blind_transfer IS NULL
AND c.transfer_to IS NULL
AND cr.transfer_to IS NULL
AND c.transfer_from IS NULL
AND cr.transfer_from IS NULL
AND COALESCE(cr.user_id, c.user_id) IS NOT NULL)) AS allow_evaluation,
cma.form_fields,
c.bridged_id,
call_center.cc_get_lookup(cc.id, cc.common_name) as contact,
c.contact_id
FROM call_center.cc_calls_history c
LEFT JOIN LATERAL ( SELECT array_agg(f_1.id) AS file_ids,
json_agg(jsonb_build_object('id', f_1.id, 'name', f_1.name, 'size', f_1.size,
'mime_type', f_1.mime_type, 'start_at',
(c.params -> 'record_start'::text)::bigint, 'stop_at',
(c.params -> 'record_stop'::text)::bigint)) AS files
FROM (SELECT f1.id,
f1.size,
f1.mime_type,
f1.name
FROM storage.files f1
WHERE f1.domain_id = c.domain_id
AND NOT f1.removed IS TRUE
AND f1.uuid::text = c.id::text
UNION ALL
SELECT f1.id,
f1.size,
f1.mime_type,
f1.name
FROM storage.files f1
WHERE f1.domain_id = c.domain_id
AND NOT f1.removed IS TRUE
AND f1.uuid::text = c.parent_id::text) f_1) f
ON c.answered_at IS NOT NULL OR c.bridged_at IS NOT NULL
LEFT JOIN call_center.cc_queue cq ON c.queue_id = cq.id
LEFT JOIN call_center.cc_team ct ON c.team_id = ct.id
LEFT JOIN call_center.cc_member cm ON c.member_id = cm.id
LEFT JOIN call_center.cc_member_attempt_history cma ON cma.id = c.attempt_id
LEFT JOIN call_center.cc_agent aa ON cma.agent_id = aa.id
LEFT JOIN directory.wbt_user cag ON cag.id = aa.user_id
LEFT JOIN directory.wbt_user u ON u.id = c.user_id
LEFT JOIN directory.sip_gateway gw ON gw.id = c.gateway_id
LEFT JOIN directory.wbt_auth au ON au.id = c.grantee_id
LEFT JOIN call_center.cc_calls_history lega ON c.parent_id IS NOT NULL AND lega.id = c.parent_id
LEFT JOIN call_center.cc_audit_rate ar ON ar.call_id::text = c.id::text
LEFT JOIN directory.wbt_user aru ON aru.id = ar.rated_user_id
LEFT JOIN directory.wbt_user arub ON arub.id = ar.created_by
left join contacts.contact cc on cc.id = c.contact_id;

create index cc_calls_history_contact_id_index
on call_center.cc_calls_history (contact_id);

0 comments on commit 9557dd4

Please sign in to comment.