Skip to content

Commit

Permalink
Merge pull request #4166 from systeminit/adamhjk/testing-arcade-embed
Browse files Browse the repository at this point in the history
docs: adding orientation and vocabulary
  • Loading branch information
adamhjk authored Jul 17, 2024
2 parents c3ae11a + 6bf44a3 commit f3a6dcf
Show file tree
Hide file tree
Showing 3 changed files with 168 additions and 20 deletions.
51 changes: 51 additions & 0 deletions app/docs/src/reference/vocabulary.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
# Vocabulary

This a reference to all of the vocabluary used in System Initiative.

## Asset

Anything that can be used on the canvas.

## Credential

A credential is a type of component that stores secret data, and has authentication functions attached to it. They are used to provide access to cloud providers, etc.

## Change Set

Change Sets represent a batch of changes to the components, assets, functions and actions in a workspace. When you want to propose a change in the real world, you first create a change set to do it. Nothing you do in a change set should alter the real world.

If you are familiar with version control systems like git, you can think of a change set as an auto-rebasing branch.

When a change set is merged to head, any other open change sets in the workspace are automatically _rebased_ against HEAD - meaning the data within them will be updated to reflect the proposed changes to the model on HEAD.

#### Creating a Change Set

Creating a change set makes a new copy of the hypergraph based on the current data in HEAD. Learn how to create a change set in the [getting started tutorial](/tutorial/getting-started).

#### Applying a Change Set

When you _apply_ a change set, all of the properties and code are merged to HEAD, and any actions enqueued. Learn how to apply a change set in the [getting started tutorial](/tutorial/getting-started).

#### Abandoning a Change Set

Abandoning a change set essentially deletes it, and all of its proposed changes, from the system.

## Hypergraph of functions

The hypergraph of functions, or hypergraph, is the datastructure that powers System Initiative. It is a graph that represents all of the code, components, resources, and functions that are in a workspace. We call it a 'hypergraph' because it is multi-dimensional through the use of change sets.

## A Model

When we refer to 'a model', we mean a single Component/Resource pair.

## The Model

When we refer to 'the model', we're talking about all of the assets, functions, components, resources, etc. that make up your hypergraph.

## Resource

A resource is the data about the real-world thing represented by a component.

## Secret

Secrets are encrypted data stored for a given type of credential. They are defined by a credential component.
3 changes: 3 additions & 0 deletions app/docs/src/tutorials/creating-new-assets.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
# Creating a new asset

<div style="position: relative; padding-bottom: calc(52.18540712019739% + 41px); height: 0; width: 100%;"><iframe src="https://demo.arcade.software/etd5PHI79RHSeveMR6R3?embed&show_copy_link=true" title="" frameborder="0" loading="lazy" webkitallowfullscreen mozallowfullscreen allowfullscreen allow="clipboard-write" style="position: absolute; top: 0; left: 0; width: 100%; height: 100%;color-scheme: light;"></iframe></div>


This tutorial will teach you how to create a new asset. The asset models an \[AWS ARN\](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference-arns.html). You will need to know basic programming concepts to follow along.

## Create a new change set
Expand Down
134 changes: 114 additions & 20 deletions app/docs/src/tutorials/orientation.md
Original file line number Diff line number Diff line change
@@ -1,41 +1,135 @@
# Getting Started

Welcome to System Initiative (SI). It's a powerful new way to manage your infrastructure and applications. This tutorial will get you up to speed on all the basics.
Welcome to System Initiative! This tutorial will teach you how to use System Initiative to model your infrastructure. We will be deploying a single free-tier EC2 instance in AWS, and cleaning it up. There should be no cost to you.

To follow along, you'll need two things:
To follow along, you'll need three things:

