Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/icidasset/ectograph

Ectograph is a set of utility functions for using Ecto in combination with graphql-elixir/graphql
https://github.com/icidasset/ectograph

ecto graphql graphql-elixir

Last synced: 6 days ago
JSON representation

Ectograph is a set of utility functions for using Ecto in combination with graphql-elixir/graphql

Awesome Lists containing this project

README

        

__Ectograph is a set of utility functions for using [Ecto](https://github.com/elixir-lang/ecto) in combination with [graphql-elixir/graphql](https://github.com/graphql-elixir/graphql).__

```
{
:ecto, "~> 2.0.2",
:graphql, "~> 0.3.1"
}
```

Features:

- Map a Ecto.Type to a GraphQL.Type
- Map a Ecto.Schema to a GraphQL.Type.ObjectType
- Provide extra GraphQL types, such as DateTime
- Utilities to help build a GraphQL schema

### How to use

##### Schemas

```elixir
defmodule Schemas.Quote do
use Ecto.Schema

schema "quotes" do
field :quote, :string
field :author, :string

timestamps
end

end

Ectograph.Schema.cast(Schemas.Quote)
# %GraphQL.Type.ObjectType{ name: "quotes", fields: %{ quote: %{ type: ... }, ... }}
```

##### Types

```elixir
Ectograph.Type.cast(:string)
# %GraphQL.Type.String{}

Ectograph.Type.cast({ :array, :integer })
# %GraphQL.Type.List{ ofType: :integer }
```

##### Utilities

```elixir
schema = %GraphQL.Schema{
query: %GraphQL.Type.ObjectType{
name: "Queries",
description: "GraphQL Queries",
fields: %{
quotes: Ectograph.Definitions.build(Quote, :all, ~w()a),
quote: Ectograph.Definitions.build(Quote, :get, ~w(id)a),
},
},
}

# BUILD FUNCTION:
# Quote = Resolver module
# :get = method on resolver that will be called
# ~w(id)a = List of fields that will be used as arguments

# NOTE:
# Either the resolver itself is an Ecto schema,
# or you define a function called 'ecto_schema' that
# returns the Ecto schema.
```

See the [integration tests](/test/integration_test.exs)
for a working example, and the docs for more info.

```elixir
# Adding extra arguments to a query
Ectograph.Definitions.extend_arguments(
put_field_aka_definition_here,
%{ extra_argument: %{ type: %GraphQL.Type.String{} }}
)

# Adding extra fields to a query
Ectograph.Definitions.extend_type_fields(
put_field_aka_definition_here,
%{ extra_field: %{ type: %GraphQL.Type.Int{} }}
)

# Adding associations
Ectograph.Definitions.add_association(
put_field_aka_definition_here,
Resolver,
:association_name,
:multiple # or :single (default = :single)
)
```

##### Maps

How to use maps as arguments in mutations:

```elixir
defmodule Example do
use Ecto.Schema

schema "examples" do
field :attributes, :map
end

def create(_, args, _) do
is_map? args[:attributes] # true
end
end

schema = %GraphQL.Schema{
mutation: %GraphQL.Type.ObjectType{
fields: %{
create: Ectograph.Definitions.build(Example, :create, ~w(attributes)a),
},
},
}
```

Query:

```
mutation _ {
create (attributes: { example: "test" }) { attributes }
}
```

Query with variables:

```
mutation _ ($attributes: Map) {
create (attributes: $attributes) { attributes }
}
```

_Note: Apparently it doesn't matter which type you put there._
_Could be `$attributes: Object` too._

### Installation

If [available in Hex](https://hex.pm/docs/publish), the package can be installed as:

1. Add ectograph to your list of dependencies in `mix.exs`:

def deps do
[{:ectograph, "~> 0.2.0"}]
end

2. Ensure ectograph is started before your application:

def application do
[applications: [:ectograph]]
end

### To do

Things that are missing or could be improved

- Embedded schemas
- Associations

Ecto types that still have to be implemented:

- binary
- [decimal](https://github.com/ericmj/decimal)
- date
- time
- _composite types_