mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-05 14:37:45 +00:00
fa9f581d56
* chore: move to new org * logging * fix: org rename caos -> zitadel Co-authored-by: adlerhurst <silvan.reusser@gmail.com>
84 lines
1.9 KiB
Go
84 lines
1.9 KiB
Go
package domain
|
|
|
|
import (
|
|
"time"
|
|
|
|
caos_errors "github.com/zitadel/zitadel/internal/errors"
|
|
es_models "github.com/zitadel/zitadel/internal/eventstore/v1/models"
|
|
)
|
|
|
|
type Metadata struct {
|
|
es_models.ObjectRoot
|
|
|
|
State MetadataState
|
|
Key string
|
|
Value []byte
|
|
}
|
|
|
|
type MetadataState int32
|
|
|
|
const (
|
|
MetadataStateUnspecified MetadataState = iota
|
|
MetadataStateActive
|
|
MetadataStateRemoved
|
|
)
|
|
|
|
func (m *Metadata) IsValid() bool {
|
|
return m.Key != "" && len(m.Value) > 0
|
|
}
|
|
|
|
func (s MetadataState) Exists() bool {
|
|
return s != MetadataStateUnspecified && s != MetadataStateRemoved
|
|
}
|
|
|
|
type MetadataSearchRequest struct {
|
|
Offset uint64
|
|
Limit uint64
|
|
SortingColumn MetadataSearchKey
|
|
Asc bool
|
|
Queries []*MetadataSearchQuery
|
|
}
|
|
|
|
type MetadataSearchKey int32
|
|
|
|
const (
|
|
MetadataSearchKeyUnspecified MetadataSearchKey = iota
|
|
MetadataSearchKeyAggregateID
|
|
MetadataSearchKeyResourceOwner
|
|
MetadataSearchKeyKey
|
|
MetadataSearchKeyValue
|
|
)
|
|
|
|
type MetadataSearchQuery struct {
|
|
Key MetadataSearchKey
|
|
Method SearchMethod
|
|
Value interface{}
|
|
}
|
|
|
|
type MetadataSearchResponse struct {
|
|
Offset uint64
|
|
Limit uint64
|
|
TotalResult uint64
|
|
Result []*Metadata
|
|
Sequence uint64
|
|
Timestamp time.Time
|
|
}
|
|
|
|
func (r *MetadataSearchRequest) EnsureLimit(limit uint64) error {
|
|
if r.Limit > limit {
|
|
return caos_errors.ThrowInvalidArgument(nil, "SEARCH-0ds32", "Errors.Limit.ExceedsDefault")
|
|
}
|
|
if r.Limit == 0 {
|
|
r.Limit = limit
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (r *MetadataSearchRequest) AppendAggregateIDQuery(aggregateID string) {
|
|
r.Queries = append(r.Queries, &MetadataSearchQuery{Key: MetadataSearchKeyAggregateID, Method: SearchMethodEquals, Value: aggregateID})
|
|
}
|
|
|
|
func (r *MetadataSearchRequest) AppendResourceOwnerQuery(resourceOwner string) {
|
|
r.Queries = append(r.Queries, &MetadataSearchQuery{Key: MetadataSearchKeyResourceOwner, Method: SearchMethodEquals, Value: resourceOwner})
|
|
}
|