diff --git a/docusaurus.config.js b/docusaurus.config.js index dec92a5829..2e07c6dd97 100644 --- a/docusaurus.config.js +++ b/docusaurus.config.js @@ -125,7 +125,7 @@ module.exports = { lastVersion: 'current', versions: { current: { - label: '0.8', + label: '0.8.1', path: '/', } }, diff --git a/package.json b/package.json index 447b8bfd9d..18c68c8fb1 100644 --- a/package.json +++ b/package.json @@ -12,10 +12,10 @@ "clear": "docusaurus clear" }, "dependencies": { - "@docusaurus/core": "^3.1.1", - "@docusaurus/plugin-client-redirects": "^3.1.1", - "@docusaurus/preset-classic": "^3.1.1", - "@docusaurus/theme-search-algolia": "^3.1.1", + "@docusaurus/core": "^3.2.0", + "@docusaurus/plugin-client-redirects": "^3.2.0", + "@docusaurus/preset-classic": "^3.2.0", + "@docusaurus/theme-search-algolia": "^3.2.0", "react": "^18.2.0", "react-dom": "^18.2.0" }, diff --git a/versioned_docs/version-0.8.0/1.index.md b/versioned_docs/version-0.8.0/1.index.md new file mode 100644 index 0000000000..c5d98ef565 --- /dev/null +++ b/versioned_docs/version-0.8.0/1.index.md @@ -0,0 +1,45 @@ +--- +id: index +title: Introduction +sidebar_label: Home +slug: / +--- + +Welcome to Skytable's docs! Skytable is a free and open-source modern NoSQL database that builds on the foundations of performance, scalability, powerful querying and a robust type system. Skytable can be deployed as just a single binary file with no special system dependencies and only relies on the operating system's `libc` implementation. + +## Guide + +Skytable has it's own query language, BlueQLTM which provides everything across DDL, DCL and DML queries and exists to be a very powerful and secure alternative to SQL. If you're coming from SQL, you should feel just at home — BlueQL has a few small but important operating differences from SQL but has very similar syntax. + +We recommend you to follow the guide in this sequence (but feel free to skip any sections): + - [**Installation**](installation) and [**using the CLI**](using-the-repl): Get everything installed on your local system + - [**System overview**](architecture): A brief introduction to Skytable, including an overview of the data model, query systems and storage + - **BlueQL**: + - [**Introduction**](blueql/overview): Serves as a basic introduction to the query language and an (currently incomplete) informal specification with information on keywords, syntax and stuctures. + - [**DDL**](blueql/ddl): Data definition with BlueQL + - [**DML**](blueql/dml): Data manipulation with BlueQL + - [**DCL**](blueql/dcl): Data control with BlueQL + - [**Configuration**](system/configuration): Information to help you configure Skytable with custom settings such as custom ports, hosts, TLS, and etc. + - [**Administration**](system/administration): Information on access control, user and other administration features + - [**Resources**](resources/overview): Helpful resources + - [**A guide to the new Skytable**](resources/migration): For old our returning Skytable users who are coming from older versions + - [**Benchmarking**](benchmarking): A guide for load testing Skytable + - [**Deployment**](deployment): An useful guide for deploying + - [**Limits**](limits): An useful guide on system limits + +## Client drivers + +Looking to integrate Skytable in your application? Great! [Find a driver for your language/framework here](libraries). + +## Getting help + +We have a collection of resources [on this page](resources/overview). If you need in help in real-time, we recommend that you join our [Discord Community](https://discord.gg/QptWFdx) where you can get help directly from the developers and our community members. +Most queries are usually answered there in a few hours! + +## Contributing + +If you find any typos, mistakes or any other scope of improvement - please don't hesitate to bring it up [here](https://github.com/skytable/docs/issues). Thank you ❤️! + +## License + +The documentation is licensed under the [CC-BY-SA-4.0 License](https://github.com/skytable/docs/tree/master/LICENSE) diff --git a/versioned_docs/version-0.8.0/13.libraries.md b/versioned_docs/version-0.8.0/13.libraries.md new file mode 100644 index 0000000000..e27772df60 --- /dev/null +++ b/versioned_docs/version-0.8.0/13.libraries.md @@ -0,0 +1,35 @@ +--- +id: libraries +title: Client drivers +--- + + +## Official drivers + +The drivers that are officially maintained can be expected to be feature complete and stable. We currently support the following drivers: + +| Language/Framework | Links | Status | Package manager command | +| ------------------------------ | --------------------------------------------------------------------------------------------------- | -------- | ----------------------- | +| Rust | [GitHub](https://github.com/skytable/client-rust), [crates.io](https://crates.io/crates/skytable) | Stable ✅ | `cargo add skytable` | +| NodeJS (JavaScript/TypeScript) | [GitHub](https://github.com/skytable/client-nodejs), [npm](https://npmjs.com/package/skytable-node) | Beta 🏗 | `npm i skytable-node` | + +:::info More lanugages +The team is always looking to support more languages and we wish we could ship more drivers. But due to limited +resources we haven't been able to. If you're willing to write a driver (it's super easy to), jump into our chat! +::: + +## Community powered + +List of community powered drivers (sorted alphabetically): + +| Language/Framework | Client source code | Upstreamed | License | Remarks | +| -------------------------------- | ------------------------------------------------------------- | ---------- | ---------- | --------------------------------------------------------------------------------- | +| **C#/.NET** | | ❗ | | | +| | [C# driver](https://github.com/martinmolin/skytable-dotnet) | ❗ | Apache-2.0 | Available on [NuGet](https://www.nuget.org/packages/Skytable.Client) | +| **Go** | | ❗ | | | +| | [Go driver](https://github.com/No3371/go-skytable) | ❗ | Apache-2.0 | Written from scratch | +| | [Go driver](https://github.com/satvik007/skytable-go) | ❗ | Apache-2.0 | Easy for migration from go-redis | +| **JavaScript/TypeScript (Node)** | | ❗ | | | +| | [NodeJS Driver](https://github.com/zhangyuannie/skytable.js) | ❗ | Apache-2.0 | Available on [npm](https://www.npmjs.com/package/skytable.js) | +| **PHP** | | ❗ | | | +| | [PHP client driver](https://github.com/hkulekci/skytable-php) | ❗ | MIT | Can be found on [Packagist](https://packagist.org/packages/hkulekci/skytable-php) | diff --git a/versioned_docs/version-0.8.0/14.benchmarking.md b/versioned_docs/version-0.8.0/14.benchmarking.md new file mode 100644 index 0000000000..26bb2e141b --- /dev/null +++ b/versioned_docs/version-0.8.0/14.benchmarking.md @@ -0,0 +1,35 @@ +--- +id: benchmarking +title: Benchmarking +--- + +Due to Skytable having in-house implementations of almost everything, starting from the protocol, the storage engine and query +language — we have our own custom load testing tool called `sky-bench` that is distributed with the bundle. + +## Setting up for benchmarking + +**Quick notes**: +- The benchmark tool will create: + - a space called `bench` + - a model called `bench` +- **Be sure that these objects don't already exist!** But don't worry, if they do — the benchmark tool will error. You won't lose any data +- **Once the benchmark is complete, the `bench` space is removed!** +- **Do not use the `bench` space during the benchmark**: You might lose data + +**The benchmark tool will:** +- Run a total of 4,000,000 queries (don't worry, they run pretty fast!): + - Run 1,000,000 `INSERT`s + - Run 1,000,000 `SELECT`s + - Run 1,000,000 `UPDATE`s + - Run 1,000,000 `DELETE`s +- The model used has the declaration `(un: string, pw: uint8)` +- The `SELECT` will select and return all fields +- The `UPDATE` will increment the value of `pw` like this `pw += 1` +- The `DELETE` removes the entire collection +- The default primary key size is 7 bytes. All generated keys will be padded with zeros from to 0 to 999,999 like this: `0000000` or `0999999` + +## Off to the races + +1. Start up the database server +2. Run `./sky-bench --password `. We need your `root` password because only the root account can create, alter and drop models and the benchmark tool needs to run these queries +3. Wait for it to happen. You may not believe your eyes, so we recommend that you keep your eyes hydrated 🔥🚀✨💣 diff --git a/versioned_docs/version-0.8.0/15.deployment.md b/versioned_docs/version-0.8.0/15.deployment.md new file mode 100644 index 0000000000..b85e92e0f2 --- /dev/null +++ b/versioned_docs/version-0.8.0/15.deployment.md @@ -0,0 +1,16 @@ +--- +id: deployment +title: Deployment +--- + +Here are some recommendations for deployment: +1. **Make sure you have enough memory and storage!** The server will start returning errors when your server runs out of resources, as you'd expect. +2. **When deploying on docker**: + - Try to map the volume to a local path. We've had unwarranted data losses when we accidentally ended up running a `docker system prune` + - Make sure you have your networking configured right. For example, if you don't map your ports correctly, you'll not be able to access the database outside docker (without running `docker inspect` to find the IP of the container) + - Keep a separate folder for all your docker containers: + - Create a directory in your home directory like: `$HOME/docker-data` + - Then for every Docker image (whether it is Skytable or any other container) create a subfolder in that directory and map + the subfolder as a volume for persistence +3. **Check your firewall**: You want to be very sure about this! If you're starting your database on a different server (as you should; ideally you keep your database server separate from the host running your application server) then make sure that the ports are open and allowed +4. **Set up virtual memory and monitoring**: To avoid exhausting resources, set up monitoring on your node and enable virtual memory to temporarily avoid OOMs diff --git a/versioned_docs/version-0.8.0/16.limits.md b/versioned_docs/version-0.8.0/16.limits.md new file mode 100644 index 0000000000..45319e642c --- /dev/null +++ b/versioned_docs/version-0.8.0/16.limits.md @@ -0,0 +1,37 @@ +--- +id: limits +title: Limits +--- + +We've made every effort to provide a robust querying interface, but there are some **temporary limitations** that we think you +should know about. We aim to remove the limitations over the next few releases which we expect should happen fairly quickly. + +Skytable's limitations primarily come from a bunch of concerns: +- **Performance and scalability**: Most of our design decisions are influenced by concerns about performance. For example, it's very hard to efficiently scale multi-column indexes. +- **Reliability**: how reliable is the execution of the task? If it's like walking on eggshells, then we're not going to implement it (for example, unreliable distributed locking) +- **Security**: If it can't be run securely, then it's off our list + +## Temporary limitations + +- **DML in collections are still limited**: You'll be able to easily `INSERT` data into any collections but the manipulations on them are currently limited.: + - `SELECT` will return the entire collection and cannot yet return a single element + - `UPDATE` can append elements to *non-nested* collections but can't do the same for nested collections + - `DELETE` can't remove individual elements +- **Models cannot be `volatile` yet**. If you've used Skytable before, you'd know that you could previously create `volatile` + models which were used as *caching tables* as in they didn't persist data across restarts. The `volatile` feature has been + temporarily removed because we're working on integrating it with the new storage engine. + +:::tip Nested collections will get an upgrade +We understand that collections are fundamental to the complexity of today's data and hence we're working on this! The only reason our team spends so much time *perfecting* features is because it has match our design philosophy. + +> You can have 100 fancy but slow features, or 10 powerful and performant features. + +If it scales, we ship it. **We're on it!** +::: + +## Soft limitations + +Following Skytable's design philosophy that closely encompasses NoSQL systems, the following soft limitations are set: +- **Only one index**: Right now, the only index that you can use is the primary index (primary_key -> row). This is due to concerns about performance and scale +- **No mass updates**: We consider mass updates, such as setting `counter += 1` to every row in a model with multi-million rows +to be very slow and bad for performance. Hence, we do not allow mass updates at this time. diff --git a/versioned_docs/version-0.8.0/2.installation.md b/versioned_docs/version-0.8.0/2.installation.md new file mode 100644 index 0000000000..07d2e83071 --- /dev/null +++ b/versioned_docs/version-0.8.0/2.installation.md @@ -0,0 +1,95 @@ +--- +id: installation +title: Installation +--- + +Getting started with Skytable involves choosing a mode of installation, downloading any required files and then starting up the database. You can choose to either use: + +- [**Native binaries (recommended)**](#native-binaries): This is what is generally recommended for the best performance. You will need to download a bundle and then start the server binary; no expert knowledge required +- [**Using a Debian package (recommended)**](#debian-package): If you're deploying on Ubuntu or any other Debian based Linux distribution, then consider using this method. Configuration files, users and passwords are autogenerated. +- [**A Docker image**](#docker-image): We generally recommend using a Docker image for experimenting with Skytable on your local system during development and you want to keep your local system *clean*. If you want to use a Docker image for deployment, you're always free to do so! + > **Note:** You might experience slightly degraded performance from the storage engine due to Docker engine's abstractions. + +## Native binaries + +To use native binaries you need to download a bundle which is simply a ZIP file with all the necessary binaries that you'll ever need to develop on and deploy Skytable. + +1. **First download the latest bundle** for your platform. You can find [download links on the releases page](https://github.com/skytable/skytable/releases). +2. **Unzip the ZIP file**. You'll find the following binaries in the extracted archive: + - `skyd`: This is the database server binary which when started runs as a daemon, serving requests + - `skysh`: This is the Skytable shell and it provides a very helpful interactive REPL database client + - `sky-bench`: This is the benchmarking tool that you can use to load test Skytable +3. **Start up the server**. You need to choose a `root` password for the `root` account which will have complete control over the database. + + ```bash + ./skyd --auth-root-password= + ``` + + **Replace with your own secure password!** + + Explanation: + - `--auth-root-password`: sets the root password + +The server starts up at `localhost:2003` and is ready to run queries. + +:::info +Your operating system might sometimes not let you run binaries directly. On Unix based systems, you'll need to run: `chmod +x skyd skysh sky-bench`. + +And on Windows systems you might need to right-click on the binaries and click on "unblock" +::: + +## Debian package + +Find the correct `*.deb` file [from the releases page](https://github.com/skytable/skytable/releases). Now simply run: + +```sh +sudo dpkg -i .deb +``` + +The package will: + +- **Generate a root password:** Watch the terminal output! +- **Create a `systemd` unit**: So you can start and stop the process using `systemd` like `systemd start skyd` +- **Generate a configuration**: Your configuration is stored in `/var/lib/skytable/config.yaml`. Go ahead and modify it if you need to! + +## Docker image + +:::info You must have docker set up! + +- Use [this great guide from Docker](https://docs.docker.com/engine/install/) to install and get started +- To be able to run `docker run` and related commands, you may need administrative privileges +::: + +### Simple setup + +1. **Download the bundle**: To be able to run queries you need to download the bundle as described above +2. **Start the container**: + + ```shell + docker run -d --name skydb -p 2003:2003 skytable/skytable:latest + ``` + +:::tip +The password for the Skytable instance on the Docker container is auto-generated. Run `docker logs -f skydb` and you'll see a log +message with the generated password. +::: + +### With persistence + +1. **Download the bundle**: To be able to run queries you need to download the bundle as described above +2. **Create the data directory**: To ensure that our database is persistent and all our data doesn't vanish as soon as the container is terminated, we'll map the data directory to an actual directory on our local system. + > **Note:** Create a folder called `skytable` in a convenient location. We recommend having a directory in `$HOME/docker-containers` where you can store the Skytable container's data and any other containers that you might use. It's a great way to keep things organized. +3. **Create your configuration**: [Download this template file](https://raw.githubusercontent.com/skytable/skytable/next/examples/config-files/template.yaml) and place it into the directory you created. Update the password with your `root` password of choice. +4. **Start the container**: + + ```shell + docker run -d --name skydb \ + -v $HOME/docker-containers/skytable:/var/lib/skytable \ + -p 2003:2003 \ + skytable/skytable:latest + ``` + + Explanation: + - This starts a container with name `skydb` + - It maps the folder (as discussed earlier) `$HOME/docker-containers/skytable` from your local file system to `/var/skytable` (in the container's file system) + - Maps port `2003` on the host to the containers port `2003` so that you can use the command-line client `skysh` without having to inspect the container's IP address diff --git a/versioned_docs/version-0.8.0/3.using-repl.md b/versioned_docs/version-0.8.0/3.using-repl.md new file mode 100644 index 0000000000..e9d62d4567 --- /dev/null +++ b/versioned_docs/version-0.8.0/3.using-repl.md @@ -0,0 +1,96 @@ +--- +id: using-the-repl +title: Using the REPL +--- + +Once you've set up Skytable [following our guide](installation), you can now get started using the REPL. Note that you must have downloaded the bundle. If not, go back to the installation guide and do it now. + +## Starting the repl + +Run this to start the command-line REPL: + +```sh +./skysh +``` + +The REPL will then ask you for a password which you need to type in. This is the root password that you would have set during your installation, so if you don't remember it go ahead and check what you set during the installation step. + +:::tip +Keep the root password safe! It's the admin access to your database and without it you won't be able to create or drop or alter +or ... do anything administrative. But if you do happen to lose it, there's an easy way to reset the password (this however requires you to stop the database, which is also the case with many other databases, and that's primarily for security). + +You can read more in the [configuration](system/configuration) page. +::: + +## Using the REPL + +You will now see a welcome message and the REPL will prompt you to run something. Now is a good time to run `sysctl report status` which should just print out `(Okay)` in a cyan shade: + +```sh +> sysctl report status +(Okay) +``` + +You can also run queries like: `inspect global` to see available global system information. + +:::info Quick notes + +- The REPL currently stores history in the `.sky_history` file. If you want to remove history, you can simply delete the file +- The REPL will automatically parameterize queries. Don't worry about what this means; you'll learn about it ahead. +- The REPL applies custom formatting to `DDL` queries. For example, even though `inspect global` returns a JSON as a string, +the REPL formats it and outputs it without quotes, to improve readability +- To connect using different settings (the REPL will attempt to authenticate as `root` by default), see the options using `skysh --help` +::: + +## First steps + +Skytable's data model is discussed in depth on [this page](architecture#data-model), but let us understand some basics. If you've used a SQL +database, you would be used to the idea of a `database` — just like this, Skytable has `space`s. A `space` is a collection +of `models` (which are like SQL's `table`s with slightly different functionality) and other containers. + +### Create a space + +Let us create a `space`: + +```sql +CREATE SPACE myspace +``` + +### Create a model + +Let us create a `model`. We want to store something that resembles the structure: + +```json +{"username": "string username", "password": "string password", "notes": []} +``` + +To do this, we create the following Skytable model: + +```sql +CREATE MODEL myspace.mymodel(username: string, password: string, notes: list { type: string }) +``` + +### Add, update and remove some data + +- **Insert some data**: + ```sql + INSERT INTO myspace.mymodel('sayan', 'password123', []) + ``` +- **Update some data**: + ```sql + UPDATE myspace.mymodel SET notes += "mynewnote" WHERE username = 'sayan' + ``` +- **Select some data**: + ```sql + SELECT notes, password FROM myspace.mymodel WHERE username = 'sayan' + ``` + +## Use in your own apps + +While we would recommend you to learn BlueQL and more about Skytable's architecture by using the REPL, you can always start using Skytable +in your own apps. [Find a client driver for your language or framework here](libraries). + +Once you've found the driver for your framework, you can come back here and follow on with the guide. Be sure to check the driver's +documentation to see how the client driver should be used. + +Good luck! diff --git a/versioned_docs/version-0.8.0/4.architecture.md b/versioned_docs/version-0.8.0/4.architecture.md new file mode 100644 index 0000000000..94678d0695 --- /dev/null +++ b/versioned_docs/version-0.8.0/4.architecture.md @@ -0,0 +1,123 @@ +--- +id: architecture +title: Architecture +--- + +Skytable is a modern NoSQL database that prioritises performance, scalability and reliability while providing a rich and powerful querying interface. We are generally targetting an audience that wants to build high performance, large-scale, low latency applications, such as social networking services, auth services, adtech and such. Skytable is designed to work with +both **structured and semi-structured data**. + +Our goal is to provide you with a powerful and solid foundation for your application with no gimmicks — just a solid core. +That's why, every component in Skytable has been engineered from the ground up, from scratch. + +And all of that, without you having to be an expert, and with the least maintenance that you can expect. + +## Fundamental differences from relational systems + +BlueQL kind of looks and feels like using SQL with a relational database but that doesn't make Skytable's internals the same, with the most important distinction being the fact that Skytable has a NoSQL engine! But Skytable's evaluation and execution of queries is fundamentally different from SQL counterparts and even NoSQL engines. Here are some key differences: + +- All DML queries are point queries and **not** range queries: + - This means that they will either return atleast one row or error + - If you intend to do a multi-row query, then it won't work unless you add `ALL`. `ALL` by itself indicates that you're applying (or selecting) a large range and can be inefficient +- Multi-row DML queries are slow and inefficient and are discouraged +- You can **only** query on the primary index, once again because of speed (and the problem with scaling multiple indexes) with a fixed set of operators. +- **Remember, in NoSQL systems we denormalize.** Hence, no `JOIN`s or foreign keys as with many other NoSQL systems +- A different transactional model: + - All DDL and DCL queries are ACID transactions + - However, DML transactions are not ACID and instead are efficiently batched and are automatically made part of a batch + transaction. The engine decides *when* it will execute them, for example based on the pressure on cache. That's because our + focus is to maximize throughput + - All these differences mean that **DDL and DCL transactions are ACID transactions** while **DML queries are ACI and *eventually* D** (we call it a *delayed durability transaction*). This delay however can be adjusted to make sure that the DML + queries *emulate* ACID transactions but that defeats the point of the eventually durable system which aims to heavily increase throughput. + - The idea of eventually durable transactions relies on the idea that hardware failure even though prominent is still rare, + thanks to the extreme hard work that cloud vendors put into reliability engineering. If you plan to run on unreliable hardware, then the delay setting (reliability service) is what you need to change. + - For extremely unreliable hardware on the other hand, we're working on a new storage driver `rtsyncblock` that is expected to be released in Q1'24 +- The transactional engine powering DDL and DCL queries might often choose to demote a transaction to a virtual transaction which makes sure that the transaction is obviously durable but not necessarily actually executed but is eventually executed. If the system crashes, the engine will still be able to actually execute the transaction (even if it crashed halfway) + +:::tip +We believe you can now hopefully see how Skytable's workings are fundamentally different from traditional engines. And, we know +that you might have a lot of questions! If you do, please reach out. We're here to help. +::: + +## Data model + +Just like SQL has `DATABASE`s, Skytable has `SPACE`s which are collections of what we call data containers like tables. +In Skytable lingo, we don't call them tables but call them `MODEL`s which enable you to *define your data model*. + +:::info +While a `MODEL` is the only data container for now, many more are set to come. Now is a good time to [join our discord server](https://discord.gg/QptWFdx) where you can directly chat with the developers working on Skytable and all our awesome community members. +::: + +### A `space` is like a `database` + +A `space` in Skytable is a collection of `model`s and other objects, and settings. It is different from a traditional SQL +Database (that is created with SQL's `CREATE DATABASE`) because it is not meant for tables only, but many other things. + +Spaces have "space local" settings that can be set for the space (and will be respected by all its `models` and other items). You'll learn more about this in the section on DDL. + +### A `model` is like a `table` + +A `model` in Skytable is like a `table` in SQL but is vastly different because of certain concepts such as: +- DML queries are point and not range queries by default +- Restrictions on indexes +- Settings (which can't be created in traditional `table`s) +- Semi-structured data: with collection types in columns such as lists and dictionaries that violates some of the ideas of + traditional schema enforcement + +## Query language + +Skytable has it's own query language BlueQLTM which takes a lot of inspiration from SQL but makes several different (and sometimes vastly different) design choices, focused on clarity, speed, simplicity and most importantly, security. + +For example, Skytable's BlueQLTM *only* allows the parameterization of queries. All the queries you ran previously with strings and numbers directly were only possible because the REPL client smartly does the paramterization behind the scenes. This is done for security. You'll learn more about BlueQL next. + +## Transactions + +Skytable's DDL and DCL queries are all ACID transactions. However, DML queries use an AOF-style storage driver that periodically +records, analyses and then intelligently syncs the changes to disk. We're working on making ACID transactions widely available +across DML queries as well. + +## Storage + +Skytable's storage engine is collectively called the Skytable Disk Storage Subsystem or SDSS for short. The storage engine uses +several different storage drivers, using ones appropriate for the task. We do not use RocksDB or any other engine but we +implement everything in house, engineering them piece by piece. + +:::info Features on track +At this point, Skytable is primarily in-memory which means that while it uses disk storage for durability, most data is stored in-memory. **This is going to change in the near future as the team is working on building a custom log-based engine.** As you might understand, this is not an everyday task and as we incorporate new ideas it will take some time. But if you're seeing this in 2023, you can expect us to ship something by Q1 2024. +::: + +DDL and DCL transactions use a log-based append-only driver while DML queries use a custom log-based append-only driver that is able to intelligently handle concurrent changes. The team will implement new and updated storage drivers from time to time but you do not have to worry about anything, due to our promise for backwards compatibility (see below). + +## Scalability + +Skytable is heavily multithreaded enabling incredible vertical scalability and you can witness it for yourself by running benchmarks (or looking at ones that we publish). Clustering and replication are on track to be released soon. + +:::info Features on track +Clustering and replication are right on track and we're expecting to deliver them by Q1 2024. We'd also like to note that +clustering is too important to ignore so you can be assured that we're hard at work on it. +::: + +Skytable will use atleast as many threads as the number of logical CPUs present on the host. At this moment it is not possible to +limit multithreading because multithreading is a part of Skytable's design principles and every attempt is made to exploit +available CPU cores to the fullest. + +## Networking + +Skytable its own in-house Skyhash protocol that is built on top of TCP enabling any programming language that has a TCP client to use it without issues. There are three phases in the connection: +- Handshake: All auth data, compatibility information and other data is exchanged at this step +- Connection mode selection: based on the handshake parameters a connection mode is chosen and the server responds with the chosen exchange mode +- Data exchange: This is where the real querying happens +- Termination: there is no special step; just a `TCP FIN` + +## Backwards compatibility + +We make the promise to you that no matter what changes in Skytable, you will always be able to: +- Upgrade from one version to another without data loss or too many hoops +- Export data from Skytable at any time + +More technically: +- **For minor/patch releases**: The minor/patch is just in the name but it indicates that no data migration effort is needed. **No minor releases ever need data migration, and any migration is done automatically** +- **For major releases**: Major releases generally introduce breaking changes (just like the upgrade from `0.7.x` to `0.8.0` is a largely breaking change). **Major releases will either automatically upgrade the data files or require you to use a migration tool that is shipped with the bundle**. +- Definitions (closely following semantic versioning): + - **A major release** is something like `1.0.0` to `2.0.0` or `0.8.0` to `0.9.0` (in development versions, 0.8.0 to 0.9.0 is a major version bump) + - **A minor release** is something like `1.0.0` to `1.1.0` or `0.8.0` to `0.8.1` + - **A patch release** is something like `1.0.0` to `1.0.1` or `0.8.0` to `0.8.1` (note that in development versions there is no distinction between a minor and patch release) diff --git a/versioned_docs/version-0.8.0/blueql/1.overview.md b/versioned_docs/version-0.8.0/blueql/1.overview.md new file mode 100644 index 0000000000..1bd14b1d0a --- /dev/null +++ b/versioned_docs/version-0.8.0/blueql/1.overview.md @@ -0,0 +1,186 @@ +--- +id: overview +title: Overview +--- + +BlueQLTM is Skytable's own query language that very closely follows the design of SQL but with many +modern features and superior security. This document explores a basic overview of BlueQL. + +Design principles: +- **Simplicity and clarity**: The language shouldn't be overwhelming to understand +- **Security with mandatory parameterization**: We want to reduce the surface of injection attacks. For this reason, [parameterization is mandatory](#parameters). + +Just like SQL, BlueQL has three categories of commands/queries inside it: + +- **DDL**: Data definition language is used to define, modify and/or remove DDL objects such as `space`s and `model`s +- **DCL**: Data control language is used to control the access to data, and perform other administrative tasks +- **DML**: Data manipulation language is used to manipulate data + +Jump to [differences from SQL](#differences-from-sql). + +:::info +This text is *not* a detailed, formal guide. It's meant for developers and users who want to work with +Skytable. If you need a more formal specification, like a grammar definition, please ask us, and we'll create +it. We haven't published it yet because no one has requested it. +::: + +## Identifiers +Can begin with any ASCII alphabet or an underscore (`_`) and then have any number of alphanumeric characters and/or underscores. + +## Keywords + +Keywords are identifiers with special meanings and hence can't be used as identifiers in other places. Here's a full-list of +keywords: + +```ts +[ + "sysctl", "create", "alter", "drop", "use", "inspect", "describe", "insert", "select", "update", + "delete", "exists", "table", "model", "space", "index", "type", "function", "rename", "add", + "remove", "transform", "set", "return", "order", "sort", "group", "limit", "asc", "desc", "all", + "by", "with", "on", "from", "into", "as", "to", "in", "of", "and", "or", "not", "if", "else", + "where", "when", "allow", "auto", "default", "null", "transaction", "batch", "lock", "read", + "write", "begin", "end", "key", "value", "primary", "truncate" +] +``` + +## Data types + +### Boolean +A boolean value, either `true` or `false` + +### Unsigned integers + +- `uint8`: unsigned 8-bit integer +- `uint16`: unsigned 16-bit integer +- `uint32`: unsigned 32-bit integer +- `uint64`: unsigned 64-bit integer + +### Signed integers + +- `sint8`: signed 8-bit integer +- `sint16`: signed 16-bit integer +- `sint32`: signed 32-bit integer +- `sint64`: signed 64-bit integer + +### Floating point values + +- `float32`: a single-precision float +- `float64`: a double-precision float + +### Simple collections + +- `binary`: a binary blob represented as a sequence of `uint8` values +- `string`: an UTF-8 string + +### Complex collections + +- `list`: a list of any of the data types, including nested lists + - A list is represented as: `[]` with values inbetween. For example, a `list { type:string }` would be represented as: + ```sql + ["sayan", "loves", "dogs"] + ``` + - **Lists cannot contain null values** + - **List can be nested**: You can have heavily nested lists like: `[[[]], [["another one"]]]` + - **List can only have one base type**: This means that if you have a list like `[[[string]]]` each element must either be the same nested list, or an empty list + +:::info Note +New data types are frequently added, so treat this list as non-exhaustive. +::: + +## Literals + +- Null literal: `null` +- Numeric literals: + - Unsigned: `1234` + - Signed: `[-]1234` +- Floating point literals: `[-]1234.5678` +- String literals: `"hello"` +- Binary literals: \`binary\` +- List literals: `[..]` +- Dictionaries: `{: }` + +:::warning Literals are not available everywhere +It is very important for you to know that literals are not allowed everywhere. The only literals allowed everywhere are: +- Lists +- Dictionaries + +Read below to understand why. +::: + +## Parameters + +All literals apart from dictionaries and lists must be used as parameters. **BlueQL only allows literals as parameters**. For example, using the Rust client, if you were to run this: + +```sql +insert into myspace.mymodel('sayan', 'pass123', ['myfirstnote']) +``` + +You are required to parameterize the query like this: + +```rust +use skytable::query; + +let query = query!("insert into myspace.mymode(?, ?, [?])", "sayan", "pass123", "myfirstnote") +``` + +If you try to run it without any parameters (don't forget that `skysh` automatically parameterizes for convenience) the query +won't even compile. + +:::tip +Just so you know, parameterizing involves passing a separate parameter list, with each parameter encoded. You wouldn't need to worry about this because the client driver does all of that for you! + +**The question is why? The answer is security.** SQL-injection vulernabilties have already costed companies a lot, so we don't +want to inherit that from SQL. + +**Also, parameterization is exclusively possible for literals**. This means that whenever you're accepting data from an untrusted +source, it becomes a parameter. If you try to not use parameters, the query will not even compile. + +On a final note, BlueQL doesn't support comments of any form also for security reasons. +::: + +## Expressions + +- `+=`: add RHS to LHS + - Can be used outside arithmetic contexts + - Add a char to a field `mystring`: `mystring += ",world"` + - Add a list to a nested list field: `mylist += ["item in nested list"]` +- `-=`: subtract RHS from LHS +- `/=`: divide LHS by RHS +- `*=`: multiply LHS by RHS + +## DDL + +Queries include: +- Spaces: + - `CREATE SPACE myspace [WITH { property: value, ... }]` + - `ALTER SPACE myspace [WITH { property: updated_value, ... }]` + - `DROP SPACE [allow not empty] myspace` +- Models: + - `CREATE MODEL myspace.mymodel([primary] [null] field: field_type, ...) [WITH { property: value, ... }]` + - `ALTER MODEL myspace.mymodel (ADD ... | UPDATE ... | REMOVE ...)` + - `DROP MODEL [allow not empty] myspace.mymodel` +- `INSPECT GLOBAL`: inspects global state, shows a list of spaces and users +- `INSPECT SPACE `: inspects a single space, shows a list of models and other things +- `INSPECT MODEL `: inspects a single model, shows information about stored data and other things + +## DML + +- `INSERT INTO myspace.mymodel(...)` +- `SELECT col1, ... FROM myspace.mymodel WHERE ...` +- `UPDATE myspace.mymodel SET counter += 1 WHERE ...` +- `DELETE FROM myspace.mymode WHERE ...` + +## DCL + +Queries include: +- `SYSCTL REPORT STATUS`: returns the status of the system. (Not a control query per se) +- `SYSCTL CREATE USER "username" WITH { password: ... }`: create a new user +- `SYSCTL DROP USER "username"`: removes the user in question + +## Differences from SQL + +- No literals (see above) +- Mandatory parameterization (see above) +- No semicolons! +- Only one statement per query. For multiple statements batches must be used +- DML queries are point queries (hence must contain a `WHERE` clause) diff --git a/versioned_docs/version-0.8.0/blueql/2.ddl.md b/versioned_docs/version-0.8.0/blueql/2.ddl.md new file mode 100644 index 0000000000..a279b2883c --- /dev/null +++ b/versioned_docs/version-0.8.0/blueql/2.ddl.md @@ -0,0 +1,255 @@ +--- +id: ddl +title: DDL +--- + +DDL short for Data Definition Language is used to create, alter and drop DDL objects such as `space`s and `model`s. + +## Generic + +### USE + +- **Syntax**: + - `USE `: sets the space that will be used for all other queries + - `USE null`: unsets the space + - `USE $current`: returns the name of the space currently set **if it still exists** or otherwise returns an error +- **Access control**: any +- **Returns**: empty or error + +:::tip DDL actions don't respect `USE` +This is so that you're specific about what DDL object you want to manipulate. + +Exception: `INSPECT` queries will respect the currently set `SPACE` if required. +::: + +### INSPECT: + +- **Syntax**: + - `INSPECT GLOBAL`: returns a JSON with a list of all spaces, users and other information. For example: + ```json + {"spaces":["space1"],"users":["root"],"settings":{}} + ``` + - `INSPECT SPACE `: returns a JSON with a list of all models in the space and other information, For example: + ```json + {"models":["model1"],"properties":{}} + ``` + - `INSPECT MODEL .`: returns a JSON with information about the model such as the declaration, row count and such: + ```json + {"decl":"{*username: string, !password: string, ?notes: [string]}","size":12345678,"properties":{}} + ``` +- **Access control**: any +- **Returns**: string or error + +## Space + +### CREATE SPACE + +**Syntax:** + +```sql +-- without any properties +CREATE SPACE [IF NOT EXISTS] +-- with properties +CREATE SPACE [IF NOT EXISTS] WITH { property_name: property_value } +``` + +- **Access control**: `root` only +- **Properties**: None +- **Returns**: + - empty or error + - when used with `if not exists`: bool indicating whether the space was actually created or not (false indicates that it was already present and hence not created) + +#### Examples + +```sql +CREATE SPACE apps +CREATE SPACE IF NOT EXISTS apps +``` + +### ALTER SPACE + + +**Syntax:** +```sql +ALTER SPACE WITH { property_name: property_value } +``` + +- **Access control**: `root` only +- **Properties**: None +- **Returns**: empty or error + +#### Examples + +```sql +ALTER SPACE apps WITH { new_cache_value: 1234 } +``` + +### DROP SPACE + +**Syntax:** +```sql +DROP SPACE [IF EXISTS] [ALLOW NOT EMPTY] +``` + +- **Access control**: `root` only +- **Operational notes**: + - **A non-empty space cannot be dropped** + To avoid catastrophic `DROP`s, a `SPACE` can only be dropped directly if it is non-empty. To drop a non-empty space, you must + run: + ```sql + DROP SPACE ALLOW NOT EMPTY + ``` +- **Returns**: + - empty or error + - when used with `if exists`: bool indicating whether the space was actually present or not + +#### Examples + +```sql +DROP SPACE myspace +DROP SPACE ALLOW NOT EMPTY myspace +``` + +## Models + +### Type definitions + +- **When used in create**: + - **A simple type**: `field_name: string` + - **A list**: `field_name: list {type: string}` + - **A nested list**: `field_name: list{type: string}` +- **When used in alter**: + - **A simple type**: `field_name { type: string }` + - **A list**: `field_name { type: list {type: string} }` + - **A nested list**: `field_name {type: list{type:list{type:string}}}` + +### CREATE MODEL + +**Syntax**: +```sql +CREATE MODEL [IF NOT EXISTS] .([primary] [null] field_name: field_type) [ WITH {property_name: property_value} ] +``` +- **Access control**: `root` only +- **Properties**: None +- **Operational notes**: + - The **first field specified automatically becomes the primary key** + - All **fields are not nullable by default** + - To make a field nullable add the `null` keyword before the field name + - If you do not want the first field to become the primary key, then you must add the `primary` keyword before the field that you want to use as the primary key + - The field order is preserved. When doing an `INSERT` you will have to supply values in the same order +- **Returns**: + - empty or error + - when used with `if not exists`: bool indicating whether the model was actually created or not (false indicates that it was already present and hence not created) + +#### Examples + +```sql +CREATE MODEL myspace.mymodel(username: string, password: string, null email_id: string, notes: list { type: string }) +CREATE MODEL IF NOT EXISTS myspace.mymodel(username: string, password: string, null email_id: string, notes: list { type: string }) +``` + +### ALTER MODEL ADD + +**Syntax:** +```sql +-- add a single field +ALTER MODEL . ADD one_field { type: string } +-- add multiple fields +ALTER MODEL . ADD ( + first_field { type: string }, + second_field { type: binary }, +) +``` + +- **Access control**: `root` only +- **Returns**: empty or error + +#### Examples +```sql +ALTER MODEL myspace.mymodel ADD one_field { type: list { type: string } } +ALTER MODEL myspace.mymodel ADD ( + email_id: { + type: string, + nullable: true, + }, + phone_number: { + type: uint64, + nullable: true, + }, +) +``` + +### ALTER MODEL UPDATE + +**Syntax** +```sql +-- update one field +ALTER MODEL . UPDATE one_field { type: string } +-- update multiple fields +ALTER MODEL . UPDATE ( + first_field { type: string }, + second_field { type: binary }, +) +``` + +- **Access control**: `root` only +- **Operational notes** + - The primary key field cannot be modified +- **Returns**: empty or error + +#### Examples + +```sql +ALTER MODEL myspace.mymodel UPDATE my_int_field { type: uint64 } +ALTER MODEL myspace.mymodel UPDATE ( + my_int_field { type: uint64 }, + my_float_field { type: float64 } +) +``` + +### ALTER MODEL REMOVE + +**Syntax**: +```sql +-- remove one field +ALTER MODEL . REMOVE one_field +-- remove multiple fields +ALTER MODEL . REMOVE (first_field, second_field, ...) +``` + +- **Access control**: `root` only +- **Operational notes** + - The primary key field cannot be removed (as is expected) +- **Returns**: empty or error + +#### Examples + +```sql +ALTER MODEL myspace.mymodel REMOVE useless_field +ALTER MODEL myspace.mymodel REMOVE (useless_field_1, useless_field2) +``` + +### DROP MODEL + +**Syntax**: +```sql +DROP MODEL [IF EXISTS] [ALLOW NOT EMPTY] . +``` + +- **Access control**: `root` only +- **Operational notes** + - **Non-empty models cannot be dropped** to avoid catastrophic drops + - **To drop a non-empty model**: you must run: + ```sql + DROP MODEL ALLOW NOT EMPTY . + ``` +- **Returns**: + - empty or error + - when used with `if exists`: bool indicating whether the model was actually present or not + +#### Examples + +```sql +DROP MODEL myspace.mymodel +DROP ALLOW NOT EMPTY myspace.mymodel +``` diff --git a/versioned_docs/version-0.8.0/blueql/3.dml.md b/versioned_docs/version-0.8.0/blueql/3.dml.md new file mode 100644 index 0000000000..f1ceb63766 --- /dev/null +++ b/versioned_docs/version-0.8.0/blueql/3.dml.md @@ -0,0 +1,124 @@ +--- +id: dml +title: DML +--- + +DML or Data Manipulation Language is what you'll be using for the most of your queries once you finish defining your data model. DML enables you to insert rows, manipulate the data in them, access their data or delete them. + +:::tip Indexes and performance +NB: Due to performance, at this point only the primary index (aka the primary key column) can be used to run DML queries. This +restriction will be eased in upcoming relases. +::: + +:::info +As you've already been told, don't forget to parameterize. The examples directly use literals to make it easier for you to understand! +::: + +## INSERT + +### Syntax + +```sql +-- insert in declaration order +INSERT INTO (?, ?, ?, ...) +-- insert using field names +INSERT INTO { + field1_name: ?, + field2_name: ?, + ... +} +``` +### Requirements and responses + +- **Access control**: any +- **Returns**: empty or error + +### Examples + +```sql +INSERT INTO mymodel('sayan', true) +INSERT INTO mymodel { + username: 'sayan', + verified: true, +} +``` + +## SELECT + +### Syntax + +```sql +-- select wildcard +SELECT * FROM WHERE = +-- select specific columns +SELECT profile_pic, phone_num FROM WHERE = +-- select several records (wildcard) +SELECT ALL * FROM LIMIT +-- select several records (named columns) +SELECT ALL username FROM LIMIT 100 +``` + +### Requirements and responses + +- **Access control**: any +- **Operational notes**: + - **Unlike SQL**, a standard `SELECT` in BlueQL is a **point query** and hence can only access a single row + - This means that if the row does not match an error is raised + - **To select multiple rows**: you need to use `SELECT ALL`. This ***must*** be accompanied by a `LIMIT` clause. +- **Access control**: any +- **Returns**: row or error + +### Examples + +```sql +SELECT * FROM apps.socialapp WHERE username = 'sayan' +SELECT password, profile_url FROM apps.logins WHERE username = 'sayan' +``` + +## UPDATE + +### Syntax + +```sql +UPDATE SET , ... WHERE = +``` + +### Requirements and responses + +- **Access control**: any +- **Operational notes**: + - **Unlike SQL**, a standard `UPDATE` in BlueQL is a **point query** and hence can only mutate a single row + - Wildcard queries aren't yet permitted. **NB: This will be fixed very soon!** +- **Access control**: any +- **Returns**: row or error + +### Examples + +```sql +UPDATE apps.socialapp SET followers += 1 WHERE username = 'sayan' +UPDATE apps.socialapp SET followers += 200, following += 5 WHERE username = 'sayan' +``` + +## DELETE + +### Syntax + +```sql +DELETE FROM WHERE = +``` + +### Requirements and responses + +- **Access control**: any +- **Operational notes**: + - **Unlike SQL**, a standard `DELETE` in BlueQL is a **point query** and hence can only remove a single row + - This means that if the row does not match an error is raised + - Wildcard queries aren't yet permitted. **NB: This will be fixed very soon!** +- **Access control**: any +- **Returns**: row or error + +### Examples + +```sql +DELETE FROM apps.socialapp WHERE username = 'aboslutely mid user' +``` diff --git a/versioned_docs/version-0.8.0/blueql/4.dcl.md b/versioned_docs/version-0.8.0/blueql/4.dcl.md new file mode 100644 index 0000000000..7c0306cfcb --- /dev/null +++ b/versioned_docs/version-0.8.0/blueql/4.dcl.md @@ -0,0 +1,51 @@ +--- +id: dcl +title: DCL +--- + +Data Control Language or DCL can be used to perform administrative tasks on the database. Currently, all DCL commands are +available under the `SYSCTL` query. + +## SYSCTL REPORT STATUS + +**Syntax**: +```sql +SYSCTL REPORT STATUS +``` +- **Access control**: any +- **Operational notes**: + - This returns the current overall health of the system +- **Returns**: empty or string or error + +## SYSCTL CREATE USER + +**Syntax**: +```sql +SYSCTL CREATE USER 'username' WITH { password: 'password' } +``` +- **Access control**: `root` only +- **Returns**: empty or error + +## SYSCTL ALTER USER + +**Syntax**: +```sql +SYSCTL ALTER USER 'username' WITH { password: 'new password' } +``` + +- **Access control**: `root` only +- **Returns**: empty or error + +:::warning +Trying to change the `root` account password will throw an error. You can only change the root by +[following the procedure here](/system/administration#resetting-the-root-password) +::: + +## SYSCTL DROP USER + +**Syntax**: +```sql +SYSCTL DROP USER 'username' +``` +- **Access control**: `root` only +- **Returns**: empty or error diff --git a/versioned_docs/version-0.8.0/protocol/1.overview.md b/versioned_docs/version-0.8.0/protocol/1.overview.md new file mode 100644 index 0000000000..02ddbfdf27 --- /dev/null +++ b/versioned_docs/version-0.8.0/protocol/1.overview.md @@ -0,0 +1,24 @@ +--- +id: overview +title: Skyhash 2 — Protocol Overview +--- + +Skyhash is the protocol used for communication between Skytable clients (client drivers or libraries) and the Skytable server, written on top of TCP. If you're building an application that needs to *talk to* Skytable, you'll usually choose a [client library](/libraries) that works with your programming language and then start building your application. + +However, if a client driver is not available for your language then you might choose to implement a client driver yourself and while it might sound like a complicated task, we've worked hard to make it as easy for for you to do so. If you've worked with string processing, what you're going to encounter is very similar. + +:::tip Looking for error codes? +Did the server return an error code and you're trying to figure out what happened? [**Jump to this page on error codes**](errors). +::: + +:::info New data types are constantly added! +We keep adding more and more data types with every release. So, if you're working to build a client, then consider keeping the type matching non-exhaustive, and if you encounter an unknown signature (that identifies the data type) then throw some sort of an exception indicating that your client does not support this data type yet. +::: + +Here are some good to know things, before a deep dive into the various pieces of the protocol: +- The protocol is based on top of TCP, so if your programming language standard library has a TCP client (as most of them do) you can build a client +- You might find the [official implementation of the Rust client](https://github.com/skytable/client-rust) to be a good reference +- If you need help, ask! (on Discord, ping us on Twitter, just reach out!) +- If the documentation doesn't seem helpful or you find it confusing, open an issue on the docs repository. We'll fix it. + +With all that out of the way, **go ahead and dive in!** diff --git a/versioned_docs/version-0.8.0/protocol/2.networking.md b/versioned_docs/version-0.8.0/protocol/2.networking.md new file mode 100644 index 0000000000..2b47e3f6dc --- /dev/null +++ b/versioned_docs/version-0.8.0/protocol/2.networking.md @@ -0,0 +1,84 @@ +--- +id: networking +title: Networking +--- + +The Skyhash protocol uses a very simple data exchange model. + +:::info This is for version 0.8.0! +This information on networking only corresponds to Skytable 0.8.0 (Octave). If you're using a different version consider looking for the appropriate document. +::: + +We use three connection stages: + +- **Client handshake**: The client sends a handshake packet + - The handshake contains all necessary information to successfully establish a connection + - The structure of the client handshake depends on the authentication plugin in use (since authentication data has to be exchanged before the connection can be established) + - For the `pwd` plugin the client handshake looks like this: + ``` + H00000\n\n + ``` +- **Server handshake**: + - **Accepted:** If the server accepts the handshake information then it will respond with: `H000` + - **Rejected**: If the server rejects the handshake information then it will respond with `H01<8-bit error code>`. You can find out what happened using [the error code index](errors) +- **Data exchange**: This is where the client and server exchange data + +How to communicate: +- Open a TCP connection to the server +- Do the handshake (as described above) and handle any errors +- Encode queries as described below + + +## Client + +### Data types + +The client side needs to send encoded data types to the server (in the form of parameters) so that the server can process them. + +Types: +- Null: Encoded as `0` +- Bool: Encoded as `1<0 or 1>\n` +- Unsigned integer: A 64-bit unsigned integer. Encoded as `2\n` +- Signed integer: A 64-bit unsigned integer. Encoded as `3\n` +- Float: A 64-bit (double precision) floating point value. Encoded as `4\n` +- Binary: A binary blob. Encoded as `5\n` +- String: An UTF-8 string. Encoded as `6\n` + +### Queries + +A query has three sections: +- The metaframe: + - Contains metadata about the query + - Encoded as: `\n` (total size of the other two sections) +- The dataframe header: Encoded as `\n` +- The dataframe: + - First part contains the query body, encoded as: `` (the query body is simply appended here) + - Second part contains the payload body with all the parameters, encoded as: `\n ...` (repeat for all parameters) + +## Server + +### Data types + +The server will respond with different data types, depending on the context. These include: +- Null: Encoded as `0` +- Bool: encoded as `1<0 or 1>\n` +- Unsigned integers: + - First byte: 2 -> 8-bit, 3 -> 16-bit, 4 -> 32-bit, 5 -> 64-bit + - Payload: `\n` +- Signed integers: + - First byte: 6 -> 8-bit, 7 -> 16-bit, 8 -> 32-bit, 9 -> 64-bit + - Payload: `\n` +- Simple collections: + - First byte: 10 -> binary, 11 -> string + - Payload: `\n` +- Complex collections: + - First byte: 11 -> list + - Payload: `\n` + +### Responses +The server can respond with any of the data types [above](#data-types-1), or it can respond with a special response type like these: + +- **Error**: Encoded as `0x10<16-bit error code>` +- **Row**: The server has returned a row. Encoded as `0x11\n` +- **Empty**: This indicates that the query ran successfully but nothing appropriate can be returned (like HTTP's 200 status). Encoded as `0x12` +- **Multirow**: The server has returned multiple rows. Encoded as `0x13\n` diff --git a/versioned_docs/version-0.8.0/protocol/3.errors.md b/versioned_docs/version-0.8.0/protocol/3.errors.md new file mode 100644 index 0000000000..cbfa32a340 --- /dev/null +++ b/versioned_docs/version-0.8.0/protocol/3.errors.md @@ -0,0 +1,58 @@ +--- +id: errors +title: Errors +--- + +If you've done something incorrectly, then the server will respond with an error code (just like HTTP status codes, but note that the server will not respond with an error code if no error occurred, unlike HTTP 200!). + +## Handshake errors + +These errors occur **before the connection is sucessfully established**. + +| Code | Meaning | Likely explanation | +| ---- | ------------------------------ | ------------------------------------------------------------------------------------------------------------------- | +| 0 | Illegal packet | Client library bug because it sent an incorrect handshake packet to the server | +| 1 | Incompatible handshake version | Server does not support handshake version used by client | +| 2 | Incompatible protocol version | Server does not support protocol version used by client | +| 3 | Incompatible exchange mode | Server does not support the chosen data exchange mode | +| 4 | Incompatible query mode | Server does not support the chosen query mode | +| 5 | Invalid authentication data | Either an incorrect username or password (or both) or the client library generated an illegal authentication header | + +## Query errors + +These errors can occur **when running a query**. + +| Category | Code | Meaning | Likely explanation | +| ------------ | ---- | ----------------------------------- | ---------------------------------------------------------------------------------------------------------------------------- | +| **System** | | | | +| | 0 | Server error | An error ocurred on the server side. Most likely a problem with I/O on the host | +| | 1 | OOM | The server is out of memory | +| | 2 | Unknown error | An unknown error occurred and the server did not provide any information on why | +| | 3 | Authentication error | Returned when a DCL query tries to do something invalid | +| | 4 | Transaction error | A transactional operation failed. Reasons could include an I/O error, too many retries, long running threshold timeout | +| | 5 | Permission denied | The query tried to do something that isn't allowed for the user | +| | 6 | Illegal client packet | The client sent a malformed query | +| **BlueQL** | | | | +| | 25 | Invalid input | Returned when a literal (or parameter) is incorrectly encoded. **This indicates a bug with the client library** | +| | 26 | Unexpected byte | Illegal character in the query | +| | 27 | Unexpected end of statement | Expected more tokens for the statement | +| | 28 | Invalid syntax | Invalid syntax used in the query | +| | 29 | Invalid collection syntax | A collection was not correctly formatted | +| | 30 | Invalid type definition | Invalid DDL type definition | +| | 31 | Expected entity name | An entity name was expected (such as a `model` name) but was not found | +| | 32 | Expected statement | A statement was expected but was not found | +| | 33 | Unknown statement | Attempted to execute unrecognized statement | +| **Database** | | | | +| | 100 | DDL object not found | The referenced DDL object (space or model or any other DDL object) was not found | +| | 101 | Unknown field | An unknown model field was referenced | +| | 102 | Invalid DDL properties | Invalid DDL properties were used | +| | 103 | DDL object already exists | Trying to create a duplicate DDL object returns this error | +| | 104 | DDL object not empty | A manipulation that requires the DDL object to be empty, was run on a nonempty DDL object | +| | 105 | DDL Illegal field declaration | The field declaration was not correct. Either because the type was invalid or because invalid properties were set. | +| | 106 | DDL illegal model definition | The model definition is incorrect | +| | 107 | DDL illegal `alter model` statement | The `alter model` statement (or any other related statement) is invalid (for example, trying to remove a primary key column) | +| | 108 | DML duplicate constraint violation | A row with the primary key already exists | +| | 109 | DML data validation error | Input data validation failed | +| | 110 | DML unindexed column | The column which was referenced as an index is not indexed | +| | 111 | DML row not found | The referenced row was not found | +| | 112 | DML needs lock | The operation needs a global lock | \ No newline at end of file diff --git a/versioned_docs/version-0.8.0/resources/1.overview.md b/versioned_docs/version-0.8.0/resources/1.overview.md new file mode 100644 index 0000000000..de4e09fce8 --- /dev/null +++ b/versioned_docs/version-0.8.0/resources/1.overview.md @@ -0,0 +1,24 @@ +--- +id: overview +title: Resources +--- + +## Community and chat + +- [**Discord Community**](https://discord.gg/QptWFdx): The community platform that we use the most is Discord. Both our developers and users hang out almost all day around here, so you can expect to get your query resolved fairly quickly. +- [**GitHub Discussions**](https://github.com/skytable/skytable/discussions): If you prefer a more forum like discussion, then please make use of GitHub Discussions. We're fairly responsive here as well. + +## News + +- [**Skytable Blog**](https://skytable.io/blog): This is where you'll hear from us about major updates such as new releases, changes in maintenance and such +- [**X/Twitter**](https://twitter.com/skytabledb): On X (formerly Twitter), we post live updates as we work on new features. If there's a quick update or milestone, you'll be the first to know here +- [**E-mail**](https://cdn.forms-content.sg-form.com/e4a9719e-d94e-11eb-89d2-9232e6ded8b5): While we haven't ever sent out any e-mails, if you're keen on signing up for updates in the (near) future, it's a good idea to subscribe to this list. Just like we said, we haven't yet sent out anything! We're building software, not sending you fancy email! + +## Examples + +- [**Jotsy (rust)**](https://github.com/ohsayan/jotsy): Jotsy is a very small "blog" implementation that is written in Rust with Skytable and the Axum framework. If you're building something in Rust, do check it out +- [**Client repo (rust)**](https://github.com/skytable/client-rust): While this is in Rust, you might find the examples useful regardless of which language you're developing your application in + +## Client drivers + +Please head over to the [libraries](/libraries) page. diff --git a/versioned_docs/version-0.8.0/resources/2.migration.md b/versioned_docs/version-0.8.0/resources/2.migration.md new file mode 100644 index 0000000000..7986704a37 --- /dev/null +++ b/versioned_docs/version-0.8.0/resources/2.migration.md @@ -0,0 +1,26 @@ +--- +id: migration +title: Migrating from an older release +--- + +Firstly, thank you patron! You're a part of an exclusive *club* which has seen Skytable take shape from *just another key-value* +store into a powerful database and we couldn't be more honored to be a choice in your stack. This document is meant for people +coming from version prior to Skytable Octave (0.8). + +Let's get you up to speed with the new semantics: + +- **Keyspaces are now spaces** +- **Tables are now models** and can store multiple fields +- **Nested lists are now supported** +- **All the actions are gone!** +- **There is no `default:default` keyspace and model**: You will need to create your own `space` and `model` + +## From actions to BlueQL + +- `SET x y` becomes: `INSERT INTO mymodel(x, ?)` +- `GET x` becomes `SELECT * FROM mymodel WHERE = x` +- `UPDATE x y` becomes `UPDATE mymodel SET field_name = ? WHERE = x` +- `DEL X` becomes `DELETE FROM mymodel WHERE = x` + +Essentially, you no longer have the key/value semantics but a more SQL-like interface for querying with BlueQL. You can continue +to use lists (create, update) but individual element access is currently limited. See [this page for more information](/limits). diff --git a/versioned_docs/version-0.8.0/system/1.configuration.md b/versioned_docs/version-0.8.0/system/1.configuration.md new file mode 100644 index 0000000000..b921b2a087 --- /dev/null +++ b/versioned_docs/version-0.8.0/system/1.configuration.md @@ -0,0 +1,97 @@ +--- +id: configuration +title: Configuration +--- + +Skytable can be configured to run per your needs. You can use either of command-line arguments, environment variables or a +configuration file. We don't have any specific recommendation for a mode of configuration but we generally consider using a +configuration file to be the best practice since it is something that won't get lost (which in other cases can get lost due +to lost shell history and such). + +## Configuration file + +The configuration file is a simple YAML file. Use this as your configuration file template: + +```yaml +system: + mode: prod + rs_window: 300 + +auth: + plugin: pwd + # replace with your root password of choice + root_pass: password + +endpoints: + secure: + host: 127.0.0.1 + port: 2004 + # replace `cert` with the path to your self-signed certificate + cert: cert.pem + # replace `private_key` with the path to your private key + private_key: private.key + # replace `passphrase.txt` with the path to your private key passphrase + pkey_passphrase: passphrase.txt + insecure: + host: 127.0.0.1 + port: 2003 +``` + +:::info Starting the server with a configuration file +To start the server with a configuration file, simply run `skyd --config .yaml` +::: + +Here's an explanation of all the keys: +- `system`: + - `mode`: set to either `dev` / `prod` mode. `prod` mode will generally make some things stricters (such as background services) + - `rs_window`: **This is a very important setting!** It is set to `300` by default and is called the "reliability service window" which ensures that if any changes are observed in `300` (or whatever value you set) seconds, then they reach the disk + as soon as that time elapses. For example, in the default configuration the system checks for changes every 5 minutes and if there are any dataset changes, they are immediately synced +- `auth`: + - `plugin`: this is the authentication plugin. we currently only have `pwd` that is a simple password based authentication system where the password is stored as an [`rcrypt` hash](https://github.com/ohsayan/rcrypt) on disk. More `plugin` options are set to be implemented for more advanced authentication, especially in enterprise settings + - `root_pass`: this is the root account password. **It must have atleast 16 characters** +- `endpoints`: + - `secure`: + - `host`: the host for your secure (TLS) endpoint + - `port`: the port for your secure (TLS) endpoint + - `cert`: path to the PEM certificate to use for TLS + - `private_key`: path to the PEM private key to use for TLS + - `pkey_passphrase`: all private keys must be secured with a passphrase; this key should be set to **the path of a plaintext file containing your passphrase** and **not the passphrase itself** + - `insecure`: + - `host`: the host for your TCP endpoint + - `port`: the port for your TCP endpoint + +## Command-line arguments + +You can use the following command line arguments: + +| Category | Argument | Example | Meaning | +| ------------- | ---------------------- | ------------------------------- | ------------------------------------------------------------------------------ | +| | `--config` | `--config=config.yaml` | Path to the configuration file. | +| **System** | | | | +| | `--service-window` | `--service-window=300` | Set the reliability service window (see above) | +| | `--mode` | `--mode=prod` | Set `dev` or `prod` mode | +| **Auth** | | | | +| | `--auth-plugin` | `--auth-plugin=pwd` | Sets the authentication plugin (see above) | +| | `--auth-root-password` | `--auth-root-password=mypass` | Sets the root account password (see above) | +| **Endpoints** | | | | +| | `--endpoint` | `--endpoint=tcp@localhost:2003` | Repeat this for all your endpoints such as `tls@host:port` and `tcp@host:port` | +| | `--tlscert` | `--tlscert=cert.pem` | Path to TLS cert | +| | `--tlskey` | `--tlskey=private.key` | Path to TLS private key | +| | `--tls-passphrase` | `--tls-passphrase=pass.txt` | Path to plaintext file containing TLS private key password | + +## Environment variables + +You can use the following environment variables: + +| Category | Variable | Example | Meaning | +| ------------- | -------------------------- | ------------------------------------------------- | --------------------------------------------------------------------------- | +| **System** | | | | +| | `SKYDB_SERVICE_WINDOW` | `SKYDB_SERVICE_WINDOW=300` | Sets the reliability service window (see above) | +| **Auth** | | | | +| | `SKYDB_AUTH_PLUGIN` | `SKYDB_AUTH_PLUGIN=pwd` | Sets the authentication plugin | +| | `SKYDB_AUTH_ROOT_PASSWORD` | `SKYDB_AUTH_ROOT_PASSWORD=mypass` | Sets the root account password | +| **Endpoints** | | | | +| | `SKYDB_ENDPOINTS` | `SKYDB_ENDPOINTS=tcp@myhost:2003,tls@myhost:2004` | Sets the endpoints to use | +| | `SKYDB_TLS_CERT` | `SKYDB_TLS_CERT=cert.pem` | Sets the path to the TLS cert | +| | `SKYDB_TLS_KEY` | `SKYDB_TLS_KEY=private.key` | Sets the path to the TLS private key | +| | `SKYDB_TLS_KEY_PASS` | `SKYDB_TLS_KEY_PASS=pass.txt` | Sets the path to the plaintext file containing the TLS private key password | diff --git a/versioned_docs/version-0.8.0/system/2.administration.md b/versioned_docs/version-0.8.0/system/2.administration.md new file mode 100644 index 0000000000..14490de1c9 --- /dev/null +++ b/versioned_docs/version-0.8.0/system/2.administration.md @@ -0,0 +1,69 @@ +--- +id: administration +title: Administration +--- + +Skytable's access control is very simple: +- there is only one `root` account +- there are zero or more standard users + +## Types of users + +### Root users + +As noted earlier there can be only one `root` account and this is primarily for security concerns. We however do plan to support +creating multiple users (the implementation isn't hard but security is key). + +#### Exclusive rights + +Root users have exclusive rights to use plus everything that standard users have access to: +- `CREATE` +- `ALTER` +- `DROP` +- `SYSCTL CREATE` +- `SYSCTL DROP` + +#### Resetting the root password + +We strongly recommend that you keep the root password in someplace safe, but if you happen to lose it — just like many other +databases, you will first need to stop the server to reset it. Once you have stopped the server, you will need to modify the root +password that you set in your [configuration source](configuration) (such as CLI/ENV/configuration file). You will then +need to restart the server. The server will issue a warning in the logs that the root password has changed but since that is +what you intended, you can safely ignore it. + +### Standard users + +You can have any number of standard users. Standard users can essentially manipulate data but can't modify the objects that store them. + +#### Changing account passwords + +To change the password for a given account, you can follow the [instructions on BlueQL's DCL guide here](/blueql/dcl#sysctl-alter-user). + +#### Rights + +Standard users can access the following query types: +- `SYSCTL REPORT STATUS` +- `INSERT` +- `SELECT` +- `UPDATE` +- `DELETE` +- `INSPECT` + +### Global management + +The single DDL query that lets you do a "sneak peek" into the status of the entire system is the `INSPECT GLOBAL` query. It +returns a JSON string like this: +```json +{ + "spaces:"["space1", "space2"], + "users":["root", "staging_server"], + "settings:{}, +} +``` + +- `spaces`: lists all the spaces in the system +- `users`: lists all users + :::info Access control note + This is only returned if you are the `root` user. Standard users cannot see the other users in the system + ::: +- `settings`: returns system settings (currently an empty dictionary is returned) diff --git a/versioned_sidebars/version-0.8.0-sidebars.json b/versioned_sidebars/version-0.8.0-sidebars.json new file mode 100644 index 0000000000..1a21b0a63e --- /dev/null +++ b/versioned_sidebars/version-0.8.0-sidebars.json @@ -0,0 +1,60 @@ +{ + "docs": [ + "index", + "installation", + "using-the-repl", + "architecture", + { + "type": "category", + "label": "BlueQL", + "items": [ + "blueql/overview", + "blueql/ddl", + "blueql/dml", + "blueql/dcl" + ], + "collapsible": false, + "link": { + "type": "generated-index", + "title": "BlueQL", + "description": "In this section we take a look at the syntax and structure of BlueQL, how it is different from SQL, and then proceed to understand different queries. We go from DDL queries which enables you to create spaces and models to DML queries like INSERT and SELECT that enable you to do perform CRUD operations on the database and finally take a look at DCL that enables you to control the access of data and perform administrative tasks. We recommend that you carefully read through this section to get a strong understanding of BlueQL and how it is different." + } + }, + { + "type": "category", + "label": "System Management", + "items": [ + "system/configuration", + "system/administration" + ], + "collapsible": false, + "link": { + "type": "generated-index", + "title": "System Management", + "description": "Learn how to configure Skytable for your needs and perform administrative tasks. We take a look at the different modes of configuration (CLI, ENV, configuration files), settings, access control, managing the root account and global management." + } + }, + "libraries", + { + "type": "category", + "label": "Resources", + "items": [ + "resources/overview", + "resources/migration" + ], + "collapsed": false + }, + { + "type": "category", + "label": "Protocol", + "items": [ + "protocol/overview", + "protocol/networking", + "protocol/errors" + ] + }, + "benchmarking", + "deployment", + "limits" + ] +} diff --git a/versions.json b/versions.json index 9ab36d9b7c..87ff77e914 100644 --- a/versions.json +++ b/versions.json @@ -1 +1,5 @@ -["0.7.5", "0.7.4"] +[ + "0.8.0", + "0.7.5", + "0.7.4" +] diff --git a/yarn.lock b/yarn.lock index b7b51a50bf..8dec8bfc9e 100644 --- a/yarn.lock +++ b/yarn.lock @@ -399,7 +399,7 @@ chalk "^2.4.2" js-tokens "^4.0.0" -"@babel/parser@^7.22.7", "@babel/parser@^7.24.0": +"@babel/parser@^7.24.0": version "7.24.0" resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.24.0.tgz#26a3d1ff49031c53a97d03b604375f028746a9ac" integrity sha512-QuP/FxEAzMSjXygs8v4N9dvdXzEHN4W1oF3PxuWAtPo08UdM17u89RDMgjLn/mlc56iM0HlLmVkO/wgR+rDgHg== @@ -1221,10 +1221,10 @@ "@docsearch/css" "3.6.0" algoliasearch "^4.19.1" -"@docusaurus/core@3.1.1", "@docusaurus/core@^3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/core/-/core-3.1.1.tgz#29ce8df7a3d3d12ee8962d6d86133b87235ff17b" - integrity sha512-2nQfKFcf+MLEM7JXsXwQxPOmQAR6ytKMZVSx7tVi9HEm9WtfwBH1fp6bn8Gj4zLUhjWKCLoysQ9/Wm+EZCQ4yQ== +"@docusaurus/core@3.2.0", "@docusaurus/core@^3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/core/-/core-3.2.0.tgz#10acb993fb76960890d1aa43025245aaa8dcdbbb" + integrity sha512-WTO6vW4404nhTmK9NL+95nd13I1JveFwZ8iOBYxb4xt+N2S3KzY+mm+1YtWw2vV37FbYfH+w+KrlrRaWuy5Hzw== dependencies: "@babel/core" "^7.23.3" "@babel/generator" "^7.23.3" @@ -1236,14 +1236,13 @@ "@babel/runtime" "^7.22.6" "@babel/runtime-corejs3" "^7.22.6" "@babel/traverse" "^7.22.8" - "@docusaurus/cssnano-preset" "3.1.1" - "@docusaurus/logger" "3.1.1" - "@docusaurus/mdx-loader" "3.1.1" + "@docusaurus/cssnano-preset" "3.2.0" + "@docusaurus/logger" "3.2.0" + "@docusaurus/mdx-loader" "3.2.0" "@docusaurus/react-loadable" "5.5.2" - "@docusaurus/utils" "3.1.1" - "@docusaurus/utils-common" "3.1.1" - "@docusaurus/utils-validation" "3.1.1" - "@slorber/static-site-generator-webpack-plugin" "^4.0.7" + "@docusaurus/utils" "3.2.0" + "@docusaurus/utils-common" "3.2.0" + "@docusaurus/utils-validation" "3.2.0" "@svgr/webpack" "^6.5.1" autoprefixer "^10.4.14" babel-loader "^9.1.3" @@ -1264,6 +1263,7 @@ detect-port "^1.5.1" escape-html "^1.0.3" eta "^2.2.0" + eval "^0.1.8" file-loader "^6.2.0" fs-extra "^11.1.1" html-minifier-terser "^7.2.0" @@ -1272,6 +1272,7 @@ leven "^3.1.0" lodash "^4.17.21" mini-css-extract-plugin "^2.7.6" + p-map "^4.0.0" postcss "^8.4.26" postcss-loader "^7.3.3" prompts "^2.4.2" @@ -1296,34 +1297,32 @@ webpack-merge "^5.9.0" webpackbar "^5.0.2" -"@docusaurus/cssnano-preset@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/cssnano-preset/-/cssnano-preset-3.1.1.tgz#03a4cb8e6d41654d7ff5ed79fddd73fd224feea4" - integrity sha512-LnoIDjJWbirdbVZDMq+4hwmrTl2yHDnBf9MLG9qyExeAE3ac35s4yUhJI8yyTCdixzNfKit4cbXblzzqMu4+8g== +"@docusaurus/cssnano-preset@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/cssnano-preset/-/cssnano-preset-3.2.0.tgz#0e0fbf19873a726f92e670b9d511e9f2828d6097" + integrity sha512-H88RXGUia7r/VF3XfyoA4kbwgpUZcKsObF6VvwBOP91EdArTf6lnHbJ/x8Ca79KS/zf98qaWyBGzW+5ez58Iyw== dependencies: cssnano-preset-advanced "^5.3.10" postcss "^8.4.26" postcss-sort-media-queries "^4.4.1" tslib "^2.6.0" -"@docusaurus/logger@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/logger/-/logger-3.1.1.tgz#423e8270c00a57b1b3a0cc8a3ee0a4c522a68387" - integrity sha512-BjkNDpQzewcTnST8trx4idSoAla6zZ3w22NqM/UMcFtvYJgmoE4layuTzlfql3VFPNuivvj7BOExa/+21y4X2Q== +"@docusaurus/logger@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/logger/-/logger-3.2.0.tgz#99d2b09478bcba69c964ec0c8600d855fb8e9e0f" + integrity sha512-Z1R1NcOGXZ8CkIJSvjvyxnuDDSlx/+1xlh20iVTw1DZRjonFmI3T3tTgk40YpXyWUYQpIgAoqqPMpuseMMdgRQ== dependencies: chalk "^4.1.2" tslib "^2.6.0" -"@docusaurus/mdx-loader@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/mdx-loader/-/mdx-loader-3.1.1.tgz#f79290abc5044bef1d7ecac4eccec887058b8e03" - integrity sha512-xN2IccH9+sv7TmxwsDJNS97BHdmlqWwho+kIVY4tcCXkp+k4QuzvWBeunIMzeayY4Fu13A6sAjHGv5qm72KyGA== +"@docusaurus/mdx-loader@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/mdx-loader/-/mdx-loader-3.2.0.tgz#d17f17ae1bb38255643c82705dda719b23c27831" + integrity sha512-JtkI5o6R/rJSr1Y23cHKz085aBJCvJw3AYHihJ7r+mBX+O8EuQIynG0e6/XpbSCpr7Ino0U50UtxaXcEbFwg9Q== dependencies: - "@babel/parser" "^7.22.7" - "@babel/traverse" "^7.22.8" - "@docusaurus/logger" "3.1.1" - "@docusaurus/utils" "3.1.1" - "@docusaurus/utils-validation" "3.1.1" + "@docusaurus/logger" "3.2.0" + "@docusaurus/utils" "3.2.0" + "@docusaurus/utils-validation" "3.2.0" "@mdx-js/mdx" "^3.0.0" "@slorber/remark-comment" "^1.0.0" escape-html "^1.0.3" @@ -1346,13 +1345,13 @@ vfile "^6.0.1" webpack "^5.88.1" -"@docusaurus/module-type-aliases@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/module-type-aliases/-/module-type-aliases-3.1.1.tgz#b304402b0535a13ebd4c0db1c368d2604d54d02f" - integrity sha512-xBJyx0TMfAfVZ9ZeIOb1awdXgR4YJMocIEzTps91rq+hJDFJgJaylDtmoRhUxkwuYmNK1GJpW95b7DLztSBJ3A== +"@docusaurus/module-type-aliases@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/module-type-aliases/-/module-type-aliases-3.2.0.tgz#ef883d8418f37e551eca72adc409014e720786d4" + integrity sha512-jRSp9YkvBwwNz6Xgy0RJPsnie+Ebb//gy7GdbkJ2pW2gvvlYKGib2+jSF0pfIzvyZLulfCynS1KQdvDKdSl8zQ== dependencies: "@docusaurus/react-loadable" "5.5.2" - "@docusaurus/types" "3.1.1" + "@docusaurus/types" "3.2.0" "@types/history" "^4.7.11" "@types/react" "*" "@types/react-router-config" "*" @@ -1360,33 +1359,33 @@ react-helmet-async "*" react-loadable "npm:@docusaurus/react-loadable@5.5.2" -"@docusaurus/plugin-client-redirects@^3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/plugin-client-redirects/-/plugin-client-redirects-3.1.1.tgz#73feb15c2f3fe292d618f8a81e5194142f982ddb" - integrity sha512-J/1Z75XkO+BmUXHW17FrCIYZQ3b0IKaJECH6yCxW5RQ8NMMJ+SZCtPtx5oYoAd0VHersNiUu+ZAxfOqbsn1jKQ== - dependencies: - "@docusaurus/core" "3.1.1" - "@docusaurus/logger" "3.1.1" - "@docusaurus/utils" "3.1.1" - "@docusaurus/utils-common" "3.1.1" - "@docusaurus/utils-validation" "3.1.1" +"@docusaurus/plugin-client-redirects@^3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/plugin-client-redirects/-/plugin-client-redirects-3.2.0.tgz#4c98c185620ce10830e1cc8a7f16a807857cb654" + integrity sha512-re5bgvYOgBHmevlI8HO3fZHL7mvX2lAULr4E89n/bQ5kgekLLhsaerWrAah22ZluMZyJC2439EGjR63E9Ba6KA== + dependencies: + "@docusaurus/core" "3.2.0" + "@docusaurus/logger" "3.2.0" + "@docusaurus/utils" "3.2.0" + "@docusaurus/utils-common" "3.2.0" + "@docusaurus/utils-validation" "3.2.0" eta "^2.2.0" fs-extra "^11.1.1" lodash "^4.17.21" tslib "^2.6.0" -"@docusaurus/plugin-content-blog@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/plugin-content-blog/-/plugin-content-blog-3.1.1.tgz#16f4fd723227b2158461bba6b9bcc18c1926f7ea" - integrity sha512-ew/3VtVoG3emoAKmoZl7oKe1zdFOsI0NbcHS26kIxt2Z8vcXKCUgK9jJJrz0TbOipyETPhqwq4nbitrY3baibg== - dependencies: - "@docusaurus/core" "3.1.1" - "@docusaurus/logger" "3.1.1" - "@docusaurus/mdx-loader" "3.1.1" - "@docusaurus/types" "3.1.1" - "@docusaurus/utils" "3.1.1" - "@docusaurus/utils-common" "3.1.1" - "@docusaurus/utils-validation" "3.1.1" +"@docusaurus/plugin-content-blog@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/plugin-content-blog/-/plugin-content-blog-3.2.0.tgz#b7b43e71634272a80a9532dc166731332391cb4b" + integrity sha512-MABqwjSicyHmYEfQueMthPCz18JkVxhK3EGhXTSRWwReAZ0UTuw9pG6+Wo+uXAugDaIcJH28rVZSwTDINPm2bw== + dependencies: + "@docusaurus/core" "3.2.0" + "@docusaurus/logger" "3.2.0" + "@docusaurus/mdx-loader" "3.2.0" + "@docusaurus/types" "3.2.0" + "@docusaurus/utils" "3.2.0" + "@docusaurus/utils-common" "3.2.0" + "@docusaurus/utils-validation" "3.2.0" cheerio "^1.0.0-rc.12" feed "^4.2.2" fs-extra "^11.1.1" @@ -1398,18 +1397,19 @@ utility-types "^3.10.0" webpack "^5.88.1" -"@docusaurus/plugin-content-docs@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/plugin-content-docs/-/plugin-content-docs-3.1.1.tgz#f2eddebf351dd8dd504a2c26061165c519e1f964" - integrity sha512-lhFq4E874zw0UOH7ujzxnCayOyAt0f9YPVYSb9ohxrdCM8B4szxitUw9rIX4V9JLLHVoqIJb6k+lJJ1jrcGJ0A== - dependencies: - "@docusaurus/core" "3.1.1" - "@docusaurus/logger" "3.1.1" - "@docusaurus/mdx-loader" "3.1.1" - "@docusaurus/module-type-aliases" "3.1.1" - "@docusaurus/types" "3.1.1" - "@docusaurus/utils" "3.1.1" - "@docusaurus/utils-validation" "3.1.1" +"@docusaurus/plugin-content-docs@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/plugin-content-docs/-/plugin-content-docs-3.2.0.tgz#6e4f727a0cce301b9d9361bf41ca6a978fe79475" + integrity sha512-uuqhahmsBnirxOz+SXksnWt7+wc+iN4ntxNRH48BUgo7QRNLATWjHCgI8t6zrMJxK4o+QL9DhLaPDlFHs91B3Q== + dependencies: + "@docusaurus/core" "3.2.0" + "@docusaurus/logger" "3.2.0" + "@docusaurus/mdx-loader" "3.2.0" + "@docusaurus/module-type-aliases" "3.2.0" + "@docusaurus/types" "3.2.0" + "@docusaurus/utils" "3.2.0" + "@docusaurus/utils-common" "3.2.0" + "@docusaurus/utils-validation" "3.2.0" "@types/react-router-config" "^5.0.7" combine-promises "^1.1.0" fs-extra "^11.1.1" @@ -1419,96 +1419,96 @@ utility-types "^3.10.0" webpack "^5.88.1" -"@docusaurus/plugin-content-pages@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/plugin-content-pages/-/plugin-content-pages-3.1.1.tgz#05aec68c2abeac2140c7a16d4c5b506bf4d19fb2" - integrity sha512-NQHncNRAJbyLtgTim9GlEnNYsFhuCxaCNkMwikuxLTiGIPH7r/jpb7O3f3jUMYMebZZZrDq5S7om9a6rvB/YCA== - dependencies: - "@docusaurus/core" "3.1.1" - "@docusaurus/mdx-loader" "3.1.1" - "@docusaurus/types" "3.1.1" - "@docusaurus/utils" "3.1.1" - "@docusaurus/utils-validation" "3.1.1" +"@docusaurus/plugin-content-pages@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/plugin-content-pages/-/plugin-content-pages-3.2.0.tgz#df28a6ee6b52c4b292a726f29f39b119756caf44" + integrity sha512-4ofAN7JDsdb4tODO9OIrizWY5DmEJXr0eu+UDIkLqGP+gXXTahJZv8h2mlxO+lPXGXRCVBOfA14OG1hOYJVPwA== + dependencies: + "@docusaurus/core" "3.2.0" + "@docusaurus/mdx-loader" "3.2.0" + "@docusaurus/types" "3.2.0" + "@docusaurus/utils" "3.2.0" + "@docusaurus/utils-validation" "3.2.0" fs-extra "^11.1.1" tslib "^2.6.0" webpack "^5.88.1" -"@docusaurus/plugin-debug@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/plugin-debug/-/plugin-debug-3.1.1.tgz#cee5aae1fef288fb93f68894db79a2612e313d3f" - integrity sha512-xWeMkueM9wE/8LVvl4+Qf1WqwXmreMjI5Kgr7GYCDoJ8zu4kD+KaMhrh7py7MNM38IFvU1RfrGKacCEe2DRRfQ== +"@docusaurus/plugin-debug@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/plugin-debug/-/plugin-debug-3.2.0.tgz#643d13d403685c2b9bdb3b65bec8050847b920a3" + integrity sha512-p6WxtO5XZGz66y6QNQtCJwBefq4S6/w75XaXVvH1/2P9uaijvF7R+Cm2EWQZ5WsvA5wl//DFWblyDHRyVC207Q== dependencies: - "@docusaurus/core" "3.1.1" - "@docusaurus/types" "3.1.1" - "@docusaurus/utils" "3.1.1" + "@docusaurus/core" "3.2.0" + "@docusaurus/types" "3.2.0" + "@docusaurus/utils" "3.2.0" fs-extra "^11.1.1" react-json-view-lite "^1.2.0" tslib "^2.6.0" -"@docusaurus/plugin-google-analytics@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/plugin-google-analytics/-/plugin-google-analytics-3.1.1.tgz#bfc58205b4fcaf3222e04f9c3542f3bef9804887" - integrity sha512-+q2UpWTqVi8GdlLoSlD5bS/YpxW+QMoBwrPrUH/NpvpuOi0Of7MTotsQf9JWd3hymZxl2uu1o3PIrbpxfeDFDQ== +"@docusaurus/plugin-google-analytics@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/plugin-google-analytics/-/plugin-google-analytics-3.2.0.tgz#770151947c0ee49500586e9200631852ab97e23a" + integrity sha512-//TepJTEyAZSvBwHKEbXHu9xT/VkK3wUil2ZakKvQZYfUC01uWn6A1E3toa8R7WhCy1xPUeIukqmJy1Clg8njQ== dependencies: - "@docusaurus/core" "3.1.1" - "@docusaurus/types" "3.1.1" - "@docusaurus/utils-validation" "3.1.1" + "@docusaurus/core" "3.2.0" + "@docusaurus/types" "3.2.0" + "@docusaurus/utils-validation" "3.2.0" tslib "^2.6.0" -"@docusaurus/plugin-google-gtag@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/plugin-google-gtag/-/plugin-google-gtag-3.1.1.tgz#7e8b5aa6847a12461c104a65a335f4a45dae2f28" - integrity sha512-0mMPiBBlQ5LFHTtjxuvt/6yzh8v7OxLi3CbeEsxXZpUzcKO/GC7UA1VOWUoBeQzQL508J12HTAlR3IBU9OofSw== +"@docusaurus/plugin-google-gtag@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/plugin-google-gtag/-/plugin-google-gtag-3.2.0.tgz#65fc7ddc242185c3a10e60308471564075229406" + integrity sha512-3s6zxlaMMb87MW2Rxy6EnSRDs0WDEQPuHilZZH402C8kOrUnIwlhlfjWZ4ZyLDziGl/Eec/DvD0PVqj0qHRomA== dependencies: - "@docusaurus/core" "3.1.1" - "@docusaurus/types" "3.1.1" - "@docusaurus/utils-validation" "3.1.1" + "@docusaurus/core" "3.2.0" + "@docusaurus/types" "3.2.0" + "@docusaurus/utils-validation" "3.2.0" "@types/gtag.js" "^0.0.12" tslib "^2.6.0" -"@docusaurus/plugin-google-tag-manager@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/plugin-google-tag-manager/-/plugin-google-tag-manager-3.1.1.tgz#e1aae4d821e786d133386b4ae6e6fe66a4bc0089" - integrity sha512-d07bsrMLdDIryDtY17DgqYUbjkswZQr8cLWl4tzXrt5OR/T/zxC1SYKajzB3fd87zTu5W5klV5GmUwcNSMXQXA== +"@docusaurus/plugin-google-tag-manager@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/plugin-google-tag-manager/-/plugin-google-tag-manager-3.2.0.tgz#730c28a43ff5073f595509c6cb77ce4311a2e369" + integrity sha512-rAKtsJ11vPHA7dTAqWCgyIy7AyFRF/lpI77Zd/4HKgqcIvIayVBvL3QtelhUazfYTLTH6ls6kQ9wjMcIFxRiGg== dependencies: - "@docusaurus/core" "3.1.1" - "@docusaurus/types" "3.1.1" - "@docusaurus/utils-validation" "3.1.1" + "@docusaurus/core" "3.2.0" + "@docusaurus/types" "3.2.0" + "@docusaurus/utils-validation" "3.2.0" tslib "^2.6.0" -"@docusaurus/plugin-sitemap@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/plugin-sitemap/-/plugin-sitemap-3.1.1.tgz#8828bf5e2922273aad207a35189f22913e6a0dfd" - integrity sha512-iJ4hCaMmDaUqRv131XJdt/C/jJQx8UreDWTRqZKtNydvZVh/o4yXGRRFOplea1D9b/zpwL1Y+ZDwX7xMhIOTmg== - dependencies: - "@docusaurus/core" "3.1.1" - "@docusaurus/logger" "3.1.1" - "@docusaurus/types" "3.1.1" - "@docusaurus/utils" "3.1.1" - "@docusaurus/utils-common" "3.1.1" - "@docusaurus/utils-validation" "3.1.1" +"@docusaurus/plugin-sitemap@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/plugin-sitemap/-/plugin-sitemap-3.2.0.tgz#cae7c92a8631072fff39dd5caf5ea7608c795540" + integrity sha512-gnWDFt6MStjLkdtt63Lzc+14EPSd8B6mzJGJp9GQMvWDUoMAUijUqpVIHYQq+DPMcI4PJZ5I2nsl5XFf1vOldA== + dependencies: + "@docusaurus/core" "3.2.0" + "@docusaurus/logger" "3.2.0" + "@docusaurus/types" "3.2.0" + "@docusaurus/utils" "3.2.0" + "@docusaurus/utils-common" "3.2.0" + "@docusaurus/utils-validation" "3.2.0" fs-extra "^11.1.1" sitemap "^7.1.1" tslib "^2.6.0" -"@docusaurus/preset-classic@^3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/preset-classic/-/preset-classic-3.1.1.tgz#15fd80012529dafd7e01cc0bce59d39ee6ad6bf5" - integrity sha512-jG4ys/hWYf69iaN/xOmF+3kjs4Nnz1Ay3CjFLDtYa8KdxbmUhArA9HmP26ru5N0wbVWhY+6kmpYhTJpez5wTyg== - dependencies: - "@docusaurus/core" "3.1.1" - "@docusaurus/plugin-content-blog" "3.1.1" - "@docusaurus/plugin-content-docs" "3.1.1" - "@docusaurus/plugin-content-pages" "3.1.1" - "@docusaurus/plugin-debug" "3.1.1" - "@docusaurus/plugin-google-analytics" "3.1.1" - "@docusaurus/plugin-google-gtag" "3.1.1" - "@docusaurus/plugin-google-tag-manager" "3.1.1" - "@docusaurus/plugin-sitemap" "3.1.1" - "@docusaurus/theme-classic" "3.1.1" - "@docusaurus/theme-common" "3.1.1" - "@docusaurus/theme-search-algolia" "3.1.1" - "@docusaurus/types" "3.1.1" +"@docusaurus/preset-classic@^3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/preset-classic/-/preset-classic-3.2.0.tgz#f64d970eace76c61e4f1b4b7d85d9f69d4a2dd0e" + integrity sha512-t7tXyk8kUgT7hUqEOgSJnPs+Foem9ucuan/a9QVYaVFCDjp92Sb2FpCY8bVasAokYCjodYe2LfpAoSCj5YDYWg== + dependencies: + "@docusaurus/core" "3.2.0" + "@docusaurus/plugin-content-blog" "3.2.0" + "@docusaurus/plugin-content-docs" "3.2.0" + "@docusaurus/plugin-content-pages" "3.2.0" + "@docusaurus/plugin-debug" "3.2.0" + "@docusaurus/plugin-google-analytics" "3.2.0" + "@docusaurus/plugin-google-gtag" "3.2.0" + "@docusaurus/plugin-google-tag-manager" "3.2.0" + "@docusaurus/plugin-sitemap" "3.2.0" + "@docusaurus/theme-classic" "3.2.0" + "@docusaurus/theme-common" "3.2.0" + "@docusaurus/theme-search-algolia" "3.2.0" + "@docusaurus/types" "3.2.0" "@docusaurus/react-loadable@5.5.2", "react-loadable@npm:@docusaurus/react-loadable@5.5.2": version "5.5.2" @@ -1518,23 +1518,23 @@ "@types/react" "*" prop-types "^15.6.2" -"@docusaurus/theme-classic@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/theme-classic/-/theme-classic-3.1.1.tgz#0a188c787fc4bf2bb525cc30c7aa34e555ee96b8" - integrity sha512-GiPE/jbWM8Qv1A14lk6s9fhc0LhPEQ00eIczRO4QL2nAQJZXkjPG6zaVx+1cZxPFWbAsqSjKe2lqkwF3fGkQ7Q== - dependencies: - "@docusaurus/core" "3.1.1" - "@docusaurus/mdx-loader" "3.1.1" - "@docusaurus/module-type-aliases" "3.1.1" - "@docusaurus/plugin-content-blog" "3.1.1" - "@docusaurus/plugin-content-docs" "3.1.1" - "@docusaurus/plugin-content-pages" "3.1.1" - "@docusaurus/theme-common" "3.1.1" - "@docusaurus/theme-translations" "3.1.1" - "@docusaurus/types" "3.1.1" - "@docusaurus/utils" "3.1.1" - "@docusaurus/utils-common" "3.1.1" - "@docusaurus/utils-validation" "3.1.1" +"@docusaurus/theme-classic@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/theme-classic/-/theme-classic-3.2.0.tgz#4aa229f1a4b1b4c138a5c80089f1d8146f56252c" + integrity sha512-4oSO5BQOJ5ja7WYdL6jK1n4J96tp+VJHamdwao6Ea252sA3W3vvR0otTflG4p4XVjNZH6hlPQoi5lKW0HeRgfQ== + dependencies: + "@docusaurus/core" "3.2.0" + "@docusaurus/mdx-loader" "3.2.0" + "@docusaurus/module-type-aliases" "3.2.0" + "@docusaurus/plugin-content-blog" "3.2.0" + "@docusaurus/plugin-content-docs" "3.2.0" + "@docusaurus/plugin-content-pages" "3.2.0" + "@docusaurus/theme-common" "3.2.0" + "@docusaurus/theme-translations" "3.2.0" + "@docusaurus/types" "3.2.0" + "@docusaurus/utils" "3.2.0" + "@docusaurus/utils-common" "3.2.0" + "@docusaurus/utils-validation" "3.2.0" "@mdx-js/react" "^3.0.0" clsx "^2.0.0" copy-text-to-clipboard "^3.2.0" @@ -1549,18 +1549,18 @@ tslib "^2.6.0" utility-types "^3.10.0" -"@docusaurus/theme-common@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/theme-common/-/theme-common-3.1.1.tgz#5a16893928b8379c9e83aef01d753e7e142459e2" - integrity sha512-38urZfeMhN70YaXkwIGXmcUcv2CEYK/2l4b05GkJPrbEbgpsIZM3Xc+Js2ehBGGZmfZq8GjjQ5RNQYG+MYzCYg== - dependencies: - "@docusaurus/mdx-loader" "3.1.1" - "@docusaurus/module-type-aliases" "3.1.1" - "@docusaurus/plugin-content-blog" "3.1.1" - "@docusaurus/plugin-content-docs" "3.1.1" - "@docusaurus/plugin-content-pages" "3.1.1" - "@docusaurus/utils" "3.1.1" - "@docusaurus/utils-common" "3.1.1" +"@docusaurus/theme-common@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/theme-common/-/theme-common-3.2.0.tgz#67f5f1a1e265e1f1a5b9fa7bfb4bf7b98dfcf981" + integrity sha512-sFbw9XviNJJ+760kAcZCQMQ3jkNIznGqa6MQ70E5BnbP+ja36kGgPOfjcsvAcNey1H1Rkhh3p2Mhf4HVLdKVVw== + dependencies: + "@docusaurus/mdx-loader" "3.2.0" + "@docusaurus/module-type-aliases" "3.2.0" + "@docusaurus/plugin-content-blog" "3.2.0" + "@docusaurus/plugin-content-docs" "3.2.0" + "@docusaurus/plugin-content-pages" "3.2.0" + "@docusaurus/utils" "3.2.0" + "@docusaurus/utils-common" "3.2.0" "@types/history" "^4.7.11" "@types/react" "*" "@types/react-router-config" "*" @@ -1570,19 +1570,19 @@ tslib "^2.6.0" utility-types "^3.10.0" -"@docusaurus/theme-search-algolia@3.1.1", "@docusaurus/theme-search-algolia@^3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/theme-search-algolia/-/theme-search-algolia-3.1.1.tgz#5170cd68cc59d150416b070bdc6d15c363ddf5e1" - integrity sha512-tBH9VY5EpRctVdaAhT+b1BY8y5dyHVZGFXyCHgTrvcXQy5CV4q7serEX7U3SveNT9zksmchPyct6i1sFDC4Z5g== +"@docusaurus/theme-search-algolia@3.2.0", "@docusaurus/theme-search-algolia@^3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/theme-search-algolia/-/theme-search-algolia-3.2.0.tgz#05338b37753dd13899fb0296f2c57130e9893dbf" + integrity sha512-PgvF4qHoqJp8+GfqClUbTF/zYNOsz4De251IuzXon7+7FAXwvb2qmYtA2nEwyMbB7faKOz33Pxzv+y+153KS/g== dependencies: "@docsearch/react" "^3.5.2" - "@docusaurus/core" "3.1.1" - "@docusaurus/logger" "3.1.1" - "@docusaurus/plugin-content-docs" "3.1.1" - "@docusaurus/theme-common" "3.1.1" - "@docusaurus/theme-translations" "3.1.1" - "@docusaurus/utils" "3.1.1" - "@docusaurus/utils-validation" "3.1.1" + "@docusaurus/core" "3.2.0" + "@docusaurus/logger" "3.2.0" + "@docusaurus/plugin-content-docs" "3.2.0" + "@docusaurus/theme-common" "3.2.0" + "@docusaurus/theme-translations" "3.2.0" + "@docusaurus/utils" "3.2.0" + "@docusaurus/utils-validation" "3.2.0" algoliasearch "^4.18.0" algoliasearch-helper "^3.13.3" clsx "^2.0.0" @@ -1592,18 +1592,18 @@ tslib "^2.6.0" utility-types "^3.10.0" -"@docusaurus/theme-translations@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/theme-translations/-/theme-translations-3.1.1.tgz#117e91ba5e3a8178cb59f3028bf41de165a508c1" - integrity sha512-xvWQFwjxHphpJq5fgk37FXCDdAa2o+r7FX8IpMg+bGZBNXyWBu3MjZ+G4+eUVNpDhVinTc+j6ucL0Ain5KCGrg== +"@docusaurus/theme-translations@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/theme-translations/-/theme-translations-3.2.0.tgz#02a0e9bd0ed8cebc21a2f1e5b6d252b0e5ee39a9" + integrity sha512-VXzZJBuyVEmwUYyud+7IgJQEBRM6R2u/s10Rp3DOP19CBQxeKgHYTKkKhFtDeKMHDassb665kjgOi0YlJfUT6w== dependencies: fs-extra "^11.1.1" tslib "^2.6.0" -"@docusaurus/types@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/types/-/types-3.1.1.tgz#747c9dee8cf7c3b0e5ee7351bac5e9c4fdc7f259" - integrity sha512-grBqOLnubUecgKFXN9q3uit2HFbCxTWX4Fam3ZFbMN0sWX9wOcDoA7lwdX/8AmeL20Oc4kQvWVgNrsT8bKRvzg== +"@docusaurus/types@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/types/-/types-3.2.0.tgz#c5bfd000ad4f72e9a7e6beff79905f9ea165fcd3" + integrity sha512-uG3FfTkkkbZIPPNYx6xRfZHKeGyRd/inIT1cqvYt1FobFLd+7WhRXrSBqwJ9JajJjEAjNioRMVFgGofGf/Wdww== dependencies: "@mdx-js/mdx" "^3.0.0" "@types/history" "^4.7.11" @@ -1615,30 +1615,32 @@ webpack "^5.88.1" webpack-merge "^5.9.0" -"@docusaurus/utils-common@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/utils-common/-/utils-common-3.1.1.tgz#b48fade63523fd40f3adb67b47c3371e5183c20b" - integrity sha512-eGne3olsIoNfPug5ixjepZAIxeYFzHHnor55Wb2P57jNbtVaFvij/T+MS8U0dtZRFi50QU+UPmRrXdVUM8uyMg== +"@docusaurus/utils-common@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/utils-common/-/utils-common-3.2.0.tgz#6163a2c415d150d6df73a8aceec6004f0ba3bb06" + integrity sha512-WEQT5L2lT/tBQgDRgeZQAIi9YJBrwEILb1BuObQn1St3T/4K1gx5fWwOT8qdLOov296XLd1FQg9Ywu27aE9svw== dependencies: tslib "^2.6.0" -"@docusaurus/utils-validation@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/utils-validation/-/utils-validation-3.1.1.tgz#3a747349ed05aee0e4d543552b41f3c9467ee731" - integrity sha512-KlY4P9YVDnwL+nExvlIpu79abfEv6ZCHuOX4ZQ+gtip+Wxj0daccdReIWWtqxM/Fb5Cz1nQvUCc7VEtT8IBUAA== +"@docusaurus/utils-validation@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/utils-validation/-/utils-validation-3.2.0.tgz#b53463d9dc6eb335a2ad93ed4b3c397162533e6d" + integrity sha512-rCzMTqwNrBrEOyU8EaD1fYWdig4TDhfj+YLqB8DY68VUAqSIgbY+yshpqFKB0bznFYNBJbn0bGpvVuImQOa/vA== dependencies: - "@docusaurus/logger" "3.1.1" - "@docusaurus/utils" "3.1.1" + "@docusaurus/logger" "3.2.0" + "@docusaurus/utils" "3.2.0" + "@docusaurus/utils-common" "3.2.0" joi "^17.9.2" js-yaml "^4.1.0" tslib "^2.6.0" -"@docusaurus/utils@3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@docusaurus/utils/-/utils-3.1.1.tgz#e822d14704e4b3bb451ca464a7cc56aea9b55a45" - integrity sha512-ZJfJa5cJQtRYtqijsPEnAZoduW6sjAQ7ZCWSZavLcV10Fw0Z3gSaPKA/B4micvj2afRZ4gZxT7KfYqe5H8Cetg== +"@docusaurus/utils@3.2.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@docusaurus/utils/-/utils-3.2.0.tgz#1312221d224eb2cbaaaf53d24efca3e1e976db3e" + integrity sha512-3rgrE7iL60yV2JQivlcoxUNNTK2APmn+OHLUmTvX2pueIM8DEOCEFHpJO4MiWjFO7V/Wq3iA/W1M03JnjdugVw== dependencies: - "@docusaurus/logger" "3.1.1" + "@docusaurus/logger" "3.2.0" + "@docusaurus/utils-common" "3.2.0" "@svgr/webpack" "^6.5.1" escape-string-regexp "^4.0.0" file-loader "^6.2.0" @@ -1650,6 +1652,7 @@ js-yaml "^4.1.0" lodash "^4.17.21" micromatch "^4.0.5" + prompts "^2.4.2" resolve-pathname "^3.0.0" shelljs "^0.8.5" tslib "^2.6.0" @@ -1856,15 +1859,6 @@ micromark-util-character "^1.1.0" micromark-util-symbol "^1.0.1" -"@slorber/static-site-generator-webpack-plugin@^4.0.7": - version "4.0.7" - resolved "https://registry.yarnpkg.com/@slorber/static-site-generator-webpack-plugin/-/static-site-generator-webpack-plugin-4.0.7.tgz#fc1678bddefab014e2145cbe25b3ce4e1cfc36f3" - integrity sha512-Ug7x6z5lwrz0WqdnNFOMYrDQNTPAprvHLSh6+/fmml3qUiz6l5eq+2MzLKWtn/q5K5NpSiFsZTP/fck/3vjSxA== - dependencies: - eval "^0.1.8" - p-map "^4.0.0" - webpack-sources "^3.2.2" - "@svgr/babel-plugin-add-jsx-attribute@^6.5.1": version "6.5.1" resolved "https://registry.yarnpkg.com/@svgr/babel-plugin-add-jsx-attribute/-/babel-plugin-add-jsx-attribute-6.5.1.tgz#74a5d648bd0347bda99d82409d87b8ca80b9a1ba" @@ -8227,7 +8221,7 @@ webpack-merge@^5.9.0: flat "^5.0.2" wildcard "^2.0.0" -webpack-sources@^3.2.2, webpack-sources@^3.2.3: +webpack-sources@^3.2.3: version "3.2.3" resolved "https://registry.yarnpkg.com/webpack-sources/-/webpack-sources-3.2.3.tgz#2d4daab8451fd4b240cc27055ff6a0c2ccea0cde" integrity sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==