2023-07-18 20:27:26 +03:00
|
|
|
package meta
|
2023-01-09 22:37:44 +02:00
|
|
|
|
|
|
|
import (
|
2023-03-28 20:20:09 +03:00
|
|
|
"github.com/aws/aws-sdk-go-v2/service/dynamodb"
|
|
|
|
"go.etcd.io/bbolt"
|
|
|
|
|
2024-02-01 06:34:07 +02:00
|
|
|
"zotregistry.dev/zot/errors"
|
|
|
|
"zotregistry.dev/zot/pkg/api/config"
|
|
|
|
"zotregistry.dev/zot/pkg/log"
|
|
|
|
"zotregistry.dev/zot/pkg/meta/boltdb"
|
|
|
|
mdynamodb "zotregistry.dev/zot/pkg/meta/dynamodb"
|
|
|
|
mTypes "zotregistry.dev/zot/pkg/meta/types"
|
2023-01-09 22:37:44 +02:00
|
|
|
)
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
func New(storageConfig config.StorageConfig, log log.Logger) (mTypes.MetaDB, error) {
|
2023-03-28 20:20:09 +03:00
|
|
|
if storageConfig.RemoteCache {
|
|
|
|
dynamoParams := getDynamoParams(storageConfig.CacheDriver, log)
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
client, err := mdynamodb.GetDynamoClient(dynamoParams)
|
2023-03-28 20:20:09 +03:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return Create("dynamodb", client, dynamoParams, log) //nolint:contextcheck
|
|
|
|
}
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
params := boltdb.DBParameters{}
|
2023-03-28 20:20:09 +03:00
|
|
|
params.RootDir = storageConfig.RootDirectory
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
driver, err := boltdb.GetBoltDriver(params)
|
2023-03-28 20:20:09 +03:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return Create("boltdb", driver, params, log) //nolint:contextcheck
|
|
|
|
}
|
|
|
|
|
|
|
|
func Create(dbtype string, dbDriver, parameters interface{}, log log.Logger, //nolint:contextcheck
|
2023-07-18 20:27:26 +03:00
|
|
|
) (mTypes.MetaDB, error,
|
2023-03-28 20:20:09 +03:00
|
|
|
) {
|
2023-01-09 22:37:44 +02:00
|
|
|
switch dbtype {
|
|
|
|
case "boltdb":
|
|
|
|
{
|
2023-03-28 20:20:09 +03:00
|
|
|
properDriver, ok := dbDriver.(*bbolt.DB)
|
2023-01-09 22:37:44 +02:00
|
|
|
if !ok {
|
2023-12-08 00:05:02 -08:00
|
|
|
log.Error().Err(errors.ErrTypeAssertionFailed).
|
|
|
|
Msgf("failed to cast type, expected type '%T' but got '%T'", &bbolt.DB{}, dbDriver)
|
2023-11-24 10:38:36 +02:00
|
|
|
|
|
|
|
return nil, errors.ErrTypeAssertionFailed
|
2023-01-09 22:37:44 +02:00
|
|
|
}
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
return boltdb.New(properDriver, log)
|
2023-01-09 22:37:44 +02:00
|
|
|
}
|
|
|
|
case "dynamodb":
|
|
|
|
{
|
2023-03-28 20:20:09 +03:00
|
|
|
properDriver, ok := dbDriver.(*dynamodb.Client)
|
2023-01-09 22:37:44 +02:00
|
|
|
if !ok {
|
2023-12-08 00:05:02 -08:00
|
|
|
log.Error().Err(errors.ErrTypeAssertionFailed).
|
|
|
|
Msgf("failed to cast type, expected type '%T' but got '%T'", &dynamodb.Client{}, dbDriver)
|
2023-11-24 10:38:36 +02:00
|
|
|
|
|
|
|
return nil, errors.ErrTypeAssertionFailed
|
2023-01-09 22:37:44 +02:00
|
|
|
}
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
properParameters, ok := parameters.(mdynamodb.DBDriverParameters)
|
2023-03-28 20:20:09 +03:00
|
|
|
if !ok {
|
2023-12-08 00:05:02 -08:00
|
|
|
log.Error().Err(errors.ErrTypeAssertionFailed).
|
|
|
|
Msgf("failed to cast type, expected type '%T' but got '%T'", mdynamodb.DBDriverParameters{},
|
|
|
|
parameters)
|
2023-11-24 10:38:36 +02:00
|
|
|
|
|
|
|
return nil, errors.ErrTypeAssertionFailed
|
2023-03-28 20:20:09 +03:00
|
|
|
}
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
return mdynamodb.New(properDriver, properParameters, log)
|
2023-01-09 22:37:44 +02:00
|
|
|
}
|
|
|
|
default:
|
|
|
|
{
|
|
|
|
return nil, errors.ErrBadConfig
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-03-28 20:20:09 +03:00
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
func getDynamoParams(cacheDriverConfig map[string]interface{}, log log.Logger) mdynamodb.DBDriverParameters {
|
2023-03-28 20:20:09 +03:00
|
|
|
allParametersOk := true
|
|
|
|
|
|
|
|
endpoint, ok := toStringIfOk(cacheDriverConfig, "endpoint", log)
|
|
|
|
allParametersOk = allParametersOk && ok
|
|
|
|
|
|
|
|
region, ok := toStringIfOk(cacheDriverConfig, "region", log)
|
|
|
|
allParametersOk = allParametersOk && ok
|
|
|
|
|
|
|
|
repoMetaTablename, ok := toStringIfOk(cacheDriverConfig, "repometatablename", log)
|
|
|
|
allParametersOk = allParametersOk && ok
|
|
|
|
|
2023-10-30 22:06:04 +02:00
|
|
|
repoBlobsInfoTablename, ok := toStringIfOk(cacheDriverConfig, "repoblobsinfotablename", log)
|
2023-03-28 20:20:09 +03:00
|
|
|
allParametersOk = allParametersOk && ok
|
|
|
|
|
2023-10-30 22:06:04 +02:00
|
|
|
imageMetaTablename, ok := toStringIfOk(cacheDriverConfig, "imagemetatablename", log)
|
2023-03-28 20:20:09 +03:00
|
|
|
allParametersOk = allParametersOk && ok
|
|
|
|
|
2023-07-07 19:27:10 +03:00
|
|
|
apiKeyTablename, ok := toStringIfOk(cacheDriverConfig, "apikeytablename", log)
|
|
|
|
allParametersOk = allParametersOk && ok
|
|
|
|
|
2023-03-28 20:20:09 +03:00
|
|
|
versionTablename, ok := toStringIfOk(cacheDriverConfig, "versiontablename", log)
|
|
|
|
allParametersOk = allParametersOk && ok
|
|
|
|
|
2023-04-24 21:13:15 +03:00
|
|
|
userDataTablename, ok := toStringIfOk(cacheDriverConfig, "userdatatablename", log)
|
|
|
|
allParametersOk = allParametersOk && ok
|
|
|
|
|
2023-03-28 20:20:09 +03:00
|
|
|
if !allParametersOk {
|
2023-11-24 10:38:36 +02:00
|
|
|
log.Panic().Msg("dynamo parameters are not specified correctly, can't proceed")
|
2023-03-28 20:20:09 +03:00
|
|
|
}
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
return mdynamodb.DBDriverParameters{
|
2023-10-30 22:06:04 +02:00
|
|
|
Endpoint: endpoint,
|
|
|
|
Region: region,
|
|
|
|
RepoMetaTablename: repoMetaTablename,
|
|
|
|
RepoBlobsInfoTablename: repoBlobsInfoTablename,
|
|
|
|
ImageMetaTablename: imageMetaTablename,
|
|
|
|
UserDataTablename: userDataTablename,
|
|
|
|
APIKeyTablename: apiKeyTablename,
|
|
|
|
VersionTablename: versionTablename,
|
2023-03-28 20:20:09 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func toStringIfOk(cacheDriverConfig map[string]interface{}, param string, log log.Logger) (string, bool) {
|
|
|
|
val, ok := cacheDriverConfig[param]
|
|
|
|
|
|
|
|
if !ok {
|
2023-12-08 00:05:02 -08:00
|
|
|
log.Error().Str("field", param).Msg("failed to parse CacheDriver config, field is not present")
|
2023-03-28 20:20:09 +03:00
|
|
|
|
|
|
|
return "", false
|
|
|
|
}
|
|
|
|
|
|
|
|
str, ok := val.(string)
|
|
|
|
|
|
|
|
if !ok {
|
2023-12-08 00:05:02 -08:00
|
|
|
log.Error().Str("parameter", param).Msg("failed to parse CacheDriver config, parameter isn't a string")
|
2023-03-28 20:20:09 +03:00
|
|
|
|
|
|
|
return "", false
|
|
|
|
}
|
|
|
|
|
|
|
|
if str == "" {
|
2023-12-08 00:05:02 -08:00
|
|
|
log.Error().Str("field", param).Msg("failed to parse CacheDriver config, field is empty")
|
2023-03-28 20:20:09 +03:00
|
|
|
|
|
|
|
return "", false
|
|
|
|
}
|
|
|
|
|
|
|
|
return str, ok
|
|
|
|
}
|