mirror of
https://gitlab.com/comunic/comunicapiv3
synced 2024-11-22 21:39:21 +00:00
Start to configure Firebase access token
This commit is contained in:
parent
c8c03d11e4
commit
6eb153eefa
@ -5,6 +5,8 @@
|
|||||||
use crate::api_data::push_notifications_status_api::PushNotificationsStatusAPI;
|
use crate::api_data::push_notifications_status_api::PushNotificationsStatusAPI;
|
||||||
use crate::data::base_request_handler::BaseRequestHandler;
|
use crate::data::base_request_handler::BaseRequestHandler;
|
||||||
use crate::data::http_request_handler::HttpRequestHandler;
|
use crate::data::http_request_handler::HttpRequestHandler;
|
||||||
|
use crate::data::user_token::PushNotificationToken;
|
||||||
|
use crate::helpers::account_helper;
|
||||||
use crate::routes::RequestResult;
|
use crate::routes::RequestResult;
|
||||||
|
|
||||||
/// Get current push notifications status for a connection
|
/// Get current push notifications status for a connection
|
||||||
@ -13,3 +15,30 @@ pub fn get_status(r: &mut HttpRequestHandler) -> RequestResult {
|
|||||||
|
|
||||||
r.set_response(PushNotificationsStatusAPI::new(status))
|
r.set_response(PushNotificationsStatusAPI::new(status))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Configure push notifications for a client
|
||||||
|
pub fn configure(r: &mut HttpRequestHandler) -> RequestResult {
|
||||||
|
let status = r.post_string("status")?;
|
||||||
|
|
||||||
|
// TODO : check availability of each option
|
||||||
|
|
||||||
|
let status = match status.as_str() {
|
||||||
|
"disabled" => PushNotificationToken::NONE,
|
||||||
|
|
||||||
|
"firebase" => {
|
||||||
|
PushNotificationToken::FIREBASE(r.post_string("firebase_token")?)
|
||||||
|
}
|
||||||
|
|
||||||
|
"independent" => {
|
||||||
|
unimplemented!();
|
||||||
|
}
|
||||||
|
|
||||||
|
_ => {
|
||||||
|
return r.bad_request(format!("Unknown status: {}", status));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
account_helper::set_push_notification_token(r.user_access_token().unwrap(), status)?;
|
||||||
|
|
||||||
|
r.ok()
|
||||||
|
}
|
@ -101,6 +101,9 @@ pub fn refresh_access_token(token: &UserAccessToken) -> Res {
|
|||||||
|
|
||||||
/// Destroy a given user login tokens
|
/// Destroy a given user login tokens
|
||||||
pub fn destroy_login_tokens(access_tokens: &UserAccessToken) -> Res {
|
pub fn destroy_login_tokens(access_tokens: &UserAccessToken) -> Res {
|
||||||
|
// TODO : un-register from independent push notifications service
|
||||||
|
// (continue to destroy token even in case of failure)
|
||||||
|
|
||||||
DeleteQuery::new(USER_ACCESS_TOKENS_TABLE)
|
DeleteQuery::new(USER_ACCESS_TOKENS_TABLE)
|
||||||
.cond_u64("id", access_tokens.id)
|
.cond_u64("id", access_tokens.id)
|
||||||
.exec()?;
|
.exec()?;
|
||||||
@ -129,6 +132,7 @@ pub fn clean_up_old_access_tokens() -> Res {
|
|||||||
pub fn destroy_all_user_tokens(id: &UserID) -> ResultBoxError {
|
pub fn destroy_all_user_tokens(id: &UserID) -> ResultBoxError {
|
||||||
user_ws_controller::disconnect_user_from_all_sockets(id)?;
|
user_ws_controller::disconnect_user_from_all_sockets(id)?;
|
||||||
|
|
||||||
|
// TODO : call destroy_login_tokens for each call to do proper cleanup
|
||||||
database::DeleteQuery::new(USER_ACCESS_TOKENS_TABLE)
|
database::DeleteQuery::new(USER_ACCESS_TOKENS_TABLE)
|
||||||
.cond_user_id("user_id", id)
|
.cond_user_id("user_id", id)
|
||||||
.exec()
|
.exec()
|
||||||
@ -306,6 +310,16 @@ pub fn set_notifications_settings(new_settings: NewNotificationsSettings) -> Res
|
|||||||
.exec()
|
.exec()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Set new push notification token
|
||||||
|
pub fn set_push_notification_token(client: &UserAccessToken, new_token: PushNotificationToken) -> Res {
|
||||||
|
// TODO : in case of independent push service, remove previous client
|
||||||
|
|
||||||
|
database::UpdateInfo::new(USER_ACCESS_TOKENS_TABLE)
|
||||||
|
.cond_u64("id", client.id)
|
||||||
|
.set_opt_str("push_notifications_token", new_token.to_db())
|
||||||
|
.exec()
|
||||||
|
}
|
||||||
|
|
||||||
/// Export an account's data
|
/// Export an account's data
|
||||||
pub fn export(user_id: &UserID) -> ResultBoxError<AccountExport> {
|
pub fn export(user_id: &UserID) -> ResultBoxError<AccountExport> {
|
||||||
let mut data = AccountExport {
|
let mut data = AccountExport {
|
||||||
|
@ -180,6 +180,7 @@ pub fn get_routes() -> Vec<Route> {
|
|||||||
|
|
||||||
// Push notifications controller
|
// Push notifications controller
|
||||||
Route::post("/push_notifications/status", Box::new(push_notifications_controller::get_status)),
|
Route::post("/push_notifications/status", Box::new(push_notifications_controller::get_status)),
|
||||||
|
Route::post("/push_notifications/configure", Box::new(push_notifications_controller::configure)),
|
||||||
|
|
||||||
// Friends controller
|
// Friends controller
|
||||||
Route::post("/friends/getList", Box::new(friends_controller::get_list)),
|
Route::post("/friends/getList", Box::new(friends_controller::get_list)),
|
||||||
|
Loading…
Reference in New Issue
Block a user