OSDN Git Service

sync the original code
[nucleus-jp/nucleus-jp-ancient.git] / utf8 / nucleus / libs / KARMA.php
1 <?php\r
2 /*\r
3  * Nucleus: PHP/MySQL Weblog CMS (http://nucleuscms.org/)\r
4  * Copyright (C) 2002-2005 The Nucleus Group\r
5  *\r
6  * This program is free software; you can redistribute it and/or\r
7  * modify it under the terms of the GNU General Public License\r
8  * as published by the Free Software Foundation; either version 2\r
9  * of the License, or (at your option) any later version.\r
10  * (see nucleus/documentation/index.html#license for more info)\r
11  */\r
12 /**\r
13  * Class representing the karma votes for a certain item\r
14  *\r
15  * @license http://nucleuscms.org/license.txt GNU General Public License\r
16  * @copyright Copyright (C) 2002-2005 The Nucleus Group\r
17  * @version $Id: KARMA.php,v 1.4 2005-08-13 07:33:02 kimitake Exp $\r
18  * $NucleusJP: KARMA.php,v 1.3 2005/03/15 07:57:29 kimitake Exp $\r
19  */\r
20 class KARMA {\r
21         \r
22         // id of item about which this object contains information\r
23         var $itemid;\r
24         \r
25         // indicates if the karma vote info has already been intialized from the DB\r
26         var $inforead;\r
27         \r
28         // amount of positive/negative votes\r
29         var $karmapos;\r
30         var $karmaneg;\r
31         \r
32         function KARMA($itemid, $initpos = 0, $initneg = 0, $initread = 0) {    \r
33                 // itemid\r
34                 $this->itemid = intval($itemid);\r
35 \r
36                 // have we read the karma info yet?\r
37                 $this->inforead = intval($initread);    \r
38                 \r
39                 // number of positive and negative votes\r
40                 $this->karmapos = intval($initpos);\r
41                 $this->karmaneg = intval($initneg);\r
42         }\r
43         \r
44         function getNbPosVotes() {\r
45                 if (!$this->inforead) $this->readFromDatabase();\r
46                 return $this->karmapos;\r
47         }\r
48         function getNbNegVotes() {\r
49                 if (!$this->inforead) $this->readFromDatabase();\r
50                 return $this->karmaneg;\r
51         }\r
52         function getNbOfVotes() {\r
53                 if (!$this->inforead) $this->readFromDatabase();\r
54                 return ($this->karmapos + $this->karmaneg);\r
55         }\r
56         function getTotalScore() {\r
57                 if (!$this->inforead) $this->readFromDatabase();\r
58                 return ($this->karmapos - $this->karmaneg);\r
59         }\r
60         \r
61         function setNbPosVotes($val) {\r
62                 $this->karmapos = intval($val);\r
63         }\r
64         function setNbNegVotes($val) {\r
65                 $this->karmaneg = intval($val);\r
66         }\r
67 \r
68 \r
69         // adds a positive vote\r
70         function votePositive() {\r
71                 $newKarma = $this->getNbPosVotes() + 1;\r
72                 $this->setNbPosVotes($newKarma);\r
73                 $this->writeToDatabase();\r
74                 $this->saveIP();\r
75         }\r
76         \r
77         // adds a negative vote\r
78         function voteNegative() {\r
79                 $newKarma = $this->getNbNegVotes() + 1; \r
80                 $this->setNbNegVotes($newKarma);                \r
81                 $this->writeToDatabase();               \r
82                 $this->saveIP();\r
83         }\r
84 \r
85 \r
86 \r
87         // these methods shouldn't be called directly\r
88         function readFromDatabase() {\r
89                 $query = 'SELECT ikarmapos, ikarmaneg FROM '.sql_table('item').' WHERE inumber=' . $this->itemid;\r
90                 $res = sql_query($query);\r
91                 $obj = mysql_fetch_object($res);\r
92                 \r
93                 $this->karmapos = $obj->ikarmapos;\r
94                 $this->karmaneg = $obj->ikarmaneg;              \r
95                 $this->inforead = 1;\r
96         }\r
97                 \r
98         \r
99         function writeToDatabase() {\r
100                 $query = 'UPDATE '.sql_table('item').' SET ikarmapos=' . $this->karmapos . ', ikarmaneg='.$this->karmaneg.' WHERE inumber=' . $this->itemid;\r
101                 sql_query($query);\r
102         }\r
103         \r
104         // checks if a vote is still allowed for an IP\r
105         function isVoteAllowed($ip) {\r
106                 $query = 'SELECT * FROM '.sql_table('karma')." WHERE itemid=$this->itemid and ip='".addslashes($ip)."'";\r
107                 $res = sql_query($query);\r
108                 return (mysql_num_rows($res) == 0);\r
109         }\r
110         \r
111         // save IP in database so no multiple votes are possible\r
112         function saveIP() {\r
113                 $query = 'INSERT INTO '.sql_table('karma').' (itemid, ip) VALUES ('.$this->itemid.",'".addslashes(serverVar('REMOTE_ADDR'))."')";\r
114                 sql_query($query);\r
115         }\r
116 }\r
117 \r
118 ?>\r