Skip to content
forked from modelix/modelix

The modelix project develops a next generation language workbench that is native to the web and the cloud.

License

Notifications You must be signed in to change notification settings

Strumenta/modelix

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Build Status

The modelix Project

The modelix project develops a next generation language workbench that is native to the web and the cloud, inspired by this document. On the path to this final vision, the short-term goal is to use MPS as the backend. To this end, we currently develop two components:

  • Database/Cloud storage for MPS models with realtime collaboration
  • Server-based execution of MPS and browser-based editors

How to run modelix

  • At this time there are no builds or releases available. You have to clone the repo to use modelix.
  • You can run modelix locally and in the Google cloud. The details are described on this wiki page.
  • Then check out some of the samples.
  • Or check out the tutorials.

Editing the sources

  • run gradlew in the main directory to download dependencies and build the project
  • While the MPS that is used for the build is downloaded automatically, you have to install MPS yourself to use it as the client. Currently we rely on MPS 2020.1 which you can get from https://www.jetbrains.com/mps/
  • open the project in the folder "mps" with MPS

Architecture

Architecture Overview

The image above shows the components that modelix currently consists of.

MPS is running in headless mode on the server with an HTTP server installed as a plugin. The browser connects to that server and receives the HTML and JavaScript code required for the interactive model editor.

A second plugin connects to a model server and replicates the data into MPS' internal module repository. All MPS instances connected to that model server will stay synchronized. This can also be a local MPS instance without a web editor. Both options are supported at the same time.

The next image gives an overview over the different docker images running in the kubernetes cluster.

Kubernetes

The model server uses an Apache Ignite cluster and just provides a REST API on top of it. A high load can be distributed over multiple instances.

Running multiple MPS instances for scalability is possible, because the model has the same state on all instances.

If you want to run MPS instances with different configurations (languages, plugins) or allow external instances to connect to the model server, a reverse proxy is used to forward the request to the correct instance.

To access the web editor a user has to login in with a google account first. An OAuth proxy takes care of that and adds an HTTP header with the users e-mail address to the request.

Editor

modelix provides an editor in the browser for the languages implemented in MPS. This can be an image based editor that renders the editor in MPS using the default editor definition or an HTML based editor that requires a separate editor definition in a language provided by modelix.

Common to both approaches is that the user input (keyboard, mouse) is processed on the server and the update of the projection after a model change also happens on the server. Even in case of the HTML based editor the resulting HTML is computed on the server side. This removes the need to replicate the model into the browser, which would result in a bad performance in case of big models.

Model

Running MPS in the cloud requires an alternative to the file system for storing models. modelix implements a data structure that allows replication between all MPS instances connected to the same model server. It is very similar to the git storage format, but instead of files it stores nodes in its key-value data store.

To support realtime collaboration, in addition to the snapshot of a version it also stores the operations that were applied on the previous version to produce the new version. Conflicts between concurrent modification are resolved using operational transformation (OT). The usually hard part of OT is to guarantee convergence, meaning that all clients end up with the same result indepent of the order in which they receive changes. This problem becomes trivial, because versions are identified by a hash over all the content. Any divergence will result in a different hash which can easily be detected.

The remaining problem is what to do when a divergence is detected. From git we know that switching between versions is fast, because it only has to apply the difference between these versions. The same is true here. Fixing a divergence is as easy as switching to the correct version. If a client doesn't have any local changes it doesn't even need to apply the change operations itself. It can just switch to the new version. So in the rare case of a divergence fixing it is nothing special. It's an operation that happens all the time.

Content of the root directory

File Description
db Files for building the PostgreSQL docker image
gradle-plugin files for building the PostgreSQL docker image
gradle-plugin-test Demo project that uses the gradle plugin.
kubernetes YAML configuration files for running modelix in a kubernetes cluster
model-server Java project that implements a REST API on top of an Apache Ignite key value store. It is very generic and lightweight and doesn't know anything about models and their storage format. The mapping between the model data structure and the key value entries happens in MPS.
mps MPS project that implements all the MPS plugins. That's a plugin for synchronizing models with the model server and plugins for editing models in the browser.
proxy Files for building a docker image for a reverse proxy used inside the kubernetes cluster.
samples Projects that show you how to build your own kubernetes cluster running MPS with custom languages.
ssl SSL support inside the kubernetes cluster
ui-client A typescript project that implements the browser part of the editor. This is generic and doesn't contain anything language specific. All language specific parts are implements on the server side in MPS.
ui-server A small Java project that configures and starts MPS in headless mode.
.dockerignore
.gitignore
.travis.yml Required for using travis as the CI server: https://travis-ci.org/github/modelix/modelix
Dockerfile-mps The docker image for the UI server is split into a separate layer for MPS, because the MPS version changes less frequently and this speeds up the rebuild of the docker image.
Dockerfile-ui For building the docker image of the UI server.
LICENSE
README.md
build-scripts.xml Generated by MPS for building the MPS project
build.gradle
docker-build-all.sh Builds all the docker images. You have to run ./gradlew first.
docker-build-db.sh
docker-build-model.sh
docker-build-mps.sh
docker-build-proxy.sh
docker-build-ui.sh
docker-push-gcloud.sh
docker-push-hub.sh Pushes all docker images to hub.docker.com and updates the version numbers in the kubernetes YAML files.
docker-run-db.sh If you want to run the PostgresSQL database locally without a kubernetes cluster
docker-run-model.sh If you want to run the model server docker image locally without a kubernetes cluster. You can also run ./gradlew run in the model-server directory.
docker-run-ui.sh If you want to run the UI server docker image locally without a kubernetes cluster. You can also just open the mps folder with MPS after running ./gradlew.
generate-modelsecret.sh Access to the model server requires clients to be logged in with their google account. Inside the kubernetes cluster the other components use a secret stored in the kubernetes cluster as the access token.
gradlew Run this to build all projects.
gradlew.bat Run this to build all projects.
kubernetes-apply-gcloud.sh
kubernetes-apply-local.sh
kubernetes-gcloud-dbsecret.sh
kubernetes-modelsecret.sh
run-ui-server.sh This is packaged into the docker image and doesn't work outside of it.
settings.gradle
update-gcloud.sh If you want to build and run your own images inside you cluster.
update-minikube.sh If you want to build and run your own images inside you cluster.

Roadmap

Here are some open topics that we may work on in the future. The order doesn't have any meaning.

  • CI integration
    • Gradle plugin for downloading models from the model server
  • Code review tool based on modelix
    • Git integration: Allow to specify a repository and a branch/version that is then loaded into an MPS instance running in kubernetes
  • Collaborative editing in MPS
    • Show list of active users working on the same model
    • Show cursors/selection of other users
  • Editor
    • Graphical notation: The current text based notation only uses very little code in the browser. All user input is processed on the server and they client receives an update of the changed HTML elements. A graphical notation based on existing JavaScript libraries would require a different API provided by the server.

About

The modelix project develops a next generation language workbench that is native to the web and the cloud.

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Languages

  • TypeScript 49.0%
  • Java 36.9%
  • Shell 5.4%
  • CSS 3.9%
  • JavaScript 3.8%
  • HTML 0.6%
  • Dockerfile 0.4%