diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 00000000..184b651f --- /dev/null +++ b/CONTRIBUTING.md @@ -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/ diff --git a/README.md b/README.md index e098fa20..219bf34f 100644 --- a/README.md +++ b/README.md @@ -1,31 +1,92 @@ -# Grackle - Functional GraphQL for the Typelevel stack +# Grackle - GraphQL for the Typelevel stack Cats friendly [![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) -Cats friendly +[![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 diff --git a/docs/CONTRIBUTING.md b/docs/CONTRIBUTING.md new file mode 120000 index 00000000..44fcc634 --- /dev/null +++ b/docs/CONTRIBUTING.md @@ -0,0 +1 @@ +../CONTRIBUTING.md \ No newline at end of file diff --git a/docs/directory.conf b/docs/directory.conf new file mode 100644 index 00000000..d5dc14e8 --- /dev/null +++ b/docs/directory.conf @@ -0,0 +1,4 @@ +laika.navigationOrder = [ + index.md + CONTRIBUTING.md +] diff --git a/docs/index.md b/docs/index.md index 3ba92272..5bb18ce5 100644 --- a/docs/index.md +++ b/docs/index.md @@ -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