Skip to content

Commit

Permalink
Improved README and added contributor guide
Browse files Browse the repository at this point in the history
  • Loading branch information
milessabin committed Oct 25, 2023
1 parent fe62f9d commit 1581351
Show file tree
Hide file tree
Showing 5 changed files with 296 additions and 27 deletions.
141 changes: 141 additions & 0 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,141 @@
# Contributing

Thanks for taking interest in helping us develop Grackle! If you want to contribute to the project, you can find some
helpful information here.

We welcome all kinds of contribution, including but not limited to,

- documentation improvements, explanatory images/diagrams, fixes in typos, useful links
- refactorings of messy code, build structure, increasing test coverage or quality
- new features and bugfixes (including [bug reports and feature requests][grackle-issues]).

Writing documentation is valuable for learning, so if you find some explanation insufficient, overly complicated or
incorrect, it's a perfect opportunity to make a change to it!

If at any point you run into problems, you can always ask a question on the **#grackle** channel on the Typelevel
[discord server][grackle-dev].

## How to submit a change

If you see something worth adding, make the relevant changes in a fork of the source code and submit a [pull
request][grackle-pulls] to the project. If you don't know what you could help with, take a look at [the issues marked
as "good first issue"][first-issues] or ask on [discord][grackle-dev].

Any contributions are expected to be made in the form of pull requests to the Grackle [repository][grackle-pulls].
Usually it takes one approval for a change to be merged. If it takes too long to get it approved, feel free to ask on
[Discord][grackle-dev].

Grackle is licensed under the Apache Software License 2.0. Opening a pull request is to be considered affirmative
consent to incorporate your changes into the project, granting an unrestricted license to Typelevel to distribute and
derive new work from your changes, as per the contribution terms of ASL 2.0. You also affirm that you own the rights
to the code you are contributing. All contributors retain the copyright to their own work.

Remember to follow the [code of conduct][coc] in online and offline discourse.

## Building the project locally

### Prerequisites

You'll need JDK 11+, [sbt][sbt], [Docker][docker] (for running DB tests) and [Node.js][node] (for running Scala.js
tests).

