2022-05-05 13:25:50 +00:00
|
|
|
// Copyright 2022 Cloudbase Solutions SRL
|
|
|
|
|
//
|
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
|
|
|
// not use this file except in compliance with the License. You may obtain
|
|
|
|
|
// a copy of the License at
|
|
|
|
|
//
|
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
//
|
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
|
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
|
// License for the specific language governing permissions and limitations
|
|
|
|
|
// under the License.
|
|
|
|
|
|
2022-05-04 13:15:27 +00:00
|
|
|
package sql
|
|
|
|
|
|
|
|
|
|
import (
|
2025-08-16 19:31:58 +00:00
|
|
|
"errors"
|
|
|
|
|
"fmt"
|
2024-06-05 06:41:16 +00:00
|
|
|
"net/url"
|
|
|
|
|
|
2023-04-10 00:03:49 +00:00
|
|
|
"github.com/google/uuid"
|
2022-05-04 13:15:27 +00:00
|
|
|
"gorm.io/gorm"
|
2024-02-22 16:54:38 +01:00
|
|
|
|
|
|
|
|
runnerErrors "github.com/cloudbase/garm-provider-common/errors"
|
2024-06-14 20:24:45 +00:00
|
|
|
"github.com/cloudbase/garm/database/common"
|
2024-02-22 16:54:38 +01:00
|
|
|
"github.com/cloudbase/garm/params"
|
2024-07-05 11:40:22 +00:00
|
|
|
"github.com/cloudbase/garm/util/appdefaults"
|
2022-05-04 13:15:27 +00:00
|
|
|
)
|
|
|
|
|
|
2024-06-05 06:41:16 +00:00
|
|
|
func dbControllerToCommonController(dbInfo ControllerInfo) (params.ControllerInfo, error) {
|
|
|
|
|
url, err := url.JoinPath(dbInfo.WebhookBaseURL, dbInfo.ControllerID.String())
|
|
|
|
|
if err != nil {
|
2025-08-16 19:31:58 +00:00
|
|
|
return params.ControllerInfo{}, fmt.Errorf("error joining webhook URL: %w", err)
|
2024-06-05 06:41:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return params.ControllerInfo{
|
|
|
|
|
ControllerID: dbInfo.ControllerID,
|
|
|
|
|
MetadataURL: dbInfo.MetadataURL,
|
|
|
|
|
WebhookURL: dbInfo.WebhookBaseURL,
|
|
|
|
|
ControllerWebhookURL: url,
|
|
|
|
|
CallbackURL: dbInfo.CallbackURL,
|
2024-07-01 10:27:31 +00:00
|
|
|
MinimumJobAgeBackoff: dbInfo.MinimumJobAgeBackoff,
|
2024-07-05 11:40:22 +00:00
|
|
|
Version: appdefaults.GetVersion(),
|
2024-06-05 06:41:16 +00:00
|
|
|
}, nil
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-04 13:15:27 +00:00
|
|
|
func (s *sqlDatabase) ControllerInfo() (params.ControllerInfo, error) {
|
|
|
|
|
var info ControllerInfo
|
|
|
|
|
q := s.conn.Model(&ControllerInfo{}).First(&info)
|
|
|
|
|
if q.Error != nil {
|
|
|
|
|
if errors.Is(q.Error, gorm.ErrRecordNotFound) {
|
2025-08-16 19:31:58 +00:00
|
|
|
return params.ControllerInfo{}, fmt.Errorf("error fetching controller info: %w", runnerErrors.ErrNotFound)
|
2022-05-04 13:15:27 +00:00
|
|
|
}
|
2025-08-16 19:31:58 +00:00
|
|
|
return params.ControllerInfo{}, fmt.Errorf("error fetching controller info: %w", q.Error)
|
2022-05-04 13:15:27 +00:00
|
|
|
}
|
2024-06-05 06:41:16 +00:00
|
|
|
|
|
|
|
|
paramInfo, err := dbControllerToCommonController(info)
|
|
|
|
|
if err != nil {
|
2025-08-16 19:31:58 +00:00
|
|
|
return params.ControllerInfo{}, fmt.Errorf("error converting controller info: %w", err)
|
2024-06-05 06:41:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return paramInfo, nil
|
2022-05-04 13:15:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (s *sqlDatabase) InitController() (params.ControllerInfo, error) {
|
|
|
|
|
if _, err := s.ControllerInfo(); err == nil {
|
|
|
|
|
return params.ControllerInfo{}, runnerErrors.NewConflictError("controller already initialized")
|
|
|
|
|
}
|
|
|
|
|
|
2023-07-04 14:22:41 +00:00
|
|
|
newID, err := uuid.NewRandom()
|
2022-05-04 13:15:27 +00:00
|
|
|
if err != nil {
|
2025-08-16 19:31:58 +00:00
|
|
|
return params.ControllerInfo{}, fmt.Errorf("error generating UUID: %w", err)
|
2022-05-04 13:15:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
newInfo := ControllerInfo{
|
2024-07-01 10:27:31 +00:00
|
|
|
ControllerID: newID,
|
|
|
|
|
MinimumJobAgeBackoff: 30,
|
2022-05-04 13:15:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
q := s.conn.Save(&newInfo)
|
|
|
|
|
if q.Error != nil {
|
2025-08-16 19:31:58 +00:00
|
|
|
return params.ControllerInfo{}, fmt.Errorf("error saving controller info: %w", q.Error)
|
2022-05-04 13:15:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return params.ControllerInfo{
|
|
|
|
|
ControllerID: newInfo.ControllerID,
|
|
|
|
|
}, nil
|
|
|
|
|
}
|
2024-06-05 06:41:16 +00:00
|
|
|
|
2024-06-14 20:24:45 +00:00
|
|
|
func (s *sqlDatabase) UpdateController(info params.UpdateControllerParams) (paramInfo params.ControllerInfo, err error) {
|
|
|
|
|
defer func() {
|
|
|
|
|
if err == nil {
|
|
|
|
|
s.sendNotify(common.ControllerEntityType, common.UpdateOperation, paramInfo)
|
|
|
|
|
}
|
|
|
|
|
}()
|
2024-06-05 06:41:16 +00:00
|
|
|
var dbInfo ControllerInfo
|
2024-06-14 20:24:45 +00:00
|
|
|
err = s.conn.Transaction(func(tx *gorm.DB) error {
|
|
|
|
|
q := tx.Model(&ControllerInfo{}).First(&dbInfo)
|
|
|
|
|
if q.Error != nil {
|
|
|
|
|
if errors.Is(q.Error, gorm.ErrRecordNotFound) {
|
2025-08-16 19:31:58 +00:00
|
|
|
return fmt.Errorf("error fetching controller info: %w", runnerErrors.ErrNotFound)
|
2024-06-14 20:24:45 +00:00
|
|
|
}
|
2025-08-16 19:31:58 +00:00
|
|
|
return fmt.Errorf("error fetching controller info: %w", q.Error)
|
2024-06-05 06:41:16 +00:00
|
|
|
}
|
|
|
|
|
|
2024-06-14 20:24:45 +00:00
|
|
|
if err := info.Validate(); err != nil {
|
2025-08-16 19:31:58 +00:00
|
|
|
return fmt.Errorf("error validating controller info: %w", err)
|
2024-06-14 20:24:45 +00:00
|
|
|
}
|
2024-06-05 06:41:16 +00:00
|
|
|
|
2024-06-14 20:24:45 +00:00
|
|
|
if info.MetadataURL != nil {
|
|
|
|
|
dbInfo.MetadataURL = *info.MetadataURL
|
|
|
|
|
}
|
2024-06-05 06:41:16 +00:00
|
|
|
|
2024-06-14 20:24:45 +00:00
|
|
|
if info.CallbackURL != nil {
|
|
|
|
|
dbInfo.CallbackURL = *info.CallbackURL
|
|
|
|
|
}
|
2024-06-05 06:41:16 +00:00
|
|
|
|
2024-06-14 20:24:45 +00:00
|
|
|
if info.WebhookURL != nil {
|
|
|
|
|
dbInfo.WebhookBaseURL = *info.WebhookURL
|
|
|
|
|
}
|
2024-06-05 06:41:16 +00:00
|
|
|
|
2024-07-01 10:27:31 +00:00
|
|
|
if info.MinimumJobAgeBackoff != nil {
|
|
|
|
|
dbInfo.MinimumJobAgeBackoff = *info.MinimumJobAgeBackoff
|
|
|
|
|
}
|
|
|
|
|
|
2024-06-14 20:24:45 +00:00
|
|
|
q = tx.Save(&dbInfo)
|
|
|
|
|
if q.Error != nil {
|
2025-08-16 19:31:58 +00:00
|
|
|
return fmt.Errorf("error saving controller info: %w", q.Error)
|
2024-06-14 20:24:45 +00:00
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
})
|
|
|
|
|
if err != nil {
|
2025-08-16 19:31:58 +00:00
|
|
|
return params.ControllerInfo{}, fmt.Errorf("error updating controller info: %w", err)
|
2024-06-05 06:41:16 +00:00
|
|
|
}
|
|
|
|
|
|
2024-06-14 20:24:45 +00:00
|
|
|
paramInfo, err = dbControllerToCommonController(dbInfo)
|
2024-06-05 06:41:16 +00:00
|
|
|
if err != nil {
|
2025-08-16 19:31:58 +00:00
|
|
|
return params.ControllerInfo{}, fmt.Errorf("error converting controller info: %w", err)
|
2024-06-05 06:41:16 +00:00
|
|
|
}
|
|
|
|
|
return paramInfo, nil
|
|
|
|
|
}
|