Exemplo n.º 1
0
 function addFeedbackFrom($user, $value)
 {
     require_once "query.php";
     $db = new DBManager();
     if (!$db->connect_errno()) {
         define_tables();
         defineFeedbackColumns();
         $table = Query::getDBSchema()->getTable(TABLE_FEEDBACK);
         $db->execute($s = Query::generateInsertStm($table, array(FEEDBACK_CREATOR => $user->getID(), FEEDBACK_SUBJECT => $this->getID(), FEEDBACK_VALUE => $value ? 1 : 0)), $table->getName(), $this);
         if ($db->affected_rows() != 1) {
             $db->display_error("User::addFeedbackFrom()");
         }
         //Genera un errore ma ritorna comunque $this
     } else {
         $db->display_connect_error("User::addFeedbackFrom()");
     }
     return $this->loadFeedback();
 }
Exemplo n.º 2
0
 /**
  * Crea un tag.
  * @param string $tag
  * @return TRUE se il tag è stato creato, FALSE altrimenti.
  */
 static function createTag($tag)
 {
     require_once "query.php";
     $db = new DBManager();
     if (!$db->connect_errno()) {
         define_tables();
         defineTagColumns();
         $table = Query::getDBSchema()->getTable(TABLE_TAG);
         $data = array(TAG_NAME => $tag);
         $db->execute($s = Query::generateInsertStm($table, $data), $table->getName(), $tag);
         if ($db->affected_rows() == 1) {
             return true;
         } else {
             return false;
         }
     } else {
         $db->display_connect_error("TagManager::createTag()");
     }
 }
Exemplo n.º 3
0
 private static function searchPostsBy($keys, $options, $echo_query = false)
 {
     require_once "query.php";
     require_once "strings/strings.php";
     define_tables();
     definePostColumns();
     $table = Query::getDBSchema()->getTable(TABLE_POST);
     $loadComments = true;
     $wheres = array();
     foreach ($keys as $key => $value) {
         if ($key == "name" || $key == "title") {
             $wheres[] = new WhereConstraint($table->getColumn(POST_TITLE), Operator::LIKE, "%" . Filter::filterText($value) . "%");
         }
         if ($key == "permalink") {
             $wheres[] = new WhereConstraint($table->getColumn(POST_PERMALINK), Operator::EQUAL, intval($value));
         }
         if ($key == "id") {
             $wheres[] = new WhereConstraint($table->getColumn(POST_ID), Operator::EQUAL, intval($value));
         }
         if ($key == "tag") {
             $wheres[] = new WhereConstraint($table->getColumn(POST_TAGS), Operator::LIKE, "%" . Filter::filterText($value) . "%");
         }
         if ($key == "day") {
             if (!is_numeric($value)) {
                 $value = date_timestamp_get(date_create_from_format("Y-m-d", $value));
             }
             $daystart = date("Y-m-d", $value);
             $dayend = date("Y-m-d", $value + 24 * 60 * 60);
             //echo "<br />" . $daystart . "-" . $dayend; //DEBUG
             $wheres[] = new WhereConstraint($table->getColumn(POST_CREATION_DATE), Operator::GREATEROREQUAL, $daystart);
             $wheres[] = new WhereConstraint($table->getColumn(POST_CREATION_DATE), Operator::LESSER, $dayend);
         }
         if ($key == "category") {
             $wheres[] = new WhereConstraint($table->getColumn(POST_CATEGORIES), Operator::LIKE, "%" . Filter::filterText($value) . "%");
         }
         if ($key == "title") {
             $wheres[] = new WhereConstraint($table->getColumn(POST_TITLE), Operator::LIKE, "%" . Filter::filterText($value) . "%");
         }
         if ($key == "content") {
             $wheres[] = new WhereConstraint($table->getColumn(POST_CONTENT), Operator::LIKE, "%" . Filter::filterText($value) . "%");
         }
         if ($key == "author") {
             $wheres[] = new WhereConstraint($table->getColumn(POST_AUTHOR), Operator::EQUAL, intval($value));
         }
         if ($key == "no_id") {
             $wheres[] = new WhereConstraint($table->getColumn(POST_ID), Operator::NOTEQUAL, intval($value));
         }
         if ($key == "loadComments") {
             $loadComments = $value == true;
         }
     }
     $newopt = array();
     foreach ($options as $key => $value) {
         if ($key == "by") {
             if (!is_array($value)) {
                 $value = array($value);
             }
             $newvalue = array();
             foreach ($value as $column) {
                 if (!is_a($column, "Column")) {
                     $column = $table->getColumn($column);
                 }
                 if (!is_null($column)) {
                     $newvalue[] = $column;
                 }
             }
             $value = $newvalue;
         }
         $newopt[$key] = $value;
     }
     $db = new DBManager();
     $db->execute($s = Query::generateSelectStm(array($table), array(), $wheres, $newopt));
     if ($echo_query) {
         echo "<font color='red'>" . $s . "</font>";
     }
     //DEBUG
     $posts = array();
     while ($row = $db->fetch_result()) {
         require_once "post/Post.php";
         $posts[] = Post::createFromDBResult($row, $loadComments);
     }
     return $posts;
 }
