Add a concept where an image can be a rendering of another, which means it is not...
[pr0n] / sql / pr0n.sql
1 CREATE TABLE events (
2     event character varying NOT NULL,
3     "date" character varying NOT NULL,
4     name character varying NOT NULL,
5     vhost character varying NOT NULL,
6     hidden boolean NOT NULL DEFAULT false,
7
8     PRIMARY KEY (vhost, event)
9 );
10
11 -- In a separate table to avoid deadlocks.
12 CREATE TABLE last_picture_cache ( 
13    vhost varchar NOT NULL,
14    event varchar NOT NULL,
15    last_picture timestamp without time zone,
16    last_update timestamp with time zone NOT NULL DEFAULT CURRENT_TIMESTAMP,
17
18    PRIMARY KEY (vhost,event),
19    FOREIGN KEY (vhost,event) REFERENCES events(vhost,event)
20 );
21
22 CREATE SEQUENCE imageid_seq;
23
24 CREATE TABLE images (
25     id integer DEFAULT nextval('imageid_seq') NOT NULL PRIMARY KEY,
26     vhost character varying NOT NULL,
27     event character varying NOT NULL,
28     filename character varying NOT NULL,
29     width integer,
30     height integer,
31     uploadedby character varying NOT NULL,
32     "date" timestamp without time zone,
33     takenby character varying NOT NULL,
34     selected boolean DEFAULT false,
35     model character varying,
36     lens character varying,
37     is_render boolean NOT NULL DEFAULT false,  -- Is this a render of another picture? (If so, don't show it separately.)
38     render_id integer,  -- If not NULL, show this picture instead of ourselves for all JPEG-creation purposes.
39
40     FOREIGN KEY (vhost,event) REFERENCES events (vhost,event),
41     FOREIGN KEY (vhost,event,render_id) REFERENCES images (vhost,event,id),
42
43     -- Redundant with the primary key, but the foreign key needs it.
44     UNIQUE (vhost,event,id),
45
46     CHECK (NOT (is_render AND (render_id IS NOT NULL)))
47 );
48 CREATE UNIQUE INDEX unique_filenames ON images USING btree (vhost, event, filename);
49
50 CREATE TABLE deleted_images (
51     id integer NOT NULL,
52     vhost character varying,
53     event character varying NOT NULL,
54     filename character varying NOT NULL,
55     width integer,
56     height integer,
57     uploadedby character varying,
58     "date" timestamp without time zone,
59     takenby character varying NOT NULL,
60     selected boolean,
61     model character varying,
62     lens character varying
63     is_render boolean NOT NULL,
64     render_id integer,
65 );
66
67 CREATE TABLE users (
68     username character varying NOT NULL,
69     vhost character varying NOT NULL,
70     cryptpassword character varying NOT NULL
71 );
72
73 -- Mainly used for manual queries -- usually too slow to be very useful
74 -- for web views in the long run.
75 CREATE TABLE exif_info (
76     image integer NOT NULL REFERENCES images (id) ON DELETE CASCADE,
77     key varchar NOT NULL,
78     value varchar NOT NULL,
79
80     PRIMARY KEY ( image, key )
81 );
82
83 CREATE INDEX exif_info_key ON exif_info ( key );
84 CLUSTER exif_info_key ON exif_info;
85
86 GRANT INSERT ON TABLE deleted_images TO pr0n;
87 GRANT INSERT,SELECT,UPDATE,DELETE ON TABLE events TO pr0n;
88 GRANT SELECT,UPDATE ON TABLE imageid_seq TO pr0n;
89 GRANT INSERT,SELECT,UPDATE,DELETE ON TABLE images TO pr0n;
90 GRANT SELECT,UPDATE ON TABLE users TO pr0n;
91 GRANT SELECT,INSERT,DELETE ON TABLE exif_info TO pr0n;
92 GRANT INSERT,SELECT,UPDATE,DELETE ON TABLE last_picture_cache TO pr0n;