summaryrefslogtreecommitdiffstats
path: root/atuin-server/src/handlers/record.rs
blob: bf454949bc5558323dd0b4b4aac3f2d666002cb4 (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
use axum::{http::StatusCode, response::IntoResponse, Json};
use serde_json::json;
use tracing::instrument;

use super::{ErrorResponse, ErrorResponseStatus, RespExt};
use crate::router::UserAuth;
use atuin_server_database::Database;

use atuin_common::record::{EncryptedData, Record};

#[instrument(skip_all, fields(user.id = user.id))]
pub async fn post<DB: Database>(
    UserAuth(user): UserAuth,
) -> Result<(), ErrorResponseStatus<'static>> {
    // anyone who has actually used the old record store (a very small number) will see this error
    // upon trying to sync.
    // 1. The status endpoint will say that the server has nothing
    // 2. The client will try to upload local records
    // 3. Sync will fail with this error

    // If the client has no local records, they will see the empty index and do nothing. For the
    // vast majority of users, this is the case.
    return Err(
        ErrorResponse::reply("record store deprecated; please upgrade")
            .with_status(StatusCode::BAD_REQUEST),
    );
}

#[instrument(skip_all, fields(user.id = user.id))]
pub async fn index<DB: Database>(UserAuth(user): UserAuth) -> axum::response::Response {
    let ret = json!({
        "hosts": {}
    });

    ret.to_string().into_response()
}

#[instrument(skip_all, fields(user.id = user.id))]
pub async fn next(
    UserAuth(user): UserAuth,
) -> Result<Json<Vec<Record<EncryptedData>>>, ErrorResponseStatus<'static>> {
    let records = Vec::new();

    Ok(Json(records))
}