
CREATE TABLE user_table (
  	email_user          	text NOT NULL,
  	gecos_user          	text,
  	password_user		text,
	last_login_date_user	integer,	
	last_login_host_user	text,
    wrong_login_count_user  integer,
	cookie_delay_user	integer,
	lang_user		text,
	attributes_user		text,
	data_user		text,
	PRIMARY KEY (email_user)
);

CREATE TABLE subscriber_table (
  	list_subscriber       	text NOT NULL,
	user_subscriber		text NOT NULL,
  	custom_attribute_subscriber text,
	robot_subscriber	text NOT NULL,
	date_subscriber		numeric NOT NULL,
	update_subscriber	numeric,
	visibility_subscriber	text,
	reception_subscriber	text,
	topics_subscriber	text,
	bounce_subscriber	text,
	bounce_address_subscriber text,
	comment_subscriber	text,
	subscribed_subscriber 	numeric,
	included_subscriber 	numeric,
	include_sources_subscriber text,
	bounce_score_subscriber integer,
	suspend_subscriber	numeric,
	suspend_start_date_subscriber	integer,
	suspend_end_date_subscriber	integer,	
	PRIMARY KEY (robot_subscriber, list_subscriber, user_subscriber)
);

CREATE TABLE admin_table (
	list_admin 		text NOT NULL,
 	user_admin 		text NOT NULL,
 	robot_admin 		text NOT NULL,
	role_admin 		text NOT NULL,
	date_admin 		numeric NOT NULL,
	update_admin 		numeric,
	reception_admin 	text,
	visibility_admin 	text,
	comment_admin 		text,
	subscribed_admin  	numeric,
	included_admin  	numeric,
	include_sources_admin  	text,
	info_admin   		text,
	profile_admin  		text,
	PRIMARY KEY (robot_admin, list_admin, role_admin, user_admin)
);
CREATE INDEX admin_user_index ON admin_table ( user_admin );

CREATE TABLE exclusion_table (
	list_exclusion 		text NOT NULL,
 	user_exclusion 		text NOT NULL,
 	robot_exclusion 		text NOT NULL,
	date_exclusion 		integer,
	PRIMARY KEY (list_exclusion, user_exclusion, robot_exclusion)
);

CREATE TABLE netidmap_table (
        netid_netidmap		text NOT NULL,
	serviceid_netidmap	text NOT NULL,
	robot_netidmap		text NOT NULL,
        email_netidmap		text,
        PRIMARY KEY (netid_netidmap, serviceid_netidmap, robot_netidmap)
);
CREATE	INDEX netidmap_idx ON netidmap_table(netid_netidmap, serviceid_netidmap, robot_netidmap);

CREATE TABLE logs_table (
	id_logs			integer NOT NULL,
	date_logs		integer NOT NULL,
	robot_logs		text,
	list_logs		text,
	action_logs		text NOT NULL,
	parameters_logs		text,
	target_email_logs	text,
	user_email_logs		text,
	msg_id_logs		text,
	status_logs		text NOT NULL,
	error_type_logs		text,
	client_logs		text,
	daemon_logs		text NOT NULL,
	PRIMARY KEY (id_logs)					  
);

CREATE TABLE session_table (
	id_session		text NOT NULL,
	start_date_session	integer NOT NULL,
	date_session		integer NOT NULL,
	remote_addr_session	text,
	robot_session		text,
	email_session		text,
	hit_session		integer,
	data_session		text,
	PRIMARY KEY (id_session)
);

CREATE TABLE one_time_ticket_table (
	ticket_one_time_ticket	text,
	robot_one_time_ticket	text,
	email_one_time_ticket	text,
	date_one_time_ticket	integer,
	data_one_time_ticket	text,
	remote_addr_one_time_ticket text,
	status_one_time_ticket	text,
	PRIMARY KEY (ticket_one_time_ticket)
);

CREATE TABLE bulkmailer_table(
  	messagekey_bulkmailer  	text NOT NULL,
	packetid_bulkmailer 	text NOT NULL,
  	messageid_bulkmailer  	text,
	receipients_bulkmailer 	text,
	returnpath_bulkmailer 	text,
	robot_bulkmailer 	text,
	listname_bulkmailer 	text,
	verp_bulkmailer 	numeric,
	merge_bulkmailer 	numeric,
	priority_message_bulkmailer 	integer,
	priority_packet_bulkmailer 	integer,
	reception_date_bulkmailer 	integer,
	delivery_date_bulkmailer 	integer,
	lock_bulkmailer 	text,
	PRIMARY KEY (messagekey_bulkmailer, packetid_bulkmailer)
);

CREATE TABLE bulkspool_table (
  	messagekey_bulkspool  	text NOT NULL,
  	messageid_bulkspool  	text,
	message_bulkspool 	text,
	lock_bulkspool 	numeric,
        dkim_privatekey_bulkspool  text,
	dkim_selector_bulkspool text,
	dkim_d_bulkspool text,
	dkim_i_bulkspool text,
	dkim_header_list_bulkspool varchar(500),
	PRIMARY KEY (messagekey_bulkspool)
);

CREATE TABLE conf_table (
	robot_conf		text,
	label_conf		text,
	value_conf		text,
	PRIMARY KEY (robot_conf,label_conf)
);

CREATE TABLE list_table (
	 creation_email_list 	text,
	 creation_epoch_list 	numeric,
	 editors_list 	text,
	 name_list 	text NOT NULL,
	 owners_list 	text,
	 path_list 	text,
	 robot_list 	text NOT NULL,
	 status_list 	text,
	 subject_list 	text,
	 topics_list 	text,
	 web_archive_list 	integer,
	 PRIMARY KEY (name_list, robot_list)
);
