123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572 |
-
-
-
-
- SET statement_timeout = 0;
- SET client_encoding = 'UTF8';
- SET standard_conforming_strings = on;
- SET check_function_bodies = false;
- SET client_min_messages = warning;
-
-
-
-
-
- CREATE EXTENSION IF NOT EXISTS plpgsql WITH SCHEMA pg_catalog;
-
-
-
-
-
-
- COMMENT ON EXTENSION plpgsql IS 'PL/pgSQL procedural language';
-
-
- SET search_path = public, pg_catalog;
-
-
-
-
-
- CREATE FUNCTION pod_update_node() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
- BEGIN
- INSERT INTO pod_nodes_history (node_id, parent_id, node_order, node_type, created_at, updated_at,
- data_label, data_content, data_datetime, node_status, data_reminder_datetime,
- data_file_name, data_file_content, data_file_mime_type, parent_tree_path,
- node_depth, owner_id, version_id, is_shared, is_public, public_url_key) VALUES (NEW.node_id, NEW.parent_id, NEW.node_order, NEW.node_type, NEW.created_at, NEW.updated_at, NEW.data_label, NEW.data_content, NEW.data_datetime, NEW.node_status, NEW.data_reminder_datetime, NEW.data_file_name, NEW.data_file_content, NEW.data_file_mime_type, NEW.parent_tree_path, NEW.node_depth, NEW.owner_id, nextval('pod_nodes_version_id_sequence'), NEW.is_shared, NEW.is_public, NEW.public_url_key);
- return new;
- END;
- $$;
-
-
-
-
-
-
- CREATE FUNCTION set_created_at() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
- BEGIN
- NEW.created_at = CURRENT_TIMESTAMP;
- NEW.updated_at = CURRENT_TIMESTAMP;
- RETURN NEW;
- END;
- $$;
-
-
-
-
-
-
- CREATE FUNCTION set_updated_at() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
- BEGIN
- NEW.updated_at = CURRENT_TIMESTAMP;
- RETURN NEW;
- END;
- $$;
-
-
- SET default_tablespace = '';
-
- SET default_with_oids = false;
-
-
-
-
-
- CREATE TABLE migrate_version (
- version_num character varying(32) NOT NULL
- );
-
-
-
-
-
-
- CREATE TABLE pod_group (
- group_id integer NOT NULL,
- group_name character varying(16) NOT NULL,
- display_name character varying(255),
- created timestamp without time zone,
- personnal_group boolean
- );
-
-
-
-
-
-
- CREATE SEQUENCE pod_group_group_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
-
-
-
-
-
-
- ALTER SEQUENCE pod_group_group_id_seq OWNED BY pod_group.group_id;
-
-
-
-
-
-
- CREATE TABLE pod_group_node (
- group_id integer NOT NULL,
- node_id integer NOT NULL,
- rights integer
- );
-
-
-
-
-
-
- CREATE TABLE pod_group_permission (
- group_id integer NOT NULL,
- permission_id integer NOT NULL
- );
-
-
-
-
-
-
-
- CREATE SEQUENCE pod_nodes_version_id_sequence
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
-
-
-
-
-
-
- CREATE TABLE pod_nodes_history (
- node_id integer NOT NULL,
- parent_id integer,
- node_order integer DEFAULT 1,
- node_type character varying(16) DEFAULT 'data'::character varying NOT NULL,
- created_at timestamp without time zone,
- updated_at timestamp without time zone,
- data_label character varying(1024),
- data_content text DEFAULT ''::text NOT NULL,
- data_datetime timestamp without time zone,
- node_status character varying(16) DEFAULT 'new'::character varying,
- data_reminder_datetime timestamp without time zone,
- data_file_name character varying(255),
- data_file_content bytea,
- data_file_mime_type character varying(255),
- parent_tree_path character varying(255),
- node_depth integer DEFAULT 0 NOT NULL,
- owner_id integer,
- version_id integer DEFAULT nextval('pod_nodes_version_id_sequence'::regclass) NOT NULL,
- is_shared boolean DEFAULT false NOT NULL,
- is_public boolean DEFAULT false NOT NULL,
- public_url_key character varying(1024)
- );
-
-
-
-
-
-
- CREATE VIEW pod_nodes AS
- SELECT DISTINCT ON (pod_nodes_history.node_id) pod_nodes_history.node_id, pod_nodes_history.parent_id, pod_nodes_history.node_order, pod_nodes_history.node_type, pod_nodes_history.created_at, pod_nodes_history.updated_at, pod_nodes_history.data_label, pod_nodes_history.data_content, pod_nodes_history.data_datetime, pod_nodes_history.node_status, pod_nodes_history.data_reminder_datetime, pod_nodes_history.data_file_name, pod_nodes_history.data_file_content, pod_nodes_history.data_file_mime_type, pod_nodes_history.parent_tree_path, pod_nodes_history.node_depth, pod_nodes_history.owner_id, pod_nodes_history.is_shared, pod_nodes_history.is_public, pod_nodes_history.public_url_key FROM pod_nodes_history ORDER BY pod_nodes_history.node_id, pod_nodes_history.updated_at DESC;
-
-
-
-
-
-
- CREATE SEQUENCE pod_nodes__node_id__sequence
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
-
-
-
-
-
-
- ALTER SEQUENCE pod_nodes__node_id__sequence OWNED BY pod_nodes_history.node_id;
-
-
-
-
-
-
- CREATE TABLE pod_permission (
- permission_id integer NOT NULL,
- permission_name character varying(63) NOT NULL,
- description character varying(255)
- );
-
-
-
-
-
-
- CREATE SEQUENCE pod_permission_permission_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
-
-
-
-
-
-
- ALTER SEQUENCE pod_permission_permission_id_seq OWNED BY pod_permission.permission_id;
-
-
-
-
-
-
- CREATE TABLE pod_user (
- user_id integer NOT NULL,
- email_address character varying(255) NOT NULL,
- display_name character varying(255),
- password character varying(128),
- created timestamp without time zone
- );
-
-
-
-
-
-
- CREATE TABLE pod_user_group (
- user_id integer NOT NULL,
- group_id integer NOT NULL
- );
-
-
-
-
-
-
- CREATE SEQUENCE pod_user_user_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
-
-
-
-
-
-
- ALTER SEQUENCE pod_user_user_id_seq OWNED BY pod_user.user_id;
-
-
-
-
-
-
- ALTER TABLE ONLY pod_group ALTER COLUMN group_id SET DEFAULT nextval('pod_group_group_id_seq'::regclass);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_nodes_history ALTER COLUMN node_id SET DEFAULT nextval('pod_nodes__node_id__sequence'::regclass);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_permission ALTER COLUMN permission_id SET DEFAULT nextval('pod_permission_permission_id_seq'::regclass);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_user ALTER COLUMN user_id SET DEFAULT nextval('pod_user_user_id_seq'::regclass);
-
-
-
-
-
-
- COPY migrate_version (version_num) FROM stdin;
- \.
-
-
-
-
-
-
- COPY pod_group (group_id, group_name, display_name, created, personnal_group) FROM stdin;
- 1 managers Managers \N f
- 3 admin Admin \N f
- -1 user_1 \N 2014-06-11 10:55:36.163634 t
- 2 user All Users \N f
- \.
-
-
-
-
-
-
- SELECT pg_catalog.setval('pod_group_group_id_seq', 1, false);
-
-
-
-
-
-
- COPY pod_group_permission (group_id, permission_id) FROM stdin;
- \.
-
-
-
-
-
- SELECT pg_catalog.setval('pod_nodes__node_id__sequence', 25, true);
-
-
-
-
-
- SELECT pg_catalog.setval('pod_nodes_version_id_sequence', 41, true);
-
-
-
-
-
-
- COPY pod_permission (permission_id, permission_name, description) FROM stdin;
- \.
-
-
-
-
-
-
- SELECT pg_catalog.setval('pod_permission_permission_id_seq', 1, false);
-
-
-
-
-
-
- COPY pod_user (user_id, email_address, display_name, password, created) FROM stdin;
- 1 admin@localhost Admin b0c2243d8052ebc30e446d557b3249ed143e0ba6922ec49d9c53f3c1a533ae25b5dc4ec00d6cc3dd9fc9c74107e9914b3ace56ba8ded846bda9c140c0d6f721e 2014-06-11 10:55:36.15707
- \.
-
-
-
-
-
-
- COPY pod_user_group (user_id, group_id) FROM stdin;
- 1 2
- 1 -1
- \.
-
-
-
-
-
-
- SELECT pg_catalog.setval('pod_user_user_id_seq', 1, true);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_group
- ADD CONSTRAINT pod_group_group_name_key UNIQUE (group_name);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_group_node
- ADD CONSTRAINT pod_group_node_pkey PRIMARY KEY (group_id, node_id);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_group_permission
- ADD CONSTRAINT pod_group_permission_pkey PRIMARY KEY (group_id, permission_id);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_group
- ADD CONSTRAINT pod_group_pkey PRIMARY KEY (group_id);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_nodes_history
- ADD CONSTRAINT pod_nodes_history_pkey PRIMARY KEY (version_id);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_permission
- ADD CONSTRAINT pod_permission_permission_name_key UNIQUE (permission_name);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_permission
- ADD CONSTRAINT pod_permission_pkey PRIMARY KEY (permission_id);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_user
- ADD CONSTRAINT pod_user_email_address_key UNIQUE (email_address);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_user_group
- ADD CONSTRAINT pod_user_group_pkey PRIMARY KEY (user_id, group_id);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_user
- ADD CONSTRAINT pod_user_pkey PRIMARY KEY (user_id);
-
-
-
-
-
-
- CREATE INDEX fki_pod_nodes__owner_id_fk ON pod_nodes_history USING btree (owner_id);
-
-
-
-
-
-
- CREATE INDEX fki_pod_nodes__parent_id_fk ON pod_nodes_history USING btree (parent_id);
-
-
-
-
-
-
- CREATE INDEX idx_pod_nodes__parent_tree_path ON pod_nodes_history USING btree (parent_tree_path);
-
-
-
-
-
-
- CREATE RULE pod_insert_new_node AS ON INSERT TO pod_nodes DO INSTEAD INSERT INTO pod_nodes_history (node_id, parent_id, node_order, node_type, created_at, updated_at, data_label, data_content, data_datetime, node_status, data_reminder_datetime, data_file_name, data_file_content, data_file_mime_type, parent_tree_path, node_depth, owner_id, version_id, is_shared, is_public, public_url_key) VALUES (nextval('pod_nodes__node_id__sequence'::regclass), new.parent_id, new.node_order, new.node_type, new.created_at, new.updated_at, new.data_label, new.data_content, new.data_datetime, new.node_status, new.data_reminder_datetime, new.data_file_name, new.data_file_content, new.data_file_mime_type, new.parent_tree_path, new.node_depth, new.owner_id, nextval('pod_nodes_version_id_sequence'::regclass), new.is_shared, new.is_public, new.public_url_key) RETURNING pod_nodes_history.node_id, pod_nodes_history.parent_id, pod_nodes_history.node_order, pod_nodes_history.node_type, pod_nodes_history.created_at, pod_nodes_history.updated_at, pod_nodes_history.data_label, pod_nodes_history.data_content, pod_nodes_history.data_datetime, pod_nodes_history.node_status, pod_nodes_history.data_reminder_datetime, pod_nodes_history.data_file_name, pod_nodes_history.data_file_content, pod_nodes_history.data_file_mime_type, pod_nodes_history.parent_tree_path, pod_nodes_history.node_depth, pod_nodes_history.owner_id, pod_nodes_history.is_shared, pod_nodes_history.is_public, pod_nodes_history.public_url_key;
-
-
-
-
-
-
- CREATE TRIGGER pod_nodes__on_insert_set_created_at BEFORE INSERT ON pod_nodes_history FOR EACH ROW EXECUTE PROCEDURE set_created_at();
-
-
-
-
-
-
- CREATE TRIGGER pod_nodes__on_update_set_updated_at BEFORE UPDATE ON pod_nodes_history FOR EACH ROW EXECUTE PROCEDURE set_updated_at();
-
-
-
-
-
-
- CREATE TRIGGER pod_update_node_tg INSTEAD OF UPDATE ON pod_nodes FOR EACH ROW EXECUTE PROCEDURE pod_update_node();
-
-
-
-
-
-
- ALTER TABLE ONLY pod_group_node
- ADD CONSTRAINT pod_group_node_group_id_fkey FOREIGN KEY (group_id) REFERENCES pod_group(group_id) ON UPDATE CASCADE ON DELETE CASCADE;
-
-
-
-
-
-
- ALTER TABLE ONLY pod_group_permission
- ADD CONSTRAINT pod_group_permission_group_id_fkey FOREIGN KEY (group_id) REFERENCES pod_group(group_id) ON UPDATE CASCADE ON DELETE CASCADE;
-
-
-
-
-
-
- ALTER TABLE ONLY pod_group_permission
- ADD CONSTRAINT pod_group_permission_permission_id_fkey FOREIGN KEY (permission_id) REFERENCES pod_permission(permission_id) ON UPDATE CASCADE ON DELETE CASCADE;
-
-
-
-
-
-
- ALTER TABLE ONLY pod_nodes_history
- ADD CONSTRAINT pod_nodes__owner_id_fk FOREIGN KEY (owner_id) REFERENCES pod_user(user_id);
-
-
-
-
-
-
- ALTER TABLE ONLY pod_user_group
- ADD CONSTRAINT pod_user_group_group_id_fkey FOREIGN KEY (group_id) REFERENCES pod_group(group_id) ON UPDATE CASCADE ON DELETE CASCADE;
-
-
-
-
-
-
- ALTER TABLE ONLY pod_user_group
- ADD CONSTRAINT pod_user_group_user_id_fkey FOREIGN KEY (user_id) REFERENCES pod_user(user_id) ON UPDATE CASCADE ON DELETE CASCADE;
-
|