aboutsummaryrefslogtreecommitdiff
path: root/planetwars-server/src/db/maps.rs
blob: c9f50a0778b1652830bbfd47adef995831a8549e (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
use diesel::{PgConnection, QueryDsl, QueryResult, RunQueryDsl};

use crate::schema::maps;

#[derive(Insertable)]
#[table_name = "maps"]
pub struct NewMap<'a> {
    pub name: &'a str,
    pub file_path: &'a str,
}

#[derive(Queryable, Clone, Debug)]
pub struct Map {
    pub id: i32,
    pub name: String,
    pub file_path: String,
}

pub fn create_map(new_map: NewMap, conn: &PgConnection) -> QueryResult<Map> {
    diesel::insert_into(maps::table)
        .values(new_map)
        .get_result(conn)
}

pub fn find_map(id: i32, conn: &PgConnection) -> QueryResult<Map> {
    maps::table.find(id).get_result(conn)
}

pub fn list_maps(conn: &PgConnection) -> QueryResult<Vec<Map>> {
    maps::table.get_results(conn)
}