]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - db/laconica.sql
move email settings to its own tab
[quix0rs-gnu-social.git] / db / laconica.sql
index 7935b8b071c5311e546e0788cc6a186b4b278a7f..e906b05fe06be3ffd89736c3e9d97e49ec6e120f 100644 (file)
@@ -11,8 +11,9 @@ create table profile (
     created datetime not null comment 'date this record was created',
     modified timestamp comment 'date this record was modified',
 
-    index profile_nickname_idx (nickname)
-) ENGINE=InnoDB;
+    index profile_nickname_idx (nickname),
+    FULLTEXT(nickname, fullname, location, bio, homepage)
+) ENGINE=MyISAM;
 
 create table avatar (
     profile_id integer not null comment 'foreign key to profile table' references profile (id),
@@ -24,10 +25,18 @@ create table avatar (
     url varchar(255) unique key comment 'avatar location',
     created datetime not null comment 'date this record was created',
     modified timestamp comment 'date this record was modified',
-    
+
     constraint primary key (profile_id, width, height),
     index avatar_profile_id_idx (profile_id)
-) ENGINE=InnoDB;
+) ENGINE=MyISAM;
+
+create table sms_carrier (
+    id integer auto_increment primary key comment 'primary key for SMS carrier',
+    name varchar(64) unique key comment 'name of the carrier',
+    email_pattern varchar(255) not null comment 'sprintf pattern for making an email address from a phone number',
+    created datetime not null comment 'date this record was created',
+    modified timestamp comment 'date this record was modified'
+) ENGINE=MyISAM;
 
 /* local users */
 
@@ -36,10 +45,18 @@ create table user (
     nickname varchar(64) unique key comment 'nickname or username, duped in profile',
     password varchar(255) comment 'salted password, can be null for OpenID users',
     email varchar(255) unique key comment 'email address for password recovery etc.',
+    emailnotifysub tinyint default 1 unique key comment 'Notify by email of subscriptions',
+    jabber varchar(255) unique key comment 'jabber ID for notices',
+    jabbernotify tinyint default 0 comment 'whether to send notices to jabber',
+    jabberreplies tinyint default 0 comment 'whether to send notices to jabber on replies',
+    updatefrompresence tinyint default 0 comment 'whether to record updates from Jabber presence notices',
+    sms varchar(64) unique key comment 'sms phone number',
+    carrier integer comment 'foreign key to sms_carrier' references sms_carrier (id),
+    smsnotify tinyint default 0 comment 'whether to send notices to SMS',
     uri varchar(255) unique key comment 'universally unique identifier, usually a tag URI',
     created datetime not null comment 'date this record was created',
     modified timestamp comment 'date this record was modified'
-) ENGINE=InnoDB;
+) ENGINE=MyISAM;
 
 /* remote people */
 
