feat: ability to create a task #14

Merged
matous-volf merged 12 commits from feat/task-create into main 2024-08-22 21:40:47 +00:00
3 changed files with 13 additions and 5 deletions
Showing only changes of commit 5d2c02cfd3 - Show all commits

View File

@ -2,7 +2,7 @@ use serde::{Deserialize, Serialize};
use std::fmt::Display;
use std::str::FromStr;
#[derive(Serialize, Deserialize, Debug)]
#[derive(Serialize, Deserialize, Clone, Debug)]
pub enum Error {
ServerInternal,
}

View File

@ -1,7 +1,9 @@
use std::fmt::Display;
use std::str::FromStr;
use serde::Deserialize;
use serde_with::serde_derive::Serialize;
#[derive(Debug)]
#[derive(Serialize, Deserialize, Clone, Debug)]
pub struct ErrorVec<T> {
errors: Vec<T>,
}

View File

@ -33,14 +33,20 @@ pub(crate) async fn create_project(new_project: NewProject)
#[server]
pub(crate) async fn get_projects()
-> Result<Vec<Project>, ServerFnError> {
-> Result<Vec<Project>, ServerFnError<ErrorVec<Error>>> {
use crate::schema::projects::dsl::*;
let mut connection = establish_database_connection()?;
let mut connection = establish_database_connection()
.map_err::<ErrorVec<Error>, _>(
|_| vec![Error::ServerInternal].into()
)?;
let results = projects
.select(Project::as_select())
.load::<Project>(&mut connection)?;
.load::<Project>(&mut connection)
.map_err::<ErrorVec<Error>, _>(
|_| vec![Error::ServerInternal].into()
)?;
Ok(results)
}