mirror of
https://github.com/project-zot/zot.git
synced 2026-06-18 05:28:07 +08:00
2402296e9a
* fix: migrate to Go module v2 for proper semantic versioning This change updates the module path from 'zotregistry.dev/zot' to 'zotregistry.dev/zot/v2' to comply with Go's semantic versioning rules. According to Go's module versioning requirements, major version v2+ must include the major version in the module path. The current module path 'zotregistry.dev/zot' only supports v0.x.x and v1.x.x versions, making existing v2.x.x tags (like v2.1.8) unusable. Changes: - Updated go.mod module path to zotregistry.dev/zot/v2 - Updated all internal import paths across 280+ Go source files - Updated configuration files (golangcilint.yaml, gqlgen.yml) - Updated README.md Go reference badge This fix enables proper use of existing v2.x.x Git tags and allows external packages to import zot v2+ versions without compatibility errors. Resolves: Go module import compatibility for v2+ versions Fixes: #3071 Signed-off-by: Luca Muscariello <muscariello@ieee.org> * fix: regenerate GraphQL files with updated v2 import paths The gqlgen tool needs to regenerate the GraphQL schema files after the module path change to use the new v2 imports. Signed-off-by: Luca Muscariello <muscariello@ieee.org> --------- Signed-off-by: Luca Muscariello <muscariello@ieee.org>
101 lines
2.4 KiB
Go
101 lines
2.4 KiB
Go
package dynamodb
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/aws/aws-sdk-go-v2/aws"
|
|
"github.com/aws/aws-sdk-go-v2/service/dynamodb"
|
|
"github.com/aws/aws-sdk-go-v2/service/dynamodb/types"
|
|
|
|
"zotregistry.dev/zot/v2/pkg/log"
|
|
)
|
|
|
|
type AttributesIterator interface {
|
|
First(ctx context.Context) (types.AttributeValue, error)
|
|
Next(ctx context.Context) (types.AttributeValue, error)
|
|
}
|
|
|
|
type BaseAttributesIterator struct {
|
|
Client *dynamodb.Client
|
|
Table string
|
|
Attribute string
|
|
|
|
itemBuffer []map[string]types.AttributeValue
|
|
currentItemIndex int
|
|
lastEvaluatedKey map[string]types.AttributeValue
|
|
readLimit *int32
|
|
|
|
log log.Logger
|
|
}
|
|
|
|
func NewBaseDynamoAttributesIterator(client *dynamodb.Client, table, attribute string, maxReadLimit int32,
|
|
log log.Logger,
|
|
) *BaseAttributesIterator {
|
|
var readLimit *int32
|
|
|
|
if maxReadLimit > 0 {
|
|
readLimit = &maxReadLimit
|
|
}
|
|
|
|
return &BaseAttributesIterator{
|
|
Client: client,
|
|
Table: table,
|
|
Attribute: attribute,
|
|
itemBuffer: []map[string]types.AttributeValue{},
|
|
currentItemIndex: 0,
|
|
readLimit: readLimit,
|
|
log: log,
|
|
}
|
|
}
|
|
|
|
func (dii *BaseAttributesIterator) First(ctx context.Context) (types.AttributeValue, error) {
|
|
scanOutput, err := dii.Client.Scan(ctx, &dynamodb.ScanInput{
|
|
TableName: aws.String(dii.Table),
|
|
Limit: dii.readLimit,
|
|
ProjectionExpression: aws.String(dii.Attribute),
|
|
})
|
|
if err != nil {
|
|
return &types.AttributeValueMemberBOOL{}, err
|
|
}
|
|
|
|
if len(scanOutput.Items) == 0 {
|
|
return nil, nil //nolint:nilnil
|
|
}
|
|
|
|
dii.itemBuffer = scanOutput.Items
|
|
dii.lastEvaluatedKey = scanOutput.LastEvaluatedKey
|
|
dii.currentItemIndex = 1
|
|
|
|
return dii.itemBuffer[0][dii.Attribute], nil
|
|
}
|
|
|
|
func (dii *BaseAttributesIterator) Next(ctx context.Context) (types.AttributeValue, error) {
|
|
if len(dii.itemBuffer) <= dii.currentItemIndex {
|
|
if dii.lastEvaluatedKey == nil {
|
|
return nil, nil //nolint:nilnil
|
|
}
|
|
|
|
scanOutput, err := dii.Client.Scan(ctx, &dynamodb.ScanInput{
|
|
TableName: aws.String(dii.Table),
|
|
ExclusiveStartKey: dii.lastEvaluatedKey,
|
|
})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
// all items have been scanned
|
|
if len(scanOutput.Items) == 0 {
|
|
return nil, nil //nolint:nilnil
|
|
}
|
|
|
|
dii.itemBuffer = scanOutput.Items
|
|
dii.lastEvaluatedKey = scanOutput.LastEvaluatedKey
|
|
dii.currentItemIndex = 0
|
|
}
|
|
|
|
nextItem := dii.itemBuffer[dii.currentItemIndex][dii.Attribute]
|
|
dii.currentItemIndex++
|
|
|
|
return nextItem, nil
|
|
}
|