1. Sign up for System Initiative.
1. [Sign up for System Initiative](https://auth.systeminit.com/signup).

2. An AWS account that allows you to create free-tier resources, such as EC2 instances.
2. An [AWS account that allows you to create free-tier resources](https://aws.amazon.com/free/), such as EC2 instances.

## Workspaces
3. Your System Initiative workspace open in another window or tab.

When you first sign in to SI, you'll be in a new, blank workspace. Workspaces are where everything happens in SI. They are where you model and customize your infrastructure. You can have as many workspaces as you want. You can switch workspaces at any time using the workspace dropdown.
## Creating a change set

## Change Sets
Click the create [change set](../reference/vocabulary#change-set) button.

Everything in System Initiative happens inside a Change Set. If you've used version control systems like Git before, think of a Change Set like a branch. You should currently be on the \`HEAD\` Change Set. HEAD represents the current desired state of your infrastructure. To make any changes, you must be in a new Change Set.
Name your new change set `Getting started`, and click the `Create change set` button.

To switch between change sets, use the change set dropdown. To create or abandon them, use the buttons to the right of the drop-down.
## Add an AWS Credential component

Create your first Change Set by clicking the new Change Set button, and name it "Tutorial".
Click `AWS Credential` from the AWS category of the asset pallete, and drop it on the diagram canvas. This creates a new [credential](../reference/vocabulary#credential) [component](../reference/vocabulary#component).

## Components and Resources
Resize the component until it fills most of the visible canvas by dragging the lower right corner of the frame.

In System Initiative, we model infrastructure through components and resources. A component is a theoretical representation of a resource that you want to manage. (Think of the component as a digital twin of the real-world resource it represents.)
## Name your component

## Configuration Diagram
Click on the `AWS Credential` you just added to the canvas. The panel on the right side of your screen will show the properties of It will have a default name like 'si-1234'.

The canvas in the center of your screen is a configuration diagram. You will place the components you need on it, and then connect them together to help configure them. Think of it like building an architecture diagram that also configures its components.
Change the name to be `tutorial`. Pressing enter or clicking outside the textbox will update the diagram with your new name.

## Creating your first component
## Add a secret

We want to create some resources in AWS, so the first component we need is our AWS Credential. In the lower left panel you will see a section titled 'Assets'. Each entry in this panel is a different component you can use. Click in the search box in the assets panel, type 'cred', and you will see AWS Credential. Click that, and then drop it on the diagram canvas to the right.
Click the 'select/add secret' button next to the AWS Credential property. Then click 'Add Secret'.

AWS Credentials appear on the diagram as a frame. Components that are frames configure the components within their boundaries. Frames are resizable. Make your new AWS Credential frame large enough to fill most of the visible diagram.
Name your secret 'Tutorial Secret'.

## Configuring the AWS Credential
Fill in your AWS accounts `Access Key Id` and `Secret Access Key`. [Refer to the AWS documentation if you do not know how what they are](https://aws.amazon.com/blogs/security/how-to-find-update-access-keys-password-mfa-aws-management-console/).

Click on the AWS Credential component. You'll see that the right panel changes, displaying information about the component's attributes. Start by giving your component the name 'development'. Giving your components meaningful names makes them easier to find later. It also makes the context contained in the diagram easier to see at a glance.
Click `Store Secret` to securely encrypt and save your [secret](../reference/vocabulary#secret).

## Add an AWS Region component and set its properties

Click on the `Region` from the AWS category of the asset pallete, and drop it inside your `tutorial credential` frame.

Resize the region to fill the space inside the `tutorial credential` frame.

Name your region 'ohio'.

Set the region property to `us-east-2`.

## Add an AWS EC2 Key Pair and set its properties

Click on the `Key Pair` from the AWS EC2 category of the asset pallete, and drop it inside your `ohio region` frame.

Name your key pair 'si-tutorial'.

Set the KeyName property to 'si-tutorial'.

## Add an AWS EC2 Instance and set its properties

Click on the `EC2 Instance` from the AWS EC2 category of the asset pallete, and drop it inside your `ohio region` frame.

Click the `Key Name` output socket of your `si-tutorial Key Pair` and connect it to the `Key Name` input socket of your new EC2 Instance component by dragging the line between them.

Ensure your `EC2 Instance` component is selected.

Name your EC2 Instance 'si-tutorial'.

Set the InstanceType property to `t2.micro`.

## Add an AWS EC2 AMI component and set its properties

Click on the `AMI` from the AWS EC2 category of the asset pallete, and drop it inside your `ohio region` frame.

Name your AMI 'Fedora CoreOS'.

Set the ImageId property to 'ami-04000bc04ccee958e'.

Connect the `Image ID` output socket of your AMI component to the `Image Id` input socket of your EC2 Instance component.

## Apply the change set

Press the 'escape' key, or click on the background of the canvas, to ensure the workspace itself is selected.

You will see two actions enqueued in the right hand panel - one to create the Key Pair, and the other to create your EC2 Instance.

Press the 'Apply Change Set' button.

You'll be prompted with a dialog to confirm you want to take these two actions. Press the 'Apply Changes' button in the dialog to confirm.

## Create the Key Pair and EC2 Instance resources

Applying the change set redirects you to the `HEAD` change set, and enqueues your actions. The proposed changes panel on the right side of the screen shows your two pending actions. As the actions are run on AWS, their resulting [resources](../reference/vocabulary#resource) are added to each model. As this happens, the actions will disappear from the proposed changes list.

Once both actions have been run, the changes panel will be empty.

## Review the si-tutorial EC2 Instances resource data

Select the `si-tutorial EC2 Instance`. Then select the 'Resource' sub-panel on the right side panel. You will see all the information about the EC2 Instance we created in AWS.

Congratulations! You have created your first resources with System Initiative.

## Clean up

Create a new change set called 'Cleanup'.

Select the 'tutorial AWS Credential' component. Press the delete key.

You'll be presented with a dialog confirming you want to delete the components we created previously. Click 'Confirm'.

Press the escape key or click on the canvas background to select the workspace.

Click the Apply Change Set button to delete your EC2 Instance and Key Pair. Confirm you want to apply the change set.

After the two delete actions are run, you will have a blank workspace, and no more resources running in AWS.

## Congratulations!

Congratulations - you've created your first resources with System Initiative. You learned how to:

- Create new change sets
- Add a credential component to the diagram canvas
- Add components to the diagram canvas
- Configure components by setting their properties
- Connect components input and output sockets to dynamically configure them
- Execute actions and create resources by applying a change set

## Next Steps

You can:

- Follow the [create assets] tutorial to learn about how to program and extend System Initiative
- Use your knowledge of AWS and System Initiative to learn how to create [AWS VPCs]
- Join us on [discord] to ask any questions you may have

AWS Credentials are sensitive and secret information. System Initiative encrypts and stores this secret data for you. Click the 'select/add secret' box in the attributes panel, then click 'add secret'.

0 comments on commit f3a6dcf

Please sign in to comment.