mirror of
https://github.com/xorgy/mediafire-fuse
synced 2026-01-13 13:14:29 -08:00
retrieve and store user's ekey when calling user/get_session_token
This commit is contained in:
@@ -109,7 +109,8 @@ int mfconn_api_user_get_session_token(mfconn * conn,
|
||||
const char *app_key,
|
||||
uint32_t * secret_key,
|
||||
char **secret_time,
|
||||
char **session_token);
|
||||
char **session_token,
|
||||
char **ekey);
|
||||
|
||||
int mfconn_api_folder_delete(mfconn * conn, const char *folderkey);
|
||||
|
||||
|
||||
@@ -37,6 +37,7 @@ struct user_get_session_token_response {
|
||||
uint32_t secret_key;
|
||||
char *secret_time;
|
||||
char *session_token;
|
||||
char *ekey;
|
||||
};
|
||||
|
||||
int
|
||||
@@ -44,7 +45,8 @@ mfconn_api_user_get_session_token(mfconn * conn, const char *server,
|
||||
const char *username, const char *password,
|
||||
int app_id, const char *app_key,
|
||||
uint32_t * secret_key,
|
||||
char **secret_time, char **session_token)
|
||||
char **secret_time, char **session_token,
|
||||
char **ekey)
|
||||
{
|
||||
char *login_url;
|
||||
char *post_args;
|
||||
@@ -66,6 +68,10 @@ mfconn_api_user_get_session_token(mfconn * conn, const char *server,
|
||||
free(*session_token);
|
||||
*session_token = NULL;
|
||||
}
|
||||
if (*ekey != NULL) {
|
||||
free(*ekey);
|
||||
*ekey = NULL;
|
||||
}
|
||||
// configure url for operation
|
||||
login_url = strdup_printf("https://%s/api/user/get_session_token.php",
|
||||
server);
|
||||
@@ -115,6 +121,7 @@ mfconn_api_user_get_session_token(mfconn * conn, const char *server,
|
||||
*secret_key = response.secret_key;
|
||||
*secret_time = response.secret_time;
|
||||
*session_token = response.session_token;
|
||||
*ekey = response.ekey;
|
||||
|
||||
return retval;
|
||||
}
|
||||
@@ -124,9 +131,7 @@ static int _decode_get_session_token(mfhttp * conn, void *user_ptr)
|
||||
json_error_t error;
|
||||
json_t *root = NULL;
|
||||
json_t *node;
|
||||
json_t *session_token;
|
||||
json_t *secret_key;
|
||||
json_t *secret_time;
|
||||
json_t *j_obj;
|
||||
struct user_get_session_token_response *response;
|
||||
int retval;
|
||||
|
||||
@@ -152,29 +157,43 @@ static int _decode_get_session_token(mfhttp * conn, void *user_ptr)
|
||||
return retval;
|
||||
}
|
||||
|
||||
session_token = json_object_get(node, "session_token");
|
||||
if (session_token == NULL) {
|
||||
j_obj = json_object_get(node, "session_token");
|
||||
if (j_obj == NULL) {
|
||||
json_decref(root);
|
||||
fprintf(stderr, "json: no /session_token content\n");
|
||||
return -1;
|
||||
}
|
||||
response->session_token = strdup(json_string_value(j_obj));
|
||||
|
||||
response->session_token = strdup(json_string_value(session_token));
|
||||
|
||||
secret_key = json_object_get(node, "secret_key");
|
||||
if (secret_key != NULL)
|
||||
response->secret_key = atoll(json_string_value(secret_key));
|
||||
j_obj = json_object_get(node, "secret_key");
|
||||
if (j_obj == NULL) {
|
||||
json_decref(root);
|
||||
fprintf(stderr, "json: no /secret_key content\n");
|
||||
return -1;
|
||||
}
|
||||
response->secret_key = atoll(json_string_value(j_obj));
|
||||
|
||||
/*
|
||||
time looks like a float but we must store it as a string to
|
||||
remain congruent with the server on decimal place presentation.
|
||||
*/
|
||||
secret_time = json_object_get(node, "time");
|
||||
if (secret_time != NULL)
|
||||
response->secret_time = strdup(json_string_value(secret_time));
|
||||
|
||||
if (root != NULL)
|
||||
j_obj = json_object_get(node, "time");
|
||||
if (j_obj == NULL) {
|
||||
json_decref(root);
|
||||
fprintf(stderr, "json: no /time content\n");
|
||||
return -1;
|
||||
}
|
||||
response->secret_time = strdup(json_string_value(j_obj));
|
||||
|
||||
j_obj = json_object_get(node, "ekey");
|
||||
if (j_obj == NULL) {
|
||||
json_decref(root);
|
||||
fprintf(stderr, "json: no /ekey content\n");
|
||||
return -1;
|
||||
}
|
||||
response->ekey = strdup(json_string_value(j_obj));
|
||||
|
||||
json_decref(root);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -37,6 +37,7 @@ struct mfconn {
|
||||
uint32_t secret_key;
|
||||
char *secret_time;
|
||||
char *session_token;
|
||||
char *ekey;
|
||||
char *username;
|
||||
char *password;
|
||||
int app_id;
|
||||
@@ -76,12 +77,14 @@ mfconn *mfconn_create(const char *server, const char *username,
|
||||
conn->max_num_retries = max_num_retries;
|
||||
conn->secret_time = NULL;
|
||||
conn->session_token = NULL;
|
||||
conn->ekey = NULL;
|
||||
retval = mfconn_api_user_get_session_token(conn, conn->server,
|
||||
conn->username, conn->password,
|
||||
conn->app_id, conn->app_key,
|
||||
&(conn->secret_key),
|
||||
&(conn->secret_time),
|
||||
&(conn->session_token));
|
||||
&(conn->session_token),
|
||||
&(conn->ekey));
|
||||
|
||||
if (retval != 0) {
|
||||
fprintf(stderr, "error: mfconn_api_user_get_session_token\n");
|
||||
@@ -99,12 +102,15 @@ int mfconn_refresh_token(mfconn * conn)
|
||||
conn->secret_time = NULL;
|
||||
free(conn->session_token);
|
||||
conn->session_token = NULL;
|
||||
free(conn->ekey);
|
||||
conn->ekey = NULL;
|
||||
retval = mfconn_api_user_get_session_token(conn, conn->server,
|
||||
conn->username, conn->password,
|
||||
conn->app_id, conn->app_key,
|
||||
&(conn->secret_key),
|
||||
&(conn->secret_time),
|
||||
&(conn->session_token));
|
||||
&(conn->session_token),
|
||||
&(conn->ekey));
|
||||
if (retval != 0) {
|
||||
fprintf(stderr, "user/get_session_token failed\n");
|
||||
return -1;
|
||||
@@ -121,6 +127,7 @@ void mfconn_destroy(mfconn * conn)
|
||||
free(conn->app_key);
|
||||
free(conn->secret_time);
|
||||
free(conn->session_token);
|
||||
free(conn->ekey);
|
||||
free(conn);
|
||||
}
|
||||
|
||||
@@ -404,6 +411,11 @@ int mfconn_get_max_num_retries(mfconn * conn)
|
||||
return conn->max_num_retries;
|
||||
}
|
||||
|
||||
const char *mfconn_get_ekey(mfconn * conn)
|
||||
{
|
||||
return conn->ekey;
|
||||
}
|
||||
|
||||
int mfconn_upload_poll_for_completion(mfconn * conn, const char *upload_key)
|
||||
{
|
||||
int status;
|
||||
|
||||
Reference in New Issue
Block a user