Skip to content

Latest commit

 

History

History
108 lines (73 loc) · 4 KB

README.md

File metadata and controls

108 lines (73 loc) · 4 KB

AlexShop

Using the latest technology in the Scala ecosystem, AlexShop is a pure Scala reactive web application built on Play 2.5, ScalaJS, Silhouette 4, Akka, Sangria, and postgres-async. It provides a good starting point for whatever you want to build.

Features

  • Local sign-in, profile, and change password support.
  • Role based security, with normal and admin roles.
  • Full admin suite for user management, reporting, and real-time session observation.
  • GraphQL schema and query interface, with shared queries and mutations.
  • Scala source that is shared between the client and server via Scala.js.
  • Websocket-driven actor support, with monitoring and tracing.

Technology

The Play application communicates over a WebSocket to a pool of Akka actors managing connections. Serialization is handled by Play Json, and all database communication runs via postgres-async. Scala.js compiles the shared code and provides an in-browser component.

The index page opens a websocket connection for bidirectional communication, handled via Play and Akka.

A GraphQL schema is provided, accessible in the administration section.

Running the app

First, either create a Postgres role and database named "alexshop", or change the application.conf to use your existing database.

CREATE ROLE alexshop WITH LOGIN PASSWORD 'alexshop';
CREATE DATABASE alexshop;
GRANT ALL PRIVILEGES ON DATABASE alexshop TO alexshop;

Alternatively, start Postgres in a Docker container using the script provided:

$ ./start_postgres.sh

You'll either need Node.js available as "node" on the path, or change project/Server.scala's EngineType to Rhino.

Then you'll need to change the Silhouette sections in application.conf to use your authentication settings.

Now, finally,

$ sbt
> run
$ open http://127.0.0.1:9000

As the application starts, it will create database tables and seed data.

The first account to sign up is created as an Admin, all subsequent users will have a normal user role.

Projects

  • server Main web application.
  • sharedJvm Core Scala logic and rules definitions, for JVM projects.
  • sharedJs Shared classes, compiled to Scala.js JavaScript.
  • client Barebones Scala.js app.

Metrics

All meaningful operations are tracked through Scala Metrics, and are exposed through JMX, or via a servlet available on port 9001. Reporting to Graphite can be enabled through application.conf, and reports to 127.0.0.1:2003 by default. Metrics exposes all actors, queries, logs, requests, and jvm info.

Make it your own

To start your own project, you can change every instance of the word "alexshop" to your project's id, and change every instance of "AlexShop" to your project's name. Don't worry, there's only a few.

Contributing

All Scala code is formatted by Scalariform, and passes all checks from Scalastyle and Scapegoat. No Scala file is longer than 100 lines, no line longer than 140 characters, and all warnings are treated as errors. Tests are part of the main source tree so they can be run from the browser.

The project is built on SBT, and can be opened by IntelliJ directly.

Technology

AlexShop relies on a whole lot of tremendous open source projects. Here's a few of them.

License

The code is licensed under Apache License v2.0.