aboutsummaryrefslogtreecommitdiff
path: root/src/cookie.h
blob: d65cbe5b20e8c89b5a4a7751e931f6e99982c8b8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#ifndef MAGI_INCLUDED_COOKIE_H
#define MAGI_INCLUDED_COOKIE_H


/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 * Cookie
 */
struct magi_cookie {
    char *name;    /* name: free(name) is valid. */
    char *data;    /* data: free(data) is valid. */
    /* Following is used in Cookie2: */
    char *path;    /* path: free(path) is valid. */
    char *domain;  /* domain: free(domain) is valid. */
    char *port;    /* port: free(port) is valid. */
};

/* Null is valid "struct magi_cookie_list *" object. */
struct magi_cookie_list {
    struct magi_cookie_list *next;
    struct magi_cookie      item;
};

/* Returns null in case of error. */
int magi_parse_cookie(struct magi_cookie_list **list, const char *input);

/*
 * Adds *item to the begining of *list, item and list are dereferencable;
 * Returns null in case of error.
 */
int magi_cookie_list_add(
    struct magi_cookie_list **list,
    struct magi_cookie *item
);

/*
 * Searchs for first node in list: node.name == name, name is C-string;
 * Returns node.data if succeed, otherwise result is null.
 */
char *magi_cookie_list_get(struct magi_cookie_list *list, const char *name);

/*
 * Destroys list; list is not valid after destruction.
 */
void magi_cookie_list_destroy(struct magi_cookie_list *list);


#endif