summaryrefslogtreecommitdiffstats
path: root/kresources/blogging
diff options
context:
space:
mode:
Diffstat (limited to 'kresources/blogging')
-rw-r--r--kresources/blogging/API_Blog.cpp121
-rw-r--r--kresources/blogging/API_Blog.h163
-rw-r--r--kresources/blogging/API_Blogger.cpp332
-rw-r--r--kresources/blogging/API_Blogger.h57
-rw-r--r--kresources/blogging/Makefile.am29
-rw-r--r--kresources/blogging/blogging.desktop49
-rw-r--r--kresources/blogging/bloggingcalendaradaptor.cpp259
-rw-r--r--kresources/blogging/bloggingcalendaradaptor.h105
-rw-r--r--kresources/blogging/bloggingglobals.cpp53
-rw-r--r--kresources/blogging/bloggingglobals.h50
-rw-r--r--kresources/blogging/kcal_resourceblogging.cpp97
-rw-r--r--kresources/blogging/kcal_resourceblogging.h60
-rw-r--r--kresources/blogging/kcal_resourceblogging_plugin.cpp41
-rw-r--r--kresources/blogging/kcal_resourcebloggingconfig.cpp41
-rw-r--r--kresources/blogging/kcal_resourcebloggingconfig.h41
-rw-r--r--kresources/blogging/resourcebloggingsettings.ui330
-rw-r--r--kresources/blogging/xmlrpcjob.cpp430
-rw-r--r--kresources/blogging/xmlrpcjob.h124
18 files changed, 0 insertions, 2382 deletions
diff --git a/kresources/blogging/API_Blog.cpp b/kresources/blogging/API_Blog.cpp
deleted file mode 100644
index 981390fa1..000000000
--- a/kresources/blogging/API_Blog.cpp
+++ /dev/null
@@ -1,121 +0,0 @@
-/***************************************************************************
-* Copyright (C) 2004-05 Reinhold Kainhofer <reinhold@kainhofer.com> *
-* *
-* 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. *
-***************************************************************************/
-#include "API_Blog.h"
-#include <kdebug.h>
-#include <tqvariant.h>
-
-using namespace KBlog;
-
-APIBlog::APIBlog( const KURL &url, TQObject *parent, const char *name ) :
- TQObject( parent, name ),
- mServerURL( url ), mAppID( TQString() ), mDownloadCount( 20 )
-{}
-
-APIBlog::~APIBlog()
-{}
-
-void APIBlog::dumpBlog( BlogPosting *blog )
-{
- kdDebug() << "-----------------------------------" << endl;
- kdDebug() << "Post " << blog->postID() << " by \"" <<
- blog->userID() << "\" on " <<
- blog->dateTime().toString() << endl;
- kdDebug() << "Title: " << blog->title() << endl;
- kdDebug() << blog->content() <<endl;
- kdDebug() << "-----------------------------------" << endl;
-}
-
-
-
-/*void APIBlog::setTemplateTags( const BlogTemplate& Template )
-{
- mTemplate = Template;
-}
-BlogTemplate APIBlog::templateTags() const
-{
- return mTemplate;
-}*/
-
-/*void APIBlog::deletePost( const TQString &postID )
-{
- BlogPosting *post = new BlogPosting();
- post->setPostID( postID );
- deletePost( post );
- delete post;
-}*/
-
-TQValueList<TQVariant> APIBlog::defaultArgs( const TQString &id )
-{
- TQValueList<TQVariant> args;
- args << TQVariant( mAppID );
- if ( !id.isNull() ) {
- args << TQVariant( id );
- }
- args << TQVariant( mUsername )
- << TQVariant( mPassword );
- return args;
-}
-
-
-KCal::Journal *APIBlog::journalFromPosting( KBlog::BlogPosting *blog )
-{
- if ( !blog ) return 0;
- KCal::Journal *j = new KCal::Journal();
- TQDateTime dt = blog->dateTime();
- TQDateTime creationDt = blog->creationDateTime();
- TQDateTime modificationDt = blog->modificationDateTime();
-kdDebug() << "dt ="<<dt.toString( TQt::ISODate ) << endl;
-kdDebug() << "creationDt ="<<creationDt.toString( TQt::ISODate ) << endl;
-kdDebug() << "modificationDt="<<modificationDt.toString( TQt::ISODate ) << endl;
- if ( dt.isValid() && !dt.isNull() ) {
- j->setDtStart( dt );
- } else if ( creationDt.isValid() && !creationDt.isNull() ) {
- j->setDtStart( creationDt );
- } else if ( modificationDt.isValid() && !modificationDt.isNull() ) {
- j->setDtStart( modificationDt );
- }
-
- j->setCreated( blog->creationDateTime() );
- j->setLastModified( blog->modificationDateTime() );
- j->setFloats( false );
- kdDebug() << "Date for blog " << blog->title() << " is "
- << blog->dateTime().toString()<<endl;
- j->setSummary( blog->title() );
- j->setDescription( blog->content() );
- j->setCategories( TQStringList( blog->category() ) );
- j->setOrganizer( blog->userID() );
- j->setCustomProperty( "KCalBloggerRes", "UserID", blog->userID() );
- j->setCustomProperty( "KCalBloggerRes", "BlogID", blog->blogID() );
- j->setCustomProperty( "KCalBloggerRes", "PostID", blog->postID() );
-
- // TODO: Set the read-only flag in the resource!
-// j->setReadOnly( readOnly() );
-
- return j;
-}
-
-KBlog::BlogPosting *APIBlog::postingFromJournal( KCal::Journal *journal )
-{
- KBlog::BlogPosting *item = new KBlog::BlogPosting();
- if ( journal && item ) {
- item->setContent( journal->description() );
- item->setTitle( journal->summary() );
- item->setCategory( journal->categories().first() );
- item->setDateTime( journal->dtStart() );
- item->setModificationDateTime( journal->lastModified() );
- item->setCreationDateTime( journal->created() );
- item->setUserID( journal->customProperty( "KCalBloggerRes", "UserID" ) );
- item->setBlogID( journal->customProperty( "KCalBloggerRes", "BlogID" ) );
- item->setPostID( journal->customProperty( "KCalBloggerRes", "PostID" ) );
- }
- return item;
-}
-
-
-#include "API_Blog.moc"
diff --git a/kresources/blogging/API_Blog.h b/kresources/blogging/API_Blog.h
deleted file mode 100644
index 9425bd5e6..000000000
--- a/kresources/blogging/API_Blog.h
+++ /dev/null
@@ -1,163 +0,0 @@
-/**************************************************************************
-* Copyright (C) 2004 by Reinhold Kainhofer <reinhold@kainhofer.com> *
-* *
-* 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. *
-***************************************************************************/
-#ifndef API_BLOG_H
-#define API_BLOG_H
-
-#include <kurl.h>
-#include <kio/job.h>
-#include <libkcal/journal.h>
-
-#include <tqobject.h>
-#include <tqstring.h>
-#include <tqvaluelist.h>
-#include <tqdatetime.h>
-
-/**
-This is the main interface for blog backends
-@author ian reinhart geiser, Reinhold Kainhofer
-*/
-
-namespace KBlog {
-
-class BlogPosting
-{
-public:
- BlogPosting() {}
- virtual ~BlogPosting() {}
-
- TQString userID() const { return mUserID; }
- void setUserID( const TQString &userID ) { mUserID = userID; }
-
- TQString blogID() const { return mBlogID; }
- void setBlogID( const TQString &blogID ) { mBlogID = blogID; }
-
- TQString postID() const { return mPostID; }
- void setPostID( const TQString &postID ) { assignPostID( postID ); mPostID = postID; }
-
- TQString title() const { return mTitle; }
- void setTitle( const TQString &title ) { mTitle = title; }
-
- TQString content() const { return mContent; }
- void setContent( const TQString &content ) { mContent = content; }
-
- TQString category() const { return mCategory; }
- void setCategory( const TQString &category ) { mCategory = category; }
-
- TQString fingerprint() const { return mFingerprint; }
- void setFingerprint( const TQString &fp ) { mFingerprint = fp; }
-
- TQDateTime dateTime() const { return mDateTime; }
- void setDateTime( const TQDateTime &datetime ) { mDateTime = datetime; }
-
- TQDateTime creationDateTime() const { return mCreationDateTime; }
- void setCreationDateTime( const TQDateTime &datetime ) { mCreationDateTime = datetime; }
-
- TQDateTime modificationDateTime() const { return mModificationDateTime; }
- void setModificationDateTime( const TQDateTime &datetime ) { mModificationDateTime = datetime; }
-
- virtual void wasDeleted( bool ) {}
- virtual void wasUploaded( bool ) {}
- virtual void error( int /*code*/, const TQString &/*error*/ ) {}
-
-protected:
- // Override this method to detect the new postID assigned when adding a new post
- virtual void assignPostID( const TQString &/*postID*/ ) {}
- TQString mUserID;
- TQString mBlogID;
- TQString mPostID;
- TQString mTitle;
- TQString mContent;
- TQString mCategory;
- TQString mFingerprint;
- TQDateTime mDateTime;
- TQDateTime mCreationDateTime;
- TQDateTime mModificationDateTime;
-};
-
-
-class APIBlog : public TQObject
-{
- Q_OBJECT
-
- public:
- APIBlog( const KURL &server, TQObject *parent = 0L, const char *name = 0L );
- virtual ~APIBlog();
- virtual TQString interfaceName() const = 0;
-
- void setAppID( const TQString &appID ) { mAppID = appID; }
- TQString appID() const { return mAppID; }
-
- void setPassword( const TQString &pass ) { mPassword = pass; }
- TQString password() const { return mPassword; }
-
- void setUsername( const TQString &uname ) { mUsername = uname; }
- TQString username() const { return mUsername; }
-
- void setURL( const KURL& url ) { mServerURL = url; }
- KURL url() const { return mServerURL; }
-
- void setDownloadCount( int nr ) { mDownloadCount = nr; }
- int downloadCount() const { return mDownloadCount; }
-
- static void dumpBlog( BlogPosting *blog );
-
-
- enum blogFunctions {
- bloggerGetUserInfo,
- bloggerGetUsersBlogs,
- bloggerGetRecentPosts,
- bloggerNewPost,
- bloggerEditPost,
- bloggerDeletePost,
- bloggerGetPost,
- bloggerGetTemplate,
- bloggerSetTemplate
- };
-
- virtual TQString getFunctionName( blogFunctions type ) = 0;
- virtual TQValueList<TQVariant> defaultArgs( const TQString &id = TQString() );
-
- virtual TDEIO::Job *createUserInfoJob() = 0;
- virtual TDEIO::Job *createListFoldersJob() = 0;
- virtual TDEIO::TransferJob *createListItemsJob( const KURL &url ) = 0;
- virtual TDEIO::TransferJob *createDownloadJob( const KURL &url ) = 0;
- virtual TDEIO::TransferJob *createUploadJob( const KURL &url, KBlog::BlogPosting *posting ) = 0;
- virtual TDEIO::TransferJob *createUploadNewJob( KBlog::BlogPosting *posting ) = 0;
- virtual TDEIO::Job *createRemoveJob( const KURL &url, const TQString &postid ) = 0;
-
- virtual bool interpretUserInfoJob( TDEIO::Job *job ) = 0;
- virtual void interpretListFoldersJob( TDEIO::Job *job ) = 0;
- virtual bool interpretListItemsJob( TDEIO::Job *job ) = 0;
- virtual bool interpretDownloadItemsJob( TDEIO::Job *job ) = 0;
-
- static KCal::Journal *journalFromPosting( KBlog::BlogPosting *post );
- static KBlog::BlogPosting *postingFromJournal( KCal::Journal *journal );
-
- signals:
- // TODO: Connect these
- void userInfoRetrieved( const TQString &nickname, const TQString &userid, const TQString &email );
- void folderInfoRetrieved( const TQString &id, const TQString &name );
-
- void itemOnServer( const KURL &remoteURL );
- void itemDownloaded( KCal::Incidence *j, const TQString &localID,
- const KURL &remoteURL, const TQString &fingerprint,
- const TQString &storageLocation );
-
-
- protected:
-
- KURL mServerURL;
- TQString mPassword;
- TQString mUsername;
- TQString mAppID;
- int mDownloadCount;
-};
-
-}
-#endif
diff --git a/kresources/blogging/API_Blogger.cpp b/kresources/blogging/API_Blogger.cpp
deleted file mode 100644
index 69a722e22..000000000
--- a/kresources/blogging/API_Blogger.cpp
+++ /dev/null
@@ -1,332 +0,0 @@
-/*
- This file is part of tdepim.
-
- Copyright (c) 2004 Reinhold Kainhofer <reinhold@kainhofer.com>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-
-#include "API_Blogger.h"
-#include "xmlrpcjob.h"
-#include <kdebug.h>
-
-using namespace KBlog;
-
-TQString APIBlogger::getFunctionName( blogFunctions type )
-{
- switch ( type ) {
- case bloggerGetUserInfo: return "blogger.getUserInfo";
- case bloggerGetUsersBlogs: return "blogger.getUsersBlogs";
- case bloggerGetRecentPosts: return "blogger.getRecentPosts";
- case bloggerNewPost: return "blogger.newPost";
- case bloggerEditPost: return "blogger.editPost";
- case bloggerDeletePost: return "blogger.deletePost";
- case bloggerGetPost: return "blogger.getPost";
- case bloggerGetTemplate: return "blogger.getTemplate";
- case bloggerSetTemplate: return "blogger.setTemplate";
- default: return TQString();
- }
-}
-
-
-
-
-TDEIO::Job *APIBlogger::createUserInfoJob()
-{
- kdDebug() << "read user info..." << endl;
- TQValueList<TQVariant> args( defaultArgs() );
- return TDEIO::xmlrpcCall( mServerURL, getFunctionName( bloggerGetUserInfo ), args, false );
-}
-
-TDEIO::Job *APIBlogger::createListFoldersJob()
-{
- // TODO: Check if we're already authenticated. If not, do it!
-// if ( isValid() ) {
- kdDebug() << "Fetch List of Blogs..." << endl;
- TQValueList<TQVariant> args( defaultArgs() );
- return TDEIO::xmlrpcCall( mServerURL, getFunctionName( bloggerGetUsersBlogs ), args, false );
-// } else {
-// warningNotInitialized();
-// return 0;
-// }
-}
-
-TDEIO::TransferJob *APIBlogger::createListItemsJob( const KURL &url )
-{
- // TODO: Check if we're already authenticated. If not, do it!
-// if ( isValid() ) {
- kdDebug() << "Fetch List of Posts..." << endl;
- TQValueList<TQVariant> args( defaultArgs( url.url() ) );
- args << TQVariant( mDownloadCount );
- return TDEIO::xmlrpcCall( mServerURL, getFunctionName( bloggerGetRecentPosts ), args, false );
-// } else {
-// warningNotInitialized();
-// return 0;
-// }
-}
-
-TDEIO::TransferJob *APIBlogger::createDownloadJob( const KURL &url )
-{
-// if ( isValid() ){
- kdDebug() << "Fetch Posting with url " << url.url() << endl;
- TQValueList<TQVariant> args( defaultArgs( url.url() ) );
- return TDEIO::xmlrpcCall( mServerURL, getFunctionName( bloggerGetPost ), args, false );
-// } else {
-// warningNotInitialized();
-// return 0;
-// }
-}
-
-TDEIO::TransferJob *APIBlogger::createUploadJob( const KURL &url, KBlog::BlogPosting *posting )
-{
- if ( !posting ) {
- kdDebug() << "APIBlogger::createUploadJob: posting=0" << endl;
- return 0;
- }
-// if ( isValid() ){
- kdDebug() << "Uploading Posting with url " << url.url() << endl;
- TQValueList<TQVariant> args( defaultArgs( posting->postID() ) );
- args << TQVariant( posting->content() );
- args << TQVariant( /*publish=*/true, 0 );
- return TDEIO::xmlrpcCall( mServerURL, getFunctionName( bloggerEditPost ), args, false );
-// } else {
-// warningNotInitialized();
-// return 0;
-// }
-}
-
-TDEIO::TransferJob *APIBlogger::createUploadNewJob( KBlog::BlogPosting *posting )
-{
- if ( !posting ) {
- kdDebug() << "APIBlogger::createUploadNewJob: posting=0" << endl;
- return 0;
- }
-// if ( isValid() ){
- kdDebug() << "Creating new Posting with blogid " << posting->blogID() << " at url " << mServerURL << endl;
- TQValueList<TQVariant> args( defaultArgs( posting->blogID() ) );
- args << TQVariant( posting->content() );
- args << TQVariant( /*publish=*/true, 0 );
- return TDEIO::xmlrpcCall( mServerURL, getFunctionName( bloggerNewPost ), args, false );
-// } else {
-// warningNotInitialized();
-// return 0;
-// }
-}
-
-TDEIO::Job *APIBlogger::createRemoveJob( const KURL &/*url*/, const TQString &postid )
-{
-kdDebug() << "APIBlogger::createRemoveJob: postid=" << postid << endl;
-// if ( isValid() ){
- TQValueList<TQVariant> args( defaultArgs( postid ) );
- args << TQVariant( /*publish=*/true, 0 );
- return TDEIO::xmlrpcCall( mServerURL, getFunctionName( bloggerDeletePost ), args, false );
-// } else {
-// warningNotInitialized();
-// return 0;
-// }
-}
-
-
-
-
-bool APIBlogger::interpretUserInfoJob( TDEIO::Job *job )
-{
- // TODO: Implement user authentication
-// isValid = true;
- TDEIO::XmlrpcJob *trfjob = dynamic_cast<TDEIO::XmlrpcJob*>(job);
- if ( job->error() || !trfjob ) {
- // TODO: Error handling
- return false;
- } else if ( trfjob ) {
- TQValueList<TQVariant> message( trfjob->response() );
-
- kdDebug () << "TOP: " << message[ 0 ].typeName() << endl;
- const TQValueList<TQVariant> posts = message;
- TQValueList<TQVariant>::ConstIterator it = posts.begin();
- TQValueList<TQVariant>::ConstIterator end = posts.end();
- for ( ; it != end; ++it ) {
- kdDebug () << "MIDDLE: " << ( *it ).typeName() << endl;
- const TQMap<TQString, TQVariant> postInfo = ( *it ).toMap();
- const TQString nickname = postInfo[ "nickname" ].toString();
- const TQString userid = postInfo[ "userid" ].toString();
- const TQString email = postInfo[ "email" ].toString();
- kdDebug() << "Post " << nickname << " " << userid << " " << email << endl;
- // FIXME: How about a BlogUserInfo class???
- emit userInfoRetrieved( nickname, userid, email );
- }
- return true;
- }
- return false;
-}
-
-void APIBlogger::interpretListFoldersJob( TDEIO::Job *job )
-{
-kdDebug() << "APIBlogger::interpretListFoldersJob" << endl;
- TDEIO::XmlrpcJob *trfjob = dynamic_cast<TDEIO::XmlrpcJob*>(job);
- if ( job->error() || !trfjob ) {
- // TODO: Error handling
- } else {
-kdDebug() << "APIBlogger::interpretListFoldersJob, no error!" << endl;
- TQValueList<TQVariant> message( trfjob->response() );
- kdDebug () << "TOP: " << message[ 0 ].typeName() << endl;
-
- const TQValueList<TQVariant> posts = message[ 0 ].toList();
- TQValueList<TQVariant>::ConstIterator it = posts.begin();
- TQValueList<TQVariant>::ConstIterator end = posts.end();
- for ( ; it != end; ++it ) {
- kdDebug () << "MIDDLE: " << ( *it ).typeName() << endl;
- const TQMap<TQString, TQVariant> postInfo = ( *it ).toMap();
-
- const TQString id( postInfo[ "blogid" ].toString() );
- const TQString name( postInfo[ "blogName" ].toString() );
- const TQString url( postInfo[ "url" ].toString() );
-
- // Use the Blog ID instead of the URL. The ID already indicates the correct blog, and the
- // URL for all calls will be the XML-RPC interface, anyway.
- if ( !id.isEmpty() && !name.isEmpty() ) {
- emit folderInfoRetrieved( id, name );
-kdDebug()<< "Emitting folderInfoRetrieved( id=" << id << ", name=" << name << "); " << endl;
- }
- }
- }
-}
-
-bool APIBlogger::interpretListItemsJob( TDEIO::Job *job )
-{
- return interpretDownloadItemsJob( job );
-}
-
-bool APIBlogger::interpretDownloadItemsJob( TDEIO::Job *job )
-{
- kdDebug(5800)<<"APIBlogger::interpretDownloadItemJob"<<endl;
- TDEIO::XmlrpcJob *trfjob = dynamic_cast<TDEIO::XmlrpcJob*>(job);
- bool success = false;
- if ( job->error() || !trfjob ) {
- // TODO: Error handling
- success = false;
- } else {
- //array of structs containing ISO.8601 dateCreated, String userid, String postid, String content;
- // TODO: Time zone for the dateCreated!
- TQValueList<TQVariant> message( trfjob->response() );
- kdDebug () << "TOP: " << message[ 0 ].typeName() << endl;
-
- const TQValueList<TQVariant> postReceived = message[ 0 ].toList();
- TQValueList<TQVariant>::ConstIterator it = postReceived.begin();
- TQValueList<TQVariant>::ConstIterator end = postReceived.end();
- success = true;
- for ( ; it != end; ++it ) {
- BlogPosting posting;
- kdDebug () << "MIDDLE: " << ( *it ).typeName() << endl;
- const TQMap<TQString, TQVariant> postInfo = ( *it ).toMap();
- if ( readPostingFromMap( &posting, postInfo ) ) {
- KCal::Journal *j = journalFromPosting( &posting );
-// dumpBlog( &posting );
- kdDebug() << "Emitting itemOnServer( posting.postID()="<<posting.postID() << "); " << endl;
- emit itemOnServer( KURL( posting.postID() ) );
- kdDebug() << "Emitting itemDownloaded( j=" << j << ", uid=" << j->uid()
- << ", postID=" << posting.postID() << ", fpr="
- << posting.fingerprint() << "); " << endl;
- emit itemDownloaded( j, j->uid(), KURL( posting.postID() ),
- posting.fingerprint(), posting.postID() );
- } else {
- kdDebug() << "readPostingFromMap failed! " << endl;
- success = false;
- // TODO: Error handling
- }
- }
- }
- return success;
-}
-
-
-bool APIBlogger::readPostingFromMap( BlogPosting *post, const TQMap<TQString, TQVariant> &postInfo )
-{
- // FIXME:
- if ( !post ) return false;
- TQStringList mapkeys = postInfo.keys();
- kdDebug() << endl << "Keys: " << mapkeys.join(", ") << endl << endl;
-
- TQString fp( TQString() );
-
- TQDateTime dt( postInfo[ "dateCreated" ].toDateTime() );
- if ( dt.isValid() && !dt.isNull() ) {
- post->setCreationDateTime( dt );
- TQString fp = dt.toString( TQt::ISODate );
- }
- dt = postInfo[ "postDate" ].toDateTime();
- if ( dt.isValid() && !dt.isNull() ) {
- post->setDateTime( dt );
- fp = dt.toString( TQt::ISODate );
- }
- dt = postInfo[ "lastModified" ].toDateTime();
- if ( dt.isValid() && !dt.isNull() ) {
- post->setModificationDateTime( dt );
- fp = dt.toString( TQt::ISODate );
- }
- post->setFingerprint( fp );
-
- post->setUserID( postInfo[ "userid" ].toString() );
- post->setPostID( postInfo[ "postid" ].toString() );
-
- TQString title( postInfo[ "title" ].toString() );
- TQString description( postInfo[ "description" ].toString() );
- TQString contents( postInfo[ "content" ].toString() );
- TQString category;
-
- // TODO: Extract title and cats from the old-style blogger api without extensions
-/*
- if ( (title.isEmpty() || description.isEmpty() ) && !contents.isEmpty() ) {
- // we don't have both title and description, so use the content (ie. it's an
- // old-style blogger api, not the extended drupal api.
-
- kdDebug() << "No title and description given, so it's an old-style "
- "Blogger API without extensions" << endl;
- TQString catTagOpen = mTemplate.categoryTagOpen();
- TQString catTagClose = mTemplate.categoryTagClose();
- TQString titleTagOpen = mTemplate.titleTagOpen();
- TQString titleTagClose = mTemplate.titleTagClose();
-
- int catStart = contents.find( catTagOpen, 0, false ) + catTagOpen.length();
- int catEnd = contents.find( catTagClose, 0, false );
-kdDebug() << " catTagOpen = " << catTagOpen << ", catTagClose = " << catTagClose << ", start - end : " << catStart <<" - " << catEnd << endl;
- if ( catEnd > catStart ) {
- category = contents.mid( catStart, catEnd - catStart );
- kdDebug() << "Found a category \"" << category << "\"" << endl;
- contents = contents.remove( catStart - catTagOpen.length(),
- catEnd - catStart + catTagClose.length() + catTagOpen.length() );
- }
- int titleStart = contents.find( titleTagOpen, 0, false ) + titleTagOpen.length();
- int titleEnd = contents.find( titleTagClose, 0, false );
-kdDebug() << " titleTagOpen = " << titleTagOpen << ", titleTagClose = " << titleTagClose << ", start - end : " << titleStart <<" - " << titleEnd << endl;
- kdDebug() << "Title start and end: " << titleStart << ", " << titleEnd << endl;
- if ( titleEnd > titleStart ) {
- title = contents.mid( titleStart, titleEnd - titleStart );
- contents = contents.remove( titleStart - titleTagOpen.length(),
- titleEnd - titleStart + titleTagClose.length() + titleTagOpen.length() );
- }
- kdDebug() << endl << endl << endl << "After treatment of the special tags, we have a content of: "<< endl << contents << endl;
- }
-*/
-
- post->setTitle( title );
- post->setContent( contents );
- if ( !category.isEmpty() )
- post->setCategory( category );
- return true;
-}
-
-
-
diff --git a/kresources/blogging/API_Blogger.h b/kresources/blogging/API_Blogger.h
deleted file mode 100644
index d7d5f43b9..000000000
--- a/kresources/blogging/API_Blogger.h
+++ /dev/null
@@ -1,57 +0,0 @@
- /*
- This file is part of tdepim.
-
- Copyright (c) 2004 Reinhold Kainhofer <reinhold@kainhofer.com>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-#ifndef API_BLOGGER_H
-#define API_BLOGGER_H
-
-#include "API_Blog.h"
-
-#include <tqstring.h>
-#include <tqvariant.h>
-#include <tqvaluelist.h>
-
-namespace KBlog {
-
-class APIBlogger : public APIBlog
-{
- public:
- APIBlogger( const KURL &server, TQObject *parent = 0L, const char *name = 0L ) : APIBlog( server, parent, name ) {}
- TQString getFunctionName( blogFunctions type );
- TQString interfaceName() const { return "Blogger API 1.0"; }
-
-
- TDEIO::Job *createUserInfoJob();
- TDEIO::Job *createListFoldersJob();
- TDEIO::TransferJob *createListItemsJob( const KURL &url );
- TDEIO::TransferJob *createDownloadJob( const KURL &url );
- TDEIO::TransferJob *createUploadJob( const KURL &url, KBlog::BlogPosting *posting );
- TDEIO::TransferJob *createUploadNewJob( KBlog::BlogPosting *posting );
- TDEIO::Job *createRemoveJob( const KURL &url, const TQString &postid );
-
- bool interpretUserInfoJob( TDEIO::Job *job );
- void interpretListFoldersJob( TDEIO::Job *job );
- bool interpretListItemsJob( TDEIO::Job *job );
- bool interpretDownloadItemsJob( TDEIO::Job *job );
- protected:
- bool readPostingFromMap( BlogPosting *post, const TQMap<TQString, TQVariant> &postInfo );
-};
-
-}
-#endif
diff --git a/kresources/blogging/Makefile.am b/kresources/blogging/Makefile.am
deleted file mode 100644
index 508b0e752..000000000
--- a/kresources/blogging/Makefile.am
+++ /dev/null
@@ -1,29 +0,0 @@
-INCLUDES = -I$(top_srcdir) -I$(top_srcdir)/kresources/lib -I../lib -I$(top_srcdir)/kresources/blogging/libkblog/ $(all_includes)
-
-lib_LTLIBRARIES = libkcal_blogging.la
-kde_module_LTLIBRARIES = kcal_blogging.la
-
-libkcal_blogging_la_SOURCES = API_Blog.cpp API_Blogger.cpp xmlrpcjob.cpp \
- bloggingglobals.cpp \
- bloggingcalendaradaptor.cpp \
- kcal_resourceblogging.cpp kcal_resourcebloggingconfig.cpp
-libkcal_blogging_la_LDFLAGS = $(KDE_RPATH) $(all_libraries) \
- -version-info 1:0:0 -no-undefined
-libkcal_blogging_la_LIBADD = \
- ../lib/libkgroupwarebase.la \
- $(top_builddir)/libkcal/libkcal.la $(top_builddir)/libtdepim/libtdepim.la
-
-
-kcal_blogging_la_SOURCES = kcal_resourceblogging_plugin.cpp
-kcal_blogging_la_LDFLAGS = $(all_libraries) -module -no-undefined $(KDE_PLUGIN)
-kcal_blogging_la_LIBADD = libkcal_blogging.la
-
-kcal_servicedir = $(kde_servicesdir)/kresources/kcal
-kcal_service_DATA = blogging.desktop
-
-METASOURCES = AUTO
-
-messages: rc.cpp
- $(XGETTEXT) *.cpp -o $(podir)/kres_blogging.pot
-
-kcal_resourceblogging.lo: ../lib/kresources_groupwareprefs.h
diff --git a/kresources/blogging/blogging.desktop b/kresources/blogging/blogging.desktop
deleted file mode 100644
index 7714a362a..000000000
--- a/kresources/blogging/blogging.desktop
+++ /dev/null
@@ -1,49 +0,0 @@
-[Desktop Entry]
-Name=Journals as Blogs on a Server
-Name[af]=Joernale as Blogs op 'n bediener
-Name[bg]=Дневници и блогове
-Name[ca]=Diaris com a blocs en un servidor
-Name[cs]=Deníky jako blogy na serveru
-Name[da]=Journaler som www-blogger på en server
-Name[de]=Journaleinträge als Blogs auf einem Server
-Name[el]=Εφημερίδες ως Blogs σε έναν εξυπηρετητή
-Name[es]=Diarios, como bitácoras en un servidor
-Name[et]=Päevik veebipäevikuna serveris
-Name[eu]=Egunkariak blog moduan zerbitzarian
-Name[fa]=نشریه‌ها به عنوان وب‌نوشتها روی یک کارساز
-Name[fi]=Päiväkirjat blogeina palvelimella
-Name[fr]=Journaux (blogs) sur un serveur
-Name[fy]=Journalen as blochs op in tsjinner
-Name[gl]=Xornais como Bitácoras nun Servidor
-Name[hu]=Naplók blogként tárolása a kiszolgálón
-Name[is]=Dagbækur sem blogg á þjóni
-Name[it]=Diari come blog su un server
-Name[ja]=サーバ上のブログとしてのジャーナル
-Name[kk]=Сервердегі күнделік блог ретінде
-Name[km]=ទិនានុប្បវត្តិ​ជា​កំណត់ហេតុ​បណ្ដាញ​នៅ​លើ​ម៉ាស៊ីន​បម្រើ
-Name[lt]=Dienynai kaip Blog'ai serveryje
-Name[ms]=Jurnal sebagai Blog pada pelayan
-Name[nb]=Dagbok som blogg på en tjener
-Name[nds]=Daagbookindräag as Blog op en Server
-Name[ne]=सर्भरमा बल्गका रुपका पत्रिका
-Name[nl]=Journalen als blogs op een server
-Name[nn]=Dagbøker som bloggar på ein tenar
-Name[pl]=Dzienniki jako blogi na serwerze
-Name[pt]=Diários como 'Blogs' num Servidor
-Name[pt_BR]=Diários como Blogs em um Servidor
-Name[ru]=Журналы (блоги) на сервере
-Name[sk]=Žurnály ako blogy na serveri
-Name[sl]=Dnevniki kot spletni dnevniki (blogi) na strežniku
-Name[sr]=Дневници као блогови на серверу
-Name[sr@Latn]=Dnevnici kao blogovi na serveru
-Name[sv]=Journaler som webbloggar på en server
-Name[ta]=சேவகனில் பேச்சுரைகள் பத்திரிககளாக உள்ளன
-Name[tr]=Web Günlüğü gibi, bir Sunucuya yazar
-Name[uk]=Журнали як веб-щоденники на сервері
-Name[zh_CN]=日记作为服务器上的博客日志
-Name[zh_TW]=日誌做為伺服器上的部落格
-X-TDE-Library=kcal_blogging
-Type=Service
-ServiceTypes=KResources/Plugin
-X-TDE-ResourceFamily=calendar
-X-TDE-ResourceType=blogging
diff --git a/kresources/blogging/bloggingcalendaradaptor.cpp b/kresources/blogging/bloggingcalendaradaptor.cpp
deleted file mode 100644
index 2ed925a88..000000000
--- a/kresources/blogging/bloggingcalendaradaptor.cpp
+++ /dev/null
@@ -1,259 +0,0 @@
-/*
- This file is part of tdepim.
-
- Copyright (c) 2005 Reinhold Kainhofer <reinhold@kainhofer.com>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-
-#include "bloggingcalendaradaptor.h"
-#include "bloggingglobals.h"
-#include <libemailfunctions/idmapper.h>
-#include <folderlister.h>
-
-#include <libkcal/calendarlocal.h>
-#include <libkcal/icalformat.h>
-#include <libkcal/resourcecached.h>
-
-#include <kdebug.h>
-
-using namespace KCal;
-
-// That terribly long app key was generated at
-// http://www.blogger.com/developers/api/1_docs/register.html
-// for the "KDE-Pim libkcal blogging resource".
-// TODO:
-/*TQString BloggingCalendarAdaptor::mAppID =
- TQString("20ffffffd7ffffffc5ffffffbdffffff87ffffffb72d39fffffffe5c4bfffff"
- "fcfffffff80ffffffd4665cfffffff375ffffff88ffffff871a0cffffff8029");
-*/
-
-
-BloggingUploadItem::BloggingUploadItem( KBlog::APIBlog *api, CalendarAdaptor *adaptor, KCal::Incidence *incidence, KPIM::GroupwareUploadItem::UploadType type )
- : GroupwareUploadItem( type ), mPosting( 0 ), mAPI( 0 )
-{
- Journal* j = dynamic_cast<Journal*>( incidence );
- if ( api && j && adaptor ) {
- mItemType = KPIM::FolderLister::Journal;
-
- setUrl( j->customProperty( adaptor->identifier(), "storagelocation" ) );
- setUid( j->uid() );
-
- mPosting = api->postingFromJournal( j );
- mAPI = api;
- }
-}
-
-BloggingUploadItem::~BloggingUploadItem()
-{
- delete mPosting;
-}
-
-TDEIO::TransferJob *BloggingUploadItem::createUploadJob( KPIM::GroupwareDataAdaptor *adaptor, const KURL &baseurl )
-{
-kdDebug()<<"BloggingUploadItem::createUploadJob, adaptor="<<adaptor<<", URL="<<baseurl.url()<<endl;
- Q_ASSERT( adaptor );
- if ( !adaptor || !mAPI ) return 0;
- kdDebug() << "Uploading to: " << url().prettyURL() << endl;
- mAPI->setURL( baseurl );
- return mAPI->createUploadJob( url(), mPosting );
-}
-
-TDEIO::TransferJob *BloggingUploadItem::createUploadNewJob( KPIM::GroupwareDataAdaptor *adaptor, const KURL &baseurl )
-{
-kdDebug()<<"BloggingUploadItem::createUploadNewJob"<<endl;
- Q_ASSERT( adaptor );
- if ( !adaptor || !mAPI ) return 0;
- kdDebug() << "Uploading new item to: " << baseurl.prettyURL() << endl;
- mAPI->setURL( baseurl );
- return mAPI->createUploadNewJob( mPosting );
-}
-
-
-
-
-
-
-BloggingCalendarAdaptor::BloggingCalendarAdaptor() : mAPI( 0 ), mAuthenticated( false )
-{
-}
-
-
-KBlog::APIBlog *BloggingCalendarAdaptor::api() const
-{
- return mAPI;
-}
-
-void BloggingCalendarAdaptor::setAPI( KBlog::APIBlog *api )
-{
- delete mAPI;
- mAPI = api;
- mAuthenticated = false;
- connect( api, TQT_SIGNAL( userInfoRetrieved( const TQString &, const TQString &,
- const TQString & ) ),
- TQT_SLOT( slotUserInfoRetrieved( const TQString &, const TQString &,
- const TQString & ) ) );
- connect( api, TQT_SIGNAL( folderInfoRetrieved( const TQString &, const TQString & ) ),
- TQT_SLOT( slotFolderInfoRetrieved( const TQString&, const TQString & ) ) );
- connect( api, TQT_SIGNAL( itemOnServer( const KURL & ) ),
- TQT_SIGNAL( itemOnServer( const KURL & ) ) );
- connect( api, TQT_SIGNAL( itemDownloaded( KCal::Incidence *, const TQString &,
- const KURL &, const TQString &, const TQString & ) ),
- TQT_SLOT( calendarItemDownloaded( KCal::Incidence *, const TQString &,
- const KURL &, const TQString &, const TQString & ) ) );
-
-}
-
-KPIM::GroupwareUploadItem *BloggingCalendarAdaptor::newUploadItem( KCal::Incidence*it,
- KPIM::GroupwareUploadItem::UploadType type )
-{
- return new BloggingUploadItem( mAPI, this, it, type );
-}
-
-
-
-void BloggingCalendarAdaptor::slotFolderInfoRetrieved( const TQString &id, const TQString &name )
-{
- emit folderInfoRetrieved( KURL(id), name, KPIM::FolderLister::Journal );
-}
-
-void BloggingCalendarAdaptor::slotUserInfoRetrieved( const TQString &/*nick*/,
- const TQString &/*user*/, const TQString &/*email*/ )
-{
-kdDebug() << "BloggingCalendarAdaptor::slotUserInfoRetrieved"<<endl;
- mAuthenticated = true;
-}
-
-void BloggingCalendarAdaptor::setBaseURL( const KURL &url )
-{
- if ( mAPI ) {
- mAPI->setURL( url );
- }
-}
-
-void BloggingCalendarAdaptor::setUser( const TQString &user )
-{
- CalendarAdaptor::setUser( user );
- if ( mAPI ) {
- mAPI->setUsername( user );
- }
-}
-
-void BloggingCalendarAdaptor::setPassword( const TQString &password )
-{
- CalendarAdaptor::setPassword( password );
- if ( mAPI ) {
- mAPI->setPassword( password );
- }
-}
-
-void BloggingCalendarAdaptor::setUserPassword( KURL & )
-{
- kdDebug(5800) << "BloggingCalendarAdaptor::setUserPassword" << endl;
-}
-
-
-
-TDEIO::Job *BloggingCalendarAdaptor::createLoginJob( const KURL &url,
- const TQString &user,
- const TQString &password )
-{
- if ( mAPI ) {
- mAPI->setURL( url );
- mAPI->setUsername( user );
- mAPI->setPassword( password );
- return mAPI->createUserInfoJob();
- } else return 0;
-}
-
-TDEIO::Job *BloggingCalendarAdaptor::createListFoldersJob( const KURL &/*url*/ )
-{
- if ( mAPI ) {
- return mAPI->createListFoldersJob();
- } else return 0;
-}
-
-TDEIO::TransferJob *BloggingCalendarAdaptor::createListItemsJob( const KURL &url )
-{
- if ( mAPI ) {
- return mAPI->createListItemsJob( url );
- } else return 0;
-}
-
-TDEIO::TransferJob *BloggingCalendarAdaptor::createDownloadJob( const KURL &url,
- KPIM::FolderLister::ContentType ctype )
-{
- if ( mAPI && (ctype & KPIM::FolderLister::Journal) ) {
- return mAPI->createDownloadJob( url );
- } else return 0;
-}
-
-TDEIO::Job *BloggingCalendarAdaptor::createRemoveJob( const KURL &url,
- KPIM::GroupwareUploadItem *deleteItem )
-{
-kdDebug()<<"BloggingCalendarAdaptor::createRemoveJob( " << url.url() << ", ..)" << endl;
- if ( mAPI && deleteItem ) {
- return mAPI->createRemoveJob( url, deleteItem->url().url() );
- } else return 0;
-}
-
-
-
-
-bool BloggingCalendarAdaptor::interpretLoginJob( TDEIO::Job *job )
-{
-kdDebug()<<"BloggingCalendarAdaptor::interpretLoginJob"<<endl;
- if ( mAPI && job ) {
-kdDebug()<<"We have an API and a job"<<endl;
- mAuthenticated = false;
- mAPI->interpretUserInfoJob( job );
-kdDebug() << "authenticated=" << mAuthenticated << endl;
- return mAuthenticated;
- } else return false;
-}
-
-
-void BloggingCalendarAdaptor::interpretListFoldersJob( TDEIO::Job *job, KPIM::FolderLister * )
-{
-kdDebug() << "BloggingCalendarAdaptor::interpretListFoldersJob" << endl;
- if ( mAPI && job ) {
- mAPI->interpretListFoldersJob( job );
- }
-}
-
-
-bool BloggingCalendarAdaptor::interpretListItemsJob( TDEIO::Job *job,
- const TQString &/*jobData*/ )
-{
- if ( mAPI ) {
- return mAPI->interpretListItemsJob( job );
- } else {
- return false;
- }
-}
-
-
-bool BloggingCalendarAdaptor::interpretDownloadItemsJob( TDEIO::Job *job,
- const TQString &/*jobData*/ )
-{
- if ( mAPI ) {
- return mAPI->interpretDownloadItemsJob( job );
- } else {
- return false;
- }
-}
-
-#include "bloggingcalendaradaptor.moc"
diff --git a/kresources/blogging/bloggingcalendaradaptor.h b/kresources/blogging/bloggingcalendaradaptor.h
deleted file mode 100644
index ee6d292aa..000000000
--- a/kresources/blogging/bloggingcalendaradaptor.h
+++ /dev/null
@@ -1,105 +0,0 @@
- /*
- This file is part of tdepim.
-
- Copyright (C) 2004-05 Reinhold Kainhofer <reinhold@kainhofer.com>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-#ifndef KCAL_BLOGGINGCALENDARADAPTOR_H
-#define KCAL_BLOGGINGCALENDARADAPTOR_H
-
-#include "calendaradaptor.h"
-#include "groupwareuploadjob.h"
-#include "API_Blog.h"
-#include <kurl.h>
-
-namespace TDEIO {
-class Job;
-}
-
-namespace KCal {
-
-class BloggingUploadItem : public KPIM::GroupwareUploadItem
-{
- public:
- BloggingUploadItem( KBlog::APIBlog *api, CalendarAdaptor *adaptor, KCal::Incidence *incidence, UploadType type );
- virtual ~BloggingUploadItem();
- virtual TDEIO::TransferJob *createUploadNewJob(
- KPIM::GroupwareDataAdaptor *adaptor, const KURL &baseurl );
- virtual TDEIO::TransferJob *createUploadJob(
- KPIM::GroupwareDataAdaptor *adaptor, const KURL &url );
-
- protected:
- BloggingUploadItem( UploadType type ) : KPIM::GroupwareUploadItem( type ) {}
- KBlog::BlogPosting *mPosting;
- KBlog::APIBlog *mAPI;
-};
-
-class BloggingCalendarAdaptor : public CalendarAdaptor
-{
-Q_OBJECT
-
- public:
- BloggingCalendarAdaptor();
- TQValueList<KPIM::FolderLister::ContentType> supportedTypes()
- {
- TQValueList<KPIM::FolderLister::ContentType> types;
- types << KPIM::FolderLister::Journal;
- return types;
- }
-
- TQCString identifier() const { return "KCalResourceBlogging"; }
- long flags() const { return GWResNeedsLogon; }
-
- void setBaseURL( const KURL &url );
- void setUser( const TQString &user );
- void setPassword( const TQString &password );
- // We don't want to set the username / pw for the URL!
- void setUserPassword( KURL &url );
-
- KBlog::APIBlog *api() const;
- void setAPI( KBlog::APIBlog *api );
-
- TDEIO::Job *createLoginJob( const KURL &url, const TQString &user,
- const TQString &password );
- TDEIO::Job *createListFoldersJob( const KURL &url );
- TDEIO::TransferJob *createListItemsJob( const KURL &url );
- TDEIO::TransferJob *createDownloadJob( const KURL &url,
- KPIM::FolderLister::ContentType ctype );
- TDEIO::Job *createRemoveJob( const KURL &url, KPIM::GroupwareUploadItem *deleteItem );
-
- bool interpretLoginJob( TDEIO::Job *job );
- void interpretListFoldersJob( TDEIO::Job *job, KPIM::FolderLister * );
- bool interpretListItemsJob( TDEIO::Job *job, const TQString &jobData );
- bool interpretDownloadItemsJob( TDEIO::Job *job, const TQString &jobData );
-
- public slots:
- void slotFolderInfoRetrieved( const TQString &id, const TQString &name );
- void slotUserInfoRetrieved( const TQString &nick, const TQString &user,
- const TQString &email );
-
- protected:
- KPIM::GroupwareUploadItem *newUploadItem( KCal::Incidence*it,
- KPIM::GroupwareUploadItem::UploadType type );
-
- KBlog::APIBlog *mAPI;
- bool mAuthenticated;
- static TQString mAppID;
-};
-
-}
-
-#endif
diff --git a/kresources/blogging/bloggingglobals.cpp b/kresources/blogging/bloggingglobals.cpp
deleted file mode 100644
index 53743e9a6..000000000
--- a/kresources/blogging/bloggingglobals.cpp
+++ /dev/null
@@ -1,53 +0,0 @@
-/*
- This file is part of tdepim.
-
- Copyright (c) 2004 Reinhold Kainhofer <reinhold@kainhofer.com>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-
-#include "bloggingglobals.h"
-
-TQString BloggingGlobals::mAppID = TQString("20ffffffd7ffffffc5ffffffbdffffff87ffffffb72d39fffffffe5c4bffffffcfffffff80ffffffd4665cfffffff375ffffff88ffffff871a0cffffff8029");
-
-TQString BloggingGlobals::getFunctionName( blogFunctions type )
-{
- switch ( type ) {
- case bloggerGetUserInfo: return "blogger.getUserInfo";
- case bloggerGetUsersBlogs: return "blogger.getUsersBlogs";
- case bloggerGetRecentPosts: return "blogger.getRecentPosts";
- case bloggerNewPost: return "blogger.newPost";
- case bloggerEditPost: return "blogger.editPost";
- case bloggerDeletePost: return "blogger.deletePost";
- case bloggerGetPost: return "blogger.getPost";
- case bloggerGetTemplate: return "blogger.getTemplate";
- case bloggerSetTemplate: return "blogger.setTemplate";
- default: return TQString();
- }
-}
-
-TQValueList<TQVariant> BloggingGlobals::defaultArgs( const TQString &user, const TQString &pw, const TQString &id )
-{
- TQValueList<TQVariant> args;
- args << TQVariant( mAppID );
- if ( !id.isNull() ) {
- args << TQVariant( id );
- }
- args << TQVariant( user )
- << TQVariant( pw );
- return args;
-}
-
diff --git a/kresources/blogging/bloggingglobals.h b/kresources/blogging/bloggingglobals.h
deleted file mode 100644
index 74eafdf75..000000000
--- a/kresources/blogging/bloggingglobals.h
+++ /dev/null
@@ -1,50 +0,0 @@
- /*
- This file is part of tdepim.
-
- Copyright (c) 2005 Reinhold Kainhofer <reinhold@kainhofer.com>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-#ifndef BLOGGINGGLOBALS_H
-#define BLOGGINGGLOBALS_H
-
-#include <tqstring.h>
-#include <tqvariant.h>
-#include <tqvaluelist.h>
-
-class BloggingGlobals
-{
- public:
- BloggingGlobals() {}
-
- enum blogFunctions {
- bloggerGetUserInfo,
- bloggerGetUsersBlogs,
- bloggerGetRecentPosts,
- bloggerNewPost,
- bloggerEditPost,
- bloggerDeletePost,
- bloggerGetPost,
- bloggerGetTemplate,
- bloggerSetTemplate
- };
-
- static TQString getFunctionName( blogFunctions type );
- static TQValueList<TQVariant> defaultArgs( const TQString &user, const TQString &pw, const TQString &id = TQString() );
- static TQString mAppID;
-};
-
-#endif
diff --git a/kresources/blogging/kcal_resourceblogging.cpp b/kresources/blogging/kcal_resourceblogging.cpp
deleted file mode 100644
index 14bb24ca3..000000000
--- a/kresources/blogging/kcal_resourceblogging.cpp
+++ /dev/null
@@ -1,97 +0,0 @@
-/*
- This file is part of tdepim.
-
- Copyright (c) 2004 Reinhold Kainhofer <reinhold@kainhofer.com>>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
-*/
-
-#include "bloggingcalendaradaptor.h"
-#include "API_Blogger.h"
-
-#include "kcal_resourceblogging.h"
-#include <kresources_groupwareprefs.h>
-
-using namespace KCal;
-
-KBlog::APIBlog *ResourceBlogging::mAPI = 0;
-
-ResourceBlogging::ResourceBlogging()
- : ResourceGroupwareBase()
-{
- init();
-}
-
-ResourceBlogging::ResourceBlogging( const TDEConfig *config )
- : ResourceGroupwareBase( config )
-{
- init();
- if ( config ) {
- readConfig( config );
- } else {
- setResourceName( i18n( "Blogs" ) );
- }
-}
-
-void ResourceBlogging::init()
-{
- setType( "ResourceBlogging" );
- setPrefs( createPrefs() );
- setFolderLister( new KPIM::FolderLister( KPIM::FolderLister::Calendar ) );
- BloggingCalendarAdaptor *ad = new BloggingCalendarAdaptor();
- setAdaptor( ad );
- ad->setAPI( new KBlog::APIBlogger( prefs()->url(), this ) );
-
- ResourceGroupwareBase::init();
-}
-
-void ResourceBlogging::readConfig( const TDEConfig *config )
-{
- BloggingCalendarAdaptor *ad = dynamic_cast<BloggingCalendarAdaptor*>( adaptor() );
- ResourceGroupwareBase::readConfig( config );
- if ( ad && prefs() ) {
- ad->setUser( prefs()->user() );
- ad->setPassword( prefs()->password() );
- ad->setBaseURL( prefs()->url() );
- }
-// TQString url = config->readEntry( "URL" );
-// mUrl = KURL( url );
-
-// mServerAPI = config->readNumEntry( "ServerAPI" );
-// mTemplate.setCategoryTagOpen( config->readEntry( "CategoryTagOpen", "<CATEGORY>" ) );
-// mTemplate.setCategoryTagClose( config->readEntry( "CategoryTagClose", "</CATEGORY>" ) );
-// mTemplate.setTitleTagOpen( config->readEntry( "TitleTagOpen", "<TITLE>" ) );
-// mTemplate.setTitleTagClose( config->readEntry( "TitleTagClose", "</TITLE>" ) );
-
-}
-
-void ResourceBlogging::writeConfig( TDEConfig *config )
-{
- kdDebug(5800) << "ResourceBlogging::writeConfig()" << endl;
-
- ResourceCalendar::writeConfig( config );
-
-// config->writeEntry( "URL", mUrl.url() );
-// config->writeEntry( "ServerAPI", mServerAPI );
-// config->writeEntry( "CategoryTagOpen", mTemplate.categoryTagOpen() );
-// config->writeEntry( "CategoryTagClose", mTemplate.categoryTagClose() );
-// config->writeEntry( "TitleTagOpen", mTemplate.titleTagOpen() );
-// config->writeEntry( "TitleTagClose", mTemplate.titleTagClose() );
-
- ResourceGroupwareBase::writeConfig( config );
-}
-
-
-#include "kcal_resourceblogging.moc"
diff --git a/kresources/blogging/kcal_resourceblogging.h b/kresources/blogging/kcal_resourceblogging.h
deleted file mode 100644
index 4e850d148..000000000
--- a/kresources/blogging/kcal_resourceblogging.h
+++ /dev/null
@@ -1,60 +0,0 @@
- /*
- This file is part of tdepim.
-
- Copyright (c) 2004 Reinhold Kainhofer <reinhold@kainhofer.com>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-#ifndef KCAL_RESOURCEBLOGGING_H
-#define KCAL_RESOURCEBLOGGING_H
-
-#include <kcal_resourcegroupwarebase.h>
-#include <tdepimmacros.h>
-
-namespace KBlog {
-class APIBlog;
-}
-
-namespace KCal {
-
-/**
- This class provides a resource for accessing blogs on a blogging server as journals
-*/
-class KDE_EXPORT ResourceBlogging : public ResourceGroupwareBase
-{
- Q_OBJECT
-
- public:
- ResourceBlogging();
- ResourceBlogging( const TDEConfig * );
-
- void readConfig( const TDEConfig *config );
- void writeConfig( TDEConfig *config );
-
- bool addEvent( Event* ) { return false; }
- bool addTodo( Todo * ) { return false; }
- bool deleteEvent( Event* ) { return false; }
- bool deleteTodo( Todo * ) { return false; }
- static KBlog::APIBlog *api() { return mAPI; }
-
- protected:
- void init();
- static KBlog::APIBlog *mAPI;
-};
-
-}
-
-#endif
diff --git a/kresources/blogging/kcal_resourceblogging_plugin.cpp b/kresources/blogging/kcal_resourceblogging_plugin.cpp
deleted file mode 100644
index 4cc3dd8cb..000000000
--- a/kresources/blogging/kcal_resourceblogging_plugin.cpp
+++ /dev/null
@@ -1,41 +0,0 @@
-/*
- This file is part of tdepim.
-
- Copyright (c) 2004 Reinhold Kainhofer <reinhold@kainhofer.com>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-
-#include "kcal_resourceblogging.h"
-#include "kcal_resourcebloggingconfig.h"
-
-#include <kglobal.h>
-#include <klocale.h>
-
-using namespace KCal;
-
-typedef KRES::PluginFactory< ResourceBlogging, ResourceBloggingConfig > BloggingFactory;
-//K_EXPORT_COMPONENT_FACTORY( kcal_blogging, BloggingFactory )
-
-extern "C"
-{
- void *init_kcal_blogging()
- {
- TDEGlobal::locale()->insertCatalogue( "tdepimresources" );
- TDEGlobal::locale()->insertCatalogue( "kres_blogging" );
- return new BloggingFactory;
- }
-}
diff --git a/kresources/blogging/kcal_resourcebloggingconfig.cpp b/kresources/blogging/kcal_resourcebloggingconfig.cpp
deleted file mode 100644
index bd999ffe3..000000000
--- a/kresources/blogging/kcal_resourcebloggingconfig.cpp
+++ /dev/null
@@ -1,41 +0,0 @@
-/*
- This file is part of tdepim.
-
- Copyright (c) 2005 Reinhold Kainhofer <reinhold@kainhofer.com>
-
- 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.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
-*/
-
-#include "kcal_resourcebloggingconfig.h"
-
-#include <kmessagebox.h>
-#include <klocale.h>
-
-using namespace KCal;
-
-ResourceBloggingConfig::ResourceBloggingConfig( TQWidget *parent, const char *name ) : ResourceGroupwareBaseConfig( parent, name )
-{
-}
-
-void ResourceBloggingConfig::saveSettings( KRES::Resource *resource )
-{
- if ( resource && !resource->readOnly() ) {
- KMessageBox::information( this, i18n("Currently, the blogging resource is only read-only. You will not be able to add journals to this resource or upload any changes to the server."), i18n("Read-Only"), "AutoSetReadOnly");
- resource->setReadOnly( true );
- }
- ResourceGroupwareBaseConfig::saveSettings( resource );
-}
-
-#include "kcal_resourcebloggingconfig.moc"
diff --git a/kresources/blogging/kcal_resourcebloggingconfig.h b/kresources/blogging/kcal_resourcebloggingconfig.h
deleted file mode 100644
index b7584167c..000000000
--- a/kresources/blogging/kcal_resourcebloggingconfig.h
+++ /dev/null
@@ -1,41 +0,0 @@
-/*
- This file is part of tdepim.
-
- Copyright (c) 2005 Reinhold Kainhofer <reinhold@kainhofer.com>
-
- 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.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
-*/
-#ifndef KCAL_RESOURCEBLOGGINGCONFIG_H
-#define KCAL_RESOURCEBLOGGINGCONFIG_H
-
-#include <tdepimmacros.h>
-#include <kcal_resourcegroupwarebaseconfig.h>
-
-namespace KCal {
-
-class KDE_EXPORT ResourceBloggingConfig : public ResourceGroupwareBaseConfig
-{
- Q_OBJECT
-
- public:
- ResourceBloggingConfig( TQWidget *parent = 0, const char *name = 0 );
-
- public slots:
- virtual void saveSettings( KRES::Resource *resource );
-};
-
-}
-
-#endif
diff --git a/kresources/blogging/resourcebloggingsettings.ui b/kresources/blogging/resourcebloggingsettings.ui
deleted file mode 100644
index 7d7e02279..000000000
--- a/kresources/blogging/resourcebloggingsettings.ui
+++ /dev/null
@@ -1,330 +0,0 @@
-<!DOCTYPE UI><UI version="3.3" stdsetdef="1">
-<class>ResourceBloggingSettings</class>
-<author>Ian Reinhart Geiser &lt;geiseri@kde.org&gt;</author>
-<widget class="TQWidget">
- <property name="name">
- <cstring>ResourceBloggingSettings</cstring>
- </property>
- <property name="geometry">
- <rect>
- <x>0</x>
- <y>0</y>
- <width>363</width>
- <height>289</height>
- </rect>
- </property>
- <vbox>
- <property name="name">
- <cstring>unnamed</cstring>
- </property>
- <widget class="TQLayoutWidget">
- <property name="name">
- <cstring>layout12</cstring>
- </property>
- <hbox>
- <property name="name">
- <cstring>unnamed</cstring>
- </property>
- <widget class="TQLabel">
- <property name="name">
- <cstring>textLabel1_4</cstring>
- </property>
- <property name="enabled">
- <bool>false</bool>
- </property>
- <property name="sizePolicy">
- <sizepolicy>
- <hsizetype>4</hsizetype>
- <vsizetype>5</vsizetype>
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
- </property>
- <property name="text">
- <string>Service:</string>
- </property>
- </widget>
- <widget class="KComboBox">
- <item>
- <property name="text">
- <string>Custom</string>
- </property>
- </item>
- <item>
- <property name="text">
- <string>Blogger.com</string>
- </property>
- </item>
- <property name="name">
- <cstring>mServiceType</cstring>
- </property>
- <property name="enabled">
- <bool>false</bool>
- </property>
- </widget>
- </hbox>
- </widget>
- <widget class="TQGroupBox">
- <property name="name">
- <cstring>groupBox2</cstring>
- </property>
- <property name="title">
- <string>Server Settings</string>
- </property>
- <grid>
- <property name="name">
- <cstring>unnamed</cstring>
- </property>
- <widget class="TQLabel" row="0" column="0">
- <property name="name">
- <cstring>textLabel1</cstring>
- </property>
- <property name="sizePolicy">
- <sizepolicy>
- <hsizetype>4</hsizetype>
- <vsizetype>5</vsizetype>
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
- </property>
- <property name="text">
- <string>URL:</string>
- </property>
- </widget>
- <widget class="TQLabel" row="1" column="0">
- <property name="name">
- <cstring>textLabel9</cstring>
- </property>
- <property name="text">
- <string>Username:</string>
- </property>
- </widget>
- <widget class="KLineEdit" row="1" column="1">
- <property name="name">
- <cstring>mUser</cstring>
- </property>
- </widget>
- <widget class="TQLabel" row="2" column="0">
- <property name="name">
- <cstring>textLabel10</cstring>
- </property>
- <property name="text">
- <string>Password:</string>
- </property>
- </widget>
- <widget class="KURLRequester" row="0" column="1">
- <property name="name">
- <cstring>mURL</cstring>
- </property>
- <property name="url" stdset="0">
- <string>http://www.kdedevelopers.com/xmlrpc.php</string>
- </property>
- <property name="showLocalProtocol">
- <bool>true</bool>
- </property>
- </widget>
- <widget class="KLineEdit" row="2" column="1">
- <property name="name">
- <cstring>mPassword</cstring>
- </property>
- <property name="echoMode">
- <enum>Password</enum>
- </property>
- </widget>
- <widget class="TQLabel" row="3" column="0">
- <property name="name">
- <cstring>textLabel4_2</cstring>
- </property>
- <property name="sizePolicy">
- <sizepolicy>
- <hsizetype>4</hsizetype>
- <vsizetype>5</vsizetype>
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
- </property>
- <property name="text">
- <string>Server API:</string>
- </property>
- </widget>
- <widget class="KComboBox" row="3" column="1">
- <item>
- <property name="text">
- <string>Blogger API</string>
- </property>
- </item>
- <item>
- <property name="text">
- <string>Drupal API</string>
- </property>
- </item>
- <item>
- <property name="text">
- <string>metaWeblog API</string>
- </property>
- </item>
- <item>
- <property name="text">
- <string>Moveable Type API</string>
- </property>
- </item>
- <property name="name">
- <cstring>mServerAPI</cstring>
- </property>
- <property name="contextMenuEnabled">
- <bool>true</bool>
- </property>
- </widget>
- </grid>
- </widget>
- <widget class="TQGroupBox">
- <property name="name">
- <cstring>groupBox3</cstring>
- </property>
- <property name="title">
- <string>Templates</string>
- </property>
- <grid>
- <property name="name">
- <cstring>unnamed</cstring>
- </property>
- <widget class="KLineEdit" row="0" column="2" rowspan="2" colspan="1">
- <property name="name">
- <cstring>mCloseTitle</cstring>
- </property>
- <property name="sizePolicy">
- <sizepolicy>
- <hsizetype>1</hsizetype>
- <vsizetype>0</vsizetype>
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
- </property>
- <property name="text">
- <string>&lt;/TITLE&gt;</string>
- </property>
- </widget>
- <widget class="TQLabel" row="0" column="0">
- <property name="name">
- <cstring>textLabel7_2</cstring>
- </property>
- <property name="text">
- <string>Title tags:</string>
- </property>
- </widget>
- <widget class="KLineEdit" row="0" column="1" rowspan="2" colspan="1">
- <property name="name">
- <cstring>mOpenTitle</cstring>
- </property>
- <property name="sizePolicy">
- <sizepolicy>
- <hsizetype>1</hsizetype>
- <vsizetype>0</vsizetype>
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
- </property>
- <property name="text">
- <string>&lt;TITLE&gt;</string>
- </property>
- </widget>
- <widget class="KLineEdit" row="2" column="1">
- <property name="name">
- <cstring>mOpenCategory</cstring>
- </property>
- <property name="sizePolicy">
- <sizepolicy>
- <hsizetype>1</hsizetype>
- <vsizetype>0</vsizetype>
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
- </property>
- <property name="lineWidth">
- <number>2</number>
- </property>
- <property name="text">
- <string>&lt;CATEGORY&gt;</string>
- </property>
- </widget>
- <widget class="TQLabel" row="1" column="0" rowspan="2" colspan="1">
- <property name="name">
- <cstring>textLabel8_2</cstring>
- </property>
- <property name="sizePolicy">
- <sizepolicy>
- <hsizetype>4</hsizetype>
- <vsizetype>1</vsizetype>
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
- </property>
- <property name="text">
- <string>Category tags:</string>
- </property>
- </widget>
- <widget class="KLineEdit" row="2" column="2">
- <property name="name">
- <cstring>mCloseCategory</cstring>
- </property>
- <property name="sizePolicy">
- <sizepolicy>
- <hsizetype>1</hsizetype>
- <vsizetype>0</vsizetype>
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
- </property>
- <property name="text">
- <string>&lt;/CATEGORY&gt;</string>
- </property>
- </widget>
- </grid>
- </widget>
- <spacer>
- <property name="name">
- <cstring>spacer4_2</cstring>
- </property>
- <property name="orientation">
- <enum>Vertical</enum>
- </property>
- <property name="sizeType">
- <enum>Expanding</enum>
- </property>
- <property name="sizeHint">
- <size>
- <width>20</width>
- <height>84</height>
- </size>
- </property>
- </spacer>
- </vbox>
-</widget>
-<customwidgets>
-</customwidgets>
-<tabstops>
- <tabstop>mServiceType</tabstop>
- <tabstop>mURL</tabstop>
- <tabstop>mUser</tabstop>
- <tabstop>mPassword</tabstop>
- <tabstop>mServerAPI</tabstop>
- <tabstop>mOpenTitle</tabstop>
- <tabstop>mCloseTitle</tabstop>
- <tabstop>mOpenCategory</tabstop>
- <tabstop>mCloseCategory</tabstop>
-</tabstops>
-<layoutdefaults spacing="5" margin="5"/>
-<includehints>
- <includehint>kcombobox.h</includehint>
- <includehint>klineedit.h</includehint>
- <includehint>kurlrequester.h</includehint>
- <includehint>klineedit.h</includehint>
- <includehint>kpushbutton.h</includehint>
- <includehint>klineedit.h</includehint>
- <includehint>kcombobox.h</includehint>
- <includehint>klineedit.h</includehint>
- <includehint>klineedit.h</includehint>
- <includehint>klineedit.h</includehint>
- <includehint>klineedit.h</includehint>
-</includehints>
-</UI>
diff --git a/kresources/blogging/xmlrpcjob.cpp b/kresources/blogging/xmlrpcjob.cpp
deleted file mode 100644
index f2e516308..000000000
--- a/kresources/blogging/xmlrpcjob.cpp
+++ /dev/null
@@ -1,430 +0,0 @@
-/* This file is part of the KDE libraries
- Copyright (C) 2004 Reinhold Kainhofer <reinhold@kainhofer.com>
-
- Based on the davjob:
- Copyright (C) 2002 Jan-Pascal van Best <janpascal@vanbest.org>
- XML-RPC specific parts taken from the xmlrpciface:
- Copyright (C) 2003 - 2004 by Frerich Raabe <raabe@kde.org>
- Tobias Koenig <tokoe@kde.org>
-
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-
-#include "xmlrpcjob.h"
-
-#include <tqvariant.h>
-#include <tqregexp.h>
-
-#include <kdebug.h>
-#include <klocale.h>
-#include <kio/http.h>
-#include <kmdcodec.h>
-#include <kio/davjob.h>
-
-
-#define KIO_ARGS TQByteArray packedArgs; \
- TQDataStream stream( packedArgs, IO_WriteOnly ); stream
-
-using namespace TDEIO;
-
-namespace TDEIO {
- class XMLRPCResult
- {
- friend class XmlrpcJob;
- public:
- XMLRPCResult() {}
- bool success() const { return m_success; }
- int errorCode() const { return m_errorCode; }
- TQString errorString() const { return m_errorString; }
- TQValueList<TQVariant> data() const { return m_data; }
- private:
- bool m_success;
- int m_errorCode;
- TQString m_errorString;
- TQValueList<TQVariant> m_data;
- };
-}
-
-class XmlrpcJob::XmlrpcJobPrivate
-{
-public:
-// TQByteArray savedStaticData;
-};
-
-
-XmlrpcJob::XmlrpcJob( const KURL& url, const TQString& method,
- const TQValueList<TQVariant> &params, bool showProgressInfo)
- : TransferJob( url, TDEIO::CMD_SPECIAL, TQByteArray(), TQByteArray(),
- showProgressInfo )
-{
- d = new XmlrpcJobPrivate;
- // We couldn't set the args when calling the parent constructor,
- // so do it now.
- TQDataStream stream( m_packedArgs, IO_WriteOnly );
- stream << (int)1 << url;
-kdDebug()<<"XMLrpcJob::url="<<url.url()<<endl;
-kdDebug()<<"XmlrpcJob::XmlrpcJob, method="<<method<<endl;
- // Same for static data
- if ( ! method.isEmpty() ) {
-kdDebug()<<"XmlrpcJob::XmlrpcJob, method not empty."<<endl;
-
- TQString call = markupCall( method, params );
- staticData = call.utf8();
- staticData.truncate( staticData.size() - 1 );
- kdDebug() << "Message: " << call << endl;
-// d->savedStaticData = staticData.copy();
- }
- addMetaData( "UserAgent", "KDE XML-RPC TransferJob" );
- addMetaData( "content-type", "Content-Type: text/xml; charset=utf-8" );
- addMetaData( "ConnectTimeout", "50" );
-}
-
-XmlrpcJob::~XmlrpcJob()
-{
- delete d;
- d = 0;
-}
-
-TQString XmlrpcJob::markupCall( const TQString &cmd,
- const TQValueList<TQVariant> &args )
-{
-kdDebug()<<"XmlrpcJob::markupCall, cmd="<<cmd<<endl;
- TQString markup = "<?xml version=\"1.0\" ?>\r\n<methodCall>\r\n";
-
- markup += "<methodName>" + cmd + "</methodName>\r\n";
-
- if ( !args.isEmpty() )
- {
- markup += "<params>\r\n";
- TQValueList<TQVariant>::ConstIterator it = args.begin();
- TQValueList<TQVariant>::ConstIterator end = args.end();
- for ( ; it != end; ++it )
- markup += "<param>\r\n" + marshal( *it ) + "</param>\r\n";
- markup += "</params>\r\n";
- }
-
- markup += "</methodCall>\r\n";
-
- return markup;
-}
-
-
-
-
-
-void XmlrpcJob::slotData( const TQByteArray& data )
-{
-kdDebug()<<"XmlrpcJob::slotData()"<<endl;
- if ( m_redirectionURL.isEmpty() || !m_redirectionURL.isValid() || m_error )
- m_str_response.append( TQString( data ) );
-}
-
-void XmlrpcJob::slotFinished()
-{
-kdDebug() << "XmlrpcJob::slotFinished()" << endl;
-kdDebug() << m_str_response << endl;
-
- // TODO: Redirection with XML-RPC??
-/* if (! m_redirectionURL.isEmpty() && m_redirectionURL.isValid() ) {
- TQDataStream istream( m_packedArgs, IO_ReadOnly );
- int s_cmd, s_method;
- KURL s_url;
- istream >> s_cmd;
- istream >> s_url;
- istream >> s_method;
- // PROPFIND
- if ( (s_cmd == 7) && (s_method == (int)TDEIO::HTTP_POST) ) {
- m_packedArgs.truncate(0);
- TQDataStream stream( m_packedArgs, IO_WriteOnly );
- stream << (int)7 << m_redirectionURL << (int)TDEIO::HTTP_POST;
- }
- } else */
-
- kdDebug() << "\033[35;40mResult: " << m_str_response << "\033[0;0m" << endl;
- TQDomDocument doc;
- TQString errMsg;
- int errLine, errCol;
- if ( doc.setContent( m_str_response, false, &errMsg, &errLine, &errCol ) ) {
- if ( isMessageResponse( doc ) ) {
- m_response = parseMessageResponse( doc ).data();
- m_responseType = XMLRPCMessageResponse;
- } else if ( isFaultResponse( doc ) ) {
- // TODO: Set the error of the job
- m_response.clear();
- m_response << TQVariant( parseFaultResponse( doc ).errorString() );
- m_responseType = XMLRPCFaultResponse;
- } else {
- // TODO: Set the error of the job
- m_response.clear();
- m_response << TQVariant( i18n( "Unknown type of XML markup received. "
- "Markup: \n %1" ).arg( m_str_response ) );
- m_responseType = XMLRPCUnknownResponse;
- }
-
- } else {
- // TODO: if we can't parse the XML response, set the correct error message!
-// emit fault( -1, i18n( "Received invalid XML markup: %1 at %2:%3" )
-// .arg( errMsg ).arg( errLine ).arg( errCol ), m_id );
- }
-
- TransferJob::slotFinished();
-// TODO: Redirect: if( d ) staticData = d->savedStaticData.copy();
-// Need to send XMLRPC request to this host too
-}
-
-
-
-
-
-bool XmlrpcJob::isMessageResponse( const TQDomDocument &doc )
-{
- return doc.documentElement().firstChild().toElement()
- .tagName().lower() == "params";
-}
-
-XMLRPCResult XmlrpcJob::parseMessageResponse( const TQDomDocument &doc )
-{
- XMLRPCResult response;
- response.m_success = true;
-
- TQDomNode paramNode = doc.documentElement().firstChild().firstChild();
- while ( !paramNode.isNull() ) {
- response.m_data << demarshal( paramNode.firstChild().toElement() );
- paramNode = paramNode.nextSibling();
- }
-
- return response;
-}
-
-
-
-
-
-bool XmlrpcJob::isFaultResponse( const TQDomDocument &doc )
-{
- return doc.documentElement().firstChild().toElement()
- .tagName().lower() == "fault";
-}
-
-XMLRPCResult XmlrpcJob::parseFaultResponse( const TQDomDocument &doc )
-{
- XMLRPCResult response;
- response.m_success = false;
-
- TQDomNode errorNode = doc.documentElement().firstChild().firstChild();
- const TQVariant errorVariant = demarshal( errorNode.toElement() );
- response.m_errorCode = errorVariant.toMap() [ "faultCode" ].toInt();
- response.m_errorString = errorVariant.toMap() [ "faultString" ].toString();
-
- return response;
-}
-
-
-
-
-
-TQString XmlrpcJob::marshal( const TQVariant &arg )
-{
- switch ( arg.type() )
- {
- case TQVariant::String:
- case TQVariant::CString:
- return "<value><string>" + arg.toString() + "</string></value>\r\n";
- case TQVariant::Int:
- return "<value><int>" + TQString::number( arg.toInt() ) +
- "</int></value>\r\n";
- case TQVariant::Double:
- return "<value><double>" + TQString::number( arg.toDouble() ) +
- "</double></value>\r\n";
- case TQVariant::Bool:
- {
- TQString markup = "<value><boolean>";
- markup += arg.toBool() ? "1" : "0";
- markup += "</boolean></value>\r\n";
- return markup;
- }
- case TQVariant::ByteArray:
- return "<value><base64>" + KCodecs::base64Encode( arg.toByteArray() ) +
- "</base64></value>\r\n";
- case TQVariant::DateTime:
- return "<value><datetime.iso8601>" +
- arg.toDateTime().toString( TQt::ISODate ) +
- "</datetime.iso8601></value>\r\n";
- case TQVariant::List:
- {
- TQString markup = "<value><array><data>\r\n";
- const TQValueList<TQVariant> args = arg.toList();
- TQValueList<TQVariant>::ConstIterator it = args.begin();
- TQValueList<TQVariant>::ConstIterator end = args.end();
- for ( ; it != end; ++it )
- markup += marshal( *it );
- markup += "</data></array></value>\r\n";
- return markup;
- }
- case TQVariant::Map:
- {
- TQString markup = "<value><struct>\r\n";
- TQMap<TQString, TQVariant> map = arg.toMap();
- TQMap<TQString, TQVariant>::ConstIterator it = map.begin();
- TQMap<TQString, TQVariant>::ConstIterator end = map.end();
- for ( ; it != end; ++it )
- {
- markup += "<member>\r\n";
- markup += "<name>" + it.key() + "</name>\r\n";
- markup += marshal( it.data() );
- markup += "</member>\r\n";
- }
- markup += "</struct></value>\r\n";
- return markup;
- }
- default:
- kdWarning() << "Failed to marshal unknown variant type: "
- << arg.type() << endl;
- };
- return TQString();
-}
-
-TQVariant XmlrpcJob::demarshal( const TQDomElement &elem )
-{
- Q_ASSERT( elem.tagName().lower() == "value" );
-
- if ( !elem.hasChildNodes() ) {
- // it doesn't have child nodes, so no explicit type name was given,
- // i.e. <value>here comes the value</value> instead of
- // <value><string>here comes the value</string></value>
- // Assume <string> in that case:
- // Actually, the element will still have a child node, so this will not help here.
- // The dirty hack is at the end of this method.
-kdDebug()<<"XmlrpcJob::demarshal: No child nodes, assume type=string. Text: "<<elem.text()<<endl;
- return TQVariant( elem.text() );
- }
-
-kdDebug()<<"Demarshalling element \"" << elem.text() <<"\"" << endl;
-
- const TQDomElement typeElement = elem.firstChild().toElement();
- const TQString typeName = typeElement.tagName().lower();
-
- if ( typeName == "string" )
- return TQVariant( typeElement.text() );
- else if ( typeName == "i4" || typeName == "int" )
- return TQVariant( typeElement.text().toInt() );
- else if ( typeName == "double" )
- return TQVariant( typeElement.text().toDouble() );
- else if ( typeName == "boolean" )
- {
- if ( typeElement.text().lower() == "true" || typeElement.text() == "1" )
- return TQVariant( true );
- else
- return TQVariant( false );
- }
- else if ( typeName == "base64" )
- return TQVariant( KCodecs::base64Decode( typeElement.text().latin1() ) );
-
- else if ( typeName == "datetime" || typeName == "datetime.iso8601" ) {
-
- TQString text( typeElement.text() );
- if ( text.find( TQRegExp("^[0-9]{8,8}T") ) >= 0 ) {
- // It's in the format 20041120T...., so adjust it to correct
- // ISO 8601 Format 2004-11-20T..., else TQDateTime::fromString won't work:
- text = text.insert( 6, '-' );
- text = text.insert( 4, '-' );
- }
- return TQVariant( TQDateTime::fromString( text, TQt::ISODate ) );
-
- } else if ( typeName == "array" ) {
-
- TQValueList<TQVariant> values;
- TQDomNode valueNode = typeElement.firstChild().firstChild();
- while ( !valueNode.isNull() ) {
- values << demarshal( valueNode.toElement() );
- valueNode = valueNode.nextSibling();
- }
- return TQVariant( values );
-
- } else if ( typeName == "struct" ) {
-
- TQMap<TQString, TQVariant> map;
- TQDomNode memberNode = typeElement.firstChild();
- while ( !memberNode.isNull() ) {
- const TQString key = memberNode.toElement().elementsByTagName( "name" ).item( 0 ).toElement().text();
- const TQVariant data = demarshal( memberNode.toElement().elementsByTagName( "value" ).item( 0 ).toElement() );
- map[ key ] = data;
- memberNode = memberNode.nextSibling();
- }
- return TQVariant( map );
-
- } else {
-
- kdWarning() << "Cannot demarshal unknown type " << typeName << ", text= " << typeElement.text() << endl;
- // FIXME: This is just a workaround, for the issue mentioned at the beginning of this method.
- return TQVariant( elem.text() );
- }
-
- return TQVariant();
-}
-
-
-
-
-
-/* Convenience methods */
-
-XmlrpcJob* TDEIO::xmlrpcCall( const KURL& url, const TQString &method, const TQValueList<TQVariant> &params, bool showProgressInfo )
-{
- if ( url.isEmpty() ) {
- kdWarning() << "Cannot execute call to " << method << ": empty server URL" << endl;
- return 0;
- }
- XmlrpcJob *job = new XmlrpcJob( url, method, params, showProgressInfo );
-// job->addMetaData( "xmlrpcDepth", depth );
-
- return job;
-}
-
-XmlrpcJob* TDEIO::xmlrpcCall( const KURL& url, const TQString &method,
- const TQVariant &arg, bool showProgressInfo )
-{
- TQValueList<TQVariant> args;
- args << arg;
- return TDEIO::xmlrpcCall( url, method, args, showProgressInfo );
-}
-
-XmlrpcJob* TDEIO::xmlrpcCall( const KURL& url, const TQString &method,
- const TQStringList &arg, bool showProgressInfo )
-{
- TQValueList<TQVariant> args;
- TQStringList::ConstIterator it = arg.begin();
- TQStringList::ConstIterator end = arg.end();
- for ( ; it != end; ++it )
- args << TQVariant( *it );
- return TDEIO::xmlrpcCall( url, method, args, showProgressInfo );
-}
-
-template <typename T>
-XmlrpcJob* TDEIO::xmlrpcCall( const KURL& url, const TQString &method,
- const TQValueList<T>&arg, bool showProgressInfo )
-{
- TQValueList<TQVariant> args;
-
- typename TQValueList<T>::ConstIterator it = arg.begin();
- typename TQValueList<T>::ConstIterator end = arg.end();
- for ( ; it != end; ++it )
- args << TQVariant( *it );
- return TDEIO::xmlrpcCall( url, method, args, showProgressInfo );
-}
-
-#include "xmlrpcjob.moc"
diff --git a/kresources/blogging/xmlrpcjob.h b/kresources/blogging/xmlrpcjob.h
deleted file mode 100644
index 1efe79e1d..000000000
--- a/kresources/blogging/xmlrpcjob.h
+++ /dev/null
@@ -1,124 +0,0 @@
-// -*- c++ -*-
-/* This file is part of the KDE libraries
- Copyright (C) 2004 Reinhold Kainhofer <reinhold@kainhofer.com>
- Based on the davjob:
- Copyright (C) 2002 Jan-Pascal van Best <janpascal@vanbest.org>
-
- This library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-
-#ifndef __kio_xmlrpcjob_h__
-#define __kio_xmlrpcjob_h__
-
-#include <kurl.h>
-
-#include <tqstring.h>
-#include <tqvaluelist.h>
-#include <tqdom.h>
-
-#include <kio/jobclasses.h>
-#include <kio/global.h>
-
-namespace TDEIO {
-
- class XMLRPCResult;
-
-/**
- * The transfer job pumps data into and/or out of a Slave.
- * Data is sent to the slave on request of the slave ( dataReq ).
- * If data coming from the slave can not be handled, the
- * reading of data from the slave should be suspended.
- * @see TDEIO::xmlrpcCall()
- * @since 3.4
- */
-class XmlrpcJob : public TransferJob {
-Q_OBJECT
-
-
- public:
- /** Indicates the response type of the call
- */
- enum XMLRPCResponseType {
- XMLRPCMessageResponse,
- XMLRPCFaultResponse,
- XMLRPCUnknownResponse
- };
- /**
- * Use TDEIO::xmlrpcPropFind(), TDEIO::xmlrpcPropPatch() and
- * TDEIO::xmlrpcSearch() to create a new XmlrpcJob.
- */
- XmlrpcJob( const KURL& url, const TQString& method,
- const TQValueList<TQVariant> &params, bool showProgressInfo );
- virtual ~XmlrpcJob();
- /**
- * Returns the response as a TQDomDocument.
- * @return the response document
- */
- TQValueList<TQVariant> &response() { return m_response; }
- /**
- * Returns the type of the response.
- * @return the type of the response
- */
- XMLRPCResponseType responseType() const { return m_responseType; }
-
- static TQString markupCall( const TQString &cmd,
- const TQValueList<TQVariant> &args );
- protected slots:
- virtual void slotFinished();
- virtual void slotData( const TQByteArray &data);
-
- protected:
- static TQString marshal( const TQVariant &arg );
- static TQVariant demarshal( const TQDomElement &e );
-
- static bool isMessageResponse( const TQDomDocument &doc );
- static bool isFaultResponse( const TQDomDocument &doc );
-
- static XMLRPCResult parseMessageResponse( const TQDomDocument &doc );
- static XMLRPCResult parseFaultResponse( const TQDomDocument &doc );
-
-
- private:
- class XmlrpcJobPrivate;
- XmlrpcJobPrivate *d;
- TQString m_str_response;
- TQValueList<TQVariant> m_response;
- XMLRPCResponseType m_responseType;
-};
-
-/**
- * Creates a XmlrpcJob that calls a @p method of the API at the given @p url.
- *
- * @param url the URL of the XML-RPC Interface of the server
- * @param method the name of the method to call
- * @param params the arguments (as TQValueList<TQVariant>) for the method call.
- * @param showProgressInfo true to show progress information
- * @return the new XmlrpcJob
- */
-XmlrpcJob* xmlrpcCall( const KURL& url, const TQString &method,
- const TQValueList<TQVariant> &params,
- bool showProgressInfo = true );
-
-XmlrpcJob* xmlrpcCall( const KURL& url, const TQString &method,
- const TQVariant &arg, bool showProgressInfo = true );
-XmlrpcJob* xmlrpcCall( const KURL& url, const TQString &method,
- const TQStringList &arg, bool showProgressInfo = true );
-template <typename T>
-XmlrpcJob* xmlrpcCall( const KURL& url, const TQString &method,
- const TQValueList<T>&arg,bool showProgressInfo = true );
-}
-
-#endif