Changes related to api in both client and server
This commit is contained in:
parent
8cfbfd17b6
commit
0ea21cfaf3
4 changed files with 51 additions and 11 deletions
|
@ -20,20 +20,20 @@ export interface Post extends NewPost {
|
||||||
|
|
||||||
export async function getPosts(): Promise<Post[]> {
|
export async function getPosts(): Promise<Post[]> {
|
||||||
// const res = await fetch(`${API_URL}/posts`);
|
// const res = await fetch(`${API_URL}/posts`);
|
||||||
const res = await fetch("/api/");
|
const res = await fetch("/api/posts");
|
||||||
const data = await res.json();
|
const data = await res.json();
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function getPost(id: string): Promise<Post> {
|
export async function getPost(id: string): Promise<Post> {
|
||||||
const res = await fetch(`/api/${id}`);
|
const res = await fetch(`/api/posts/${id}`);
|
||||||
const data = await res.json();
|
const data = await res.json();
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function createPost(post: NewPost): Promise<void> {
|
export async function createPost(post: NewPost): Promise<void> {
|
||||||
// await fetch(`${API_URL}`, {
|
// await fetch(`${API_URL}`, {
|
||||||
await fetch("/api/", {
|
await fetch("/api/posts", {
|
||||||
method: "POST",
|
method: "POST",
|
||||||
headers: {
|
headers: {
|
||||||
"Content-Type": "application/json",
|
"Content-Type": "application/json",
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
use crate::routes::{NewPost, Post};
|
use crate::routes::{NewPost, Post};
|
||||||
|
use log::warn;
|
||||||
use sqlx::{Row, SqlitePool};
|
use sqlx::{Row, SqlitePool};
|
||||||
|
|
||||||
// Gets all posts from the database
|
// Gets all posts from the database
|
||||||
|
@ -11,10 +12,19 @@ pub async fn db_get_posts(pool: &SqlitePool) -> Vec<Post> {
|
||||||
|
|
||||||
// Inserts a new post to the database
|
// Inserts a new post to the database
|
||||||
pub async fn db_new_post(post: NewPost, pool: &SqlitePool) -> Option<Post> {
|
pub async fn db_new_post(post: NewPost, pool: &SqlitePool) -> Option<Post> {
|
||||||
let q2 = sqlx::query!("INSERT INTO posts (content) VALUES (?)", post.content)
|
let q2 = sqlx::query!(
|
||||||
|
"INSERT INTO posts (user_id, content) VALUES (1, ?)",
|
||||||
|
post.content
|
||||||
|
)
|
||||||
.execute(pool)
|
.execute(pool)
|
||||||
.await;
|
.await;
|
||||||
|
|
||||||
|
if q2.is_err() {
|
||||||
|
let s = q2.err().unwrap();
|
||||||
|
warn!("Error inserting post into database: {}", s);
|
||||||
|
return None;
|
||||||
|
}
|
||||||
|
|
||||||
let q = sqlx::query_as!(
|
let q = sqlx::query_as!(
|
||||||
Post,
|
Post,
|
||||||
"SELECT * FROM posts WHERE id = (SELECT MAX(id) FROM posts)"
|
"SELECT * FROM posts WHERE id = (SELECT MAX(id) FROM posts)"
|
||||||
|
|
|
@ -24,6 +24,7 @@ async fn main() -> std::io::Result<()> {
|
||||||
App::new()
|
App::new()
|
||||||
.wrap(middleware::Compress::default())
|
.wrap(middleware::Compress::default())
|
||||||
.wrap(middleware::Logger::default())
|
.wrap(middleware::Logger::default())
|
||||||
|
.wrap(middleware::NormalizePath::trim())
|
||||||
.service(
|
.service(
|
||||||
scope("/api")
|
scope("/api")
|
||||||
.service(get_posts)
|
.service(get_posts)
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
use sqlx::Pool;
|
use sqlx::Pool;
|
||||||
use sqlx::Sqlite;
|
use sqlx::Sqlite;
|
||||||
|
use sqlx::SqlitePool;
|
||||||
use sqlx::{self, sqlite};
|
use sqlx::{self, sqlite};
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
|
@ -11,7 +12,7 @@ impl ServerState {
|
||||||
pub async fn new() -> Self {
|
pub async fn new() -> Self {
|
||||||
// This is almost certainly bad practice for more reasons than I can count
|
// This is almost certainly bad practice for more reasons than I can count
|
||||||
dotenvy::dotenv().ok();
|
dotenvy::dotenv().ok();
|
||||||
let db_url = dotenvy::var("DATABASE_URL").unwrap_or("sqlite:./db.sqlite".to_string());
|
let db_url = dotenvy::var("DATABASE_URL").unwrap_or(":memory:".to_string());
|
||||||
|
|
||||||
let pool = sqlite::SqlitePoolOptions::new()
|
let pool = sqlite::SqlitePoolOptions::new()
|
||||||
.max_connections(5)
|
.max_connections(5)
|
||||||
|
@ -21,9 +22,37 @@ impl ServerState {
|
||||||
|
|
||||||
sqlx::migrate!("./migrations").run(&pool).await.unwrap();
|
sqlx::migrate!("./migrations").run(&pool).await.unwrap();
|
||||||
|
|
||||||
Self {
|
#[cfg(debug_assertions)]
|
||||||
// posts: Arc::new(Mutex::new(BTreeMap::new())),
|
debug_setup(&pool).await;
|
||||||
pool: pool,
|
|
||||||
|
Self { pool }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Inserts a bunch of dummy data into the database
|
||||||
|
// Mostly useful for debugging new posts, as we need to satisfy foreign key constraints.
|
||||||
|
#[cfg(debug_assertions)]
|
||||||
|
async fn debug_setup(pool: &SqlitePool) {
|
||||||
|
use chrono::NaiveDateTime;
|
||||||
|
use sqlx::query;
|
||||||
|
|
||||||
|
let now = NaiveDateTime::from_timestamp(0, 0);
|
||||||
|
|
||||||
|
query!(
|
||||||
|
"INSERT INTO users (username, password, created_at, updated_at) VALUES ('test', 'test', ?, ?)",
|
||||||
|
now,
|
||||||
|
now
|
||||||
|
)
|
||||||
|
.execute(pool)
|
||||||
|
.await
|
||||||
|
.unwrap();
|
||||||
|
|
||||||
|
query!(
|
||||||
|
"INSERT INTO posts (user_id, content, created_at, updated_at) VALUES (1, 'Hello world!', ?, ?)",
|
||||||
|
now,
|
||||||
|
now
|
||||||
|
)
|
||||||
|
.execute(pool)
|
||||||
|
.await
|
||||||
|
.unwrap();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue