annotate libsci/apic.h @ 50:b474f0985e39

scictl: add API key support
author David Demelier <markand@malikania.fr>
date Wed, 17 Aug 2022 09:11:58 +0200
parents e52c762d8ba8
children 71cd8447e3a4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
33
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
1 /*
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
2 * apic.h -- synchronous HTTP request
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
3 *
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
4 * Copyright (c) 2021-2022 David Demelier <markand@malikania.fr>
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
5 *
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
6 * Permission to use, copy, modify, and/or distribute this software for any
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
7 * purpose with or without fee is hereby granted, provided that the above
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
8 * copyright notice and this permission notice appear in all copies.
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
9 *
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
17 */
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
18
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
19 #ifndef SCI_APIC_H
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
20 #define SCI_APIC_H
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
21
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
22 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
23 * \file apic.h
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
24 * \brief Synchronous HTTP request.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
25 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
26 * This module provides function to retrieve and send data to scid using HTTP
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
27 * requests.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
28 */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
29
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
30 #include <jansson.h>
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
31
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
32 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
33 * \brief Maximum error message.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
34 */
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
35 #define APIC_ERR_MAX 128
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
36 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
37 * \brief Maximum URL length.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
38 */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
39 #define APIC_URL_MAX 512
50
b474f0985e39 scictl: add API key support
David Demelier <markand@malikania.fr>
parents: 34
diff changeset
40 /**
b474f0985e39 scictl: add API key support
David Demelier <markand@malikania.fr>
parents: 34
diff changeset
41 * \brief Maximum URL length.
b474f0985e39 scictl: add API key support
David Demelier <markand@malikania.fr>
parents: 34
diff changeset
42 */
b474f0985e39 scictl: add API key support
David Demelier <markand@malikania.fr>
parents: 34
diff changeset
43 #define APIC_KEY_MAX (40 + 1)
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
44
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
45 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
46 * \brief Request context.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
47 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
48 * This structure contains the error message and the HTTP return status,
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
49 * nothing has to be free'd.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
50 */
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
51 struct apic {
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
52 char error[APIC_ERR_MAX]; /*!< Error message (empty unless). */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
53 long status; /*!< HTTP return code. */
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
54 };
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
55
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
56 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
57 * \brief Client configuration.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
58 */
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
59 extern struct apiconf {
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
60 char baseurl[APIC_URL_MAX]; /*!< Base API URL for requets. */
50
b474f0985e39 scictl: add API key support
David Demelier <markand@malikania.fr>
parents: 34
diff changeset
61 char key[APIC_KEY_MAX]; /*!< Maximum length for API key. */
33
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
62 } apiconf /*! Global variable. */;
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
63
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
64 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
65 * Perform a GET request.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
66 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
67 * The URL format will be appended to the base URL using printf(3) format
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
68 * style.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
69 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
70 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
71 * \pre fmt != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
72 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
73 * \param fmt the format string for URL page
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
74 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
75 */
27
dae2de19ca5d misc: switch to JSON everywhere
David Demelier <markand@malikania.fr>
parents: 23
diff changeset
76 json_t *
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
77 apic_get(struct apic *req, const char *fmt, ...);
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
78
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
79 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
80 * Perform a POST request.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
81 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
82 * The URL format will be appended to the base URL using printf(3) format
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
83 * style.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
84 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
85 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
86 * \pre fmt != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
87 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
88 * \param body the optional document body
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
89 * \param fmt the format string for URL page
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
90 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
91 */
27
dae2de19ca5d misc: switch to JSON everywhere
David Demelier <markand@malikania.fr>
parents: 23
diff changeset
92 json_t *
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
93 apic_post(struct apic *req, const json_t *body, const char *fmt, ...);
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
94
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
95 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
96 * Add a new job.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
97 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
98 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
99 * \pre job != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
100 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
101 * \param job the job model
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
102 * \return 0 on success or -1 on error
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
103 */
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
104 int
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
105 apic_job_add(struct apic *req, json_t *job);
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
106
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
107 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
108 * Get a list of job to perform for this worker.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
109 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
110 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
111 * \pre worker != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
112 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
113 * \param worker the worker name
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
114 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
115 */
27
dae2de19ca5d misc: switch to JSON everywhere
David Demelier <markand@malikania.fr>
parents: 23
diff changeset
116 json_t *
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
117 apic_job_todo(struct apic *req, const char *worker);
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
118
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
119 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
120 * Add a new job result.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
121 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
122 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
123 * \pre jobresult != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
124 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
125 * \param jobresult the jobresult model
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
126 * \return 0 on success or -1 on error
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
127 */
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
128 int
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
129 apic_jobresult_add(struct apic *req, json_t *jobresult);
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
130
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
131 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
132 * Add or update a project.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
133 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
134 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
135 * \pre project != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
136 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
137 * \param project the project model
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
138 * \return 0 on success or -1 on error
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
139 */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
140 int
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
141 apic_project_save(struct apic *req, json_t *project);
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
142
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
143 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
144 * Get a list of projects.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
145 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
146 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
147 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
148 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
149 */
27
dae2de19ca5d misc: switch to JSON everywhere
David Demelier <markand@malikania.fr>
parents: 23
diff changeset
150 json_t *
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
151 apic_project_list(struct apic *req);
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
152
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
153 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
154 * Get a project by name.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
155 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
156 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
157 * \pre name != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
158 * \param name the project name
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
159 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
160 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
161 */
27
dae2de19ca5d misc: switch to JSON everywhere
David Demelier <markand@malikania.fr>
parents: 23
diff changeset
162 json_t *
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
163 apic_project_find(struct apic *req, const char *name);
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
164
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
165 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
166 * Add or update a worker.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
167 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
168 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
169 * \pre worker != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
170 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
171 * \param worker the worker model
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
172 * \return 0 on success or -1 on error
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
173 */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
174 int
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
175 apic_worker_save(struct apic *req, json_t *worker);
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
176
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
177 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
178 * Get a list of workers.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
179 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
180 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
181 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
182 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
183 */
27
dae2de19ca5d misc: switch to JSON everywhere
David Demelier <markand@malikania.fr>
parents: 23
diff changeset
184 json_t *
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
185 apic_worker_list(struct apic *req);
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
186
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
187 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
188 * Get a worker by name.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
189 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
190 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
191 * \pre name != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
192 * \param name the worker name
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
193 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
194 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
195 */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
196 json_t *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
197 apic_worker_find(struct apic *req, const char *name);
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
198
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
199 #endif /* !SCI_APIC_H */