view ui/taskscheduler.h @ 1298:9017c524e762

(issue123) Use document preview icon
author Andre Heinecke <andre.heinecke@intevation.de>
date Mon, 29 Sep 2014 16:26:01 +0200
parents 2a1aa9df8f11
children
line wrap: on
line source
/* Copyright (C) 2014 by Bundesamt für Sicherheit in der Informationstechnik
 * Software engineering by Intevation GmbH
 *
 * This file is Free Software under the GNU GPL (v>=2)
 * and comes with ABSOLUTELY NO WARRANTY!
 * See LICENSE.txt for details.
 */
#ifndef TASKSCHEDULER_H
#define TASKSCHEDULER_H

/**
 * @file taskscheduler.h
 * @brief Interface to the Task Scheduler API
 * 
 * Provides a Qt / C++ API to work with the windows task scheduler.
 */

#include <QString>
#include <QTime>
#ifndef INITGUID
#define INITGUID
#include <mstask.h>
#undef INITGUID
#endif

//struct ITaskScheduler;

/** @brief Interface to the Task Scheduler API
*
* Provides a Qt / C++ API to work with the windows task scheduler.
*/
class TaskScheduler
{
public:
    /** @brief Initializes the COM objects */
    TaskScheduler();

    /**@brief Uninitializes the COM objects */
    ~TaskScheduler();
    /** @brief create a task that is executed daily if the user is logged in.
     *
     * @param[in] executable Absolute path to the executable to run.
     * @param[in] args the arguements to pass to the executable.
     * @param[in] startTime the preferred time to start the task.
     *
     * @returns True on success, false on error */
    bool createDailyTask(const QString &executable, const QString &args, const QTime &startTime);

    /** @brief check if the Initialization was successful */
    bool isInitialized() {return mInitialized;}

private:
    bool mInitialized;
    ITaskScheduler *mTaskScheduler;
};

#endif // TASKSCHEDULER_H

http://wald.intevation.org/projects/trustbridge/