Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kiosion/sanity-ex
Primitive Sanity.io client for Elixir applications
https://github.com/kiosion/sanity-ex
elixir elixir-lang elixir-library sanity sanity-cms sanity-io
Last synced: 12 days ago
JSON representation
Primitive Sanity.io client for Elixir applications
- Host: GitHub
- URL: https://github.com/kiosion/sanity-ex
- Owner: kiosion
- License: mit
- Created: 2023-06-16T18:13:24.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-07-23T19:23:57.000Z (over 1 year ago)
- Last Synced: 2024-12-17T11:44:20.884Z (2 months ago)
- Topics: elixir, elixir-lang, elixir-library, sanity, sanity-cms, sanity-io
- Language: Elixir
- Homepage: https://hexdocs.pm/sanity_ex/
- Size: 49.8 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# SanityEx
A client for interacting with the Sanity API and constructing GROQ queries from Elixir applications.
This is a very primitive implementation, built mostly for practice & my own use, and only supports _some_ of GROQ's syntax. Please feel free to contribute!
## Installation
Add `sanity_ex` to your list of dependencies in `mix.exs`:
```elixir
def deps do
[
{:sanity_ex, "~> 0.1.0"}
]
```and run `$ mix deps.get`.
## Usage
Add the Client to your supervision tree:
```elixir
defmodule MyApp.Application do
use Applicationdef start(_type, _args) do
children = [
{
SanityEx.Client,
project_id: "your_project_id",
dataset: "production",
api_version: "v2021-03-25",
token: "your_token"
}
]opts = [strategy: :one_for_one, name: MyApp.Supervisor]
Supervisor.start_link(children, opts)
end
end
```Then you can use the Client to interact with the Sanity API:
```elixir
SanityEx.Client.query("*[_type == 'movie']{title, releaseYear}")
```### Options
The following options are required when configuring the client:
- `project_id` - The project ID for your Sanity project.
- `api_version` - The dated version of the Sanity API to use.
- `token` - The API token for making authorized requests.The following are optional:
- `dataset` - The dataset to query against. Defaults to `production`.
- `asset_url` - The base asset URL to use. Defaults to `cdn.sanity.io/images/{project_id}/{dataset}/`.## Documentation
Documentation can be found at [https://hexdocs.pm/sanity_ex](https://hexdocs.pm/sanity_ex).