You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123 lines
4.4 KiB

CREATE TABLE pbx_organizacao
(
id serial NOT NULL PRIMARY KEY,
nome VARCHAR(128) NOT NULL,
status INTEGER NOT NULL DEFAULT 1,
master int not null DEFAULT 0,
updated_at timestamp without time zone,
created_at timestamp without time zone NOT NULL DEFAULT now()
);
CREATE TABLE pbx_organizacao_usuarios
(
id SERIAL not null primary key,
id_usuario INTEGER not null,
id_organizacao INTEGER not null,
updated_at timestamp without time zone,
created_at timestamp without time zone NOT NULL DEFAULT now()
);
ALTER TABLE pbx_organizacao_usuarios ADD CONSTRAINT id_usuario FOREIGN KEY (id_usuario)
REFERENCES pbx_usuarios(id) ON DELETE CASCADE;
ALTER TABLE pbx_organizacao_usuarios ADD CONSTRAINT id_organizacao FOREIGN KEY (id_organizacao)
REFERENCES pbx_organizacao(id) ON DELETE CASCADE;
CREATE OR REPLACE FUNCTION public.tipoligacao(numfone character varying, entrada boolean DEFAULT true, organizacao int default 0)
RETURNS integer
LANGUAGE plpgsql
AS $function$
declare tam integer;
declare dddfone integer;
declare ddddef integer;
declare nonoDigito integer;
declare numerofone varchar(18);
BEGIN
if(length(numfone) > 18)then
numerofone = substring(numfone, '..................$');
else
numerofone = numfone;
end if;
ddddef = (select prm_ddd_padrao from pbx_parametros where org_id = organizacao);
tam = length(strtoint(numerofone)::text);
nonoDigito = strtoint( substring(substring(numerofone, '.........$'), 1, 1) );
if((tam = 3) and (numerofone in('100', '128', '190', '191', '192', '193', '194', '197', '198', '199')))then
return 4;
elsif((tam >= 8) and (substring(numerofone,1,4) in('0300','0500','0900','4000','4001','4002','4003','4004', '4005', '4006','4007','4008','4009','0800')))then
return 5;
elsif(tam = 8)then
return (case when(entrada)then 21 else 31 end);
elsif(tam < 8)then
return 1;
elsif((nonoDigito = 9) and (tam < 11))then /* Celular local */
return (case when(entrada)then 23 else 33 end);
elseif((not entrada) and (substring(numerofone,1,2) = '00'))then
return 35;
end if;
if(nonoDigito = 9)then
dddfone = substring(substring(numerofone, '...........$'), 1, 2);
else
dddfone = substring(substring(numerofone, '..........$'), 1, 2);
end if;
if((nonoDigito = 9) and (dddfone <> ddddef))then
return (case when(entrada)then 24 else 34 end);
elsif((nonoDigito = 9) and (dddfone = ddddef))then
return (case when(entrada)then 23 else 33 end);
elsif(dddfone <> ddddef)then
return (case when(entrada)then 22 else 32 end);
elsif(dddfone = ddddef)then
return (case when(entrada)then 21 else 31 end);
end if;
return 1;
END;
$function$
;
ALTER TABLE pbx_usuarios ADD COLUMN org_padrao int
------------------------------------------
----- ADICAO DE ID NAS TABELAS -----
------------------------------------------
DROP INDEX "idxSipRamaisNome";
DROP INDEX "pbx_usuarios_matricula_key";
DROP INDEX "idxUsuariosApelido";
DROP INDEX "idxGrupNome";
-----------------
ALTER TABLE pbx_grupo DROP CONSTRAINT "idxGrupNome";
ALTER TABLE pbx_usuarios DROP CONSTRAINT pbx_usuarios_new_matricula_key;
ALTER TABLE pbx_grupo_usuario DROP CONSTRAINT "pkGpUserId";
ALTER TABLE pbx_grupo ADD CONSTRAINT gp_id PRIMARY KEY (gp_id);
-----------------
-- AUTOMATIZADO NO IMPORTAEMPRESA.PHP
-- ALTER TABLE pbx_workflow_parametros DROP COLUMN wkf_id;
-- ALTER TABLE pbx_parametros DROP COLUMN id;
-- ALTER TABLE pbx_sip_general ADD COLUMN id SERIAL PRIMARY KEY;
-- ALTER TABLE pbx_iax_general ADD COLUMN id SERIAL PRIMARY KEY;
-- ALTER TABLE pbx_facilidades ADD COLUMN id SERIAL PRIMARY KEY;
-- ALTER TABLE pbx_features_general ADD COLUMN id SERIAL PRIMARY KEY;
-- ALTER TABLE pbx_features_featuremap ADD COLUMN id SERIAL PRIMARY KEY;
-- ALTER TABLE pbx_voicemail_general ADD COLUMN id SERIAL PRIMARY KEY;
-- ALTER TABLE pbx_workflow_parametros ADD COLUMN wkf_id SERIAL PRIMARY KEY;
-- ALTER TABLE pbx_parametros ADD COLUMN id SERIAL PRIMARY KEY;
-----------------
---------------------------------------------------------------
---------Correcao do tipo da senha do Conta e Senha------------
---------------------------------------------------------------
ALTER TABLE pbx_cs_usuarios
ALTER COLUMN senha TYPE VARCHAR(100);
---------------------------------------------------------------
---------Remocao do conflito entre nomes de status-------------
---------------------------------------------------------------
ALTER TABLE pbx_campanha_contato_status
DROP CONSTRAINT idxcontstatusnome;