37baabe134
* EE-384: add endpoint to set auto backup (#224) * EE-383: add endpoint to fetch backup settings (#231) * add get backup settings handler * add api docs desc * EE-382: restore from s3 (#233) * EE-381: add GET backup status handler (#234) * EE-385: Add S3 backup execute handler (#237) * add s3 backup execute handler * refactories inside `./api/backup/backup_scheduler.go` and `./api/backup/backup_scheduler.go` * fix tests * EE-375: added backup to S3 form * EE-376: added restore from S3 form * EE-377: Update Home screen to display last backup run status * update backup service with back end endpoints. * restart admin monitor during s3 restores * use go 1.13 * go 1.13 compatibility * EE-375: added cron-validator lib * EE-375: using enum to compare form types * EE-375: validate cron rule field * try fix windows build * EE-375 EE-376 backup and restore forms validation changes * fix(autobackup): update autobackup settings validation rules (#260) * fix(autobackup): automate backup to s3 fe update (#261) * EE-292: fixed typo in property. * EE-292: updated auto backup front end validation. * EE-292: updated lib to validate cron rule in front end * fix dependencies * bumped libcompose version Co-authored-by: Hui <arris_li@hotmail.com> Co-authored-by: Felix Han <felix.han@portainer.io> Co-authored-by: fhanportainer <79428273+fhanportainer@users.noreply.github.com>
70 lines
2.1 KiB
Go
70 lines
2.1 KiB
Go
package backup
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/robfig/cron/v3"
|
|
|
|
"github.com/pkg/errors"
|
|
httperror "github.com/portainer/libhttp/error"
|
|
"github.com/portainer/libhttp/request"
|
|
portainer "github.com/portainer/portainer/api"
|
|
)
|
|
|
|
type backupSettings struct {
|
|
portainer.S3BackupSettings
|
|
}
|
|
|
|
func (p *backupSettings) Validate(r *http.Request) error {
|
|
if p.CronRule == "" {
|
|
return nil
|
|
}
|
|
if _, err := cron.ParseStandard(p.CronRule); err != nil {
|
|
return errors.New("invalid cron rule")
|
|
}
|
|
if p.AccessKeyID == "" {
|
|
return errors.New("missing AccessKeyID")
|
|
}
|
|
if p.SecretAccessKey == "" {
|
|
return errors.New("missing SecretAccessKey")
|
|
}
|
|
if p.Region == "" {
|
|
return errors.New("missing Region")
|
|
}
|
|
if p.BucketName == "" {
|
|
return errors.New("missing BucketName")
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// @id UpdateS3Settings
|
|
// @summary Updates stored s3 backup settings and updates running cron jobs as needed
|
|
// @description Updates stored s3 backup settings and updates running cron jobs as needed
|
|
// @description **Access policy**: admin
|
|
// @tags backup
|
|
// @security jwt
|
|
// @produce json
|
|
// @param CronRule body string false "Crontab rule to make periodical backups"
|
|
// @param AccessKeyID body string false "AWS access key id"
|
|
// @param SecretAccessKey body string false "AWS secret access key"
|
|
// @param Region body string false "AWS S3 region"
|
|
// @param BucketName body string false "AWS S3 bucket name"
|
|
// @param Password body string false "Password to encrypt the backup with"
|
|
// @success 200 "Success"
|
|
// @failure 400 "Invalid request"
|
|
// @failure 500 "Server error"
|
|
// @router /backup/s3/settings [post]
|
|
func (h *Handler) updateSettings(w http.ResponseWriter, r *http.Request) *httperror.HandlerError {
|
|
var payload backupSettings
|
|
err := request.DecodeAndValidateJSONPayload(r, &payload)
|
|
if err != nil {
|
|
return &httperror.HandlerError{StatusCode: http.StatusBadRequest, Message: "Invalid request payload", Err: err}
|
|
}
|
|
|
|
if err := h.backupScheduler.Update(payload.S3BackupSettings); err != nil {
|
|
return &httperror.HandlerError{StatusCode: http.StatusInternalServerError, Message: "Couldn't update backup settings", Err: err}
|
|
}
|
|
|
|
return nil
|
|
}
|