create db::maps module
This commit is contained in:
parent
aa066ef5bb
commit
f727613efb
2 changed files with 32 additions and 0 deletions
31
planetwars-server/src/db/maps.rs
Normal file
31
planetwars-server/src/db/maps.rs
Normal file
|
@ -0,0 +1,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)
|
||||||
|
}
|
|
@ -1,4 +1,5 @@
|
||||||
pub mod bots;
|
pub mod bots;
|
||||||
|
pub mod maps;
|
||||||
pub mod matches;
|
pub mod matches;
|
||||||
pub mod ratings;
|
pub mod ratings;
|
||||||
pub mod sessions;
|
pub mod sessions;
|
||||||
|
|
Loading…
Reference in a new issue