006b44f580
* Begin adding support for timeline * fix some bugs with parser * fmt * add error reporting for parser * add tests for timeline query parser * add rejection tests for parse * begin adding support for lists also run migration before compiling, so schema.rs is up to date * add sqlite migration * end adding lists still miss tests and query integration * cargo fmt * try to add some tests * Add some constraint to db, and fix list test and refactor other tests to use begin_transaction * add more tests for lists * add support for lists in query executor * add keywords for including/excluding boosts and likes * cargo fmt * add function to list lists used by query will make it easier to warn users when creating timeline with unknown lists * add lang support * add timeline creation error message when using unexisting lists * Update .po files * WIP: interface for timelines * don't use diesel for migrations not sure how it passed the ci on the other branch * add some tests for timeline add an int representing the order of timelines (first one will be on top, second just under...) use first() instead of limit(1).get().into_iter().nth(0) remove migrations from build artifacts as they are now compiled in * cargo fmt * remove timeline order * fix tests * add tests for timeline creation failure * cargo fmt * add tests for timelines * add test for matching direct lists and keywords * add test for language filtering * Add a more complex test for Timeline::matches, and fix TQ::matches for TQ::Or * Make the main crate compile + FMT * Use the new timeline system - Replace the old "feed" system with timelines - Display all timelines someone can access on their home page (either their personal ones, or instance timelines) - Remove functions that were used to get user/local/federated feed - Add new posts to timelines - Create a default timeline called "My feed" for everyone, and "Local feed"/"Federated feed" with timelines @fdb-hiroshima I don't know if that's how you pictured it? If you imagined it differently I can of course make changes. I hope I didn't forgot anything… * Cargo fmt * Try to fix the migration * Fix tests * Fix the test (for real this time ?) * Fix the tests ? + fmt * Use Kind::Like and Kind::Reshare when needed * Forgot to run cargo fmt once again * revert translations * fix reviewed stuff * reduce code duplication by macros * cargo fmt
317 lines
6.7 KiB
Rust
317 lines
6.7 KiB
Rust
table! {
|
|
api_tokens (id) {
|
|
id -> Int4,
|
|
creation_date -> Timestamp,
|
|
value -> Text,
|
|
scopes -> Text,
|
|
app_id -> Int4,
|
|
user_id -> Int4,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
apps (id) {
|
|
id -> Int4,
|
|
name -> Text,
|
|
client_id -> Text,
|
|
client_secret -> Text,
|
|
redirect_uri -> Nullable<Text>,
|
|
website -> Nullable<Text>,
|
|
creation_date -> Timestamp,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
blog_authors (id) {
|
|
id -> Int4,
|
|
blog_id -> Int4,
|
|
author_id -> Int4,
|
|
is_owner -> Bool,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
blogs (id) {
|
|
id -> Int4,
|
|
actor_id -> Varchar,
|
|
title -> Varchar,
|
|
summary -> Text,
|
|
outbox_url -> Varchar,
|
|
inbox_url -> Varchar,
|
|
instance_id -> Int4,
|
|
creation_date -> Timestamp,
|
|
ap_url -> Text,
|
|
private_key -> Nullable<Text>,
|
|
public_key -> Text,
|
|
fqn -> Text,
|
|
summary_html -> Text,
|
|
icon_id -> Nullable<Int4>,
|
|
banner_id -> Nullable<Int4>,
|
|
theme -> Nullable<Varchar>,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
comments (id) {
|
|
id -> Int4,
|
|
content -> Text,
|
|
in_response_to_id -> Nullable<Int4>,
|
|
post_id -> Int4,
|
|
author_id -> Int4,
|
|
creation_date -> Timestamp,
|
|
ap_url -> Nullable<Varchar>,
|
|
sensitive -> Bool,
|
|
spoiler_text -> Text,
|
|
public_visibility -> Bool,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
comment_seers (id) {
|
|
id -> Int4,
|
|
comment_id -> Int4,
|
|
user_id -> Int4,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
follows (id) {
|
|
id -> Int4,
|
|
follower_id -> Int4,
|
|
following_id -> Int4,
|
|
ap_url -> Text,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
instances (id) {
|
|
id -> Int4,
|
|
public_domain -> Varchar,
|
|
name -> Varchar,
|
|
local -> Bool,
|
|
blocked -> Bool,
|
|
creation_date -> Timestamp,
|
|
open_registrations -> Bool,
|
|
short_description -> Text,
|
|
long_description -> Text,
|
|
default_license -> Text,
|
|
long_description_html -> Varchar,
|
|
short_description_html -> Varchar,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
likes (id) {
|
|
id -> Int4,
|
|
user_id -> Int4,
|
|
post_id -> Int4,
|
|
creation_date -> Timestamp,
|
|
ap_url -> Varchar,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
list_elems (id) {
|
|
id -> Int4,
|
|
list_id -> Int4,
|
|
user_id -> Nullable<Int4>,
|
|
blog_id -> Nullable<Int4>,
|
|
word -> Nullable<Varchar>,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
lists (id) {
|
|
id -> Int4,
|
|
name -> Varchar,
|
|
user_id -> Nullable<Int4>,
|
|
#[sql_name = "type"]
|
|
type_ -> Int4,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
medias (id) {
|
|
id -> Int4,
|
|
file_path -> Text,
|
|
alt_text -> Text,
|
|
is_remote -> Bool,
|
|
remote_url -> Nullable<Text>,
|
|
sensitive -> Bool,
|
|
content_warning -> Nullable<Text>,
|
|
owner_id -> Int4,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
mentions (id) {
|
|
id -> Int4,
|
|
mentioned_id -> Int4,
|
|
post_id -> Nullable<Int4>,
|
|
comment_id -> Nullable<Int4>,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
notifications (id) {
|
|
id -> Int4,
|
|
user_id -> Int4,
|
|
creation_date -> Timestamp,
|
|
kind -> Varchar,
|
|
object_id -> Int4,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
password_reset_requests (id) {
|
|
id -> Int4,
|
|
email -> Varchar,
|
|
token -> Varchar,
|
|
expiration_date -> Timestamp,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
post_authors (id) {
|
|
id -> Int4,
|
|
post_id -> Int4,
|
|
author_id -> Int4,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
posts (id) {
|
|
id -> Int4,
|
|
blog_id -> Int4,
|
|
slug -> Varchar,
|
|
title -> Varchar,
|
|
content -> Text,
|
|
published -> Bool,
|
|
license -> Varchar,
|
|
creation_date -> Timestamp,
|
|
ap_url -> Varchar,
|
|
subtitle -> Text,
|
|
source -> Text,
|
|
cover_id -> Nullable<Int4>,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
reshares (id) {
|
|
id -> Int4,
|
|
user_id -> Int4,
|
|
post_id -> Int4,
|
|
ap_url -> Varchar,
|
|
creation_date -> Timestamp,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
tags (id) {
|
|
id -> Int4,
|
|
tag -> Text,
|
|
is_hashtag -> Bool,
|
|
post_id -> Int4,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
timeline (id) {
|
|
id -> Int4,
|
|
post_id -> Int4,
|
|
timeline_id -> Int4,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
timeline_definition (id) {
|
|
id -> Int4,
|
|
user_id -> Nullable<Int4>,
|
|
name -> Varchar,
|
|
query -> Varchar,
|
|
}
|
|
}
|
|
|
|
table! {
|
|
users (id) {
|
|
id -> Int4,
|
|
username -> Varchar,
|
|
display_name -> Varchar,
|
|
outbox_url -> Varchar,
|
|
inbox_url -> Varchar,
|
|
summary -> Text,
|
|
email -> Nullable<Text>,
|
|
hashed_password -> Nullable<Text>,
|
|
instance_id -> Int4,
|
|
creation_date -> Timestamp,
|
|
ap_url -> Text,
|
|
private_key -> Nullable<Text>,
|
|
public_key -> Text,
|
|
shared_inbox_url -> Nullable<Varchar>,
|
|
followers_endpoint -> Varchar,
|
|
avatar_id -> Nullable<Int4>,
|
|
last_fetched_date -> Timestamp,
|
|
fqn -> Text,
|
|
summary_html -> Text,
|
|
role -> Int4,
|
|
preferred_theme -> Nullable<Varchar>,
|
|
hide_custom_css -> Bool,
|
|
}
|
|
}
|
|
|
|
joinable!(api_tokens -> apps (app_id));
|
|
joinable!(api_tokens -> users (user_id));
|
|
joinable!(blog_authors -> blogs (blog_id));
|
|
joinable!(blog_authors -> users (author_id));
|
|
joinable!(blogs -> instances (instance_id));
|
|
joinable!(comment_seers -> comments (comment_id));
|
|
joinable!(comment_seers -> users (user_id));
|
|
joinable!(comments -> posts (post_id));
|
|
joinable!(comments -> users (author_id));
|
|
joinable!(likes -> posts (post_id));
|
|
joinable!(likes -> users (user_id));
|
|
joinable!(list_elems -> blogs (blog_id));
|
|
joinable!(list_elems -> lists (list_id));
|
|
joinable!(list_elems -> users (user_id));
|
|
joinable!(lists -> users (user_id));
|
|
joinable!(mentions -> comments (comment_id));
|
|
joinable!(mentions -> posts (post_id));
|
|
joinable!(mentions -> users (mentioned_id));
|
|
joinable!(notifications -> users (user_id));
|
|
joinable!(post_authors -> posts (post_id));
|
|
joinable!(post_authors -> users (author_id));
|
|
joinable!(posts -> blogs (blog_id));
|
|
joinable!(posts -> medias (cover_id));
|
|
joinable!(reshares -> posts (post_id));
|
|
joinable!(reshares -> users (user_id));
|
|
joinable!(tags -> posts (post_id));
|
|
joinable!(timeline -> posts (post_id));
|
|
joinable!(timeline -> timeline_definition (timeline_id));
|
|
joinable!(timeline_definition -> users (user_id));
|
|
joinable!(users -> instances (instance_id));
|
|
|
|
allow_tables_to_appear_in_same_query!(
|
|
api_tokens,
|
|
apps,
|
|
blog_authors,
|
|
blogs,
|
|
comments,
|
|
comment_seers,
|
|
follows,
|
|
instances,
|
|
likes,
|
|
list_elems,
|
|
lists,
|
|
medias,
|
|
mentions,
|
|
notifications,
|
|
password_reset_requests,
|
|
post_authors,
|
|
posts,
|
|
reshares,
|
|
tags,
|
|
timeline,
|
|
timeline_definition,
|
|
users,
|
|
);
|