Skip to content

accolasia/ideaflow

 
 

Repository files navigation

Build Status

IdeaFlow Metrics Server

The "/ideaflow" service acts as a centralized endpoint for IdeaFlow data collection (@see https://plugins.jetbrains.com/idea/plugin/9239) and low-level metrics profiling on individual Idea Flow Maps (@see github.com/openmastery/ideaflow-profiler).

The service is implemented with SpringBoot, and Gradle, and designed to be run as a SaaS platform or run on-prem. The project is OSS under a GPL 3.0 license. The client-tools.jar that connects to the ideaflow server is under Apache 2.0 license.

What does the service do?

The following endpoints are available (swagger docs coming soon):

Stub data is loaded on startup in the [email protected] account that you can use to explore the API. The API-Key for the demo account is printed on the screen at startup. You'll need to pass the API-Key as a header to all API calls. To setup new user accounts, see instructions below.

To Run

Install/setup docker (instructions below), then:

git clone [email protected]:openmastery/ideaflow.git
./gradlew bootRun

User Access

All APIs require access using an API-KEY header. When you access the API via the plugin, you need to configure preferences to use the API Key.

To generate an API-Key for a user:

curl -X POST -H "X-API-KEY: <api-key>" <server-url>/[email protected]

Where is the default user API-KEY between the *******'s on ideaflow component startup

To Build

This project requires

  • Java 1.8
  • IntelliJ Lombok plugin installed
  • IntelliJ annotation processing enabled
git clone [email protected]:openmastery/ideaflow.git

cd ideaflow

./gradlew clean check

./gradlew idea

Import project or module into IDEA and get to coding.

Install/Setup Docker

If you've got Docker for Mac, or Docker for Windows installed, you can skip this section completely. If you get any errors when running Gradle build commands for postgres, run docker ps to make sure docker is on your path.

To install, follow instructions here:

https://docs.docker.com/machine/install-machine/

Then to start the machine:

docker-machine start default

To enable Docker in your current shell, run:

eval "$(docker-machine env default)"

Finally, to configure the machine, you'll need to add an entry to your /etc/hosts configuration. First, run:

docker-machine env default

And copy the IP address from the configuration line that looks like this:

export DOCKER_HOST="tcp://<ip-address>:2376"

Edit your /etc/hosts file and add:

<ip-address>	local.docker

Postgres

Postres is required to run the component tests.

As a one-time operation, pull and create the postgres container

./gradlew pullPostgres createPostgres

To start the container before running tests

./gradlew startPostgres

To re-create the postgres container

./gradlew refreshPostgres

Troubleshooting Setup

If you get an error on starting up the app that looks like:

"org.postgresql.util.PSQLException: Connection refused."

That means the application is unable to connect to Docker.
Run through the docker setup/install steps.

After a Restart, SpringBoot Hangs

After a restart SpringBoot will hang while it tries to connect to a non-existent VM.

Run:

docker-machine start default
eval "$(docker-machine env default)"
docker start postgres

Then bounce the server.

Swagger

Swagger docs are generated automatically as part of the build. Once a server is running, navigate to /s/index.html (e.g. localhost, http://localhost:8080/s/index.html) to bring up the swagger docs. To upgrade Swagger UI, checkout https://github.com/swagger-api/swagger-ui and copy the dist directory into src/main/resources/static. You'll also need to update index.html and set url = "/s/api-json/service.json" rather than the default petstore url.

Heroku

This application is currently deployed on Heroku at http://om-ideaflow.herokuapp.com. For an API-Key on the shared service, please contact [email protected]. We will have account creation setup soon, but while this project is still in early development, accounts are created manually.

Install heroku cli (google)

Log into heroku

heroku login

Initial Heroku Application Creation

Create the heroku application

heroku create om-ideaflow

Create the database (can upgrade to hobby-basic just by associating credit card w/ account)

heroku addons:create heroku-postgresql:hobby-dev

Configure the domain

heroku domains:add ideaflowdx.openmastery.org

Set up SSL

heroku certs:auto:enable

Ongoing Heroku Application Deployment

If you have not previously deployed to Heroku, initialize the remote

heroku git:remote -a om-ideaflow

Deploy the application on heroku

git push heroku master

How to Troubleshooting Heroku DB specific Issue

heroku pg:backups:capture

heroku pg:backups:download

pg_restore --verbose --clean --no-acl --no-owner -h local.docker -U postgres -d ideaflow latest.dump

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 74.0%
  • Groovy 14.9%
  • Java 7.9%
  • CSS 3.1%
  • HTML 0.1%