HSAdmin Backend Domains, E-Mail, Datenbanken
Peter Hormanns
2013-05-13 522b89c5372746a79c500578967c3e8ba276320a
hsarback/database/database_update.sql
@@ -1,67 +1,61 @@
-- Migrate database from version 2.2 to version 2.3
--
--- Add domain option "php".
INSERT INTO domain_option (domain_option_name)
   VALUES ('php');
--- Set default values for pacs
INSERT INTO domain__domain_option SELECT domain_option_id, domain_id
   FROM domain
         JOIN unixuser on ( domain.domain_owner = unixuser.unixuser_id )
         JOIN packet on ( unixuser.packet_id = packet.packet_id )
         JOIN basepacket on ( packet.bp_id = basepacket.basepacket_id )
      , domain_option
   WHERE basepacket.basepacket_code = 'DW/B'
      AND domain_option.domain_option_name = 'php' ;
DELETE FROM domain__domain_option USING domain_option, domain
      JOIN unixuser on ( domain.domain_owner = unixuser.unixuser_id )
      JOIN packet on ( unixuser.packet_id = packet.packet_id )
      JOIN basepacket on ( packet.bp_id = basepacket.basepacket_id )
   WHERE basepacket.basepacket_code != 'DW/B'
      AND domain__domain_option.domain_option_id = domain_option.domain_option_id
      AND domain_option.domain_option_name = 'php' ;
--- Updates related to HSBilling
update bank_account set autodebit_ar = false where autodebit_ar is null;
alter table bank_account alter column autodebit_ar set not null;
update bank_account set autodebit_ga = false where autodebit_ga is null;
alter table bank_account alter column autodebit_ga set not null;
update bank_account set autodebit_op = false where autodebit_op is null;
alter table bank_account alter column autodebit_op set not null;
alter table basepacket add column article_number integer not null default 1;
alter table basepacket alter column article_number drop default;
alter table component add column article_number integer not null default 1;
alter table component alter column article_number drop default;
create table price_list (
  id serial primary key,
  name varchar(20)
);
insert into price_list values (1, 'Default Price List');
create table customer_price_list_mapping (
  customer integer references business_partner(bp_id),
  price_list integer references price_list(id)
);
insert into customer_price_list_mapping (select bp_id, 1 from business_partner);
create table price (
  id serial primary key,
        article_number integer not null,
        price decimal(10, 2) not null,
        vat decimal(4,2) not null,
        price_list integer references price_list(id)
);
insert into price values (1, 0, 0, 0, 1);
-- INSERT INTO domain__domain_option
--    SELECT domain_option_id, domain_id FROM domain
--       JOIN unixuser on ( domain.domain_owner = unixuser.unixuser_id )
--       JOIN packet on ( unixuser.packet_id = packet.packet_id )
--       JOIN basepacket on ( packet.bp_id = basepacket.basepacket_id ), domain_option
--       WHERE basepacket.basepacket_code = 'PAC/DW'
--          AND domain_option.domain_option_name = 'php' ;
-- DELETE FROM domain__domain_option
--    USING domain_option, domain
--       JOIN unixuser on ( domain.domain_owner = unixuser.unixuser_id )
--       JOIN packet on ( unixuser.packet_id = packet.packet_id )
--       JOIN basepacket on ( packet.bp_id = basepacket.basepacket_id )
--       WHERE basepacket.basepacket_code != 'PAC/DW'
--          AND domain__domain_option.domain_option_id = domain_option.domain_option_id
--          AND domain_option.domain_option_name = 'php' ;
--
-- End of migration to version 2.3
-- Name: packet_component_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
CREATE SEQUENCE packet_component_id_seq
    INCREMENT BY 1
    NO MAXVALUE
    NO MINVALUE
    CACHE 1;
CREATE SEQUENCE component_id_seq
    INCREMENT BY 1
    NO MAXVALUE
    NO MINVALUE
    CACHE 1;
ALTER TABLE packet_component ADD COLUMN packet_component_id integer
   DEFAULT nextval(('"packet_component_id_seq"'::text)::regclass) NOT NULL;
ALTER TABLE component ADD COLUMN component_id integer
   DEFAULT nextval(('"component_id_seq"'::text)::regclass) NOT NULL;
ALTER TABLE ONLY packet_component
   DROP CONSTRAINT pk_packet_component;
ALTER TABLE ONLY component
   DROP CONSTRAINT pk_component CASCADE;
ALTER TABLE ONLY packet_component
    ADD CONSTRAINT pk_packet_component PRIMARY KEY (packet_component_id);
ALTER TABLE ONLY component
    ADD CONSTRAINT pk_component PRIMARY KEY (component_id);
ALTER TABLE ONLY packet ADD COLUMN basepacket_id integer;
UPDATE packet SET basepacket_id = ( SELECT basepacket_id FROM packet_component
   WHERE packet_component.packet_id = packet.packet_id LIMIT 1 );
ALTER TABLE ONLY packet
    ADD CONSTRAINT base_packet_ref FOREIGN KEY (basepacket_id) REFERENCES basepacket(basepacket_id);
ALTER TABLE ONLY packet_component
   DROP COLUMN basepacket_id;