Exemplo n.º 4
0
<?php

require_once "strings/strings.php";
defineCategoryColumns();
defineCommentColumns();
defineContactColumns();
defineContactTypeColumns();
defineContestColumns();
defineContestSubscriberColumns();
defineFeedbackColumns();
defineFollowColumns();
defineLogColumns();
defineMailColumns();
defineMailDirColumns();
defineMailInDirColumns();
definePostColumns();
defineReportColumns();
defineResourceColumns();
defineRoleColumns();
defineSubCategoryColumns();
defineTagColumns();
defineUserColumns();
defineVoteColumns();
define_tables();
$s = "CREATE TABLE IF NOT EXISTS `" . TABLE_CATEGORY . "` (\n  `" . CATEGORY_NAME . "` varchar(50) NOT NULL,\n  PRIMARY KEY (`" . CATEGORY_NAME . "`)\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_CONTEST . "` (\n  `" . CONTEST_ID . "` bigint(20) NOT NULL AUTO_INCREMENT,\n  `" . CONTEST_TITLE . "` varchar(50) DEFAULT NULL,\n  `" . CONTEST_DESCRIPTION . "` text DEFAULT NULL,\n  `" . CONTEST_TYPE_OF_SUBSCRIBER . "` enum('post','photoreportage','videoreportage','news','collection','album','playlist','magazine') DEFAULT NULL,\n  `" . CONTEST_RULES . "` text,\n  `" . CONTEST_PRIZES . "` text DEFAULT NULL,\n  `" . CONTEST_START . "` datetime NULL DEFAULT NULL,\n  `" . CONTEST_END . "` datetime NULL DEFAULT NULL,\n  PRIMARY KEY (`" . CONTEST_ID . "`)\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_ROLE . "` (\n  `" . ROLE_NAME . "` varchar(50) NOT NULL,\n  PRIMARY KEY (`" . ROLE_NAME . "`)\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_USER . "` (\n  `" . USER_ID . "` bigint(20) NOT NULL AUTO_INCREMENT,\n  `" . USER_NICKNAME . "` varchar(100) NULL,\n  `" . USER_E_MAIL . "` varchar(100) NOT NULL,\n  `" . USER_PASSWORD . "` varchar(128) NOT NULL,\n  `" . USER_NAME . "` varchar(100) NULL,\n  `" . USER_SURNAME . "` varchar(100) NULL,\n  `" . USER_GENDER . "` enum('m','f') DEFAULT NULL,\n  `" . USER_BIRTHDAY . "` date NULL,\n  `" . USER_BIRTHPLACE . "` varchar(255) NULL,\n  `" . USER_LIVINGPLACE . "` varchar(255) NULL,\n  `" . USER_AVATAR . "` varchar(255) DEFAULT NULL,\n  `" . USER_HOBBIES . "` varchar(200) NULL,\n  `" . USER_JOB . "` varchar(100) NULL,\n  `" . USER_ROLE . "` varchar(50) NULL DEFAULT 'user',\n  `" . USER_CREATION_DATE . "` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,\n  `" . USER_VISIBLE . "` tinyint(1) DEFAULT 0,\n  `" . USER_VERIFIED . "` tinyint(1) DEFAULT 0,\n  PRIMARY KEY (`" . USER_ID . "`),\n  UNIQUE KEY `" . USER_NICKNAME_UKEY . "` (`" . USER_NICKNAME . "`),\n  UNIQUE KEY `" . USER_E_MAIL_UKEY . "` (`" . USER_E_MAIL . "`),\n  KEY `" . USER_ROLE_FKEY . "` (`" . USER_ROLE . "`),\n  FOREIGN KEY (`" . USER_ROLE . "`) REFERENCES `" . TABLE_ROLE . "` (`" . ROLE_NAME . "`) ON DELETE SET NULL\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin AUTO_INCREMENT=1;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_POST . "` (\n  `" . POST_ID . "` bigint(20) NOT NULL AUTO_INCREMENT,\n  `" . POST_PERMALINK . "` text NOT NULL,\n  `" . POST_TYPE . "` enum('post','photoreportage','videoreportage','news','collection','album','playlist','magazine') DEFAULT NULL,\n  `" . POST_TITLE . "` varchar(100) NOT NULL,\n  `" . POST_SUBTITLE . "` varchar(100) NULL,\n  `" . POST_HEADLINE . "` varchar(100) NULL,\n  `" . POST_CREATION_DATE . "` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,\n  `" . POST_MODIFICATION_DATE . "` datetime NULL,\n  `" . POST_CONTENT . "` text NOT NULL,\n  `" . POST_TAGS . "` text NULL,\n  `" . POST_CATEGORIES . "` text NULL,\n  `" . POST_VISIBLE . "` tinyint(1) DEFAULT 0,\n  `" . POST_AUTHOR . "` bigint(20) NULL,\n  `" . POST_PLACE . "` text NULL,\n  PRIMARY KEY (`" . POST_ID . "`),\n  KEY `" . POST_USER_FKEY . "` (`" . POST_AUTHOR . "`),\n  FOREIGN KEY (`" . POST_AUTHOR . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE SET NULL\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin AUTO_INCREMENT=1;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_COMMENT . "` (\n  `" . COMMENT_ID . "` bigint(20) NOT NULL AUTO_INCREMENT,\n  `" . COMMENT_CREATION_DATE . "` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,\n  `" . COMMENT_COMMENT . "` text NOT NULL,\n  `" . COMMENT_AUTHOR . "` bigint(20) NULL,\n  `" . COMMENT_POST . "` bigint(20) NOT NULL,\n  PRIMARY KEY (`" . COMMENT_ID . "`),\n  KEY `" . COMMENT_USER_FKEY . "` (`" . COMMENT_AUTHOR . "`),\n  KEY `" . COMMENT_POST_FKEY . "` (`" . COMMENT_POST . "`),\n  FOREIGN KEY (`" . COMMENT_AUTHOR . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE SET NULL,\n  FOREIGN KEY (`" . COMMENT_POST . "`) REFERENCES `" . TABLE_POST . "` (`" . POST_ID . "`) ON DELETE CASCADE\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_CONTACT_TYPE . "` (\n  `" . CONTACT_TYPE_TYPE . "` enum('phone', 'address', 'email', 'website', 'IM') NOT NULL,\n  `" . CONTACT_TYPE_NAME . "` varchar(20) NOT NULL,\n  PRIMARY KEY (`" . CONTACT_TYPE_NAME . "`)\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_CONTACT . "` (\n  `" . CONTACT_ID . "` bigint(20) NOT NULL AUTO_INCREMENT,\n  `" . CONTACT_CONTACT . "` varchar(100) NOT NULL,\n  `" . CONTACT_USER . "` bigint(20) NOT NULL,\n  `" . CONTACT_NAME . "` varchar(20) NULL DEFAULT 'other',\n  PRIMARY KEY (`" . CONTACT_ID . "`),\n  KEY `" . CONTACT_CONTACT_TYPE_FKEY . "` (`" . CONTACT_NAME . "`),\n  KEY `" . CONTACT_USER_FKEY . "` (`" . CONTACT_USER . "`),\n  FOREIGN KEY (`" . CONTACT_USER . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE CASCADE,\n  FOREIGN KEY (`" . CONTACT_NAME . "`) REFERENCES `" . TABLE_CONTACT_TYPE . "` (`" . CONTACT_TYPE_NAME . "`) ON DELETE SET NULL ON UPDATE CASCADE\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_CONTEST_SUBSCRIBER . "` (\n  `" . CONTEST_SUBSCRIBER_CONTEST . "` bigint(20) NOT NULL,\n  `" . CONTEST_SUBSCRIBER_POST . "` bigint(20) NOT NULL,\n  `" . CONTEST_SUBSCRIBER_PLACEMENT . "` tinyint(10) NOT NULL,\n  PRIMARY KEY (`" . CONTEST_SUBSCRIBER_CONTEST . "`,`" . CONTEST_SUBSCRIBER_POST . "`),\n  KEY `" . CONTEST_SUBSCRIBER_CONTEST_FKEY . "` (`" . CONTEST_SUBSCRIBER_CONTEST . "`),\n  KEY `" . CONTEST_SUBSCRIBER_POST_FKEY . "` (`" . CONTEST_SUBSCRIBER_POST . "`),\n  UNIQUE KEY `" . CONTEST_SUBSCRIBER_UKEY . "` (`" . CONTEST_SUBSCRIBER_CONTEST . "`, `" . CONTEST_SUBSCRIBER_PLACEMENT . "`),\n  FOREIGN KEY (`" . CONTEST_SUBSCRIBER_CONTEST . "`) REFERENCES `" . TABLE_CONTEST . "` (`" . CONTEST_ID . "`) ON DELETE CASCADE,\n  FOREIGN KEY (`" . CONTEST_SUBSCRIBER_POST . "`) REFERENCES `" . TABLE_POST . "` (`" . POST_ID . "`) ON DELETE CASCADE\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_FEEDBACK . "` (\n  `" . FEEDBACK_CREATOR . "` bigint(20) NOT NULL,\n  `" . FEEDBACK_SUBJECT . "` bigint(20) NOT NULL,\n  `" . FEEDBACK_VALUE . "` int(11) DEFAULT NULL,\n  `" . FEEDBACK_CREATION_DATE . "` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,\n  PRIMARY KEY (`" . FEEDBACK_CREATOR . "`,`" . FEEDBACK_SUBJECT . "`),\n  KEY `" . FEEDBACK_USER_FKEY1 . "` (`" . FEEDBACK_CREATOR . "`),\n  KEY `" . FEEDBACK_USER_FKEY2 . "` (`" . FEEDBACK_SUBJECT . "`),\n  FOREIGN KEY (`" . FEEDBACK_CREATOR . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE CASCADE,\n  FOREIGN KEY (`" . FEEDBACK_SUBJECT . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE CASCADE\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_FOLLOW . "` (\n  `" . FOLLOW_SUBJECT . "` bigint(20) NOT NULL,\n  `" . FOLLOW_FOLLOWER . "` bigint(20) NOT NULL,\n  `" . FOLLOW_SUBSCRIPTION_DATE . "` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,\n  PRIMARY KEY (`" . FOLLOW_SUBJECT . "`,`" . FOLLOW_FOLLOWER . "`),\n  KEY `" . FOLLOW_USER_FKEY1 . "` (`" . FOLLOW_SUBJECT . "`),\n  KEY `" . FOLLOW_USER_FKEY2 . "` (`" . FOLLOW_FOLLOWER . "`),\n  FOREIGN KEY (`" . FOLLOW_SUBJECT . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE CASCADE,\n  FOREIGN KEY (`" . FOLLOW_FOLLOWER . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE CASCADE\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_LOG . "` (\n  `" . LOG_ID . "` varchar(40) NOT NULL,\n  `" . LOG_TIMESTAMP . "` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,\n  `" . LOG_ACTION . "` enum('INSERT','UPDATE','DELETE') NOT NULL,\n  `" . LOG_TABLE . "` varchar(20) NOT NULL,\n  `" . LOG_SUBJECT . "` bigint(20) NULL,\n  `" . LOG_OBJECT . "` varchar(40) NOT NULL,\n  PRIMARY KEY (`" . LOG_ID . "`),\n  KEY `" . LOG_USER_FKEY . "` (`" . LOG_SUBJECT . "`),\n  FOREIGN KEY (`" . LOG_SUBJECT . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE SET NULL\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `AccessLog` (\n  `alog_type` varchar(10) NOT NULL,\n  `alog_id` bigint(20) NOT NULL,\n  `alog_count` bigint(20) NOT NULL DEFAULT 1,\n  PRIMARY KEY (`alog_type`, `alog_id`)\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_MAIL . "` (\n  `" . MAIL_ID . "` bigint(20) NOT NULL AUTO_INCREMENT,\n  `" . MAIL_SUBJECT . "` varchar(50) DEFAULT NULL,\n  `" . MAIL_TEXT . "` text,\n  `" . MAIL_FROM . "` bigint(20) NOT NULL,\n  `" . MAIL_TO . "` varchar(255) NOT NULL,\n  `" . MAIL_REPLIES_TO . "` bigint(20) NULL,\n  `" . MAIL_CREATION_DATE . "` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,\n  PRIMARY KEY (`" . MAIL_ID . "`),\n  KEY `" . MAIL_USER_FKEY . "` (`" . MAIL_FROM . "`),\n  KEY `" . MAIL_MAIL_FKEY . "` (`" . MAIL_REPLIES_TO . "`),\n  FOREIGN KEY (`" . MAIL_FROM . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE CASCADE,\n  FOREIGN KEY (`" . MAIL_REPLIES_TO . "`) REFERENCES `" . TABLE_MAIL . "` (`" . MAIL_ID . "`) ON DELETE SET NULL\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin AUTO_INCREMENT=1;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_MAIL_DIRECTORY . "` (\n  `" . MAIL_DIRECTORY_ID . "` bigint(20) NOT NULL AUTO_INCREMENT,\n  `" . MAIL_DIRECTORY_NAME . "` varchar(50) NOT NULL,\n  `" . MAIL_DIRECTORY_OWNER . "` bigint(20) NOT NULL,\n  PRIMARY KEY (`" . MAIL_DIRECTORY_ID . "`),\n  KEY `" . MAIL_DIRECTORY_USER_FKEY . "` (`" . MAIL_DIRECTORY_OWNER . "`),\n  FOREIGN KEY (`" . MAIL_DIRECTORY_OWNER . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE CASCADE\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin AUTO_INCREMENT=1;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_MAIL_IN_DIRECTORY . "` (\n  `" . MAIL_IN_DIRECTORY_READ . "` tinyint(1) DEFAULT 0,\n  `" . MAIL_IN_DIRECTORY_DIRECTORY . "` bigint(20) NOT NULL,\n  `" . MAIL_IN_DIRECTORY_MAIL . "` bigint(20) NOT NULL,\n  PRIMARY KEY (`mod_dir`,`mod_mail`),\n  KEY `" . MAIL_IN_DIRECTORY_MAIL_DIRECTORY_FKEY . "` (`" . MAIL_IN_DIRECTORY_DIRECTORY . "`),\n  KEY `" . MAIL_IN_DIRECTORY_MAIL_FKEY . "` (`" . MAIL_IN_DIRECTORY_MAIL . "`),\n  FOREIGN KEY (`" . MAIL_IN_DIRECTORY_DIRECTORY . "`) REFERENCES `" . TABLE_MAIL_DIRECTORY . "` (`" . MAIL_DIRECTORY_ID . "`) ON DELETE CASCADE,\n  FOREIGN KEY (`" . MAIL_IN_DIRECTORY_MAIL . "`) REFERENCES `" . TABLE_MAIL . "` (`" . MAIL_ID . "`) ON DELETE CASCADE\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_REPORT . "` (\n  `" . REPORT_ID . "` bigint(20) NOT NULL AUTO_INCREMENT,\n  `" . REPORT_POST . "` bigint(20) NOT NULL,\n  `" . REPORT_USER . "` bigint(20) NULL,\n  `rp_report` text NOT NULL,\n  PRIMARY KEY (`" . REPORT_ID . "`),\n  UNIQUE KEY `" . REPORT_USER_POST_UKEY . "` (`" . REPORT_POST . "`, `" . REPORT_USER . "`),\n  KEY `" . REPORT_POST_FKEY . "` (`" . REPORT_POST . "`),\n  KEY `" . REPORT_USER_FKEY . "` (`" . REPORT_USER . "`),\n  FOREIGN KEY (`" . REPORT_POST . "`) REFERENCES `" . TABLE_POST . "` (`" . POST_ID . "`) ON DELETE CASCADE,\n  FOREIGN KEY (`" . REPORT_USER . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE SET NULL\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin AUTO_INCREMENT=1;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_RESOURCE . "` (\n  `" . RESOURCE_ID . "` bigint(20) NOT NULL,\n  `" . RESOURCE_TYPE . "` enum('video','photo') NOT NULL,\n  `" . RESOURCE_PATH . "` varchar(255) NOT NULL,\n  `" . RESOURCE_OWNER . "` bigint(20) NULL,\n  PRIMARY KEY (`" . RESOURCE_ID . "`),\n  KEY `" . RESOURCE_USER_FKEY . "` (`" . RESOURCE_OWNER . "`),\n  FOREIGN KEY (`" . RESOURCE_OWNER . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE SET NULL\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_SUB_CATEGORY . "` (\n  `" . SUB_CATEGORY_PARENT . "` varchar(50) NOT NULL,\n  `" . SUB_CATEGORY_CATEGORY . "` varchar(50) NOT NULL,\n  PRIMARY KEY (`" . SUB_CATEGORY_PARENT . "`,`" . SUB_CATEGORY_CATEGORY . "`),\n  KEY `" . SUB_CATEGORY_CATEGORY_FKEY1 . "` (`" . SUB_CATEGORY_PARENT . "`),\n  KEY `" . SUB_CATEGORY_CATEGORY_FKEY2 . "` (`" . SUB_CATEGORY_CATEGORY . "`),\n  FOREIGN KEY (`" . SUB_CATEGORY_PARENT . "`) REFERENCES `" . TABLE_CATEGORY . "` (`" . CATEGORY_NAME . "`) ON DELETE CASCADE,\n  FOREIGN KEY (`" . SUB_CATEGORY_CATEGORY . "`) REFERENCES `" . TABLE_CATEGORY . "` (`" . CATEGORY_NAME . "`) ON DELETE CASCADE\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_TAG . "` (\n  `" . TAG_NAME . "` varchar(50) NOT NULL,\n  PRIMARY KEY (`" . TAG_NAME . "`)\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;\n\nCREATE TABLE IF NOT EXISTS `" . TABLE_VOTE . "` (\n  `" . VOTE_CREATION_DATE . "` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,\n  `" . VOTE_VOTE . "` int(10) unsigned NOT NULL,\n  `" . VOTE_AUTHOR . "` bigint(20) NULL,\n  `" . VOTE_POST . "` bigint(20) NOT NULL,\n  KEY `" . VOTE_USER_FKEY . "` (`" . VOTE_AUTHOR . "`),\n  KEY `" . VOTE_POST_FKEY . "` (`" . VOTE_POST . "`),\n  FOREIGN KEY (`" . VOTE_AUTHOR . "`) REFERENCES `" . TABLE_USER . "` (`" . USER_ID . "`) ON DELETE SET NULL,\n  FOREIGN KEY (`" . VOTE_POST . "`) REFERENCES `" . TABLE_POST . "` (`" . POST_ID . "`) ON DELETE CASCADE\n) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin DEFAULT CHARSET=utf8 COLLATE=utf8_bin;";
//avatar non può essere in dipendenza da una risorsa perché crea un ciclio di dipendenze…
//una soluzione è creare una tabella Avatar… da discutere.
//ALTER TABLE `" . TABLE_USER . "` ADD CONSTRAINT
//  KEY `" . USER_RESOURCE_FKEY . "` (`" . USER_AVATAR . "`),
//  FOREIGN KEY (`" . USER_AVATAR . "`) REFERENCES `" . TABLE_RESOURCE . "` (`" . RESOURCE_ID . "`) ON DELETE NO ACTION";
Exemplo n.º 5
0
 /**
  * @deprecated
  * Enter description here ...
  * @param unknown_type $type
  * @param unknown_type $id
  */
 static function getAccessCount($type, $id)
 {
     if ($type == null || $type == "" || $id == null) {
         return 0;
     }
     $db = new DBManager();
     if (!$db->connect_errno()) {
         define_tables();
         defineLogColumns();
         $table = Query::getDBSchema()->getTable("AccessLog");
         $exists = false;
         if ($type == "Post") {
             require_once 'post/PostManager.php';
             return 0;
             $exists = PostManager::postExists($id);
         } else {
             if ($type == "User") {
                 require_once 'user/UserManager.php';
                 return 0;
                 $exists = UserManager::userExists($id);
             } elseif ($type == "Partner") {
                 //TODO: implementa Partner
                 //				require_once 'post/PartnerManager.php';
                 //				$exists = PartnerManager::partnerExists($id);
             }
         }
         if ($exists) {
             $wheres = array(new WhereConstraint($table->getColumn("alog_type"), Operator::EQUAL, $type), new WhereConstraint($table->getColumn("alog_id"), Operator::EQUAL, $id));
             $db->execute($s = Query::generateSelectStm(array($table), array(), $wheres, array()));
             if ($db->num_rows() == 1) {
                 $row = $db->fetch_result();
                 $data = array("alog_count" => ++$row["alog_count"]);
                 $db->execute($s = Query::generateUpdateStm($table, $data, $wheres), null, LOGMANAGER);
                 if ($db->affected_rows() == 1) {
                     return $row["alog_count"];
                 }
             } else {
                 $data = array("alog_type" => $type, "alog_id" => $id);
                 $db->execute($s = Query::generateInsertStm($table, $data));
                 if ($db->affected_rows() == 1) {
                 }
                 return 1;
             }
         }
         return 0;
     }
 }
Exemplo n.º 6
0
 function loadFeedback()
 {
     require_once "query.php";
     $db = new DBManager();
     if (!$db->connect_errno()) {
         define_tables();
         defineFeedbackColumns();
         $table = Query::getDBSchema()->getTable(TABLE_FEEDBACK);
         $db->execute($s = Query::generateSelectStm(array($table), array(), array(new WhereConstraint($table->getColumn(FEEDBACK_SUBJECT), Operator::EQUAL, $this->getID())), array()));
         if ($db->num_rows() > 0) {
             require_once "strings/strings.php";
             $fb = FEEDBACK_INITIAL_VALUE;
             while ($row = $db->fetch_result()) {
                 $fb += intval($row[FEEDBACK_VALUE]) > 0 ? 1 : -1;
                 //se sul DB è 0 allora è -1 se è positivo allora +1;
             }
             return $this->setFeedback($fb);
         } else {
             if ($db->errno()) {
                 $db->display_error("User::loadFeedback()");
             }
         }
     } else {
         $db->display_connect_error("User::loadFeedback()");
     }
     return $this->setFeedback(FEEDBACK_INITIAL_VALUE);
 }
Exemplo n.º 7
0
 static function loadMailsFromUser($user)
 {
     require_once "query.php";
     $db = new DBManager();
     if (!$db->connect_errno()) {
         define_tables();
         defineMailColumns();
         $table = Query::getDBSchema()->getTable(TABLE_MAIL);
         $db->execute($s = Query::generateSelectStm(array($table), array(), array(new WhereConstraint($table->getColumn(MAIL_FROM), Operator::EQUAL, $user)), array()), $table->getName(), $this);
         //echo "<p>" . $s . "</p>"; //DEBUG
         //echo "<p>" . $db->num_rows() . "</p>"; //DEBUG
         if ($db->num_rows() == 1) {
             // echo serialize(mysql_fetch_assoc($rs)); //DEBUG
             $mails = array();
             while ($row = $db->fetch_result()) {
                 $data = array("text" => $row[MAIL_TEXT], "subject" => $row[MAIL_SUBJECT], "from" => intval($row[MAIL_FROM]), "to" => $row[MAIL_TO], "repliesTo" => $row[MAIL_REPLIES_TO]);
                 $m = new Mail($data);
                 $m->setID(intval($row[MAIL_ID]))->setCreationDate(date_timestamp_get(date_create_from_format("Y-m-d G:i:s", $row[MAIL_CREATION_DATE])));
                 $mails[] = $m;
             }
             //echo "<p>" .$m ."</p>";
             return $mails;
         } else {
             $db->display_error("Mail::loadMailsFromUser()");
         }
     } else {
         $db->display_connect_error("Mail::loadMailsFromUser()");
     }
     return false;
 }
Exemplo n.º 8
0
 /**
  * Carica in this i report recuperati dal database per questo post (deve avere un ID!).
  */
 function loadReports()
 {
     require_once "query.php";
     $db = new DBManager();
     if (!$db->connect_errno()) {
         define_tables();
         defineReportColumns();
         $table = Query::getDBSchema()->getTable(TABLE_REPORT);
         $rs = $db->execute($s = Query::generateSelectStm(array($table), array(), array(new WhereConstraint($table->getColumn(REPORT_POST), Operator::EQUAL, $this->getID())), array()), $table->getName(), $this);
         if ($rs !== false) {
             $reports = array();
             while ($row = $db->fetch_result()) {
                 require_once "common.php";
                 $report = new Report(intval($row[REPORT_USER]), intval($row[REPORT_POST]), $row[REPORT_TEXT]);
                 $report->setID($row[REPORT_ID]);
                 $reports[] = $report;
             }
             $this->setReports($reports);
         } else {
             if ($db->errno()) {
                 $db->display_error("Post::loadReports()");
             }
         }
     } else {
         $db->display_connect_error("Post::loadReports()");
     }
     return $this;
 }
Exemplo n.º 9
0
 function loadSubscribers()
 {
     require_once "query.php";
     $db = new DBManager();
     if (!$db->connect_errno()) {
         define_tables();
         defineContestSubscriberColumns();
         $table = Query::getDBSchema()->getTable(TABLE_CONTEST_SUBSCRIBER);
         $rs = $db->execute($s = Query::generateSelectStm(array($table), array(), array(new WhereConstraint($table->getColumn(CONTEST_SUBSCRIBER_CONTEST), Operator::EQUAL, $this->getID())), array()), $table->getName(), $this);
         //echo "<p>" . $s . "</p>"; //DEBUG;
         //echo "<p>" . mysql_num_rows($rs) . "</p>"; //DEBUG;
         if ($db->num_rows() > 0) {
             $sub = array();
             while ($row = $db->fetch_result()) {
                 $sub[] = $row[CONTEST_SUBSCRIBER_POST];
             }
             $this->setSubscribers($sub);
         } else {
             if ($db->errno()) {
                 $db->display_error("Contest::loadSubscribers()");
             }
         }
     } else {
         $db->display_connect_error("Contest::loadSubscribers()");
     }
     return $this;
 }
Exemplo n.º 10
0
 function addFollower($user)
 {
     require_once "query.php";
     $db = new DBManager();
     if (!$db->connect_errno()) {
         define_tables();
         defineFollowColumns();
         $table = Query::getDBSchema()->getTable(TABLE_FOLLOW);
         $db->execute($s = Query::generateInsertStm($table, array(FOLLOW_FOLLOWER => $user->getID(), FOLLOW_SUBJECT => $this->getID())), $table->getName(), $this);
         if ($db->affected_rows() != 1) {
             $db->display_error("User::addFollower()");
         }
         //Genera un errore ma ritorna comunque $this
     } else {
         $db->display_connect_error("User::addFollower()");
     }
     return $this->loadFollowers();
 }
Exemplo n.º 11
0
 /**
  * Crea un voto caricando i dati dal database.
  * È come fare una ricerca sul database e poi fare new Vote().
  *
  * @param $id: l'ID del voto da caricare.
  * @return: il voto caricato o FALSE se non lo trova.
  */
 static function loadFromDatabase($author, $post)
 {
     require_once "query.php";
     $db = new DBManager();
     if (!$db->connect_errno()) {
         require_once 'strings/strings.php';
         define_tables();
         defineVoteColumns();
         $table = Query::getDBSchema()->getTable(TABLE_VOTE);
         $rs = $db->execute($s = Query::generateSelectStm(array($table), array(), array(new WhereConstraint($table->getColumn(VOTE_AUTHOR), Operator::EQUAL, $author), new WhereConstraint($table->getColumn(VOTE_POST), Operator::EQUAL, $post)), array()), $table->getName(), null);
         if ($db->num_rows() == 1) {
             $row = $db->fetch_result();
             $v = new Vote(intval($row[VOTE_AUTHOR]), intval($row[VOTE_POST]), $row[VOTE_VOTE] > 0);
             $v->setCreationDate(date_timestamp_get(date_create_from_format("Y-m-d G:i:s", $row[VOTE_CREATION_DATE])));
             return $v;
         }
         //else $db->display_error("Vote::loadFromDatabase()");
     } else {
         $db->display_connect_error("Vote::LoadFromDatabase()");
     }
     return false;
 }