From 6dd43ca7e0d199b1e06645f84a0bceeac6e8ee2c Mon Sep 17 00:00:00 2001 From: Pijus Kamandulis Date: Sun, 25 Feb 2024 23:27:21 +0200 Subject: [PATCH] Added README --- LICENSE | 21 +++++++++++++++++++ Makefile | 14 ++++++++++--- README.md | 60 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 92 insertions(+), 3 deletions(-) create mode 100644 LICENSE create mode 100644 README.md diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..3bef017 --- /dev/null +++ b/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) Pijus Kamandulis + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/Makefile b/Makefile index d03ec28..c3dd415 100644 --- a/Makefile +++ b/Makefile @@ -9,16 +9,24 @@ DIST_DIR=dist all: test build-all -build-all: build-darwin-arm64 build-linux-amd64 +build-all: build-darwin-arm64 build-darwin-amd64 build-linux-amd64 build-windows-amd64 build-darwin-arm64: - @echo "Building macOS binary..." + @echo "Building macOS ARM binary..." @GOOS=darwin GOARCH=arm64 $(GOBUILD) -o $(DIST_DIR)/$(BINARY_NAME)-darwin-arm64 . +build-darwin-amd64: + @echo "Building macOS x64 binary..." + @GOOS=darwin GOARCH=amd64 $(GOBUILD) -o $(DIST_DIR)/$(BINARY_NAME)-darwin-amd64 . + build-linux-amd64: - @echo "Building Linux binary..." + @echo "Building Linux x64 binary..." @GOOS=linux GOARCH=amd64 $(GOBUILD) -o $(DIST_DIR)/$(BINARY_NAME)-linux-amd64 . +build-windows-amd64: + @echo "Building Windows x64 binary..." + @GOOS=windows GOARCH=amd64 $(GOBUILD) -o $(DIST_DIR)/$(BINARY_NAME)-windows-amd64.exe . + generate-parser-nosql: pigeon -o ./parsers/nosql/nosql.go ./parsers/nosql/nosql.peg diff --git a/README.md b/README.md new file mode 100644 index 0000000..808c797 --- /dev/null +++ b/README.md @@ -0,0 +1,60 @@ +# Cosmium + +Cosmium is a lightweight Cosmos DB emulator designed to facilitate local development and testing. While it aims to provide developers with a solution for running a local database during development, it's important to note that it's not 100% compatible with Cosmos DB. However, it serves as a convenient tool for E2E or integration tests during the CI/CD pipeline. + +One of Cosmium's notable features is its ability to save and load state to a single JSON file. This feature makes it easy to load different test cases or share state with other developers, enhancing collaboration and efficiency in development workflows. + +# Getting Started +### Downloading Cosmium + +You can download the latest version of Cosmium from the [GitHub Releases page](https://github.com/pikami/cosmium/releases). Choose the appropriate release for your operating system and architecture. + +### Supported Platforms + +Cosmium is available for the following platforms: + +* **Linux**: cosmium-linux-amd64 +* **macOS**: cosmium-darwin-amd64 +* **macOS on Apple Silicon**: cosmium-darwin-arm64 +* **Windows**: cosmium-windows-amd64.exe + +### Running Cosmium + +Once downloaded, you can launch Cosmium using the following command: + +```sh +./cosmium-linux-amd64 \ + -Cert "cert.crt" \ + -CertKey "cert.key" \ + -Persist "./save.json" \ + -InitialData "./save.json" +``` + +Connection String Example: +``` +AccountEndpoint=https://localhost:8081/;AccountKey=C2y6yDjf5/R+ob0N8A7Cgv30VRDJIWEHLM+4QDU5DE2nQ9nDuVTqobD4b8mGGyPMbIZnqyMsEcaGQy67XIw/Jw==; +``` + +### Running Cosmos DB Explorer + +If you want to run Cosmos DB Explorer alongside Cosmium, you'll need to build it yourself and point the `-ExplorerDir` argument to the dist directory. Please refer to the [Cosmos DB Explorer repository](https://github.com/Azure/cosmos-explorer) for instructions on building the application. + +Once running, the explorer can be reached by navigating following URL: `https://127.0.0.1:8081/_explorer/` (might be different depending on your configuration). + +### SSL Certificate + +By default, Cosmium runs on HTTP. However, if you provide an SSL certificate, it will use HTTPS. Most applications will require HTTPS, so you can specify paths to the SSL certificate and key (PEM format) using the `-Cert` and `-CertKey` arguments, respectively. + +### Other Available Arguments + +* **-AccountKey**: Account key for authentication (default "C2y6yDjf5/R+ob0N8A7Cgv30VRDJIWEHLM+4QDU5DE2nQ9nDuVTqobD4b8mGGyPMbIZnqyMsEcaGQy67XIw/Jw==") +* **-DisableAuth**: Disable authentication +* **-Host**: Hostname (default "localhost") +* **-InitialData**: Path to JSON containing initial state +* **-Persist**: Saves data to the given path on application exit +* **-Port**: Listen port (default 8081) + +These arguments allow you to configure various aspects of Cosmium's behavior according to your requirements. + +# License +This project is [MIT licensed](./LICENSE).