Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Giorgi/GraphQLinq
LINQ to GraphQL - Strongly typed GraphQL queries with LINQ query syntax. No more magic strings and runtime errors.
https://github.com/Giorgi/GraphQLinq
csharp graphql json linq netcore
Last synced: 3 months ago
JSON representation
LINQ to GraphQL - Strongly typed GraphQL queries with LINQ query syntax. No more magic strings and runtime errors.
- Host: GitHub
- URL: https://github.com/Giorgi/GraphQLinq
- Owner: Giorgi
- License: other
- Archived: true
- Created: 2017-02-21T21:01:34.000Z (almost 8 years ago)
- Default Branch: main
- Last Pushed: 2023-07-18T11:20:21.000Z (over 1 year ago)
- Last Synced: 2024-05-01T21:19:24.246Z (9 months ago)
- Topics: csharp, graphql, json, linq, netcore
- Language: C#
- Homepage: https://www.giorgi.dev/dotnet/introducing-graphqlinq-strongly-typed-graphql-queries-with-linq-to-graphql/
- Size: 298 KB
- Stars: 204
- Watchers: 7
- Forks: 22
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
Awesome Lists containing this project
README
# GraphQLinq
LINQ to GraphQL - Strongly typed GraphQL queries with LINQ query syntax.
> You **must regenerate** your client code with GraphQLinq.Scaffolding after updating GraphQLinq.Client to a newer version
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg?style=for-the-badge&logo=Apache)](License.md)
[![AppVeyor](https://img.shields.io/appveyor/build/Giorgi/graphqlinq/master.svg?style=for-the-badge&logo=appveyor)](https://ci.appveyor.com/project/Giorgi/graphqlinq)
[![Coverage Status](https://img.shields.io/coveralls/github/Giorgi/GraphQLinq?logo=coveralls&style=for-the-badge)](https://coveralls.io/github/Giorgi/GraphQLinq)
[![Ko-Fi](https://img.shields.io/static/v1?style=for-the-badge&message=Support%20the%20Project&color=success&logo=ko-fi&label=$$)](https://ko-fi.com/U6U81LHU8)[![](https://img.shields.io/nuget/dt/GraphQLinq.Client.svg?label=GraphQLinq.Client&style=for-the-badge&logo=NuGet)](https://www.nuget.org/packages/GraphQLinq.Client/)
[![](https://img.shields.io/nuget/dt/GraphQLinq.Scaffolding.svg?label=GraphQLinq.Scaffolding&style=for-the-badge&logo=NuGet)](https://www.nuget.org/packages/GraphQLinq.Scaffolding/)![Project Icon](docs/Images/Icon.png "GraphQLinq Project Icon")
## This library is not maintained any more. For a similar LINQ style GraphQL syntax library check out [ZeroQL](https://github.com/byme8/ZeroQL/)
- [About The Project](#about-the-project)
- [Getting Started](#getting-started)
- [Installing Scaffolding Tool](#installing-scaffolding-tool)
- [Scaffolding Client Code](#scaffolding-client-code)
- [Install GraphQLinq NuGet Package](#install-graphqlinq-nuget-package)
- [Running GraphQL Queries with LINQ](#running-graphql-queries-with-linq)
- [Query all Primitive Properties of a Type](#query-all-primitive-properties-of-a-type)
- [Query Specific Properties](#query-specific-properties)
- [Include Navigation Properties](#include-navigation-properties)
- [Pass Parameters to Queries and Compose Queries](#pass-parameters-to-queries-and-compose-queries)
- [Include Multiple Levels of Navigation Properties](#include-multiple-levels-of-navigation-properties)
- [View Generated Query](#view-generated-query)
- [Roadmap](#roadmap)
- [Contributing](#contributing)
- [License](#license)## About The Project
GraphQLinq is a .NET tool for generating C# classes from a GraphQL endpoint and a .Net Standard library for writing strongly typed GraphQL queries with LINQ.
With GraphQLinq you will:
- Write strongly typed queries with LINQ.
- Have your queries checked by the compiler.
- Run queries and deserialize JSON response into strongly typed classes in a single method call.
- View queries generated by LINQ to GraphQL.## Getting Started
### Install Scaffolding Tool
Before you starting writing queries, you need to generate classes from GraphQL types. This is done by `GraphQLinq.Scaffolding`, a .NET tool that is part of this project.
To get the tool, open your favourite command shell and run
```sh
dotnet tool install --global --version 1.1.0-beta GraphQLinq.Scaffolding
```Running this command will install the `GraphQLinq.Scaffolding` tool and make it available globally for all projects.
### Scaffolding Client Code
Next, navigate to the project where you want to add the classes and scaffold the client code. In this example, I will use the [SpaceX GraphQL Api](https://api.spacex.land/graphql) so run the following command:
```sh
graphqlinq-scaffold https://api.spacex.land/graphql -o SpaceX -n SpaceX
```The `o` option specifies the output directory for generated classes, and `n` specifies the namespace of the classes.
![Scaffolding](docs/Images/Scaffolding.gif "Scaffolding GraphQL Client")
### Install GraphQLinq NuGet Package
Before writing the queries, you need to install the LINQ to GraphQL client library from NuGet. Run the following command to install it in the current project:
```sh
dotnet add package GraphQLinq.Client --version 1.1.0-beta
```## Running GraphQL Queries with LINQ
The scaffolding tool generates classes for types available in the GraphQL type system and a `QueryContext` class that serves as an entry point for running the queries. GraphQLinq supports running different kinds of queries.
### Query all Primitive Properties of a Type
To query all properties of a type, simply run a query like this:
```cs
var spaceXContext = new QueryContext();var company = await spaceXContext.Company().ToItem();
RenderCompanyDetails(company);
```This will query all primitive and string properties of `Company`, but it won't query nested properties or collection type properties. Here is the output of the code snippet:
```sh
┌───────────┬──────────────────────────────────────────────────────────────────────────────────────────────────────────┐
│ Property │ Value │
├───────────┼──────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Name │ SpaceX │
│ Ceo │ Elon Musk │
│ Summary │ SpaceX designs, manufactures and launches advanced rockets and spacecraft. The company was founded in │
│ │ 2002 to revolutionize space technology, with the ultimate goal of enabling people to live on other │
│ │ planets. │
│ Founded │ 2002 │
│ Founder │ Elon Musk │
│ Employees │ 7000 │
└───────────┴──────────────────────────────────────────────────────────────────────────────────────────────────────────┘
```### Query Specific Properties
If you want to query specific properties, including a navigation property, you can specify it with the `Select` method. You either map the projection to an existing type or an anonymous object (`Headquarters` is a nested property):
```cs
var companySummaryAnonymous = await spaceXContext.Company().Select(c => new { c.Ceo, c.Name, c.Headquarters }).ToItem();//Use data class to select specific properties
var companySummary = await spaceXContext.Company().Select(c => new CompanySummary
{
Ceo = c.Ceo,
Name = c.Name,
Headquarters = c.Headquarters
}).ToItem();RenderCompanySummary(companySummary);
```This will result in the following output:
```sh
┌──────────────┬─────────────────┐
│ Property │ Value │
├──────────────┼─────────────────┤
│ Name │ SpaceX │
│ Ceo │ Elon Musk │
│ Headquarters │ ┌─────────────┐ │
│ │ │ California │ │
│ │ │ Hawthorne │ │
│ │ │ Rocket Road │ │
│ │ └─────────────┘ │
└──────────────┴─────────────────┘
```### Include Navigation Properties
You can also query navigation properties using the `Include` method. You can include several properties if you need, and you can also `Include` nested navigation properties:
```cs
var companyWithHeadquartersAndLinks = await spaceXContext.Company()
.Include(info => info.Headquarters)
.Include(info => info.Links).ToItem();RenderCompanyDetailsAndLinks(companyWithHeadquartersAndLinks);
```### Pass Parameters to Queries and Compose Queries
If the query has parameters, the generated method will have a parameter for each query parameter.
This code will query for all `Missions` that included **Orbital ATK** as a manufacturer. It also builds a new query over the existing one that
includes `Payloads` in the result.```cs
var missionsQuery = spaceXContext.Missions(new MissionsFind { Manufacturer = "Orbital ATK" }, null, null)
.Include(mission => mission.Manufacturers);
var missions = await missionsQuery.ToEnumerable();RenderMissions(missions);
var missionsWithPayloads = await missionsQuery.Include(mission => mission.Payloads).ToEnumerable();
RenderMissions(missionsWithPayloads, true);
```### Include Multiple Levels of Navigation Properties
The `Include` method allows quering for multi-level nested properties too. For example, here is how to query for `Launches` and include Rocket's second stage payload manufacturer:
```cs
//Launch_date_unix and Static_fire_date_unix need custom converter
spaceXContext.JsonSerializerOptions.Converters.Add(new UnixEpochDateTimeConverter());var launches = await spaceXContext.Launches(null, 10, 0, null, null)
.Include(launch => launch.Links)
.Include(launch => launch.Rocket)
.Include(launch => launch.Rocket.Second_stage.Payloads.Select(payload => payload.Manufacturer))
.ToEnumerable();RenderLaunches(launches);
```### View Generated Query
You can view the GraphQL query and variables by using the `Query` and `Variables` property of the `GraphQuery` class. The `ToString()` method of the `GraphQuery` class returns the query and the variables combined:
```cs
var missionsQuery = spaceXContext.Missions(new MissionsFind { Manufacturer = "Orbital ATK" }, null, null)
.Include(mission => mission.Manufacturers);var query = missionsQuery.Query;
var fullQuery = missionsQuery.ToString();
```If you run the above code `query` will be equal to
```js
query ($find: MissionsFind) { result: missions (find: $find) {
description
id
name
website
wikipedia
manufacturers
}}
```and the content of `fullQuery` will be:
```json
{"query":"query ($find: MissionsFind) { result: missions (find: $find) {
description
id
name
website
wikipedia
manufacturers
}}","variables":{"find":{"manufacturer":"Orbital ATK"}}}
```## Roadmap
See the [open issues](https://github.com/Giorgi/GraphQLinq/issues) for a list of proposed features and known issues.
## Contributing
If you encounter a bug or have a feature request, please use the [Issue Tracker](https://github.com/Giorgi/GraphQLinq/issues/new). The project is also open to contributions, so feel free to fork the project and open pull requests.
## License
Copyright © Giorgi Dalakishvili
Distributed under the Apache License. See [License](License.md) for more information.