OSDN Git Service

preparation for 4.0 trunk: move whole scripts just under trunk directory
[nucleus-jp/nucleus-jp-ancient.git] / nucleus / xmlrpc / api_metaweblog.inc.php
diff --git a/nucleus/xmlrpc/api_metaweblog.inc.php b/nucleus/xmlrpc/api_metaweblog.inc.php
new file mode 100755 (executable)
index 0000000..90ef82f
--- /dev/null
@@ -0,0 +1,533 @@
+<?php
+
+/*
+ * Nucleus: PHP/MySQL Weblog CMS (http://nucleuscms.org/)
+ * Copyright (C) 2002-2011 The Nucleus Group
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ * (see nucleus/documentation/index.html#license for more info)
+ */
+
+/**
+ *     This file contains definitions for the methods of the metaWeblog API
+ *
+ * @license http://nucleuscms.org/license.txt GNU General Public License
+ * @copyright Copyright (C) 2002-2011 The Nucleus Group
+ * @version $Id$
+ * $NucleusJP: api_metaweblog.inc.php,v 1.5 2006/07/17 20:03:45 kimitake Exp $
+ */
+
+
+       // metaWeblog.newPost
+       $f_metaWeblog_newPost_sig = array(array(
+                       // return type
+                       $xmlrpcString,  // itemid of the new item
+
+                       // params:
+                       $xmlrpcString,  // blogid
+                       $xmlrpcString,  // username
+                       $xmlrpcString,  // password
+                       $xmlrpcStruct,  // content
+                       $xmlrpcBoolean, // publish boolean (set to false to create draft)
+
+               ));
+       $f_metaWeblog_newPost_doc = "Adds a new item to the given blog. Adds it as a draft when publish is false";
+       function f_metaWeblog_newPost($m) {
+               global $manager;
+               
+               $blogid =                       _getScalar($m,0);
+               $username =             _getScalar($m,1);
+               $password =             _getScalar($m,2);
+               $struct =                       $m->getParam(3);
+               
+               $content =              _getStructVal($struct, 'description');
+               $more =                 _getStructVal($struct, 'mt_text_more');
+               $title =                _getStructVal($struct, 'title');
+
+               // category is optional (thus: be careful)!
+               $catlist = $struct->structmem('categories');
+               if ($catlist && ($catlist->kindOf() == "array") && ($catlist->arraysize() > 0))
+                       $category = _getArrayVal($catlist, 0);
+               
+               
+//             $comments = (int) _getStructVal($struct, 'mt_allow_comments') ? 0 : 1;
+               $comments = $struct->structmem('mt_allow_comments');
+               if ($comments) {
+                       $closed = (intval(_getStructVal($struct, 'mt_allow_comments')) == 1) ? 0 : 1;
+               } else {
+                       $closed = 0;
+               }
+                                       $publish = _getScalar($m,4);
+
+
+               // Add item
+//             $res = _addItem($blogid, $username, $password, $title, $content, $more, $publish, $comments, $category);
+               $res = _addItem($blogid, $username, $password, $title, $content, $more, $publish, $closed, $category);
+                                                       
+               // Handle trackbacks
+               $trackbacks = array();
+               $tblist = $struct->structmem('mt_tb_ping_urls');
+               if ($tblist && ($tblist->kindOf() == "array") && ($tblist->arraysize() > 0)) {
+                       
+                       for ($i = 0; $i < $tblist->arraysize(); $i++) {
+                               $trackbacks[] = _getArrayVal($tblist, $i);
+                       }
+                       
+                       $manager->notify('SendTrackback', array ('tb_id' => $itemid, 'urls' => & $trackbacks));
+               }
+
+               return $res;
+       }
+
+
+       // metaWeblog.getCategories
+       $f_metaWeblog_getCategories_sig = array(array(
+               // return
+               $xmlrpcStruct,  // categories for blog
+
+               // params
+               $xmlrpcString,  // blogid
+               $xmlrpcString,  // username
+               $xmlrpcString,  // password
+
+       ));
+       $f_metaWeblog_getCategories_doc = "Returns the categories for a given blog";
+       function f_metaWeblog_getCategories($m) {
+               $blogid =       _getScalar($m,0);
+               $username =     _getScalar($m,1);
+               $password =     _getScalar($m,2);
+
+               return _categoryList($blogid, $username, $password);
+       }
+
+
+       // metaWeblog.getPost
+       $f_metaWeblog_getPost_sig = array(array(
+               // return
+               $xmlrpcStruct,  // the juice
+
+               // params
+               $xmlrpcString,  // itemid
+               $xmlrpcString,  // username
+               $xmlrpcString,  // password
+
+       ));
+       $f_metaWeblog_getPost_doc = "Retrieves a post";
+       function f_metaWeblog_getPost($m) {
+               $itemid =       _getScalar($m,0);
+               $username =     _getScalar($m,1);
+               $password =     _getScalar($m,2);
+
+               return _mw_getPost($itemid, $username, $password);
+       }
+
+
+       // metaWeblog.editPost
+       $f_metaWeblog_editPost_sig = array(array(
+                       // return type
+                       $xmlrpcBoolean, // true
+
+                       // params:
+                       $xmlrpcString,  // itemid
+                       $xmlrpcString,  // username
+                       $xmlrpcString,  // password
+                       $xmlrpcStruct,  // content
+                       $xmlrpcBoolean, // publish boolean (set to false to create draft)
+
+               ));
+       $f_metaWeblog_editPost_doc = "Edits an item";
+       function f_metaWeblog_editPost($m) {
+               global $manager;
+
+               $itemid =                       _getScalar($m,0);
+               $username =             _getScalar($m,1);
+               $password =             _getScalar($m,2);
+
+               $category = '';
+               $struct =                       $m->getParam(3);
+                       $content =              _getStructVal($struct, 'description');
+                       $title =                _getStructVal($struct, 'title');
+
+                       // category is optional (thus: be careful)!
+                       $catlist = $struct->structmem('categories');
+                       if ($catlist && ($catlist->kindOf() == "array") && ($catlist->arraysize() > 0)) {
+                               $category = _getArrayVal($catlist, 0);
+                       }
+
+               $publish = _getScalar($m,4);
+
+               
+               // get old title and extended part
+               if (!$manager->existsItem($itemid,1,1))
+                       return _error(6,"No such item ($itemid)");
+               $blogid = getBlogIDFromItemID($itemid);
+
+               $old =& $manager->getItem($itemid,1,1);
+
+               if ($category == '')
+               {
+                       // leave category unchanged when not present
+                       $catid = $old['catid'];
+               }
+               else
+               {
+                       $blog = new BLOG($blogid);
+                       $catid = $blog->getCategoryIdFromName($category);
+               }
+
+               if ($old['draft'] && $publish) {
+                       $wasdraft = 1;
+                       $publish = 1;
+               } else {
+                       $wasdraft = 0;
+               }
+
+               $more = $struct->structmem('mt_text_more');
+               if ($more) {
+                       $more = _getStructVal($struct, 'mt_text_more');
+               } else {
+                       $more = $old['more'];
+               }
+               
+               $comments = $struct->structmem('mt_allow_comments');
+               if ($comments) {
+//                     $comments = (int) _getStructVal($struct, 'mt_allow_comments') ? 0 : 1;
+                       $closed = (intval(_getStructVal($struct, 'mt_allow_comments')) == 1) ? 0 : 1;
+               } else {
+//                     $comments = $old['closed'];
+                       $closed = $old['closed'];
+               }
+
+//             $res = _edititem($itemid, $username, $password, $catid, $title, $content, $more, $wasdraft, $publish, $comments);
+               $res = _edititem($itemid, $username, $password, $catid, $title, $content, $more, $wasdraft, $publish, $closed);
+               // Handle trackbacks
+               $trackbacks = array();
+               $tblist = $struct->structmem('mt_tb_ping_urls');
+               if ($tblist && ($tblist->kindOf() == "array") && ($tblist->arraysize() > 0)) {
+                       
+                       for ($i = 0; $i < $tblist->arraysize(); $i++) {
+                               $trackbacks[] = _getArrayVal($tblist, $i);
+                       }
+                       
+                       $manager->notify('SendTrackback', array ('tb_id' => $itemid, 'urls' => & $trackbacks));
+               }
+
+               return $res;
+       }
+
+       // metaWeblog.newMediaObject
+       $f_metaWeblog_newMediaObject_sig = array(array(
+               //  return type
+               $xmlrpcStruct,          // "url" element
+
+               // params
+               $xmlrpcString,          // blogid
+               $xmlrpcString,          // username
+               $xmlrpcString,          // password
+               $xmlrpcStruct           // 'name', 'type' and 'bits'
+       ));
+       $f_metaWeblog_newMediaObject_doc = 'Uploads a file to to the media library of the user';
+       function f_metaWeblog_newMediaObject($m) {
+               $blogid         = _getScalar($m, 0);
+               $username       = _getScalar($m, 1);
+               $password       = _getScalar($m, 2);
+
+               $struct         = $m->getParam(3);
+                       $name   = _getStructVal($struct, 'name');
+                       $type   = _getStructVal($struct, 'type');
+                       $bits   = _getStructVal($struct, 'bits');
+
+               return _newMediaObject($blogid, $username, $password, array('name' => $name, 'type' => $type, 'bits' => $bits));
+       }
+
+       // metaWeblog.getRecentPosts
+       $f_metaWeblog_getRecentPosts_sig = array(array(
+               // return type
+               $xmlrpcStruct,          // array of structs
+
+               // params
+               $xmlrpcString,          // blogid
+               $xmlrpcString,          // username
+               $xmlrpcString,          // password
+               $xmlrpcInt                      // number of posts
+       ));
+       $f_metaWeblog_getRecentPosts_doc = 'Returns recent weblog items.';
+       function f_metaWeblog_getRecentPosts($m) {
+               $blogid         = _getScalar($m, 0);
+               $username       = _getScalar($m, 1);
+               $password       = _getScalar($m, 2);
+               $amount         = intval(_getScalar($m, 3));
+
+               return _getRecentItemsMetaWeblog($blogid, $username, $password, $amount);
+       }
+
+       function _getRecentItemsMetaWeblog($blogid, $username, $password, $amount) {
+
+               $blogid = intval($blogid);
+               $amount = intval($amount);
+
+               // 1. login
+               $mem = new MEMBER();
+               if (!$mem->login($username, $password))
+                       return _error(1,"Could not log in");
+
+               // 2. check if allowed
+               if (!BLOG::existsID($blogid))
+                       return _error(2,"No such blog ($blogid)");
+               if (!$mem->teamRights($blogid))
+                       return _error(3,"Not a team member");
+               $amount = intval($amount);
+               if (($amount < 1) or ($amount > 20))
+                       return _error(5,"Amount parameter must be in range 1..20");
+
+               // 3. create and return list of recent items
+               // Struct returned has dateCreated, userid, blogid and content
+
+               $blog = new BLOG($blogid);
+
+               $structarray = array();         // the array in which the structs will be stored
+
+               $query = "SELECT mname, ibody, imore, iauthor, ibody, inumber, ititle as title, itime, cname as category, iclosed"
+                          .' FROM '.sql_table('item').', '.sql_table('category').', '.sql_table('member')
+                          ." WHERE iblog=$blogid and icat=catid and iauthor=mnumber"
+                          ." ORDER BY itime DESC"
+                          ." LIMIT $amount";
+               $r = sql_query($query);
+
+               while ($row = sql_fetch_assoc($r)) {
+
+                       // remove linebreaks if needed
+                       if ($blog->convertBreaks()) {
+                               $row['ibody'] = removeBreaks($row['ibody']);
+                               $row['imore'] = removeBreaks($row['imore']);
+                       }
+
+                       $newstruct = new xmlrpcval(array(
+                               "dateCreated" => new xmlrpcval(iso8601_encode(strtotime($row['itime'])),"dateTime.iso8601"),
+                               "userid" => new xmlrpcval($row['iauthor'],"string"),
+                               "blogid" => new xmlrpcval($blogid,"string"),
+                               "postid" => new xmlrpcval($row['inumber'],"string"),
+                               "description" => new xmlrpcval($row['ibody'],"string"),
+                               "title" => new xmlrpcval($row['title'],"string"),
+                               "categories" => new xmlrpcval(
+                                               array(
+                                                       new xmlrpcval($row['category'], "string")
+                                               )
+                                               ,"array"),
+                               
+                                               
+                               "mt_text_more"          => new xmlrpcval($row['imore'], "string"),
+                               "mt_allow_comments" => new xmlrpcval($row['iclosed'] ? 0 : 1, "int"),
+                               "mt_allow_pings"        => new xmlrpcval(1, "int")
+                       ),'struct');
+
+               //TODO: String link?
+               //TODO: String permaLink?
+
+
+                       array_push($structarray, $newstruct);
+               }
+
+               return new xmlrpcresp(new xmlrpcval( $structarray , "array"));
+       }
+
+       function _newMediaObject($blogid, $username, $password, $info) {
+               global $CONF, $DIR_MEDIA, $DIR_LIBS;
+
+               // - login
+               $mem = new MEMBER();
+               if (!$mem->login($username, $password))
+                       return _error(1,'Could not log in');
+
+               // - check if team member
+               if (!BLOG::existsID($blogid))
+                       return _error(2,"No such blog ($blogid)");
+               if (!$mem->teamRights($blogid))
+                       return _error(3,'Not a team member');
+
+               $b = new BLOG($blogid);
+
+               // - decode data
+               $data = $info['bits']; // decoding was done transparantly by xmlrpclib
+
+               // - check filesize
+               if (strlen($data) > $CONF['MaxUploadSize'])
+                       return _error(9, 'filesize is too big');
+
+
+               // - check if filetype is allowed (check filename)
+               $filename = $info['name'];
+               $ok = 0;
+               $allowedtypes = explode (',', $CONF['AllowedTypes']);
+               foreach ( $allowedtypes as $type )
+               {
+                       //if (eregi("\." .$type. "$",$filename)) $ok = 1;
+                       if (preg_match("#\." .$type. "$#i",$filename)) $ok = 1;
+               }
+               if (!$ok)
+                       _error(8, 'Filetype is not allowed');
+
+               // - add file to media library
+               //include_once($DIR_LIBS . 'MEDIA.php');        // media classes
+               include_libs('MEDIA.php',true,false);
+
+               // always use private media library of member
+               $collection = $mem->getID();
+
+               // prefix filename with current date (YYYY-MM-DD-)
+               // this to avoid nameclashes
+               if ($CONF['MediaPrefix'])
+                       $filename = strftime("%Y%m%d-", time()) . $filename;
+
+               $res = MEDIA::addMediaObjectRaw($collection, $filename, $data);
+               if ($res)
+                       return _error(10, $res);
+
+               // - return URL
+               $urlstruct = new xmlrpcval(array(
+                       "url" => new xmlrpcval($CONF['MediaURL'] . $collection. '/' . $filename,'string')
+               ),'struct');
+
+               return new xmlrpcresp($urlstruct);
+       }
+
+       function _categoryList($blogid, $username, $password) {
+               // 1. login
+               $mem = new MEMBER();
+               if (!$mem->login($username, $password))
+                       return _error(1,"Could not log in");
+
+               // check if on team and blog exists
+               if (!BLOG::existsID($blogid))
+                       return _error(2,"No such blog ($blogid)");
+               if (!$mem->teamRights($blogid))
+                       return _error(3,"Not a team member");
+
+               $b = new BLOG($blogid);
+
+               $categorystruct = array();
+
+               $query =  "SELECT cname, cdesc, catid"
+                               . ' FROM '.sql_table('category')
+                               . " WHERE cblog=" . intval($blogid)
+                               . " ORDER BY cname";
+               $r = sql_query($query);
+
+               while ($obj = sql_fetch_object($r)) {
+
+                       $categorystruct[$obj->cname] = new xmlrpcval(
+                               array(
+                                       "description" => new xmlrpcval($obj->cdesc,"string"),
+                                       "htmlUrl" => new xmlrpcval($b->getURL() . "?catid=" . $obj->catid ,"string"),
+                                       "rssUrl" => new xmlrpcval("","string")
+                               )
+                       ,'struct');
+               }
+
+
+               return new xmlrpcresp(new xmlrpcval( $categorystruct , "struct"));
+
+       }
+
+
+       function _mw_getPost($itemid, $username, $password) {
+               global $manager;
+
+               // 1. login
+               $mem = new MEMBER();
+               if (!$mem->login($username, $password))
+                       return _error(1,"Could not log in");
+
+               // 2. check if allowed
+               if (!$manager->existsItem($itemid,1,1))
+                       return _error(6,"No such item ($itemid)");
+               $blogid = getBlogIDFromItemID($itemid);
+               if (!$mem->teamRights($blogid))
+                       return _error(3,"Not a team member");
+
+               // 3. return the item
+               $item =& $manager->getItem($itemid,1,1); // (also allow drafts and future items)
+
+               $b = new BLOG($blogid);
+               if ($b->convertBreaks()) {
+                       $item['body'] = removeBreaks($item['body']);
+                       $item['more'] = removeBreaks($item['more']);
+               }
+
+               $categoryname = $b->getCategoryName($item['catid']);
+
+               $newstruct = new xmlrpcval(array(
+                       "dateCreated" => new xmlrpcval(iso8601_encode($item['timestamp']),"dateTime.iso8601"),
+                       "userid" => new xmlrpcval($item['authorid'],"string"),
+                       "blogid" => new xmlrpcval($blogid,"string"),
+                       "postid" => new xmlrpcval($itemid, "string"),
+                       "description" => new xmlrpcval($item['body'],"string"),
+                       "title" => new xmlrpcval($item['title'],"string"),
+                       "categories" => new xmlrpcval(
+                                       array(
+                                               new xmlrpcval($categoryname, "string")
+                                       )
+                                       ,"array"),
+                               
+                       "mt_text_more"          => new xmlrpcval($item['more'], "string"),
+                       "mt_allow_comments" => new xmlrpcval($item['closed'] ? 0 : 1, "int"),
+                       "mt_allow_pings"        => new xmlrpcval(1, "int")
+               ),'struct');
+
+               //TODO: add "String link" to struct?
+               //TODO: add "String permaLink" to struct?
+
+               return new xmlrpcresp($newstruct);
+
+       }
+
+       $functionDefs = array_merge($functionDefs,
+               array(
+                        "metaWeblog.newPost" =>
+                        array(
+                               "function" => "f_metaWeblog_newPost",
+                               "signature" => $f_metaWeblog_newPost_sig,
+                               "docstring" => $f_metaWeblog_newPost_doc
+                        ),
+
+                        "metaWeblog.getCategories" =>
+                        array(
+                               "function" => "f_metaWeblog_getCategories",
+                               "signature" => $f_metaWeblog_getCategories_sig,
+                               "docstring" => $f_metaWeblog_getCategories_doc
+                        ),
+
+                        "metaWeblog.getPost" =>
+                        array(
+                               "function" => "f_metaWeblog_getPost",
+                               "signature" => $f_metaWeblog_getPost_sig,
+                               "docstring" => $f_metaWeblog_getPost_doc
+                        ),
+
+                        "metaWeblog.editPost" =>
+                        array(
+                               "function" => "f_metaWeblog_editPost",
+                               "signature" => $f_metaWeblog_editPost_sig,
+                               "docstring" => $f_metaWeblog_editPost_doc
+                        ),
+
+                        'metaWeblog.newMediaObject' =>
+                        array(
+                               'function' => 'f_metaWeblog_newMediaObject',
+                               'signature' => $f_metaWeblog_newMediaObject_sig,
+                               'docstring' => $f_metaWeblog_newMediaObject_doc
+                        ),
+
+                        'metaWeblog.getRecentPosts' =>
+                        array(
+                               'function' => 'f_metaWeblog_getRecentPosts',
+                               'signature' => $f_metaWeblog_getRecentPosts_sig,
+                               'docstring' => $f_metaWeblog_getRecentPosts_doc
+                        )
+
+               )
+       );
+?>
\ No newline at end of file