@@ -50,7 +67,7 @@ create table remote_profile (
     updateprofileurl varchar(255) comment 'URL we use for updates to this profile',
     created datetime not null comment 'date this record was created',
     modified timestamp comment 'date this record was modified'
-) ENGINE=InnoDB;
+) ENGINE=MyISAM;
 
 create table subscription (
     subscriber integer not null comment 'profile listening',
@@ -63,30 +80,47 @@ create table subscription (
     constraint primary key (subscriber, subscribed),
     index subscription_subscriber_idx (subscriber),
     index subscription_subscribed_idx (subscribed)
-) ENGINE=InnoDB;
+) ENGINE=MyISAM;
 
 create table notice (
+
     id integer auto_increment primary key comment 'unique identifier',
     profile_id integer not null comment 'who made the update' references profile (id),
     uri varchar(255) unique key comment 'universally unique identifier, usually a tag URI',
     content varchar(140) comment 'update content',
-    /* XXX: cache rendered content. */
+    rendered text comment 'HTML version of the content',
     url varchar(255) comment 'URL of any attachment (image, video, bookmark, whatever)',
     created datetime not null comment 'date this record was created',
     modified timestamp comment 'date this record was modified',
+    reply_to integer comment 'notice replied to (usually a guess)' references notice (id),
+
+    index notice_profile_id_idx (profile_id),
+    FULLTEXT(content)
+) ENGINE=MyISAM;
+
+create table reply (
 
-    index notice_profile_id_idx (profile_id)
-) ENGINE=InnoDB;
+    notice_id integer not null comment 'notice that is the reply' references notice (id),
+    profile_id integer not null comment 'profile replied to' references profile (id),
+    modified timestamp not null comment 'date this record was modified',
+    replied_id integer comment 'notice replied to (not used, see notice.reply_to)',
+    
+    constraint primary key (notice_id, profile_id),
+    index reply_notice_id_idx (notice_id),
+    index reply_profile_id_idx (profile_id),
+    index reply_replied_id_idx (replied_id)
+
+) ENGINE=MyISAM;
 
 /* tables for OAuth */
 
 create table consumer (
     consumer_key varchar(255) primary key comment 'unique identifier, root URL',
     seed char(32) not null comment 'seed for new tokens by this consumer',
-    
+
     created datetime not null comment 'date this record was created',
     modified timestamp comment 'date this record was modified'
-) ENGINE=InnoDB;
+) ENGINE=MyISAM;
 
 create table token (
     consumer_key varchar(255) not null comment 'unique identifier, root URL' references consumer (consumer_key),
@@ -94,25 +128,25 @@ create table token (
     secret char(32) not null comment 'secret value',
     type tinyint not null default 0 comment 'request or access',
     state tinyint default 0 comment 'for requests; 0 = initial, 1 = authorized, 2 = used',
-    
+
     created datetime not null comment 'date this record was created',
     modified timestamp comment 'date this record was modified',
-    
+
     constraint primary key (consumer_key, tok)
-) ENGINE=InnoDB;
+) ENGINE=MyISAM;
 
 create table nonce (
     consumer_key varchar(255) not null comment 'unique identifier, root URL',
     tok char(32) not null comment 'identifying value',
     nonce char(32) not null comment 'nonce',
     ts datetime not null comment 'timestamp sent',
-    
+
     created datetime not null comment 'date this record was created',
     modified timestamp comment 'date this record was modified',
-    
+
     constraint primary key (consumer_key, tok, nonce),
     constraint foreign key (consumer_key, tok) references token (consumer_key, tok)
-) ENGINE=InnoDB;
+) ENGINE=MyISAM;
 
 /* One-to-many relationship of user to openid_url */
 
@@ -122,9 +156,9 @@ create table user_openid (
     user_id integer not null comment 'user owning this URL' references user (id),
     created datetime not null comment 'date this record was created',
     modified timestamp comment 'date this record was modified',
-    
+
     index user_openid_user_id_idx (user_id)
-) ENGINE=InnoDB;
+) ENGINE=MyISAM;
 
 /* These are used by JanRain OpenID library */
 
@@ -136,18 +170,39 @@ create table oid_associations (
     lifetime INTEGER,
     assoc_type VARCHAR(64),
     PRIMARY KEY (server_url(255), handle)
-) ENGINE=InnoDB;
+) ENGINE=MyISAM;
 
 create table oid_nonces (
     server_url VARCHAR(2047),
     timestamp INTEGER,
     salt CHAR(40),
     UNIQUE (server_url(255), timestamp, salt)
-) ENGINE=InnoDB;
+) ENGINE=MyISAM;
 
-create table confirmemail (
+create table confirm_address (
     code varchar(32) not null primary key comment 'good random code',
     user_id integer not null comment 'user who requested confirmation' references user (id),
-    email varchar(255) not null comment 'email address for password recovery etc.',
+    address varchar(255) not null comment 'address (email, Jabber, SMS, etc.)',
+    address_extra varchar(255) not null comment 'carrier ID, for SMS',
+    address_type varchar(8) not null comment 'address type ("email", "jabber", "sms")',
+    claimed datetime comment 'date this was claimed for queueing',
+    sent datetime comment 'date this was sent for queueing',
     modified timestamp comment 'date this record was modified'
-);
+) ENGINE=MyISAM;
+
+create table remember_me (
+    code varchar(32) not null primary key comment 'good random code',
+    user_id integer not null comment 'user who is logged in' references user (id),
+    modified timestamp comment 'date this record was modified'
+) ENGINE=MyISAM;
+
+create table queue_item (
+
+    notice_id integer not null primary key comment 'notice queued' references notice (id),
+    created datetime not null comment 'date this record was created',
+    claimed datetime comment 'date this item was claimed',
+
+    index queue_item_created_idx (created)
+
+) ENGINE=MyISAM;
+