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

feat!: JSON RPC based typegraph #877

Open
wants to merge 49 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 4 commits
Commits
Show all changes
49 commits
Select commit Hold shift + click to select a range
eb2db29
update: replace wit with codegen interface
luckasRanarison Oct 25, 2024
c3e62f9
wip: dummy server & client sdk rewrite
luckasRanarison Oct 28, 2024
a3077a7
fixup: cleanup
luckasRanarison Oct 28, 2024
fe4b9f1
wip: fix python & try testing
luckasRanarison Oct 29, 2024
93c8226
fix: dev mode & test typegraph parsing
luckasRanarison Nov 4, 2024
752bafe
Merge branch 'main' into feat/typegraph-ng
luckasRanarison Nov 4, 2024
cc03068
fix: several fixes
luckasRanarison Nov 4, 2024
332cd39
wip: fix tests
luckasRanarison Nov 4, 2024
30fc9b9
fix: ghjk tg-build & codegen deno
luckasRanarison Nov 5, 2024
a2c02cb
fix: remove wasm related ops
luckasRanarison Nov 5, 2024
70375bb
fix: TS client
luckasRanarison Nov 5, 2024
76a2064
fix: bad mappings
luckasRanarison Nov 5, 2024
4de7198
fix: wasm tests
luckasRanarison Nov 5, 2024
dc7c676
fix: tg-build
luckasRanarison Nov 6, 2024
e3bc708
fix: node support
luckasRanarison Nov 6, 2024
5129994
fix: cli stuff
luckasRanarison Nov 6, 2024
530446d
fix: fs operations & python lockfile
luckasRanarison Nov 6, 2024
122ca73
fix: python sync test
luckasRanarison Nov 6, 2024
fd3942f
wip: temporary fixes
luckasRanarison Nov 11, 2024
ad4070b
fix prisma_test.ts, fix pre-commit
Natoandro Nov 12, 2024
0a1626f
fix other tests
Natoandro Nov 12, 2024
89a91f9
wip: more fixes
luckasRanarison Nov 12, 2024
f9d32d0
fix: snapshot test
luckasRanarison Nov 12, 2024
96d3080
Merge branch 'main' into feat/typegraph-ng
luckasRanarison Nov 13, 2024
d9cacb2
fix: build & merge conflicts
luckasRanarison Nov 13, 2024
0a709c2
fixup: missing import
luckasRanarison Nov 13, 2024
87b6774
fix: jsonrpc prefix
luckasRanarison Nov 13, 2024
c72ddaa
lint (pre-commit)
Natoandro Nov 14, 2024
1f9f159
remove conflicting migrations
Natoandro Nov 14, 2024
cfb0745
fix: merge conflicts
luckasRanarison Nov 14, 2024
b54bdf1
fix: build & some tests
luckasRanarison Nov 14, 2024
39f7b3a
fix: validation test
luckasRanarison Nov 15, 2024
b6f7c39
fix: deno.lock
luckasRanarison Nov 15, 2024
90e42de
Merge branch 'main' into feat/typegraph-ng
luckasRanarison Nov 16, 2024
323571a
fix: some fixes & cleanup
luckasRanarison Nov 16, 2024
045f4a1
fix: additional fixes
luckasRanarison Nov 16, 2024
958a483
fix: metagen & workflow
luckasRanarison Nov 17, 2024
af25ea4
fix: pre-commit
luckasRanarison Nov 17, 2024
63afdea
fix: docker build
luckasRanarison Nov 18, 2024
055bbcd
fix: some parts
luckasRanarison Nov 20, 2024
af5a9b2
fix: dockerfile
luckasRanarison Nov 20, 2024
95e5d45
Merge branch 'main' into feat/typegraph-ng
luckasRanarison Nov 25, 2024
aea1bca
fix: remove logger
luckasRanarison Nov 25, 2024
3ac927e
Merge branch 'main' into feat/typegraph-ng
luckasRanarison Dec 3, 2024
fbb7287
fix: metagen test
luckasRanarison Dec 3, 2024
29a38de
fix: merging & tests
luckasRanarison Jan 7, 2025
0ddaf9a
Merge branch 'main' into feat/typegraph-ng
luckasRanarison Jan 7, 2025
3fe99d7
fix: merge conflits
luckasRanarison Jan 7, 2025
64ba313
fix: pre-commit
luckasRanarison Jan 7, 2025
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
2 changes: 1 addition & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

5 changes: 1 addition & 4 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ common = { path = "src/common/" }
substantial = { path = "src/substantial/" }
metagen = { path = "src/metagen/" }
typegate_engine = { path = "src/typegate/engine" }
typegraph_core = { path = "src/typegraph/core" }

