User_im_prefs.php 3.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. <?php
  2. /**
  3. * StatusNet, the distributed open-source microblogging tool
  4. *
  5. * Data class for user IM preferences
  6. *
  7. * PHP version 5
  8. *
  9. * LICENCE: This program is free software: you can redistribute it and/or modify
  10. * it under the terms of the GNU Affero General Public License as published by
  11. * the Free Software Foundation, either version 3 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU Affero General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU Affero General Public License
  20. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  21. *
  22. * @category Data
  23. * @package StatusNet
  24. * @author Craig Andrews <candrews@integralblue.com>
  25. * @copyright 2009 StatusNet Inc.
  26. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
  27. * @link http://status.net/
  28. */
  29. require_once INSTALLDIR.'/classes/Memcached_DataObject.php';
  30. class User_im_prefs extends Managed_DataObject
  31. {
  32. ###START_AUTOCODE
  33. /* the code below is auto generated do not remove the above tag */
  34. public $__table = 'user_im_prefs'; // table name
  35. public $user_id; // int(4) primary_key not_null
  36. public $screenname; // varchar(255) not_null
  37. public $transport; // varchar(255) not_null
  38. public $notify; // tinyint(1)
  39. public $replies; // tinyint(1)
  40. public $microid; // tinyint(1)
  41. public $updatefrompresence; // tinyint(1)
  42. public $created; // datetime not_null default_0000-00-00%2000%3A00%3A00
  43. public $modified; // timestamp not_null default_CURRENT_TIMESTAMP
  44. /* the code above is auto generated do not remove the tag below */
  45. ###END_AUTOCODE
  46. public static function schemaDef()
  47. {
  48. return array(
  49. 'fields' => array(
  50. 'user_id' => array('type' => 'int', 'not null' => true, 'description' => 'user'),
  51. 'screenname' => array('type' => 'varchar', 'length' => 255, 'not null' => true, 'description' => 'screenname on this service'),
  52. 'transport' => array('type' => 'varchar', 'length' => 255, 'not null' => true, 'description' => 'transport (ex xmpp, aim)'),
  53. 'notify' => array('type' => 'int', 'size' => 'tiny', 'not null' => true, 'default' => 0, 'description' => 'Notify when a new notice is sent'),
  54. 'replies' => array('type' => 'int', 'size' => 'tiny', 'not null' => true, 'default' => 0, 'description' => 'Send replies from people not subscribed to'),
  55. 'microid' => array('type' => 'int', 'size' => 'tiny', 'not null' => true, 'default' => 1, 'description' => 'Publish a MicroID'),
  56. 'updatefrompresence' => array('type' => 'int', 'size' => 'tiny', 'not null' => true, 'default' => 0, 'description' => 'Send replies from people not subscribed to.'),
  57. 'created' => array('type' => 'datetime', 'not null' => true, 'description' => 'date this record was created'),
  58. 'modified' => array('type' => 'timestamp', 'not null' => true, 'description' => 'date this record was modified'),
  59. ),
  60. 'primary key' => array('user_id', 'transport'),
  61. 'unique keys' => array(
  62. 'transport_screenname_key' => array('transport', 'screenname'),
  63. ),
  64. 'foreign keys' => array(
  65. 'user_im_prefs_user_id_fkey' => array('user', array('user_id' => 'id')),
  66. ),
  67. );
  68. }
  69. }