Skip to content

Latest commit

 

History

History
87 lines (47 loc) · 4.03 KB

File metadata and controls

87 lines (47 loc) · 4.03 KB

Welcome to the GitHub repository for the Event Store's Application Development Fundamentals training course.

Overview

This content will be used as course content for instructor-led and self-paced offerings.

Labs

The "labs" directory contains a folder for each module and sub-folders for each lab.

Solutions

Solutions are included in each module folder, but please try to work through the labs independently before checking the solutions.

Running the Labs

The exercises are designed to be run in GitHub Codespaces.

To run the code locally, you must start an EventStoreDB instance. A Docker container is available for that. For more information on setting up your environment, please visit Event Store Academy's From Scratch series.

Please note that in live training events, the instructor can only assist in debugging code run in GitHub Codespaces, as that is a controlled environment. Your local environment might have different software package versions, making it difficult for us to debug live in class.

That said, the content should be straightforward to reproduce locally with minimal effort.

Programming Language

This code in this course is written using Node.js.

FAQs

Why not TypeScript?

TypeScript is great. We love it, and you should look into using it. However, TypeScript is enhanced Javascript, and your TypeScript code transpilers down to Javascript code. By going straight to Javascript, the course can focus on reading and writing events to EventStoreDB without getting distracted by the TypeScript => Javascript discussion. If you learn to interact with EventStoreDB in Javascript, you can quickly transfer those skills to TypeScript.

Why not Java?

Jave is great. We love Java. Since the client libraries for each language are very similar, we assume that a Java developer will be able to take what they learn from this class and apply it to Java.

Why not Python?

Python is great. We love Python. We assume that a Python developer will be able to take what they learn here and apply it to an application built in Python.

Why not .NET?

.NET is great. EventStoreDB is written in .NET. However, we felt an interpreted language was best for a general audience.

Codespaces

The content is built using a configuration file for GitHub Codespaces, which provides a Docker environment and a browser implementation of VScode.

That is the .devcontainer file you see as part of the repo. Please do not edit that.

How to use codespaces

The instructor will demonstrate the usage of Codespaces during a live training class. For those completing the course as a self-paced endeavor, please follow the instructions in module 00_Validate_Setup/instructions.md.

Running EventstoreDB in the Docker container

This repo provides a shell script to start and restart the EventStoreDB Docker container local to the CodeSpaces container. The course is written so that each user has their own instance of EventStoreDB.

NOTE Running ./start.sh will clear your current EventStoreDB instance and return an empty instance. This is purposefully designed to isolate each exercise and avoid dependencies or conflicts.

Running the Content Locally

EventStoreDB's From Scratch series provides complete instructions on setting up a local Node environment.

To clone this repo and run the code locally, run the following in a terminal.

git clone <repo name>

Once downloaded, you will run yarn install to download the dependencies locally.

Running the EventStoreDB Docker container locally

The content in this repository will work with a locally available EventStoreDB container running in unsecured mode.

Instructions: https://hub.docker.com/r/eventstore/eventstore.

The process is as follows:

  1. Install Docker
  2. Run
     eventstore/eventstore:latest --insecure --run-projections=All \
     --enable-external-tcp --enable-atom-pub-over-http```