OpenDNSSEC-signer  1.4.6
task.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2009 NLNet Labs. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  * notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  * notice, this list of conditions and the following disclaimer in the
11  * documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
14  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
15  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
17  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
19  * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
21  * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
22  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
23  * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  *
25  */
26 
32 #ifndef SCHEDULER_TASK_H
33 #define SCHEDULER_TASK_H
34 
35 #include "config.h"
36 #include "shared/allocator.h"
37 
38 #include <ldns/ldns.h>
39 
41  TASK_NONE = 0,
42  TASK_SIGNCONF, /* ods-signer update */
43  TASK_READ, /* ods-signer sign */
45  TASK_SIGN, /* ods-signer flush */
47 };
48 typedef enum task_id_enum task_id;
49 
53 typedef struct task_struct task_type;
54 struct task_struct {
59  time_t when;
60  time_t halted_when;
61  time_t backoff;
62  int flush;
63  void* zone;
64 };
65 
74 task_type* task_create(task_id what, time_t when, void* zone);
75 
82 void task_backup(FILE* fd, task_type* task);
83 
91 int task_compare(const void* a, const void* b);
92 
100 char* task2str(task_type* task, char* buftask);
101 
108 const char* task_what2str(task_id what);
109 
115 const char* task_who2str(task_type* task);
116 
123 void task_print(FILE* out, task_type* task);
124 
130 void task_log(task_type* task);
131 
137 void task_cleanup(task_type* task);
138 
139 #endif /* SCHEDULER_TASK_H */
Definition: task.h:41
time_t when
Definition: task.h:59
task_id interrupt
Definition: task.h:57
int flush
Definition: task.h:62
time_t backoff
Definition: task.h:61
Definition: task.h:45
void * zone
Definition: task.h:63
enum task_id_enum task_id
Definition: task.h:48
const char * task_what2str(task_id what)
Definition: task.c:146
allocator_type * allocator
Definition: task.h:55
Definition: task.h:43
time_t halted_when
Definition: task.h:60
const char * task_who2str(task_type *task)
Definition: task.c:176
task_id halted
Definition: task.h:58
task_id_enum
Definition: task.h:40
void task_backup(FILE *fd, task_type *task)
Definition: task.c:87
void task_cleanup(task_type *task)
Definition: task.c:275
task_id what
Definition: task.h:56
void task_log(task_type *task)
Definition: task.c:253
int task_compare(const void *a, const void *b)
Definition: task.c:112
char * task2str(task_type *task, char *buftask)
Definition: task.c:194
void task_print(FILE *out, task_type *task)
Definition: task.c:231
task_type * task_create(task_id what, time_t when, void *zone)
Definition: task.c:48