aboutsummaryrefslogtreecommitdiff
path: root/restapi/auth.c
blob: dbe77d716164b62800817b31341a0423ad0c1114 (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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
#include <cjson/cJSON.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>

#include "auth.h"
#include "common/config.h"
#include "common/http.h"

#define USER_STR "user="
#define PASS_STR "&password="

char // returns 0 if ok, greater than 0 otherwise
restapi_login(const char* username, const char* password)
{
    char ret = 0;
    http_init();
    size_t user_str_len = strlen(USER_STR);
    size_t user_len = strlen(username);
    size_t pass_str_len = strlen(PASS_STR);
    size_t pass_len = strlen(password);
    char* login_args = malloc(user_str_len + user_len + pass_str_len + pass_len + 1);
    strcpy(login_args, USER_STR);
    strcpy(login_args + user_str_len, username);
    strcpy(login_args + user_str_len + user_len, PASS_STR);
    strcpy(login_args + user_str_len + user_len + pass_str_len, password);
    const char* buffer = http_post("/api/v1/login", login_args);
    free(login_args);
    if (buffer == NULL) {
        fprintf(stderr, "Error while authenticating, http post didn't return any data.\n");
        return 1;
    }

    cJSON* json = cJSON_Parse(buffer);
    if (json == NULL) {
        const char *error_ptr = cJSON_GetErrorPtr();
        if (error_ptr != NULL)
            fprintf(stderr, "Json parsing error before: %s\n", error_ptr);
        fprintf(stderr, "Error while authenticating, couldn't parse json output :\n%s\n", buffer);
        ret = 2;
        goto login_json_cleanup;
    }

    const cJSON* status = cJSON_GetObjectItemCaseSensitive(json, "status");
    if (cJSON_IsString(status) && status->valuestring != NULL && strcmp(status->valuestring, "success") == 0) {
        cJSON* data = cJSON_GetObjectItemCaseSensitive(json, "data");
        if (!cJSON_IsObject(data)) {
            fprintf(stderr, "Error while authenticating, couldn't parse json output :\n%s\n", buffer);
            ret = 4;
            goto login_json_cleanup;
        }
        cJSON* userId = cJSON_GetObjectItemCaseSensitive(data, "userId");
        cJSON* authToken = cJSON_GetObjectItemCaseSensitive(data, "authToken");
        if (!cJSON_IsString(userId) || userId->valuestring == NULL || !cJSON_IsString(authToken) || authToken->valuestring == NULL) {
            fprintf(stderr, "Error while authenticating, couldn't parse json output :\n%s\n", buffer);
            ret = 5;
            goto login_json_cleanup;
        }

        printf("userid: %s\nauthtoken: %s\n", userId->valuestring, authToken->valuestring);
        http_add_header("X-User-Id", userId->valuestring);
        http_add_header("X-Auth-Token", authToken->valuestring);
        http_add_header("Content-type", "application/json");
        http_add_header("Expect", "");
    } else {
        const cJSON* msg = cJSON_GetObjectItemCaseSensitive(json, "message");
        if (cJSON_IsString(msg) && msg->valuestring != NULL)
            fprintf(stderr, "Error while authenticating: %s\n", msg->valuestring);
        else
            fprintf(stderr, "Error while authenticating.\n%s\n", buffer);
        ret = 3;
    }
login_json_cleanup:
    cJSON_Delete(json);
    return ret;
}

void restapi_logout(void)
{
    (void) http_post("/api/v1/logout", NULL);
    http_clean();
}