OSDN Git Service

b12de3be598cb2af45317170c5480686a0b19855
[nucleus-jp/nucleus-jp-ancient.git] / utf8 / nucleus / libs / ITEM.php
1 <?php\r
2 \r
3 /*\r
4  * Nucleus: PHP/MySQL Weblog CMS (http://nucleuscms.org/)\r
5  * Copyright (C) 2002-2005 The Nucleus Group\r
6  *\r
7  * This program is free software; you can redistribute it and/or\r
8  * modify it under the terms of the GNU General Public License\r
9  * as published by the Free Software Foundation; either version 2\r
10  * of the License, or (at your option) any later version.\r
11  * (see nucleus/documentation/index.html#license for more info)\r
12  */\r
13 /**\r
14  * A class representing an item\r
15  *\r
16  * @license http://nucleuscms.org/license.txt GNU General Public License\r
17  * @copyright Copyright (C) 2002-2005 The Nucleus Group\r
18  * @version $Id: ITEM.php,v 1.4 2005-08-13 07:33:02 kimitake Exp $\r
19   * $NucleusJP: ITEM.php,v 1.3 2005/03/12 06:19:05 kimitake Exp $\r
20  */\r
21 class ITEM {\r
22         \r
23         var $itemid;\r
24         \r
25         function ITEM($itemid) {\r
26                 $this->itemid = $itemid;\r
27         }\r
28         \r
29         /**\r
30           * Returns one item with the specific itemid\r
31           * (static)\r
32           */\r
33         function getitem($itemid, $allowdraft, $allowfuture) {\r
34                 global $manager;\r
35 \r
36                 $itemid = intval($itemid);\r
37                 \r
38                 $query =  'SELECT i.idraft as draft, i.inumber as itemid, i.iclosed as closed, '\r
39                        . ' i.ititle as title, i.ibody as body, m.mname as author, '\r
40                        . ' i.iauthor as authorid, i.itime, i.imore as more, i.ikarmapos as karmapos, '\r
41                        . ' i.ikarmaneg as karmaneg, i.icat as catid, i.iblog as blogid '\r
42                        . ' FROM '.sql_table('item').' as i, '.sql_table('member').' as m, ' . sql_table('blog') . ' as b '\r
43                        . ' WHERE i.inumber=' . $itemid\r
44                        . ' and i.iauthor=m.mnumber '\r
45                        . ' and i.iblog=b.bnumber';\r
46                        \r
47                 if (!$allowdraft)\r
48                         $query .= ' and i.idraft=0';\r
49                         \r
50                 if (!$allowfuture) {\r
51                         $blog =& $manager->getBlog(getBlogIDFromItemID($itemid));\r
52                         $query .= ' and i.itime <=' . mysqldate($blog->getCorrectTime());               \r
53                 }\r
54                 \r
55                 $query .= ' LIMIT 1';\r
56 \r
57                 $res = sql_query($query);\r
58 \r
59                 if (mysql_num_rows($res) == 1)\r
60                 {\r
61                         $aItemInfo = mysql_fetch_assoc($res);\r
62                         $aItemInfo['timestamp'] = strtotime($aItemInfo['itime']);       \r
63                         return $aItemInfo;\r
64                 } else {\r
65                         return 0;\r
66                 }\r
67 \r
68         }       \r
69         \r
70         /**\r
71          * Tries to create an item from the data in the current request (comes from\r
72          * bookmarklet or admin area \r
73          *\r
74          * Returns an array with status info (status = 'added', 'error', 'newcategory')\r
75          *\r
76          * (static)\r
77          */\r
78         function createFromRequest() {\r
79                  global $member, $manager;\r
80                  \r
81                  $i_author =            $member->getID();\r
82                  $i_body =                      postVar('body');\r
83                  $i_title =                     postVar('title');\r
84                  $i_more =                      postVar('more');\r
85                  $i_actiontype =        postVar('actiontype');           \r
86                  $i_closed =            intPostVar('closed');\r
87                  $i_hour =                      intPostVar('hour');              \r
88                  $i_minutes =           intPostVar('minutes');           \r
89                  $i_month =             intPostVar('month');             \r
90                  $i_day =                       intPostVar('day');               \r
91                  $i_year =                      intPostVar('year');                              \r
92 \r
93                  $i_catid =             postVar('catid');\r
94                  \r
95                  if (!$member->canAddItem($i_catid))\r
96                         return array('status' => 'error', 'message' => _ERROR_DISALLOWED);\r
97                  \r
98                  if (!$i_actiontype) $i_actiontype = 'addnow';\r
99 \r
100                  switch ($i_actiontype) {\r
101                         case 'adddraft':\r
102                                 $i_draft = 1;\r
103                                 break;\r
104                         case 'addfuture':\r
105                         case 'addnow':\r
106                         default:\r
107                                 $i_draft = 0;\r
108                  }\r
109                  \r
110                  if (!trim($i_body))\r
111                         return array('status' => 'error', 'message' => _ERROR_NOEMPTYITEMS);\r
112                  \r
113                 // create new category if needed \r
114                 if (strstr($i_catid,'newcat')) {\r
115                         // get blogid \r
116                         list($i_blogid) = sscanf($i_catid,"newcat-%d");\r
117                         \r
118                         // create\r
119                         $blog =& $manager->getBlog($i_blogid);\r
120                         $i_catid = $blog->createNewCategory();\r
121 \r
122                         // show error when sth goes wrong\r
123                         if (!$i_catid) \r
124                                 return array('status' => 'error','message' => 'Could not create new category');\r
125                 } else {\r
126                         // force blogid (must be same as category id)\r
127                         $i_blogid = getBlogIDFromCatID($i_catid);\r
128                         $blog =& $manager->getBlog($i_blogid);\r
129                 }\r
130                 \r
131                 if ($i_actiontype == 'addfuture') {\r
132                         $posttime = mktime($i_hour, $i_minutes, 0, $i_month, $i_day, $i_year);\r
133                         \r
134                         // make sure the date is in the future, unless we allow past dates \r
135                         if ((!$blog->allowPastPosting()) && ($posttime < $blog->getCorrectTime()))\r
136                                 $posttime = $blog->getCorrectTime();\r
137                 } else {\r
138                         // time with offset, or 0 for drafts\r
139                         $posttime = $i_draft ? 0 : $blog->getCorrectTime();     \r
140                 }\r
141                 \r
142                 $itemid = $blog->additem($i_catid, $i_title,$i_body,$i_more,$i_blogid,$i_author,$posttime,$i_closed,$i_draft);  \r
143                 \r
144                 //Setting the itemOptions\r
145                 $aOptions = requestArray('plugoption');\r
146                 NucleusPlugin::_applyPluginOptions($aOptions, $itemid);\r
147                 $manager->notify('PostPluginOptionsUpdate',array('context' => 'item', 'itemid' => $itemid, 'item' => array('title' => $i_title, 'body' => $i_body, 'more' => $i_more, 'closed' => $i_closed, 'catid' => $i_catid)));\r
148                 \r
149                 // success\r
150                 if ($i_catid != intRequestVar('catid'))\r
151                         return array('status' => 'newcategory', 'itemid' => $itemid, 'catid' => $i_catid);\r
152                 else\r
153                         return array('status' => 'added', 'itemid' => $itemid);\r
154         }\r
155         \r
156         \r
157         /**\r
158           * Updates an item (static)\r
159           */\r
160         function update($itemid, $catid, $title, $body, $more, $closed, $wasdraft, $publish, $timestamp = 0) {\r
161                 global $manager;\r
162                 \r
163                 $itemid = intval($itemid);\r
164 \r
165                 // make sure value is 1 or 0\r
166                 if ($closed != 1) $closed = 0;\r
167                         \r
168                 // get destination blogid \r
169                 $new_blogid = getBlogIDFromCatID($catid);\r
170                 $old_blogid = getBlogIDFromItemID($itemid);\r
171                 \r
172                 // move will be done on end of method\r
173                 if ($new_blogid != $old_blogid)\r
174                         $moveNeeded = 1;\r
175                 \r
176                 // add <br /> before newlines\r
177                 $blog =& $manager->getBlog($new_blogid);\r
178                 if ($blog->convertBreaks()) {\r
179                         $body = addBreaks($body);\r
180                         $more = addBreaks($more);\r
181                 }\r
182         \r
183                 // call plugins\r
184                 $manager->notify('PreUpdateItem',array('itemid' => $itemid, 'title' => &$title, 'body' => &$body, 'more' => &$more, 'blog' => &$blog, 'closed' => &$closed, 'catid' => &$catid));\r
185         \r
186                 // update item itsself\r
187                 $query =  'UPDATE '.sql_table('item')\r
188                        . ' SET' \r
189                        . " ibody='". addslashes($body) ."',"\r
190                        . " ititle='" . addslashes($title) . "',"\r
191                        . " imore='" . addslashes($more) . "',"\r
192                        . " iclosed=" . intval($closed) . ","\r
193                        . " icat=" . intval($catid);\r
194 \r
195                 // if we received an updated timestamp in the past, but past posting is not allowed,\r
196                 // reject that date change (timestamp = 0 will make sure the current date is kept)\r
197                 if ( (!$blog->allowPastPosting()) && ($timestamp < $blog->getCorrectTime()))\r
198                                 $timestamp = 0;\r
199                 \r
200                 if ($wasdraft && $publish) {\r
201                         $query .= ', idraft=0';\r
202                         \r
203                         // set timestamp to current date only if it's not a future item\r
204                         // draft items have timestamp == 0\r
205                         // don't allow timestamps in the past (unless otherwise defined in blogsettings)\r
206                         if ($timestamp > $blog->getCorrectTime())\r
207                                 $isFuture = 1;\r
208                         \r
209                         if ($timestamp == 0)\r
210                                 $timestamp = $blog->getCorrectTime();\r
211                         \r
212                         // send new item notification\r
213                         if (!$isFuture && $blog->getNotifyAddress() && $blog->notifyOnNewItem()) \r
214                                 $blog->sendNewItemNotification($itemid, $title, $body);\r
215                 }\r
216                 \r
217                 // update timestamp when needed\r
218                 if ($timestamp != 0)\r
219                         $query .= ", itime=" . mysqldate($timestamp);   \r
220 \r
221                 // make sure the correct item is updated                        \r
222                 $query .= ' WHERE inumber=' . $itemid;\r
223                 \r
224                 // off we go!\r
225                 sql_query($query);      \r
226                 \r
227                 // when needed, move item and comments to new blog\r
228                 if ($moveNeeded) \r
229                         ITEM::move($itemid, $catid);\r
230                 \r
231                 //update the itemOptions\r
232                 $aOptions = requestArray('plugoption');\r
233                 NucleusPlugin::_applyPluginOptions($aOptions);\r
234                 $manager->notify('PostPluginOptionsUpdate',array('context' => 'item', 'itemid' => $itemid, 'item' => array('title' => $title, 'body' => $body, 'more' => $more, 'closed' => $closed, 'catid' => $catid)));\r
235                 \r
236         }\r
237         \r
238         // move an item to another blog (no checks, static)\r
239         function move($itemid, $new_catid) {\r
240                 global $manager;\r
241                 \r
242                 $itemid = intval($itemid);\r
243                 $new_catid = intval($new_catid);\r
244                 \r
245                 $new_blogid = getBlogIDFromCatID($new_catid);\r
246 \r
247                 $manager->notify(\r
248                         'PreMoveItem',\r
249                         array(\r
250                                 'itemid' => $itemid,\r
251                                 'destblogid' => $new_blogid,\r
252                                 'destcatid' => $new_catid\r
253                         )\r
254                 );\r
255         \r
256         \r
257                 // update item table\r
258                 $query = 'UPDATE '.sql_table('item')." SET iblog=$new_blogid, icat=$new_catid WHERE inumber=$itemid";\r
259                 sql_query($query);              \r
260                 \r
261                 // update comments\r
262                 $query = 'UPDATE '.sql_table('comment')." SET cblog=" . $new_blogid." WHERE citem=" . $itemid;\r
263                 sql_query($query);      \r
264                 \r
265                 $manager->notify(\r
266                         'PostMoveItem',\r
267                         array(\r
268                                 'itemid' => $itemid,\r
269                                 'destblogid' => $new_blogid,\r
270                                 'destcatid' => $new_catid\r
271                         )\r
272                 );              \r
273         }\r
274         \r
275         /**\r
276           * Deletes an item\r
277           */\r
278         function delete($itemid) {\r
279                 global $manager;\r
280                 \r
281                 $itemid = intval($itemid);\r
282                 \r
283                 $manager->notify('PreDeleteItem', array('itemid' => $itemid));\r
284                 \r
285                 // delete item\r
286                 $query = 'DELETE FROM '.sql_table('item').' WHERE inumber=' . $itemid;\r
287                 sql_query($query);\r
288 \r
289                 // delete the comments associated with the item\r
290                 $query = 'DELETE FROM '.sql_table('comment').' WHERE citem=' . $itemid;\r
291                 sql_query($query);        \r
292                 \r
293                 // delete all associated plugin options\r
294                 NucleusPlugin::_deleteOptionValues('item', $itemid);\r
295                 \r
296                 $manager->notify('PostDeleteItem', array('itemid' => $itemid));         \r
297         }\r
298         \r
299         // returns true if there is an item with the given ID (static)\r
300         function exists($id,$future,$draft) {\r
301                 global $manager;\r
302                 \r
303                 $id = intval($id);\r
304                 \r
305                 $r = 'select * FROM '.sql_table('item').' WHERE inumber='.$id;\r
306                 if (!$future) {\r
307                         $bid = getBlogIDFromItemID($id);\r
308                         if (!$bid) return 0;\r
309                         $b =& $manager->getBlog($bid);\r
310                         $r .= ' and itime<='.mysqldate($b->getCorrectTime());\r
311                 }\r
312                 if (!$draft) {\r
313                         $r .= ' and idraft=0';\r
314                 }\r
315                 $r = sql_query($r);\r
316 \r
317                 return (mysql_num_rows($r) != 0);\r
318         }       \r
319         \r
320 }\r
321 \r
322 ?>\r