persistence

package
v1.0.0-1 Latest Latest
Warning

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

Go to latest
Published: Jul 5, 2022 License: MIT Imports: 18 Imported by: 1

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func ConvertToMap

func ConvertToMap(values any) map[string]any

func GenerateParameters

func GenerateParameters[T any](values any) string

GenerateParameters generates a list of value parameters to use in SQL statements like: "$1,$2,$3"

Parameters:
	- values an array with column values or a key-value map
Returns: a generated list of value parameters

Types

type IPostgresPersistenceOverrides

type IPostgresPersistenceOverrides[T any] interface {
	DefineSchema()
	ConvertFromPublic(item T) map[string]any
	ConvertToPublic(item pgx.Rows) T
	ConvertFromPublicPartial(item map[string]any) map[string]any
}

type IdentifiableJsonPostgresPersistence

type IdentifiableJsonPostgresPersistence[T any, K any] struct {
	IdentifiablePostgresPersistence[T, K]
}

IdentifiableJsonPostgresPersistence is an abstract persistence component that stores data in PostgreSQL in JSON or JSONB fields and implements a number of CRUD operations over data items with unique ids. The data items must implement IIdentifiable interface.

The JSON table has only two fields: id and data.

In basic scenarios child classes shall only override getPageByFilter, getListByFilter or deleteByFilter operations with specific filter function. All other operations can be used out of the box.

In complex scenarios child classes can implement additional operations by accessing c._collection and c._model properties.

### Configuration parameters ###

	- collection:                  (optional) PostgreSQL collection name
	- connection(s):
		- discovery_key:             (optional) a key to retrieve the connection from IDiscovery
		- host:                      host name or IP address
		- port:                      port number (default: 27017)
		- uri:                       resource URI or connection string with all parameters in it
	- credential(s):
		- store_key:                 (optional) a key to retrieve the credentials from ICredentialStore
		- username:                  (optional) user name
		- password:                  (optional) user password
	- options:
		- connect_timeout:      (optional) number of milliseconds to wait before timing out when connecting a new client (default: 0)
		- idle_timeout:         (optional) number of milliseconds a client must sit idle in the pool and not be checked out (default: 10000)
		- max_pool_size:        (optional) maximum number of clients the pool should contain (default: 10)

### References ###
	- \*:logger:\*:\*:1.0           (optional) ILogger components to pass log messages components to pass log messages
	- \*:discovery:\*:\*:1.0        (optional) IDiscovery services
	- \*:credential-store:\*:\*:1.0 (optional) Credential stores to resolve credentials

### Example ###

func InheritIdentifiableJsonPostgresPersistence

func InheritIdentifiableJsonPostgresPersistence[T any, K any](overrides IPostgresPersistenceOverrides[T], tableName string) *IdentifiableJsonPostgresPersistence[T, K]

InheritIdentifiableJsonPostgresPersistence creates a new instance of the persistence component.

Parameters:
	- overrides References to override virtual methods
	- tableName    (optional) a table name.

func (*IdentifiableJsonPostgresPersistence[T, K]) ConvertFromPublic

func (c *IdentifiableJsonPostgresPersistence[T, K]) ConvertFromPublic(value T) map[string]any

ConvertFromPublic convert object value from public to internal format.

	Parameters:
   - value     an object in public format to convert.

Returns converted object in internal format.

func (*IdentifiableJsonPostgresPersistence[T, K]) ConvertFromPublicPartial

func (c *IdentifiableJsonPostgresPersistence[T, K]) ConvertFromPublicPartial(value map[string]any) map[string]any

ConvertFromPublicPartial convert object value from public to internal format.

Parameters:
	- value     an object in public format to convert.
Returns: converted object in internal format.

func (*IdentifiableJsonPostgresPersistence[T, K]) ConvertToPublic

func (c *IdentifiableJsonPostgresPersistence[T, K]) ConvertToPublic(rows pgx.Rows) T

ConvertToPublic converts object value from internal to public format.

Parameters:
	- value an object in internal format to convert.
Returns: converted object in public format.

func (*IdentifiableJsonPostgresPersistence[T, K]) EnsureTable

func (c *IdentifiableJsonPostgresPersistence[T, K]) EnsureTable(idType string, dataType string)

EnsureTable Adds DML statement to automatically create JSON(B) table

	Parameters:
  - idType type of the id column (default: TEXT)
  - dataType type of the data column (default: JSONB)

