annotate libsci/apic.h @ 38:96008a1953ba

scid: improve page access message
author David Demelier <markand@malikania.fr>
date Sun, 07 Aug 2022 08:41:28 +0200
parents e52c762d8ba8
children b474f0985e39
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
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
40
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
41 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
42 * \brief Request context.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
43 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
44 * This structure contains the error message and the HTTP return status,
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
45 * nothing has to be free'd.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
46 */
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
47 struct apic {
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
48 char error[APIC_ERR_MAX]; /*!< Error message (empty unless). */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
49 long status; /*!< HTTP return code. */
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
50 };
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
51
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
52 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
53 * \brief Client configuration.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
54 */
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
55 extern struct apiconf {
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
56 char baseurl[APIC_URL_MAX]; /*!< Base API URL for requets. */
33
1d0ddf9e6efd misc: general documentation
David Demelier <markand@malikania.fr>
parents: 27
diff changeset
57 } apiconf /*! Global variable. */;
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
58
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
59 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
60 * Perform a GET request.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
61 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
62 * 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
63 * style.
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 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
66 * \pre fmt != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
67 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
68 * \param fmt the format string for URL page
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
69 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
70 */
27
dae2de19ca5d misc: switch to JSON everywhere
David Demelier <markand@malikania.fr>
parents: 23
diff changeset
71 json_t *
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
72 apic_get(struct apic *req, const char *fmt, ...);
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
73
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
74 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
75 * Perform a POST request.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
76 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
77 * 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
78 * style.
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 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
81 * \pre fmt != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
82 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
83 * \param body the optional document body
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
84 * \param fmt the format string for URL page
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
85 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
86 */
27
dae2de19ca5d misc: switch to JSON everywhere
David Demelier <markand@malikania.fr>
parents: 23
diff changeset
87 json_t *
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
88 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
89
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
90 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
91 * Add a new job.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
92 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
93 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
94 * \pre job != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
95 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
96 * \param job the job model
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
97 * \return 0 on success or -1 on error
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
98 */
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
99 int
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
100 apic_job_add(struct apic *req, json_t *job);
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
101
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
102 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
103 * Get a list of job to perform for this worker.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
104 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
105 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
106 * \pre worker != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
107 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
108 * \param worker the worker name
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
109 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
110 */
27
dae2de19ca5d misc: switch to JSON everywhere
David Demelier <markand@malikania.fr>
parents: 23
diff changeset
111 json_t *
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
112 apic_job_todo(struct apic *req, const char *worker);
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
113
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
114 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
115 * Add a new job result.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
116 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
117 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
118 * \pre jobresult != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
119 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
120 * \param jobresult the jobresult model
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
121 * \return 0 on success or -1 on error
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
122 */
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
123 int
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
124 apic_jobresult_add(struct apic *req, json_t *jobresult);
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
125
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
126 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
127 * Add or update a project.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
128 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
129 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
130 * \pre project != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
131 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
132 * \param project the project model
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
133 * \return 0 on success or -1 on error
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
134 */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
135 int
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
136 apic_project_save(struct apic *req, json_t *project);
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
137
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
138 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
139 * Get a list of projects.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
140 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
141 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
142 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
143 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
144 */
27
dae2de19ca5d misc: switch to JSON everywhere
David Demelier <markand@malikania.fr>
parents: 23
diff changeset
145 json_t *
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
146 apic_project_list(struct apic *req);
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
147
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
148 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
149 * Get a project by name.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
150 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
151 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
152 * \pre name != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
153 * \param name the project name
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
154 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
155 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
156 */
27
dae2de19ca5d misc: switch to JSON everywhere
David Demelier <markand@malikania.fr>
parents: 23
diff changeset
157 json_t *
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
158 apic_project_find(struct apic *req, const char *name);
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
159
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
160 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
161 * Add or update a worker.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
162 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
163 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
164 * \pre worker != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
165 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
166 * \param worker the worker model
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
167 * \return 0 on success or -1 on error
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
168 */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
169 int
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
170 apic_worker_save(struct apic *req, json_t *worker);
20
f98ea578b1ef misc: revamp database
David Demelier <markand@malikania.fr>
parents: 19
diff changeset
171
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
172 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
173 * Get a list of workers.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
174 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
175 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
176 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
177 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
178 */
27
dae2de19ca5d misc: switch to JSON everywhere
David Demelier <markand@malikania.fr>
parents: 23
diff changeset
179 json_t *
34
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
180 apic_worker_list(struct apic *req);
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
181
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
182 /**
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
183 * Get a worker by name.
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
184 *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
185 * \pre req != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
186 * \pre name != NULL
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
187 * \param name the worker name
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
188 * \param req the request output
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
189 * \return the JSON document received from the server or NULL on failure
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
190 */
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
191 json_t *
e52c762d8ba8 misc: cleanups
David Demelier <markand@malikania.fr>
parents: 33
diff changeset
192 apic_worker_find(struct apic *req, const char *name);
19
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
193
de4bf839b565 misc: revamp SQL
David Demelier <markand@malikania.fr>
parents:
diff changeset
194 #endif /* !SCI_APIC_H */