We use several sbt plugins to build and check the project, including [MiMa (Migration Manager)][mima] and. The
[sbt-typelevel](https://typelevel.org/sbt-typelevel/) plugin does the bulk of the SBT configuration.

### Build process

To compile the code for the whole repository, you can start an interactive sbt shell:

```bash
% sbt
[info] welcome to sbt 1.9.7 (GraalVM Community Java 17.0.8)
[info] loading settings for project global-plugins from sbt-updates.sbt ...
[info] loading global plugins from /home/miles/.sbt/1.0/plugins
[info] loading settings for project grackle-build-build-build-build from metals.sbt ...
[info] loading project definition from /home/miles/projects/grackle/project/project/project/project
[info] loading settings for project grackle-build-build-build from metals.sbt ...
[info] loading project definition from /home/miles/projects/grackle/project/project/project
[success] Generated .bloop/grackle-build-build-build.json
[success] Total time: 2 s, completed 25 Oct 2023, 12:55:45
[info] loading settings for project grackle-build-build from metals.sbt,plugins.sbt ...
[info] loading project definition from /home/miles/projects/grackle/project/project
[success] Generated .bloop/grackle-build-build.json
[success] Total time: 1 s, completed 25 Oct 2023, 12:55:46
[info] loading settings for project grackle-build from metals.sbt,plugins.sbt ...
[info] loading project definition from /home/miles/projects/grackle/project
[info] loading settings for project root from build.sbt ...
[info] resolving key references (29638 settings) ...
[info] set scmInfo to https://github.com/typelevel/grackle
[info] set current project to root (in build file:/home/miles/projects/grackle/)
[info] sbt server started at local:///home/miles/.sbt/1.0/server/9b2532ef9aeebb6c666d/sock
[info] started sbt server
sbt:root>
```

Inside the shell, you can compile the sources for the currently selected Scala version using the `compile` command. To
compile the code for all Scala versions enabled in the build, use `+compile`. To include tests, `Test/compile` or
`+Test/compile`, accordingly.


### Testing

To test the code, you can run the `test` command in sbt. If you want the tests on a single platform, you can use
`rootJVM/test`, `rootJS/test`, or `rootNative/test` instead.

It is possible to run a single test suite from a project on a single platform by [executing a more specific
task](https://www.scala-sbt.org/1.x/docs/Testing.html#testOnly), like `coreJVM/testOnly compiler.ScalarsSuite`.

You can list all available projects by executing the `projects` task:

```sbt
sbt:root> projects
[info] In file:/home/miles/projects/grackle/
[info] benchmarks
[info] buildInfoJS
[info] buildInfoJVM
[info] buildInfoNative
[info] circeJS
[info] circeJVM
[info] circeNative
[info] coreJS
[info] coreJVM
[info] coreNative
[info] demo
[info] docs
[info] doobie
[info] genericJS
[info] genericJVM
[info] genericNative
[info] profile
[info] * root
[info] rootJS
[info] rootJVM
[info] rootNative
[info] skunkJS
[info] skunkJVM
[info] skunkNative
[info] sqlJS
[info] sqlJVM
[info] sqlNative
[info] unidocs
```

Before submitting a change for review, it's worth running some extra checks that will be triggered in Continuous
Integration:

```sbt
sbt:root> prePR
```

If you run into any problems with tests, binary compatibility or other issues, feel free to ask questions on
[discord][grackle-dev].

[grackle-issues]: https://github.com/typelevel/grackle/issues
[grackle-pulls]: https://github.com/typelevel/grackle/pulls
[grackle-dev]: https://discord.gg/GYD4J9w8EK
[coc]: https://github.com/typelevel/grackle/blob/main/CODE_OF_CONDUCT.md
[sbt]: https://www.scala-sbt.org
[mima]: https://github.com/lightbend/mima
[first-issues]: https://github.com/typelevel/grackle/issues?q=is%3Aopen+is%3Aissue+label%3A%22good+first+issue%22
[docker]: https://www.docker.com/
[node]: https://nodejs.org/en/
91 changes: 76 additions & 15 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,31 +1,92 @@
# Grackle - Functional GraphQL for the Typelevel stack
# Grackle - GraphQL for the Typelevel stack <a href="https://typelevel.org/cats/"><img src="https://typelevel.org/cats/img/cats-badge.svg" height="40px" align="right" alt="Cats friendly" /></a>

[![Build Status](https://github.com/typelevel/grackle/workflows/Continuous%20Integration/badge.svg?branch=main)](https://github.com/typelevel/grackle/actions?query=branch%3Amain+workflow%3A%22Continuous+Integration%22)
[![Maven Central](https://img.shields.io/maven-central/v/org.typelevel/grackle-core_2.13?versionPrefix=0)](https://img.shields.io/maven-central/v/org.typelevel/grackle-core_2.13?versionPrefix=0)
[![javadoc](https://javadoc.io/badge2/org.typelevel/grackle-core_2.13/javadoc.svg)](https://javadoc.io/doc/org.typelevel/grackle-core_2.13)
[![Typelevel library](https://img.shields.io/badge/typelevel-library-green.svg)](https://typelevel.org/projects/#grackle)
[![Discord](https://img.shields.io/discord/632277896739946517.svg?label=&logo=discord&logoColor=ffffff&color=404244&labelColor=6A7EC2)](https://discord.gg/GYD4J9w8EK)
<a href="https://typelevel.org/cats/"><img src="https://typelevel.org/cats/img/cats-badge.svg" height="40px" align="right" alt="Cats friendly" /></a>
[![Discord](https://img.shields.io/discord/632277896739946517.svg?label=&logo=discord&logoColor=ffffff&color=404244&labelColor=6A7EC2)][grackle-dev]

## Overview

* Grackle is a [GraphQL](https://graphql.org/) server implementation for [Scala](https://www.scala-lang.org).
* Grackle is powered by [cats](http://typelevel.org/cats/), [cats-effect](https://typelevel.org/cats-effect/), and
[circe](https://circe.github.io/circe/).
Grackle is a [GraphQL](https://graphql.org) server written in functional [Scala](https://www.scala-lang.org), built on
the [Typelevel](https://typelevel.org) stack.

## How to Learn
It's powered by [cats](https://typelevel.org/cats), [cats-effect](https://typelevel.org/cats-effect/),
[fs2](https://github.com/typelevel/fs2) and [http4s](https://http4s.org/), and supports GraphQL queries, mutations and
subscriptions.

* See the [tutorial](https://typelevel.org/grackle)
It has an abstract model of data sources implemented in terms of declarative mappings between GraphQL schemas and
backing data, and cursors into that data. It supports in-memory, DB-backed, and effectful data sources.

## How to Contribute
Grackle is structured as a compiler/interpreter. Queries are type-checked against a GraphQL schema and compiled into
an internal query algebra. The query algebra may be further compiled in a backend-specific way to materialize data. In
particular it can be compiled to efficient SQL and in that regard currently supports Postgres via
[Doobie](https://tpolecat.github.io/doobie/) or [Skunk](https://typelevel.org/skunk/).

- Test it out!
- If you find a bug, open an issue (or fix it and open a PR) at our [GitHub
Repository](https://github.com/typelevel/grackle).
- If you want to make a larger contribution please open an issue first so we can discuss.
Grackle is an [Apache 2.0 licensed](https://www.apache.org/licenses/LICENSE-2.0) Typelevel project and is available
for Scala 2/3 and for [Scala.js](https://www.scala-js.org/) and [Scala Native](https://scala-native.org/en/stable/).

## Code of Conduct
Work has been generously sponsored by
[Aura/Gemini](https://www.aura-astronomy.org/centers/nsfs-oir-lab/gemini-observatory/) and [ITV](https://itv.com) over
the last four years.

## Getting Started

+ See the [tutorial](https://typelevel.org/grackle) and accompanying [demo](https://github.com/typelevel/grackle/tree/main/demo/src/main).
+ Online Scaladoc is available [here](https://javadoc.io/doc/org.typelevel/grackle-core_2.13).
+ Ask us anything the in **#grackle** channel on the Typelevel [discord server][grackle-dev].

To add Grackle to your project you should add the following to your `build.sbt`,

```scala
// Required: Scala 2.13/3.3+
libraryDependencies += "org.typelevel" %% "grackle-core" % "0.15.0"

// Optional: support for in-memory Json backend using circe
libraryDependencies += "org.typelevel" %% "grackle-circe" % "0.15.0"

// Optional: support for in-memory generic Scala backend using shapeless
libraryDependencies += "org.typelevel" %% "grackle-generic" % "0.15.0"

// Optional: support for Postgres backend via Doobie (JVM only)
libraryDependencies += "org.typelevel" %% "grackle-doobie-pg" % "0.15.0"

// Optional: support for Postgres backend via Skunk
libraryDependencies += "org.typelevel" %% "grackle-skunk" % "0.15.0"
```

## Community

Grackle is proud to be a [Typelevel](https://typelevel.org/) project. We are committed to providing a friendly, safe
and welcoming environment for all, and ask that the community adhere to the [Scala Code of
Conduct](https://www.scala-lang.org/conduct/).
Conduct](https://www.scala-lang.org/conduct/) in all venues.

Conversations around Grackle are currently happening on [GitHub issues][grackle-issues], [PR
discussions][grackle-pulls], and [discord][grackle-dev].

The Typelevel [discord][grackle-dev] has a **#grackle** channel, as well as channels for related
projects channels such as **#cats**, **#cats-effect**, **#fs2**, **#doobie** and **#skunk**. If you're new to the Typelevel
ecosystem the **#beginners** channel might also be useful. Please join us!

## Contributing

This project exists thanks to [all the people who
contribute](https://github.com/typelevel/grackle/graphs/contributors).

We welcome all kinds of contribution, including but not limited to,

- documentation improvements, explanatory images/diagrams, fixes in typos, useful links
- refactorings of messy code, build structure, increasing test coverage or quality
- new features and bugfixes (including [bug reports and feature requests][grackle-issues]).

Writing documentation is valuable for learning, so if you find some explanation insufficient, overly complicated or
incorrect, it's a perfect opportunity to make a change to it!

If at any point you run into problems, you can always ask a question on the **#grackle** channel on the Typelevel
[discord server][grackle-dev].

More information, including on how to build locally and submit pull requests, can be found [here](CONTRIBUTING.md).

[grackle-issues]: https://github.com/typelevel/grackle/issues
[grackle-pulls]: https://github.com/typelevel/grackle/pulls
[grackle-dev]: https://discord.gg/GYD4J9w8EK
1 change: 1 addition & 0 deletions docs/CONTRIBUTING.md
4 changes: 4 additions & 0 deletions docs/directory.conf
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
laika.navigationOrder = [
index.md
CONTRIBUTING.md
]
86 changes: 74 additions & 12 deletions docs/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,23 +2,85 @@

## Overview

* Grackle is a [GraphQL](https://graphql.org/) server implementation for [Scala](https://www.scala-lang.org).
* Grackle is powered by [cats](http://typelevel.org/cats/), [cats-effect](https://typelevel.org/cats-effect/), and
[circe](https://circe.github.io/circe/).
Grackle is a [GraphQL](https://graphql.org) server written in functional [Scala](https://www.scala-lang.org), built on
the [Typelevel](https://typelevel.org) stack.

## How to Learn
It's powered by [cats](https://typelevel.org/cats), [cats-effect](https://typelevel.org/cats-effect/),
[fs2](https://github.com/typelevel/fs2) and [http4s](https://http4s.org/), and supports GraphQL queries, mutations and
subscriptions.

* See the [tutorial](tutorial/intro.md)
It has an abstract model of data sources implemented in terms of declarative mappings between GraphQL schemas and
backing data, and cursors into that data. It supports in-memory, DB-backed, and effectful data sources.

## How to Contribute
Grackle is structured as a compiler/interpreter. Queries are type-checked against a GraphQL schema and compiled into
an internal query algebra. The query algebra may be further compiled in a backend-specific way to materialize data. In
particular it can be compiled to efficient SQL and in that regard currently supports Postgres via
[Doobie](https://tpolecat.github.io/doobie/) or [Skunk](https://typelevel.org/skunk/).

- Test it out!
- If you find a bug, open an issue (or fix it and open a PR) at our [GitHub
Repository](https://github.com/typelevel/grackle).
- If you want to make a larger contribution please open an issue first so we can discuss.
Grackle is an [Apache 2.0 licensed](https://www.apache.org/licenses/LICENSE-2.0) Typelevel project and is available
for Scala 2/3 and for [Scala.js](https://www.scala-js.org/) and [Scala Native](https://scala-native.org/en/stable/).

## Code of Conduct
Work has been generously sponsored by
[Aura/Gemini](https://www.aura-astronomy.org/centers/nsfs-oir-lab/gemini-observatory/) and [ITV](https://itv.com) over
the last four years.

## Getting Started

+ See the [tutorial](https://typelevel.org/grackle) and accompanying [demo](https://github.com/typelevel/grackle/tree/main/demo/src/main).
+ Online Scaladoc is available [here](https://javadoc.io/doc/org.typelevel/grackle-core_2.13).
+ Ask us anything the in **#grackle** channel on the Typelevel [discord server][grackle-dev].

To add Grackle to your project you should add the following to your `build.sbt`,

```scala
// Required: Scala 2.13/3.3+
libraryDependencies += "org.typelevel" %% "grackle-core" % "0.15.0"

// Optional: support for in-memory Json backend using circe
libraryDependencies += "org.typelevel" %% "grackle-circe" % "0.15.0"

// Optional: support for in-memory generic Scala backend using shapeless
libraryDependencies += "org.typelevel" %% "grackle-generic" % "0.15.0"

// Optional: support for Postgres backend via Doobie (JVM only)
libraryDependencies += "org.typelevel" %% "grackle-doobie-pg" % "0.15.0"

// Optional: support for Postgres backend via Skunk
libraryDependencies += "org.typelevel" %% "grackle-skunk" % "0.15.0"
```

## Community

Grackle is proud to be a [Typelevel](https://typelevel.org/) project. We are committed to providing a friendly, safe
and welcoming environment for all, and ask that the community adhere to the [Scala Code of
Conduct](https://www.scala-lang.org/conduct/).
Conduct](https://www.scala-lang.org/conduct/) in all venues.

Conversations around Grackle are currently happening on [GitHub issues][grackle-issues], [PR
discussions][grackle-pulls], and [discord][grackle-dev].

The Typelevel [discord][grackle-dev] has a **#grackle** channel, as well as channels for related
projects channels such as **#cats**, **#cats-effect**, **#fs2**, **#doobie** and **#skunk**. If you're new to the Typelevel
ecosystem the **#beginners** channel might also be useful. Please join us!

## Contributing

This project exists thanks to [all the people who
contribute](https://github.com/typelevel/grackle/graphs/contributors).

We welcome all kinds of contribution, including but not limited to,

- documentation improvements, explanatory images/diagrams, fixes in typos, useful links
- refactorings of messy code, build structure, increasing test coverage or quality
- new features and bugfixes (including [bug reports and feature requests][grackle-issues]).

Writing documentation is valuable for learning, so if you find some explanation insufficient, overly complicated or
incorrect, it's a perfect opportunity to make a change to it!

If at any point you run into problems, you can always ask a question on the **#grackle** channel on the Typelevel
[discord server][grackle-dev].

More information, including on how to build locally and submit pull requests, can be found [here](CONTRIBUTING.md).

[grackle-issues]: https://github.com/typelevel/grackle/issues
[grackle-pulls]: https://github.com/typelevel/grackle/pulls
[grackle-dev]: https://discord.gg/GYD4J9w8EK

0 comments on commit 1581351

Please sign in to comment.