func (*IdentifiableJsonPostgresPersistence[T, K]) UpdatePartially

func (c *IdentifiableJsonPostgresPersistence[T, K]) UpdatePartially(ctx context.Context, correlationId string,
	id K, data cdata.AnyValueMap) (result T, err error)

UpdatePartially updates only few selected fields in a data item.

Parameters:
	- ctx context.Context
	- correlation_id    (optional) transaction id to trace execution through call chain.
	- id                an id of data item to be updated.
	- data              a map with fields to be updated.

Returns: receives updated item or error.

type IdentifiablePostgresPersistence

type IdentifiablePostgresPersistence[T any, K any] struct {
	*PostgresPersistence[T]
}

IdentifiablePostgresPersistence Abstract persistence component that stores data in PostgreSQL and implements a number of CRUD operations over data items with unique ids. The data items must implement IIdentifiable interface.

In basic scenarios child classes shall only override getPageByFilter, getListByFilter or deleteByFilter operations with specific filter function. All other operations can be used out of the box.

In complex scenarios child classes can implement additional operations by accessing c._collection and c._model properties.

### Configuration parameters ###
	- collection:               (optional) PostgreSQL collection name
	- connection(s):
		- discovery_key:        (optional) a key to retrieve the connection from IDiscovery
		- host:                 host name or IP address
		- port:                 port number (default: 27017)
		- uri:                  resource URI or connection string with all parameters in it
	- credential(s):
		- store_key:            (optional) a key to retrieve the credentials from ICredentialStore
		- username:             (optional) user name
		- password:             (optional) user password
	- options:
		- connect_timeout:      (optional) number of milliseconds to wait before timing out when connecting a new client (default: 0)
		- idle_timeout:         (optional) number of milliseconds a client must sit idle in the pool and not be checked out (default: 10000)
		- max_pool_size:        (optional) maximum number of clients the pool should contain (default: 10)

### References ###

- \*:logger:\*:\*:1.0 (optional) ILogger components to pass log messages components to pass log messages - \*:discovery:\*:\*:1.0 (optional) IDiscovery services - \*:credential-store:\*:\*:1.0 (optional) Credential stores to resolve credentials * ### Example ###

func InheritIdentifiablePostgresPersistence

func InheritIdentifiablePostgresPersistence[T any, K any](overrides IPostgresPersistenceOverrides[T], tableName string) *IdentifiablePostgresPersistence[T, K]

InheritIdentifiablePostgresPersistence creates a new instance of the persistence component.

Parameters:
	- overrides References to override virtual methods
	- tableName    (optional) a table name.

func (*IdentifiablePostgresPersistence[T, K]) Create

func (c *IdentifiablePostgresPersistence[T, K]) Create(ctx context.Context, correlationId string, item T) (result T, err error)

Create a data item.

Parameters:
	- ctx context.Context
	- correlation_id    (optional) transaction id to trace execution through call chain.
	- item              an item to be created.
Returns: (optional)  created item or error.

func (*IdentifiablePostgresPersistence[T, K]) DeleteById

func (c *IdentifiablePostgresPersistence[T, K]) DeleteById(ctx context.Context, correlationId string, id K) (result T, err error)

DeleteById deletes a data item by its unique id.

Parameters:
	- ctx context.Context
	- correlation_id    (optional) transaction id to trace execution through call chain.
	- id                an id of the item to be deleted
Returns: (optional)  deleted item or error.

func (*IdentifiablePostgresPersistence[T, K]) DeleteByIds

func (c *IdentifiablePostgresPersistence[T, K]) DeleteByIds(ctx context.Context, correlationId string, ids []K) error

DeleteByIds deletes multiple data items by their unique ids.

Parameters:
	- ctx context.Context
	- correlationId     (optional) transaction id to trace execution through call chain.
	- ids                of data items to be deleted.
Returns: (optional)  error or null for success.

func (*IdentifiablePostgresPersistence[T, K]) GetListByIds

func (c *IdentifiablePostgresPersistence[T, K]) GetListByIds(ctx context.Context, correlationId string,
	ids []K) (items []T, err error)

GetListByIds gets a list of data items retrieved by given unique ids.

Parameters:
	- ctx context.Context
	- correlationId     (optional) transaction id to trace execution through call chain.
	- ids of data items to be retrieved
Returns: a data list or error.

func (*IdentifiablePostgresPersistence[T, K]) GetOneById

