typedb_driver/common/info.rs
1/*
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements. See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership. The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License. You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing,
13 * software distributed under the License is distributed on an
14 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 * KIND, either express or implied. See the License for the
16 * specific language governing permissions and limitations
17 * under the License.
18 */
19
20use super::address::Address;
21
22#[derive(Debug)]
23pub(crate) struct DatabaseInfo {
24 pub(crate) name: String,
25 pub(crate) replicas: Vec<ReplicaInfo>,
26}
27
28/// The metadata and state of an individual raft replica of a database.
29#[derive(Debug)]
30pub struct ReplicaInfo {
31 /// The server hosting this replica
32 pub server: Address,
33 /// Whether this is the primary replica of the raft cluster.
34 pub is_primary: bool,
35 /// Whether this is the preferred replica of the raft cluster.
36 /// If true, Operations which can be run on any replica will prefer to use this replica.
37 pub is_preferred: bool,
38 /// The raft protocol ‘term’ of this replica.
39 pub term: i64,
40}
41
42#[derive(Debug)]
43pub(crate) struct UserInfo {
44 pub(crate) name: String,
45 pub(crate) password: Option<String>,
46}