129 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#pragma once
 | 
						|
/*
 | 
						|
 * Copyright (c) 2016 MariaDB Corporation Ab
 | 
						|
 *
 | 
						|
 * Use of this software is governed by the Business Source License included
 | 
						|
 * in the LICENSE.TXT file and at www.mariadb.com/bsl11.
 | 
						|
 *
 | 
						|
 * Change Date: 2020-01-01
 | 
						|
 *
 | 
						|
 * On the date above, in accordance with the Business Source License, use
 | 
						|
 * of this software will be governed by version 2 or later of the General
 | 
						|
 * Public License.
 | 
						|
 */
 | 
						|
 | 
						|
/**
 | 
						|
 * @file housekeeper.h A mechanism to have task run periodically
 | 
						|
 */
 | 
						|
 | 
						|
#include <maxscale/cdefs.h>
 | 
						|
#include <time.h>
 | 
						|
#include <maxscale/dcb.h>
 | 
						|
#include <maxscale/hk_heartbeat.h>
 | 
						|
 | 
						|
MXS_BEGIN_DECLS
 | 
						|
 | 
						|
typedef enum
 | 
						|
{
 | 
						|
    HK_REPEATED = 1,
 | 
						|
    HK_ONESHOT
 | 
						|
} HKTASK_TYPE;
 | 
						|
 | 
						|
/**
 | 
						|
 * The housekeeper task list
 | 
						|
 */
 | 
						|
typedef struct hktask
 | 
						|
{
 | 
						|
    char *name;               /*< A simple task name */
 | 
						|
    void (*task)(void *data); /*< The task to call */
 | 
						|
    void *data;               /*< Data to pass the task */
 | 
						|
    int frequency;            /*< How often to call the tasks (seconds) */
 | 
						|
    time_t nextdue;           /*< When the task should be next run */
 | 
						|
    HKTASK_TYPE type;         /*< The task type */
 | 
						|
    struct hktask *next;      /*< Next task in the list */
 | 
						|
} HKTASK;
 | 
						|
 | 
						|
/**
 | 
						|
 * Initialises the housekeeper mechanism.
 | 
						|
 *
 | 
						|
 * A call to any of the other housekeeper functions can be made only if
 | 
						|
 * this function returns successfully.
 | 
						|
 *
 | 
						|
 * @return True if the housekeeper mechanism was initialized, false otherwise.
 | 
						|
 */
 | 
						|
extern bool hkinit();
 | 
						|
 | 
						|
/**
 | 
						|
 * Shuts down the housekeeper mechanism.
 | 
						|
 *
 | 
						|
 * Should be called @b only if @c hkinit() returned successfully.
 | 
						|
 *
 | 
						|
 * @see hkinit hkfinish
 | 
						|
 */
 | 
						|
extern void hkshutdown();
 | 
						|
 | 
						|
/**
 | 
						|
 * Waits for the housekeeper thread to finish. Should be called only after
 | 
						|
 * hkshutdown() has been called.
 | 
						|
 */
 | 
						|
extern void hkfinish();
 | 
						|
 | 
						|
/**
 | 
						|
 * @brief Add a new task
 | 
						|
 *
 | 
						|
 * The task will be first run @c frequency seconds after this call is
 | 
						|
 * made and will the be executed repeatedly every frequency seconds
 | 
						|
 * until the task is removed.
 | 
						|
 *
 | 
						|
 * Task names must be unique.
 | 
						|
 *
 | 
						|
 * @param name      Task name
 | 
						|
 * @param task      Function to execute
 | 
						|
 * @param data      Data passed to function as the parameter
 | 
						|
 * @param frequency Frequency of execution
 | 
						|
 *
 | 
						|
 * @return 1 if task was added
 | 
						|
 */
 | 
						|
int hktask_add(const char *name, void (*task)(void *) , void *data, int frequency);
 | 
						|
 | 
						|
/**
 | 
						|
 * @brief Add oneshot task
 | 
						|
 *
 | 
						|
 * The task will only execute once.
 | 
						|
 *
 | 
						|
 * @param name Task name
 | 
						|
 * @param task Function to execute
 | 
						|
 * @param data Data passed to function as the parameter
 | 
						|
 * @param when Number of seconds to wait until task is executed
 | 
						|
 *
 | 
						|
 * @return 1 if task was added
 | 
						|
 */
 | 
						|
int hktask_oneshot(const char *name, void (*task)(void *) , void *data, int when);
 | 
						|
 | 
						|
/**
 | 
						|
 * @brief Remove a task
 | 
						|
 *
 | 
						|
 * @param name Task name
 | 
						|
 *
 | 
						|
 * @return 1 if the task was removed
 | 
						|
 */
 | 
						|
int hktask_remove(const char *name);
 | 
						|
 | 
						|
/**
 | 
						|
 * @brief Show the tasks that are scheduled for the house keeper
 | 
						|
 *
 | 
						|
 * @param pdcb The DCB to send to output
 | 
						|
 */
 | 
						|
void hkshow_tasks(DCB *pdcb);
 | 
						|
 | 
						|
/**
 | 
						|
 * @brief Show tasks as JSON resource
 | 
						|
 *
 | 
						|
 * @param host Hostname of this server
 | 
						|
 *
 | 
						|
 * @return Collection of JSON formatted task resources
 | 
						|
 */
 | 
						|
json_t* hk_tasks_json(const char* host);
 | 
						|
 | 
						|
MXS_END_DECLS
 |