func (c *IdentifiablePostgresPersistence[T, K]) GetOneById(ctx context.Context, correlationId string, id K) (item T, err error)

GetOneById gets a data item by its unique id.

Parameters:
	- ctx context.Context
	- correlationId     (optional) transaction id to trace execution through call chain.
	- id                an id of data item to be retrieved.

Returns: data item or error.

func (*IdentifiablePostgresPersistence[T, K]) Set

func (c *IdentifiablePostgresPersistence[T, K]) Set(ctx context.Context, correlationId string, item T) (result T, err error)

Set a data item. If the data item exists it updates it, otherwise it creates a new data item.

Parameters:
	- ctx context.Context
	- correlation_id    (optional) transaction id to trace execution through call chain.
	- item              an item to be set.
Returns: (optional)  updated item or error.

func (*IdentifiablePostgresPersistence[T, K]) Update

func (c *IdentifiablePostgresPersistence[T, K]) Update(ctx context.Context, correlationId string, item T) (result T, err error)

Update a data item.

Parameters:
	- ctx context.Context
	- correlation_id    (optional) transaction id to trace execution through call chain.
	- item              an item to be updated.
Returns          (optional)  updated item or error.

func (*IdentifiablePostgresPersistence[T, K]) UpdatePartially

func (c *IdentifiablePostgresPersistence[T, K]) UpdatePartially(ctx context.Context, correlationId string, id K, data cdata.AnyValueMap) (result T, err error)

UpdatePartially updates only few selected fields in a data item.

Parameters:
	- ctx context.Context
	- correlation_id    (optional) transaction id to trace execution through call chain.
	- id                an id of data item to be updated.
	- data              a map with fields to be updated.
Returns: updated item or error.

type PostgresPersistence

type PostgresPersistence[T any] struct {
	Overrides        IPostgresPersistenceOverrides[T]
	JsonConvertor    cconv.IJSONEngine[T]
	JsonMapConvertor cconv.IJSONEngine[map[string]any]

	//The dependency resolver.
	DependencyResolver *cref.DependencyResolver
	//The logger.
	Logger *clog.CompositeLogger
	//The PostgreSQL connection component.
	Connection *conn.PostgresConnection
	//The PostgreSQL connection pool object.
	Client *pgxpool.Pool
	//The PostgreSQL database name.
	DatabaseName string
	//The PostgreSQL database schema name. If not set use "public" by default
	SchemaName string
	//The PostgreSQL table object.
	TableName   string
	MaxPageSize int
	// contains filtered or unexported fields
}

PostgresPersistence Abstract persistence component that stores data in PostgreSQL using plain driver.

This is the most basic persistence component that is only able to store data items of any type. Specific CRUD operations over the data items must be implemented in child classes by accessing c._db or c._collection properties.

### Configuration parameters ###
	- collection:                  (optional) PostgreSQL collection name
	- schema:                  	   (optional) PostgreSQL schema, default "public"
	- connection(s):
		- discovery_key:             (optional) a key to retrieve the connection from IDiscovery
		- host:                      host name or IP address
		- port:                      port number (default: 27017)
		- uri:                       resource URI or connection string with all parameters in it
	- credential(s):
		- store_key:                 (optional) a key to retrieve the credentials from ICredentialStore
		- username:                  (optional) user name
		- password:                  (optional) user password
	- options:
		- connect_timeout:      (optional) number of milliseconds to wait before timing out when connecting a new client (default: 0)
		- idle_timeout:         (optional) number of milliseconds a client must sit idle in the pool and not be checked out (default: 10000)
		- max_pool_size:        (optional) maximum number of clients the pool should contain (default: 10)

### References ###
	- \*:logger:\*:\*:1.0           (optional) ILogger components to pass log messages
	- \*:discovery:\*:\*:1.0        (optional) IDiscovery services
	- \*:credential-store:\*:\*:1.0 (optional) Credential stores to resolve credentials

### Example ###

func InheritPostgresPersistence

func InheritPostgresPersistence[T any](overrides IPostgresPersistenceOverrides[T], tableName string) *PostgresPersistence[T]

InheritPostgresPersistence creates a new instance of the persistence component.

Parameters:
	- overrides References to override virtual methods
	- tableName    (optional) a table name.

func (*PostgresPersistence[T]) Clear

func (c *PostgresPersistence[T]) Clear(ctx context.Context, correlationId string) error

Clear component state.

