6 releases (breaking)
0.5.0 | Nov 12, 2021 |
---|---|
0.4.1 | Nov 8, 2021 |
0.3.0 | Nov 5, 2021 |
0.2.0 | Nov 3, 2021 |
0.1.0 | Oct 26, 2021 |
#836 in Procedural macros
40KB
890 lines
ConfQL
This is intended as a very low-friction means of turning structured yaml into a GraphQL service.
Your first place to look should be the quick start example in the source repo. There you'll find a way to containerize a GraphQL service given only a quick container build against your schema, run with a data directory mount.
The client surface to this library is pretty much just the procedural macro [graphql_schema_from_file].
Example
use confql::graphql_schema;
use indoc::indoc;
use juniper::{graphql_value, EmptyMutation, EmptySubscription};
use test_files::TestFiles;
// In practice you'll more likely use the `graphql_schema_from_file` macro
// but this macro is nice for tests.
graphql_schema!{
type Alien {
name: String! @confql(arrayIdentifier: true)
size: Float!
}
type Query {
customers: [Alien!]!
}
schema {
query: Query
}
};
// We have some types generated to play with
let _mork = Alien {
name: "Mork".to_string(),
size: 12.0
};
// And juniper can execute, resolving against files
// Assemble some demo data on the filesystem
let mocks = TestFiles::new();
mocks.file(
"customers/Paul.yml",
indoc! {"
---
size: 9.5
"},
);
// The `Ctx` struct has been generated for us, implementing
// `juniper::Context`. All it needs to initialize is a `PathBuf`
// pointing at the root of the data directory.
let ctx = Ctx::from(mocks.path().to_path_buf());
// Run the executor.
let (res, _errors) = juniper::execute_sync(
indoc!{"
query {
customers {
name
size
}
}
"},
None,
&Schema::new(Query, EmptyMutation::new(), EmptySubscription::new()),
&juniper::Variables::new(),
&ctx,
)
.unwrap();
// Ensure the value matches.
assert_eq!(
res,
graphql_value!({
"customers": [
{
"name": "Paul",
"size": 9.5
}
]
})
);
Current version: 0.5.0
License: MIT
Dependencies
~12MB
~240K SLoC