mirror of
https://github.com/tomahawk-player/tomahawk.git
synced 2025-08-12 09:04:33 +02:00
Successfully parse friend and mentions timelines
This commit is contained in:
@@ -302,6 +302,8 @@ SettingsDialog::authenticateTwitter()
|
|||||||
ui->twitterStatusLabel->setText("Status: Credentials saved");
|
ui->twitterStatusLabel->setText("Status: Credentials saved");
|
||||||
ui->twitterAuthenticateButton->setText( "Re-authenticate" );
|
ui->twitterAuthenticateButton->setText( "Re-authenticate" );
|
||||||
ui->twitterInstructionsBox->setVisible( true );
|
ui->twitterInstructionsBox->setVisible( true );
|
||||||
|
TomahawkSettings::instance()->setTwitterCachedFriendsSinceId( 0 );
|
||||||
|
TomahawkSettings::instance()->setTwitterCachedMentionsSinceId( 0 );
|
||||||
TomahawkApp::instance()->sipHandler()->connectPlugins( false, "SIPTWITTER" );
|
TomahawkApp::instance()->sipHandler()->connectPlugins( false, "SIPTWITTER" );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@@ -16,6 +16,8 @@ TwitterPlugin::TwitterPlugin()
|
|||||||
: SipPlugin()
|
: SipPlugin()
|
||||||
, m_isValid( false )
|
, m_isValid( false )
|
||||||
, m_checkTimer( this )
|
, m_checkTimer( this )
|
||||||
|
, m_cachedFriendsSinceId( 0 )
|
||||||
|
, m_cachedMentionsSinceId( 0 )
|
||||||
{
|
{
|
||||||
m_checkTimer.setInterval( 60000 );
|
m_checkTimer.setInterval( 60000 );
|
||||||
m_checkTimer.setSingleShot( false );
|
m_checkTimer.setSingleShot( false );
|
||||||
@@ -90,7 +92,9 @@ TwitterPlugin::connectAuthVerifyReply( const QTweetUser &user )
|
|||||||
if ( !m_twitterAuth.isNull() )
|
if ( !m_twitterAuth.isNull() )
|
||||||
{
|
{
|
||||||
m_friendsTimeline = QWeakPointer<QTweetFriendsTimeline>( new QTweetFriendsTimeline( m_twitterAuth.data(), this ) );
|
m_friendsTimeline = QWeakPointer<QTweetFriendsTimeline>( new QTweetFriendsTimeline( m_twitterAuth.data(), this ) );
|
||||||
|
m_mentions = QWeakPointer<QTweetMentions>( new QTweetMentions( m_twitterAuth.data(), this ) );
|
||||||
QObject::connect( m_friendsTimeline.data(), SIGNAL( parsedStatuses(const QList< QTweetStatus > &) ), SLOT( friendsTimelineStatuses(const QList<QTweetStatus> &) ) );
|
QObject::connect( m_friendsTimeline.data(), SIGNAL( parsedStatuses(const QList< QTweetStatus > &) ), SLOT( friendsTimelineStatuses(const QList<QTweetStatus> &) ) );
|
||||||
|
QObject::connect( m_mentions.data(), SIGNAL( parsedStatuses(const QList< QTweetStatus > &) ), SLOT( mentionsStatuses(const QList<QTweetStatus> &) ) );
|
||||||
QMetaObject::invokeMethod( this, "checkTimerFired", Qt::DirectConnection );
|
QMetaObject::invokeMethod( this, "checkTimerFired", Qt::DirectConnection );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -106,27 +110,54 @@ TwitterPlugin::checkTimerFired()
|
|||||||
{
|
{
|
||||||
if ( isValid() )
|
if ( isValid() )
|
||||||
{
|
{
|
||||||
qint64 cachedfriendssinceid = TomahawkSettings::instance()->twitterCachedFriendsSinceId();
|
if ( m_cachedFriendsSinceId == 0 )
|
||||||
|
m_cachedFriendsSinceId = TomahawkSettings::instance()->twitterCachedFriendsSinceId();
|
||||||
if ( !m_friendsTimeline.isNull() )
|
if ( !m_friendsTimeline.isNull() )
|
||||||
m_friendsTimeline.data()->fetch( cachedfriendssinceid, 0, 800 );
|
m_friendsTimeline.data()->fetch( m_cachedFriendsSinceId, 0, 800 );
|
||||||
|
|
||||||
|
if ( m_cachedMentionsSinceId == 0 )
|
||||||
|
m_cachedMentionsSinceId = TomahawkSettings::instance()->twitterCachedMentionsSinceId();
|
||||||
|
if ( !m_mentions.isNull() )
|
||||||
|
m_mentions.data()->fetch( m_cachedMentionsSinceId, 0, 800 );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
TwitterPlugin::friendsTimelineStatuses( const QList< QTweetStatus >& statuses )
|
TwitterPlugin::friendsTimelineStatuses( const QList< QTweetStatus >& statuses )
|
||||||
{
|
{
|
||||||
|
qDebug() << "TwitterPlugin checking friends";
|
||||||
QRegExp regex( QString( "^(@[a-zA-Z0-9]+ )?Got Tomahawk\\?(.*)$" ) );
|
QRegExp regex( QString( "^(@[a-zA-Z0-9]+ )?Got Tomahawk\\?(.*)$" ) );
|
||||||
foreach( QTweetStatus status, statuses )
|
foreach( QTweetStatus status, statuses )
|
||||||
{
|
{
|
||||||
|
if ( status.id() > m_cachedFriendsSinceId )
|
||||||
|
m_cachedFriendsSinceId = status.id();
|
||||||
QString statusText = status.text();
|
QString statusText = status.text();
|
||||||
qDebug() << "Performing matching on status text " << statusText;
|
|
||||||
if ( regex.exactMatch( statusText ) )
|
if ( regex.exactMatch( statusText ) )
|
||||||
{
|
{
|
||||||
qDebug() << "Found an exact matching Tweet from user " << status.user().screenName();
|
qDebug() << "TwitterPlugin found an exact tweet from friend " << status.user().screenName();
|
||||||
}
|
}
|
||||||
else
|
|
||||||
qDebug() << "No match, matched length is " << regex.matchedLength();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TomahawkSettings::instance()->setTwitterCachedFriendsSinceId( m_cachedFriendsSinceId );
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
TwitterPlugin::mentionsStatuses( const QList< QTweetStatus >& statuses )
|
||||||
|
{
|
||||||
|
qDebug() << "TwitterPlugin checking mentions";
|
||||||
|
QRegExp regex( QString( "^(@[a-zA-Z0-9]+ )?Got Tomahawk\\?(.*)$" ) );
|
||||||
|
foreach( QTweetStatus status, statuses )
|
||||||
|
{
|
||||||
|
if ( status.id() > m_cachedMentionsSinceId )
|
||||||
|
m_cachedMentionsSinceId = status.id();
|
||||||
|
QString statusText = status.text();
|
||||||
|
if ( regex.exactMatch( statusText ) )
|
||||||
|
{
|
||||||
|
qDebug() << "TwitterPlugin found an exact matching mention from user " << status.user().screenName();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TomahawkSettings::instance()->setTwitterCachedMentionsSinceId( m_cachedMentionsSinceId );
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@@ -7,6 +7,7 @@
|
|||||||
#include <qtweetuser.h>
|
#include <qtweetuser.h>
|
||||||
#include <qtweetnetbase.h>
|
#include <qtweetnetbase.h>
|
||||||
#include <qtweetfriendstimeline.h>
|
#include <qtweetfriendstimeline.h>
|
||||||
|
#include <qtweetmentions.h>
|
||||||
|
|
||||||
#include "../sipdllmacro.h"
|
#include "../sipdllmacro.h"
|
||||||
#include "sip/SipPlugin.h"
|
#include "sip/SipPlugin.h"
|
||||||
@@ -49,12 +50,16 @@ private slots:
|
|||||||
void connectAuthVerifyReply( const QTweetUser &user );
|
void connectAuthVerifyReply( const QTweetUser &user );
|
||||||
void checkTimerFired();
|
void checkTimerFired();
|
||||||
void friendsTimelineStatuses( const QList< QTweetStatus > &statuses );
|
void friendsTimelineStatuses( const QList< QTweetStatus > &statuses );
|
||||||
|
void mentionsStatuses( const QList< QTweetStatus > &statuses );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QWeakPointer<TomahawkOAuthTwitter> m_twitterAuth;
|
QWeakPointer<TomahawkOAuthTwitter> m_twitterAuth;
|
||||||
|
QWeakPointer<QTweetFriendsTimeline> m_friendsTimeline;
|
||||||
|
QWeakPointer<QTweetMentions> m_mentions;
|
||||||
bool m_isValid;
|
bool m_isValid;
|
||||||
QTimer m_checkTimer;
|
QTimer m_checkTimer;
|
||||||
QWeakPointer<QTweetFriendsTimeline> m_friendsTimeline;
|
qint64 m_cachedFriendsSinceId;
|
||||||
|
qint64 m_cachedMentionsSinceId;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Reference in New Issue
Block a user