Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/cr-org/neutron

:stars: Purely functional Apache Pulsar client for Scala built on top of Fs2
https://github.com/cr-org/neutron

apache cats-effect dhall fp fs2 nix pulsar scala typelevel

Last synced: 26 days ago
JSON representation

:stars: Purely functional Apache Pulsar client for Scala built on top of Fs2

Awesome Lists containing this project

README

        

# neutron

[![CI Status](https://github.com/cr-org/neutron/workflows/Scala/badge.svg)](https://github.com/cr-org/neutron/actions)
[![MergifyStatus](https://img.shields.io/endpoint.svg?url=https://gh.mergify.io/badges/cr-org/neutron&style=flat)](https://mergify.io)
[![Maven Central](https://img.shields.io/maven-central/v/com.chatroulette/neutron-core_2.13.svg)](https://search.maven.org/search?q=com.chatroulette.neutron)
[![Scala Steward badge](https://img.shields.io/badge/Scala_Steward-helping-brightgreen.svg?style=flat&logo=)](https://scala-steward.org)
Cats friendly

A *pulsar* is a celestial object, thought to be a rapidly rotating neutron star, that emits regular pulses of radio waves and other electromagnetic radiation at rates of up to one thousand pulses per second.

[![pulsar](https://www.jpl.nasa.gov/spaceimages/images/largesize/PIA18845_hires.jpg "An accreting pulsar. Credit NASA/JPL-Caltech")](https://www.jpl.nasa.gov/spaceimages/?search=pulsar&category=#submit)

### Disclaimer

**Chatroulette** uses this library in production as the base of the whole platform. However, this library is in active development so if you want to use it, **do it at your own risk**.

### Documentation

Check out the [microsite](https://cr-org.github.io/neutron/).

### Pulsar version

At the moment, we target Apache Pulsar 2.10.x.

### Development

If you have `sbt` installed, you don't have to worry about anything. Simply run `sbt +test` command in the project root to run the tests.

If you are a `nix` user, make sure you enter a `Nix Shell` by running `nix-shell` at the project's root.

```
sbt +test
```

Remember to first start Pulsar and initialize it with docker-compose

```
./docker-compose up -d
```

### Schemas

Working with schemas when using our Pulsar `docker-compose` configuration.

Get [schema compatibility strategy](https://pulsar.apache.org/docs/en/schema-evolution-compatibility/#schema-compatibility-check-strategy):

```
$ docker-compose exec pulsar bin/pulsar-admin namespaces get-schema-compatibility-strategy public/default
FULL
```

Set schema compatibility strategy:

```
$ docker-compose exec pulsar bin/pulsar-admin namespaces set-schema-compatibility-strategy -c BACKWARD public/default
```