Skip to content

Commit

Permalink
impl og service
Browse files Browse the repository at this point in the history
  • Loading branch information
zignis committed Apr 8, 2024
1 parent 3c89c2f commit 4fd6f10
Show file tree
Hide file tree
Showing 50 changed files with 2,127 additions and 183 deletions.
122 changes: 0 additions & 122 deletions .config/nextest.toml

This file was deleted.

3 changes: 3 additions & 0 deletions .env.mapping
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@ HOST
PORT

CDN_SERVER_URL
RPC_SERVER_URL

RPC_SECRET_TOKEN

REDIS_HOST
REDIS_PORT
Expand Down
50 changes: 50 additions & 0 deletions .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
name: Continuous integration

on: [pull_request, push]

env:
CARGO_TERM_COLOR: always

jobs:
lint:
name: Lint
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4

- name: Install latest stable
uses: actions-rs/toolchain@v1
with:
toolchain: stable
override: true
components: rustfmt, clippy

- name: Run cargo clippy
uses: actions-rs/cargo@v1
with:
command: clippy
args: --all-targets --all-features -- -D warnings

test:
name: Run tests
runs-on: ubuntu-latest
needs: lint
steps:
- name: Checkout
uses: actions/checkout@v4
with:
# By default actions/checkout checks out a merge commit. Check out the PR head instead.
# https://github.com/actions/checkout#checkout-pull-request-head-commit-instead-of-merge-commit
ref: ${{ github.event.pull_request.head.sha }}

- name: Install latest stable release
uses: actions-rs/toolchain@v1
with:
toolchain: stable
override: true

- name: Run tests
uses: actions-rs/cargo@v1
with:
command: test
27 changes: 24 additions & 3 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -6,24 +6,45 @@ license = "MIT"
authors = ["zignis <[email protected]>"]
repository = "https://github.com/storiny/og.git"

[lib]
doctest = false

[dependencies]
abbrev-num = "0.1.0"
actix-cors = "0.7.0"
actix-extensible-rate-limit = { version = "0.2.1", features = ["redis"] }
actix-http = "3.4.0"
actix-web = { version = "4.4.0", features = ["__compress"] }
async-trait = "0.1.73"
dotenv = "0.15.0"
envy = "0.4.2"
lazy_static = "1.4.0"
mime = "0.3.17"
png = "0.17.13"
prost = "0.12.4"
redis = { version = "0.25.3", features = ["tokio-comp", "aio", "connection-manager"] }
reqwest = { version = "0.12.2", features = ["json"] }
reqwest = { version = "0.12.3", features = ["blocking"] }
resvg = "0.41.0"
rust_decimal = "1.35.0"
rusttype = "0.9.3"
sailfish = "0.8.3"
sentry = { version = "0.32.0", features = ["tracing"] }
serde = { version = "1.0.188", features = ["derive"] }
serde_json = "1.0.115"
strum = { version = "0.26.2", features = ["derive"] }
tonic = { version = "0.11.0", features = ["gzip", "tls", "transport"] }
textwrap = { version = "0.16.1", features = ["smawk"] }
thiserror = "1.0.48"
tiny-skia = { version = "0.11.4", features = ["png-format"] }
tokio = { version = "1.32.0", features = ["macros"] }
tracing = { version = "0.1.40", features = ["attributes"] }
tracing-actix-web = "0.7.9"
tracing-bunyan-formatter = "0.3.9"
tracing-subscriber = { version = "0.3.18", features = ["env-filter"] }
unicode-segmentation = "1.11.0"
unidecode = "0.3.0"
usvg = "0.41.0"
pbjson = "0.6.0"
async-trait = "0.1.79"

[dev-dependencies]
image = { version = "0.25.1", default-features = false, features = ["jpeg", "png", "rayon"] }
image-compare = "0.4.1"
Binary file added fixtures/story.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added fixtures/story_with_external_images.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added fixtures/tag.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added fonts/CabinetGrotesk/CabinetGrotesk-Bold.ttf
Binary file not shown.
Binary file not shown.
Binary file added fonts/CabinetGrotesk/CabinetGrotesk-Medium.ttf
Binary file not shown.
Binary file added fonts/CabinetGrotesk/CabinetGrotesk-Regular.ttf
Binary file not shown.
Binary file added fonts/Satoshi/Satoshi-Bold.ttf
Binary file not shown.
Binary file added fonts/Satoshi/Satoshi-Medium.ttf
Binary file not shown.
Binary file added fonts/Satoshi/Satoshi-Regular.ttf
Binary file not shown.
9 changes: 0 additions & 9 deletions justfile
Original file line number Diff line number Diff line change
Expand Up @@ -13,14 +13,5 @@ build_img:
fmt:
cargo +nightly fmt

test:
cargo nextest run --workspace

test_ci:
cargo nextest run --no-fail-fast --workspace

test_verbose:
cargo nextest run --no-capture --no-fail-fast --workspace

udeps:
cargo +nightly udeps --all-targets
4 changes: 4 additions & 0 deletions src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,10 @@ pub struct Config {
pub port: String,
/// Public URL of the CDN server
pub cdn_server_url: String,
/// Private URL of the RPC server
pub rpc_server_url: String,
/// Private RPC authentication token
pub rpc_secret_token: String,
/// Redis host
pub redis_host: String,
/// Redis port
Expand Down
2 changes: 2 additions & 0 deletions src/constants/dimensions.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
pub const IMG_WIDTH: u32 = 1200;
pub const IMG_HEIGHT: u32 = 630;
40 changes: 40 additions & 0 deletions src/constants/fonts.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
use lazy_static::lazy_static;
use rusttype::Font;

lazy_static! {
// Cabinet Grotesk
pub static ref CABINET_GROTESK_BOLD: Font<'static> =
#[allow(clippy::expect_used)]
Font::try_from_bytes(include_bytes!("../../fonts/CabinetGrotesk/CabinetGrotesk-Bold.ttf") as &[u8])
.expect("error loading the `CabinetGrotesk-Bold.ttf` font file");
//
pub static ref CABINET_GROTESK_EXTRABOLD: Font<'static> =
#[allow(clippy::expect_used)]
Font::try_from_bytes(include_bytes!("../../fonts/CabinetGrotesk/CabinetGrotesk-Extrabold.ttf") as &[u8])
.expect("error loading the `CabinetGrotesk-Extrabold.ttf` font file");
//
pub static ref CABINET_GROTESK_MEDIUM: Font<'static> =
#[allow(clippy::expect_used)]
Font::try_from_bytes(include_bytes!("../../fonts/CabinetGrotesk/CabinetGrotesk-Medium.ttf") as &[u8])
.expect("error loading the `CabinetGrotesk-Medium.ttf` font file");
//
pub static ref CABINET_GROTESK_REGULAR: Font<'static> =
#[allow(clippy::expect_used)]
Font::try_from_bytes(include_bytes!("../../fonts/CabinetGrotesk/CabinetGrotesk-Regular.ttf") as &[u8])
.expect("error loading the `CabinetGrotesk-Regular.ttf` font file");
// Satoshi
pub static ref SATOSHI_BOLD: Font<'static> =
#[allow(clippy::expect_used)]
Font::try_from_bytes(include_bytes!("../../fonts/Satoshi/Satoshi-Bold.ttf") as &[u8])
.expect("error loading the `Satoshi-Bold.ttf` font file");
//
pub static ref SATOSHI_MEDIUM: Font<'static> =
#[allow(clippy::expect_used)]
Font::try_from_bytes(include_bytes!("../../fonts/Satoshi/Satoshi-Medium.ttf") as &[u8])
.expect("error loading the `Satoshi-Medium.ttf` font file");
//
pub static ref SATOSHI_REGULAR: Font<'static> =
#[allow(clippy::expect_used)]
Font::try_from_bytes(include_bytes!("../../fonts/Satoshi/Satoshi-Regular.ttf") as &[u8])
.expect("error loading the `Satoshi-Regular.ttf` font file");
}
1 change: 1 addition & 0 deletions src/constants/icons.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
pub const DEFAULT_AVATAR: &str = r#""#;
3 changes: 3 additions & 0 deletions src/constants/mod.rs
Original file line number Diff line number Diff line change
@@ -1 +1,4 @@
pub mod dimensions;
pub mod fonts;
pub mod icons;
pub mod redis_namespaces;
Loading

0 comments on commit 4fd6f10

Please sign in to comment.