Skip to content

Commit

Permalink
refactor: inject job_id
Browse files Browse the repository at this point in the history
  • Loading branch information
bodymindarts committed Jun 11, 2024
1 parent 50b1f7f commit f14ec47
Show file tree
Hide file tree
Showing 6 changed files with 22 additions and 10 deletions.
3 changes: 3 additions & 0 deletions bats/examples.bats
Original file line number Diff line number Diff line change
Expand Up @@ -23,10 +23,13 @@ wait_for_new_import_job() {
exec_graphql 'list-accounts'
accounts_before=$(graphql_output '.data.accounts.nodes | length')

job_id=$(random_uuid)
variables=$(
jq -n \
--arg jobId "$job_id" \
'{
input: {
jobId: $jobId,
name: "rust-example",
endpoint: "http://localhost:2253"
}
Expand Down
3 changes: 2 additions & 1 deletion cala-server/migrations/20231211151809_cala_server_setup.sql
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
CREATE TABLE jobs (
id UUID NOT NULL UNIQUE,
name VARCHAR NOT NULL UNIQUE,
name VARCHAR NOT NULL,
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
);
CREATE INDEX idx_jobs_name ON jobs (name);

CREATE TABLE job_events (
id UUID REFERENCES jobs(id) NOT NULL,
Expand Down
4 changes: 3 additions & 1 deletion cala-server/src/extension/cala_outbox_import/mutation.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,12 @@ use async_graphql::*;
use super::job::*;
use crate::{
app::CalaApp,
graphql::{DbOp, Job},
graphql::{primitives::UUID, DbOp, Job},
};

#[derive(InputObject)]
pub struct CalaOutboxImportJobCreateInput {
pub job_id: UUID,
pub name: String,
pub description: Option<String>,
pub endpoint: String,
Expand Down Expand Up @@ -37,6 +38,7 @@ impl Mutation {
.jobs()
.create_and_spawn_in_op::<CalaOutboxImportJobInitializer, _>(
&mut op,
input.job_id.into(),
input.name.clone(),
input.description.clone(),
CalaOutboxImportConfig::from(input),
Expand Down
14 changes: 10 additions & 4 deletions cala-server/src/graphql/primitives.rs
Original file line number Diff line number Diff line change
Expand Up @@ -103,15 +103,21 @@ impl From<UUID> for cala_ledger::TxTemplateId {
}
}

impl From<UUID> for crate::integration::IntegrationId {
impl From<UUID> for cala_ledger::TransactionId {
fn from(uuid: UUID) -> Self {
crate::integration::IntegrationId::from(uuid.0)
cala_ledger::TransactionId::from(uuid.0)
}
}

impl From<UUID> for cala_ledger::TransactionId {
impl From<UUID> for crate::primitives::JobId {
fn from(uuid: UUID) -> Self {
cala_ledger::TransactionId::from(uuid.0)
crate::primitives::JobId::from(uuid.0)
}
}

impl From<UUID> for crate::integration::IntegrationId {
fn from(uuid: UUID) -> Self {
crate::integration::IntegrationId::from(uuid.0)
}
}

Expand Down
6 changes: 2 additions & 4 deletions cala-server/src/job/entity.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ use serde::{Deserialize, Serialize};
use std::borrow::Cow;

use super::error::JobError;
use crate::primitives::JobId;
pub use crate::primitives::JobId;

#[derive(Clone, Eq, Hash, PartialEq, Debug, Serialize, Deserialize, sqlx::Type)]
#[sqlx(transparent)]
Expand Down Expand Up @@ -111,9 +111,7 @@ pub struct NewJob {

impl NewJob {
pub fn builder() -> NewJobBuilder {
let mut builder = NewJobBuilder::default();
builder.id(JobId::new());
builder
NewJobBuilder::default()
}

pub(super) fn initial_events(self) -> EntityEvents<JobEvent> {
Expand Down
2 changes: 2 additions & 0 deletions cala-server/src/job/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,11 +47,13 @@ impl Jobs {
pub async fn create_and_spawn_in_op<I: JobInitializer + Default, D: serde::Serialize>(
&self,
op: &mut AtomicOperation<'_>,
id: JobId,
name: String,
description: Option<String>,
data: D,
) -> Result<Job, JobError> {
let new_job = NewJob::builder()
.id(id)
.name(name)
.description(description)
.data(data)?
Expand Down

0 comments on commit f14ec47

Please sign in to comment.