/* $Id$ */ #ifndef _TQUERY_SERVICE #define _TQUERY_SERVICE /*************************************************************************** query.h - A query interface to select RSS feeds. ------------------- begin : Saturday 15 February 2003 copyright : (C) 2003 by Ian Reinhart Geiser email : geiseri@kde.org ***************************************************************************/ /*************************************************************************** * * * 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 "rssnewsfeed.h" #include "xmlrpciface.h" #include <dcopobject.h> #include <tqmap.h> #include <tqobject.h> #include <tqvaluelist.h> #include <tqvariant.h> class RSSService; /** * Helper class which just calls the slot given it's TQObject/const char* * representation. */ class SlotCaller : public TQObject { Q_OBJECT // TQ_OBJECT public: static void call( TQObject *object, const char *slot, const KXMLRPC::Query::Result &value ); signals: void signal( const KXMLRPC::Query::Result &value ); private: SlotCaller() { } }; class QueryService : public TQObject, public DCOPObject { K_DCOP Q_OBJECT // TQ_OBJECT public: QueryService( RSSService *service ); k_dcop_signals: void feedIds( TQValueList<int> ids ); void feedInfo(TQMap<TQString, TQString> links); void feedInfo(TQValueList<RSSNewsFeed> feeds); void gotCategories( const TQStringList &categories ); void gotFeedsInCategory( const TQValueList<int> &ids ); k_dcop: /** * Lists the active feeds in use... **/ TQStringList listActive(); // just for testing... /** * Query the www.syndic8.com XML-RPC interface for the * string. The RSS ids are treturned in a integer list. **/ void findFeeds( const TQString& query ); /** * Query the www.syndic8.com XML-RPC interface for the * string and matches it against the SiteURL feed of * each feed in the feed list. The RSS ids are treturned * in a integer list. **/ void findSites( const TQString& query ); /** * Query the www.syndic8.com XML-RPC interface for the * requested RSS feed(s). Returned is a TQMap with the format * of Name (Site URL), RSS URL **/ void getFeedInfo( const TQVariant& ids ); /** * Returns the list of subcategories in the specified category. * If no "Top" is specified, the root categories are returned. */ void getCategories( const TQString &category ); /** * Queries the database for the list of needsfeed ID's which are * associated with the given category. */ void getFeedsInCategory( const TQString &category ); private slots: void slotFoundFeeds( const KXMLRPC::Query::Result &result ); void slotGotFeedInfo( const KXMLRPC::Query::Result &result ); void slotGotCategories( const KXMLRPC::Query::Result &result ); void slotGotFeedsInCategory( const KXMLRPC::Query::Result &result ); private: void cachedCall( const TQString &method, const TQValueList<TQVariant> &args, const char *slot ); void updateCache( const KXMLRPC::Query::Result &result ); RSSService *m_service; KXMLRPC::Server *m_xmlrpcServer; }; #endif