[tracking] Add Q_OBJECT, sanitize API

This commit is contained in:
Adriaan de Groot 2021-09-08 13:30:32 +02:00
parent 8d71e67a75
commit cefe3dd4ff
2 changed files with 77 additions and 66 deletions

View File

@ -19,11 +19,76 @@
#include <KMacroExpander> #include <KMacroExpander>
#include <QSemaphore>
#include <QTimer>
#include <chrono> #include <chrono>
// Namespace keeps all the actual jobs anonymous, the
// public API is the addJob() functions below the namespace.
namespace
{
/** @brief Install-tracking job (gets a URL)
*
* The install-tracking job (there is only one kind) does a GET
* on a configured URL with some additional information about
* the machine (if configured into the URL).
*
* No persistent tracking is done.
*/
class TrackingInstallJob : public Calamares::Job
{
Q_OBJECT
public:
TrackingInstallJob( const QString& url );
~TrackingInstallJob() override;
QString prettyName() const override;
QString prettyStatusMessage() const override;
Calamares::JobResult exec() override;
private:
const QString m_url;
};
/** @brief Tracking machines, update-manager style
*
* The machine has a machine-id, and this is sed(1)'ed into the
* update-manager configuration, to report the machine-id back
* to distro servers.
*/
class TrackingMachineUpdateManagerJob : public Calamares::Job
{
Q_OBJECT
public:
~TrackingMachineUpdateManagerJob() override;
QString prettyName() const override;
QString prettyStatusMessage() const override;
Calamares::JobResult exec() override;
};
/** @brief Turn on KUserFeedback in target system
*
* This writes suitable files for turning on KUserFeedback for the
* normal user configured in Calamares. The feedback can be reconfigured
* by the user through Plasma's user-feedback dialog.
*/
class TrackingKUserFeedbackJob : public Calamares::Job
{
Q_OBJECT
public:
TrackingKUserFeedbackJob( const QString& username, const QStringList& areas );
~TrackingKUserFeedbackJob() override;
QString prettyName() const override;
QString prettyStatusMessage() const override;
Calamares::JobResult exec() override;
private:
QString m_username;
QStringList m_areas;
};
TrackingInstallJob::TrackingInstallJob( const QString& url ) TrackingInstallJob::TrackingInstallJob( const QString& url )
: m_url( url ) : m_url( url )
{ {
@ -161,6 +226,8 @@ FeedbackLevel=16
return Calamares::JobResult::ok(); return Calamares::JobResult::ok();
} }
} // namespace
void void
addJob( Calamares::JobList& list, InstallTrackingConfig* config ) addJob( Calamares::JobList& list, InstallTrackingConfig* config )
{ {
@ -223,3 +290,7 @@ addJob( Calamares::JobList& list, UserTrackingConfig* config )
} }
} }
} }
#include "utils/moc-warnings.h"
#include "TrackingJobs.moc"

View File

@ -16,79 +16,19 @@ class InstallTrackingConfig;
class MachineTrackingConfig; class MachineTrackingConfig;
class UserTrackingConfig; class UserTrackingConfig;
class QSemaphore;
/** @section Tracking Jobs /** @section Tracking Jobs
* *
* The tracking jobs do the actual work of configuring tracking on the * The tracking jobs do the actual work of configuring tracking on the
* target machine. Tracking jobs may have *styles*, variations depending * target machine. Tracking jobs may have *styles*, variations depending
* on the distro or environment of the target system. At the root of * on the distro or environment of the target system. At the root of
* each family of tracking jobs (installation, machine, user) there is * each family of tracking jobs (installation, machine, user) there is
* a class with static method `addJob()` that takes the configuration * free function `addJob()` that takes the configuration
* information from the relevant Config sub-object and optionally * information from the relevant Config sub-object and optionally
* adds the right job (subclass!) to the list of jobs. * adds the right job (subclass!) to the list of jobs.
*/
/** @brief Install-tracking job (gets a URL)
* *
* The install-tracking job (there is only one kind) does a GET * There are no job-classes defined here because you need to be using the
* on a configured URL with some additional information about * `addJob()` interface instead.
* the machine (if configured into the URL).
*
* No persistent tracking is done.
*/ */
class TrackingInstallJob : public Calamares::Job
{
Q_OBJECT
public:
TrackingInstallJob( const QString& url );
~TrackingInstallJob() override;
QString prettyName() const override;
QString prettyStatusMessage() const override;
Calamares::JobResult exec() override;
private:
const QString m_url;
};
/** @brief Tracking machines, update-manager style
*
* The machine has a machine-id, and this is sed(1)'ed into the
* update-manager configuration, to report the machine-id back
* to distro servers.
*/
class TrackingMachineUpdateManagerJob : public Calamares::Job
{
Q_OBJECT
public:
~TrackingMachineUpdateManagerJob() override;
QString prettyName() const override;
QString prettyStatusMessage() const override;
Calamares::JobResult exec() override;
};
/** @brief Turn on KUserFeedback in target system
*
* This writes suitable files for turning on KUserFeedback for the
* normal user configured in Calamares. The feedback can be reconfigured
* by the user through Plasma's user-feedback dialog.
*/
class TrackingKUserFeedbackJob : public Calamares::Job
{
public:
TrackingKUserFeedbackJob( const QString& username, const QStringList& areas );
~TrackingKUserFeedbackJob() override;
QString prettyName() const override;
QString prettyStatusMessage() const override;
Calamares::JobResult exec() override;
private:
QString m_username;
QStringList m_areas;
};
void addJob( Calamares::JobList& list, InstallTrackingConfig* config ); void addJob( Calamares::JobList& list, InstallTrackingConfig* config );
void addJob( Calamares::JobList& list, MachineTrackingConfig* config ); void addJob( Calamares::JobList& list, MachineTrackingConfig* config );