mirror of
https://github.com/tomahawk-player/tomahawk.git
synced 2025-08-09 15:47:38 +02:00
Separate AclRegistry into lib/impl parts. Removes GUI dependency in lib,
among other things.
This commit is contained in:
233
src/AclRegistryImpl.cpp
Normal file
233
src/AclRegistryImpl.cpp
Normal file
@@ -0,0 +1,233 @@
|
|||||||
|
/* === This file is part of Tomahawk Player - <http://tomahawk-player.org> ===
|
||||||
|
*
|
||||||
|
* Copyright 2010-2011, Christian Muehlhaeuser <muesli@tomahawk-player.org>
|
||||||
|
* Copyright 2010-2012, Jeff Mitchell <jeff@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 "AclRegistryImpl.h"
|
||||||
|
|
||||||
|
#include <QThread>
|
||||||
|
#include <QVariant>
|
||||||
|
|
||||||
|
#include "TomahawkSettings.h"
|
||||||
|
#include "TomahawkApp.h"
|
||||||
|
#include "Source.h"
|
||||||
|
|
||||||
|
#ifndef ENABLE_HEADLESS
|
||||||
|
#include "accounts/AccountManager.h"
|
||||||
|
#include "accounts/Account.h"
|
||||||
|
#include "jobview/AclJobItem.h"
|
||||||
|
#include "jobview/JobStatusView.h"
|
||||||
|
#include "jobview/JobStatusModel.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "utils/Logger.h"
|
||||||
|
|
||||||
|
|
||||||
|
AclRegistryImpl::AclRegistryImpl( QObject* parent )
|
||||||
|
: AclRegistry( parent )
|
||||||
|
, m_jobCount( 0 )
|
||||||
|
{
|
||||||
|
AclRegistry::setInstance( this );
|
||||||
|
load();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
AclRegistryImpl::~AclRegistryImpl()
|
||||||
|
{
|
||||||
|
save();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
AclRegistry::ACL
|
||||||
|
AclRegistryImpl::isAuthorizedUser( const QString& dbid, const QString &username, AclRegistry::ACL globalType, bool skipEmission )
|
||||||
|
{
|
||||||
|
tLog() << Q_FUNC_INFO;
|
||||||
|
if ( QThread::currentThread() != TOMAHAWK_APPLICATION::instance()->thread() )
|
||||||
|
{
|
||||||
|
if ( !skipEmission )
|
||||||
|
QMetaObject::invokeMethod( this, "isAuthorizedUser", Qt::QueuedConnection, Q_ARG( const QString&, dbid ), Q_ARG( const QString &, username ), Q_ARG( AclRegistry::ACL, globalType ), Q_ARG( bool, skipEmission ) );
|
||||||
|
return AclRegistry::NotFound;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef ENABLE_HEADLESS
|
||||||
|
if ( Tomahawk::Accounts::AccountManager::instance() )
|
||||||
|
{
|
||||||
|
tDebug( LOGVERBOSE ) << Q_FUNC_INFO << "Checking account friendly names against" << username;
|
||||||
|
Tomahawk::Accounts::AccountManager* accountManager = Tomahawk::Accounts::AccountManager::instance();
|
||||||
|
QList< Tomahawk::Accounts::Account* > accounts = accountManager->accounts();
|
||||||
|
foreach( Tomahawk::Accounts::Account* account, accounts )
|
||||||
|
{
|
||||||
|
if ( !( account->types() & Tomahawk::Accounts::SipType ) )
|
||||||
|
continue;
|
||||||
|
tDebug( LOGVERBOSE ) << Q_FUNC_INFO << "Checking against account friendly name" << account->accountFriendlyName();
|
||||||
|
if ( account->accountFriendlyName() == username )
|
||||||
|
{
|
||||||
|
if ( !skipEmission )
|
||||||
|
emit aclResult( dbid, username, AclRegistry::Stream );
|
||||||
|
return AclRegistry::Stream;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
bool found = false;
|
||||||
|
QMutableListIterator< AclRegistry::User > i( m_cache );
|
||||||
|
while ( i.hasNext() )
|
||||||
|
{
|
||||||
|
AclRegistry::User user = i.next();
|
||||||
|
foreach ( QString knowndbid, user.knownDbids )
|
||||||
|
{
|
||||||
|
if ( dbid == knowndbid )
|
||||||
|
{
|
||||||
|
if ( !user.knownAccountIds.contains( username ) )
|
||||||
|
user.knownAccountIds.append( username );
|
||||||
|
found = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ( QString knownaccountid, user.knownAccountIds )
|
||||||
|
{
|
||||||
|
if ( username == knownaccountid )
|
||||||
|
{
|
||||||
|
if ( !user.knownDbids.contains( dbid ) )
|
||||||
|
user.knownDbids.append( dbid );
|
||||||
|
found = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( found )
|
||||||
|
{
|
||||||
|
if ( !skipEmission )
|
||||||
|
emit aclResult( dbid, username, user.acl );
|
||||||
|
i.setValue( user );
|
||||||
|
return user.acl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( skipEmission )
|
||||||
|
return AclRegistry::NotFound;
|
||||||
|
|
||||||
|
// User was not found, create a new user entry
|
||||||
|
AclRegistry::User user;
|
||||||
|
user.knownDbids.append( dbid );
|
||||||
|
user.knownAccountIds.append( username );
|
||||||
|
if ( globalType != AclRegistry::NotFound )
|
||||||
|
user.acl = globalType;
|
||||||
|
#ifdef ENABLE_HEADLESS
|
||||||
|
user.acl = AclRegistry::Stream;
|
||||||
|
#else
|
||||||
|
if ( !TomahawkUtils::headless() )
|
||||||
|
{
|
||||||
|
getUserDecision( user, username );
|
||||||
|
return AclRegistry::NotFound;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
user.acl = AclRegistry::Stream;
|
||||||
|
#endif
|
||||||
|
m_cache.append( user );
|
||||||
|
save();
|
||||||
|
emit aclResult( dbid, username, user.acl );
|
||||||
|
return user.acl;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef ENABLE_HEADLESS
|
||||||
|
void
|
||||||
|
AclRegistryImpl::getUserDecision( AclRegistry::User user, const QString &username )
|
||||||
|
{
|
||||||
|
if ( TomahawkUtils::headless() )
|
||||||
|
return;
|
||||||
|
|
||||||
|
tLog() << Q_FUNC_INFO;
|
||||||
|
AclJobItem* job = new AclJobItem( user, username );
|
||||||
|
m_jobQueue.enqueue( job );
|
||||||
|
QTimer::singleShot( 0, this, SLOT( queueNextJob() ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
AclRegistryImpl::userDecision( AclRegistry::User user )
|
||||||
|
{
|
||||||
|
if ( TomahawkUtils::headless() )
|
||||||
|
return;
|
||||||
|
|
||||||
|
tLog() << Q_FUNC_INFO;
|
||||||
|
m_cache.append( user );
|
||||||
|
save();
|
||||||
|
emit aclResult( user.knownDbids.first(), user.knownAccountIds.first(), user.acl );
|
||||||
|
|
||||||
|
m_jobCount--;
|
||||||
|
if ( !m_jobQueue.isEmpty() )
|
||||||
|
QTimer::singleShot( 0, this, SLOT( queueNextJob() ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
AclRegistryImpl::queueNextJob()
|
||||||
|
{
|
||||||
|
if ( TomahawkUtils::headless() )
|
||||||
|
return;
|
||||||
|
|
||||||
|
if ( QThread::currentThread() != TOMAHAWK_APPLICATION::instance()->thread() )
|
||||||
|
{
|
||||||
|
QMetaObject::invokeMethod( this, "queueNextJob", Qt::QueuedConnection );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
tLog() << Q_FUNC_INFO << "jobCount = " << m_jobCount;
|
||||||
|
tLog() << Q_FUNC_INFO << "jobQueue size = " << m_jobQueue.length();
|
||||||
|
if ( m_jobCount != 0 )
|
||||||
|
return;
|
||||||
|
|
||||||
|
if ( !m_jobQueue.isEmpty() )
|
||||||
|
{
|
||||||
|
AclJobItem* job = m_jobQueue.dequeue();
|
||||||
|
AclRegistry::User user = job->user();
|
||||||
|
bool found = false;
|
||||||
|
foreach( QString dbid, user.knownDbids )
|
||||||
|
{
|
||||||
|
AclRegistry::ACL acl = isAuthorizedUser( dbid, job->username(), AclRegistry::NotFound, true );
|
||||||
|
if ( acl != AclRegistry::NotFound )
|
||||||
|
{
|
||||||
|
tLog() << Q_FUNC_INFO << "Found existing acl entry for = " << user.knownAccountIds.first();
|
||||||
|
found = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ( found )
|
||||||
|
{
|
||||||
|
tLog() << Q_FUNC_INFO << "deleting job, already have ACL for " << user.knownAccountIds.first();
|
||||||
|
delete job;
|
||||||
|
QTimer::singleShot( 0, this, SLOT( queueNextJob() ) );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
tLog() << Q_FUNC_INFO << "activating job for user" << user.knownAccountIds.first();
|
||||||
|
m_jobCount++;
|
||||||
|
JobStatusView::instance()->model()->addJob( job );
|
||||||
|
connect( job, SIGNAL( userDecision( AclRegistry::User ) ), this, SLOT( userDecision( AclRegistry::User ) ) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void
|
||||||
|
AclRegistryImpl::wipeEntries()
|
||||||
|
{
|
||||||
|
AclRegistry::wipeEntries();
|
||||||
|
save();
|
||||||
|
}
|
77
src/AclRegistryImpl.h
Normal file
77
src/AclRegistryImpl.h
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
/* === This file is part of Tomahawk Player - <http://tomahawk-player.org> ===
|
||||||
|
*
|
||||||
|
* Copyright 2010-2011, Christian Muehlhaeuser <muesli@tomahawk-player.org>
|
||||||
|
* Copyright 2010-2012, Jeff Mitchell <jeff@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/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef TOMAHAWK_ACLREGISTRYIMPL_H
|
||||||
|
#define TOMAHAWK_ACLREGISTRYIMPL_H
|
||||||
|
|
||||||
|
#include <QObject>
|
||||||
|
#include <QString>
|
||||||
|
#include <QHash>
|
||||||
|
#include <QTimer>
|
||||||
|
#include <QMutex>
|
||||||
|
#include <QVariant>
|
||||||
|
#include <QQueue>
|
||||||
|
#include <QStringList>
|
||||||
|
#include <QUuid>
|
||||||
|
|
||||||
|
#include "AclRegistry.h"
|
||||||
|
#include "HeadlessCheck.h"
|
||||||
|
#include "DllMacro.h"
|
||||||
|
|
||||||
|
class AclJobItem;
|
||||||
|
|
||||||
|
class AclRegistryImpl : public AclRegistry
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
AclRegistryImpl( QObject *parent = 0 );
|
||||||
|
virtual ~AclRegistryImpl();
|
||||||
|
|
||||||
|
signals:
|
||||||
|
void aclResult( QString nodeid, QString username, AclRegistry::ACL peerStatus );
|
||||||
|
|
||||||
|
public slots:
|
||||||
|
/**
|
||||||
|
* @brief Checks if peer is authorized; optionally, can authorize peer with given type if not found
|
||||||
|
*
|
||||||
|
* @param dbid DBID of peer
|
||||||
|
* @param globalType Global ACL to store if peer not found; if AclRegistry::NotFound, does not store the peer Defaults to AclRegistry::NotFound.
|
||||||
|
* @param username If not empty, will store the given username along with the new ACL value. Defaults to QString().
|
||||||
|
* @return AclRegistry::ACL
|
||||||
|
**/
|
||||||
|
virtual AclRegistry::ACL isAuthorizedUser( const QString &dbid, const QString &username, AclRegistry::ACL globalType = AclRegistry::NotFound, bool skipEmission = false );
|
||||||
|
|
||||||
|
#ifndef ENABLE_HEADLESS
|
||||||
|
void getUserDecision( AclRegistry::User user, const QString &username );
|
||||||
|
|
||||||
|
virtual void wipeEntries();
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void userDecision( AclRegistry::User user );
|
||||||
|
void queueNextJob();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
private:
|
||||||
|
QQueue< AclJobItem* > m_jobQueue;
|
||||||
|
int m_jobCount;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // TOMAHAWK_ACLREGISTRYIMPL_H
|
@@ -37,6 +37,7 @@ ENDIF()
|
|||||||
SET( tomahawkSources ${tomahawkSources}
|
SET( tomahawkSources ${tomahawkSources}
|
||||||
web/Api_v1.cpp
|
web/Api_v1.cpp
|
||||||
|
|
||||||
|
AclRegistryImpl.cpp
|
||||||
ShortcutHandler.cpp
|
ShortcutHandler.cpp
|
||||||
UbuntuUnityHack.cpp
|
UbuntuUnityHack.cpp
|
||||||
TomahawkApp.cpp
|
TomahawkApp.cpp
|
||||||
|
@@ -510,7 +510,7 @@ SettingsDialog::aclEntryClearButtonClicked()
|
|||||||
);
|
);
|
||||||
if ( button == QMessageBox::Ok )
|
if ( button == QMessageBox::Ok )
|
||||||
{
|
{
|
||||||
ACLRegistry::instance()->wipeEntries();
|
AclRegistry::instance()->wipeEntries();
|
||||||
ui->aclEntryClearButton->setEnabled( false );
|
ui->aclEntryClearButton->setEnabled( false );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -31,8 +31,9 @@
|
|||||||
#include <QtCore/QFileInfo>
|
#include <QtCore/QFileInfo>
|
||||||
#include <QTranslator>
|
#include <QTranslator>
|
||||||
|
|
||||||
#include "Artist.h"
|
#include "AclRegistryImpl.h"
|
||||||
#include "Album.h"
|
#include "Album.h"
|
||||||
|
#include "Artist.h"
|
||||||
#include "Collection.h"
|
#include "Collection.h"
|
||||||
#include "infosystem/InfoSystem.h"
|
#include "infosystem/InfoSystem.h"
|
||||||
#include "accounts/AccountManager.h"
|
#include "accounts/AccountManager.h"
|
||||||
@@ -204,6 +205,8 @@ TomahawkApp::init()
|
|||||||
|
|
||||||
TomahawkSettings* s = TomahawkSettings::instance();
|
TomahawkSettings* s = TomahawkSettings::instance();
|
||||||
|
|
||||||
|
AclRegistryImpl* ari = new AclRegistryImpl( this );
|
||||||
|
|
||||||
tDebug( LOGINFO ) << "Setting NAM.";
|
tDebug( LOGINFO ) << "Setting NAM.";
|
||||||
// Cause the creation of the nam, but don't need to address it directly, so prevent warning
|
// Cause the creation of the nam, but don't need to address it directly, so prevent warning
|
||||||
Q_UNUSED( TomahawkUtils::nam() );
|
Q_UNUSED( TomahawkUtils::nam() );
|
||||||
|
@@ -26,18 +26,10 @@
|
|||||||
#include "TomahawkApp.h"
|
#include "TomahawkApp.h"
|
||||||
#include "Source.h"
|
#include "Source.h"
|
||||||
|
|
||||||
#ifndef ENABLE_HEADLESS
|
|
||||||
#include "accounts/AccountManager.h"
|
|
||||||
#include "accounts/Account.h"
|
|
||||||
#include "jobview/AclJobItem.h"
|
|
||||||
#include "jobview/JobStatusView.h"
|
|
||||||
#include "jobview/JobStatusModel.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "utils/Logger.h"
|
#include "utils/Logger.h"
|
||||||
|
|
||||||
|
|
||||||
QDataStream& operator<<( QDataStream &out, const ACLRegistry::User &user )
|
QDataStream& operator<<( QDataStream &out, const AclRegistry::User &user )
|
||||||
{
|
{
|
||||||
out << ACLUSERVERSION;
|
out << ACLUSERVERSION;
|
||||||
out << user.uuid;
|
out << user.uuid;
|
||||||
@@ -52,7 +44,7 @@ QDataStream& operator<<( QDataStream &out, const ACLRegistry::User &user )
|
|||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
QDataStream& operator>>( QDataStream &in, ACLRegistry::User &user )
|
QDataStream& operator>>( QDataStream &in, AclRegistry::User &user )
|
||||||
{
|
{
|
||||||
int ver;
|
int ver;
|
||||||
in >> ver;
|
in >> ver;
|
||||||
@@ -78,231 +70,56 @@ QDataStream& operator>>( QDataStream &in, ACLRegistry::User &user )
|
|||||||
}
|
}
|
||||||
int aclIn;
|
int aclIn;
|
||||||
in >> aclIn;
|
in >> aclIn;
|
||||||
user.acl = (ACLRegistry::ACL)( aclIn );
|
user.acl = (AclRegistry::ACL)( aclIn );
|
||||||
}
|
}
|
||||||
return in;
|
return in;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
ACLRegistry* ACLRegistry::s_instance = 0;
|
AclRegistry* AclRegistry::s_instance = 0;
|
||||||
|
|
||||||
ACLRegistry*
|
AclRegistry*
|
||||||
ACLRegistry::instance()
|
AclRegistry::instance()
|
||||||
{
|
{
|
||||||
if( !s_instance )
|
|
||||||
new ACLRegistry();
|
|
||||||
return s_instance;
|
return s_instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
ACLRegistry::ACLRegistry( QObject* parent )
|
void
|
||||||
|
AclRegistry::setInstance( AclRegistry* instance )
|
||||||
|
{
|
||||||
|
s_instance = instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
AclRegistry::AclRegistry( QObject* parent )
|
||||||
: QObject( parent )
|
: QObject( parent )
|
||||||
, m_jobCount( 0 )
|
|
||||||
{
|
{
|
||||||
s_instance = this;
|
qRegisterMetaType< AclRegistry::ACL >( "AclRegistry::ACL" );
|
||||||
qRegisterMetaType< ACLRegistry::ACL >( "ACLRegistry::ACL" );
|
qRegisterMetaType< AclRegistry::User >( "AclRegistry::User" );
|
||||||
qRegisterMetaType< ACLRegistry::User >( "ACLRegistry::User" );
|
qRegisterMetaTypeStreamOperators< AclRegistry::User >( "AclRegistry::User" );
|
||||||
qRegisterMetaTypeStreamOperators< ACLRegistry::User >( "ACLRegistry::User" );
|
|
||||||
load();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
ACLRegistry::~ACLRegistry()
|
AclRegistry::~AclRegistry()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
ACLRegistry::ACL
|
|
||||||
ACLRegistry::isAuthorizedUser( const QString& dbid, const QString &username, ACLRegistry::ACL globalType, bool skipEmission )
|
|
||||||
{
|
|
||||||
tLog() << Q_FUNC_INFO;
|
|
||||||
if ( QThread::currentThread() != TOMAHAWK_APPLICATION::instance()->thread() )
|
|
||||||
{
|
|
||||||
if ( !skipEmission )
|
|
||||||
QMetaObject::invokeMethod( this, "isAuthorizedUser", Qt::QueuedConnection, Q_ARG( const QString&, dbid ), Q_ARG( const QString &, username ), Q_ARG( ACLRegistry::ACL, globalType ), Q_ARG( bool, skipEmission ) );
|
|
||||||
return ACLRegistry::NotFound;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef ENABLE_HEADLESS
|
|
||||||
if ( Tomahawk::Accounts::AccountManager::instance() )
|
|
||||||
{
|
|
||||||
tDebug( LOGVERBOSE ) << Q_FUNC_INFO << "Checking account friendly names against" << username;
|
|
||||||
Tomahawk::Accounts::AccountManager* accountManager = Tomahawk::Accounts::AccountManager::instance();
|
|
||||||
QList< Tomahawk::Accounts::Account* > accounts = accountManager->accounts();
|
|
||||||
foreach( Tomahawk::Accounts::Account* account, accounts )
|
|
||||||
{
|
|
||||||
if ( !( account->types() & Tomahawk::Accounts::SipType ) )
|
|
||||||
continue;
|
|
||||||
tDebug( LOGVERBOSE ) << Q_FUNC_INFO << "Checking against account friendly name" << account->accountFriendlyName();
|
|
||||||
if ( account->accountFriendlyName() == username )
|
|
||||||
{
|
|
||||||
if ( !skipEmission )
|
|
||||||
emit aclResult( dbid, username, ACLRegistry::Stream );
|
|
||||||
return ACLRegistry::Stream;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
bool found = false;
|
|
||||||
QMutableListIterator< ACLRegistry::User > i( m_cache );
|
|
||||||
while ( i.hasNext() )
|
|
||||||
{
|
|
||||||
ACLRegistry::User user = i.next();
|
|
||||||
foreach ( QString knowndbid, user.knownDbids )
|
|
||||||
{
|
|
||||||
if ( dbid == knowndbid )
|
|
||||||
{
|
|
||||||
if ( !user.knownAccountIds.contains( username ) )
|
|
||||||
user.knownAccountIds.append( username );
|
|
||||||
found = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ( QString knownaccountid, user.knownAccountIds )
|
|
||||||
{
|
|
||||||
if ( username == knownaccountid )
|
|
||||||
{
|
|
||||||
if ( !user.knownDbids.contains( dbid ) )
|
|
||||||
user.knownDbids.append( dbid );
|
|
||||||
found = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( found )
|
|
||||||
{
|
|
||||||
if ( !skipEmission )
|
|
||||||
emit aclResult( dbid, username, user.acl );
|
|
||||||
i.setValue( user );
|
|
||||||
return user.acl;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( skipEmission )
|
|
||||||
return ACLRegistry::NotFound;
|
|
||||||
|
|
||||||
// User was not found, create a new user entry
|
|
||||||
ACLRegistry::User user;
|
|
||||||
user.knownDbids.append( dbid );
|
|
||||||
user.knownAccountIds.append( username );
|
|
||||||
if ( globalType != ACLRegistry::NotFound )
|
|
||||||
user.acl = globalType;
|
|
||||||
#ifdef ENABLE_HEADLESS
|
|
||||||
user.acl = ACLRegistry::Stream;
|
|
||||||
#else
|
|
||||||
if ( !TomahawkUtils::headless() )
|
|
||||||
{
|
|
||||||
getUserDecision( user, username );
|
|
||||||
return ACLRegistry::NotFound;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
user.acl = ACLRegistry::Stream;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
m_cache.append( user );
|
|
||||||
save();
|
|
||||||
emit aclResult( dbid, username, user.acl );
|
|
||||||
return user.acl;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef ENABLE_HEADLESS
|
|
||||||
|
|
||||||
void
|
|
||||||
ACLRegistry::getUserDecision( ACLRegistry::User user, const QString &username )
|
|
||||||
{
|
|
||||||
if ( TomahawkUtils::headless() )
|
|
||||||
return;
|
|
||||||
|
|
||||||
tLog() << Q_FUNC_INFO;
|
|
||||||
AclJobItem* job = new AclJobItem( user, username );
|
|
||||||
m_jobQueue.enqueue( job );
|
|
||||||
QTimer::singleShot( 0, this, SLOT( queueNextJob() ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
ACLRegistry::userDecision( ACLRegistry::User user )
|
AclRegistry::load()
|
||||||
{
|
|
||||||
if ( TomahawkUtils::headless() )
|
|
||||||
return;
|
|
||||||
|
|
||||||
tLog() << Q_FUNC_INFO;
|
|
||||||
m_cache.append( user );
|
|
||||||
save();
|
|
||||||
emit aclResult( user.knownDbids.first(), user.knownAccountIds.first(), user.acl );
|
|
||||||
|
|
||||||
m_jobCount--;
|
|
||||||
if ( !m_jobQueue.isEmpty() )
|
|
||||||
QTimer::singleShot( 0, this, SLOT( queueNextJob() ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void
|
|
||||||
ACLRegistry::queueNextJob()
|
|
||||||
{
|
|
||||||
if ( TomahawkUtils::headless() )
|
|
||||||
return;
|
|
||||||
|
|
||||||
if ( QThread::currentThread() != TOMAHAWK_APPLICATION::instance()->thread() )
|
|
||||||
{
|
|
||||||
QMetaObject::invokeMethod( this, "queueNextJob", Qt::QueuedConnection );
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
tLog() << Q_FUNC_INFO << "jobCount = " << m_jobCount;
|
|
||||||
tLog() << Q_FUNC_INFO << "jobQueue size = " << m_jobQueue.length();
|
|
||||||
if ( m_jobCount != 0 )
|
|
||||||
return;
|
|
||||||
|
|
||||||
if ( !m_jobQueue.isEmpty() )
|
|
||||||
{
|
|
||||||
AclJobItem* job = m_jobQueue.dequeue();
|
|
||||||
ACLRegistry::User user = job->user();
|
|
||||||
bool found = false;
|
|
||||||
foreach( QString dbid, user.knownDbids )
|
|
||||||
{
|
|
||||||
ACLRegistry::ACL acl = isAuthorizedUser( dbid, job->username(), ACLRegistry::NotFound, true );
|
|
||||||
if ( acl != ACLRegistry::NotFound )
|
|
||||||
{
|
|
||||||
tLog() << Q_FUNC_INFO << "Found existing acl entry for = " << user.knownAccountIds.first();
|
|
||||||
found = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ( found )
|
|
||||||
{
|
|
||||||
tLog() << Q_FUNC_INFO << "deleting job, already have ACL for " << user.knownAccountIds.first();
|
|
||||||
delete job;
|
|
||||||
QTimer::singleShot( 0, this, SLOT( queueNextJob() ) );
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
tLog() << Q_FUNC_INFO << "activating job for user" << user.knownAccountIds.first();
|
|
||||||
m_jobCount++;
|
|
||||||
JobStatusView::instance()->model()->addJob( job );
|
|
||||||
connect( job, SIGNAL( userDecision( ACLRegistry::User ) ), this, SLOT( userDecision( ACLRegistry::User ) ) );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
void
|
|
||||||
ACLRegistry::load()
|
|
||||||
{
|
{
|
||||||
tLog() << Q_FUNC_INFO;
|
tLog() << Q_FUNC_INFO;
|
||||||
QVariantList entryList = TomahawkSettings::instance()->aclEntries();
|
QVariantList entryList = TomahawkSettings::instance()->aclEntries();
|
||||||
foreach ( QVariant entry, entryList )
|
foreach ( QVariant entry, entryList )
|
||||||
{
|
{
|
||||||
if ( !entry.isValid() || !entry.canConvert< ACLRegistry::User >() )
|
if ( !entry.isValid() || !entry.canConvert< AclRegistry::User >() )
|
||||||
{
|
{
|
||||||
tLog() << Q_FUNC_INFO << "entry is invalid";
|
tLog() << Q_FUNC_INFO << "entry is invalid";
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
tLog() << Q_FUNC_INFO << "loading entry";
|
tLog() << Q_FUNC_INFO << "loading entry";
|
||||||
ACLRegistry::User entryUser = entry.value< ACLRegistry::User >();
|
AclRegistry::User entryUser = entry.value< AclRegistry::User >();
|
||||||
if ( entryUser.knownAccountIds.empty() || entryUser.knownDbids.empty() )
|
if ( entryUser.knownAccountIds.empty() || entryUser.knownDbids.empty() )
|
||||||
{
|
{
|
||||||
tLog() << Q_FUNC_INFO << "user known account/dbids is empty";
|
tLog() << Q_FUNC_INFO << "user known account/dbids is empty";
|
||||||
@@ -314,14 +131,14 @@ ACLRegistry::load()
|
|||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
ACLRegistry::save()
|
AclRegistry::save()
|
||||||
{
|
{
|
||||||
tLog() << Q_FUNC_INFO;
|
tLog() << Q_FUNC_INFO;
|
||||||
QVariantList entryList;
|
QVariantList entryList;
|
||||||
foreach ( ACLRegistry::User user, m_cache )
|
foreach ( AclRegistry::User user, m_cache )
|
||||||
{
|
{
|
||||||
tLog() << Q_FUNC_INFO << "user is " << user.uuid << " with known name " << user.knownAccountIds.first();
|
tLog() << Q_FUNC_INFO << "user is " << user.uuid << " with known name " << user.knownAccountIds.first();
|
||||||
QVariant val = QVariant::fromValue< ACLRegistry::User >( user );
|
QVariant val = QVariant::fromValue< AclRegistry::User >( user );
|
||||||
if ( val.isValid() )
|
if ( val.isValid() )
|
||||||
entryList.append( val );
|
entryList.append( val );
|
||||||
}
|
}
|
||||||
@@ -330,9 +147,9 @@ ACLRegistry::save()
|
|||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
ACLRegistry::wipeEntries()
|
AclRegistry::wipeEntries()
|
||||||
{
|
{
|
||||||
tLog() << Q_FUNC_INFO;
|
tLog() << Q_FUNC_INFO;
|
||||||
m_cache.clear();
|
m_cache.clear();
|
||||||
save();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -35,15 +35,14 @@
|
|||||||
|
|
||||||
#define ACLUSERVERSION 1
|
#define ACLUSERVERSION 1
|
||||||
|
|
||||||
class AclJobItem;
|
class DLLEXPORT AclRegistry : public QObject
|
||||||
|
|
||||||
class DLLEXPORT ACLRegistry : public QObject
|
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
static ACLRegistry* instance();
|
static AclRegistry* instance();
|
||||||
|
static void setInstance( AclRegistry* instance );
|
||||||
|
|
||||||
enum ACL {
|
enum ACL {
|
||||||
NotFound = 0,
|
NotFound = 0,
|
||||||
@@ -57,20 +56,20 @@ public:
|
|||||||
QString friendlyName;
|
QString friendlyName;
|
||||||
QStringList knownDbids;
|
QStringList knownDbids;
|
||||||
QStringList knownAccountIds;
|
QStringList knownAccountIds;
|
||||||
ACLRegistry::ACL acl;
|
AclRegistry::ACL acl;
|
||||||
|
|
||||||
User()
|
User()
|
||||||
: uuid( QUuid::createUuid().toString() )
|
: uuid( QUuid::createUuid().toString() )
|
||||||
, friendlyName()
|
, friendlyName()
|
||||||
, knownDbids()
|
, knownDbids()
|
||||||
, knownAccountIds()
|
, knownAccountIds()
|
||||||
, acl( ACLRegistry::NotFound )
|
, acl( AclRegistry::NotFound )
|
||||||
{}
|
{}
|
||||||
|
|
||||||
~User()
|
~User()
|
||||||
{}
|
{}
|
||||||
|
|
||||||
User( QString p_uuid, QString p_friendlyName, QStringList p_knownDbids, QStringList p_knownAccountIds, ACLRegistry::ACL p_acl )
|
User( QString p_uuid, QString p_friendlyName, QStringList p_knownDbids, QStringList p_knownAccountIds, AclRegistry::ACL p_acl )
|
||||||
: uuid( p_uuid )
|
: uuid( p_uuid )
|
||||||
, friendlyName( p_friendlyName )
|
, friendlyName( p_friendlyName )
|
||||||
, knownDbids( p_knownDbids )
|
, knownDbids( p_knownDbids )
|
||||||
@@ -87,51 +86,39 @@ public:
|
|||||||
{}
|
{}
|
||||||
};
|
};
|
||||||
|
|
||||||
ACLRegistry( QObject *parent = 0 );
|
AclRegistry( QObject *parent = 0 );
|
||||||
~ACLRegistry();
|
virtual ~AclRegistry();
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void aclResult( QString nodeid, QString username, ACLRegistry::ACL peerStatus );
|
void aclResult( QString nodeid, QString username, AclRegistry::ACL peerStatus );
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
/**
|
/**
|
||||||
* @brief Checks if peer is authorized; optionally, can authorize peer with given type if not found
|
* @brief Checks if peer is authorized; optionally, can authorize peer with given type if not found
|
||||||
*
|
*
|
||||||
* @param dbid DBID of peer
|
* @param dbid DBID of peer
|
||||||
* @param globalType Global ACL to store if peer not found; if ACLRegistry::NotFound, does not store the peer Defaults to ACLRegistry::NotFound.
|
* @param globalType Global ACL to store if peer not found; if AclRegistry::NotFound, does not store the peer Defaults to AclRegistry::NotFound.
|
||||||
* @param username If not empty, will store the given username along with the new ACL value. Defaults to QString().
|
* @param username If not empty, will store the given username along with the new ACL value. Defaults to QString().
|
||||||
* @return ACLRegistry::ACL
|
* @return AclRegistry::ACL
|
||||||
**/
|
**/
|
||||||
ACLRegistry::ACL isAuthorizedUser( const QString &dbid, const QString &username, ACLRegistry::ACL globalType = ACLRegistry::NotFound, bool skipEmission = false );
|
virtual AclRegistry::ACL isAuthorizedUser( const QString &dbid, const QString &username, AclRegistry::ACL globalType = AclRegistry::NotFound, bool skipEmission = false ) = 0;
|
||||||
void wipeEntries();
|
virtual void wipeEntries();
|
||||||
|
|
||||||
#ifndef ENABLE_HEADLESS
|
|
||||||
void getUserDecision( ACLRegistry::User user, const QString &username );
|
|
||||||
|
|
||||||
private slots:
|
|
||||||
void userDecision( ACLRegistry::User user );
|
|
||||||
void queueNextJob();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
private:
|
protected:
|
||||||
/**
|
/**
|
||||||
* @brief Saves the cache.
|
* @brief Saves the cache.
|
||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
**/
|
**/
|
||||||
void save();
|
virtual void save();
|
||||||
|
virtual void load();
|
||||||
|
|
||||||
void load();
|
QList< AclRegistry::User > m_cache;
|
||||||
|
|
||||||
QList< ACLRegistry::User > m_cache;
|
static AclRegistry* s_instance;
|
||||||
|
|
||||||
static ACLRegistry* s_instance;
|
|
||||||
|
|
||||||
QQueue< AclJobItem* > m_jobQueue;
|
|
||||||
int m_jobCount;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_DECLARE_METATYPE( ACLRegistry::ACL );
|
Q_DECLARE_METATYPE( AclRegistry::ACL );
|
||||||
Q_DECLARE_METATYPE( ACLRegistry::User );
|
Q_DECLARE_METATYPE( AclRegistry::User );
|
||||||
|
|
||||||
#endif // TOMAHAWK_ACLREGISTRY_H
|
#endif // TOMAHAWK_ACLREGISTRY_H
|
||||||
|
@@ -148,9 +148,9 @@ AclJobDelegate::editorEvent( QEvent* event, QAbstractItemModel* model, const QSt
|
|||||||
{
|
{
|
||||||
QMouseEvent* me = static_cast< QMouseEvent* >( event );
|
QMouseEvent* me = static_cast< QMouseEvent* >( event );
|
||||||
if ( m_savedAcceptRect.contains( me->pos() ) )
|
if ( m_savedAcceptRect.contains( me->pos() ) )
|
||||||
emit aclResult( ACLRegistry::Stream );
|
emit aclResult( AclRegistry::Stream );
|
||||||
else if ( m_savedDenyRect.contains( me->pos() ) )
|
else if ( m_savedDenyRect.contains( me->pos() ) )
|
||||||
emit aclResult( ACLRegistry::Deny );
|
emit aclResult( AclRegistry::Deny );
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -159,7 +159,7 @@ AclJobDelegate::editorEvent( QEvent* event, QAbstractItemModel* model, const QSt
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
AclJobItem::AclJobItem( ACLRegistry::User user, const QString &username )
|
AclJobItem::AclJobItem( AclRegistry::User user, const QString &username )
|
||||||
: m_delegate( 0 )
|
: m_delegate( 0 )
|
||||||
, m_user( user )
|
, m_user( user )
|
||||||
, m_username( username )
|
, m_username( username )
|
||||||
@@ -197,7 +197,7 @@ AclJobDelegate::emitSizeHintChanged( const QModelIndex& index )
|
|||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
AclJobItem::aclResult( ACLRegistry::ACL result )
|
AclJobItem::aclResult( AclRegistry::ACL result )
|
||||||
{
|
{
|
||||||
tLog() << Q_FUNC_INFO;
|
tLog() << Q_FUNC_INFO;
|
||||||
m_user.acl = result;
|
m_user.acl = result;
|
||||||
|
@@ -20,14 +20,15 @@
|
|||||||
#ifndef ACLJOBITEM_H
|
#ifndef ACLJOBITEM_H
|
||||||
#define ACLJOBITEM_H
|
#define ACLJOBITEM_H
|
||||||
|
|
||||||
#include <jobview/JobStatusItem.h>
|
|
||||||
#include "AclRegistry.h"
|
#include "AclRegistry.h"
|
||||||
|
#include "DllMacro.h"
|
||||||
|
#include "jobview/JobStatusItem.h"
|
||||||
|
|
||||||
#include <QStyledItemDelegate>
|
#include <QStyledItemDelegate>
|
||||||
|
|
||||||
class QListView;
|
class QListView;
|
||||||
|
|
||||||
class AclJobDelegate : public QStyledItemDelegate
|
class DLLEXPORT AclJobDelegate : public QStyledItemDelegate
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
@@ -39,53 +40,53 @@ public:
|
|||||||
virtual QSize sizeHint( const QStyleOptionViewItem& option, const QModelIndex& index ) const;
|
virtual QSize sizeHint( const QStyleOptionViewItem& option, const QModelIndex& index ) const;
|
||||||
|
|
||||||
virtual void emitSizeHintChanged( const QModelIndex &index );
|
virtual void emitSizeHintChanged( const QModelIndex &index );
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void update( const QModelIndex& idx );
|
void update( const QModelIndex& idx );
|
||||||
void aclResult( ACLRegistry::ACL result );
|
void aclResult( AclRegistry::ACL result );
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual bool editorEvent( QEvent* event, QAbstractItemModel* model, const QStyleOptionViewItem& option, const QModelIndex& index );
|
virtual bool editorEvent( QEvent* event, QAbstractItemModel* model, const QStyleOptionViewItem& option, const QModelIndex& index );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void drawRoundedButton( QPainter* painter, const QRect& btnRect, bool red = false ) const;
|
void drawRoundedButton( QPainter* painter, const QRect& btnRect, bool red = false ) const;
|
||||||
|
|
||||||
QPoint m_savedHoverPos;
|
QPoint m_savedHoverPos;
|
||||||
mutable QRect m_savedAcceptRect;
|
mutable QRect m_savedAcceptRect;
|
||||||
mutable QRect m_savedDenyRect;
|
mutable QRect m_savedDenyRect;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
class AclJobItem : public JobStatusItem
|
class DLLEXPORT AclJobItem : public JobStatusItem
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
explicit AclJobItem( ACLRegistry::User user, const QString &username );
|
explicit AclJobItem( AclRegistry::User user, const QString &username );
|
||||||
virtual ~AclJobItem();
|
virtual ~AclJobItem();
|
||||||
|
|
||||||
virtual QString rightColumnText() const { return QString(); }
|
virtual QString rightColumnText() const { return QString(); }
|
||||||
virtual QString mainText() const { return QString(); }
|
virtual QString mainText() const { return QString(); }
|
||||||
virtual QPixmap icon() const { return QPixmap(); }
|
virtual QPixmap icon() const { return QPixmap(); }
|
||||||
virtual QString type() const { return "acljob"; }
|
virtual QString type() const { return "acljob"; }
|
||||||
|
|
||||||
virtual int concurrentJobLimit() const { return 3; }
|
virtual int concurrentJobLimit() const { return 3; }
|
||||||
|
|
||||||
virtual bool hasCustomDelegate() const { return true; }
|
virtual bool hasCustomDelegate() const { return true; }
|
||||||
virtual void createDelegate( QObject* parent = 0 );
|
virtual void createDelegate( QObject* parent = 0 );
|
||||||
virtual QStyledItemDelegate* customDelegate() const { return m_delegate; }
|
virtual QStyledItemDelegate* customDelegate() const { return m_delegate; }
|
||||||
|
|
||||||
virtual ACLRegistry::User user() const { return m_user; }
|
virtual AclRegistry::User user() const { return m_user; }
|
||||||
virtual const QString& username() const { return m_username; }
|
virtual const QString& username() const { return m_username; }
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void userDecision( ACLRegistry::User user );
|
void userDecision( AclRegistry::User user );
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void aclResult( ACLRegistry::ACL result );
|
void aclResult( AclRegistry::ACL result );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QStyledItemDelegate* m_delegate;
|
QStyledItemDelegate* m_delegate;
|
||||||
ACLRegistry::User m_user;
|
AclRegistry::User m_user;
|
||||||
const QString m_username;
|
const QString m_username;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -113,7 +113,7 @@ JobStatusView::customDelegateJobInserted( int row, JobStatusItem* item )
|
|||||||
{
|
{
|
||||||
tLog() << Q_FUNC_INFO << "delegate found";
|
tLog() << Q_FUNC_INFO << "delegate found";
|
||||||
connect( delegate, SIGNAL( update( const QModelIndex& ) ), m_view, SLOT( update( const QModelIndex & ) ) );
|
connect( delegate, SIGNAL( update( const QModelIndex& ) ), m_view, SLOT( update( const QModelIndex & ) ) );
|
||||||
connect( delegate, SIGNAL( aclResult( ACLRegistry::ACL ) ), item, SLOT( aclResult( ACLRegistry::ACL ) ) );
|
connect( delegate, SIGNAL( aclResult( AclRegistry::ACL ) ), item, SLOT( aclResult( AclRegistry::ACL ) ) );
|
||||||
delegate->emitSizeHintChanged( m_model->index( row ) );
|
delegate->emitSizeHintChanged( m_model->index( row ) );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@@ -208,13 +208,13 @@ Connection::checkACL()
|
|||||||
QString nodeid = property( "nodeid" ).toString();
|
QString nodeid = property( "nodeid" ).toString();
|
||||||
QString bareName = name().contains( '/' ) ? name().left( name().indexOf( "/" ) ) : name();
|
QString bareName = name().contains( '/' ) ? name().left( name().indexOf( "/" ) ) : name();
|
||||||
tDebug( LOGVERBOSE ) << Q_FUNC_INFO << "Checking ACL for" << name();
|
tDebug( LOGVERBOSE ) << Q_FUNC_INFO << "Checking ACL for" << name();
|
||||||
connect( ACLRegistry::instance(), SIGNAL( aclResult( QString, QString, ACLRegistry::ACL ) ), this, SLOT( checkACLResult( QString, QString, ACLRegistry::ACL ) ), Qt::QueuedConnection );
|
connect( AclRegistry::instance(), SIGNAL( aclResult( QString, QString, AclRegistry::ACL ) ), this, SLOT( checkACLResult( QString, QString, AclRegistry::ACL ) ), Qt::QueuedConnection );
|
||||||
QMetaObject::invokeMethod( ACLRegistry::instance(), "isAuthorizedUser", Qt::QueuedConnection, Q_ARG( QString, nodeid ), Q_ARG( QString, bareName ), Q_ARG( ACLRegistry::ACL, ACLRegistry::NotFound ) );
|
QMetaObject::invokeMethod( AclRegistry::instance(), "isAuthorizedUser", Qt::QueuedConnection, Q_ARG( QString, nodeid ), Q_ARG( QString, bareName ), Q_ARG( AclRegistry::ACL, AclRegistry::NotFound ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
Connection::checkACLResult( const QString &nodeid, const QString &username, ACLRegistry::ACL peerStatus )
|
Connection::checkACLResult( const QString &nodeid, const QString &username, AclRegistry::ACL peerStatus )
|
||||||
{
|
{
|
||||||
QString bareName = name().contains( '/' ) ? name().left( name().indexOf( "/" ) ) : name();
|
QString bareName = name().contains( '/' ) ? name().left( name().indexOf( "/" ) ) : name();
|
||||||
if ( nodeid != property( "nodeid" ).toString() || username != bareName )
|
if ( nodeid != property( "nodeid" ).toString() || username != bareName )
|
||||||
@@ -223,9 +223,9 @@ Connection::checkACLResult( const QString &nodeid, const QString &username, ACLR
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
disconnect( ACLRegistry::instance(), SIGNAL( aclResult( QString, QString, ACLRegistry::ACL ) ) );
|
disconnect( AclRegistry::instance(), SIGNAL( aclResult( QString, QString, AclRegistry::ACL ) ) );
|
||||||
tDebug( LOGVERBOSE ) << Q_FUNC_INFO << "ACL status is" << peerStatus;
|
tDebug( LOGVERBOSE ) << Q_FUNC_INFO << "ACL status is" << peerStatus;
|
||||||
if ( peerStatus == ACLRegistry::Stream )
|
if ( peerStatus == AclRegistry::Stream )
|
||||||
{
|
{
|
||||||
QTimer::singleShot( 0, this, SLOT( doSetup() ) );
|
QTimer::singleShot( 0, this, SLOT( doSetup() ) );
|
||||||
return;
|
return;
|
||||||
|
@@ -120,7 +120,7 @@ private slots:
|
|||||||
void readyRead();
|
void readyRead();
|
||||||
void doSetup();
|
void doSetup();
|
||||||
void checkACL();
|
void checkACL();
|
||||||
void checkACLResult( const QString &nodeid, const QString &username, ACLRegistry::ACL peerStatus );
|
void checkACLResult( const QString &nodeid, const QString &username, AclRegistry::ACL peerStatus );
|
||||||
void authCheckTimeout();
|
void authCheckTimeout();
|
||||||
void bytesWritten( qint64 );
|
void bytesWritten( qint64 );
|
||||||
void calcStats();
|
void calcStats();
|
||||||
|
@@ -65,7 +65,7 @@ Servent::Servent( QObject* parent )
|
|||||||
s_instance = this;
|
s_instance = this;
|
||||||
|
|
||||||
m_lanHack = qApp->arguments().contains( "--lanhack" );
|
m_lanHack = qApp->arguments().contains( "--lanhack" );
|
||||||
ACLRegistry::instance();
|
AclRegistry::instance();
|
||||||
setProxy( QNetworkProxy::NoProxy );
|
setProxy( QNetworkProxy::NoProxy );
|
||||||
|
|
||||||
{
|
{
|
||||||
@@ -90,7 +90,7 @@ Servent::Servent( QObject* parent )
|
|||||||
|
|
||||||
Servent::~Servent()
|
Servent::~Servent()
|
||||||
{
|
{
|
||||||
delete ACLRegistry::instance();
|
delete AclRegistry::instance();
|
||||||
delete m_portfwd;
|
delete m_portfwd;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user