Parameters:
	- ctx context.Context
	- correlationId 	(optional) transaction id to trace execution through call chain.
Returns: error or nil no errors occured.

func (*PostgresPersistence[T]) ClearSchema

func (c *PostgresPersistence[T]) ClearSchema()

ClearSchema clears all auto-created objects

func (*PostgresPersistence[T]) Close

func (c *PostgresPersistence[T]) Close(ctx context.Context, correlationId string) (err error)

Close component and frees used resources.

Parameters:
	- ctx context.Context
	- correlationId (optional) transaction id to trace execution through call chain.
Returns: error or nil no errors occurred.

func (*PostgresPersistence[T]) Configure

func (c *PostgresPersistence[T]) Configure(ctx context.Context, config *cconf.ConfigParams)

Configure component by passing configuration parameters.

Parameters:
	- ctx context.Context
	- config configuration parameters to be set.

func (*PostgresPersistence[T]) ConvertFromPublic

func (c *PostgresPersistence[T]) ConvertFromPublic(value T) map[string]any

ConvertFromPublic сonvert object value from func (c * PostgresPersistence) to internal format.

Parameters:
	- value an object in func (c * PostgresPersistence) format to convert.
Returns: converted object in internal format.

func (*PostgresPersistence[T]) ConvertFromPublicPartial

func (c *PostgresPersistence[T]) ConvertFromPublicPartial(value map[string]any) map[string]any

ConvertFromPublicPartial converts the given object from the public partial format.

Parameters:
	- value the object to convert from the public partial format.
Returns: the initial object.

func (*PostgresPersistence[T]) ConvertToPublic

func (c *PostgresPersistence[T]) ConvertToPublic(rows pgx.Rows) T

ConvertToPublic converts object value from internal to func (c * PostgresPersistence) format.

Parameters:
	- value an object in internal format to convert.
Returns: converted object in func (c * PostgresPersistence) format.

func (*PostgresPersistence[T]) Create

func (c *PostgresPersistence[T]) Create(ctx context.Context, correlationId string, item T) (result T, err error)

Create creates a data item.

Parameters:
	- ctx context.Context
	- correlation_id    (optional) transaction id to trace execution through call chain.
	- item              an item to be created.
Returns: (optional) callback function that receives created item or error.

func (*PostgresPersistence[T]) CreateSchema

func (c *PostgresPersistence[T]) CreateSchema(ctx context.Context, correlationId string) (err error)

func (*PostgresPersistence[T]) DefineSchema

func (c *PostgresPersistence[T]) DefineSchema()

DefineSchema a database schema for this persistence, have to call in child class

func (*PostgresPersistence[T]) DeleteByFilter

func (c *PostgresPersistence[T]) DeleteByFilter(ctx context.Context, correlationId string, filter string) (err error)

DeleteByFilter deletes data items that match to a given filter. This method shall be called by a func (c * PostgresPersistence) deleteByFilter method from child class that receives FilterParams and converts them into a filter function.

Parameters:
	- ctx context.Context
	- correlationId     (optional) transaction id to trace execution through call chain.
	- filter            (optional) a filter JSON object.
Returns: error or nil for success.

func (*PostgresPersistence[T]) EnsureIndex

func (c *PostgresPersistence[T]) EnsureIndex(name string, keys map[string]string, options map[string]string)

EnsureIndex adds index definition to create it on opening

Parameters:
	- keys index keys (fields)
	- options index options

func (*PostgresPersistence[T]) EnsureSchema

func (c *PostgresPersistence[T]) EnsureSchema(schemaStatement string)

EnsureSchema adds a statement to schema definition

	Parameters:
  - schemaStatement a statement to be added to the schema

func (*PostgresPersistence[T]) GenerateColumns

func (c *PostgresPersistence[T]) GenerateColumns(values any) string

GenerateColumns generates a list of column names to use in SQL statements like: "column1,column2,column3"

Parameters:
	- values an array with column values or a key-value map
Returns: a generated list of column names

func (*PostgresPersistence[T]) GenerateParameters

func (c *PostgresPersistence[T]) GenerateParameters(values any) string

GenerateParameters generates a list of value parameters to use in SQL statements like: "$1,$2,$3"

Parameters:
	- values an array with column values or a key-value map
Returns: a generated list of value parameters

func (*PostgresPersistence[T]) GenerateSetParameters

func (c *PostgresPersistence[T]) GenerateSetParameters(values any) (setParams string, columns string)

