. }}} */ namespace App\Entity; /** * Entity for user invitations * * @category DB * @package GNUsocial * * @author Zach Copley * @copyright 2010 StatusNet Inc. * @author Mikael Nordfeldth * @copyright 2009-2014 Free Software Foundation, Inc http://www.fsf.org * @author Hugo Sales * @copyright 2020 Free Software Foundation, Inc http://www.fsf.org * @license https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later */ class Invitation { // AUTOCODE BEGIN // AUTOCODE END public static function schemaDef(): array { return [ 'name' => 'invitation', 'fields' => [ 'code' => ['type' => 'varchar', 'length' => 32, 'not null' => true, 'description' => 'random code for an invitation'], 'user_id' => ['type' => 'int', 'not null' => true, 'description' => 'who sent the invitation'], 'address' => ['type' => 'varchar', 'length' => 191, 'not null' => true, 'description' => 'invitation sent to'], 'address_type' => ['type' => 'varchar', 'length' => 8, 'not null' => true, 'description' => 'address type ("email", "xmpp", "sms")'], 'created' => ['type' => 'datetime', 'not null' => true, 'default' => '0000-00-00 00:00:00', 'description' => 'date this record was created'], 'registered_user_id' => ['type' => 'int', 'not null' => false, 'description' => 'if the invitation is converted, who the new user is'], ], 'primary key' => ['code'], 'foreign keys' => [ 'invitation_user_id_fkey' => ['user', ['user_id' => 'id']], 'invitation_registered_user_id_fkey' => ['user', ['registered_user_id' => 'id']], ], 'indexes' => [ 'invitation_address_idx' => ['address', 'address_type'], 'invitation_user_id_idx' => ['user_id'], 'invitation_registered_user_id_idx' => ['registered_user_id'], ], ]; } }