26#include <QStandardPaths>
37 return basePath + QDir::separator() +
"profiles";
42 const QString profileName = defaultProfile.isEmpty() ?
defaultProfileName() : defaultProfile;
58 mRootProfilePath = rootProfileLocation;
63 mSettings.reset(
new QSettings( settingsFile(), QSettings::IniFormat ) );
68 mWatchProfiles = enabled;
69 if ( mWatchProfiles && !mRootProfilePath.isEmpty() && QDir( mRootProfilePath ).exists() )
71 mWatcher.reset(
new QFileSystemWatcher() );
72 mWatcher->addPath( mRootProfilePath );
73 connect( mWatcher.get(), &QFileSystemWatcher::directoryChanged,
this, [
this]
75 emit profilesChanged();
86 return static_cast< bool >( mWatcher.get() );
91 return !mRootProfilePath.isEmpty();
96 const QString defaultName = QStringLiteral(
"default" );
102 if ( !mSettings->contains( QStringLiteral(
"/core/defaultProfile" ) ) || globalSettings.
value( QStringLiteral(
"overrideLocalProfile" ),
false,
QgsSettings::Core ).toBool() )
104 return globalSettings.
value( QStringLiteral(
"defaultProfile" ), defaultName,
QgsSettings::Core ).toString();
106 return mSettings->value( QStringLiteral(
"/core/defaultProfile" ), defaultName ).toString();
111 mSettings->setValue( QStringLiteral(
"/core/defaultProfile" ), name );
122 return mSettings->value( QStringLiteral(
"/core/lastProfile" ), QString() ).toString();
127 mSettings->setValue( QStringLiteral(
"/core/lastProfile" ),
userProfile()->name() );
138 mSettings->setValue( QStringLiteral(
"/core/selectionPolicy" ),
static_cast< int >( policy ) );
144 return QDir( mRootProfilePath ).entryList( QDir::Dirs | QDir::NoDotAndDotDot );
154 const QString profilePath = mRootProfilePath + QDir::separator() + name;
164 const QDir folder( mRootProfilePath + QDir::separator() + name );
165 if ( !folder.exists() )
167 if ( !QDir().mkpath( folder.absolutePath() ) )
169 error.
append( tr(
"Cannot write '%1'" ).arg( folder.absolutePath() ) );
174 QFile qgisPrivateDbFile( folder.absolutePath() + QDir::separator() +
"qgis.db" );
177 if ( !qgisPrivateDbFile.exists() )
181 QFile masterFile( qgisMasterDbFileName );
184 masterFile.copy( qgisPrivateDbFile.fileName() );
188 const QFile::Permissions perms = QFile( qgisPrivateDbFile.fileName() ).permissions();
189 if ( !( perms & QFile::WriteOwner ) )
191 if ( !qgisPrivateDbFile.setPermissions( perms | QFile::WriteOwner ) )
193 error.
append( tr(
"Can not make '%1' user writable" ).arg( qgisPrivateDbFile.fileName() ) );
209 QDir folder( mRootProfilePath + QDir::separator() + name );
212 const bool deleted = folder.removeRecursively();
215 error.
append( ( tr(
"Unable to fully delete user profile folder" ) ) );
224QString QgsUserProfileManager::settingsFile()
const
226 return mRootProfilePath + QDir::separator() +
"profiles.ini";
231 return mSettings.get();
236 return mUserProfile.get();
241#if QT_CONFIG(process)
242 const QString path = QDir::toNativeSeparators( QCoreApplication::applicationFilePath() );
243 QStringList arguments;
244 arguments << QCoreApplication::arguments();
248 arguments.removeFirst();
249 arguments << QStringLiteral(
"--profile" ) << name;
250 QgsDebugMsgLevel( QStringLiteral(
"Starting instance from %1 with %2" ).arg( path ).arg( arguments.join(
" " ) ), 2 );
251 QProcess::startDetached( path, arguments, QDir::toNativeSeparators( QCoreApplication::applicationDirPath() ) );
254 Q_ASSERT(
"Starting the user profile is not supported on the platform" );
260 if ( ! mUserProfile.get() )
UserProfileSelectionPolicy
User profile selection policy.
static QString qgisMasterDatabaseFilePath()
Returns the path to the master qgis.db file.
A container for error messages.
bool isEmpty() const
Test if any error is set.
void append(const QString &message, const QString &tag)
Append new error message.
This class is a composition of two QSettings instances:
QVariant value(const QString &key, const QVariant &defaultValue=QVariant(), Section section=NoSection) const
Returns the value for setting key.
QgsUserProfile * getProfile(const QString &defaultProfile="default", bool createNew=true, bool initSettings=true)
Returns the profile from the given root profile location.
void setRootLocation(const QString &rootProfileLocation)
Set the root profile location for the profile manager.
QgsError createUserProfile(const QString &name)
Create a user profile given by the name.
void setActiveUserProfile(const QString &profile)
Sets the active profile in the manager.
bool profileExists(const QString &name) const
Check if a profile exists.
QgsUserProfile * userProfile()
The currently active user profile.
void setDefaultProfileName(const QString &name)
Sets the default profile name.
QString rootLocation()
Returns the path to the root profiles location.
void setDefaultFromActive()
Set the default profile name from the current active profile.
QStringList allProfiles() const
Returns a list of all found profile names.
bool rootLocationIsSet() const
Check if the root location has been set for the manager.
QgsError deleteProfile(const QString &name)
Deletes a profile from the root profiles folder.
QSettings * settings()
Returns the settings for the profile manager.
static QString resolveProfilesFolder(const QString &basePath=QString())
Resolves the profiles folder for the given path.
void setUserProfileSelectionPolicy(Qgis::UserProfileSelectionPolicy policy)
Sets the user profile selection policy.
void setNewProfileNotificationEnabled(bool enabled)
Sets whether the manager should watch for the creation of new user profiles and emit the profilesChan...
QString defaultProfileName() const
Returns the name of the default profile that has been set in .default.
QgsUserProfileManager(const QString &rootLocation=QString(), QObject *parent=nullptr)
User profile manager used to manage user profiles for the instance of QGIS.
Qgis::UserProfileSelectionPolicy userProfileSelectionPolicy() const
Returns the user profile selection policy.
void profilesChanged()
Emitted when the list of profiles is changed.
QString lastProfileName() const
Returns the name of the most recently closed profile.
void updateLastProfileName()
Updates the last closed profile name.
QgsUserProfile * profileForName(const QString &name) const
Returns the profile found for a given name.
void loadUserProfile(const QString &name)
Starts a new instance of QGIS for the given profile.
bool isNewProfileNotificationEnabled() const
Returns whether the manager is watching for the creation of new user profiles and emitting the profil...
User profile contains information about the user profile folders on the machine.
void initSettings() const
Init the settings from the user folder.
#define QgsDebugMsgLevel(str, level)