GenerateSetParameters generates a list of column sets to use in UPDATE statements like: column1=$1,column2=$2

Parameters:
	- values an array with column values or a key-value map
Returns: a generated list of column sets

func (*PostgresPersistence[T]) GenerateValues

func (c *PostgresPersistence[T]) GenerateValues(columns string, values any) []any

GenerateValues generates a list of column parameters

Parameters:
	- values an array with column values or a key-value map
Returns: a generated list of column values

func (*PostgresPersistence[T]) GetCountByFilter

func (c *PostgresPersistence[T]) GetCountByFilter(ctx context.Context, correlationId string,
	filter any) (count int64, err error)

GetCountByFilter gets a number of data items retrieved by a given filter. This method shall be called by a func (c * PostgresPersistence) getCountByFilter method from child class that receives FilterParams and converts them into a filter function.

Parameters:
	- ctx context.Context
	- correlationId     (optional) transaction id to trace execution through call chain.
	- filter            (optional) a filter JSON object
Returns: data page or error.

func (*PostgresPersistence[T]) GetListByFilter

func (c *PostgresPersistence[T]) GetListByFilter(ctx context.Context, correlationId string,
	filter any, sort any, sel any) (items []T, err error)

GetListByFilter gets a list of data items retrieved by a given filter and sorted according to sort parameters. This method shall be called by a func (c * PostgresPersistence) getListByFilter method from child class that receives FilterParams and converts them into a filter function.

Parameters:
	- ctx context.Context
	- correlationId    (optional) transaction id to trace execution through call chain.
	- filter           (optional) a filter JSON object
	- paging           (optional) paging parameters
	- sort             (optional) sorting JSON object
	- select           (optional) projection JSON object
Returns: data list or error.

func (*PostgresPersistence[T]) GetOneRandom

func (c *PostgresPersistence[T]) GetOneRandom(ctx context.Context, correlationId string, filter any) (item T, err error)

GetOneRandom gets a random item from items that match to a given filter. This method shall be called by a func (c * PostgresPersistence) getOneRandom method from child class that receives FilterParams and converts them into a filter function.

Parameters:
	- ctx context.Context
	- correlationId     (optional) transaction id to trace execution through call chain.
	- filter            (optional) a filter JSON object
Returns: random item or error.

func (*PostgresPersistence[T]) GetPageByFilter

func (c *PostgresPersistence[T]) GetPageByFilter(ctx context.Context, correlationId string,
	filter any, paging cdata.PagingParams, sort any, sel any) (page cdata.DataPage[T], err error)

GetPageByFilter gets a page of data items retrieved by a given filter and sorted according to sort parameters. This method shall be called by a func (c * PostgresPersistence) getPageByFilter method from child class that receives FilterParams and converts them into a filter function.

Parameters:
	- ctx context.Context
	- correlationId     (optional) transaction id to trace execution through call chain.
	- filter            (optional) a filter JSON object
	- paging            (optional) paging parameters
	- sort              (optional) sorting JSON object
	- select            (optional) projection JSON object
Returns: receives a data page or error.

func (*PostgresPersistence[T]) IsOpen

func (c *PostgresPersistence[T]) IsOpen() bool

IsOpen checks if the component is opened.

Returns: true if the component has been opened and false otherwise.

func (*PostgresPersistence[T]) Open

func (c *PostgresPersistence[T]) Open(ctx context.Context, correlationId string) (err error)

Open the component.

Parameters:
	- ctx context.Context
	- correlationId (optional) transaction id to trace execution through call chain.
Returns: error or nil no errors occurred.

func (*PostgresPersistence[T]) QuoteIdentifier

func (c *PostgresPersistence[T]) QuoteIdentifier(value string) string

func (*PostgresPersistence[T]) QuotedTableName

func (c *PostgresPersistence[T]) QuotedTableName() string

QuotedTableName return quoted SchemaName with TableName ("schema"."table")

func (*PostgresPersistence[T]) SetReferences

func (c *PostgresPersistence[T]) SetReferences(ctx context.Context, references cref.IReferences)

SetReferences to dependent components.

Parameters:
	- ctx context.Context
	- references references to locate the component dependencies.

func (*PostgresPersistence[T]) UnsetReferences

func (c *PostgresPersistence[T]) UnsetReferences()

UnsetReferences (clears) previously set references to dependent components.

Jump to

Keyboard shortcuts

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