3f878cb11887e3cff8cdca16f248e996f01c9c1e
[opendmarc.git] / usr / share / doc / opendmarc / schema.mysql
1 -- OpenDMARC database schema
2 --
3 -- Copyright (c) 2012, The Trusted Domain Project.
4 -- All rights reserved.
5
6 CREATE DATABASE IF NOT EXISTS opendmarc;
7 USE opendmarc;
8
9 -- A table for mapping domain names and their DMARC policies to IDs
10 CREATE TABLE IF NOT EXISTS domains (
11 id INT NOT NULL AUTO_INCREMENT,
12 name VARCHAR(255) NOT NULL,
13 firstseen TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
14
15 PRIMARY KEY(id),
16 UNIQUE KEY(name)
17 );
18
19 -- A table for logging reporting requests
20 CREATE TABLE IF NOT EXISTS requests (
21 id INT NOT NULL AUTO_INCREMENT,
22 domain INT NOT NULL,
23 repuri VARCHAR(255) NOT NULL,
24 adkim TINYINT NOT NULL,
25 aspf TINYINT NOT NULL,
26 policy TINYINT NOT NULL,
27 spolicy TINYINT NOT NULL,
28 pct TINYINT NOT NULL,
29 locked TINYINT NOT NULL,
30 firstseen TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
31 lastsent TIMESTAMP NOT NULL DEFAULT '0000-00-00 00:00:00',
32
33 PRIMARY KEY(id),
34 KEY(lastsent),
35 UNIQUE KEY(domain)
36 );
37
38 -- A table for reporting hosts
39 CREATE TABLE IF NOT EXISTS reporters (
40 id INT NOT NULL AUTO_INCREMENT,
41 name VARCHAR(255) NOT NULL,
42 firstseen TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
43
44 PRIMARY KEY(id),
45 UNIQUE KEY(name)
46 );
47
48 -- A table for IP addresses
49 CREATE TABLE IF NOT EXISTS ipaddr (
50 id INT NOT NULL AUTO_INCREMENT,
51 addr VARCHAR(64) NOT NULL,
52 firstseen TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
53
54 PRIMARY KEY(id),
55 UNIQUE KEY(addr)
56 );
57
58 -- A table for messages
59 CREATE TABLE IF NOT EXISTS messages (
60 id INT NOT NULL AUTO_INCREMENT,
61 date TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
62 jobid VARCHAR(128) NOT NULL,
63 reporter INT UNSIGNED NOT NULL,
64 policy TINYINT UNSIGNED NOT NULL,
65 disp TINYINT UNSIGNED NOT NULL,
66 ip INT UNSIGNED NOT NULL,
67 env_domain INT UNSIGNED NOT NULL,
68 from_domain INT UNSIGNED NOT NULL,
69 policy_domain INT UNSIGNED NOT NULL,
70 spf TINYINT UNSIGNED NOT NULL,
71 align_dkim TINYINT UNSIGNED NOT NULL,
72 align_spf TINYINT UNSIGNED NOT NULL,
73 sigcount TINYINT UNSIGNED NOT NULL,
74
75 PRIMARY KEY(id),
76 KEY(date),
77 UNIQUE KEY(reporter, date, jobid)
78 );
79
80 -- A table for signatures
81 CREATE TABLE IF NOT EXISTS signatures (
82 id INT NOT NULL AUTO_INCREMENT,
83 message INT NOT NULL,
84 domain INT NOT NULL,
85 pass TINYINT NOT NULL,
86 error TINYINT NOT NULL,
87
88 PRIMARY KEY(id),
89 KEY(message)
90 );
91
92 -- CREATE USER 'opendmarc'@'localhost' IDENTIFIED BY 'changeme';
93 -- GRANT ALL ON opendmarc.* to 'opendmarc'@'localhost';