Compare commits
82 Commits
feat/with-
...
main
Author | SHA1 | Date | |
---|---|---|---|
277c09d490 | |||
5f522e314b | |||
e1f1d2429e | |||
24722e1550 | |||
b21a5d8647 | |||
730ae66c2b | |||
6f0f60286d | |||
87e3256660 | |||
1c6198b97a | |||
f3aef000ef | |||
b6b608ca1f
|
|||
cce311cfa3
|
|||
d6cc3ae5c5
|
|||
9a9734b2d7
|
|||
2712707da8
|
|||
0c6ba3d630
|
|||
227bbcef8e
|
|||
ac3c5d3672
|
|||
4c3c67c84d | |||
727ee95537 | |||
66c84555f4 | |||
eb7b2e6a6d | |||
fec9e03ada | |||
80159d71d0 | |||
fc9598dadf | |||
4317551cbc | |||
f3e3d93426 | |||
cafd4680bc | |||
cf7f6d45be | |||
a1985d38d5 | |||
07a083ed7e | |||
0575c92a71 | |||
aeba0f00c6
|
|||
a74225d9da
|
|||
64a8ff073e
|
|||
5b5ac71a1e | |||
5a68e8bbdf | |||
5967fe9e1d | |||
312515157c | |||
05821b0f23 | |||
e9abbfb266
|
|||
56c01088b8 | |||
1d76c7b826
|
|||
39a73ee4f0
|
|||
3baff7fe7c
|
|||
b016bfcc5d
|
|||
63e7ef1c63
|
|||
b7dfb28b10
|
|||
7c83d04f48
|
|||
7e15006175
|
|||
abac0169d8
|
|||
ef737418c3
|
|||
22319ce56d
|
|||
bd6b19fde6
|
|||
9f499a4be7
|
|||
4308016351
|
|||
7fc0d8c204
|
|||
c93ee9823c
|
|||
c1d71df0e5
|
|||
90928d08ff
|
|||
03d293bdc8
|
|||
f112bcf1a9
|
|||
98f5bd5c09 | |||
5e6905d3b1 | |||
70650902d0 | |||
5836f63ce2 | |||
d260e48bba | |||
4b97c91b8b | |||
00daeaf166
|
|||
310df8f127
|
|||
e1d19c8fc1
|
|||
2c25e6e75b
|
|||
ecdf3e98bf
|
|||
c61abf50ec
|
|||
5caf30ec9d
|
|||
09f0f0152b
|
|||
1582b6b754
|
|||
5e49d71f0f | |||
cca765e1b0 | |||
b1930d6fa2 | |||
dbb418ebe2 | |||
237a1d094c |
33
.drone.yml
33
.drone.yml
@@ -47,8 +47,6 @@ steps:
|
|||||||
volumes:
|
volumes:
|
||||||
- name: ssh
|
- name: ssh
|
||||||
path: /root/.ssh/
|
path: /root/.ssh/
|
||||||
- name: dockersock
|
|
||||||
path: /var/run
|
|
||||||
- name: ci
|
- name: ci
|
||||||
path: /mnt/ci
|
path: /mnt/ci
|
||||||
commands:
|
commands:
|
||||||
@@ -56,13 +54,21 @@ steps:
|
|||||||
- ssh-add
|
- ssh-add
|
||||||
- echo "$DOCKER_PASSWORD" | docker login --password-stdin --username="$DOCKER_USERNAME" docker.io
|
- echo "$DOCKER_PASSWORD" | docker login --password-stdin --username="$DOCKER_USERNAME" docker.io
|
||||||
- apk add git
|
- apk add git
|
||||||
|
- cuddle --version
|
||||||
- $CI_PREFIX pr
|
- $CI_PREFIX pr
|
||||||
environment:
|
environment:
|
||||||
|
DAGGER_CLOUD_TOKEN:
|
||||||
|
from_secret: dagger_cloud_token
|
||||||
|
DRONE_HOST: "https://ci.i.kjuulh.io"
|
||||||
|
DRONE_USER: "kjuulh"
|
||||||
|
DRONE_TOKEN:
|
||||||
|
from_secret: drone_token
|
||||||
DOCKER_BUILDKIT: 1
|
DOCKER_BUILDKIT: 1
|
||||||
DOCKER_PASSWORD:
|
DOCKER_PASSWORD:
|
||||||
from_secret: docker_password
|
from_secret: docker_password
|
||||||
DOCKER_USERNAME:
|
DOCKER_USERNAME:
|
||||||
from_secret: docker_username
|
from_secret: docker_username
|
||||||
|
DOCKER_HOST: "tcp://192.168.1.155:2376"
|
||||||
CUDDLE_SECRETS_PROVIDER: 1password
|
CUDDLE_SECRETS_PROVIDER: 1password
|
||||||
CUDDLE_ONE_PASSWORD_DOT_ENV: ".env.ci"
|
CUDDLE_ONE_PASSWORD_DOT_ENV: ".env.ci"
|
||||||
CUDDLE_SSH_AGENT: "true"
|
CUDDLE_SSH_AGENT: "true"
|
||||||
@@ -87,8 +93,6 @@ steps:
|
|||||||
volumes:
|
volumes:
|
||||||
- name: ssh
|
- name: ssh
|
||||||
path: /root/.ssh/
|
path: /root/.ssh/
|
||||||
# - name: dockersock
|
|
||||||
# path: /var/run
|
|
||||||
- name: ci
|
- name: ci
|
||||||
path: /mnt/ci
|
path: /mnt/ci
|
||||||
commands:
|
commands:
|
||||||
@@ -96,8 +100,15 @@ steps:
|
|||||||
- ssh-add
|
- ssh-add
|
||||||
- echo "$DOCKER_PASSWORD" | docker login --password-stdin --username="$DOCKER_USERNAME" docker.io
|
- echo "$DOCKER_PASSWORD" | docker login --password-stdin --username="$DOCKER_USERNAME" docker.io
|
||||||
- apk add git
|
- apk add git
|
||||||
|
- cuddle --version
|
||||||
- $CI_PREFIX main
|
- $CI_PREFIX main
|
||||||
environment:
|
environment:
|
||||||
|
DAGGER_CLOUD_TOKEN:
|
||||||
|
from_secret: dagger_cloud_token
|
||||||
|
DRONE_HOST: "https://ci.i.kjuulh.io"
|
||||||
|
DRONE_USER: "kjuulh"
|
||||||
|
DRONE_TOKEN:
|
||||||
|
from_secret: drone_token
|
||||||
REGISTRY_CACHE_USERNAME:
|
REGISTRY_CACHE_USERNAME:
|
||||||
from_secret: registry_cache_username
|
from_secret: registry_cache_username
|
||||||
REGISTRY_CACHE_PASSWORD:
|
REGISTRY_CACHE_PASSWORD:
|
||||||
@@ -117,7 +128,7 @@ steps:
|
|||||||
GIT_PASSWORD:
|
GIT_PASSWORD:
|
||||||
from_secret: git_password
|
from_secret: git_password
|
||||||
CI_PREFIX: "/mnt/ci/ci"
|
CI_PREFIX: "/mnt/ci/ci"
|
||||||
DOCKER_HOST: "tcp://192.168.1.233:2376"
|
DOCKER_HOST: "tcp://192.168.1.155:2376"
|
||||||
CUDDLE_PLEASE_TOKEN:
|
CUDDLE_PLEASE_TOKEN:
|
||||||
from_secret: cuddle_please_token
|
from_secret: cuddle_please_token
|
||||||
OP_SERVICE_ACCOUNT_TOKEN:
|
OP_SERVICE_ACCOUNT_TOKEN:
|
||||||
@@ -140,8 +151,6 @@ steps:
|
|||||||
volumes:
|
volumes:
|
||||||
- name: ssh
|
- name: ssh
|
||||||
path: /root/.ssh/
|
path: /root/.ssh/
|
||||||
- name: dockersock
|
|
||||||
path: /var/run
|
|
||||||
- name: ci
|
- name: ci
|
||||||
path: /mnt/ci
|
path: /mnt/ci
|
||||||
commands:
|
commands:
|
||||||
@@ -175,18 +184,8 @@ steps:
|
|||||||
- "load_secret"
|
- "load_secret"
|
||||||
- "build ci"
|
- "build ci"
|
||||||
|
|
||||||
services:
|
|
||||||
- name: docker
|
|
||||||
image: docker:dind
|
|
||||||
privileged: true
|
|
||||||
volumes:
|
|
||||||
- name: dockersock
|
|
||||||
path: /var/run
|
|
||||||
|
|
||||||
volumes:
|
volumes:
|
||||||
- name: ssh
|
- name: ssh
|
||||||
temp: {}
|
temp: {}
|
||||||
- name: dockersock
|
|
||||||
temp: {}
|
|
||||||
- name: ci
|
- name: ci
|
||||||
temp: {}
|
temp: {}
|
||||||
|
3795
Cargo.lock
generated
3795
Cargo.lock
generated
File diff suppressed because it is too large
Load Diff
@@ -4,9 +4,11 @@ resolver = "2"
|
|||||||
|
|
||||||
[workspace.dependencies]
|
[workspace.dependencies]
|
||||||
|
|
||||||
anyhow = { version = "1.0.80" }
|
anyhow = { version = "1.0.86" }
|
||||||
tokio = { version = "1", features = ["full"] }
|
tokio = { version = "1", features = ["full"] }
|
||||||
tracing = { version = "0.1", features = ["log"] }
|
tracing = { version = "0.1", features = ["log"] }
|
||||||
tracing-subscriber = { version = "0.3.18" }
|
tracing-subscriber = { version = "0.3.18" }
|
||||||
clap = { version = "4.5.2", features = ["derive", "env"] }
|
clap = { version = "4.5.4", features = ["derive", "env"] }
|
||||||
dotenv = { version = "0.15.0" }
|
dotenv = { version = "0.15.0" }
|
||||||
|
|
||||||
|
cuddle-clusters = { git = "https://git.front.kjuulh.io/kjuulh/cuddle-clusters", branch = "main" } #tag = "v0.1.1" }
|
||||||
|
@@ -8,7 +8,7 @@ edition = "2021"
|
|||||||
[dependencies]
|
[dependencies]
|
||||||
tokio.workspace = true
|
tokio.workspace = true
|
||||||
|
|
||||||
dagger-sdk = {git = "https://github.com/kjuulh/dagger.git", branch = "feat/with-send-sync"}
|
dagger-sdk = "0.15.0"
|
||||||
eyre = { version = "0.6.12" }
|
eyre = { version = "0.6.12" }
|
||||||
|
|
||||||
dagger-components = { git = "https://git.front.kjuulh.io/kjuulh/dagger-components", branch = "main" }
|
dagger-components = { git = "https://git.front.kjuulh.io/kjuulh/dagger-components", branch = "main" }
|
||||||
|
@@ -1,15 +1,17 @@
|
|||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
|
||||||
|
use cuddle_ci::drone_templater::DroneTemplater;
|
||||||
use cuddle_ci::rust_service::architecture::{Architecture, Os};
|
use cuddle_ci::rust_service::architecture::{Architecture, Os};
|
||||||
use cuddle_ci::rust_service::{extensions::*, RustService};
|
use cuddle_ci::rust_service::{extensions::*, RustService};
|
||||||
use cuddle_ci::CuddleCI;
|
use cuddle_ci::CuddleCI;
|
||||||
use tokio::sync::Mutex;
|
use tokio::sync::Mutex;
|
||||||
|
|
||||||
|
const BIN_NAME: &str = "cuddle-rust-service-plan";
|
||||||
|
|
||||||
#[tokio::main]
|
#[tokio::main]
|
||||||
async fn main() -> eyre::Result<()> {
|
async fn main() -> eyre::Result<()> {
|
||||||
let client = dagger_sdk::connect().await?;
|
dagger_sdk::connect(|client| async move {
|
||||||
|
let service = &RustService::from(client.clone())
|
||||||
let service = RustService::from(client)
|
|
||||||
.with_arch(Architecture::Amd64)
|
.with_arch(Architecture::Amd64)
|
||||||
.with_os(Os::Linux)
|
.with_os(Os::Linux)
|
||||||
.with_apt(&[
|
.with_apt(&[
|
||||||
@@ -19,25 +21,33 @@ async fn main() -> eyre::Result<()> {
|
|||||||
"libgit2-dev",
|
"libgit2-dev",
|
||||||
"git",
|
"git",
|
||||||
"openssh-client",
|
"openssh-client",
|
||||||
|
"protobuf-compiler",
|
||||||
])
|
])
|
||||||
.with_apt_release(&["git", "openssh-client"])
|
.with_apt_release(&["git", "openssh-client", "protobuf-compiler"])
|
||||||
.with_docker_cli()
|
.with_docker_cli()
|
||||||
.with_cuddle_cli()
|
.with_cuddle_cli()
|
||||||
.with_kubectl()
|
.with_kubectl()
|
||||||
.with_apt_ca_certificates()
|
.with_apt_ca_certificates()
|
||||||
.with_crates(["ci", "crates/*"])
|
.with_crates(["ci", "crates/*"])
|
||||||
.with_mold("2.3.3")
|
.with_mold("2.3.3")
|
||||||
.with_bin_name("cuddle-rust-service-plan")
|
.with_bin_name(BIN_NAME)
|
||||||
.with_deployment(false)
|
.with_deployment(false)
|
||||||
.to_owned();
|
.to_owned();
|
||||||
|
|
||||||
let service = Arc::new(Mutex::new(service));
|
let drone_templater =
|
||||||
|
&DroneTemplater::new(client, "templates/cuddle-rust-service-plan.yaml")
|
||||||
|
.with_variable("bin_name", BIN_NAME)
|
||||||
|
.to_owned();
|
||||||
|
|
||||||
CuddleCI::default()
|
CuddleCI::default()
|
||||||
.with_pull_request(service.clone())
|
.with_pull_request(service)
|
||||||
.with_main(service.clone())
|
.with_main(service)
|
||||||
|
.with_main(drone_templater)
|
||||||
.execute(std::env::args())
|
.execute(std::env::args())
|
||||||
.await?;
|
.await?;
|
||||||
|
Ok(())
|
||||||
|
})
|
||||||
|
.await?;
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
@@ -6,10 +6,14 @@ edition = "2021"
|
|||||||
[dependencies]
|
[dependencies]
|
||||||
tokio.workspace = true
|
tokio.workspace = true
|
||||||
|
|
||||||
dagger-sdk = {git = "https://github.com/kjuulh/dagger.git", branch = "feat/with-send-sync"}
|
dagger-sdk = "0.15.0"
|
||||||
eyre = { version = "0.6.12" }
|
eyre = { version = "0.6.12" }
|
||||||
|
|
||||||
|
tracing.workspace = true
|
||||||
|
tracing-subscriber.workspace = true
|
||||||
|
|
||||||
dagger-components = { git = "https://git.front.kjuulh.io/kjuulh/dagger-components", branch = "main" }
|
dagger-components = { git = "https://git.front.kjuulh.io/kjuulh/dagger-components", branch = "main" }
|
||||||
dagger-rust = { git = "https://git.front.kjuulh.io/kjuulh/dagger-components", branch = "main" }
|
dagger-rust = { git = "https://git.front.kjuulh.io/kjuulh/dagger-components", branch = "main" }
|
||||||
cuddle-ci = { git = "https://git.front.kjuulh.io/kjuulh/dagger-components", branch = "main" }
|
cuddle-ci = { git = "https://git.front.kjuulh.io/kjuulh/dagger-components", branch = "main" }
|
||||||
async-trait = "0.1.77"
|
cuddle-clusters.workspace = true
|
||||||
|
async-trait = "0.1.80"
|
||||||
|
@@ -1,51 +1,187 @@
|
|||||||
use std::sync::Arc;
|
use std::collections::HashMap;
|
||||||
|
use std::path::PathBuf;
|
||||||
|
use std::time::{SystemTime, UNIX_EPOCH};
|
||||||
|
|
||||||
use async_trait::async_trait;
|
use async_trait::async_trait;
|
||||||
use cuddle_ci::cuddle_file::CuddleFile;
|
use cuddle_ci::cuddle_file::CuddleFile;
|
||||||
|
use cuddle_ci::cuddle_please::CuddlePlease;
|
||||||
use cuddle_ci::cuddle_releaser::CuddleReleaser;
|
use cuddle_ci::cuddle_releaser::CuddleReleaser;
|
||||||
use cuddle_ci::rust_service::architecture::{Architecture, Os};
|
use cuddle_ci::rust_service::architecture::{Architecture, Os};
|
||||||
use cuddle_ci::rust_service::RustService;
|
use cuddle_ci::rust_service::RustService;
|
||||||
use cuddle_ci::rust_service::{extensions::*, RustServiceContext};
|
use cuddle_ci::rust_service::{extensions::*, RustServiceContext};
|
||||||
use cuddle_ci::{Context, CuddleCI, MainAction, PullRequestAction};
|
use cuddle_ci::{Context, CuddleCI, MainAction, PullRequestAction};
|
||||||
use tokio::sync::Mutex;
|
use cuddle_clusters::catalog::cluster_vars::ClusterVars;
|
||||||
|
use cuddle_clusters::catalog::crdb_database::CockroachDB;
|
||||||
|
use cuddle_clusters::catalog::cuddle_vars::CuddleVars;
|
||||||
|
use cuddle_clusters::catalog::ingress::Ingress;
|
||||||
|
use cuddle_clusters::catalog::postgres_database::PostgresDatabase;
|
||||||
|
use cuddle_clusters::catalog::vault_secret::VaultSecret;
|
||||||
|
use cuddle_clusters::releaser::Releaser;
|
||||||
|
use cuddle_clusters::IntoComponent;
|
||||||
|
|
||||||
#[tokio::main]
|
#[tokio::main]
|
||||||
async fn main() -> eyre::Result<()> {
|
async fn main() -> eyre::Result<()> {
|
||||||
let client = dagger_sdk::connect().await?;
|
tracing_subscriber::fmt::init();
|
||||||
|
|
||||||
|
dagger_sdk::connect(|client| async move {
|
||||||
let cuddle_file = CuddleFile::from_cuddle_file().await?;
|
let cuddle_file = CuddleFile::from_cuddle_file().await?;
|
||||||
|
|
||||||
let service = RustService::from(client.clone())
|
let service = &RustService::from(client.clone())
|
||||||
|
.with_cuddle_file(&cuddle_file)
|
||||||
.with_arch(Architecture::Amd64)
|
.with_arch(Architecture::Amd64)
|
||||||
.with_os(Os::Linux)
|
.with_os(Os::Linux)
|
||||||
.with_apt(&["libssl-dev", "libz-dev", "libpq-dev", "protobuf-compiler"])
|
.with_apt(&["libssl-dev", "libz-dev", "libpq-dev", "protobuf-compiler"])
|
||||||
.with_apt_release(&["libssl-dev", "libz-dev", "libpq-dev"])
|
.with_apt_release(&["libssl-dev", "libz-dev", "libpq-dev"])
|
||||||
.with_apt_ca_certificates()
|
.with_apt_ca_certificates()
|
||||||
.with_crates(["crates/*"])
|
.with_workspace_crates()
|
||||||
|
.await
|
||||||
.with_mold("2.3.3")
|
.with_mold("2.3.3")
|
||||||
.with_bin_name(cuddle_file.vars.service)
|
|
||||||
.with_deployment(false)
|
|
||||||
.to_owned();
|
.to_owned();
|
||||||
|
|
||||||
let service = Arc::new(Mutex::new(service));
|
let render = &RustServiceRender {
|
||||||
|
service: cuddle_file.vars.service.clone(),
|
||||||
|
//registry: "http://127.0.0.1:7900".into(),
|
||||||
|
//registry: "http://10.0.11.19:7900".into(),
|
||||||
|
registry: "https://releaser.i.kjuulh.io:443".into(),
|
||||||
|
};
|
||||||
|
let deployment = &CuddleReleaser::new(client.clone()).await?;
|
||||||
|
|
||||||
let render = Arc::new(Mutex::new(RustServiceRender::default()));
|
let mut ci = CuddleCI::default();
|
||||||
|
ci.with_pull_request(service)
|
||||||
|
.with_pull_request(render)
|
||||||
|
.with_main(service)
|
||||||
|
.with_main(render)
|
||||||
|
.with_main(deployment)
|
||||||
|
.with_release(service);
|
||||||
|
|
||||||
let deployment = Arc::new(Mutex::new(CuddleReleaser::new(client).await?));
|
if cuddle_file.please.is_some() {
|
||||||
CuddleCI::default()
|
ci.with_main(&CuddlePlease::new(client.clone()));
|
||||||
.with_pull_request(service.clone())
|
}
|
||||||
//.with_pull_request(render.clone())
|
|
||||||
//.with_pull_request(deployment.clone())
|
let name = cuddle_file.vars.service.clone();
|
||||||
.with_main(service.clone())
|
let system_time = SystemTime::now().duration_since(UNIX_EPOCH)?;
|
||||||
.with_main(render.clone())
|
let build_notifications = client
|
||||||
.with_main(deployment.clone())
|
.container()
|
||||||
.execute(std::env::args())
|
.from("docker.io/kasperhermansen/build-notifications:main-1731768496")
|
||||||
|
.with_env_variable("TIME", system_time.as_secs().to_string())
|
||||||
|
.with_env_variable(
|
||||||
|
"SERVICE_HOST",
|
||||||
|
"https://build-notifications.prod.internal.kjuulh.app",
|
||||||
|
)
|
||||||
|
.with_env_variable(
|
||||||
|
"SERVICE_GRPC_HOST",
|
||||||
|
"https://grpc.build-notifications.prod.internal.kjuulh.app",
|
||||||
|
);
|
||||||
|
|
||||||
|
if let Err(e) = build_notifications
|
||||||
|
.with_exec(vec![
|
||||||
|
"build-notifications",
|
||||||
|
"build-started",
|
||||||
|
"--project-name",
|
||||||
|
&name,
|
||||||
|
])
|
||||||
|
.sync()
|
||||||
|
.await
|
||||||
|
{
|
||||||
|
tracing::warn!("failed to send start notification: {}", e.to_string())
|
||||||
|
}
|
||||||
|
|
||||||
|
match ci.execute(std::env::args()).await {
|
||||||
|
Ok(()) => {
|
||||||
|
if let Err(e) = build_notifications
|
||||||
|
.with_exec(vec![
|
||||||
|
"build-notifications",
|
||||||
|
"build-success",
|
||||||
|
"--project-name",
|
||||||
|
&name,
|
||||||
|
])
|
||||||
|
.sync()
|
||||||
|
.await
|
||||||
|
{
|
||||||
|
tracing::warn!("failed to send success notification: {}", e.to_string())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Err(e) => {
|
||||||
|
if let Err(e) = build_notifications
|
||||||
|
.with_exec(vec![
|
||||||
|
"build-notifications",
|
||||||
|
"build-failure",
|
||||||
|
"--project-name",
|
||||||
|
&name,
|
||||||
|
"--error",
|
||||||
|
&e.to_string(),
|
||||||
|
])
|
||||||
|
.sync()
|
||||||
|
.await
|
||||||
|
{
|
||||||
|
tracing::warn!("failed to send failure notification: {}", e.to_string())
|
||||||
|
}
|
||||||
|
|
||||||
|
return Err(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
})
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Default)]
|
#[derive(Default, Clone)]
|
||||||
struct RustServiceRender {}
|
struct RustServiceRender {
|
||||||
|
service: String,
|
||||||
|
registry: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl RustServiceRender {
|
||||||
|
async fn render_templates(&self, image_tag: &str) -> eyre::Result<()> {
|
||||||
|
let mut releaser = Releaser::default();
|
||||||
|
|
||||||
|
releaser
|
||||||
|
.with_service(&self.service)
|
||||||
|
.with_registry(&self.registry);
|
||||||
|
|
||||||
|
match cuddle_clusters::process_opts(
|
||||||
|
vec![
|
||||||
|
CuddleVars::new(&std::env::current_dir()?)
|
||||||
|
.await
|
||||||
|
.map_err(|e| eyre::anyhow!("failed to get cuddle vars: {}", e.to_string()))?
|
||||||
|
.into_component(),
|
||||||
|
ClusterVars::default().into_component(),
|
||||||
|
VaultSecret::default().into_component(),
|
||||||
|
CockroachDB::new(&std::env::current_dir()?)
|
||||||
|
.await
|
||||||
|
.map_err(|e| eyre::anyhow!("failed to get cuddle vars: {}", e.to_string()))?
|
||||||
|
.into_component(),
|
||||||
|
PostgresDatabase::new(&std::env::current_dir()?)
|
||||||
|
.await
|
||||||
|
.map_err(|e| eyre::anyhow!("failed to get cuddle vars: {}", e.to_string()))?
|
||||||
|
.into_component(),
|
||||||
|
Ingress::new(&std::env::current_dir()?)
|
||||||
|
.await
|
||||||
|
.map_err(|e| eyre::anyhow!("failed to get cuddle vars: {}", e.to_string()))?
|
||||||
|
.into_component(),
|
||||||
|
],
|
||||||
|
cuddle_clusters::process::ProcessOpts {
|
||||||
|
path: std::env::current_dir()?,
|
||||||
|
output: PathBuf::from(".cuddle/tmp/cuddle-clusters"),
|
||||||
|
variables: HashMap::from([("image_tag".into(), image_tag.into())]),
|
||||||
|
},
|
||||||
|
Some(releaser),
|
||||||
|
)
|
||||||
|
.await
|
||||||
|
.map_err(|e| eyre::anyhow!("failed to process templates: {}", e.to_string()))
|
||||||
|
{
|
||||||
|
Ok(_) => {}
|
||||||
|
Err(e) => {
|
||||||
|
tracing::error!("failed to process templates: {}", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[async_trait]
|
#[async_trait]
|
||||||
impl MainAction for RustServiceRender {
|
impl MainAction for RustServiceRender {
|
||||||
@@ -54,13 +190,15 @@ impl MainAction for RustServiceRender {
|
|||||||
.get_image_tag()?
|
.get_image_tag()?
|
||||||
.ok_or(eyre::anyhow!("failed to find image_tag"))?;
|
.ok_or(eyre::anyhow!("failed to find image_tag"))?;
|
||||||
|
|
||||||
cuddle_ci::cuddle_x::well_known::render(vec![
|
self.render_templates(&image_tag).await?;
|
||||||
"--cluster",
|
|
||||||
"clank-prod",
|
// cuddle_ci::cuddle_x::well_known::render(vec![
|
||||||
"--image_tag",
|
// "--cluster",
|
||||||
&image_tag,
|
// "clank-prod",
|
||||||
])
|
// "--image_tag",
|
||||||
.await?;
|
// &image_tag,
|
||||||
|
// ])
|
||||||
|
// .await?;
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
@@ -73,13 +211,7 @@ impl PullRequestAction for RustServiceRender {
|
|||||||
.get_image_tag()?
|
.get_image_tag()?
|
||||||
.ok_or(eyre::anyhow!("failed to find image_tag"))?;
|
.ok_or(eyre::anyhow!("failed to find image_tag"))?;
|
||||||
|
|
||||||
cuddle_ci::cuddle_x::well_known::render(vec![
|
self.render_templates(&image_tag).await?;
|
||||||
"--cluster",
|
|
||||||
"clank-dev",
|
|
||||||
"--image_tag",
|
|
||||||
&image_tag,
|
|
||||||
])
|
|
||||||
.await?;
|
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
0
cuddle-clusters/k8s/dev/configmap.yaml
Normal file
0
cuddle-clusters/k8s/dev/configmap.yaml
Normal file
@@ -10,6 +10,13 @@ vars:
|
|||||||
clank-prod:
|
clank-prod:
|
||||||
replicas: "3"
|
replicas: "3"
|
||||||
namespace: prod
|
namespace: prod
|
||||||
|
config:
|
||||||
|
something: something
|
||||||
|
secrets:
|
||||||
|
something.else: something
|
||||||
|
|
||||||
|
cuddle/clusters:
|
||||||
|
dev:
|
||||||
|
|
||||||
scripts:
|
scripts:
|
||||||
render:
|
render:
|
||||||
|
13
templates/clusters/configmap.yaml.jinja2
Normal file
13
templates/clusters/configmap.yaml.jinja2
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
{%- set cluster_namespace = vars.cluster_vars.namespace -%}
|
||||||
|
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
name: {{ vars.cuddle_vars.service }}-config
|
||||||
|
namespace: {{ cluster_namespace }}
|
||||||
|
data:
|
||||||
|
{%- if (vars.cluster_vars.env | items | length) > 0 %}
|
||||||
|
{%- for (name, value) in vars.cluster_vars.env | dictsort %}
|
||||||
|
{{name | upper | replace(".", "_") | replace("-", "_") }}: {{value}}
|
||||||
|
{%- endfor %}
|
||||||
|
{%- endif %}
|
86
templates/clusters/deployment.yaml.jinja2
Normal file
86
templates/clusters/deployment.yaml.jinja2
Normal file
@@ -0,0 +1,86 @@
|
|||||||
|
{%- set service_name = vars.cuddle_vars.service -%}
|
||||||
|
{%- set cluster_name = vars.cluster_vars.name -%}
|
||||||
|
{%- set cluster_namespace = vars.cluster_vars.namespace -%}
|
||||||
|
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: {{ service_name }}
|
||||||
|
cluster: {{ cluster_name }}
|
||||||
|
name: {{ service_name }}
|
||||||
|
namespace: {{ cluster_namespace }}
|
||||||
|
spec:
|
||||||
|
replicas: {{ vars.cluster_vars.replicas }}
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: {{ service_name }}
|
||||||
|
cluster: {{ cluster_name }}
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: {{ service_name }}
|
||||||
|
cluster: {{ cluster_name }}
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- args:
|
||||||
|
- serve
|
||||||
|
command:
|
||||||
|
- {{ service_name }}
|
||||||
|
image: kasperhermansen/{{ service_name }}:{{ vars.user_vars.image_tag }}
|
||||||
|
name: {{ service_name }}
|
||||||
|
envFrom:
|
||||||
|
- configMapRef:
|
||||||
|
name: {{service_name}}-config
|
||||||
|
{%- if vars.cuddle_crdb.has_values %}
|
||||||
|
- configMapRef:
|
||||||
|
name: {{ vars.cuddle_crdb.file_name(service_name) }}
|
||||||
|
{%- endif %}
|
||||||
|
{%- if vars.cuddle_postgres.has_values %}
|
||||||
|
- configMapRef:
|
||||||
|
name: {{ vars.cuddle_postgres.file_name(service_name) }}
|
||||||
|
{%- endif %}
|
||||||
|
{%- if vars.vault_secret.has_values or vars.cuddle_crdb.has_values or vars.cuddle_postgres.has_values %}
|
||||||
|
env:
|
||||||
|
|
||||||
|
{%- if vars.vault_secret.has_values %}
|
||||||
|
{%- for secret in vars.vault_secret.secrets %}
|
||||||
|
- name: {{secret | upper | replace(".", "_") | replace("-", "_") }}
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: {{ vars.vault_secret.file_name(service_name) }}
|
||||||
|
key: {{ secret }}
|
||||||
|
{%- endfor %}
|
||||||
|
{%- endif %}
|
||||||
|
|
||||||
|
{#
|
||||||
|
{%- if vars.cuddle_postgres.has_values %}
|
||||||
|
{%- for env in vars.cuddle_postgres.env %}
|
||||||
|
- name: {{ env | upper | replace(".", "_") | replace("-", "_") }}
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: {{ vars.cuddle_postgres.file_name(service_name) }}
|
||||||
|
key: {{ env }}
|
||||||
|
{%- endfor %}
|
||||||
|
{%- endif %}
|
||||||
|
#}
|
||||||
|
|
||||||
|
{#
|
||||||
|
{%- if vars.cuddle_crdb.has_values %}
|
||||||
|
- name: {{vars.cuddle_crdb.env }}
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: {{ vars.cuddle_crdb.file_name(service_name) }}
|
||||||
|
key: {{ vars.cuddle_crdb.env }}
|
||||||
|
{%- endif %}
|
||||||
|
#}
|
||||||
|
{%- endif %}
|
||||||
|
ports:
|
||||||
|
- containerPort: 3000
|
||||||
|
name: external-http
|
||||||
|
- containerPort: 3001
|
||||||
|
name: internal-http
|
||||||
|
- containerPort: 4000
|
||||||
|
name: external-grpc
|
||||||
|
- containerPort: 4001
|
||||||
|
name: internal-grpc
|
42
templates/clusters/service.yaml.jinja2
Normal file
42
templates/clusters/service.yaml.jinja2
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
{%- set service_name = vars.cuddle_vars.service -%}
|
||||||
|
{%- set cluster_name = vars.cluster_vars.name -%}
|
||||||
|
{%- set cluster_namespace = vars.cluster_vars.namespace -%}
|
||||||
|
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: "{{ service_name }}"
|
||||||
|
namespace: {{ cluster_namespace }}
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
app: {{ service_name }}
|
||||||
|
cluster: {{ cluster_name }}
|
||||||
|
type: LoadBalancer
|
||||||
|
ports:
|
||||||
|
- name: external-http
|
||||||
|
port: 3000
|
||||||
|
targetPort: 3000
|
||||||
|
- name: internal-http
|
||||||
|
port: 3001
|
||||||
|
targetPort: 3001
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: "{{ service_name }}-grpc"
|
||||||
|
namespace: {{ cluster_namespace }}
|
||||||
|
annotations:
|
||||||
|
traefik.ingress.kubernetes.io/service.serversscheme: h2c
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
app: {{ service_name }}
|
||||||
|
cluster: {{ cluster_name }}
|
||||||
|
type: LoadBalancer
|
||||||
|
ports:
|
||||||
|
- name: external-grpc
|
||||||
|
port: 4000
|
||||||
|
targetPort: 4000
|
||||||
|
- name: internal-grpc
|
||||||
|
port: 4001
|
||||||
|
targetPort: 4001
|
||||||
|
|
134
templates/cuddle-rust-service-plan.yaml
Normal file
134
templates/cuddle-rust-service-plan.yaml
Normal file
@@ -0,0 +1,134 @@
|
|||||||
|
kind: pipeline
|
||||||
|
name: cuddle-rust-service-plan
|
||||||
|
type: docker
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: load_secret
|
||||||
|
image: debian:buster-slim
|
||||||
|
volumes:
|
||||||
|
- name: ssh
|
||||||
|
path: /root/.ssh/
|
||||||
|
environment:
|
||||||
|
SSH_KEY:
|
||||||
|
from_secret: gitea_id_ed25519
|
||||||
|
commands:
|
||||||
|
- mkdir -p $HOME/.ssh/
|
||||||
|
- echo "$SSH_KEY" | base64 -d > $HOME/.ssh/id_ed25519
|
||||||
|
- chmod -R 600 ~/.ssh
|
||||||
|
- |
|
||||||
|
cat >$HOME/.ssh/config <<EOL
|
||||||
|
Host git.front.kjuulh.io
|
||||||
|
IdentityFile $HOME/.ssh/id_ed25519
|
||||||
|
IdentitiesOnly yes
|
||||||
|
UserKnownHostsFile=/dev/null
|
||||||
|
StrictHostKeyChecking no
|
||||||
|
EOL
|
||||||
|
- chmod 700 ~/.ssh/config
|
||||||
|
|
||||||
|
- name: build pr
|
||||||
|
image: kasperhermansen/{{bin_name}}:{{image_tag}}
|
||||||
|
volumes:
|
||||||
|
- name: ssh
|
||||||
|
path: /root/.ssh/
|
||||||
|
commands:
|
||||||
|
- eval `ssh-agent`
|
||||||
|
- ssh-add
|
||||||
|
- echo "$DOCKER_PASSWORD" | docker login --password-stdin --username="$DOCKER_USERNAME" docker.io
|
||||||
|
- export CLUSTER=clank-dev
|
||||||
|
- cuddle --version
|
||||||
|
- {{ bin_name }} pr
|
||||||
|
environment:
|
||||||
|
DAGGER_CLOUD_TOKEN:
|
||||||
|
from_secret: dagger_cloud_token
|
||||||
|
DRONE_HOST: "https://ci.i.kjuulh.io"
|
||||||
|
DRONE_USER: "kjuulh"
|
||||||
|
DRONE_TOKEN:
|
||||||
|
from_secret: drone_token
|
||||||
|
REGISTRY_CACHE_USERNAME:
|
||||||
|
from_secret: registry_cache_username
|
||||||
|
REGISTRY_CACHE_PASSWORD:
|
||||||
|
from_secret: registry_cache_password
|
||||||
|
REGISTRY_CACHE_TOKEN:
|
||||||
|
from_secret: registry_cache_token
|
||||||
|
REGISTRY_CACHE_url:
|
||||||
|
from_secret: registry_cache_url
|
||||||
|
DOCKER_BUILDKIT: 1
|
||||||
|
DOCKER_PASSWORD:
|
||||||
|
from_secret: docker_password
|
||||||
|
DOCKER_USERNAME:
|
||||||
|
from_secret: docker_username
|
||||||
|
CUDDLE_SECRETS_PROVIDER: 1password
|
||||||
|
CUDDLE_ONE_PASSWORD_DOT_ENV: ".env.ci"
|
||||||
|
CUDDLE_SSH_AGENT: "true"
|
||||||
|
GIT_PASSWORD:
|
||||||
|
from_secret: git_password
|
||||||
|
CI_PREFIX: "/mnt/ci/ci"
|
||||||
|
DOCKER_HOST: "tcp://192.168.1.155:2376"
|
||||||
|
CUDDLE_PLEASE_TOKEN:
|
||||||
|
from_secret: cuddle_please_token
|
||||||
|
OP_SERVICE_ACCOUNT_TOKEN:
|
||||||
|
from_secret: op_service_account_token
|
||||||
|
when:
|
||||||
|
event:
|
||||||
|
- pull_request
|
||||||
|
depends_on:
|
||||||
|
- "load_secret"
|
||||||
|
|
||||||
|
- name: build main
|
||||||
|
image: kasperhermansen/{{bin_name}}:{{image_tag}}
|
||||||
|
volumes:
|
||||||
|
- name: ssh
|
||||||
|
path: /root/.ssh/
|
||||||
|
commands:
|
||||||
|
- eval `ssh-agent`
|
||||||
|
- ssh-add
|
||||||
|
- echo "$DOCKER_PASSWORD" | docker login --password-stdin --username="$DOCKER_USERNAME" docker.io
|
||||||
|
- export CLUSTER=clank-prod
|
||||||
|
- cuddle --version
|
||||||
|
- {{ bin_name }} main
|
||||||
|
environment:
|
||||||
|
DAGGER_CLOUD_TOKEN:
|
||||||
|
from_secret: dagger_cloud_token
|
||||||
|
DRONE_HOST: "https://ci.i.kjuulh.io"
|
||||||
|
DRONE_USER: "kjuulh"
|
||||||
|
DRONE_TOKEN:
|
||||||
|
from_secret: drone_token
|
||||||
|
REGISTRY_CACHE_USERNAME:
|
||||||
|
from_secret: registry_cache_username
|
||||||
|
REGISTRY_CACHE_PASSWORD:
|
||||||
|
from_secret: registry_cache_password
|
||||||
|
REGISTRY_CACHE_TOKEN:
|
||||||
|
from_secret: registry_cache_token
|
||||||
|
REGISTRY_CACHE_url:
|
||||||
|
from_secret: registry_cache_url
|
||||||
|
DOCKER_BUILDKIT: 1
|
||||||
|
DOCKER_PASSWORD:
|
||||||
|
from_secret: docker_password
|
||||||
|
DOCKER_USERNAME:
|
||||||
|
from_secret: docker_username
|
||||||
|
CUDDLE_SECRETS_PROVIDER: 1password
|
||||||
|
CUDDLE_ONE_PASSWORD_DOT_ENV: ".env.ci"
|
||||||
|
CUDDLE_SSH_AGENT: "true"
|
||||||
|
GIT_PASSWORD:
|
||||||
|
from_secret: git_password
|
||||||
|
CI_PREFIX: "/mnt/ci/ci"
|
||||||
|
DOCKER_HOST: "tcp://192.168.1.155:2376"
|
||||||
|
CUDDLE_PLEASE_TOKEN:
|
||||||
|
from_secret: cuddle_please_token
|
||||||
|
OP_SERVICE_ACCOUNT_TOKEN:
|
||||||
|
from_secret: op_service_account_token
|
||||||
|
when:
|
||||||
|
event:
|
||||||
|
- push
|
||||||
|
branch:
|
||||||
|
- main
|
||||||
|
- master
|
||||||
|
exclude:
|
||||||
|
- pull_request
|
||||||
|
depends_on:
|
||||||
|
- "load_secret"
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
- name: ssh
|
||||||
|
temp: {}
|
||||||
|
|
@@ -16,5 +16,7 @@ spec:
|
|||||||
name: external_http
|
name: external_http
|
||||||
- containerPort: 3001
|
- containerPort: 3001
|
||||||
name: internal_http
|
name: internal_http
|
||||||
- containerPort: 3002
|
- containerPort: 4000
|
||||||
|
name: external_grpc
|
||||||
|
- containerPort: 4001
|
||||||
name: internal_grpc
|
name: internal_grpc
|
||||||
|
@@ -1,3 +1,5 @@
|
|||||||
|
{% set_global cluster_vars = filter_by_prefix(prefix=["clusters", cluster]) %}
|
||||||
|
|
||||||
apiVersion: apps/v1
|
apiVersion: apps/v1
|
||||||
kind: Deployment
|
kind: Deployment
|
||||||
metadata:
|
metadata:
|
||||||
@@ -20,3 +22,18 @@ spec:
|
|||||||
name: internal-http
|
name: internal-http
|
||||||
- containerPort: 3002
|
- containerPort: 3002
|
||||||
name: internal-grpc
|
name: internal-grpc
|
||||||
|
{% if cluster_vars.config or cluster_vars.secrets %}
|
||||||
|
env:
|
||||||
|
{% for secret in cluster_vars.secrets %}
|
||||||
|
- name: SECRET_USERNAME
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: my-secret
|
||||||
|
key: username
|
||||||
|
- name: SECRET_PASSWORD
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: my-secret
|
||||||
|
key: password
|
||||||
|
{% endfor %}
|
||||||
|
{% endif %}
|
||||||
|
@@ -1,4 +1,3 @@
|
|||||||
|
|
||||||
{% set_global cluster_vars = filter_by_prefix(prefix=["clusters", cluster]) %}
|
{% set_global cluster_vars = filter_by_prefix(prefix=["clusters", cluster]) %}
|
||||||
|
|
||||||
apiVersion: kustomize.config.k8s.io/v1beta1
|
apiVersion: kustomize.config.k8s.io/v1beta1
|
||||||
|
Reference in New Issue
Block a user