types

package
v0.15.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 12, 2024 License: Apache-2.0 Imports: 1 Imported by: 0

Documentation

Overview

Package types defines the core data types used in Rigel.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Cache added in v0.9.0

type Cache interface {
	Get(key string) (value string, found bool)
	Set(key string, value string)
	Delete(key string)
}

type Constraints added in v0.11.0

type Constraints struct {
	Min  *int     `json:"min,omitempty"`
	Max  *int     `json:"max,omitempty"`
	Enum []string `json:"enum,omitempty"`
}

type Event added in v0.9.0

type Event struct {
	Key   string
	Value string
}

Event represents a change to a key in the storage. Key is the key that was changed Value is the new value of the key

type Field

type Field struct {
	Name        string       `json:"name"` // Name represents the name of the field (config parameter).
	Type        string       `json:"type"` // Type represents the type of the field. Currently, the supported types are "string", "int", and "bool".
	Description string       `json:"description"`
	Constraints *Constraints `json:"constraints"`
}

Field represents a single field in a schema. Currently, the only supported types are string, int, and bool.

Example:

{
  "name": "maxConnections",
  "type": "int"
}

type Schema

type Schema struct {
	Fields      []Field // Fields is a list of fields that the schema contains
	Version     int     // Version represents the version of the schema
	Description string  // Description provides more information about the schema
}

Schema represents the structure of a schema. Currently, the only supported type is JSON.

Example:

{
  "name": "webServer",
  "version": 1,
  "fields": [
    {"name": "host", "type": "string"},
    {"name": "port", "type": "int"},
    {"name": "logLevel", "type": "string"},
    {"name": "maxConnections", "type": "int"},
    {"name": "enableHttps", "type": "bool"},
  ],
  "description": "Configuration for a web server application"
}

type Storage

type Storage interface {
	// Get retrieves a value associated with the given key.
	// If the key does not exist, it returns an empty string and no error.
	// If an error occurs during the operation, it is returned.
	Get(ctx context.Context, key string) (string, error)

	// Put stores a value with the specified key.
	// If the key already exists, its value is updated; if it does not, a new key-value pair is created.
	// If an error occurs during the operation, it is returned.
	Put(ctx context.Context, key string, value string) error

	// Watch watches for changes to a key in the storage and sends the events to the provided channel.
	// The events includes the key and the updated value.
	// events is the channel to send events when the key's value changes
	Watch(ctx context.Context, key string, events chan<- Event) error
}

Storage is an interface that abstracts the operations for getting and putting data in Rigel's underlying storage

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL