switch-to-seaorm #1
							
								
								
									
										22
									
								
								migration/Cargo.toml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								migration/Cargo.toml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| [package] | ||||
| name = "migration" | ||||
| version = "0.1.0" | ||||
| edition = "2021" | ||||
| publish = false | ||||
| 
 | ||||
| [lib] | ||||
| name = "migration" | ||||
| path = "src/lib.rs" | ||||
| 
 | ||||
| [dependencies] | ||||
| async-std = { version = "1", features = ["attributes", "tokio1"] } | ||||
| 
 | ||||
| [dependencies.sea-orm-migration] | ||||
| version = "0.12.0" | ||||
| features = [ | ||||
|   # Enable at least one `ASYNC_RUNTIME` and `DATABASE_DRIVER` feature if you want to run migration via CLI. | ||||
|   # View the list of supported features at https://www.sea-ql.org/SeaORM/docs/install-and-config/database-and-async-runtime. | ||||
|   # e.g. | ||||
|   # "runtime-tokio-rustls",  # `ASYNC_RUNTIME` feature | ||||
|   # "sqlx-postgres",         # `DATABASE_DRIVER` feature | ||||
| ] | ||||
							
								
								
									
										41
									
								
								migration/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								migration/README.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,41 @@ | ||||
| # Running Migrator CLI | ||||
| 
 | ||||
| - Generate a new migration file | ||||
|     ```sh | ||||
|     cargo run -- generate MIGRATION_NAME | ||||
|     ``` | ||||
| - Apply all pending migrations | ||||
|     ```sh | ||||
|     cargo run | ||||
|     ``` | ||||
|     ```sh | ||||
|     cargo run -- up | ||||
|     ``` | ||||
| - Apply first 10 pending migrations | ||||
|     ```sh | ||||
|     cargo run -- up -n 10 | ||||
|     ``` | ||||
| - Rollback last applied migrations | ||||
|     ```sh | ||||
|     cargo run -- down | ||||
|     ``` | ||||
| - Rollback last 10 applied migrations | ||||
|     ```sh | ||||
|     cargo run -- down -n 10 | ||||
|     ``` | ||||
| - Drop all tables from the database, then reapply all migrations | ||||
|     ```sh | ||||
|     cargo run -- fresh | ||||
|     ``` | ||||
| - Rollback all applied migrations, then reapply all migrations | ||||
|     ```sh | ||||
|     cargo run -- refresh | ||||
|     ``` | ||||
| - Rollback all applied migrations | ||||
|     ```sh | ||||
|     cargo run -- reset | ||||
|     ``` | ||||
| - Check the status of all migrations | ||||
|     ```sh | ||||
|     cargo run -- status | ||||
|     ``` | ||||
							
								
								
									
										12
									
								
								migration/src/lib.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								migration/src/lib.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | ||||
| pub use sea_orm_migration::prelude::*; | ||||
| 
 | ||||
| mod m20220101_000001_create_table; | ||||
| 
 | ||||
| pub struct Migrator; | ||||
| 
 | ||||
| #[async_trait::async_trait] | ||||
| impl MigratorTrait for Migrator { | ||||
|     fn migrations() -> Vec<Box<dyn MigrationTrait>> { | ||||
|         vec![Box::new(m20220101_000001_create_table::Migration)] | ||||
|     } | ||||
| } | ||||
							
								
								
									
										47
									
								
								migration/src/m20220101_000001_create_table.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								migration/src/m20220101_000001_create_table.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,47 @@ | ||||
| use sea_orm_migration::prelude::*; | ||||
| 
 | ||||
| #[derive(DeriveMigrationName)] | ||||
| pub struct Migration; | ||||
| 
 | ||||
| #[async_trait::async_trait] | ||||
| impl MigrationTrait for Migration { | ||||
|     async fn up(&self, manager: &SchemaManager) -> Result<(), DbErr> { | ||||
|         // Replace the sample below with your own migration scripts
 | ||||
|         todo!(); | ||||
| 
 | ||||
|         manager | ||||
|             .create_table( | ||||
|                 Table::create() | ||||
|                     .table(Post::Table) | ||||
|                     .if_not_exists() | ||||
|                     .col( | ||||
|                         ColumnDef::new(Post::Id) | ||||
|                             .integer() | ||||
|                             .not_null() | ||||
|                             .auto_increment() | ||||
|                             .primary_key(), | ||||
|                     ) | ||||
|                     .col(ColumnDef::new(Post::Title).string().not_null()) | ||||
|                     .col(ColumnDef::new(Post::Text).string().not_null()) | ||||
|                     .to_owned(), | ||||
|             ) | ||||
|             .await | ||||
|     } | ||||
| 
 | ||||
|     async fn down(&self, manager: &SchemaManager) -> Result<(), DbErr> { | ||||
|         // Replace the sample below with your own migration scripts
 | ||||
|         todo!(); | ||||
| 
 | ||||
|         manager | ||||
|             .drop_table(Table::drop().table(Post::Table).to_owned()) | ||||
|             .await | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| #[derive(DeriveIden)] | ||||
| enum Post { | ||||
|     Table, | ||||
|     Id, | ||||
|     Title, | ||||
|     Text, | ||||
| } | ||||
							
								
								
									
										6
									
								
								migration/src/main.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								migration/src/main.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,6 @@ | ||||
| use sea_orm_migration::prelude::*; | ||||
| 
 | ||||
| #[async_std::main] | ||||
| async fn main() { | ||||
|     cli::run_cli(migration::Migrator).await; | ||||
| } | ||||
| @ -1,7 +1,5 @@ | ||||
| use diesel::pg::PgConnection; | ||||
| use diesel::prelude::*; | ||||
| use dotenvy::dotenv; | ||||
| use miniweb::users::models::{NewUser, User}; | ||||
| use miniweb::auth::models::{NewUser, User}; | ||||
| use std::env; | ||||
| use std::io::stdin; | ||||
| 
 | ||||
| @ -18,11 +16,13 @@ pub fn create_user(conn: &mut PgConnection, username: &str) -> User { | ||||
| 
 | ||||
|     let new_user = NewUser { username }; | ||||
| 
 | ||||
|     /* | ||||
|     diesel::insert_into(users::table) | ||||
|         .values(&new_user) | ||||
|         .returning(User::as_returning()) | ||||
|         .get_result(conn) | ||||
|         .expect("Error saving new user") | ||||
|          */ | ||||
| } | ||||
| 
 | ||||
| fn main() { | ||||
|  | ||||
| @ -1,8 +1,5 @@ | ||||
| use diesel::pg::PgConnection; | ||||
| use diesel::prelude::*; | ||||
| use dotenvy::dotenv; | ||||
| use miniweb::schema::users::dsl::*; | ||||
| use miniweb::users::models::User; | ||||
| use miniweb::auth::models::User; | ||||
| use std::env; | ||||
| 
 | ||||
| pub fn establish_connection() -> PgConnection { | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user