This project is depricated. Use new Vue 3 based project
- What is Plastic-IO
- Installation
- provider-settings
- How does this work?
- Extending The Graph Editor
- Client Server Sequence Diagram
- Implementing the Graph Scheduler Directly
- Operational Transformation
- Contributing
- Installing Development Graph Editor
Visual programming using a graph interface. If you can hook up a cable box, you can write programs in Plastic-IO. Click and drag vectors into your graph, then connect them together and run it.
Plastic-IO is a general purpose graph programming language. It can be used to create any sort of program in any domain. Here's a few ideas:
- Build your entire microservice architecture as reusable graphs and vectors.
- Build an entire front facing web site, code and views on the same graph.
- Create a highly mailable services facade to control the shape and flow of your existing APIs.
- Create your massively parallel CLI build pipeline.
Declarative graph programming is great for parallel and asynchronous tasks and generally runs faster and can be built in less time than imperative programming.
- Build your components in the same interface where you build your graph.
- Pure serverless environment. Plastic-IO only uses lambdas and CDN based client applications.
- Operational Transformation ensures you can rewind or fast-forward changes made to your graph.
- Multiuser debug environment for server side and client side programming.
- See the actual animated server data flow in your program live via web sockets.
- Typescript Graph Scheduling Engine built on promises from the ground up.
- Distributed graph schema allows for in-line or runtime side loaded resources to optimize performance.
- Immutable artifact system allows for instant safe reuse of components in other graphs.
- Public and private registries for cataloging and sharing graph components.
- Graph Design and Presentation views allow for live editing of highly complex asynchronous web sites.
Plastic-IO graphs are domain agnostic. If it can run JavaScript, it can run a Plastic-IO graph. Just like JavaScript, Plastic-IO vectors and graphs can run in mixed domains, although some are dedicated to a specific domain, for example, a vector that reads files from the file system will likely not work in the browser domain, but will work in the server or CLI domains. Vectors and graphs are tagged with which domains they work in, so you can make sure you're using the right kind.
You can install Plastic-IO in three ways.
- Use the public version in a local sandbox.
- Use the public version connected to a private graph server.
- Deploy your own Graph Editor IDE and connect to a private graph server.
The instruction below cover each use case.
- Open your graph editor and start making graphs.
No installation required. Graphs and vectors you make are saved to your browser, but you can still export them to files to be shared with others.
- Install the AWS based Plastic-IO Graph Server
- Create a free account with Auth0, setup a SPA and an API for your Graph-Editor and Graph-Server.
- Configure your provider settings here at
/graph-editor/provider-settings
. - Open your graph editor and start making graphs.
This is the recommended way to install the program for use in an enterprise environment. This will ensure that changes to the public graph editor have no impact on your system.
- Install the AWS based Plastic-IO Graph Server
- Create a free account with Auth0, setup a SPA and an API for your Graph-Editor and Graph-Server.
- Clone the graph-editor repository.
- Change to the repository directory
- Optional: add a .env file using the instructions below.
- Run
npm install && npm run build
- Copy the content of the
/dist
directory to your CDN. - Set your CDN to use the
/dist/index.html
file as the 404 page, and configure the CDN to return 200 status code. - Open
/graph-editor/provider-settings
and configure your browser.
When using the public CDN graph editor, you can change which server you're connected to by visiting the provider settings page on the public graph editor. The settings are saved to the browser.
Alternatively, you can deploy your own instance of the graph editor to your own CDN. This makes it so the graph editor is hosted in your network where you have more control over it. When hosted this way, you can automatically fill out the values of provider settings page by setting an .env
file in the root of your project with the following values:
Property | Description |
---|---|
VUE_APP_GRAPH_HTTP_SERVER | The HTTPS endpoint of your graph server instance, provider after graph server deploy. |
VUE_APP_GRAPH_WSS_SERVER | The WSS endpoint of your graph server instance, provider after graph server deploy. |
VUE_APP_AUTH_PROVIDER_NAME | The authentication provider name. Currently only auth0 is supported. |
VUE_APP_AUTH_DOMAIN | The authentication domain name. Provided by your authentication provider. |
VUE_APP_AUTH_CLIENT_ID | The authentication client ID. Provided by your authentication provider. |
VUE_APP_AUTH_AUDIENCE | The authentication audience. Provided by your authentication provider. |
VUE_APP_FORCE_SERVER | When true, the provider-settings page is disabled and forced to use the above settings. |
Example .env
file:
VUE_APP_GRAPH_HTTP_SERVER=https://7hcv242f49.execute-api.us-east-1.amazonaws.com/dev/ VUE_APP_GRAPH_WSS_SERVER=wss://w84525agw3.execute-api.us-east-1.amazonaws.com/dev VUE_APP_AUTH_PROVIDER_NAME=auth0 VUE_APP_AUTH_DOMAIN=dev-32-g55ap.us.auth0.com VUE_APP_AUTH_CLIENT_ID=V352372k7efF4asfsJyizdfasasUKl VUE_APP_AUTH_AUDIENCE=plastic-io-graph-server VUE_APP_FORCE_SERVER=false
In this integrated development environment (IDE), you can create and share graph programs. Graph programs consist of 4 major parts:
- Graph
- Vectors
- View
- Bus
Graphs in Plastic-IO are classed as "hypergraphs". This means your graph can be imported into another graph where it will show up as a vector. Graphs are made up of a collection of vectors. Graphs have an explicit URL. You can publish and share graphs. Graphs can be executed on the client, or server, or both. Graphs are domain agnostic. It can execute anywhere JavaScript can execute.
Vectors are points on the graph. Vectors have an explicit URL. Vectors in Plastic-IO are classed as "hypervectors". This means your vector can have multiple sets of "edges" that connect your vector to other points on the graph. Additionally, each edge can be shared with multiple other vector's edges at the same time. These "hyper edges" are called "connectors". The relationship between the vectors, edges and connectors controls the flow of your graph program.
Each vector has a view. The graph itself has a view as well. When you use the graph editor, you can see the view of each vector or graph. You can edit the view of the vector directly in the IDE. Although the Plastic-IO execution engine is rendering engine agnostic, this view on the graph editor uses Vue and Vuetify to render views. It is currently not possible to use rendering engines other than Vue.
Each vector on the graph is registered as a Vue component with the following name vector-<vector-id>
where <vector-id>
is the
unique ID of the vector. The graph itself is also registered as a Vue component with the following name vector-<graph-id>
where <graph-id>
is the unique id of the graph. The graph view is only visible when in presentation mode. By setting the graph to start in presentation mode you can create functional web sites that can be presented to end users.
When a graph is imported into another graph, the graph view template gains the property vector
that represents the host vector.
Each vector has a "set" function. This set function dictates how data flows through the graph. You can edit the set function of the vector directly in the IDE. The flow of data through the graph is called "the bus". Data always flows in one direction, left to right. This meams data always "comes out" of the right hand side of a vector and "goes into" the left side a vector.
Plastic-IO graphs are a high level graph programming language built on top of JavaScript and executed with the Plastic-IO Scheduling Engine. Plastic-IO graphs are stored as JSON files. The GUI for Plastic-IO is the Plastic-IO Graph Editor IDE.
Graph can be executed directly in the design view of the editor, however you can also set your graph to "Presentation Mode". In presentation mode, connectors not marked "Visible in Presentation" will be hidden. The template that is displayed is defined on the graph properties. From this template you can display other vectors on your graph or enter your own template code.
When a vector's set function is being invoked, the this
object contains a few helpful properties:
Property | Description |
---|---|
props | Vue Component props of this vector. |
component | Vue Component instance. |
When you installed your server, you took note of the endpoint beginning with ANY - https://
. This is where your graphs can be executed from. Where you see <root>
below is where you would put your HTTP server.
ANY - https://4bc4u834549.execute-api.us-east-1.amazonaws.com/dev/{proxy+}
Your graph URL goes where you see {proxy+}
Note: In production /dev/
is not present at the end of the ANY
URL.
You can execute graphs on the server by subscribing events to the lambda "DefaultRoute" in this project. By default, all unbound HTTP traffic to the domain will come to the graph route. What graph gets executed is based on the URL.
<root>/<graph.url>.<graph.vector[].url>
Example:
The following URL would run vector "html" on graph "home"
https://mysite.com/home.html
Graphs are stored by their URL. Once the graph is looked up, the scheduler is invoked with the matching vector's URL.
If no vector URL is specified, the vector URL "index" is assumed. Similarity, if no graph URL is specified, the graph "index" is assumed. That makes the default route to the server "/" the graph "index" and the vector "index".
When a vector's set function is being invoked, the this
object contains a few helpful properties:
Property | Description |
---|---|
event | The AWS request event. |
context | The AWS request context. |
callback | The AWS request HTTP callback. |
AWS | The AWS library. |
console | Web socket console transmitter. Sends log data to the client side Graph Editor IDE. |
// example callback
this.callback(null, {
statusCode: 200,
body: "Hello World!"
});
This is quite literally the AWS callback method passed to the lambda. If you do not call it within 30 seconds, it will automatically be called and a timeout will be logged. Your lambda can run for longer than 30 seconds, but API gateway requires all HTTP responses end within 30 seconds.
When you publish a graph, that graph becomes available in the production environment. Changes to the graph will not take effect until you publish the graph once again. You can still test your graph in the development environment after each change.
When you publish your vector or graph, it becomes available to other users of your Graph Database. These published versions are immutable and free of dependency issues. Once a graph or vector is published, users of that artifact can be sure it will never change. Past versions are listed right next to current versions and clearly labeled.
You can also share your graphs and vectors by downloading them via links provided in the IDE and then clicking and dragging the files onto other graphs. Unlike using published graphs and vectors, importing this way causes the imported artifact to originate on the graph you are currently editing, where published vectors and graphs are linked and can potentially have their data side loaded.
Because you can share the parts of the graph, and entire hypergraphs, Plastic-IO server allows you to build your entire infrastructure using first "low level" JavaScript and then higher level graphical programming, all within the multiuser Plastic-IO IDE.
Because each vector and graph in Plastic-IO are implicitly modular, this makes it so you can reuse the artifacts you create in other graphs very easily. Plastic-IO graph server provides a marketplace of graphs and vectors for developers to choose from, safely and securely.
You can add your own components to the graph editor using the vue plugin framework. This is the way the graph editor imports its own components.
Here are the steps to create a plugin. Below that is a plugin template.
- Make a fork of this project (https://github.com/plastic-io/graph-editor).
- Make a new file to hold your plugin, usually in
/src/plugins
. - Copy the template below into your new file and name the file your plugin's name.
- Edit
/src/main.ts
. Import your plugin file. E.g.:import MyPlugin from "./plugins/MyPlugin";
. - Add your plugin inside of the
--- ADD PLUGINS BETWEEN THESE LINES ---
lines. E.g.:Vue.use(MyPlugin(store));
.
- vectorProperties
- graphProperties
When using the addPlugin
action to define a vectorProperties
plugin or graphProperties
plugin, you must select an icon that is registered in the vuetify icon library. You can select an icon from the mdi-icons list or you can register custom icons, instructions. When a user clicks the tab with your plugin, your component will load in the tab content area. Trying to register a component to a non existent plugin type will cause an error.
The template below is setup to allow you to pass parameters from main.ts
into your plugin. In this example, the vuex store instance is passed into the plugin as the argument context
. In the plugin template, a store module is created with some examples. Using this pattern you can add your plugin UI and functionality in a single interface.
export default function (context: any) {
return {
install: () => {
const store = {
namespaced: true,
state: {
status: "PENDING",
},
mutations: {
SET_STATUS(state, e) {
state.status = e;
},
},
actions: {
changeStatus(context, e) {
context.commit("SET_STATUS", e);
}
},
};
// add graph editor plugins
context.commit("addPlugin", {
type: "vectorProperties",
icon: "mdi-flask",
component: TestView,
});
// add custom store
context.registerModule('myplugin', store);
}
};
};
+-----------+ +------------------+ +-----------------------------+ +----------------+
| | | | | | | |
| Browser | | Local Graph | | Local Remote Graph Copy | | Remote Graph |
| | | | | | | |
+-----+-----+ +--------+---------+ +-------------+---------------+ +--------+-------+
| | | |
| +++ | +++
+----Change---> | | +----Diff Calc----------------Change sent to Server--> | |
| | | | | |
| | | +++ | |
| | | | | | |
| | | <----Diff Calc------+ | | <---Change Sent to Client--+ | |
| +++ +++ +++
| | | |
| | | |
If you use the Graph-Editor and Graph-Server together all of this is abstracted from you and you can concentrate on graph programming. However if you want to use the scheduling engine directly, it is very easy to do.
Plastic-IO uses a number of code build and analysis tools to build and execute code held in graphs or side loaded in via registries and CDNs. Compiled code executes through the graph scheduling engine.
To get started, a graph is built then passed to the scheduler.
const scheduler = new Scheduler(graph, {}, {}, console);
Next, let the scheduler know which vector to invoke first by using the vector's URL.
scheduler.url('my-vectors-url');
And that's it! The code within the graph's vectors takes care of the rest.
You can hook into a variety of events listed in the scheduling engine documentation if you want to log or react to different events and changes that occur during the runtime of the graph.
Scheduling engine documentation: Scheduler
Plastic-IO uses Operational Transformation (OT), Event Sourcing (ES), Command Query Resource Separation (CQRS), Blockchain, and Domain Driven Design (DDD) for event bus, and storage patterns. By using these patterns Plastic-IO works very much like git. Each change creates an event that is saved into a collection of change events that is then projected into a state.
DDD and ES are used to create different views using the OT events in conjunction with real time runtime ES data pushed to graph data subscribers, for example using your graph as an interactive web site.
The event bus itself is CQRS, which means all OT messages are fire and forget. No response is sent back from the websocket based server. Rather, interested clients subscribe to the graph's notification topic and events are pushed out to the client.
In order to maintain consistency in OT edits, a Blockchain pattern is used. Each OT change event sent to the central server contains a cryptographic link to the previous state and the projected changed state. This cryptographic signature ensures that, in theory, the OT event ledger can never be corrupted due to invalid state change messages.
We offer a very free and open environment where you can express yourself in a multitude of ways, and showcase your creations to the world! There are four major paths of contribution.
Always looking for contributors to our public catalog. At Plastic-IO we maintain a catalog of user generated graphs and vectors that are available by default to all installation of the graph-editor.
You can contribute to the core public artifact registry by making pull requests to the Graph Registry repository. From there you can create categories and sub-categories of your work and make it available to the public.
Your creations can be in any domain (browser, aws server, CLI), and you can use your own creations to make new creations. Even mix and match creations from other people in your new creations and repeat.
Here's a few ideas:
- Navigation bar component with drop down menus
- Reusable table with XHR paging support
- Closed loop CRUD system for you favorite AWS data storage solution
- Web page skeleton that people can modify to make their own
- Build pipeline configuration builder
- Admin web site with basic CRUD functionality
- MIDI component synthesizer using a lib like Tone.js
- Visualization pipeline using a lib like LiquidFun
Make them and publish them so others can use them directly or use them as building blocks in another creation.
The Graph Editor IDE itself is always in need of love. Built with Typescript, Vue, Vuex, and Vuetify, the graph-editor both produces the graphs that are executed by the scheduling engine, but also renders the views built into the graphs and vectors. It is also responsible for displaying events that occur in the graph execution runtime environment, both on the server and the browser using web sockets.
Contributing to the graph editor is not for beginners, but there are some tickets that are easier to accomplish than others. If you think you're up to the task check out the issues page and look for the "good first time issue" tag.
The Graph Server is an AWS HTTP Lambda {proxy+} implementation of the graph server. Using Operational Transformation (OT) and a publishing pipeline, the graph server lambda represents an entire micro service architecture framework. Graphs are accessed via their registered URLs and served to the users as HTTPS APIs. Graphs running on the graph server have full access to the AWS infrastructure and can do anything AWS allows.
Work on the graph server is not for beginners. Here we are creating new O(1) routing paradigms that fit with graph programming. Additionally the graph server is used to communicate debugging and business intelligence events to AWS cloud watch and the Graph Editor IDE. These are highly complex system and require a skilled and careful hand to maintain. If you think you're up for it check out the issues list on the graph server.
There is a limited set of media assets here. Contributions to the asset set is always welcome. There are no current issues opened, but feel free to create an issue and make a PR.
Uses local storage
npm install
npm run serve
npm run build
npm run lint
npm run test:unit
npm run test:e2e