# cli
clap = "=4.5.13"
Expand Down Expand Up @@ -71,7 +72,6 @@ seahash = "4.1.0"
# patterns
anyhow = "1.0.89" # FIXME: replace anyhow with eyre
color-eyre = "0.6.3"
eyre = "0.6.12" # NOTE: keep in sync with verison used by color-eyre
thiserror = "1.0.64"
indoc = "2.0.5"
unindent = "0.2.3"
Expand Down Expand Up @@ -124,7 +124,6 @@ uuid = "1.10.0"
# wasm
wasmtime = "25.0.2"
wasmtime-wasi = "25.0.2"
wit-bindgen = "0.34.0"

# deno
# deno = { path = "../deno/cli" }
Expand All @@ -145,8 +144,6 @@ tracing-subscriber = { version = "0.3.18", features = [
tracing-error = "0.2"
# `unwrap` that also logs
tracing-unwrap = { version = "1.0.1", features = ["log-location"] }
# collect traces to file
tracing-appender = "0.2.3"

# async
futures = "=0.3.30" # pinned due to bug with .31 with zeromq (deno)
Expand Down
1 change: 1 addition & 0 deletions src/meta-cli/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ typegate = ["dep:typegate_engine"]
[dependencies]

# internal
typegraph_core.workspace = true
typegate_engine = { workspace = true, optional = true }
common.workspace = true
metagen.workspace = true
Expand Down
2 changes: 1 addition & 1 deletion src/meta-cli/src/deploy/actors/task/action.rs
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,7 @@ pub trait TaskAction: std::fmt::Debug + Clone + Send + Unpin {

fn get_rpc_response(
&self,
call: &Self::RpcCall,
call: Self::RpcCall,
) -> impl Future<Output = Result<serde_json::Value>>;
}

Expand Down
12 changes: 9 additions & 3 deletions src/meta-cli/src/deploy/actors/task/deploy.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ use crate::deploy::actors::console::Console;
use crate::deploy::actors::task_manager::TaskRef;
use crate::interlude::*;
use crate::secrets::Secrets;
use crate::typegraph::rpc::{RpcCall as TypegraphRpcCall, RpcDispatch};
use color_eyre::owo_colors::OwoColorize;
use common::node::Node;
use serde::Deserialize;
Expand Down Expand Up @@ -161,7 +162,11 @@ pub enum MigrationActionOverride {
#[serde(tag = "method", content = "params")]
pub enum RpcCall {
GetDeployTarget,
GetDeployData { typegraph: String },
GetDeployData {
typegraph: String,
},
#[serde(untagged)]
TypegraphCall(TypegraphRpcCall),
}

struct ResetDatabase(PrismaRuntimeId);
Expand Down Expand Up @@ -297,14 +302,15 @@ impl TaskAction for DeployAction {
&self.task_ref
}

async fn get_rpc_response(&self, call: &RpcCall) -> Result<serde_json::Value> {
async fn get_rpc_response(&self, call: RpcCall) -> Result<serde_json::Value> {
match call {
RpcCall::GetDeployTarget => {
let deploy_target: &Node = &self.deploy_target;
Ok(serde_json::to_value(deploy_target)?)
}

RpcCall::GetDeployData { typegraph } => Ok(self.get_deploy_data(typegraph).await?),
RpcCall::GetDeployData { typegraph } => Ok(self.get_deploy_data(&typegraph).await?),
RpcCall::TypegraphCall(call) => Ok(call.dispatch()?),
}
}
}
Expand Down
2 changes: 1 addition & 1 deletion src/meta-cli/src/deploy/actors/task/list.rs
Original file line number Diff line number Diff line change
Expand Up @@ -175,7 +175,7 @@ impl TaskAction for ListAction {
&self.task_ref
}

async fn get_rpc_response(&self, _call: &serde_json::Value) -> Result<serde_json::Value> {
async fn get_rpc_response(&self, _call: serde_json::Value) -> Result<serde_json::Value> {
Err(ferr!("rpc request not supported on list task"))
}
}
7 changes: 4 additions & 3 deletions src/meta-cli/src/deploy/actors/task/serialize.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ use super::deploy::MigrationAction;
use crate::deploy::actors::console::Console;
use crate::deploy::actors::task_manager::TaskRef;
use crate::interlude::*;
use crate::typegraph::rpc::{RpcCall as TypegraphRpcCall, RpcDispatch};
use color_eyre::owo_colors::OwoColorize;
use common::typegraph::Typegraph;
use serde::Deserialize;
Expand Down Expand Up @@ -106,7 +107,7 @@ impl TaskAction for SerializeAction {
type FailureData = SerializeError;
type Options = SerializeOptions;
type Generator = SerializeActionGenerator;
type RpcCall = serde_json::Value;
type RpcCall = TypegraphRpcCall;

async fn get_command(&self) -> Result<Command> {
build_task_command(
Expand Down Expand Up @@ -171,7 +172,7 @@ impl TaskAction for SerializeAction {
&self.task_ref
}

async fn get_rpc_response(&self, _call: &serde_json::Value) -> Result<serde_json::Value> {
Err(ferr!("rpc request not supported on serialize task"))
async fn get_rpc_response(&self, call: Self::RpcCall) -> Result<serde_json::Value> {
Ok(call.dispatch()?)
}
}
2 changes: 1 addition & 1 deletion src/meta-cli/src/deploy/actors/task_io.rs
Original file line number Diff line number Diff line change
Expand Up @@ -257,7 +257,7 @@ impl<A: TaskAction + 'static> TaskIoActor<A> {
let scope = self.get_console_scope();

let fut = async move {
match action.get_rpc_response(&rpc_call).await {
match action.get_rpc_response(rpc_call).await {
Ok(response) => {
self_addr.do_send(message::SendRpcResponse(req.response(response)));
}
Expand Down
1 change: 1 addition & 0 deletions src/meta-cli/src/typegraph/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,4 @@

pub mod dependency_graph;
pub mod loader;
pub mod rpc;
30 changes: 30 additions & 0 deletions src/meta-cli/src/typegraph/rpc/aws.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
use serde::{Serialize, Deserialize};
use serde_json::Value;
use typegraph_core::{errors::Result, Lib};
use typegraph_core::sdk::aws::*;
#[allow(unused)]
use typegraph_core::sdk::core::{MaterializerId, RuntimeId};

#[derive(Debug, Serialize, Deserialize)]
#[serde(tag = "method", content = "params", rename_all="snake_case")]
pub enum RpcCall {
RegisterS3Runtime { data: S3RuntimeData },
S3PresignGet { runtime: RuntimeId, data: S3PresignGetParams },
S3PresignPut { runtime: RuntimeId, data: S3PresignPutParams },
S3List { runtime: RuntimeId, bucket: String },
S3Upload { runtime: RuntimeId, bucket: String },
S3UploadAll { runtime: RuntimeId, bucket: String },
}

impl super::RpcDispatch for RpcCall {
fn dispatch(self) -> Result<Value> {
match self {
Self::RegisterS3Runtime { data } => Lib::register_s3_runtime(data).map(|res| serde_json::to_value(res).unwrap()),
Self::S3PresignGet { runtime, data } => Lib::s3_presign_get(runtime, data).map(|res| serde_json::to_value(res).unwrap()),
Self::S3PresignPut { runtime, data } => Lib::s3_presign_put(runtime, data).map(|res| serde_json::to_value(res).unwrap()),
Self::S3List { runtime, bucket } => Lib::s3_list(runtime, bucket).map(|res| serde_json::to_value(res).unwrap()),
Self::S3Upload { runtime, bucket } => Lib::s3_upload(runtime, bucket).map(|res| serde_json::to_value(res).unwrap()),
Self::S3UploadAll { runtime, bucket } => Lib::s3_upload_all(runtime, bucket).map(|res| serde_json::to_value(res).unwrap()),
}
}
}
72 changes: 72 additions & 0 deletions src/meta-cli/src/typegraph/rpc/core.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
use serde::{Serialize, Deserialize};
use serde_json::Value;
use typegraph_core::{errors::Result, Lib};
use typegraph_core::sdk::core::*;

#[derive(Debug, Serialize, Deserialize)]
#[serde(tag = "method", content = "params", rename_all="snake_case")]
pub enum RpcCall {
InitTypegraph { params: TypegraphInitParams },
SerializeTypegraph { params: SerializeParams },
WithInjection { type_id: TypeId, injection: String },
WithConfig { type_id: TypeId, config: String },
Refb { name: String, attributes: Option<String> },
Floatb { data: TypeFloat },
Integerb { data: TypeInteger },
Booleanb,
Stringb { data: TypeString },
AsId { id: TypeId, composite: bool },
Fileb { data: TypeFile },
Listb { data: TypeList },
Optionalb { data: TypeOptional },
Unionb { data: TypeUnion },
Eitherb { data: TypeEither },
Structb { data: TypeStruct },
ExtendStruct { tpe: TypeId, props: Vec<(String, TypeId)> },
GetTypeRepr { id: TypeId },
Funcb { data: TypeFunc },
GetTransformData { resolver_input: TypeId, transform_tree: String },
RegisterPolicy { pol: Policy },
WithPolicy { type_id: TypeId, policy_chain: Vec<PolicySpec> },
GetPublicPolicy,
GetInternalPolicy,
RegisterContextPolicy { key: String, check: ContextCheck },
RenameType { tpe: TypeId, new_name: String },
Expose { fns: Vec<(String, TypeId)>, default_policy: Option<Vec<PolicySpec>> },
SetSeed { seed: Option<u32> },
}

impl super::RpcDispatch for RpcCall {
fn dispatch(self) -> Result<Value> {
match self {
Self::InitTypegraph { params } => Lib::init_typegraph(params).map(|res| serde_json::to_value(res).unwrap()),
Self::SerializeTypegraph { params } => Lib::serialize_typegraph(params).map(|res| serde_json::to_value(res).unwrap()),
Self::WithInjection { type_id, injection } => Lib::with_injection(type_id, injection).map(|res| serde_json::to_value(res).unwrap()),
Self::WithConfig { type_id, config } => Lib::with_config(type_id, config).map(|res| serde_json::to_value(res).unwrap()),
Self::Refb { name, attributes } => Lib::refb(name, attributes).map(|res| serde_json::to_value(res).unwrap()),
Self::Floatb { data } => Lib::floatb(data).map(|res| serde_json::to_value(res).unwrap()),
Self::Integerb { data } => Lib::integerb(data).map(|res| serde_json::to_value(res).unwrap()),
Self::Booleanb => Lib::booleanb().map(|res| serde_json::to_value(res).unwrap()),
Self::Stringb { data } => Lib::stringb(data).map(|res| serde_json::to_value(res).unwrap()),
Self::AsId { id, composite } => Lib::as_id(id, composite).map(|res| serde_json::to_value(res).unwrap()),
Self::Fileb { data } => Lib::fileb(data).map(|res| serde_json::to_value(res).unwrap()),
Self::Listb { data } => Lib::listb(data).map(|res| serde_json::to_value(res).unwrap()),
Self::Optionalb { data } => Lib::optionalb(data).map(|res| serde_json::to_value(res).unwrap()),
Self::Unionb { data } => Lib::unionb(data).map(|res| serde_json::to_value(res).unwrap()),
Self::Eitherb { data } => Lib::eitherb(data).map(|res| serde_json::to_value(res).unwrap()),
Self::Structb { data } => Lib::structb(data).map(|res| serde_json::to_value(res).unwrap()),
Self::ExtendStruct { tpe, props } => Lib::extend_struct(tpe, props).map(|res| serde_json::to_value(res).unwrap()),
Self::GetTypeRepr { id } => Lib::get_type_repr(id).map(|res| serde_json::to_value(res).unwrap()),
Self::Funcb { data } => Lib::funcb(data).map(|res| serde_json::to_value(res).unwrap()),
Self::GetTransformData { resolver_input, transform_tree } => Lib::get_transform_data(resolver_input, transform_tree).map(|res| serde_json::to_value(res).unwrap()),
Self::RegisterPolicy { pol } => Lib::register_policy(pol).map(|res| serde_json::to_value(res).unwrap()),
Self::WithPolicy { type_id, policy_chain } => Lib::with_policy(type_id, policy_chain).map(|res| serde_json::to_value(res).unwrap()),
Self::GetPublicPolicy => Lib::get_public_policy().map(|res| serde_json::to_value(res).unwrap()),
Self::GetInternalPolicy => Lib::get_internal_policy().map(|res| serde_json::to_value(res).unwrap()),
Self::RegisterContextPolicy { key, check } => Lib::register_context_policy(key, check).map(|res| serde_json::to_value(res).unwrap()),
Self::RenameType { tpe, new_name } => Lib::rename_type(tpe, new_name).map(|res| serde_json::to_value(res).unwrap()),
Self::Expose { fns, default_policy } => Lib::expose(fns, default_policy).map(|res| serde_json::to_value(res).unwrap()),
Self::SetSeed { seed } => Lib::set_seed(seed).map(|res| serde_json::to_value(res).unwrap()),
}
}
}
24 changes: 24 additions & 0 deletions src/meta-cli/src/typegraph/rpc/mod.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
pub mod aws;
pub mod core;
pub mod runtimes;
pub mod utils;

use enum_dispatch::enum_dispatch;
use serde::{Serialize, Deserialize};
use serde_json::Value;
use typegraph_core::errors::Result;

#[enum_dispatch]
pub trait RpcDispatch {
fn dispatch(self) -> Result<Value>;
}

#[derive(Debug, Serialize, Deserialize)]
#[enum_dispatch(RpcDispatch)]
#[serde(untagged)]
pub enum RpcCall {
Aws(aws::RpcCall),
Core(core::RpcCall),
Runtimes(runtimes::RpcCall),
Utils(utils::RpcCall),
}
Loading
Loading