Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/outworkers/phantom

Schema safe, type-safe, reactive Scala driver for Cassandra/Datastax Enterprise
https://github.com/outworkers/phantom

cassandra datastax-enterprise phantom reactive reactive-streams scala

Last synced: about 1 month ago
JSON representation

Schema safe, type-safe, reactive Scala driver for Cassandra/Datastax Enterprise

Awesome Lists containing this project

README

        

## phantom

| CI | Test coverage(%) | Code quality | Stable version | ScalaDoc | Chat | Open issues | Average issue resolution time |
| --- | ---------------- | -------------| -------------- | -------- | ---- | ----------- | ----------------------------- |
| [![Build Status](https://travis-ci.org/outworkers/phantom.svg?branch=develop)](https://travis-ci.org/outworkers/phantom?branch=develop) | [![Coverage Status](https://coveralls.io/repos/github/outworkers/phantom/badge.svg?branch=develop)](https://coveralls.io/github/outworkers/phantom?branch=develop) | [![Codacy Rating](https://api.codacy.com/project/badge/grade/25bee222a7d142ff8151e6ceb39151b4)](https://www.codacy.com/app/flavian/phantom_2) | [![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.outworkers/phantom-dsl_2.11/badge.svg)](https://maven-badges.herokuapp.com/maven-central/com.outworkers/phantom-dsl_2.11) | [![ScalaDoc](http://javadoc-badge.appspot.com/com.outworkers/phantom-dsl_2.11.svg?label=scaladoc)](http://javadoc-badge.appspot.com/com.outworkers/phantom-dsl_2.11) | [![Gitter](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/outworkers/phantom?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge) | [![Percentage of issues still open](http://isitmaintained.com/badge/open/outworkers/phantom.svg)](http://isitmaintained.com/project/outworkers/phantom "%% of issues still open") | [![Average time to resolve an issue](http://isitmaintained.com/badge/resolution/outworkers/phantom.svg)](http://isitmaintained.com/project/outworkers/phantom "Average time to resolve an issue") |

Reactive type-safe Scala driver for Apache Cassandra/Datastax Enterprise

To stay up-to-date with our latest releases and news, follow us on Twitter: [@outworkers](https://twitter.com/outworkers_uk).

If you use phantom, please consider adding your company to our list of adopters. Phantom is and will always be open source, but the more adopters our projects have, the more people from our company will actively work to make them better.

![phantom](https://s3-eu-west-1.amazonaws.com/websudos/oss/logos/phantom.png "Outworkers Phantom")

Migrating to phantom 2.14.0 and using execution backends.
=========================================================

Please refer to the new docs on query execution to understand the breaking changes in phantom 2.14.0. They will
affect all users of phantom, as we further optimise the internals for better performance and to gently prepare 3.0.

Details [here](docs_bkp/querying/execution.md). In short, query generation is no longer coupled with query execution within
the framework. That means phantom can natively support different kind of concurrency frameworks in parallel, using
different sub-modules. That includes Monix, Twitter Util, Scala Futures, and a few others, some of which only available
via phantom-pro.

`import com.outworkers.phantom.dsl._` is now required in more places than before. The `future` method is no longer implementation by query classes, but
rather added via implicit augmentation by `QueryContext`. The return type of the `future` method is now dependent
on which `QueryContext` you use, so that's why importing is required, without it the necessary implicits will not
be in scope by default, or similarly, in some places new implicits are required to specify things specific to an execution backend.

Scala 2.13 support
=================================

As of phantom 2.50.0, Scala 2.13 support is officially available, however all support has been dropped for Scala 2.10. To use
Scala 2.10 with phantom, please use a version of phantom earlier than 2.5.0. No support or ongoing maintenance will be
offered for 2.10 artifacts, as the codebase has undergone significant change to support newer versions, and the various
libraries we depend on no longer support this.

Migrating to phantom 2.x.x series
=================================

The new series of phantom introduces several key backwards incompatible changes with previous versions.
This was done to obtain massive performance boosts and to thoroughly improve user experience with
phantom.

Read the [MIGRATION GUIDE](docs_bkp/migrate.md) for more information on how to upgrade.

Available modules
=================

This is a table of the available modules for the various Scala versions. Not all modules are available for all versions just yet, and this is because certain dependencies have yet to be published for Scala 2.12.

#### Phantom OSS

| Module name | Scala 2.11.x | Scala 2.12.x | Scala 2.13.x |
| ------------ | ------------------| ----------------- | ------------------- |
| phantom-connectors | yes | yes | yes |
| phantom-dsl | yes | yes | yes |
| phantom-jdk8 | yes | yes | yes |
| phantom-sbt | no | yes | no |
| phantom-example | yes | yes | yes |
| phantom-thrift | yes | yes | yes |
| phantom-finagle | yes | yes | yes |
| phantom-streams | yes | yes | no |

#### Phantom Pro subscription edition

Modules marked with "x" are still in beta or pre-publishing mode.

| Module name | Scala 2.11.x | Scala 2.12.x | Scala 2.13.x | Release date |
| ------------ | ------------------| ----------------- | ------------------- | -------------- |
| phantom-dse | yes | yes | yes | Released |
| phantom-udt | yes | yes | yes | Released |
| phantom-autotables | yes | yes | yes | Released |
| phantom-monix | yes | yes | yes | Released |
| phantom-docker | x | x | x | Released |
| phantom-migrations | yes | yes | yes | Released |
| phantom-graph | x | x | x | April 2020 |
| phantom-spark | x | x | x | July 2020 |
| phantom-solr | x | x | x | July 2020 |
| phantom-native | x | x | x | December 2020 |
| phantom-java-dsl | x | x | x | December 2020 |

Using phantom
=============

### Scala 2.11, 2.12 and 2.13 releases ###

We publish phantom in 2 formats, stable releases and bleeding edge.

- The stable release is always available on Maven Central and will be indicated by the badge at the top of this readme. The Maven Central badge is pointing at the latest version

- Intermediary releases are available through our Bintray repo available at `Resolver.bintrayRepo("outworkers", "oss-releases")` or `https://dl.bintray.com/outworkers/oss-releases/`. The latest version available on our Bintray repository is indicated by the Bintray badge at the top of this readme.

### How phantom compares

To compare phantom to similar tools in the Scala/Cassandra category, you can read more [here](docs_bkp/comparison.md).

### Latest versions

The latest versions are available here. The badges automatically update when a new version is released.

- Latest stable version: [![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.outworkers/phantom-dsl_2.12/badge.svg)](https://maven-badges.herokuapp.com/maven-central/com.outworkers/phantom-dsl_2.12) (Maven Central)
- Bleeding edge: [![Bintray](https://api.bintray.com/packages/outworkers/oss-releases/phantom-dsl/images/download.svg)](https://bintray.com/outworkers/oss-releases/phantom-dsl/_latestVersion) (OSS releases on Bintray)

Tutorials on phantom and Cassandra
======================================================================

For ease of use and far better management of documentation, we have decided to export the `README.md` to a compiled
documentation page, now available [here](https://github.com/outworkers/phantom/tree/develop/docs).

The following are the current resources available for learning phantom, outside of tests which are very useful in
highlighting all the possible features in phantom and how to use them.

This is a list of resources to help you learn phantom and Cassandra:

- [ ] [Quickstart](docs_bkp/quickstart.md)
- [ ] [Official documentation](docs_bkp/README.md)
- [ ] [Datastax Introduction to Cassandra](http://www.datastax.com/documentation/getting_started/doc/getting_started/gettingStartedIntro_r.html).
- [ ] [The official Scala API docs for phantom](http://phantom-docs.s3-website-eu-west-1.amazonaws.com/)
- [ ] [The main Wiki](https://github.com/outworkers/phantom/tree/develop/docs)
- [ ] The StackOverflow [phantom-dsl](http://stackoverflow.com/questions/tagged/phantom-dsl) tag, which we always monitor!
- [ ] Anything tagged phantom on our blog is a phantom tutorial: [phantom tutorials](http://outworkers.com/blog/tag/phantom)
- [ ] [A series on Cassandra: Getting rid of the SQL mentality](https://medium.com/@flavian_87939/at-outworkers-cassandra-and-datastax-enterprise-are-core-technologies-in-our-area-of-competence-4a1df2eb718d)
- [ ] [A series on Cassandra: Indexes and keys](https://medium.com/outworkers/a-series-on-cassandra-part-2-indexes-and-keys-1351ece6055f)
- [ ] [A series on Cassandra: Advanced features](https://medium.com/@flavian_87939/a-series-on-cassandra-part-3-advanced-features-73abed9d99ab)
- [ ] [A series on phantom: Getting started with phantom](https://medium.com/@flavian_87939/a-series-of-phantom-part1-getting-started-with-phantom-1014787bc550)
- [ ] [The Play! Phantom Activator template](https://github.com/outworkers/phantom-activator-template)
- [ ] [Thiago's Cassandra + Phantom demo repository](https://github.com/thiagoandrade6/cassandra-phantom)

Issues and questions
=====================================================
back to top

We love Cassandra to bits and use it in every bit of our stack. phantom makes it super trivial for Scala users to embrace Cassandra.

Cassandra is highly scalable and it is by far the most powerful database technology available, open source or otherwise.

Phantom is built on top of the [Datastax Java Driver](https://github.com/datastax/java-driver), which handles Cassandra connectivity
and raw query execution.

We are very happy to help implement missing features in phantom, answer questions about phantom, and occasionally help you out with Cassandra questions! Please use GitHub for any issues or bug reports.

Adopters
========

Here are a few of the biggest phantom adopters, though the full list is far more comprehensive.

![Microsoft](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/microsoft.png "Microsoft")
![CreditSuisse](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/creditsuisse.png "CreditSuisse")
![ING](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/ing.png "ING")
![UBS](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/ubs.png "UBS")
![Wincor Nixdorf](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/wincornixdorf.png "Wincor Nixdorf")
![Paddy Power](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/paddypower.png "Paddy Power")
![Strava](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/strava.png "Strava")
![Equens](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/equens.png "Equens")
![Pellucid Analytics](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/pellucid.png "Pellucid Analytics")
![Anomaly42](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/anomaly42.png "Anomaly42")
![ChartBoost](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/chartboost.png "Chartboost")
![Tecsisa](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/tecsisa.png "Tecsisa")
![Mobli](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/mobli.png "Mobli")
![VictorOps](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/victorops.png "Mobli")
![Socrata](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/socrata.png "Socrata")
![Sphonic](https://s3-eu-west-1.amazonaws.com/websudos/oss/adopters/sphonic.png "Sphonic")

License and copyright
======================

Phantom is distributed under the Apache V2 License.

- `Outworkers, Limited` is the copyright holder.

- You can use phantom in commercial products or otherwise.

- We strongly appreciate and encourage contributions.

- All paid for features are published and sold separately as `phantom-pro`, everything that is currently available for free will remain so forever.

If you would like our help with any new content or initiatives, we'd love to hear about it!

Contributors
=====================================
back to top

Phantom was developed at outworkers as an in-house project. All Cassandra integration at outworkers goes through phantom, and nowadays it's safe to say most Scala/Cassandra users in the world rely on phantom.

* Flavian Alexandru ([@alexflav23](https://github.com/alexflav23)) - maintainer
* Bartosz Jankiewicz ([@bjankie1](https://github.com/bjankie1))
* Benjamin Edwards ([@benjumanji](https://github.com/benjumanji))
* Kevin Wright ([@kevinwright](https://github.com/kevinwright))
* Eugene Zhulenev ([@ezhulenev](https://github.com/ezhulenev))
* Michal Matloka ([@mmatloka](https://github.com/mmatloka))
* Thiago Pereira ([@thiagoandrade6](https://github.com/thiagoandrade6))
* Juan José Vázquez ([@juanjovazquez](https://github.com/juanjovazquez))
* Viktor Taranenko ([@viktortnk](https://github.com/viktortnk))
* Stephen Samuel ([@sksamuel](https://github.com/sksamuel))
* Evan Chan ([@evanfchan](https://github.com/velvia))
* Jens Halm ([@jenshalm](https://github.com/jenshalm))
* Donovan Levinson ([@levinson](https://github.com/levinson))

Copyright
===============================
back to top

Special thanks to Viktor Taranenko from WhiskLabs, who gave us the original idea, and special thanks to Miles Sabin and team behind
Shapeless, where we shamelessly stole all the good patterns from.

Copyright © 2013 - 2017 outworkers.

Contributing to phantom
=======================
back to top

Contributions are most welcome! Use GitHub for issues and pull requests and we will happily help out in any way we can!