Merge pull request '[PR]: feat: rust backend model and utilities' (#10250) from nmkj/calckey:native-model into develop
Reviewed-on: https://codeberg.org/calckey/calckey/pulls/10250
This commit is contained in:
commit
d81af5e991
112 changed files with 6833 additions and 140 deletions
|
@ -27,7 +27,7 @@
|
||||||
"e2e": "start-server-and-test start:test http://localhost:61812 cy:run",
|
"e2e": "start-server-and-test start:test http://localhost:61812 cy:run",
|
||||||
"mocha": "pnpm --filter backend run mocha",
|
"mocha": "pnpm --filter backend run mocha",
|
||||||
"test": "pnpm run mocha",
|
"test": "pnpm run mocha",
|
||||||
"format": "pnpm rome format packages/**/* --write && pnpm --filter client run format",
|
"format": "pnpm rome format packages/**/* --write && pnpm -r run format",
|
||||||
"clean": "pnpm node ./scripts/clean.js",
|
"clean": "pnpm node ./scripts/clean.js",
|
||||||
"clean-all": "pnpm node ./scripts/clean-all.js",
|
"clean-all": "pnpm node ./scripts/clean-all.js",
|
||||||
"cleanall": "pnpm run clean-all"
|
"cleanall": "pnpm run clean-all"
|
||||||
|
|
3
packages/backend/native-utils/.editorconfig
Normal file
3
packages/backend/native-utils/.editorconfig
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
[*.rs]
|
||||||
|
indent_style = space
|
||||||
|
indent_size = 4
|
|
@ -3,13 +3,42 @@ edition = "2021"
|
||||||
name = "native-utils"
|
name = "native-utils"
|
||||||
version = "0.0.0"
|
version = "0.0.0"
|
||||||
|
|
||||||
|
[workspace]
|
||||||
|
members = ["migration"]
|
||||||
|
|
||||||
|
[features]
|
||||||
|
default = []
|
||||||
|
noarray = []
|
||||||
|
napi = ["dep:napi", "dep:napi-derive", "dep:radix_fmt"]
|
||||||
|
|
||||||
[lib]
|
[lib]
|
||||||
crate-type = ["cdylib"]
|
crate-type = ["cdylib", "lib"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
|
async-trait = "0.1.68"
|
||||||
|
cfg-if = "1.0.0"
|
||||||
|
chrono = "0.4.24"
|
||||||
|
cuid2 = "0.1.0"
|
||||||
|
derive_more = "0.99.17"
|
||||||
|
jsonschema = "0.17.0"
|
||||||
|
once_cell = "1.17.1"
|
||||||
|
parse-display = "0.8.0"
|
||||||
|
rand = "0.8.5"
|
||||||
|
schemars = { version = "0.8.12", features = ["chrono"] }
|
||||||
|
sea-orm = { version = "0.11.3", features = ["sqlx-postgres", "postgres-array", "sqlx-sqlite", "runtime-tokio-rustls"] }
|
||||||
|
serde = { version = "1.0.163", features = ["derive"] }
|
||||||
|
serde_json = "1.0.96"
|
||||||
|
thiserror = "1.0.40"
|
||||||
|
tokio = { version = "1.28.1", features = ["full"] }
|
||||||
|
utoipa = "3.3.0"
|
||||||
|
|
||||||
# Default enable napi4 feature, see https://nodejs.org/api/n-api.html#node-api-version-matrix
|
# Default enable napi4 feature, see https://nodejs.org/api/n-api.html#node-api-version-matrix
|
||||||
napi = { version = "2.12.0", default-features = false, features = ["napi4"] }
|
napi = { version = "2.12.0", default-features = false, features = ["napi6", "tokio_rt"], optional = true }
|
||||||
napi-derive = "2.12.0"
|
napi-derive = { version = "2.12.0", optional = true }
|
||||||
|
radix_fmt = { version = "1.0.0", optional = true }
|
||||||
|
|
||||||
|
[dev-dependencies]
|
||||||
|
pretty_assertions = "1.3.0"
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
napi-build = "2.0.1"
|
napi-build = "2.0.1"
|
||||||
|
|
|
@ -1,6 +1,12 @@
|
||||||
import test from "ava";
|
import test from "ava";
|
||||||
|
|
||||||
import { convertId, IdConvertType } from "../built/index.js";
|
import {
|
||||||
|
convertId,
|
||||||
|
IdConvertType,
|
||||||
|
nativeInitIdGenerator,
|
||||||
|
nativeCreateId,
|
||||||
|
nativeRandomStr,
|
||||||
|
} from "../built/index.js";
|
||||||
|
|
||||||
test("convert to mastodon id", (t) => {
|
test("convert to mastodon id", (t) => {
|
||||||
t.is(convertId("9gf61ehcxv", IdConvertType.MastodonId), "960365976481219");
|
t.is(convertId("9gf61ehcxv", IdConvertType.MastodonId), "960365976481219");
|
||||||
|
@ -13,3 +19,14 @@ test("convert to mastodon id", (t) => {
|
||||||
"3494513243013053824",
|
"3494513243013053824",
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test("create cuid2 with timestamp prefix", (t) => {
|
||||||
|
nativeInitIdGenerator(16, "");
|
||||||
|
t.not(nativeCreateId(BigInt(Date.now())), nativeCreateId(BigInt(Date.now())));
|
||||||
|
t.is(nativeCreateId(BigInt(Date.now())).length, 16);
|
||||||
|
});
|
||||||
|
|
||||||
|
test("create random string", (t) => {
|
||||||
|
t.not(nativeRandomStr(16), nativeRandomStr(16));
|
||||||
|
t.is(nativeRandomStr(24).length, 24);
|
||||||
|
});
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
extern crate napi_build;
|
extern crate napi_build;
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
napi_build::setup();
|
napi_build::setup();
|
||||||
}
|
}
|
||||||
|
|
34
packages/backend/native-utils/migration/Cargo.toml
Normal file
34
packages/backend/native-utils/migration/Cargo.toml
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
[package]
|
||||||
|
name = "migration"
|
||||||
|
version = "0.1.0"
|
||||||
|
edition = "2021"
|
||||||
|
publish = false
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
name = "migration"
|
||||||
|
path = "src/lib.rs"
|
||||||
|
|
||||||
|
[features]
|
||||||
|
default = []
|
||||||
|
convert = ["dep:native-utils"]
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
|
async-std = { version = "1", features = ["attributes", "tokio1"] }
|
||||||
|
serde_json = "1.0.96"
|
||||||
|
native-utils = { path = "../", optional = true }
|
||||||
|
indicatif = { version = "0.17.4", features = ["tokio"] }
|
||||||
|
tokio = { version = "1.28.2", features = ["full"] }
|
||||||
|
futures = "0.3.28"
|
||||||
|
serde_yaml = "0.9.21"
|
||||||
|
serde = { version = "1.0.163", features = ["derive"] }
|
||||||
|
|
||||||
|
[dependencies.sea-orm-migration]
|
||||||
|
version = "0.11.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
|
||||||
|
"sqlx-sqlite",
|
||||||
|
]
|
41
packages/backend/native-utils/migration/README.md
Normal file
41
packages/backend/native-utils/migration/README.md
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
# Running Migrator CLI
|
||||||
|
|
||||||
|
- Generate a new migration file
|
||||||
|
```sh
|
||||||
|
cargo run -- migrate 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
packages/backend/native-utils/migration/src/lib.rs
Normal file
12
packages/backend/native-utils/migration/src/lib.rs
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
pub use sea_orm_migration::prelude::*;
|
||||||
|
|
||||||
|
mod m20230531_180824_drop_reversi;
|
||||||
|
|
||||||
|
pub struct Migrator;
|
||||||
|
|
||||||
|
#[async_trait::async_trait]
|
||||||
|
impl MigratorTrait for Migrator {
|
||||||
|
fn migrations() -> Vec<Box<dyn MigrationTrait>> {
|
||||||
|
vec![Box::new(m20230531_180824_drop_reversi::Migration)]
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,51 @@
|
||||||
|
use sea_orm_migration::{
|
||||||
|
prelude::*,
|
||||||
|
sea_orm::{DbBackend, Statement},
|
||||||
|
};
|
||||||
|
|
||||||
|
#[derive(DeriveMigrationName)]
|
||||||
|
pub struct Migration;
|
||||||
|
|
||||||
|
#[async_trait::async_trait]
|
||||||
|
impl MigrationTrait for Migration {
|
||||||
|
async fn up(&self, manager: &SchemaManager) -> Result<(), DbErr> {
|
||||||
|
if manager.get_database_backend() == DbBackend::Sqlite {
|
||||||
|
return Ok(());
|
||||||
|
}
|
||||||
|
|
||||||
|
let db = manager.get_connection();
|
||||||
|
db.query_one(Statement::from_string(
|
||||||
|
DbBackend::Postgres,
|
||||||
|
Table::drop()
|
||||||
|
.table(ReversiGame::Table)
|
||||||
|
.if_exists()
|
||||||
|
.to_string(PostgresQueryBuilder),
|
||||||
|
))
|
||||||
|
.await?;
|
||||||
|
db.query_one(Statement::from_string(
|
||||||
|
DbBackend::Postgres,
|
||||||
|
Table::drop()
|
||||||
|
.table(ReversiMatching::Table)
|
||||||
|
.if_exists()
|
||||||
|
.to_string(PostgresQueryBuilder),
|
||||||
|
))
|
||||||
|
.await?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn down(&self, _manager: &SchemaManager) -> Result<(), DbErr> {
|
||||||
|
// Replace the sample below with your own migration scripts
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Learn more at https://docs.rs/sea-query#iden
|
||||||
|
#[derive(Iden)]
|
||||||
|
enum ReversiGame {
|
||||||
|
Table,
|
||||||
|
}
|
||||||
|
#[derive(Iden)]
|
||||||
|
enum ReversiMatching {
|
||||||
|
Table,
|
||||||
|
}
|
45
packages/backend/native-utils/migration/src/main.rs
Normal file
45
packages/backend/native-utils/migration/src/main.rs
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
use serde::Deserialize;
|
||||||
|
use std::env;
|
||||||
|
use std::fs;
|
||||||
|
|
||||||
|
use sea_orm_migration::prelude::*;
|
||||||
|
|
||||||
|
#[cfg(feature = "convert")]
|
||||||
|
mod vec_to_json;
|
||||||
|
|
||||||
|
#[async_std::main]
|
||||||
|
async fn main() {
|
||||||
|
let cwd = env::current_dir().unwrap();
|
||||||
|
let yml = fs::File::open(cwd.join("../../.config/default.yml"))
|
||||||
|
.expect("Unable to read '.config/default.yml'");
|
||||||
|
let config: Config = serde_yaml::from_reader(yml).expect("Unable to parse");
|
||||||
|
|
||||||
|
env::set_var(
|
||||||
|
"DATABASE_URL",
|
||||||
|
format!(
|
||||||
|
"postgres://{}:{}@{}:{}/{}",
|
||||||
|
config.db.user, config.db.pass, config.db.host, config.db.port, config.db.db
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
cli::run_cli(migration::Migrator).await;
|
||||||
|
|
||||||
|
#[cfg(feature = "convert")]
|
||||||
|
vec_to_json::convert().await;
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, PartialEq, Deserialize)]
|
||||||
|
#[serde(rename = "camelCase")]
|
||||||
|
pub struct Config {
|
||||||
|
pub db: DbConfig,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, PartialEq, Deserialize)]
|
||||||
|
#[serde(rename = "camelCase")]
|
||||||
|
pub struct DbConfig {
|
||||||
|
pub host: String,
|
||||||
|
pub port: u32,
|
||||||
|
pub db: String,
|
||||||
|
pub user: String,
|
||||||
|
pub pass: String,
|
||||||
|
}
|
498
packages/backend/native-utils/migration/src/vec_to_json.rs
Normal file
498
packages/backend/native-utils/migration/src/vec_to_json.rs
Normal file
|
@ -0,0 +1,498 @@
|
||||||
|
use indicatif::{MultiProgress, ProgressBar, ProgressStyle};
|
||||||
|
use native_utils::model::entity::newtype::{I32Vec, StringVec};
|
||||||
|
use sea_orm_migration::{
|
||||||
|
prelude::*,
|
||||||
|
sea_orm::{Database, DbBackend, DbConn, Statement, TryGetable},
|
||||||
|
};
|
||||||
|
use serde_json::json;
|
||||||
|
use std::env;
|
||||||
|
use std::time::Duration;
|
||||||
|
|
||||||
|
pub async fn convert() {
|
||||||
|
let uri = env::var("DATABASE_URL").expect("Environment variable 'DATABASE_URL' not set");
|
||||||
|
|
||||||
|
let db = Database::connect(uri).await.expect("Unable to connect");
|
||||||
|
let mp = MultiProgress::new();
|
||||||
|
|
||||||
|
let handlers = vec![
|
||||||
|
tokio::spawn(to_json::<AccessToken, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
AccessToken::Table,
|
||||||
|
AccessToken::Id,
|
||||||
|
AccessToken::Permission,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Antenna, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Antenna::Table,
|
||||||
|
Antenna::Id,
|
||||||
|
Antenna::Users,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<App, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
App::Table,
|
||||||
|
App::Id,
|
||||||
|
App::Permission,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Emoji, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Emoji::Table,
|
||||||
|
Emoji::Id,
|
||||||
|
Emoji::Aliases,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<GalleryPost, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
GalleryPost::Table,
|
||||||
|
GalleryPost::Id,
|
||||||
|
GalleryPost::FileIds,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<GalleryPost, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
GalleryPost::Table,
|
||||||
|
GalleryPost::Id,
|
||||||
|
GalleryPost::Tags,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Hashtag, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Hashtag::Table,
|
||||||
|
Hashtag::Id,
|
||||||
|
Hashtag::MentionedUserIds,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Hashtag, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Hashtag::Table,
|
||||||
|
Hashtag::Id,
|
||||||
|
Hashtag::MentionedLocalUserIds,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Hashtag, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Hashtag::Table,
|
||||||
|
Hashtag::Id,
|
||||||
|
Hashtag::MentionedRemoteUserIds,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Hashtag, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Hashtag::Table,
|
||||||
|
Hashtag::Id,
|
||||||
|
Hashtag::AttachedUserIds,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Hashtag, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Hashtag::Table,
|
||||||
|
Hashtag::Id,
|
||||||
|
Hashtag::AttachedLocalUserIds,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Hashtag, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Hashtag::Table,
|
||||||
|
Hashtag::Id,
|
||||||
|
Hashtag::AttachedRemoteUserIds,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<MessagingMessage, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
MessagingMessage::Table,
|
||||||
|
MessagingMessage::Id,
|
||||||
|
MessagingMessage::Reads,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Meta, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Meta::Table,
|
||||||
|
Meta::Id,
|
||||||
|
Meta::Langs,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Meta, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Meta::Table,
|
||||||
|
Meta::Id,
|
||||||
|
Meta::BlockedHosts,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Meta, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Meta::Table,
|
||||||
|
Meta::Id,
|
||||||
|
Meta::HiddenTags,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Meta, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Meta::Table,
|
||||||
|
Meta::Id,
|
||||||
|
Meta::PinnedUsers,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Meta, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Meta::Table,
|
||||||
|
Meta::Id,
|
||||||
|
Meta::PinnedPages,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Meta, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Meta::Table,
|
||||||
|
Meta::Id,
|
||||||
|
Meta::RecommendedInstances,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Meta, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Meta::Table,
|
||||||
|
Meta::Id,
|
||||||
|
Meta::SilencedHosts,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Note, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Note::Table,
|
||||||
|
Note::Id,
|
||||||
|
Note::FileIds,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Note, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Note::Table,
|
||||||
|
Note::Id,
|
||||||
|
Note::AttachedFileTypes,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Note, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Note::Table,
|
||||||
|
Note::Id,
|
||||||
|
Note::VisibleUserIds,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Note, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Note::Table,
|
||||||
|
Note::Id,
|
||||||
|
Note::Mentions,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Note, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Note::Table,
|
||||||
|
Note::Id,
|
||||||
|
Note::Emojis,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Note, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Note::Table,
|
||||||
|
Note::Id,
|
||||||
|
Note::Tags,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<NoteEdit, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
NoteEdit::Table,
|
||||||
|
NoteEdit::Id,
|
||||||
|
NoteEdit::FileIds,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Page, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Page::Table,
|
||||||
|
Page::Id,
|
||||||
|
Page::VisibleUserIds,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<RegistryItem, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
RegistryItem::Table,
|
||||||
|
RegistryItem::Id,
|
||||||
|
RegistryItem::Scope,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<User, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
User::Table,
|
||||||
|
User::Id,
|
||||||
|
User::Tags,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<User, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
User::Table,
|
||||||
|
User::Id,
|
||||||
|
User::Emojis,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Webhook, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Webhook::Table,
|
||||||
|
Webhook::Id,
|
||||||
|
Webhook::On,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Poll, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Poll::Table,
|
||||||
|
Poll::NoteId,
|
||||||
|
Poll::Choices,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<Poll, Vec<i32>, I32Vec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
Poll::Table,
|
||||||
|
Poll::NoteId,
|
||||||
|
Poll::Votes,
|
||||||
|
)),
|
||||||
|
tokio::spawn(to_json::<UserProfile, Vec<String>, StringVec>(
|
||||||
|
db.clone(),
|
||||||
|
mp.clone(),
|
||||||
|
UserProfile::Table,
|
||||||
|
UserProfile::UserId,
|
||||||
|
UserProfile::MutingNotificationTypes,
|
||||||
|
)),
|
||||||
|
];
|
||||||
|
|
||||||
|
futures::future::join_all(handlers).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
fn select_query<T: Iden + 'static>(table: T, id: T, col: T) -> String {
|
||||||
|
Query::select()
|
||||||
|
.column(id)
|
||||||
|
.column(col)
|
||||||
|
.from(table)
|
||||||
|
.to_string(PostgresQueryBuilder)
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn get_vec<T: TryGetable>(db: &DbConn, query: String) -> Result<Vec<(String, T)>, DbErr> {
|
||||||
|
let res: Vec<(String, T)> = db
|
||||||
|
.query_all(Statement::from_string(DbBackend::Postgres, query))
|
||||||
|
.await?
|
||||||
|
.iter()
|
||||||
|
.filter_map(|r| r.try_get_many_by_index().ok())
|
||||||
|
.collect();
|
||||||
|
Ok(res)
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn convert_col<T: Iden + Clone + 'static>(
|
||||||
|
db: &DbConn,
|
||||||
|
table: T,
|
||||||
|
col: T,
|
||||||
|
) -> Result<(), DbErr> {
|
||||||
|
let stmt = Table::alter()
|
||||||
|
.table(table)
|
||||||
|
.drop_column(col.to_owned())
|
||||||
|
.add_column(
|
||||||
|
ColumnDef::new(col.to_owned())
|
||||||
|
.json_binary()
|
||||||
|
.not_null()
|
||||||
|
.default(json!([])),
|
||||||
|
)
|
||||||
|
.to_string(PostgresQueryBuilder);
|
||||||
|
db.query_one(Statement::from_string(DbBackend::Postgres, stmt))
|
||||||
|
.await?;
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn to_json<T, U, V>(
|
||||||
|
db: DbConn,
|
||||||
|
mp: MultiProgress,
|
||||||
|
table: T,
|
||||||
|
id: T,
|
||||||
|
col: T,
|
||||||
|
) -> Result<(), DbErr>
|
||||||
|
where
|
||||||
|
T: Iden + Clone + 'static,
|
||||||
|
U: TryGetable + IntoIterator + Clone,
|
||||||
|
V: From<U> + Into<SimpleExpr>,
|
||||||
|
{
|
||||||
|
let query = select_query(table.clone(), id.clone(), col.clone());
|
||||||
|
let loading = ProgressBar::new_spinner()
|
||||||
|
.with_style(ProgressStyle::with_template("{prefix} {msg} {spinner}").unwrap())
|
||||||
|
.with_prefix("[-]")
|
||||||
|
.with_message(format!(
|
||||||
|
"Loading data from {}.{}",
|
||||||
|
table.to_string(),
|
||||||
|
col.to_string()
|
||||||
|
));
|
||||||
|
let loading = mp.add(loading);
|
||||||
|
loading.enable_steady_tick(Duration::from_millis(100));
|
||||||
|
let res = get_vec::<U>(&db, query).await?;
|
||||||
|
let models: Vec<(String, V)> = res
|
||||||
|
.iter()
|
||||||
|
.filter(|(_, r)| r.clone().into_iter().count() > 0)
|
||||||
|
.map(|(id, r)| (id.clone(), <V>::from(r.clone())))
|
||||||
|
.collect();
|
||||||
|
loading.finish_and_clear();
|
||||||
|
convert_col(&db, table.clone(), col.clone()).await?;
|
||||||
|
|
||||||
|
let progress = ProgressBar::new(models.len() as u64)
|
||||||
|
.with_style(
|
||||||
|
ProgressStyle::with_template("{prefix} {msg} {wide_bar} {pos}/{len}")
|
||||||
|
.unwrap()
|
||||||
|
.progress_chars("##-"),
|
||||||
|
)
|
||||||
|
.with_prefix("[*]")
|
||||||
|
.with_message(format!("Copying {}.{}", table.to_string(), col.to_string()));
|
||||||
|
let progress = mp.add(progress);
|
||||||
|
|
||||||
|
for model in models {
|
||||||
|
progress.inc(1);
|
||||||
|
let q = Query::update()
|
||||||
|
.table(table.clone())
|
||||||
|
.values([(col.clone(), model.1.into())])
|
||||||
|
.and_where(Expr::col(id.clone()).eq(model.0))
|
||||||
|
.to_string(PostgresQueryBuilder);
|
||||||
|
db.query_one(Statement::from_string(DbBackend::Postgres, q))
|
||||||
|
.await?;
|
||||||
|
}
|
||||||
|
progress.finish_with_message(format!("Done {}.{}", table.to_string(), col.to_string()));
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum AccessToken {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
Permission,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum Antenna {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
Users,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum App {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
Permission,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum Emoji {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
Aliases,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum GalleryPost {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
#[iden = "fileIds"]
|
||||||
|
FileIds,
|
||||||
|
Tags,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum Hashtag {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
#[iden = "mentionedUserIds"]
|
||||||
|
MentionedUserIds,
|
||||||
|
#[iden = "mentionedLocalUserIds"]
|
||||||
|
MentionedLocalUserIds,
|
||||||
|
#[iden = "mentionedRemoteUserIds"]
|
||||||
|
MentionedRemoteUserIds,
|
||||||
|
#[iden = "attachedUserIds"]
|
||||||
|
AttachedUserIds,
|
||||||
|
#[iden = "attachedLocalUserIds"]
|
||||||
|
AttachedLocalUserIds,
|
||||||
|
#[iden = "attachedRemoteUserIds"]
|
||||||
|
AttachedRemoteUserIds,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum MessagingMessage {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
Reads,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum Meta {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
Langs,
|
||||||
|
#[iden = "hiddenTags"]
|
||||||
|
HiddenTags,
|
||||||
|
#[iden = "blockedHosts"]
|
||||||
|
BlockedHosts,
|
||||||
|
#[iden = "pinnedUsers"]
|
||||||
|
PinnedUsers,
|
||||||
|
#[iden = "pinnedPages"]
|
||||||
|
PinnedPages,
|
||||||
|
#[iden = "recommendedInstances"]
|
||||||
|
RecommendedInstances,
|
||||||
|
#[iden = "silencedHosts"]
|
||||||
|
SilencedHosts,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum Note {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
#[iden = "fileIds"]
|
||||||
|
FileIds,
|
||||||
|
#[iden = "attachedFileTypes"]
|
||||||
|
AttachedFileTypes,
|
||||||
|
#[iden = "visibleUserIds"]
|
||||||
|
VisibleUserIds,
|
||||||
|
Mentions,
|
||||||
|
Emojis,
|
||||||
|
Tags,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum NoteEdit {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
#[iden = "fileIds"]
|
||||||
|
FileIds,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum Page {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
#[iden = "visibleUserIds"]
|
||||||
|
VisibleUserIds,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum Poll {
|
||||||
|
Table,
|
||||||
|
#[iden = "noteId"]
|
||||||
|
NoteId,
|
||||||
|
Choices,
|
||||||
|
Votes, // I32Vec
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum RegistryItem {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
Scope,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum User {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
Tags,
|
||||||
|
Emojis,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum UserProfile {
|
||||||
|
Table,
|
||||||
|
#[iden = "userId"]
|
||||||
|
UserId,
|
||||||
|
#[iden = "mutingNotificationTypes"]
|
||||||
|
MutingNotificationTypes,
|
||||||
|
}
|
||||||
|
#[derive(Iden, Clone)]
|
||||||
|
enum Webhook {
|
||||||
|
Table,
|
||||||
|
Id,
|
||||||
|
On,
|
||||||
|
}
|
|
@ -23,8 +23,8 @@
|
||||||
},
|
},
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@napi-rs/cli": "^2.15.0",
|
"@napi-rs/cli": "2.15.0",
|
||||||
"ava": "^5.1.1"
|
"ava": "5.1.1"
|
||||||
},
|
},
|
||||||
"ava": {
|
"ava": {
|
||||||
"timeout": "3m"
|
"timeout": "3m"
|
||||||
|
@ -34,11 +34,15 @@
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"artifacts": "napi artifacts",
|
"artifacts": "napi artifacts",
|
||||||
"build": "napi build --platform --release ./built/",
|
"build": "napi build --features napi --platform --release ./built/",
|
||||||
"build:debug": "napi build --platform",
|
"build:debug": "napi build --platform",
|
||||||
"prepublishOnly": "napi prepublish -t npm",
|
"prepublishOnly": "napi prepublish -t npm",
|
||||||
"test": "ava",
|
"test": "pnpm run cargo:test && pnpm run build && ava",
|
||||||
"universal": "napi universal",
|
"universal": "napi universal",
|
||||||
"version": "napi version"
|
"version": "napi version",
|
||||||
|
"format": "cargo fmt --all",
|
||||||
|
"cargo:test": "pnpm run cargo:unit && pnpm run cargo:integration",
|
||||||
|
"cargo:unit": "cargo test unit_test && cargo test -F napi unit_test",
|
||||||
|
"cargo:integration": "cargo test -F noarray int_test -- --test-threads=1"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,2 +0,0 @@
|
||||||
tab_spaces = 2
|
|
||||||
edition = "2021"
|
|
13
packages/backend/native-utils/src/database/error.rs
Normal file
13
packages/backend/native-utils/src/database/error.rs
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
use sea_orm::error::DbErr;
|
||||||
|
|
||||||
|
use crate::impl_into_napi_error;
|
||||||
|
|
||||||
|
#[derive(thiserror::Error, Debug, PartialEq, Eq)]
|
||||||
|
pub enum Error {
|
||||||
|
#[error("The database connections have not been initialized yet")]
|
||||||
|
Uninitialized,
|
||||||
|
#[error("ORM error: {0}")]
|
||||||
|
OrmError(#[from] DbErr),
|
||||||
|
}
|
||||||
|
|
||||||
|
impl_into_napi_error!(Error);
|
38
packages/backend/native-utils/src/database/mod.rs
Normal file
38
packages/backend/native-utils/src/database/mod.rs
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
pub mod error;
|
||||||
|
|
||||||
|
use cfg_if::cfg_if;
|
||||||
|
use error::Error;
|
||||||
|
use sea_orm::{Database, DbConn};
|
||||||
|
|
||||||
|
static DB_CONN: once_cell::sync::OnceCell<DbConn> = once_cell::sync::OnceCell::new();
|
||||||
|
|
||||||
|
pub async fn init_database(conn_uri: impl Into<String>) -> Result<(), Error> {
|
||||||
|
let conn = Database::connect(conn_uri.into()).await?;
|
||||||
|
DB_CONN.get_or_init(move || conn);
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn get_database() -> Result<&'static DbConn, Error> {
|
||||||
|
DB_CONN.get().ok_or(Error::Uninitialized)
|
||||||
|
}
|
||||||
|
|
||||||
|
cfg_if! {
|
||||||
|
if #[cfg(feature = "napi")] {
|
||||||
|
use napi_derive::napi;
|
||||||
|
|
||||||
|
#[napi]
|
||||||
|
pub async fn native_init_database(conn_uri: String) -> napi::Result<()> {
|
||||||
|
init_database(conn_uri).await.map_err(Into::into)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod unit_test {
|
||||||
|
use super::{error::Error, get_database};
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn error_uninitialized() {
|
||||||
|
assert_eq!(get_database().unwrap_err(), Error::Uninitialized);
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,2 +1,7 @@
|
||||||
|
pub mod database;
|
||||||
|
pub mod macros;
|
||||||
|
pub mod model;
|
||||||
|
pub mod util;
|
||||||
|
|
||||||
|
#[cfg(feature = "napi")]
|
||||||
pub mod mastodon_api;
|
pub mod mastodon_api;
|
||||||
|
|
11
packages/backend/native-utils/src/macros.rs
Normal file
11
packages/backend/native-utils/src/macros.rs
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
#[macro_export]
|
||||||
|
macro_rules! impl_into_napi_error {
|
||||||
|
($a:ty) => {
|
||||||
|
#[cfg(feature = "napi")]
|
||||||
|
impl Into<napi::Error> for $a {
|
||||||
|
fn into(self) -> napi::Error {
|
||||||
|
napi::Error::from_reason(self.to_string())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
|
@ -7,64 +7,64 @@ static CHAR_COLLECTION: &str = "0123456789abcdefghijklmnopqrstuvwxyz";
|
||||||
|
|
||||||
#[napi]
|
#[napi]
|
||||||
pub enum IdConvertType {
|
pub enum IdConvertType {
|
||||||
MastodonId,
|
MastodonId,
|
||||||
CalckeyId,
|
CalckeyId,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[napi]
|
#[napi]
|
||||||
pub fn convert_id(in_id: String, id_convert_type: IdConvertType) -> napi::Result<String> {
|
pub fn convert_id(in_id: String, id_convert_type: IdConvertType) -> napi::Result<String> {
|
||||||
use IdConvertType::*;
|
use IdConvertType::*;
|
||||||
match id_convert_type {
|
match id_convert_type {
|
||||||
MastodonId => {
|
MastodonId => {
|
||||||
let mut out: i64 = 0;
|
let mut out: i64 = 0;
|
||||||
for (i, c) in in_id.to_lowercase().chars().rev().enumerate() {
|
for (i, c) in in_id.to_lowercase().chars().rev().enumerate() {
|
||||||
out += num_from_char(c)? as i64 * 36_i64.pow(i as u32);
|
out += num_from_char(c)? as i64 * 36_i64.pow(i as u32);
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(out.to_string())
|
Ok(out.to_string())
|
||||||
}
|
|
||||||
CalckeyId => {
|
|
||||||
let mut input: i64 = match in_id.parse() {
|
|
||||||
Ok(s) => s,
|
|
||||||
Err(_) => {
|
|
||||||
return Err(Error::new(
|
|
||||||
Status::InvalidArg,
|
|
||||||
"Unable to parse ID as MasstodonId",
|
|
||||||
))
|
|
||||||
}
|
}
|
||||||
};
|
CalckeyId => {
|
||||||
let mut out = String::new();
|
let mut input: i64 = match in_id.parse() {
|
||||||
|
Ok(s) => s,
|
||||||
|
Err(_) => {
|
||||||
|
return Err(Error::new(
|
||||||
|
Status::InvalidArg,
|
||||||
|
"Unable to parse ID as MasstodonId",
|
||||||
|
))
|
||||||
|
}
|
||||||
|
};
|
||||||
|
let mut out = String::new();
|
||||||
|
|
||||||
while input != 0 {
|
while input != 0 {
|
||||||
out.insert(0, char_from_num((input % 36) as u8)?);
|
out.insert(0, char_from_num((input % 36) as u8)?);
|
||||||
input /= 36;
|
input /= 36;
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(out)
|
Ok(out)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// -- end --
|
// -- end --
|
||||||
|
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
fn num_from_char(character: char) -> napi::Result<u8> {
|
fn num_from_char(character: char) -> napi::Result<u8> {
|
||||||
for (i, c) in CHAR_COLLECTION.chars().enumerate() {
|
for (i, c) in CHAR_COLLECTION.chars().enumerate() {
|
||||||
if c == character {
|
if c == character {
|
||||||
return Ok(i as u8);
|
return Ok(i as u8);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
Err(Error::new(
|
Err(Error::new(
|
||||||
Status::InvalidArg,
|
Status::InvalidArg,
|
||||||
"Invalid character in parsed base36 id",
|
"Invalid character in parsed base36 id",
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
fn char_from_num(number: u8) -> napi::Result<char> {
|
fn char_from_num(number: u8) -> napi::Result<char> {
|
||||||
CHAR_COLLECTION
|
CHAR_COLLECTION
|
||||||
.chars()
|
.chars()
|
||||||
.nth(number as usize)
|
.nth(number as usize)
|
||||||
.ok_or(Error::from_status(Status::Unknown))
|
.ok_or(Error::from_status(Status::Unknown))
|
||||||
}
|
}
|
||||||
|
|
74
packages/backend/native-utils/src/model/entity.rs
Normal file
74
packages/backend/native-utils/src/model/entity.rs
Normal file
|
@ -0,0 +1,74 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
pub mod prelude;
|
||||||
|
|
||||||
|
pub mod abuse_user_report;
|
||||||
|
pub mod access_token;
|
||||||
|
pub mod ad;
|
||||||
|
pub mod announcement;
|
||||||
|
pub mod announcement_read;
|
||||||
|
pub mod antenna;
|
||||||
|
pub mod antenna_note;
|
||||||
|
pub mod app;
|
||||||
|
pub mod attestation_challenge;
|
||||||
|
pub mod auth_session;
|
||||||
|
pub mod blocking;
|
||||||
|
pub mod channel;
|
||||||
|
pub mod channel_following;
|
||||||
|
pub mod channel_note_pining;
|
||||||
|
pub mod clip;
|
||||||
|
pub mod clip_note;
|
||||||
|
pub mod drive_file;
|
||||||
|
pub mod drive_folder;
|
||||||
|
pub mod emoji;
|
||||||
|
pub mod follow_request;
|
||||||
|
pub mod following;
|
||||||
|
pub mod gallery_like;
|
||||||
|
pub mod gallery_post;
|
||||||
|
pub mod hashtag;
|
||||||
|
pub mod instance;
|
||||||
|
pub mod messaging_message;
|
||||||
|
pub mod meta;
|
||||||
|
pub mod migrations;
|
||||||
|
pub mod moderation_log;
|
||||||
|
pub mod muted_note;
|
||||||
|
pub mod muting;
|
||||||
|
pub mod newtype;
|
||||||
|
pub mod note;
|
||||||
|
pub mod note_edit;
|
||||||
|
pub mod note_favorite;
|
||||||
|
pub mod note_reaction;
|
||||||
|
pub mod note_thread_muting;
|
||||||
|
pub mod note_unread;
|
||||||
|
pub mod note_watching;
|
||||||
|
pub mod notification;
|
||||||
|
pub mod page;
|
||||||
|
pub mod page_like;
|
||||||
|
pub mod password_reset_request;
|
||||||
|
pub mod poll;
|
||||||
|
pub mod poll_vote;
|
||||||
|
pub mod promo_note;
|
||||||
|
pub mod promo_read;
|
||||||
|
pub mod registration_ticket;
|
||||||
|
pub mod registry_item;
|
||||||
|
pub mod relay;
|
||||||
|
pub mod renote_muting;
|
||||||
|
pub mod sea_orm_active_enums;
|
||||||
|
pub mod signin;
|
||||||
|
pub mod sw_subscription;
|
||||||
|
pub mod used_username;
|
||||||
|
pub mod user;
|
||||||
|
pub mod user_group;
|
||||||
|
pub mod user_group_invitation;
|
||||||
|
pub mod user_group_invite;
|
||||||
|
pub mod user_group_joining;
|
||||||
|
pub mod user_ip;
|
||||||
|
pub mod user_keypair;
|
||||||
|
pub mod user_list;
|
||||||
|
pub mod user_list_joining;
|
||||||
|
pub mod user_note_pining;
|
||||||
|
pub mod user_pending;
|
||||||
|
pub mod user_profile;
|
||||||
|
pub mod user_publickey;
|
||||||
|
pub mod user_security_key;
|
||||||
|
pub mod webhook;
|
|
@ -0,0 +1,55 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "abuse_user_report")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "targetUserId")]
|
||||||
|
pub target_user_id: String,
|
||||||
|
#[sea_orm(column_name = "reporterId")]
|
||||||
|
pub reporter_id: String,
|
||||||
|
#[sea_orm(column_name = "assigneeId")]
|
||||||
|
pub assignee_id: Option<String>,
|
||||||
|
pub resolved: bool,
|
||||||
|
pub comment: String,
|
||||||
|
#[sea_orm(column_name = "targetUserHost")]
|
||||||
|
pub target_user_host: Option<String>,
|
||||||
|
#[sea_orm(column_name = "reporterHost")]
|
||||||
|
pub reporter_host: Option<String>,
|
||||||
|
pub forwarded: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::ReporterId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User3,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::AssigneeId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "SetNull"
|
||||||
|
)]
|
||||||
|
User2,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::TargetUserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User1,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,71 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "access_token")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
pub token: String,
|
||||||
|
pub hash: String,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "appId")]
|
||||||
|
pub app_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "lastUsedAt")]
|
||||||
|
pub last_used_at: Option<DateTimeWithTimeZone>,
|
||||||
|
pub session: Option<String>,
|
||||||
|
pub name: Option<String>,
|
||||||
|
pub description: Option<String>,
|
||||||
|
#[sea_orm(column_name = "iconUrl")]
|
||||||
|
pub icon_url: Option<String>,
|
||||||
|
pub permission: StringVec,
|
||||||
|
pub fetched: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::app::Entity",
|
||||||
|
from = "Column::AppId",
|
||||||
|
to = "super::app::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
App,
|
||||||
|
#[sea_orm(has_many = "super::notification::Entity")]
|
||||||
|
Notification,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::app::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::App.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::notification::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Notification.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
26
packages/backend/native-utils/src/model/entity/ad.rs
Normal file
26
packages/backend/native-utils/src/model/entity/ad.rs
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "ad")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "expiresAt")]
|
||||||
|
pub expires_at: DateTimeWithTimeZone,
|
||||||
|
pub place: String,
|
||||||
|
pub priority: String,
|
||||||
|
pub url: String,
|
||||||
|
#[sea_orm(column_name = "imageUrl")]
|
||||||
|
pub image_url: String,
|
||||||
|
pub memo: String,
|
||||||
|
pub ratio: i32,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,32 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "announcement")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
pub text: String,
|
||||||
|
pub title: String,
|
||||||
|
#[sea_orm(column_name = "imageUrl")]
|
||||||
|
pub image_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "updatedAt")]
|
||||||
|
pub updated_at: Option<DateTimeWithTimeZone>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::announcement_read::Entity")]
|
||||||
|
AnnouncementRead,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::announcement_read::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::AnnouncementRead.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,50 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "announcement_read")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "announcementId")]
|
||||||
|
pub announcement_id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::announcement::Entity",
|
||||||
|
from = "Column::AnnouncementId",
|
||||||
|
to = "super::announcement::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Announcement,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::announcement::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Announcement.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
92
packages/backend/native-utils/src/model/entity/antenna.rs
Normal file
92
packages/backend/native-utils/src/model/entity/antenna.rs
Normal file
|
@ -0,0 +1,92 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use super::{newtype, sea_orm_active_enums::AntennaSrcEnum};
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "antenna")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
pub name: String,
|
||||||
|
pub src: AntennaSrcEnum,
|
||||||
|
#[sea_orm(column_name = "userListId")]
|
||||||
|
pub user_list_id: Option<String>,
|
||||||
|
#[sea_orm(column_type = "JsonBinary")]
|
||||||
|
pub keywords: newtype::JsonKeyword,
|
||||||
|
#[sea_orm(column_name = "withFile")]
|
||||||
|
pub with_file: bool,
|
||||||
|
pub expression: Option<String>,
|
||||||
|
pub notify: bool,
|
||||||
|
#[sea_orm(column_name = "caseSensitive")]
|
||||||
|
pub case_sensitive: bool,
|
||||||
|
#[sea_orm(column_name = "withReplies")]
|
||||||
|
pub with_replies: bool,
|
||||||
|
#[sea_orm(column_name = "userGroupJoiningId")]
|
||||||
|
pub user_group_joining_id: Option<String>,
|
||||||
|
pub users: newtype::StringVec,
|
||||||
|
#[sea_orm(column_name = "excludeKeywords", column_type = "JsonBinary")]
|
||||||
|
pub exclude_keywords: newtype::JsonKeyword,
|
||||||
|
#[sea_orm(column_type = "JsonBinary")]
|
||||||
|
pub instances: newtype::JsonStringVec,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::antenna_note::Entity")]
|
||||||
|
AntennaNote,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user_group_joining::Entity",
|
||||||
|
from = "Column::UserGroupJoiningId",
|
||||||
|
to = "super::user_group_joining::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
UserGroupJoining,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user_list::Entity",
|
||||||
|
from = "Column::UserListId",
|
||||||
|
to = "super::user_list::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
UserList,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::antenna_note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::AntennaNote.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group_joining::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroupJoining.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_list::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserList.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,49 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "antenna_note")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: String,
|
||||||
|
#[sea_orm(column_name = "antennaId")]
|
||||||
|
pub antenna_id: String,
|
||||||
|
pub read: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::antenna::Entity",
|
||||||
|
from = "Column::AntennaId",
|
||||||
|
to = "super::antenna::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Antenna,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::antenna::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Antenna.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
58
packages/backend/native-utils/src/model/entity/app.rs
Normal file
58
packages/backend/native-utils/src/model/entity/app.rs
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "app")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: Option<String>,
|
||||||
|
pub secret: String,
|
||||||
|
pub name: String,
|
||||||
|
pub description: String,
|
||||||
|
pub permission: StringVec,
|
||||||
|
#[sea_orm(column_name = "callbackUrl")]
|
||||||
|
pub callback_url: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::access_token::Entity")]
|
||||||
|
AccessToken,
|
||||||
|
#[sea_orm(has_many = "super::auth_session::Entity")]
|
||||||
|
AuthSession,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "SetNull"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::access_token::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::AccessToken.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::auth_session::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::AuthSession.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,37 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "attestation_challenge")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "userId", primary_key, auto_increment = false)]
|
||||||
|
pub user_id: String,
|
||||||
|
pub challenge: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "registrationChallenge")]
|
||||||
|
pub registration_challenge: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,51 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "auth_session")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
pub token: String,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "appId")]
|
||||||
|
pub app_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::app::Entity",
|
||||||
|
from = "Column::AppId",
|
||||||
|
to = "super::app::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
App,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::app::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::App.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
38
packages/backend/native-utils/src/model/entity/blocking.rs
Normal file
38
packages/backend/native-utils/src/model/entity/blocking.rs
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "blocking")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "blockeeId")]
|
||||||
|
pub blockee_id: String,
|
||||||
|
#[sea_orm(column_name = "blockerId")]
|
||||||
|
pub blocker_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::BlockerId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User2,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::BlockeeId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User1,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
82
packages/backend/native-utils/src/model/entity/channel.rs
Normal file
82
packages/backend/native-utils/src/model/entity/channel.rs
Normal file
|
@ -0,0 +1,82 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "channel")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "lastNotedAt")]
|
||||||
|
pub last_noted_at: Option<DateTimeWithTimeZone>,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: Option<String>,
|
||||||
|
pub name: String,
|
||||||
|
pub description: Option<String>,
|
||||||
|
#[sea_orm(column_name = "bannerId")]
|
||||||
|
pub banner_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "notesCount")]
|
||||||
|
pub notes_count: i32,
|
||||||
|
#[sea_orm(column_name = "usersCount")]
|
||||||
|
pub users_count: i32,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::channel_following::Entity")]
|
||||||
|
ChannelFollowing,
|
||||||
|
#[sea_orm(has_many = "super::channel_note_pining::Entity")]
|
||||||
|
ChannelNotePining,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::drive_file::Entity",
|
||||||
|
from = "Column::BannerId",
|
||||||
|
to = "super::drive_file::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "SetNull"
|
||||||
|
)]
|
||||||
|
DriveFile,
|
||||||
|
#[sea_orm(has_many = "super::note::Entity")]
|
||||||
|
Note,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "SetNull"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::channel_following::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::ChannelFollowing.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::channel_note_pining::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::ChannelNotePining.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::drive_file::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::DriveFile.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,50 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "channel_following")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "followeeId")]
|
||||||
|
pub followee_id: String,
|
||||||
|
#[sea_orm(column_name = "followerId")]
|
||||||
|
pub follower_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::channel::Entity",
|
||||||
|
from = "Column::FolloweeId",
|
||||||
|
to = "super::channel::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Channel,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::FollowerId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::channel::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Channel.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,50 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "channel_note_pining")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "channelId")]
|
||||||
|
pub channel_id: String,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::channel::Entity",
|
||||||
|
from = "Column::ChannelId",
|
||||||
|
to = "super::channel::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Channel,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::channel::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Channel.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
46
packages/backend/native-utils/src/model/entity/clip.rs
Normal file
46
packages/backend/native-utils/src/model/entity/clip.rs
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "clip")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
pub name: String,
|
||||||
|
#[sea_orm(column_name = "isPublic")]
|
||||||
|
pub is_public: bool,
|
||||||
|
pub description: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::clip_note::Entity")]
|
||||||
|
ClipNote,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::clip_note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::ClipNote.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
48
packages/backend/native-utils/src/model/entity/clip_note.rs
Normal file
48
packages/backend/native-utils/src/model/entity/clip_note.rs
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "clip_note")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: String,
|
||||||
|
#[sea_orm(column_name = "clipId")]
|
||||||
|
pub clip_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::clip::Entity",
|
||||||
|
from = "Column::ClipId",
|
||||||
|
to = "super::clip::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Clip,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::clip::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Clip.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
113
packages/backend/native-utils/src/model/entity/drive_file.rs
Normal file
113
packages/backend/native-utils/src/model/entity/drive_file.rs
Normal file
|
@ -0,0 +1,113 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "drive_file")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "userHost")]
|
||||||
|
pub user_host: Option<String>,
|
||||||
|
pub md5: String,
|
||||||
|
pub name: String,
|
||||||
|
pub r#type: String,
|
||||||
|
pub size: i32,
|
||||||
|
pub comment: Option<String>,
|
||||||
|
#[sea_orm(column_type = "JsonBinary")]
|
||||||
|
pub properties: Json,
|
||||||
|
#[sea_orm(column_name = "storedInternal")]
|
||||||
|
pub stored_internal: bool,
|
||||||
|
pub url: String,
|
||||||
|
#[sea_orm(column_name = "thumbnailUrl")]
|
||||||
|
pub thumbnail_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "webpublicUrl")]
|
||||||
|
pub webpublic_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "accessKey")]
|
||||||
|
pub access_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "thumbnailAccessKey")]
|
||||||
|
pub thumbnail_access_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "webpublicAccessKey")]
|
||||||
|
pub webpublic_access_key: Option<String>,
|
||||||
|
pub uri: Option<String>,
|
||||||
|
pub src: Option<String>,
|
||||||
|
#[sea_orm(column_name = "folderId")]
|
||||||
|
pub folder_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "isSensitive")]
|
||||||
|
pub is_sensitive: bool,
|
||||||
|
#[sea_orm(column_name = "isLink")]
|
||||||
|
pub is_link: bool,
|
||||||
|
pub blurhash: Option<String>,
|
||||||
|
#[sea_orm(column_name = "webpublicType")]
|
||||||
|
pub webpublic_type: Option<String>,
|
||||||
|
#[sea_orm(column_name = "requestHeaders", column_type = "JsonBinary", nullable)]
|
||||||
|
pub request_headers: Option<Json>,
|
||||||
|
#[sea_orm(column_name = "requestIp")]
|
||||||
|
pub request_ip: Option<String>,
|
||||||
|
#[sea_orm(column_name = "maybeSensitive")]
|
||||||
|
pub maybe_sensitive: bool,
|
||||||
|
#[sea_orm(column_name = "maybePorn")]
|
||||||
|
pub maybe_porn: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::channel::Entity")]
|
||||||
|
Channel,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::drive_folder::Entity",
|
||||||
|
from = "Column::FolderId",
|
||||||
|
to = "super::drive_folder::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "SetNull"
|
||||||
|
)]
|
||||||
|
DriveFolder,
|
||||||
|
#[sea_orm(has_many = "super::messaging_message::Entity")]
|
||||||
|
MessagingMessage,
|
||||||
|
#[sea_orm(has_many = "super::page::Entity")]
|
||||||
|
Page,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "SetNull"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::channel::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Channel.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::drive_folder::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::DriveFolder.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::messaging_message::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::MessagingMessage.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::page::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Page.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,53 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "drive_folder")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
pub name: String,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "parentId")]
|
||||||
|
pub parent_id: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::drive_file::Entity")]
|
||||||
|
DriveFile,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "Entity",
|
||||||
|
from = "Column::ParentId",
|
||||||
|
to = "Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "SetNull"
|
||||||
|
)]
|
||||||
|
SelfRef,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::drive_file::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::DriveFile.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
32
packages/backend/native-utils/src/model/entity/emoji.rs
Normal file
32
packages/backend/native-utils/src/model/entity/emoji.rs
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "emoji")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "updatedAt")]
|
||||||
|
pub updated_at: Option<DateTimeWithTimeZone>,
|
||||||
|
pub name: String,
|
||||||
|
pub host: Option<String>,
|
||||||
|
#[sea_orm(column_name = "originalUrl")]
|
||||||
|
pub original_url: String,
|
||||||
|
pub uri: Option<String>,
|
||||||
|
pub r#type: Option<String>,
|
||||||
|
pub aliases: StringVec,
|
||||||
|
pub category: Option<String>,
|
||||||
|
#[sea_orm(column_name = "publicUrl")]
|
||||||
|
pub public_url: String,
|
||||||
|
pub license: Option<String>,
|
||||||
|
pub width: Option<i32>,
|
||||||
|
pub height: Option<i32>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,60 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "follow_request")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "followeeId")]
|
||||||
|
pub followee_id: String,
|
||||||
|
#[sea_orm(column_name = "followerId")]
|
||||||
|
pub follower_id: String,
|
||||||
|
#[sea_orm(column_name = "requestId")]
|
||||||
|
pub request_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "followerHost")]
|
||||||
|
pub follower_host: Option<String>,
|
||||||
|
#[sea_orm(column_name = "followerInbox")]
|
||||||
|
pub follower_inbox: Option<String>,
|
||||||
|
#[sea_orm(column_name = "followerSharedInbox")]
|
||||||
|
pub follower_shared_inbox: Option<String>,
|
||||||
|
#[sea_orm(column_name = "followeeHost")]
|
||||||
|
pub followee_host: Option<String>,
|
||||||
|
#[sea_orm(column_name = "followeeInbox")]
|
||||||
|
pub followee_inbox: Option<String>,
|
||||||
|
#[sea_orm(column_name = "followeeSharedInbox")]
|
||||||
|
pub followee_shared_inbox: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::notification::Entity")]
|
||||||
|
Notification,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::FolloweeId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User2,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::FollowerId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User1,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::notification::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Notification.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
50
packages/backend/native-utils/src/model/entity/following.rs
Normal file
50
packages/backend/native-utils/src/model/entity/following.rs
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "following")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "followeeId")]
|
||||||
|
pub followee_id: String,
|
||||||
|
#[sea_orm(column_name = "followerId")]
|
||||||
|
pub follower_id: String,
|
||||||
|
#[sea_orm(column_name = "followerHost")]
|
||||||
|
pub follower_host: Option<String>,
|
||||||
|
#[sea_orm(column_name = "followerInbox")]
|
||||||
|
pub follower_inbox: Option<String>,
|
||||||
|
#[sea_orm(column_name = "followerSharedInbox")]
|
||||||
|
pub follower_shared_inbox: Option<String>,
|
||||||
|
#[sea_orm(column_name = "followeeHost")]
|
||||||
|
pub followee_host: Option<String>,
|
||||||
|
#[sea_orm(column_name = "followeeInbox")]
|
||||||
|
pub followee_inbox: Option<String>,
|
||||||
|
#[sea_orm(column_name = "followeeSharedInbox")]
|
||||||
|
pub followee_shared_inbox: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::FolloweeId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User2,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::FollowerId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User1,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,50 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "gallery_like")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "postId")]
|
||||||
|
pub post_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::gallery_post::Entity",
|
||||||
|
from = "Column::PostId",
|
||||||
|
to = "super::gallery_post::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
GalleryPost,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::gallery_post::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::GalleryPost.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,55 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "gallery_post")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "updatedAt")]
|
||||||
|
pub updated_at: DateTimeWithTimeZone,
|
||||||
|
pub title: String,
|
||||||
|
pub description: Option<String>,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "fileIds")]
|
||||||
|
pub file_ids: StringVec,
|
||||||
|
#[sea_orm(column_name = "isSensitive")]
|
||||||
|
pub is_sensitive: bool,
|
||||||
|
#[sea_orm(column_name = "likedCount")]
|
||||||
|
pub liked_count: i32,
|
||||||
|
pub tags: StringVec,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::gallery_like::Entity")]
|
||||||
|
GalleryLike,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::gallery_like::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::GalleryLike.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
42
packages/backend/native-utils/src/model/entity/hashtag.rs
Normal file
42
packages/backend/native-utils/src/model/entity/hashtag.rs
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "hashtag")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
pub name: String,
|
||||||
|
#[sea_orm(column_name = "mentionedUserIds")]
|
||||||
|
pub mentioned_user_ids: StringVec,
|
||||||
|
#[sea_orm(column_name = "mentionedUsersCount")]
|
||||||
|
pub mentioned_users_count: i32,
|
||||||
|
#[sea_orm(column_name = "mentionedLocalUserIds")]
|
||||||
|
pub mentioned_local_user_ids: StringVec,
|
||||||
|
#[sea_orm(column_name = "mentionedLocalUsersCount")]
|
||||||
|
pub mentioned_local_users_count: i32,
|
||||||
|
#[sea_orm(column_name = "mentionedRemoteUserIds")]
|
||||||
|
pub mentioned_remote_user_ids: StringVec,
|
||||||
|
#[sea_orm(column_name = "mentionedRemoteUsersCount")]
|
||||||
|
pub mentioned_remote_users_count: i32,
|
||||||
|
#[sea_orm(column_name = "attachedUserIds")]
|
||||||
|
pub attached_user_ids: StringVec,
|
||||||
|
#[sea_orm(column_name = "attachedUsersCount")]
|
||||||
|
pub attached_users_count: i32,
|
||||||
|
#[sea_orm(column_name = "attachedLocalUserIds")]
|
||||||
|
pub attached_local_user_ids: StringVec,
|
||||||
|
#[sea_orm(column_name = "attachedLocalUsersCount")]
|
||||||
|
pub attached_local_users_count: i32,
|
||||||
|
#[sea_orm(column_name = "attachedRemoteUserIds")]
|
||||||
|
pub attached_remote_user_ids: StringVec,
|
||||||
|
#[sea_orm(column_name = "attachedRemoteUsersCount")]
|
||||||
|
pub attached_remote_users_count: i32,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
58
packages/backend/native-utils/src/model/entity/instance.rs
Normal file
58
packages/backend/native-utils/src/model/entity/instance.rs
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "instance")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "caughtAt")]
|
||||||
|
pub caught_at: DateTimeWithTimeZone,
|
||||||
|
pub host: String,
|
||||||
|
#[sea_orm(column_name = "usersCount")]
|
||||||
|
pub users_count: i32,
|
||||||
|
#[sea_orm(column_name = "notesCount")]
|
||||||
|
pub notes_count: i32,
|
||||||
|
#[sea_orm(column_name = "followingCount")]
|
||||||
|
pub following_count: i32,
|
||||||
|
#[sea_orm(column_name = "followersCount")]
|
||||||
|
pub followers_count: i32,
|
||||||
|
#[sea_orm(column_name = "latestRequestSentAt")]
|
||||||
|
pub latest_request_sent_at: Option<DateTimeWithTimeZone>,
|
||||||
|
#[sea_orm(column_name = "latestStatus")]
|
||||||
|
pub latest_status: Option<i32>,
|
||||||
|
#[sea_orm(column_name = "latestRequestReceivedAt")]
|
||||||
|
pub latest_request_received_at: Option<DateTimeWithTimeZone>,
|
||||||
|
#[sea_orm(column_name = "lastCommunicatedAt")]
|
||||||
|
pub last_communicated_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "isNotResponding")]
|
||||||
|
pub is_not_responding: bool,
|
||||||
|
#[sea_orm(column_name = "softwareName")]
|
||||||
|
pub software_name: Option<String>,
|
||||||
|
#[sea_orm(column_name = "softwareVersion")]
|
||||||
|
pub software_version: Option<String>,
|
||||||
|
#[sea_orm(column_name = "openRegistrations")]
|
||||||
|
pub open_registrations: Option<bool>,
|
||||||
|
pub name: Option<String>,
|
||||||
|
pub description: Option<String>,
|
||||||
|
#[sea_orm(column_name = "maintainerName")]
|
||||||
|
pub maintainer_name: Option<String>,
|
||||||
|
#[sea_orm(column_name = "maintainerEmail")]
|
||||||
|
pub maintainer_email: Option<String>,
|
||||||
|
#[sea_orm(column_name = "infoUpdatedAt")]
|
||||||
|
pub info_updated_at: Option<DateTimeWithTimeZone>,
|
||||||
|
#[sea_orm(column_name = "isSuspended")]
|
||||||
|
pub is_suspended: bool,
|
||||||
|
#[sea_orm(column_name = "iconUrl")]
|
||||||
|
pub icon_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "themeColor")]
|
||||||
|
pub theme_color: Option<String>,
|
||||||
|
#[sea_orm(column_name = "faviconUrl")]
|
||||||
|
pub favicon_url: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,77 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "messaging_message")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "recipientId")]
|
||||||
|
pub recipient_id: Option<String>,
|
||||||
|
pub text: Option<String>,
|
||||||
|
#[sea_orm(column_name = "isRead")]
|
||||||
|
pub is_read: bool,
|
||||||
|
#[sea_orm(column_name = "fileId")]
|
||||||
|
pub file_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "groupId")]
|
||||||
|
pub group_id: Option<String>,
|
||||||
|
pub reads: StringVec,
|
||||||
|
pub uri: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::drive_file::Entity",
|
||||||
|
from = "Column::FileId",
|
||||||
|
to = "super::drive_file::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
DriveFile,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User2,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::RecipientId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User1,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user_group::Entity",
|
||||||
|
from = "Column::GroupId",
|
||||||
|
to = "super::user_group::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
UserGroup,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::drive_file::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::DriveFile.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroup.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
212
packages/backend/native-utils/src/model/entity/meta.rs
Normal file
212
packages/backend/native-utils/src/model/entity/meta.rs
Normal file
|
@ -0,0 +1,212 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use super::sea_orm_active_enums::MetaSensitivemediadetectionEnum;
|
||||||
|
use super::sea_orm_active_enums::MetaSensitivemediadetectionsensitivityEnum;
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "meta")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
pub name: Option<String>,
|
||||||
|
pub description: Option<String>,
|
||||||
|
#[sea_orm(column_name = "maintainerName")]
|
||||||
|
pub maintainer_name: Option<String>,
|
||||||
|
#[sea_orm(column_name = "maintainerEmail")]
|
||||||
|
pub maintainer_email: Option<String>,
|
||||||
|
#[sea_orm(column_name = "disableRegistration")]
|
||||||
|
pub disable_registration: bool,
|
||||||
|
#[sea_orm(column_name = "disableLocalTimeline")]
|
||||||
|
pub disable_local_timeline: bool,
|
||||||
|
#[sea_orm(column_name = "disableGlobalTimeline")]
|
||||||
|
pub disable_global_timeline: bool,
|
||||||
|
#[sea_orm(column_name = "useStarForReactionFallback")]
|
||||||
|
pub use_star_for_reaction_fallback: bool,
|
||||||
|
pub langs: StringVec,
|
||||||
|
#[sea_orm(column_name = "hiddenTags")]
|
||||||
|
pub hidden_tags: StringVec,
|
||||||
|
#[sea_orm(column_name = "blockedHosts")]
|
||||||
|
pub blocked_hosts: StringVec,
|
||||||
|
#[sea_orm(column_name = "mascotImageUrl")]
|
||||||
|
pub mascot_image_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "bannerUrl")]
|
||||||
|
pub banner_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "errorImageUrl")]
|
||||||
|
pub error_image_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "iconUrl")]
|
||||||
|
pub icon_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "cacheRemoteFiles")]
|
||||||
|
pub cache_remote_files: bool,
|
||||||
|
#[sea_orm(column_name = "enableRecaptcha")]
|
||||||
|
pub enable_recaptcha: bool,
|
||||||
|
#[sea_orm(column_name = "recaptchaSiteKey")]
|
||||||
|
pub recaptcha_site_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "recaptchaSecretKey")]
|
||||||
|
pub recaptcha_secret_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "localDriveCapacityMb")]
|
||||||
|
pub local_drive_capacity_mb: i32,
|
||||||
|
#[sea_orm(column_name = "remoteDriveCapacityMb")]
|
||||||
|
pub remote_drive_capacity_mb: i32,
|
||||||
|
#[sea_orm(column_name = "summalyProxy")]
|
||||||
|
pub summaly_proxy: Option<String>,
|
||||||
|
#[sea_orm(column_name = "enableEmail")]
|
||||||
|
pub enable_email: bool,
|
||||||
|
pub email: Option<String>,
|
||||||
|
#[sea_orm(column_name = "smtpSecure")]
|
||||||
|
pub smtp_secure: bool,
|
||||||
|
#[sea_orm(column_name = "smtpHost")]
|
||||||
|
pub smtp_host: Option<String>,
|
||||||
|
#[sea_orm(column_name = "smtpPort")]
|
||||||
|
pub smtp_port: Option<i32>,
|
||||||
|
#[sea_orm(column_name = "smtpUser")]
|
||||||
|
pub smtp_user: Option<String>,
|
||||||
|
#[sea_orm(column_name = "smtpPass")]
|
||||||
|
pub smtp_pass: Option<String>,
|
||||||
|
#[sea_orm(column_name = "enableServiceWorker")]
|
||||||
|
pub enable_service_worker: bool,
|
||||||
|
#[sea_orm(column_name = "swPublicKey")]
|
||||||
|
pub sw_public_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "swPrivateKey")]
|
||||||
|
pub sw_private_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "enableTwitterIntegration")]
|
||||||
|
pub enable_twitter_integration: bool,
|
||||||
|
#[sea_orm(column_name = "twitterConsumerKey")]
|
||||||
|
pub twitter_consumer_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "twitterConsumerSecret")]
|
||||||
|
pub twitter_consumer_secret: Option<String>,
|
||||||
|
#[sea_orm(column_name = "enableGithubIntegration")]
|
||||||
|
pub enable_github_integration: bool,
|
||||||
|
#[sea_orm(column_name = "githubClientId")]
|
||||||
|
pub github_client_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "githubClientSecret")]
|
||||||
|
pub github_client_secret: Option<String>,
|
||||||
|
#[sea_orm(column_name = "enableDiscordIntegration")]
|
||||||
|
pub enable_discord_integration: bool,
|
||||||
|
#[sea_orm(column_name = "discordClientId")]
|
||||||
|
pub discord_client_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "discordClientSecret")]
|
||||||
|
pub discord_client_secret: Option<String>,
|
||||||
|
#[sea_orm(column_name = "pinnedUsers")]
|
||||||
|
pub pinned_users: StringVec,
|
||||||
|
#[sea_orm(column_name = "ToSUrl")]
|
||||||
|
pub to_s_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "repositoryUrl")]
|
||||||
|
pub repository_url: String,
|
||||||
|
#[sea_orm(column_name = "feedbackUrl")]
|
||||||
|
pub feedback_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "useObjectStorage")]
|
||||||
|
pub use_object_storage: bool,
|
||||||
|
#[sea_orm(column_name = "objectStorageBucket")]
|
||||||
|
pub object_storage_bucket: Option<String>,
|
||||||
|
#[sea_orm(column_name = "objectStoragePrefix")]
|
||||||
|
pub object_storage_prefix: Option<String>,
|
||||||
|
#[sea_orm(column_name = "objectStorageBaseUrl")]
|
||||||
|
pub object_storage_base_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "objectStorageEndpoint")]
|
||||||
|
pub object_storage_endpoint: Option<String>,
|
||||||
|
#[sea_orm(column_name = "objectStorageRegion")]
|
||||||
|
pub object_storage_region: Option<String>,
|
||||||
|
#[sea_orm(column_name = "objectStorageAccessKey")]
|
||||||
|
pub object_storage_access_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "objectStorageSecretKey")]
|
||||||
|
pub object_storage_secret_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "objectStoragePort")]
|
||||||
|
pub object_storage_port: Option<i32>,
|
||||||
|
#[sea_orm(column_name = "objectStorageUseSSL")]
|
||||||
|
pub object_storage_use_ssl: bool,
|
||||||
|
#[sea_orm(column_name = "proxyAccountId")]
|
||||||
|
pub proxy_account_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "objectStorageUseProxy")]
|
||||||
|
pub object_storage_use_proxy: bool,
|
||||||
|
#[sea_orm(column_name = "enableHcaptcha")]
|
||||||
|
pub enable_hcaptcha: bool,
|
||||||
|
#[sea_orm(column_name = "hcaptchaSiteKey")]
|
||||||
|
pub hcaptcha_site_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "hcaptchaSecretKey")]
|
||||||
|
pub hcaptcha_secret_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "objectStorageSetPublicRead")]
|
||||||
|
pub object_storage_set_public_read: bool,
|
||||||
|
#[sea_orm(column_name = "pinnedPages")]
|
||||||
|
pub pinned_pages: StringVec,
|
||||||
|
#[sea_orm(column_name = "backgroundImageUrl")]
|
||||||
|
pub background_image_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "logoImageUrl")]
|
||||||
|
pub logo_image_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "pinnedClipId")]
|
||||||
|
pub pinned_clip_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "objectStorageS3ForcePathStyle")]
|
||||||
|
pub object_storage_s3_force_path_style: bool,
|
||||||
|
#[sea_orm(column_name = "allowedHosts")]
|
||||||
|
pub allowed_hosts: Option<StringVec>,
|
||||||
|
#[sea_orm(column_name = "secureMode")]
|
||||||
|
pub secure_mode: Option<bool>,
|
||||||
|
#[sea_orm(column_name = "privateMode")]
|
||||||
|
pub private_mode: Option<bool>,
|
||||||
|
#[sea_orm(column_name = "deeplAuthKey")]
|
||||||
|
pub deepl_auth_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "deeplIsPro")]
|
||||||
|
pub deepl_is_pro: bool,
|
||||||
|
#[sea_orm(column_name = "emailRequiredForSignup")]
|
||||||
|
pub email_required_for_signup: bool,
|
||||||
|
#[sea_orm(column_name = "themeColor")]
|
||||||
|
pub theme_color: Option<String>,
|
||||||
|
#[sea_orm(column_name = "defaultLightTheme")]
|
||||||
|
pub default_light_theme: Option<String>,
|
||||||
|
#[sea_orm(column_name = "defaultDarkTheme")]
|
||||||
|
pub default_dark_theme: Option<String>,
|
||||||
|
#[sea_orm(column_name = "sensitiveMediaDetection")]
|
||||||
|
pub sensitive_media_detection: MetaSensitivemediadetectionEnum,
|
||||||
|
#[sea_orm(column_name = "sensitiveMediaDetectionSensitivity")]
|
||||||
|
pub sensitive_media_detection_sensitivity: MetaSensitivemediadetectionsensitivityEnum,
|
||||||
|
#[sea_orm(column_name = "setSensitiveFlagAutomatically")]
|
||||||
|
pub set_sensitive_flag_automatically: bool,
|
||||||
|
#[sea_orm(column_name = "enableIpLogging")]
|
||||||
|
pub enable_ip_logging: bool,
|
||||||
|
#[sea_orm(column_name = "enableSensitiveMediaDetectionForVideos")]
|
||||||
|
pub enable_sensitive_media_detection_for_videos: bool,
|
||||||
|
#[sea_orm(column_name = "enableActiveEmailValidation")]
|
||||||
|
pub enable_active_email_validation: bool,
|
||||||
|
#[sea_orm(column_name = "customMOTD")]
|
||||||
|
pub custom_motd: StringVec,
|
||||||
|
#[sea_orm(column_name = "customSplashIcons")]
|
||||||
|
pub custom_splash_icons: StringVec,
|
||||||
|
#[sea_orm(column_name = "disableRecommendedTimeline")]
|
||||||
|
pub disable_recommended_timeline: bool,
|
||||||
|
#[sea_orm(column_name = "recommendedInstances")]
|
||||||
|
pub recommended_instances: StringVec,
|
||||||
|
#[sea_orm(column_name = "enableGuestTimeline")]
|
||||||
|
pub enable_guest_timeline: bool,
|
||||||
|
#[sea_orm(column_name = "defaultReaction")]
|
||||||
|
pub default_reaction: String,
|
||||||
|
#[sea_orm(column_name = "libreTranslateApiUrl")]
|
||||||
|
pub libre_translate_api_url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "libreTranslateApiKey")]
|
||||||
|
pub libre_translate_api_key: Option<String>,
|
||||||
|
#[sea_orm(column_name = "silencedHosts")]
|
||||||
|
pub silenced_hosts: StringVec,
|
||||||
|
#[sea_orm(column_name = "experimentalFeatures", column_type = "JsonBinary")]
|
||||||
|
pub experimental_features: Json,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::ProxyAccountId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "SetNull"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
17
packages/backend/native-utils/src/model/entity/migrations.rs
Normal file
17
packages/backend/native-utils/src/model/entity/migrations.rs
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "migrations")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key)]
|
||||||
|
pub id: i32,
|
||||||
|
pub timestamp: i64,
|
||||||
|
pub name: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,37 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "moderation_log")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
pub r#type: String,
|
||||||
|
#[sea_orm(column_type = "JsonBinary")]
|
||||||
|
pub info: Json,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
50
packages/backend/native-utils/src/model/entity/muted_note.rs
Normal file
50
packages/backend/native-utils/src/model/entity/muted_note.rs
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use super::sea_orm_active_enums::MutedNoteReasonEnum;
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "muted_note")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: String,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
pub reason: MutedNoteReasonEnum,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
40
packages/backend/native-utils/src/model/entity/muting.rs
Normal file
40
packages/backend/native-utils/src/model/entity/muting.rs
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "muting")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "muteeId")]
|
||||||
|
pub mutee_id: String,
|
||||||
|
#[sea_orm(column_name = "muterId")]
|
||||||
|
pub muter_id: String,
|
||||||
|
#[sea_orm(column_name = "expiresAt")]
|
||||||
|
pub expires_at: Option<DateTimeWithTimeZone>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::MuterId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User2,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::MuteeId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User1,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,51 @@
|
||||||
|
#[macro_export]
|
||||||
|
macro_rules! impl_json_newtype {
|
||||||
|
($a:tt) => {
|
||||||
|
impl From<$a> for Value {
|
||||||
|
fn from(source: $a) -> Self {
|
||||||
|
Value::Json(serde_json::to_value(source).ok().map(Box::new))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl TryGetable for $a {
|
||||||
|
fn try_get_by<I: sea_orm::ColIdx>(
|
||||||
|
res: &QueryResult,
|
||||||
|
idx: I,
|
||||||
|
) -> Result<Self, TryGetError> {
|
||||||
|
let json_value: serde_json::Value =
|
||||||
|
res.try_get_by(idx).map_err(TryGetError::DbErr)?;
|
||||||
|
serde_json::from_value(json_value)
|
||||||
|
.map_err(|e| TryGetError::DbErr(DbErr::Json(e.to_string())))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl sea_query::ValueType for $a {
|
||||||
|
fn try_from(v: Value) -> Result<Self, sea_query::ValueTypeErr> {
|
||||||
|
match v {
|
||||||
|
Value::Json(Some(x)) => Ok($a(
|
||||||
|
serde_json::from_value(*x).map_err(|_| sea_query::ValueTypeErr)?
|
||||||
|
)),
|
||||||
|
_ => Err(sea_query::ValueTypeErr),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn type_name() -> String {
|
||||||
|
stringify!($a).to_owned()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn array_type() -> sea_query::ArrayType {
|
||||||
|
sea_query::ArrayType::Json
|
||||||
|
}
|
||||||
|
|
||||||
|
fn column_type() -> sea_query::ColumnType {
|
||||||
|
sea_query::ColumnType::JsonBinary
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl sea_query::Nullable for $a {
|
||||||
|
fn null() -> Value {
|
||||||
|
Value::Json(None)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
|
@ -0,0 +1,30 @@
|
||||||
|
mod macros;
|
||||||
|
|
||||||
|
use cfg_if::cfg_if;
|
||||||
|
use derive_more::{From, Into};
|
||||||
|
use sea_orm::{sea_query, DbErr, QueryResult, TryGetError, TryGetable, Value};
|
||||||
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
|
use crate::impl_json_newtype;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, Eq, Serialize, Deserialize, From, Into, Default)]
|
||||||
|
pub struct JsonKeyword(pub Vec<Vec<String>>);
|
||||||
|
impl_json_newtype!(JsonKeyword);
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, Eq, Serialize, Deserialize, From, Into, Default)]
|
||||||
|
pub struct JsonStringVec(pub Vec<String>);
|
||||||
|
impl_json_newtype!(JsonStringVec);
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, Eq, Serialize, Deserialize, From, Into, Default)]
|
||||||
|
pub struct JsonI32Vec(pub Vec<i32>);
|
||||||
|
impl_json_newtype!(JsonI32Vec);
|
||||||
|
|
||||||
|
cfg_if! {
|
||||||
|
if #[cfg(feature = "noarray")] {
|
||||||
|
pub type StringVec = JsonStringVec;
|
||||||
|
pub type I32Vec = JsonI32Vec;
|
||||||
|
} else {
|
||||||
|
pub type StringVec = Vec<String>;
|
||||||
|
pub type I32Vec = Vec<i32>;
|
||||||
|
}
|
||||||
|
}
|
236
packages/backend/native-utils/src/model/entity/note.rs
Normal file
236
packages/backend/native-utils/src/model/entity/note.rs
Normal file
|
@ -0,0 +1,236 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use super::sea_orm_active_enums::NoteVisibilityEnum;
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "note")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "replyId")]
|
||||||
|
pub reply_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "renoteId")]
|
||||||
|
pub renote_id: Option<String>,
|
||||||
|
#[sea_orm(column_type = "Text", nullable)]
|
||||||
|
pub text: Option<String>,
|
||||||
|
pub name: Option<String>,
|
||||||
|
pub cw: Option<String>,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "localOnly")]
|
||||||
|
pub local_only: bool,
|
||||||
|
#[sea_orm(column_name = "renoteCount")]
|
||||||
|
pub renote_count: i16,
|
||||||
|
#[sea_orm(column_name = "repliesCount")]
|
||||||
|
pub replies_count: i16,
|
||||||
|
#[sea_orm(column_type = "JsonBinary")]
|
||||||
|
pub reactions: Json,
|
||||||
|
pub visibility: NoteVisibilityEnum,
|
||||||
|
pub uri: Option<String>,
|
||||||
|
pub score: i32,
|
||||||
|
#[sea_orm(column_name = "fileIds")]
|
||||||
|
pub file_ids: StringVec,
|
||||||
|
#[sea_orm(column_name = "attachedFileTypes")]
|
||||||
|
pub attached_file_types: StringVec,
|
||||||
|
#[sea_orm(column_name = "visibleUserIds")]
|
||||||
|
pub visible_user_ids: StringVec,
|
||||||
|
pub mentions: StringVec,
|
||||||
|
#[sea_orm(column_name = "mentionedRemoteUsers", column_type = "Text")]
|
||||||
|
pub mentioned_remote_users: String,
|
||||||
|
pub emojis: StringVec,
|
||||||
|
pub tags: StringVec,
|
||||||
|
#[sea_orm(column_name = "hasPoll")]
|
||||||
|
pub has_poll: bool,
|
||||||
|
#[sea_orm(column_name = "userHost")]
|
||||||
|
pub user_host: Option<String>,
|
||||||
|
#[sea_orm(column_name = "replyUserId")]
|
||||||
|
pub reply_user_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "replyUserHost")]
|
||||||
|
pub reply_user_host: Option<String>,
|
||||||
|
#[sea_orm(column_name = "renoteUserId")]
|
||||||
|
pub renote_user_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "renoteUserHost")]
|
||||||
|
pub renote_user_host: Option<String>,
|
||||||
|
pub url: Option<String>,
|
||||||
|
#[sea_orm(column_name = "channelId")]
|
||||||
|
pub channel_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "threadId")]
|
||||||
|
pub thread_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "updatedAt")]
|
||||||
|
pub updated_at: Option<DateTimeWithTimeZone>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::antenna_note::Entity")]
|
||||||
|
AntennaNote,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::channel::Entity",
|
||||||
|
from = "Column::ChannelId",
|
||||||
|
to = "super::channel::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Channel,
|
||||||
|
#[sea_orm(has_many = "super::channel_note_pining::Entity")]
|
||||||
|
ChannelNotePining,
|
||||||
|
#[sea_orm(has_many = "super::clip_note::Entity")]
|
||||||
|
ClipNote,
|
||||||
|
#[sea_orm(has_many = "super::muted_note::Entity")]
|
||||||
|
MutedNote,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "Entity",
|
||||||
|
from = "Column::ReplyId",
|
||||||
|
to = "Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
SelfRef2,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "Entity",
|
||||||
|
from = "Column::RenoteId",
|
||||||
|
to = "Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
SelfRef1,
|
||||||
|
#[sea_orm(has_many = "super::note_edit::Entity")]
|
||||||
|
NoteEdit,
|
||||||
|
#[sea_orm(has_many = "super::note_favorite::Entity")]
|
||||||
|
NoteFavorite,
|
||||||
|
#[sea_orm(has_many = "super::note_reaction::Entity")]
|
||||||
|
NoteReaction,
|
||||||
|
#[sea_orm(has_many = "super::note_unread::Entity")]
|
||||||
|
NoteUnread,
|
||||||
|
#[sea_orm(has_many = "super::note_watching::Entity")]
|
||||||
|
NoteWatching,
|
||||||
|
#[sea_orm(has_many = "super::notification::Entity")]
|
||||||
|
Notification,
|
||||||
|
#[sea_orm(has_one = "super::poll::Entity")]
|
||||||
|
Poll,
|
||||||
|
#[sea_orm(has_many = "super::poll_vote::Entity")]
|
||||||
|
PollVote,
|
||||||
|
#[sea_orm(has_one = "super::promo_note::Entity")]
|
||||||
|
PromoNote,
|
||||||
|
#[sea_orm(has_many = "super::promo_read::Entity")]
|
||||||
|
PromoRead,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
#[sea_orm(has_many = "super::user_note_pining::Entity")]
|
||||||
|
UserNotePining,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::antenna_note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::AntennaNote.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::channel::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Channel.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::channel_note_pining::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::ChannelNotePining.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::clip_note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::ClipNote.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::muted_note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::MutedNote.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note_edit::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::NoteEdit.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note_favorite::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::NoteFavorite.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note_reaction::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::NoteReaction.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note_unread::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::NoteUnread.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note_watching::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::NoteWatching.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::notification::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Notification.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::poll::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Poll.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::poll_vote::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::PollVote.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::promo_note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::PromoNote.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::promo_read::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::PromoRead.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_note_pining::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserNotePining.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
41
packages/backend/native-utils/src/model/entity/note_edit.rs
Normal file
41
packages/backend/native-utils/src/model/entity/note_edit.rs
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "note_edit")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: String,
|
||||||
|
#[sea_orm(column_type = "Text", nullable)]
|
||||||
|
pub text: Option<String>,
|
||||||
|
pub cw: Option<String>,
|
||||||
|
#[sea_orm(column_name = "fileIds")]
|
||||||
|
pub file_ids: StringVec,
|
||||||
|
#[sea_orm(column_name = "updatedAt")]
|
||||||
|
pub updated_at: DateTimeWithTimeZone,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,50 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "note_favorite")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,51 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "note_reaction")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: String,
|
||||||
|
pub reaction: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,36 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "note_thread_muting")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "threadId")]
|
||||||
|
pub thread_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,56 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "note_unread")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: String,
|
||||||
|
#[sea_orm(column_name = "noteUserId")]
|
||||||
|
pub note_user_id: String,
|
||||||
|
#[sea_orm(column_name = "isSpecified")]
|
||||||
|
pub is_specified: bool,
|
||||||
|
#[sea_orm(column_name = "isMentioned")]
|
||||||
|
pub is_mentioned: bool,
|
||||||
|
#[sea_orm(column_name = "noteChannelId")]
|
||||||
|
pub note_channel_id: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,52 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "note_watching")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: String,
|
||||||
|
#[sea_orm(column_name = "noteUserId")]
|
||||||
|
pub note_user_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
114
packages/backend/native-utils/src/model/entity/notification.rs
Normal file
114
packages/backend/native-utils/src/model/entity/notification.rs
Normal file
|
@ -0,0 +1,114 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use super::sea_orm_active_enums::NotificationTypeEnum;
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "notification")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "notifieeId")]
|
||||||
|
pub notifiee_id: String,
|
||||||
|
#[sea_orm(column_name = "notifierId")]
|
||||||
|
pub notifier_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "isRead")]
|
||||||
|
pub is_read: bool,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: Option<String>,
|
||||||
|
pub reaction: Option<String>,
|
||||||
|
pub choice: Option<i32>,
|
||||||
|
#[sea_orm(column_name = "followRequestId")]
|
||||||
|
pub follow_request_id: Option<String>,
|
||||||
|
pub r#type: NotificationTypeEnum,
|
||||||
|
#[sea_orm(column_name = "userGroupInvitationId")]
|
||||||
|
pub user_group_invitation_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "customBody")]
|
||||||
|
pub custom_body: Option<String>,
|
||||||
|
#[sea_orm(column_name = "customHeader")]
|
||||||
|
pub custom_header: Option<String>,
|
||||||
|
#[sea_orm(column_name = "customIcon")]
|
||||||
|
pub custom_icon: Option<String>,
|
||||||
|
#[sea_orm(column_name = "appAccessTokenId")]
|
||||||
|
pub app_access_token_id: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::access_token::Entity",
|
||||||
|
from = "Column::AppAccessTokenId",
|
||||||
|
to = "super::access_token::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
AccessToken,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::follow_request::Entity",
|
||||||
|
from = "Column::FollowRequestId",
|
||||||
|
to = "super::follow_request::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
FollowRequest,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::NotifierId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User2,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::NotifieeId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User1,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user_group_invitation::Entity",
|
||||||
|
from = "Column::UserGroupInvitationId",
|
||||||
|
to = "super::user_group_invitation::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
UserGroupInvitation,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::access_token::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::AccessToken.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::follow_request::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::FollowRequest.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group_invitation::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroupInvitation.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
91
packages/backend/native-utils/src/model/entity/page.rs
Normal file
91
packages/backend/native-utils/src/model/entity/page.rs
Normal file
|
@ -0,0 +1,91 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use super::sea_orm_active_enums::PageVisibilityEnum;
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "page")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "updatedAt")]
|
||||||
|
pub updated_at: DateTimeWithTimeZone,
|
||||||
|
pub title: String,
|
||||||
|
pub name: String,
|
||||||
|
pub summary: Option<String>,
|
||||||
|
#[sea_orm(column_name = "alignCenter")]
|
||||||
|
pub align_center: bool,
|
||||||
|
pub font: String,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "eyeCatchingImageId")]
|
||||||
|
pub eye_catching_image_id: Option<String>,
|
||||||
|
#[sea_orm(column_type = "JsonBinary")]
|
||||||
|
pub content: Json,
|
||||||
|
#[sea_orm(column_type = "JsonBinary")]
|
||||||
|
pub variables: Json,
|
||||||
|
pub visibility: PageVisibilityEnum,
|
||||||
|
#[sea_orm(column_name = "visibleUserIds")]
|
||||||
|
pub visible_user_ids: StringVec,
|
||||||
|
#[sea_orm(column_name = "likedCount")]
|
||||||
|
pub liked_count: i32,
|
||||||
|
#[sea_orm(column_name = "hideTitleWhenPinned")]
|
||||||
|
pub hide_title_when_pinned: bool,
|
||||||
|
pub script: String,
|
||||||
|
#[sea_orm(column_name = "isPublic")]
|
||||||
|
pub is_public: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::drive_file::Entity",
|
||||||
|
from = "Column::EyeCatchingImageId",
|
||||||
|
to = "super::drive_file::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
DriveFile,
|
||||||
|
#[sea_orm(has_many = "super::page_like::Entity")]
|
||||||
|
PageLike,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
#[sea_orm(has_one = "super::user_profile::Entity")]
|
||||||
|
UserProfile,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::drive_file::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::DriveFile.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::page_like::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::PageLike.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_profile::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserProfile.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
50
packages/backend/native-utils/src/model/entity/page_like.rs
Normal file
50
packages/backend/native-utils/src/model/entity/page_like.rs
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "page_like")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "pageId")]
|
||||||
|
pub page_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::page::Entity",
|
||||||
|
from = "Column::PageId",
|
||||||
|
to = "super::page::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Page,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::page::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Page.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,35 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "password_reset_request")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
pub token: String,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
44
packages/backend/native-utils/src/model/entity/poll.rs
Normal file
44
packages/backend/native-utils/src/model/entity/poll.rs
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use super::sea_orm_active_enums::PollNotevisibilityEnum;
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::{I32Vec, StringVec};
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "poll")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(column_name = "noteId", primary_key, auto_increment = false, unique)]
|
||||||
|
pub note_id: String,
|
||||||
|
#[sea_orm(column_name = "expiresAt")]
|
||||||
|
pub expires_at: Option<DateTimeWithTimeZone>,
|
||||||
|
pub multiple: bool,
|
||||||
|
pub choices: StringVec,
|
||||||
|
pub votes: I32Vec,
|
||||||
|
#[sea_orm(column_name = "noteVisibility")]
|
||||||
|
pub note_visibility: PollNotevisibilityEnum,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "userHost")]
|
||||||
|
pub user_host: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
51
packages/backend/native-utils/src/model/entity/poll_vote.rs
Normal file
51
packages/backend/native-utils/src/model/entity/poll_vote.rs
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "poll_vote")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: String,
|
||||||
|
pub choice: i32,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
70
packages/backend/native-utils/src/model/entity/prelude.rs
Normal file
70
packages/backend/native-utils/src/model/entity/prelude.rs
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
pub use super::abuse_user_report::Entity as AbuseUserReport;
|
||||||
|
pub use super::access_token::Entity as AccessToken;
|
||||||
|
pub use super::ad::Entity as Ad;
|
||||||
|
pub use super::announcement::Entity as Announcement;
|
||||||
|
pub use super::announcement_read::Entity as AnnouncementRead;
|
||||||
|
pub use super::antenna::Entity as Antenna;
|
||||||
|
pub use super::antenna_note::Entity as AntennaNote;
|
||||||
|
pub use super::app::Entity as App;
|
||||||
|
pub use super::attestation_challenge::Entity as AttestationChallenge;
|
||||||
|
pub use super::auth_session::Entity as AuthSession;
|
||||||
|
pub use super::blocking::Entity as Blocking;
|
||||||
|
pub use super::channel::Entity as Channel;
|
||||||
|
pub use super::channel_following::Entity as ChannelFollowing;
|
||||||
|
pub use super::channel_note_pining::Entity as ChannelNotePining;
|
||||||
|
pub use super::clip::Entity as Clip;
|
||||||
|
pub use super::clip_note::Entity as ClipNote;
|
||||||
|
pub use super::drive_file::Entity as DriveFile;
|
||||||
|
pub use super::drive_folder::Entity as DriveFolder;
|
||||||
|
pub use super::emoji::Entity as Emoji;
|
||||||
|
pub use super::follow_request::Entity as FollowRequest;
|
||||||
|
pub use super::following::Entity as Following;
|
||||||
|
pub use super::gallery_like::Entity as GalleryLike;
|
||||||
|
pub use super::gallery_post::Entity as GalleryPost;
|
||||||
|
pub use super::hashtag::Entity as Hashtag;
|
||||||
|
pub use super::instance::Entity as Instance;
|
||||||
|
pub use super::messaging_message::Entity as MessagingMessage;
|
||||||
|
pub use super::meta::Entity as Meta;
|
||||||
|
pub use super::migrations::Entity as Migrations;
|
||||||
|
pub use super::moderation_log::Entity as ModerationLog;
|
||||||
|
pub use super::muted_note::Entity as MutedNote;
|
||||||
|
pub use super::muting::Entity as Muting;
|
||||||
|
pub use super::note::Entity as Note;
|
||||||
|
pub use super::note_edit::Entity as NoteEdit;
|
||||||
|
pub use super::note_favorite::Entity as NoteFavorite;
|
||||||
|
pub use super::note_reaction::Entity as NoteReaction;
|
||||||
|
pub use super::note_thread_muting::Entity as NoteThreadMuting;
|
||||||
|
pub use super::note_unread::Entity as NoteUnread;
|
||||||
|
pub use super::note_watching::Entity as NoteWatching;
|
||||||
|
pub use super::notification::Entity as Notification;
|
||||||
|
pub use super::page::Entity as Page;
|
||||||
|
pub use super::page_like::Entity as PageLike;
|
||||||
|
pub use super::password_reset_request::Entity as PasswordResetRequest;
|
||||||
|
pub use super::poll::Entity as Poll;
|
||||||
|
pub use super::poll_vote::Entity as PollVote;
|
||||||
|
pub use super::promo_note::Entity as PromoNote;
|
||||||
|
pub use super::promo_read::Entity as PromoRead;
|
||||||
|
pub use super::registration_ticket::Entity as RegistrationTicket;
|
||||||
|
pub use super::registry_item::Entity as RegistryItem;
|
||||||
|
pub use super::relay::Entity as Relay;
|
||||||
|
pub use super::renote_muting::Entity as RenoteMuting;
|
||||||
|
pub use super::signin::Entity as Signin;
|
||||||
|
pub use super::sw_subscription::Entity as SwSubscription;
|
||||||
|
pub use super::used_username::Entity as UsedUsername;
|
||||||
|
pub use super::user::Entity as User;
|
||||||
|
pub use super::user_group::Entity as UserGroup;
|
||||||
|
pub use super::user_group_invitation::Entity as UserGroupInvitation;
|
||||||
|
pub use super::user_group_invite::Entity as UserGroupInvite;
|
||||||
|
pub use super::user_group_joining::Entity as UserGroupJoining;
|
||||||
|
pub use super::user_ip::Entity as UserIp;
|
||||||
|
pub use super::user_keypair::Entity as UserKeypair;
|
||||||
|
pub use super::user_list::Entity as UserList;
|
||||||
|
pub use super::user_list_joining::Entity as UserListJoining;
|
||||||
|
pub use super::user_note_pining::Entity as UserNotePining;
|
||||||
|
pub use super::user_pending::Entity as UserPending;
|
||||||
|
pub use super::user_profile::Entity as UserProfile;
|
||||||
|
pub use super::user_publickey::Entity as UserPublickey;
|
||||||
|
pub use super::user_security_key::Entity as UserSecurityKey;
|
||||||
|
pub use super::webhook::Entity as Webhook;
|
34
packages/backend/native-utils/src/model/entity/promo_note.rs
Normal file
34
packages/backend/native-utils/src/model/entity/promo_note.rs
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "promo_note")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(column_name = "noteId", primary_key, auto_increment = false, unique)]
|
||||||
|
pub note_id: String,
|
||||||
|
#[sea_orm(column_name = "expiresAt")]
|
||||||
|
pub expires_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
50
packages/backend/native-utils/src/model/entity/promo_read.rs
Normal file
50
packages/backend/native-utils/src/model/entity/promo_read.rs
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "promo_read")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,18 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "registration_ticket")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
pub code: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,43 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "registry_item")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "updatedAt")]
|
||||||
|
pub updated_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
pub key: String,
|
||||||
|
pub scope: StringVec,
|
||||||
|
pub domain: Option<String>,
|
||||||
|
#[sea_orm(column_type = "JsonBinary", nullable)]
|
||||||
|
pub value: Option<Json>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
18
packages/backend/native-utils/src/model/entity/relay.rs
Normal file
18
packages/backend/native-utils/src/model/entity/relay.rs
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use super::sea_orm_active_enums::RelayStatusEnum;
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "relay")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
pub inbox: String,
|
||||||
|
pub status: RelayStatusEnum,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,21 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "renote_muting")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "muteeId")]
|
||||||
|
pub mutee_id: String,
|
||||||
|
#[sea_orm(column_name = "muterId")]
|
||||||
|
pub muter_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,184 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, EnumIter, DeriveActiveEnum, Default)]
|
||||||
|
#[sea_orm(rs_type = "String", db_type = "Enum", enum_name = "antenna_src_enum")]
|
||||||
|
pub enum AntennaSrcEnum {
|
||||||
|
#[default]
|
||||||
|
#[sea_orm(string_value = "all")]
|
||||||
|
All,
|
||||||
|
#[sea_orm(string_value = "group")]
|
||||||
|
Group,
|
||||||
|
#[sea_orm(string_value = "home")]
|
||||||
|
Home,
|
||||||
|
#[sea_orm(string_value = "instances")]
|
||||||
|
Instances,
|
||||||
|
#[sea_orm(string_value = "list")]
|
||||||
|
List,
|
||||||
|
#[sea_orm(string_value = "users")]
|
||||||
|
Users,
|
||||||
|
}
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, EnumIter, DeriveActiveEnum, Default)]
|
||||||
|
#[sea_orm(
|
||||||
|
rs_type = "String",
|
||||||
|
db_type = "Enum",
|
||||||
|
enum_name = "meta_sensitivemediadetection_enum"
|
||||||
|
)]
|
||||||
|
pub enum MetaSensitivemediadetectionEnum {
|
||||||
|
#[default]
|
||||||
|
#[sea_orm(string_value = "all")]
|
||||||
|
All,
|
||||||
|
#[sea_orm(string_value = "local")]
|
||||||
|
Local,
|
||||||
|
#[sea_orm(string_value = "none")]
|
||||||
|
None,
|
||||||
|
#[sea_orm(string_value = "remote")]
|
||||||
|
Remote,
|
||||||
|
}
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, EnumIter, DeriveActiveEnum, Default)]
|
||||||
|
#[sea_orm(
|
||||||
|
rs_type = "String",
|
||||||
|
db_type = "Enum",
|
||||||
|
enum_name = "meta_sensitivemediadetectionsensitivity_enum"
|
||||||
|
)]
|
||||||
|
pub enum MetaSensitivemediadetectionsensitivityEnum {
|
||||||
|
#[sea_orm(string_value = "high")]
|
||||||
|
High,
|
||||||
|
#[sea_orm(string_value = "low")]
|
||||||
|
Low,
|
||||||
|
#[default]
|
||||||
|
#[sea_orm(string_value = "medium")]
|
||||||
|
Medium,
|
||||||
|
#[sea_orm(string_value = "veryHigh")]
|
||||||
|
VeryHigh,
|
||||||
|
#[sea_orm(string_value = "veryLow")]
|
||||||
|
VeryLow,
|
||||||
|
}
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, EnumIter, DeriveActiveEnum, Default)]
|
||||||
|
#[sea_orm(
|
||||||
|
rs_type = "String",
|
||||||
|
db_type = "Enum",
|
||||||
|
enum_name = "muted_note_reason_enum"
|
||||||
|
)]
|
||||||
|
pub enum MutedNoteReasonEnum {
|
||||||
|
#[default]
|
||||||
|
#[sea_orm(string_value = "manual")]
|
||||||
|
Manual,
|
||||||
|
#[sea_orm(string_value = "other")]
|
||||||
|
Other,
|
||||||
|
#[sea_orm(string_value = "spam")]
|
||||||
|
Spam,
|
||||||
|
#[sea_orm(string_value = "word")]
|
||||||
|
Word,
|
||||||
|
}
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, EnumIter, DeriveActiveEnum, Default)]
|
||||||
|
#[sea_orm(
|
||||||
|
rs_type = "String",
|
||||||
|
db_type = "Enum",
|
||||||
|
enum_name = "note_visibility_enum"
|
||||||
|
)]
|
||||||
|
pub enum NoteVisibilityEnum {
|
||||||
|
#[sea_orm(string_value = "followers")]
|
||||||
|
Followers,
|
||||||
|
#[sea_orm(string_value = "hidden")]
|
||||||
|
Hidden,
|
||||||
|
#[sea_orm(string_value = "home")]
|
||||||
|
Home,
|
||||||
|
#[default]
|
||||||
|
#[sea_orm(string_value = "public")]
|
||||||
|
Public,
|
||||||
|
#[sea_orm(string_value = "specified")]
|
||||||
|
Specified,
|
||||||
|
}
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, EnumIter, DeriveActiveEnum, Default)]
|
||||||
|
#[sea_orm(
|
||||||
|
rs_type = "String",
|
||||||
|
db_type = "Enum",
|
||||||
|
enum_name = "notification_type_enum"
|
||||||
|
)]
|
||||||
|
pub enum NotificationTypeEnum {
|
||||||
|
#[sea_orm(string_value = "app")]
|
||||||
|
App,
|
||||||
|
#[sea_orm(string_value = "follow")]
|
||||||
|
Follow,
|
||||||
|
#[sea_orm(string_value = "followRequestAccepted")]
|
||||||
|
FollowRequestAccepted,
|
||||||
|
#[sea_orm(string_value = "groupInvited")]
|
||||||
|
GroupInvited,
|
||||||
|
#[sea_orm(string_value = "mention")]
|
||||||
|
Mention,
|
||||||
|
#[sea_orm(string_value = "pollEnded")]
|
||||||
|
PollEnded,
|
||||||
|
#[sea_orm(string_value = "pollVote")]
|
||||||
|
PollVote,
|
||||||
|
#[sea_orm(string_value = "quote")]
|
||||||
|
Quote,
|
||||||
|
#[sea_orm(string_value = "reaction")]
|
||||||
|
Reaction,
|
||||||
|
#[sea_orm(string_value = "receiveFollowRequest")]
|
||||||
|
ReceiveFollowRequest,
|
||||||
|
#[sea_orm(string_value = "renote")]
|
||||||
|
Renote,
|
||||||
|
#[default]
|
||||||
|
#[sea_orm(string_value = "reply")]
|
||||||
|
Reply,
|
||||||
|
}
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, EnumIter, DeriveActiveEnum, Default)]
|
||||||
|
#[sea_orm(
|
||||||
|
rs_type = "String",
|
||||||
|
db_type = "Enum",
|
||||||
|
enum_name = "page_visibility_enum"
|
||||||
|
)]
|
||||||
|
pub enum PageVisibilityEnum {
|
||||||
|
#[sea_orm(string_value = "followers")]
|
||||||
|
Followers,
|
||||||
|
#[default]
|
||||||
|
#[sea_orm(string_value = "public")]
|
||||||
|
Public,
|
||||||
|
#[sea_orm(string_value = "specified")]
|
||||||
|
Specified,
|
||||||
|
}
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, EnumIter, DeriveActiveEnum, Default)]
|
||||||
|
#[sea_orm(
|
||||||
|
rs_type = "String",
|
||||||
|
db_type = "Enum",
|
||||||
|
enum_name = "poll_notevisibility_enum"
|
||||||
|
)]
|
||||||
|
pub enum PollNotevisibilityEnum {
|
||||||
|
#[sea_orm(string_value = "followers")]
|
||||||
|
Followers,
|
||||||
|
#[sea_orm(string_value = "home")]
|
||||||
|
Home,
|
||||||
|
#[default]
|
||||||
|
#[sea_orm(string_value = "public")]
|
||||||
|
Public,
|
||||||
|
#[sea_orm(string_value = "specified")]
|
||||||
|
Specified,
|
||||||
|
}
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, EnumIter, DeriveActiveEnum, Default)]
|
||||||
|
#[sea_orm(rs_type = "String", db_type = "Enum", enum_name = "relay_status_enum")]
|
||||||
|
pub enum RelayStatusEnum {
|
||||||
|
#[sea_orm(string_value = "accepted")]
|
||||||
|
Accepted,
|
||||||
|
#[sea_orm(string_value = "rejected")]
|
||||||
|
Rejected,
|
||||||
|
#[default]
|
||||||
|
#[sea_orm(string_value = "requesting")]
|
||||||
|
Requesting,
|
||||||
|
}
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, EnumIter, DeriveActiveEnum, Default)]
|
||||||
|
#[sea_orm(
|
||||||
|
rs_type = "String",
|
||||||
|
db_type = "Enum",
|
||||||
|
enum_name = "user_profile_ffvisibility_enum"
|
||||||
|
)]
|
||||||
|
pub enum UserProfileFfvisibilityEnum {
|
||||||
|
#[sea_orm(string_value = "followers")]
|
||||||
|
Followers,
|
||||||
|
#[sea_orm(string_value = "private")]
|
||||||
|
Private,
|
||||||
|
#[default]
|
||||||
|
#[sea_orm(string_value = "public")]
|
||||||
|
Public,
|
||||||
|
}
|
38
packages/backend/native-utils/src/model/entity/signin.rs
Normal file
38
packages/backend/native-utils/src/model/entity/signin.rs
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "signin")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
pub ip: String,
|
||||||
|
#[sea_orm(column_type = "JsonBinary")]
|
||||||
|
pub headers: Json,
|
||||||
|
pub success: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,39 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "sw_subscription")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
pub endpoint: String,
|
||||||
|
pub auth: String,
|
||||||
|
pub publickey: String,
|
||||||
|
#[sea_orm(column_name = "sendReadMessage")]
|
||||||
|
pub send_read_message: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,17 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "used_username")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub username: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
426
packages/backend/native-utils/src/model/entity/user.rs
Normal file
426
packages/backend/native-utils/src/model/entity/user.rs
Normal file
|
@ -0,0 +1,426 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "updatedAt")]
|
||||||
|
pub updated_at: Option<DateTimeWithTimeZone>,
|
||||||
|
#[sea_orm(column_name = "lastFetchedAt")]
|
||||||
|
pub last_fetched_at: Option<DateTimeWithTimeZone>,
|
||||||
|
pub username: String,
|
||||||
|
#[sea_orm(column_name = "usernameLower")]
|
||||||
|
pub username_lower: String,
|
||||||
|
pub name: Option<String>,
|
||||||
|
#[sea_orm(column_name = "followersCount")]
|
||||||
|
pub followers_count: i32,
|
||||||
|
#[sea_orm(column_name = "followingCount")]
|
||||||
|
pub following_count: i32,
|
||||||
|
#[sea_orm(column_name = "notesCount")]
|
||||||
|
pub notes_count: i32,
|
||||||
|
#[sea_orm(column_name = "avatarId", unique)]
|
||||||
|
pub avatar_id: Option<String>,
|
||||||
|
#[sea_orm(column_name = "bannerId", unique)]
|
||||||
|
pub banner_id: Option<String>,
|
||||||
|
pub tags: StringVec,
|
||||||
|
#[sea_orm(column_name = "isSuspended")]
|
||||||
|
pub is_suspended: bool,
|
||||||
|
#[sea_orm(column_name = "isSilenced")]
|
||||||
|
pub is_silenced: bool,
|
||||||
|
#[sea_orm(column_name = "isLocked")]
|
||||||
|
pub is_locked: bool,
|
||||||
|
#[sea_orm(column_name = "isBot")]
|
||||||
|
pub is_bot: bool,
|
||||||
|
#[sea_orm(column_name = "isCat")]
|
||||||
|
pub is_cat: bool,
|
||||||
|
#[sea_orm(column_name = "isAdmin")]
|
||||||
|
pub is_admin: bool,
|
||||||
|
#[sea_orm(column_name = "isModerator")]
|
||||||
|
pub is_moderator: bool,
|
||||||
|
pub emojis: StringVec,
|
||||||
|
pub host: Option<String>,
|
||||||
|
pub inbox: Option<String>,
|
||||||
|
#[sea_orm(column_name = "sharedInbox")]
|
||||||
|
pub shared_inbox: Option<String>,
|
||||||
|
pub featured: Option<String>,
|
||||||
|
pub uri: Option<String>,
|
||||||
|
#[sea_orm(unique)]
|
||||||
|
pub token: Option<String>,
|
||||||
|
#[sea_orm(column_name = "isExplorable")]
|
||||||
|
pub is_explorable: bool,
|
||||||
|
#[sea_orm(column_name = "followersUri")]
|
||||||
|
pub followers_uri: Option<String>,
|
||||||
|
#[sea_orm(column_name = "lastActiveDate")]
|
||||||
|
pub last_active_date: Option<DateTimeWithTimeZone>,
|
||||||
|
#[sea_orm(column_name = "hideOnlineStatus")]
|
||||||
|
pub hide_online_status: bool,
|
||||||
|
#[sea_orm(column_name = "isDeleted")]
|
||||||
|
pub is_deleted: bool,
|
||||||
|
#[sea_orm(column_name = "showTimelineReplies")]
|
||||||
|
pub show_timeline_replies: bool,
|
||||||
|
#[sea_orm(column_name = "driveCapacityOverrideMb")]
|
||||||
|
pub drive_capacity_override_mb: Option<i32>,
|
||||||
|
#[sea_orm(column_name = "movedToUri")]
|
||||||
|
pub moved_to_uri: Option<String>,
|
||||||
|
#[sea_orm(column_name = "alsoKnownAs", column_type = "Text", nullable)]
|
||||||
|
pub also_known_as: Option<String>,
|
||||||
|
#[sea_orm(column_name = "speakAsCat")]
|
||||||
|
pub speak_as_cat: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::access_token::Entity")]
|
||||||
|
AccessToken,
|
||||||
|
#[sea_orm(has_many = "super::announcement_read::Entity")]
|
||||||
|
AnnouncementRead,
|
||||||
|
#[sea_orm(has_many = "super::antenna::Entity")]
|
||||||
|
Antenna,
|
||||||
|
#[sea_orm(has_many = "super::app::Entity")]
|
||||||
|
App,
|
||||||
|
#[sea_orm(has_many = "super::attestation_challenge::Entity")]
|
||||||
|
AttestationChallenge,
|
||||||
|
#[sea_orm(has_many = "super::auth_session::Entity")]
|
||||||
|
AuthSession,
|
||||||
|
#[sea_orm(has_many = "super::channel::Entity")]
|
||||||
|
Channel,
|
||||||
|
#[sea_orm(has_many = "super::channel_following::Entity")]
|
||||||
|
ChannelFollowing,
|
||||||
|
#[sea_orm(has_many = "super::clip::Entity")]
|
||||||
|
Clip,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::drive_file::Entity",
|
||||||
|
from = "Column::AvatarId",
|
||||||
|
to = "super::drive_file::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "SetNull"
|
||||||
|
)]
|
||||||
|
DriveFile2,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::drive_file::Entity",
|
||||||
|
from = "Column::BannerId",
|
||||||
|
to = "super::drive_file::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "SetNull"
|
||||||
|
)]
|
||||||
|
DriveFile1,
|
||||||
|
#[sea_orm(has_many = "super::drive_folder::Entity")]
|
||||||
|
DriveFolder,
|
||||||
|
#[sea_orm(has_many = "super::gallery_like::Entity")]
|
||||||
|
GalleryLike,
|
||||||
|
#[sea_orm(has_many = "super::gallery_post::Entity")]
|
||||||
|
GalleryPost,
|
||||||
|
#[sea_orm(has_many = "super::meta::Entity")]
|
||||||
|
Meta,
|
||||||
|
#[sea_orm(has_many = "super::moderation_log::Entity")]
|
||||||
|
ModerationLog,
|
||||||
|
#[sea_orm(has_many = "super::muted_note::Entity")]
|
||||||
|
MutedNote,
|
||||||
|
#[sea_orm(has_many = "super::note::Entity")]
|
||||||
|
Note,
|
||||||
|
#[sea_orm(has_many = "super::note_favorite::Entity")]
|
||||||
|
NoteFavorite,
|
||||||
|
#[sea_orm(has_many = "super::note_reaction::Entity")]
|
||||||
|
NoteReaction,
|
||||||
|
#[sea_orm(has_many = "super::note_thread_muting::Entity")]
|
||||||
|
NoteThreadMuting,
|
||||||
|
#[sea_orm(has_many = "super::note_unread::Entity")]
|
||||||
|
NoteUnread,
|
||||||
|
#[sea_orm(has_many = "super::note_watching::Entity")]
|
||||||
|
NoteWatching,
|
||||||
|
#[sea_orm(has_many = "super::page::Entity")]
|
||||||
|
Page,
|
||||||
|
#[sea_orm(has_many = "super::page_like::Entity")]
|
||||||
|
PageLike,
|
||||||
|
#[sea_orm(has_many = "super::password_reset_request::Entity")]
|
||||||
|
PasswordResetRequest,
|
||||||
|
#[sea_orm(has_many = "super::poll_vote::Entity")]
|
||||||
|
PollVote,
|
||||||
|
#[sea_orm(has_many = "super::promo_read::Entity")]
|
||||||
|
PromoRead,
|
||||||
|
#[sea_orm(has_many = "super::registry_item::Entity")]
|
||||||
|
RegistryItem,
|
||||||
|
#[sea_orm(has_many = "super::signin::Entity")]
|
||||||
|
Signin,
|
||||||
|
#[sea_orm(has_many = "super::sw_subscription::Entity")]
|
||||||
|
SwSubscription,
|
||||||
|
#[sea_orm(has_many = "super::user_group::Entity")]
|
||||||
|
UserGroup,
|
||||||
|
#[sea_orm(has_many = "super::user_group_invitation::Entity")]
|
||||||
|
UserGroupInvitation,
|
||||||
|
#[sea_orm(has_many = "super::user_group_invite::Entity")]
|
||||||
|
UserGroupInvite,
|
||||||
|
#[sea_orm(has_many = "super::user_group_joining::Entity")]
|
||||||
|
UserGroupJoining,
|
||||||
|
#[sea_orm(has_one = "super::user_keypair::Entity")]
|
||||||
|
UserKeypair,
|
||||||
|
#[sea_orm(has_many = "super::user_list::Entity")]
|
||||||
|
UserList,
|
||||||
|
#[sea_orm(has_many = "super::user_list_joining::Entity")]
|
||||||
|
UserListJoining,
|
||||||
|
#[sea_orm(has_many = "super::user_note_pining::Entity")]
|
||||||
|
UserNotePining,
|
||||||
|
#[sea_orm(has_one = "super::user_profile::Entity")]
|
||||||
|
UserProfile,
|
||||||
|
#[sea_orm(has_one = "super::user_publickey::Entity")]
|
||||||
|
UserPublickey,
|
||||||
|
#[sea_orm(has_many = "super::user_security_key::Entity")]
|
||||||
|
UserSecurityKey,
|
||||||
|
#[sea_orm(has_many = "super::webhook::Entity")]
|
||||||
|
Webhook,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::access_token::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::AccessToken.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::announcement_read::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::AnnouncementRead.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::antenna::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Antenna.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::app::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::App.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::attestation_challenge::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::AttestationChallenge.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::auth_session::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::AuthSession.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::channel::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Channel.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::channel_following::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::ChannelFollowing.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::clip::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Clip.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::drive_folder::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::DriveFolder.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::gallery_like::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::GalleryLike.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::gallery_post::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::GalleryPost.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::meta::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Meta.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::moderation_log::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::ModerationLog.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::muted_note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::MutedNote.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note_favorite::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::NoteFavorite.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note_reaction::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::NoteReaction.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note_thread_muting::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::NoteThreadMuting.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note_unread::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::NoteUnread.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note_watching::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::NoteWatching.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::page::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Page.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::page_like::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::PageLike.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::password_reset_request::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::PasswordResetRequest.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::poll_vote::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::PollVote.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::promo_read::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::PromoRead.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::registry_item::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::RegistryItem.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::signin::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Signin.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::sw_subscription::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::SwSubscription.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroup.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group_invitation::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroupInvitation.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group_invite::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroupInvite.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group_joining::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroupJoining.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_keypair::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserKeypair.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_list::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserList.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_list_joining::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserListJoining.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_note_pining::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserNotePining.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_profile::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserProfile.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_publickey::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserPublickey.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_security_key::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserSecurityKey.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::webhook::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Webhook.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
69
packages/backend/native-utils/src/model/entity/user_group.rs
Normal file
69
packages/backend/native-utils/src/model/entity/user_group.rs
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_group")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
pub name: String,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "isPrivate")]
|
||||||
|
pub is_private: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::messaging_message::Entity")]
|
||||||
|
MessagingMessage,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
#[sea_orm(has_many = "super::user_group_invitation::Entity")]
|
||||||
|
UserGroupInvitation,
|
||||||
|
#[sea_orm(has_many = "super::user_group_invite::Entity")]
|
||||||
|
UserGroupInvite,
|
||||||
|
#[sea_orm(has_many = "super::user_group_joining::Entity")]
|
||||||
|
UserGroupJoining,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::messaging_message::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::MessagingMessage.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group_invitation::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroupInvitation.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group_invite::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroupInvite.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group_joining::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroupJoining.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,58 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_group_invitation")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "userGroupId")]
|
||||||
|
pub user_group_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::notification::Entity")]
|
||||||
|
Notification,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user_group::Entity",
|
||||||
|
from = "Column::UserGroupId",
|
||||||
|
to = "super::user_group::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
UserGroup,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::notification::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Notification.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroup.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,50 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_group_invite")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "userGroupId")]
|
||||||
|
pub user_group_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user_group::Entity",
|
||||||
|
from = "Column::UserGroupId",
|
||||||
|
to = "super::user_group::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
UserGroup,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroup.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,58 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_group_joining")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "userGroupId")]
|
||||||
|
pub user_group_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::antenna::Entity")]
|
||||||
|
Antenna,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user_group::Entity",
|
||||||
|
from = "Column::UserGroupId",
|
||||||
|
to = "super::user_group::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
UserGroup,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::antenna::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Antenna.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_group::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserGroup.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
20
packages/backend/native-utils/src/model/entity/user_ip.rs
Normal file
20
packages/backend/native-utils/src/model/entity/user_ip.rs
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_ip")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key)]
|
||||||
|
pub id: i32,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
pub ip: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,34 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_keypair")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(column_name = "userId", primary_key, auto_increment = false, unique)]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "publicKey")]
|
||||||
|
pub public_key: String,
|
||||||
|
#[sea_orm(column_name = "privateKey")]
|
||||||
|
pub private_key: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
51
packages/backend/native-utils/src/model/entity/user_list.rs
Normal file
51
packages/backend/native-utils/src/model/entity/user_list.rs
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_list")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
pub name: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(has_many = "super::antenna::Entity")]
|
||||||
|
Antenna,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
#[sea_orm(has_many = "super::user_list_joining::Entity")]
|
||||||
|
UserListJoining,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::antenna::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Antenna.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_list_joining::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserListJoining.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,50 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_list_joining")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "userListId")]
|
||||||
|
pub user_list_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user_list::Entity",
|
||||||
|
from = "Column::UserListId",
|
||||||
|
to = "super::user_list::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
UserList,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user_list::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::UserList.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,50 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_note_pining")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "noteId")]
|
||||||
|
pub note_id: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::note::Entity",
|
||||||
|
from = "Column::NoteId",
|
||||||
|
to = "super::note::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
Note,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::note::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Note.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,21 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_pending")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
pub code: String,
|
||||||
|
pub username: String,
|
||||||
|
pub email: String,
|
||||||
|
pub password: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
112
packages/backend/native-utils/src/model/entity/user_profile.rs
Normal file
112
packages/backend/native-utils/src/model/entity/user_profile.rs
Normal file
|
@ -0,0 +1,112 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use super::sea_orm_active_enums::UserProfileFfvisibilityEnum;
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_profile")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(column_name = "userId", primary_key, auto_increment = false, unique)]
|
||||||
|
pub user_id: String,
|
||||||
|
pub location: Option<String>,
|
||||||
|
pub birthday: Option<String>,
|
||||||
|
pub description: Option<String>,
|
||||||
|
#[sea_orm(column_type = "JsonBinary")]
|
||||||
|
pub fields: Json,
|
||||||
|
pub url: Option<String>,
|
||||||
|
pub email: Option<String>,
|
||||||
|
#[sea_orm(column_name = "emailVerifyCode")]
|
||||||
|
pub email_verify_code: Option<String>,
|
||||||
|
#[sea_orm(column_name = "emailVerified")]
|
||||||
|
pub email_verified: bool,
|
||||||
|
#[sea_orm(column_name = "twoFactorTempSecret")]
|
||||||
|
pub two_factor_temp_secret: Option<String>,
|
||||||
|
#[sea_orm(column_name = "twoFactorSecret")]
|
||||||
|
pub two_factor_secret: Option<String>,
|
||||||
|
#[sea_orm(column_name = "twoFactorEnabled")]
|
||||||
|
pub two_factor_enabled: bool,
|
||||||
|
pub password: Option<String>,
|
||||||
|
#[sea_orm(column_name = "clientData", column_type = "JsonBinary")]
|
||||||
|
pub client_data: Json,
|
||||||
|
#[sea_orm(column_name = "autoAcceptFollowed")]
|
||||||
|
pub auto_accept_followed: bool,
|
||||||
|
#[sea_orm(column_name = "alwaysMarkNsfw")]
|
||||||
|
pub always_mark_nsfw: bool,
|
||||||
|
#[sea_orm(column_name = "carefulBot")]
|
||||||
|
pub careful_bot: bool,
|
||||||
|
#[sea_orm(column_name = "userHost")]
|
||||||
|
pub user_host: Option<String>,
|
||||||
|
#[sea_orm(column_name = "securityKeysAvailable")]
|
||||||
|
pub security_keys_available: bool,
|
||||||
|
#[sea_orm(column_name = "usePasswordLessLogin")]
|
||||||
|
pub use_password_less_login: bool,
|
||||||
|
#[sea_orm(column_name = "pinnedPageId", unique)]
|
||||||
|
pub pinned_page_id: Option<String>,
|
||||||
|
#[sea_orm(column_type = "JsonBinary")]
|
||||||
|
pub room: Json,
|
||||||
|
#[sea_orm(column_type = "JsonBinary")]
|
||||||
|
pub integrations: Json,
|
||||||
|
#[sea_orm(column_name = "injectFeaturedNote")]
|
||||||
|
pub inject_featured_note: bool,
|
||||||
|
#[sea_orm(column_name = "enableWordMute")]
|
||||||
|
pub enable_word_mute: bool,
|
||||||
|
#[sea_orm(column_name = "mutedWords", column_type = "JsonBinary")]
|
||||||
|
pub muted_words: Json,
|
||||||
|
#[sea_orm(column_name = "mutingNotificationTypes")]
|
||||||
|
pub muting_notification_types: StringVec,
|
||||||
|
#[sea_orm(column_name = "noCrawle")]
|
||||||
|
pub no_crawle: bool,
|
||||||
|
#[sea_orm(column_name = "receiveAnnouncementEmail")]
|
||||||
|
pub receive_announcement_email: bool,
|
||||||
|
#[sea_orm(column_name = "emailNotificationTypes", column_type = "JsonBinary")]
|
||||||
|
pub email_notification_types: Json,
|
||||||
|
pub lang: Option<String>,
|
||||||
|
#[sea_orm(column_name = "mutedInstances", column_type = "JsonBinary")]
|
||||||
|
pub muted_instances: Json,
|
||||||
|
#[sea_orm(column_name = "publicReactions")]
|
||||||
|
pub public_reactions: bool,
|
||||||
|
#[sea_orm(column_name = "ffVisibility")]
|
||||||
|
pub ff_visibility: UserProfileFfvisibilityEnum,
|
||||||
|
#[sea_orm(column_name = "autoSensitive")]
|
||||||
|
pub auto_sensitive: bool,
|
||||||
|
#[sea_orm(column_name = "moderationNote")]
|
||||||
|
pub moderation_note: String,
|
||||||
|
#[sea_orm(column_name = "preventAiLearning")]
|
||||||
|
pub prevent_ai_learning: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::page::Entity",
|
||||||
|
from = "Column::PinnedPageId",
|
||||||
|
to = "super::page::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "SetNull"
|
||||||
|
)]
|
||||||
|
Page,
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::page::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::Page.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,34 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_publickey")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(column_name = "userId", primary_key, auto_increment = false, unique)]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "keyId")]
|
||||||
|
pub key_id: String,
|
||||||
|
#[sea_orm(column_name = "keyPem")]
|
||||||
|
pub key_pem: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
|
@ -0,0 +1,37 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "user_security_key")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
#[sea_orm(column_name = "publicKey")]
|
||||||
|
pub public_key: String,
|
||||||
|
#[sea_orm(column_name = "lastUsed")]
|
||||||
|
pub last_used: DateTimeWithTimeZone,
|
||||||
|
pub name: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
45
packages/backend/native-utils/src/model/entity/webhook.rs
Normal file
45
packages/backend/native-utils/src/model/entity/webhook.rs
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.11.3
|
||||||
|
|
||||||
|
use sea_orm::entity::prelude::*;
|
||||||
|
|
||||||
|
use super::newtype::StringVec;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Default)]
|
||||||
|
#[sea_orm(table_name = "webhook")]
|
||||||
|
pub struct Model {
|
||||||
|
#[sea_orm(primary_key, auto_increment = false)]
|
||||||
|
pub id: String,
|
||||||
|
#[sea_orm(column_name = "createdAt")]
|
||||||
|
pub created_at: DateTimeWithTimeZone,
|
||||||
|
#[sea_orm(column_name = "userId")]
|
||||||
|
pub user_id: String,
|
||||||
|
pub name: String,
|
||||||
|
pub on: StringVec,
|
||||||
|
pub url: String,
|
||||||
|
pub secret: String,
|
||||||
|
pub active: bool,
|
||||||
|
#[sea_orm(column_name = "latestSentAt")]
|
||||||
|
pub latest_sent_at: Option<DateTimeWithTimeZone>,
|
||||||
|
#[sea_orm(column_name = "latestStatus")]
|
||||||
|
pub latest_status: Option<i32>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
||||||
|
pub enum Relation {
|
||||||
|
#[sea_orm(
|
||||||
|
belongs_to = "super::user::Entity",
|
||||||
|
from = "Column::UserId",
|
||||||
|
to = "super::user::Column::Id",
|
||||||
|
on_update = "NoAction",
|
||||||
|
on_delete = "Cascade"
|
||||||
|
)]
|
||||||
|
User,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Related<super::user::Entity> for Entity {
|
||||||
|
fn to() -> RelationDef {
|
||||||
|
Relation::User.def()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ActiveModelBehavior for ActiveModel {}
|
15
packages/backend/native-utils/src/model/error.rs
Normal file
15
packages/backend/native-utils/src/model/error.rs
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
use crate::impl_into_napi_error;
|
||||||
|
|
||||||
|
#[derive(thiserror::Error, Debug, PartialEq, Eq)]
|
||||||
|
pub enum Error {
|
||||||
|
#[error("Failed to parse string: {0}")]
|
||||||
|
ParseError(#[from] parse_display::ParseError),
|
||||||
|
#[error("Failed to get database connection: {0}")]
|
||||||
|
DbConnError(#[from] crate::database::error::Error),
|
||||||
|
#[error("Database operation error: {0}")]
|
||||||
|
DbOperationError(#[from] sea_orm::DbErr),
|
||||||
|
#[error("Requested entity not found")]
|
||||||
|
NotFound,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl_into_napi_error!(Error);
|
4
packages/backend/native-utils/src/model/mod.rs
Normal file
4
packages/backend/native-utils/src/model/mod.rs
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
pub mod entity;
|
||||||
|
pub mod error;
|
||||||
|
pub mod repository;
|
||||||
|
pub mod schema;
|
33
packages/backend/native-utils/src/model/repository.rs
Normal file
33
packages/backend/native-utils/src/model/repository.rs
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
pub mod antenna;
|
||||||
|
|
||||||
|
use async_trait::async_trait;
|
||||||
|
use schemars::JsonSchema;
|
||||||
|
|
||||||
|
use super::error::Error;
|
||||||
|
|
||||||
|
/// Repositories have a packer that converts a database model to its
|
||||||
|
/// corresponding API schema.
|
||||||
|
#[async_trait]
|
||||||
|
pub trait Repository<T: JsonSchema> {
|
||||||
|
async fn pack(self) -> Result<T, Error>;
|
||||||
|
/// Retrieves one model by its id and pack it.
|
||||||
|
async fn pack_by_id(id: String) -> Result<T, Error>;
|
||||||
|
}
|
||||||
|
|
||||||
|
mod macros {
|
||||||
|
/// Provides the default implementation of
|
||||||
|
/// [crate::model::repository::Repository::pack_by_id].
|
||||||
|
macro_rules! impl_pack_by_id {
|
||||||
|
($a:ty, $b:ident) => {
|
||||||
|
match <$a>::find_by_id($b)
|
||||||
|
.one(crate::database::get_database()?)
|
||||||
|
.await?
|
||||||
|
{
|
||||||
|
None => Err(Error::NotFound),
|
||||||
|
Some(m) => m.pack().await,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
pub(crate) use impl_pack_by_id;
|
||||||
|
}
|
|
@ -0,0 +1,62 @@
|
||||||
|
use async_trait::async_trait;
|
||||||
|
use cfg_if::cfg_if;
|
||||||
|
use sea_orm::{ColumnTrait, EntityTrait, QueryFilter};
|
||||||
|
|
||||||
|
use crate::database;
|
||||||
|
use crate::model::entity::{antenna, antenna_note, user_group_joining};
|
||||||
|
use crate::model::error::Error;
|
||||||
|
use crate::model::schema::Antenna;
|
||||||
|
|
||||||
|
use super::macros::impl_pack_by_id;
|
||||||
|
use super::Repository;
|
||||||
|
|
||||||
|
#[async_trait]
|
||||||
|
impl Repository<Antenna> for antenna::Model {
|
||||||
|
async fn pack(self) -> Result<Antenna, Error> {
|
||||||
|
let db = database::get_database()?;
|
||||||
|
let has_unread_note = antenna_note::Entity::find()
|
||||||
|
.filter(antenna_note::Column::AntennaId.eq(self.id.to_owned()))
|
||||||
|
.filter(antenna_note::Column::Read.eq(false))
|
||||||
|
.one(db)
|
||||||
|
.await?
|
||||||
|
.is_some();
|
||||||
|
let user_group_joining = match self.user_group_joining_id {
|
||||||
|
None => None,
|
||||||
|
Some(id) => user_group_joining::Entity::find_by_id(id).one(db).await?,
|
||||||
|
};
|
||||||
|
let user_group_id = match user_group_joining {
|
||||||
|
None => None,
|
||||||
|
Some(m) => Some(m.user_group_id),
|
||||||
|
};
|
||||||
|
|
||||||
|
cfg_if! {
|
||||||
|
if #[cfg(feature = "napi")] {
|
||||||
|
let created_at: String = self.created_at.to_rfc3339();
|
||||||
|
} else {
|
||||||
|
let created_at: chrono::DateTime<chrono::Utc> = self.created_at.into();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(Antenna {
|
||||||
|
id: self.id,
|
||||||
|
created_at,
|
||||||
|
name: self.name,
|
||||||
|
keywords: self.keywords.into(),
|
||||||
|
exclude_keywords: self.exclude_keywords.into(),
|
||||||
|
src: self.src.try_into()?,
|
||||||
|
user_list_id: self.user_list_id,
|
||||||
|
user_group_id,
|
||||||
|
users: self.users.into(),
|
||||||
|
instances: self.instances.into(),
|
||||||
|
case_sensitive: self.case_sensitive,
|
||||||
|
notify: self.notify,
|
||||||
|
with_replies: self.with_replies,
|
||||||
|
with_file: self.with_file,
|
||||||
|
has_unread_note,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn pack_by_id(id: String) -> Result<Antenna, Error> {
|
||||||
|
impl_pack_by_id!(antenna::Entity, id)
|
||||||
|
}
|
||||||
|
}
|
35
packages/backend/native-utils/src/model/schema.rs
Normal file
35
packages/backend/native-utils/src/model/schema.rs
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
pub mod antenna;
|
||||||
|
pub mod app;
|
||||||
|
|
||||||
|
use cfg_if::cfg_if;
|
||||||
|
use jsonschema::JSONSchema;
|
||||||
|
use schemars::{schema_for, JsonSchema};
|
||||||
|
|
||||||
|
/// Structs of schema defitions implement this trait in order to
|
||||||
|
/// provide the JSON Schema validator [`jsonschema::JSONSchema`].
|
||||||
|
pub trait Schema<T: JsonSchema> {
|
||||||
|
/// Returns the validator of [JSON Schema Draft
|
||||||
|
/// 7](https://json-schema.org/specification-links.html#draft-7) with the
|
||||||
|
/// default settings of [`schemars::gen::SchemaSettings`].
|
||||||
|
fn validator() -> JSONSchema {
|
||||||
|
let root = schema_for!(T);
|
||||||
|
let schema = serde_json::to_value(&root).expect("Schema definition invalid");
|
||||||
|
JSONSchema::options()
|
||||||
|
.with_draft(jsonschema::Draft::Draft7)
|
||||||
|
.compile(&schema)
|
||||||
|
.expect("Unable to compile schema")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
cfg_if! {
|
||||||
|
if #[cfg(feature = "napi")] {
|
||||||
|
// Will be disabled once we completely migrate to rust
|
||||||
|
pub use antenna::NativeAntennaSchema as Antenna;
|
||||||
|
pub use antenna::NativeAntennaSrc as AntennaSrc;
|
||||||
|
} else {
|
||||||
|
pub use antenna::Antenna;
|
||||||
|
pub use antenna::AntennaSrc;
|
||||||
|
pub use app::App;
|
||||||
|
pub use app::AppPermission;
|
||||||
|
}
|
||||||
|
}
|
217
packages/backend/native-utils/src/model/schema/antenna.rs
Normal file
217
packages/backend/native-utils/src/model/schema/antenna.rs
Normal file
|
@ -0,0 +1,217 @@
|
||||||
|
use cfg_if::cfg_if;
|
||||||
|
use jsonschema::JSONSchema;
|
||||||
|
use once_cell::sync::Lazy;
|
||||||
|
use parse_display::FromStr;
|
||||||
|
use schemars::JsonSchema;
|
||||||
|
use utoipa::ToSchema;
|
||||||
|
|
||||||
|
use super::Schema;
|
||||||
|
use crate::model;
|
||||||
|
use crate::model::entity::sea_orm_active_enums::AntennaSrcEnum;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, Eq, JsonSchema, ToSchema)]
|
||||||
|
#[serde(rename_all = "camelCase")]
|
||||||
|
pub struct Antenna {
|
||||||
|
pub id: String,
|
||||||
|
pub created_at: chrono::DateTime<chrono::Utc>,
|
||||||
|
pub name: String,
|
||||||
|
pub keywords: Vec<Vec<String>>,
|
||||||
|
pub exclude_keywords: Vec<Vec<String>>,
|
||||||
|
#[schema(inline)]
|
||||||
|
pub src: AntennaSrc,
|
||||||
|
pub user_list_id: Option<String>,
|
||||||
|
pub user_group_id: Option<String>,
|
||||||
|
pub users: Vec<String>,
|
||||||
|
pub instances: Vec<String>,
|
||||||
|
#[serde(default)]
|
||||||
|
pub case_sensitive: bool,
|
||||||
|
#[serde(default)]
|
||||||
|
pub notify: bool,
|
||||||
|
#[serde(default)]
|
||||||
|
pub with_replies: bool,
|
||||||
|
#[serde(default)]
|
||||||
|
pub with_file: bool,
|
||||||
|
#[serde(default)]
|
||||||
|
pub has_unread_note: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, FromStr, PartialEq, Eq, JsonSchema, ToSchema)]
|
||||||
|
#[serde(rename_all = "camelCase")]
|
||||||
|
#[display(style = "camelCase")]
|
||||||
|
#[display("'{}'")]
|
||||||
|
pub enum AntennaSrc {
|
||||||
|
Home,
|
||||||
|
All,
|
||||||
|
Users,
|
||||||
|
List,
|
||||||
|
Group,
|
||||||
|
Instances,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl TryFrom<AntennaSrcEnum> for super::AntennaSrc {
|
||||||
|
type Error = model::error::Error;
|
||||||
|
|
||||||
|
fn try_from(value: AntennaSrcEnum) -> Result<Self, Self::Error> {
|
||||||
|
value.to_string().parse().map_err(model::error::Error::from)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ---- TODO: could be macro
|
||||||
|
impl Schema<Self> for super::Antenna {}
|
||||||
|
pub static VALIDATOR: Lazy<JSONSchema> = Lazy::new(|| super::Antenna::validator());
|
||||||
|
// ----
|
||||||
|
|
||||||
|
cfg_if! {
|
||||||
|
if #[cfg(feature = "napi")] {
|
||||||
|
use napi::bindgen_prelude::{FromNapiValue, ToNapiValue};
|
||||||
|
use napi_derive::napi;
|
||||||
|
|
||||||
|
use crate::model::entity::antenna;
|
||||||
|
use crate::model::repository::Repository;
|
||||||
|
|
||||||
|
/// For NAPI because [chrono] is not supported.
|
||||||
|
#[napi(object)]
|
||||||
|
#[derive(Clone, Debug, PartialEq, Eq, JsonSchema, ToSchema)]
|
||||||
|
#[serde(rename_all = "camelCase")]
|
||||||
|
pub struct NativeAntennaSchema {
|
||||||
|
pub id: String,
|
||||||
|
pub created_at: String,
|
||||||
|
pub name: String,
|
||||||
|
pub keywords: Vec<Vec<String>>,
|
||||||
|
pub exclude_keywords: Vec<Vec<String>>,
|
||||||
|
#[schema(inline)]
|
||||||
|
pub src: NativeAntennaSrc,
|
||||||
|
pub user_list_id: Option<String>,
|
||||||
|
pub user_group_id: Option<String>,
|
||||||
|
pub users: Vec<String>,
|
||||||
|
pub instances: Vec<String>,
|
||||||
|
#[serde(default)]
|
||||||
|
pub case_sensitive: bool,
|
||||||
|
#[serde(default)]
|
||||||
|
pub notify: bool,
|
||||||
|
#[serde(default)]
|
||||||
|
pub with_replies: bool,
|
||||||
|
#[serde(default)]
|
||||||
|
pub with_file: bool,
|
||||||
|
#[serde(default)]
|
||||||
|
pub has_unread_note: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[napi(string_enum)]
|
||||||
|
#[derive(Debug, FromStr, PartialEq, Eq, JsonSchema, ToSchema)]
|
||||||
|
#[display("'{}'")]
|
||||||
|
#[allow(non_camel_case_types)]
|
||||||
|
pub enum NativeAntennaSrc {
|
||||||
|
home,
|
||||||
|
all,
|
||||||
|
users,
|
||||||
|
list,
|
||||||
|
group,
|
||||||
|
instances,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[napi]
|
||||||
|
pub async fn native_pack_antenna_by_id(id: String) -> napi::Result<NativeAntennaSchema> {
|
||||||
|
antenna::Model::pack_by_id(id).await.map_err(Into::into)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod unit_test {
|
||||||
|
use cfg_if::cfg_if;
|
||||||
|
use pretty_assertions::assert_eq;
|
||||||
|
use serde_json::json;
|
||||||
|
|
||||||
|
use crate::model::{entity::sea_orm_active_enums::AntennaSrcEnum, schema::AntennaSrc};
|
||||||
|
|
||||||
|
use super::VALIDATOR;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn src_from_active_enum() {
|
||||||
|
let src = AntennaSrc::try_from(AntennaSrcEnum::All).unwrap();
|
||||||
|
cfg_if! {
|
||||||
|
if #[cfg(feature = "napi")] {
|
||||||
|
assert_eq!(src, AntennaSrc::all);
|
||||||
|
} else {
|
||||||
|
assert_eq!(src, AntennaSrc::All);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn antenna_valid() {
|
||||||
|
let instance = json!({
|
||||||
|
"id": "9fil64s6g7cskdrb",
|
||||||
|
"createdAt": "2023-05-24T06:56:14.323Z",
|
||||||
|
"name": "Valid Antenna",
|
||||||
|
"keywords": [["first", "keyword"], ["second"]],
|
||||||
|
"excludeKeywords": [["excluding", "keywrods"], ["from", "antenna"]],
|
||||||
|
"src": "users",
|
||||||
|
// "userListId" and "userGroupId" can be null or be omitted
|
||||||
|
"userListId": null,
|
||||||
|
"users": ["9fil64s6g7cskdrb", "9fil66brl1udxau2"],
|
||||||
|
"instances": [],
|
||||||
|
// "caseSensitive", "notify", "withReplies", "withFile", and
|
||||||
|
// "hasUnreadNote" are false if ommited
|
||||||
|
"notify": false,
|
||||||
|
"withReplies": false,
|
||||||
|
"withFile": false,
|
||||||
|
"hasUnreadNote": false,
|
||||||
|
});
|
||||||
|
|
||||||
|
assert!(VALIDATOR.is_valid(&instance));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn antenna_invalid() {
|
||||||
|
let instance = json!({
|
||||||
|
// "id" is required
|
||||||
|
"id": null,
|
||||||
|
// trailing "Z" is missing
|
||||||
|
"createdAt": "2023-05-24T07:36:34.389",
|
||||||
|
// "name" is required
|
||||||
|
// "keywords" must be an array
|
||||||
|
"keywords": "invalid keyword",
|
||||||
|
// "excludeKeywords" is required
|
||||||
|
"excludeKeywords": null,
|
||||||
|
// "src" must be one of "home", "all", "users", "list", "group", and
|
||||||
|
// "instances"
|
||||||
|
"src": "invalid_src",
|
||||||
|
// "userListId" is string
|
||||||
|
"userListId": ["9f4ziiqfxw"],
|
||||||
|
// "users" must be an array of strings
|
||||||
|
"users": [1, "9fil64s6g7cskdrb"],
|
||||||
|
"instances": ["9fil65jzhtjpi3xn"],
|
||||||
|
// "caseSensitive" is boolean
|
||||||
|
"caseSensitive": 0,
|
||||||
|
"notify": true,
|
||||||
|
"withReplies": true,
|
||||||
|
"withFile": true,
|
||||||
|
"hasUnreadNote": true,
|
||||||
|
});
|
||||||
|
|
||||||
|
let result = VALIDATOR
|
||||||
|
.validate(&instance)
|
||||||
|
.expect_err("validation must fail");
|
||||||
|
let mut paths: Vec<String> = result
|
||||||
|
.map(|e| e.instance_path.to_string())
|
||||||
|
.filter(|e| !e.is_empty())
|
||||||
|
.collect();
|
||||||
|
paths.sort();
|
||||||
|
assert_eq!(
|
||||||
|
paths,
|
||||||
|
vec![
|
||||||
|
"/caseSensitive",
|
||||||
|
#[cfg(not(feature = "napi"))]
|
||||||
|
"/createdAt",
|
||||||
|
"/excludeKeywords",
|
||||||
|
"/id",
|
||||||
|
"/keywords",
|
||||||
|
"/src",
|
||||||
|
"/userListId",
|
||||||
|
"/users/0"
|
||||||
|
]
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
147
packages/backend/native-utils/src/model/schema/app.rs
Normal file
147
packages/backend/native-utils/src/model/schema/app.rs
Normal file
|
@ -0,0 +1,147 @@
|
||||||
|
use jsonschema::JSONSchema;
|
||||||
|
use once_cell::sync::Lazy;
|
||||||
|
use schemars::JsonSchema;
|
||||||
|
use utoipa::ToSchema;
|
||||||
|
|
||||||
|
use super::Schema;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, Eq, JsonSchema, ToSchema)]
|
||||||
|
#[serde(rename_all = "camelCase")]
|
||||||
|
pub struct App {
|
||||||
|
pub id: String,
|
||||||
|
pub name: String,
|
||||||
|
#[schemars(url)]
|
||||||
|
pub callback_url: Option<String>,
|
||||||
|
#[schema(inline)]
|
||||||
|
pub permission: Vec<AppPermission>,
|
||||||
|
pub secret: Option<String>,
|
||||||
|
pub is_authorized: Option<bool>,
|
||||||
|
}
|
||||||
|
|
||||||
|
/// This represents `permissions` in `packages/calckey-js/src/consts.ts`.
|
||||||
|
#[derive(Clone, Debug, PartialEq, Eq, JsonSchema, ToSchema)]
|
||||||
|
pub enum AppPermission {
|
||||||
|
#[serde(rename = "read:account")]
|
||||||
|
ReadAccount,
|
||||||
|
#[serde(rename = "write:account")]
|
||||||
|
WriteAccount,
|
||||||
|
#[serde(rename = "read:blocks")]
|
||||||
|
ReadBlocks,
|
||||||
|
#[serde(rename = "write:blocks")]
|
||||||
|
WriteBlocks,
|
||||||
|
#[serde(rename = "read:drive")]
|
||||||
|
ReadDrive,
|
||||||
|
#[serde(rename = "write:drive")]
|
||||||
|
WriteDrive,
|
||||||
|
#[serde(rename = "read:favorites")]
|
||||||
|
ReadFavorites,
|
||||||
|
#[serde(rename = "write:favorites")]
|
||||||
|
WriteFavorites,
|
||||||
|
#[serde(rename = "read:following")]
|
||||||
|
ReadFollowing,
|
||||||
|
#[serde(rename = "write:following")]
|
||||||
|
WriteFollowing,
|
||||||
|
#[serde(rename = "read:messaging")]
|
||||||
|
ReadMessaging,
|
||||||
|
#[serde(rename = "write:messaging")]
|
||||||
|
WriteMessaging,
|
||||||
|
#[serde(rename = "read:mutes")]
|
||||||
|
ReadMutes,
|
||||||
|
#[serde(rename = "write:mutes")]
|
||||||
|
WriteMutes,
|
||||||
|
#[serde(rename = "read:notes")]
|
||||||
|
ReadNotes,
|
||||||
|
#[serde(rename = "write:notes")]
|
||||||
|
WriteNotes,
|
||||||
|
#[serde(rename = "read:notifications")]
|
||||||
|
ReadNotifications,
|
||||||
|
#[serde(rename = "write:notifications")]
|
||||||
|
WriteNotifications,
|
||||||
|
#[serde(rename = "read:reactions")]
|
||||||
|
ReadReactions,
|
||||||
|
#[serde(rename = "write:reactions")]
|
||||||
|
WriteReactions,
|
||||||
|
#[serde(rename = "write:votes")]
|
||||||
|
WriteVotes,
|
||||||
|
#[serde(rename = "read:pages")]
|
||||||
|
ReadPages,
|
||||||
|
#[serde(rename = "write:pages")]
|
||||||
|
WritePages,
|
||||||
|
#[serde(rename = "read:page-likes")]
|
||||||
|
ReadPageLikes,
|
||||||
|
#[serde(rename = "write:page-likes")]
|
||||||
|
WritePageLikes,
|
||||||
|
#[serde(rename = "read:user-groups")]
|
||||||
|
ReadUserGroups,
|
||||||
|
#[serde(rename = "write:user-groups")]
|
||||||
|
WriteUserGroups,
|
||||||
|
#[serde(rename = "read:channels")]
|
||||||
|
ReadChannels,
|
||||||
|
#[serde(rename = "write:channels")]
|
||||||
|
WriteChannels,
|
||||||
|
#[serde(rename = "read:gallery")]
|
||||||
|
ReadGallery,
|
||||||
|
#[serde(rename = "write:gallery")]
|
||||||
|
WriteGallery,
|
||||||
|
#[serde(rename = "read:gallery-likes")]
|
||||||
|
ReadGalleryLikes,
|
||||||
|
#[serde(rename = "write:gallery-likes")]
|
||||||
|
WriteGalleryLikes,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Schema<Self> for App {}
|
||||||
|
|
||||||
|
pub static VALIDATOR: Lazy<JSONSchema> = Lazy::new(|| App::validator());
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod unit_test {
|
||||||
|
use pretty_assertions::assert_eq;
|
||||||
|
use serde_json::json;
|
||||||
|
|
||||||
|
use crate::util::id::{create_id, init_id};
|
||||||
|
use crate::util::random::gen_string;
|
||||||
|
|
||||||
|
use super::VALIDATOR;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn app_valid() {
|
||||||
|
init_id(12, "");
|
||||||
|
let instance = json!({
|
||||||
|
"id": create_id().unwrap(),
|
||||||
|
"name": "Test App",
|
||||||
|
"secret": gen_string(24),
|
||||||
|
"callbackUrl": "urn:ietf:wg:oauth:2.0:oob",
|
||||||
|
"permission": ["read:account", "write:account", "read:notes"],
|
||||||
|
});
|
||||||
|
|
||||||
|
assert!(VALIDATOR.is_valid(&instance));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn app_invalid() {
|
||||||
|
init_id(12, "");
|
||||||
|
let instance = json!({
|
||||||
|
"id": create_id().unwrap(),
|
||||||
|
// "name" is required
|
||||||
|
"name": null,
|
||||||
|
// "permission" must be one of the app permissions
|
||||||
|
"permission": ["write:invalid_perm", "write:notes"],
|
||||||
|
// "secret" is a nullable string
|
||||||
|
"secret": 123,
|
||||||
|
// "is_authorized" is a nullable boolean
|
||||||
|
"isAuthorized": "true-ish",
|
||||||
|
});
|
||||||
|
let result = VALIDATOR
|
||||||
|
.validate(&instance)
|
||||||
|
.expect_err("validation must fail");
|
||||||
|
let mut paths: Vec<String> = result
|
||||||
|
.map(|e| e.instance_path.to_string())
|
||||||
|
.filter(|e| !e.is_empty())
|
||||||
|
.collect();
|
||||||
|
paths.sort();
|
||||||
|
assert_eq!(
|
||||||
|
paths,
|
||||||
|
vec!["/isAuthorized", "/name", "/permission/0", "/secret"]
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
98
packages/backend/native-utils/src/util/id.rs
Normal file
98
packages/backend/native-utils/src/util/id.rs
Normal file
|
@ -0,0 +1,98 @@
|
||||||
|
//! ID generation utility based on [cuid2]
|
||||||
|
|
||||||
|
use cfg_if::cfg_if;
|
||||||
|
use once_cell::sync::OnceCell;
|
||||||
|
|
||||||
|
use crate::impl_into_napi_error;
|
||||||
|
|
||||||
|
#[derive(thiserror::Error, Debug, PartialEq, Eq)]
|
||||||
|
#[error("ID generator has not been initialized yet")]
|
||||||
|
pub struct ErrorUninitialized;
|
||||||
|
|
||||||
|
impl_into_napi_error!(ErrorUninitialized);
|
||||||
|
|
||||||
|
static FINGERPRINT: OnceCell<String> = OnceCell::new();
|
||||||
|
static GENERATOR: OnceCell<cuid2::CuidConstructor> = OnceCell::new();
|
||||||
|
|
||||||
|
/// Initializes Cuid2 generator. Must be called before any [create_id].
|
||||||
|
pub fn init_id(length: u16, fingerprint: impl Into<String>) {
|
||||||
|
FINGERPRINT.get_or_init(move || format!("{}{}", fingerprint.into(), cuid2::create_id()));
|
||||||
|
GENERATOR.get_or_init(move || {
|
||||||
|
cuid2::CuidConstructor::new()
|
||||||
|
.with_length(length)
|
||||||
|
.with_fingerprinter(|| FINGERPRINT.get().unwrap().clone())
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns Cuid2 with the length specified by [init_id]. Must be called after
|
||||||
|
/// [init_id], otherwise returns [ErrorUninitialized].
|
||||||
|
pub fn create_id() -> Result<String, ErrorUninitialized> {
|
||||||
|
match GENERATOR.get() {
|
||||||
|
None => Err(ErrorUninitialized),
|
||||||
|
Some(gen) => Ok(gen.create_id()),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
cfg_if! {
|
||||||
|
if #[cfg(feature = "napi")] {
|
||||||
|
use radix_fmt::radix_36;
|
||||||
|
use std::cmp;
|
||||||
|
use napi::bindgen_prelude::BigInt;
|
||||||
|
use napi_derive::napi;
|
||||||
|
|
||||||
|
const TIME_2000: u64 = 946_684_800_000;
|
||||||
|
const TIMESTAMP_LENGTH: u16 = 8;
|
||||||
|
|
||||||
|
/// Calls [init_id] inside. Must be called before [native_create_id].
|
||||||
|
#[napi]
|
||||||
|
pub fn native_init_id_generator(length: u16, fingerprint: String) {
|
||||||
|
// length to pass init_id shoule be greater than or equal to 8.
|
||||||
|
init_id(cmp::max(length - TIMESTAMP_LENGTH, 8), fingerprint);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Generates
|
||||||
|
#[napi]
|
||||||
|
pub fn native_create_id(date_num: BigInt) -> String {
|
||||||
|
let time = cmp::max(date_num.get_u64().1 - TIME_2000, 0);
|
||||||
|
format!("{:0>8}{}", radix_36(time).to_string(), create_id().unwrap())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod unit_test {
|
||||||
|
use crate::util::id;
|
||||||
|
use cfg_if::cfg_if;
|
||||||
|
use pretty_assertions::{assert_eq, assert_ne};
|
||||||
|
use std::thread;
|
||||||
|
|
||||||
|
cfg_if! {
|
||||||
|
if #[cfg(feature = "napi")] {
|
||||||
|
use chrono::Utc;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn can_generate_aid_compat_ids() {
|
||||||
|
id::native_init_id_generator(20, "".to_string());
|
||||||
|
let id1 = id::native_create_id(Utc::now().timestamp_millis().into());
|
||||||
|
assert_eq!(id1.len(), 20);
|
||||||
|
let id1 = id::native_create_id(Utc::now().timestamp_millis().into());
|
||||||
|
let id2 = id::native_create_id(Utc::now().timestamp_millis().into());
|
||||||
|
assert_ne!(id1, id2);
|
||||||
|
let id1 = thread::spawn(|| id::native_create_id(Utc::now().timestamp_millis().into()));
|
||||||
|
let id2 = thread::spawn(|| id::native_create_id(Utc::now().timestamp_millis().into()));
|
||||||
|
assert_ne!(id1.join().unwrap(), id2.join().unwrap());
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
#[test]
|
||||||
|
fn can_generate_unique_ids() {
|
||||||
|
assert_eq!(id::create_id(), Err(id::ErrorUninitialized));
|
||||||
|
id::init_id(12, "");
|
||||||
|
assert_eq!(id::create_id().unwrap().len(), 12);
|
||||||
|
assert_ne!(id::create_id().unwrap(), id::create_id().unwrap());
|
||||||
|
let id1 = thread::spawn(|| id::create_id().unwrap());
|
||||||
|
let id2 = thread::spawn(|| id::create_id().unwrap());
|
||||||
|
assert_ne!(id1.join().unwrap(), id2.join().unwrap());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
2
packages/backend/native-utils/src/util/mod.rs
Normal file
2
packages/backend/native-utils/src/util/mod.rs
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
pub mod id;
|
||||||
|
pub mod random;
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue