Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(common): feature flagged utoipa dependency #817

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 3 additions & 2 deletions common/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ tracing = { workspace = true, features = ["std"] }
tracing-opentelemetry = { workspace = true, optional = true }
tracing-subscriber = { workspace = true, optional = true }
ttl_cache = { workspace = true, optional = true }
utoipa = { workspace = true }
utoipa = { workspace = true, optional = true }
uuid = { workspace = true, features = ["v4", "serde"], optional = true }

[features]
Expand All @@ -54,7 +54,7 @@ backend = [
"tower-http",
"tracing-subscriber/env-filter",
"tracing-subscriber/fmt",
"ttl_cache",
"ttl_cache"
]
claims = [
"bytes",
Expand All @@ -72,6 +72,7 @@ claims = [
]
display = ["chrono/clock", "comfy-table", "crossterm"]
error = ["prost-types", "thiserror", "uuid"]
openapi = ["utoipa/chrono", "utoipa/uuid"]
models = ["anyhow", "async-trait", "display", "http", "reqwest", "service"]
service = ["chrono/serde", "once_cell", "rustrict", "serde/derive", "uuid"]
tracing = []
Expand Down
12 changes: 8 additions & 4 deletions common/src/database.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,28 +2,32 @@ use std::fmt::Display;

use serde::{Deserialize, Serialize};
use strum::Display;
#[cfg(feature = "openapi")]
use utoipa::ToSchema;

#[derive(Clone, Debug, Deserialize, Serialize, Eq, PartialEq, ToSchema)]
#[derive(Clone, Debug, Deserialize, Serialize, Eq, PartialEq)]
#[serde(rename_all = "lowercase")]
#[schema(as = shuttle_common::database::Type)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::database::Type))]
pub enum Type {
AwsRds(AwsRdsEngine),
Shared(SharedEngine),
}

#[derive(Clone, Debug, Deserialize, Display, Serialize, Eq, PartialEq, ToSchema)]
#[derive(Clone, Debug, Deserialize, Display, Serialize, Eq, PartialEq)]
#[serde(rename_all = "lowercase")]
#[strum(serialize_all = "lowercase")]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
pub enum AwsRdsEngine {
Postgres,
MySql,
MariaDB,
}

#[derive(Clone, Debug, Deserialize, Display, Serialize, Eq, PartialEq, ToSchema)]
#[derive(Clone, Debug, Deserialize, Display, Serialize, Eq, PartialEq)]
#[serde(rename_all = "lowercase")]
#[strum(serialize_all = "lowercase")]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
pub enum SharedEngine {
Postgres,
MongoDb,
Expand Down
6 changes: 4 additions & 2 deletions common/src/deployment.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
use serde::{Deserialize, Serialize};
use strum::Display;
#[cfg(feature = "openapi")]
use utoipa::ToSchema;

#[derive(Clone, Debug, Deserialize, Display, Serialize, ToSchema)]
#[derive(Clone, Debug, Deserialize, Display, Serialize)]
#[serde(rename_all = "lowercase")]
#[strum(serialize_all = "lowercase")]
#[schema(as = shuttle_common::deployment::State)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::deployment::State))]
pub enum State {
Queued,
Building,
Expand Down
19 changes: 11 additions & 8 deletions common/src/log.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,23 +5,25 @@ use chrono::{DateTime, Utc};
#[cfg(feature = "display")]
use crossterm::style::{StyledContent, Stylize};
use serde::{Deserialize, Serialize};
#[cfg(feature = "openapi")]
use utoipa::ToSchema;
use uuid::Uuid;

use crate::deployment::State;

pub const STATE_MESSAGE: &str = "NEW STATE";

#[derive(Clone, Debug, Deserialize, Serialize, ToSchema)]
#[schema(as = shuttle_common::log::Item)]
#[derive(Clone, Debug, Deserialize, Serialize)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::log::Item))]
pub struct Item {
#[schema(value_type = KnownFormat::Uuid)]
#[cfg_attr(feature = "openapi", schema(value_type = KnownFormat::Uuid))]
pub id: Uuid,
#[schema(value_type = KnownFormat::DateTime)]
#[cfg_attr(feature = "openapi", schema(value_type = KnownFormat::DateTime))]
pub timestamp: DateTime<Utc>,
#[schema(value_type = shuttle_common::deployment::State)]
#[cfg_attr(feature = "openapi", schema(value_type = shuttle_common::deployment::State))]
pub state: State,
#[schema(value_type = shuttle_common::log::Level)]
#[cfg_attr(feature = "openapi", schema(value_type = shuttle_common::log::Level))]
pub level: Level,
pub file: Option<String>,
pub line: Option<u32>,
Expand Down Expand Up @@ -83,9 +85,10 @@ impl std::fmt::Display for Item {
}
}

#[derive(Clone, Debug, Deserialize, Serialize, Eq, PartialEq, ToSchema)]
#[derive(Clone, Debug, Deserialize, Serialize, Eq, PartialEq)]
#[serde(rename_all = "lowercase")]
#[schema(as = shuttle_common::log::Level)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::log::Level))]
pub enum Level {
Trace,
Debug,
Expand Down
14 changes: 8 additions & 6 deletions common/src/models/deployment.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,21 +7,23 @@ use comfy_table::{
};
use crossterm::style::Stylize;
use serde::{Deserialize, Serialize};
#[cfg(feature = "openapi")]
use utoipa::ToSchema;
use uuid::Uuid;

use crate::deployment::State;

#[derive(Deserialize, Serialize, ToSchema)]
#[schema(as = shuttle_common::models::deployment::Response)]
#[derive(Deserialize, Serialize)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::models::deployment::Response))]
pub struct Response {
#[schema(value_type = KnownFormat::Uuid)]
#[cfg_attr(feature = "openapi", schema(value_type = KnownFormat::Uuid))]
pub id: Uuid,
#[schema(value_type = KnownFormat::Uuid)]
#[cfg_attr(feature = "openapi", schema(value_type = KnownFormat::Uuid))]
pub service_id: Uuid,
#[schema(value_type = shuttle_common::deployment::State)]
#[cfg_attr(feature = "openapi", schema(value_type = shuttle_common::deployment::State))]
pub state: State,
#[schema(value_type = KnownFormat::DateTime)]
#[cfg_attr(feature = "openapi", schema(value_type = KnownFormat::DateTime))]
pub last_update: DateTime<Utc>,
}

Expand Down
18 changes: 11 additions & 7 deletions common/src/models/project.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ use crossterm::style::Stylize;
use serde::{Deserialize, Serialize};
use std::fmt::{Display, Formatter};
use strum::EnumString;
#[cfg(feature = "openapi")]
use utoipa::ToSchema;

/// Timeframe before a project is considered idle
Expand All @@ -16,17 +17,19 @@ pub const fn idle_minutes() -> u64 {
IDLE_MINUTES
}

#[derive(Deserialize, Serialize, Clone, ToSchema)]
#[schema(as = shuttle_common::models::project::Response)]
#[derive(Deserialize, Serialize, Clone)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::models::project::Response))]
pub struct Response {
pub name: String,
#[schema(value_type = shuttle_common::models::project::State)]
#[cfg_attr(feature = "openapi", schema(value_type = shuttle_common::models::project::State))]
pub state: State,
}

#[derive(Clone, Debug, Deserialize, Serialize, EnumString, ToSchema)]
#[derive(Clone, Debug, Deserialize, Serialize, EnumString)]
#[serde(rename_all = "lowercase")]
#[schema(as = shuttle_common::models::project::State)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::models::project::State))]
pub enum State {
Creating { recreate_count: usize },
Attaching { recreate_count: usize },
Expand Down Expand Up @@ -173,8 +176,9 @@ pub struct Config {
pub idle_minutes: u64,
}

#[derive(Deserialize, Serialize, ToSchema)]
#[schema(as = shuttle_common::models::project::AdminResponse)]
#[derive(Deserialize, Serialize)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::models::project::AdminResponse))]
pub struct AdminResponse {
pub project_name: String,
pub account_name: String,
Expand Down
8 changes: 5 additions & 3 deletions common/src/models/secret.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,15 @@ use comfy_table::{
};
use crossterm::style::Stylize;
use serde::{Deserialize, Serialize};
#[cfg(feature = "openapi")]
use utoipa::ToSchema;

#[derive(Deserialize, Serialize, ToSchema)]
#[schema(as = shuttle_common::models::secret::Response)]
#[derive(Deserialize, Serialize)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::models::secret::Response))]
pub struct Response {
pub key: String,
#[schema(value_type = KnownFormat::DateTime)]
#[cfg_attr(feature = "openapi", schema(value_type = KnownFormat::DateTime))]
pub last_update: DateTime<Utc>,
}

Expand Down
15 changes: 9 additions & 6 deletions common/src/models/service.rs
Original file line number Diff line number Diff line change
@@ -1,24 +1,27 @@
use crossterm::style::Stylize;
use serde::{Deserialize, Serialize};
use std::fmt::Display;
#[cfg(feature = "openapi")]
use utoipa::ToSchema;
use uuid::Uuid;

use crate::models::deployment;

#[derive(Deserialize, Serialize, ToSchema)]
#[schema(as = shuttle_common::models::service::Response)]
#[derive(Deserialize, Serialize)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::models::service::Response))]
pub struct Response {
#[schema(value_type = KnownFormat::Uuid)]
#[cfg_attr(feature = "openapi", schema(value_type = KnownFormat::Uuid))]
pub id: Uuid,
pub name: String,
}

#[derive(Deserialize, Serialize, ToSchema)]
#[schema(as = shuttle_common::models::service::Summary)]
#[derive(Deserialize, Serialize)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::models::service::Summary))]
pub struct Summary {
pub name: String,
#[schema(value_type = shuttle_common::models::deployment::Response)]
#[cfg_attr(feature = "openapi", schema(value_type = shuttle_common::models::deployment::Response))]
pub deployment: Option<deployment::Response>,
pub uri: String,
}
Expand Down
11 changes: 7 additions & 4 deletions common/src/models/stats.rs
Original file line number Diff line number Diff line change
@@ -1,15 +1,18 @@
use serde::{Deserialize, Serialize};
#[cfg(feature = "openapi")]
use utoipa::ToSchema;
use uuid::Uuid;

#[derive(Deserialize, Serialize, ToSchema)]
#[schema(as = shuttle_common::models::stats::LoadRequest)]
#[derive(Deserialize, Serialize)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::models::stats::LoadRequest))]
pub struct LoadRequest {
pub id: Uuid,
}

#[derive(Deserialize, Serialize, ToSchema)]
#[schema(as = shuttle_common::models::stats::LoadResponse)]
#[derive(Deserialize, Serialize)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::models::stats::LoadResponse))]
pub struct LoadResponse {
pub builds_count: usize,
pub has_capacity: bool,
Expand Down
19 changes: 11 additions & 8 deletions common/src/resource.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,32 +2,35 @@ use std::fmt::Display;

use serde::{Deserialize, Serialize};
use serde_json::Value;
#[cfg(feature = "openapi")]
use utoipa::ToSchema;

use crate::database;

/// Common type to hold all the information we need for a generic resource
#[derive(Clone, Deserialize, Serialize, ToSchema)]
#[schema(as = shuttle_common::resource::Response)]
#[derive(Clone, Deserialize, Serialize)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::resource::Response))]
pub struct Response {
/// The type of this resource.
#[schema(value_type = shuttle_common::resource::Type)]
#[cfg_attr(feature = "openapi", schema(value_type = shuttle_common::resource::Type))]
pub r#type: Type,

/// The config used when creating this resource. Use the [Self::r#type] to know how to parse this data.
#[schema(value_type = Object)]
#[cfg_attr(feature = "openapi", schema(value_type = Object))]
pub config: Value,

/// The data associated with this resource. Use the [Self::r#type] to know how to parse this data.
#[schema(value_type = Object)]
#[cfg_attr(feature = "openapi", schema(value_type = Object))]
pub data: Value,
}

#[derive(Clone, Debug, Deserialize, Serialize, Eq, PartialEq, ToSchema)]
#[derive(Clone, Debug, Deserialize, Serialize, Eq, PartialEq)]
#[serde(rename_all = "lowercase")]
#[schema(as = shuttle_common::resource::Type)]
#[cfg_attr(feature = "openapi", derive(ToSchema))]
#[cfg_attr(feature = "openapi", schema(as = shuttle_common::resource::Type))]
pub enum Type {
#[schema(value_type = shuttle_common::database::Type)]
#[cfg_attr(feature = "openapi", schema(value_type = shuttle_common::database::Type))]
Database(database::Type),
Secrets,
StaticFolder,
Expand Down
2 changes: 1 addition & 1 deletion deployer/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ uuid = { workspace = true, features = ["v4"] }

[dependencies.shuttle-common]
workspace = true
features = ["backend", "models"]
features = ["backend", "models", "openapi"]

[dependencies.shuttle-proto]
workspace = true
Expand Down
2 changes: 1 addition & 1 deletion gateway/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ x509-parser = "0.14.0"

[dependencies.shuttle-common]
workspace = true
features = ["backend", "models"]
features = ["backend", "models", "openapi"]

[dev-dependencies]
anyhow = { workspace = true }
Expand Down