mirror of
https://github.com/tomahawk-player/tomahawk.git
synced 2025-08-08 23:26:40 +02:00
Account properly saves itself now and can reload a saved account
This commit is contained in:
@@ -33,7 +33,7 @@ include_directories( . ${CMAKE_CURRENT_BINARY_DIR} ..
|
|||||||
${QTWEETLIB_INCLUDE_DIR}
|
${QTWEETLIB_INCLUDE_DIR}
|
||||||
)
|
)
|
||||||
|
|
||||||
qt4_wrap_cpp( tomahawkOAuthTwitterMoc ${tomahawkOAuthTwitterSources} )
|
qt4_wrap_cpp( tomahawkOAuthTwitterMoc ${tomahawkOAuthTwitterHeaders} )
|
||||||
add_library( tomahawk_oauth_twitter SHARED ${tomahawkOAuthTwitterSources} ${tomahawkOAuthTwitterMoc} )
|
add_library( tomahawk_oauth_twitter SHARED ${tomahawkOAuthTwitterSources} ${tomahawkOAuthTwitterMoc} )
|
||||||
qt4_wrap_cpp( twitterAccountMoc ${twitterAccountHeaders} )
|
qt4_wrap_cpp( twitterAccountMoc ${twitterAccountHeaders} )
|
||||||
qt4_wrap_ui( twitterAccountUI_H ${twitterAccountUI} )
|
qt4_wrap_ui( twitterAccountUI_H ${twitterAccountUI} )
|
||||||
@@ -57,6 +57,7 @@ target_link_libraries( tomahawk_oauth_twitter
|
|||||||
|
|
||||||
target_link_libraries( tomahawk_account_twitter
|
target_link_libraries( tomahawk_account_twitter
|
||||||
tomahawk_oauth_twitter
|
tomahawk_oauth_twitter
|
||||||
|
tomahawk_siptwitter
|
||||||
${TOMAHAWK_LIBRARIES}
|
${TOMAHAWK_LIBRARIES}
|
||||||
${QTWEETLIB_LIBRARIES}
|
${QTWEETLIB_LIBRARIES}
|
||||||
${QT_LIBRARIES}
|
${QT_LIBRARIES}
|
||||||
|
@@ -45,7 +45,7 @@ TwitterAccount::TwitterAccount( const QString &accountId )
|
|||||||
|
|
||||||
setAccountServiceName( "Twitter" );
|
setAccountServiceName( "Twitter" );
|
||||||
QSet< AccountType > types;
|
QSet< AccountType > types;
|
||||||
types << InfoType;
|
types << InfoType << SipType;
|
||||||
setTypes( types );
|
setTypes( types );
|
||||||
|
|
||||||
m_configWidget = QWeakPointer< TwitterConfigWidget >( new TwitterConfigWidget( this, 0 ) );
|
m_configWidget = QWeakPointer< TwitterConfigWidget >( new TwitterConfigWidget( this, 0 ) );
|
||||||
|
@@ -62,7 +62,7 @@ public:
|
|||||||
|
|
||||||
bool canSelfAuthenticate() { return false; }
|
bool canSelfAuthenticate() { return false; }
|
||||||
bool authenticate() { return false; }
|
bool authenticate() { return false; }
|
||||||
bool isAuthenticated() { return m_isAuthenticated; }
|
bool isAuthenticated() const { return m_isAuthenticated; }
|
||||||
|
|
||||||
Tomahawk::InfoSystem::InfoPlugin* infoPlugin() { return 0; }
|
Tomahawk::InfoSystem::InfoPlugin* infoPlugin() { return 0; }
|
||||||
SipPlugin* sipPlugin();
|
SipPlugin* sipPlugin();
|
||||||
|
@@ -38,6 +38,7 @@ set( libSources
|
|||||||
EchonestCatalogSynchronizer.cpp
|
EchonestCatalogSynchronizer.cpp
|
||||||
|
|
||||||
accounts/accountmanager.cpp
|
accounts/accountmanager.cpp
|
||||||
|
accounts/account.cpp
|
||||||
|
|
||||||
sip/SipPlugin.cpp
|
sip/SipPlugin.cpp
|
||||||
sip/SipHandler.cpp
|
sip/SipHandler.cpp
|
||||||
|
64
src/libtomahawk/accounts/account.cpp
Normal file
64
src/libtomahawk/accounts/account.cpp
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
/* === This file is part of Tomahawk Player - <http://tomahawk-player.org> ===
|
||||||
|
*
|
||||||
|
* Copyright 2010-2011, Christian Muehlhaeuser <muesli@tomahawk-player.org>
|
||||||
|
*
|
||||||
|
* Tomahawk 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 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Tomahawk 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 Tomahawk. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "account.h"
|
||||||
|
|
||||||
|
namespace Tomahawk
|
||||||
|
{
|
||||||
|
|
||||||
|
namespace Accounts
|
||||||
|
{
|
||||||
|
|
||||||
|
QWidget*
|
||||||
|
Account::configurationWidget()
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
QWidget*
|
||||||
|
Account::aclWidget()
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
QIcon
|
||||||
|
Account::icon() const
|
||||||
|
{
|
||||||
|
return QIcon();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool
|
||||||
|
Account::authenticate()
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool
|
||||||
|
Account::isAuthenticated() const
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@@ -80,7 +80,7 @@ public:
|
|||||||
virtual QIcon icon() const = 0;
|
virtual QIcon icon() const = 0;
|
||||||
|
|
||||||
virtual bool authenticate() = 0; //if none needed, just return true
|
virtual bool authenticate() = 0; //if none needed, just return true
|
||||||
virtual bool isAuthenticated() = 0;
|
virtual bool isAuthenticated() const = 0;
|
||||||
|
|
||||||
virtual Tomahawk::InfoSystem::InfoPlugin* infoPlugin() = 0;
|
virtual Tomahawk::InfoSystem::InfoPlugin* infoPlugin() = 0;
|
||||||
virtual SipPlugin* sipPlugin() = 0;
|
virtual SipPlugin* sipPlugin() = 0;
|
||||||
@@ -190,7 +190,7 @@ public:
|
|||||||
virtual QIcon icon() const { return QIcon(); }
|
virtual QIcon icon() const { return QIcon(); }
|
||||||
virtual bool isUnique() const { return false; }
|
virtual bool isUnique() const { return false; }
|
||||||
|
|
||||||
virtual Account* createAccount( const QString& pluginId = QString() ) = 0;
|
virtual Account* createAccount( const QString& accountId = QString() ) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@@ -112,9 +112,9 @@ AccountManager::loadPluginFactories( const QStringList& paths )
|
|||||||
|
|
||||||
|
|
||||||
QString
|
QString
|
||||||
AccountManager::factoryFromId( const QString& pluginId ) const
|
AccountManager::factoryFromId( const QString& accountId ) const
|
||||||
{
|
{
|
||||||
return pluginId.split( "_" ).first();
|
return accountId.split( "_" ).first();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -143,21 +143,22 @@ AccountManager::loadPluginFactory( const QString& path )
|
|||||||
void
|
void
|
||||||
AccountManager::loadFromConfig()
|
AccountManager::loadFromConfig()
|
||||||
{
|
{
|
||||||
QStringList pluginIds = TomahawkSettings::instance()->accountPlugins();
|
QStringList accountIds = TomahawkSettings::instance()->accounts();
|
||||||
|
|
||||||
//FIXME: this is just for debugging
|
//FIXME: this is just for debugging
|
||||||
if ( pluginIds.isEmpty() )
|
if ( accountIds.isEmpty() )
|
||||||
{
|
{
|
||||||
Account* account = m_accountFactories[ "twitteraccount" ]->createAccount();
|
Account* account = m_accountFactories[ "twitteraccount" ]->createAccount();
|
||||||
addAccountPlugin( account );
|
addAccountPlugin( account );
|
||||||
|
TomahawkSettings::instance()->addAccount( account->accountId() );
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach( const QString& pluginId, pluginIds )
|
foreach( const QString& accountId, accountIds )
|
||||||
{
|
{
|
||||||
QString pluginFactory = factoryFromId( pluginId );
|
QString pluginFactory = factoryFromId( accountId );
|
||||||
if( m_accountFactories.contains( pluginFactory ) )
|
if( m_accountFactories.contains( pluginFactory ) )
|
||||||
{
|
{
|
||||||
Account* account = loadPlugin( pluginId );
|
Account* account = loadPlugin( accountId );
|
||||||
addAccountPlugin( account );
|
addAccountPlugin( account );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -166,13 +167,13 @@ AccountManager::loadFromConfig()
|
|||||||
|
|
||||||
|
|
||||||
Account*
|
Account*
|
||||||
AccountManager::loadPlugin( const QString& pluginId )
|
AccountManager::loadPlugin( const QString& accountId )
|
||||||
{
|
{
|
||||||
QString factoryName = factoryFromId( pluginId );
|
QString factoryName = factoryFromId( accountId );
|
||||||
|
|
||||||
Q_ASSERT( m_accountFactories.contains( factoryName ) );
|
Q_ASSERT( m_accountFactories.contains( factoryName ) );
|
||||||
|
|
||||||
Account* account = m_accountFactories[ factoryName ]->createAccount( pluginId );
|
Account* account = m_accountFactories[ factoryName ]->createAccount( accountId );
|
||||||
|
|
||||||
// caller responsible for calling pluginAdded() and hookupPlugin
|
// caller responsible for calling pluginAdded() and hookupPlugin
|
||||||
return account;
|
return account;
|
||||||
@@ -186,7 +187,7 @@ AccountManager::addAccountPlugin( Account* account )
|
|||||||
|
|
||||||
foreach( AccountType type, account->types() )
|
foreach( AccountType type, account->types() )
|
||||||
m_accountsByAccountType[ type ].append( account );
|
m_accountsByAccountType[ type ].append( account );
|
||||||
//TODO:
|
//TODO:?
|
||||||
//emit pluginAdded( account );
|
//emit pluginAdded( account );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -49,8 +49,8 @@ public:
|
|||||||
void loadFromConfig();
|
void loadFromConfig();
|
||||||
void loadPluginFactory( const QString &path );
|
void loadPluginFactory( const QString &path );
|
||||||
void addAccountPlugin( Account* account );
|
void addAccountPlugin( Account* account );
|
||||||
Account* loadPlugin( const QString &pluginId );
|
Account* loadPlugin( const QString &accountId );
|
||||||
QString factoryFromId( const QString& pluginId ) const;
|
QString factoryFromId( const QString& accountId ) const;
|
||||||
|
|
||||||
QList< Account* > getAccounts() { return m_accounts; };
|
QList< Account* > getAccounts() { return m_accounts; };
|
||||||
QList< Account* > getAccounts( Tomahawk::Accounts::AccountType type ) { return m_accountsByAccountType[ type ]; }
|
QList< Account* > getAccounts( Tomahawk::Accounts::AccountType type ) { return m_accountsByAccountType[ type ]; }
|
||||||
|
@@ -693,34 +693,34 @@ TomahawkSettings::removeSipPlugin( const QString& pluginId )
|
|||||||
|
|
||||||
|
|
||||||
QStringList
|
QStringList
|
||||||
TomahawkSettings::accountPlugins() const
|
TomahawkSettings::accounts() const
|
||||||
{
|
{
|
||||||
return value( "accounts/allplugins", QStringList() ).toStringList();
|
return value( "accounts/allaccounts", QStringList() ).toStringList();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
TomahawkSettings::setAccountPlugins( const QStringList& plugins )
|
TomahawkSettings::setAccounts( const QStringList& accountIds )
|
||||||
{
|
{
|
||||||
setValue( "accounts/allplugins", plugins );
|
setValue( "accounts/allaccounts", accountIds );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
TomahawkSettings::addAccountPlugin( const QString& pluginId )
|
TomahawkSettings::addAccount( const QString& accountId )
|
||||||
{
|
{
|
||||||
QStringList list = accountPlugins();
|
QStringList list = accounts();
|
||||||
list << pluginId;
|
list << accountId;
|
||||||
setAccountPlugins( list );
|
setAccounts( list );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
TomahawkSettings::removeAccountPlugin( const QString& pluginId )
|
TomahawkSettings::removeAccount( const QString& accountId )
|
||||||
{
|
{
|
||||||
QStringList list = accountPlugins();
|
QStringList list = accounts();
|
||||||
list.removeAll( pluginId );
|
list.removeAll( accountId );
|
||||||
setAccountPlugins( list );
|
setAccounts( list );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@@ -106,10 +106,10 @@ public:
|
|||||||
void addSipPlugin( const QString& pluginId, bool enable = true );
|
void addSipPlugin( const QString& pluginId, bool enable = true );
|
||||||
void removeSipPlugin( const QString& pluginId );
|
void removeSipPlugin( const QString& pluginId );
|
||||||
|
|
||||||
void setAccountPlugins( const QStringList& plugins );
|
void setAccounts( const QStringList& accountIds );
|
||||||
QStringList accountPlugins() const;
|
QStringList accounts() const;
|
||||||
void addAccountPlugin( const QString& pluginId );
|
void addAccount( const QString& accountId );
|
||||||
void removeAccountPlugin( const QString& pluginId );
|
void removeAccount( const QString& accountId );
|
||||||
|
|
||||||
|
|
||||||
void setBookmarkPlaylist( const QString& guid );
|
void setBookmarkPlaylist( const QString& guid );
|
||||||
|
@@ -33,7 +33,6 @@ ENDIF( WIN32 )
|
|||||||
|
|
||||||
target_link_libraries( tomahawk_siptwitter
|
target_link_libraries( tomahawk_siptwitter
|
||||||
tomahawk_oauth_twitter
|
tomahawk_oauth_twitter
|
||||||
tomahawk_account_twitter
|
|
||||||
${TOMAHAWK_LIBRARIES}
|
${TOMAHAWK_LIBRARIES}
|
||||||
${QTWEETLIB_LIBRARIES}
|
${QTWEETLIB_LIBRARIES}
|
||||||
${QT_LIBRARIES}
|
${QT_LIBRARIES}
|
||||||
|
@@ -510,6 +510,7 @@ TomahawkApp::initServent()
|
|||||||
void
|
void
|
||||||
TomahawkApp::initSIP()
|
TomahawkApp::initSIP()
|
||||||
{
|
{
|
||||||
|
tDebug() << Q_FUNC_INFO;
|
||||||
foreach ( Tomahawk::Accounts::Account* account, Tomahawk::Accounts::AccountManager::instance()->getAccounts() )
|
foreach ( Tomahawk::Accounts::Account* account, Tomahawk::Accounts::AccountManager::instance()->getAccounts() )
|
||||||
{
|
{
|
||||||
tDebug() << Q_FUNC_INFO << "testing account with name " << account->accountServiceName();
|
tDebug() << Q_FUNC_INFO << "testing account with name " << account->accountServiceName();
|
||||||
|
Reference in New Issue
Block a user