2023-12-24 10:18:08 +00:00
|
|
|
// This file is part of the happyDomain (R) project.
|
|
|
|
// Copyright (c) 2020-2024 happyDomain
|
|
|
|
// Authors: Pierre-Olivier Mercier, et al.
|
2020-07-18 01:35:27 +00:00
|
|
|
//
|
2023-12-24 10:18:08 +00:00
|
|
|
// This program is offered under a commercial and under the AGPL license.
|
|
|
|
// For commercial licensing, contact us at <contact@happydomain.org>.
|
2020-07-18 01:35:27 +00:00
|
|
|
//
|
2023-12-24 10:18:08 +00:00
|
|
|
// For AGPL licensing:
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU Affero General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
2020-07-18 01:35:27 +00:00
|
|
|
//
|
2023-12-24 10:18:08 +00:00
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU Affero General Public License for more details.
|
2020-07-18 01:35:27 +00:00
|
|
|
//
|
2023-12-24 10:18:08 +00:00
|
|
|
// You should have received a copy of the GNU Affero General Public License
|
|
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
2020-07-18 01:35:27 +00:00
|
|
|
|
2020-10-10 16:46:28 +00:00
|
|
|
package api
|
2020-07-18 01:35:27 +00:00
|
|
|
|
|
|
|
import (
|
2021-05-05 01:48:16 +00:00
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
|
2023-09-07 09:37:18 +00:00
|
|
|
"git.happydns.org/happyDomain/config"
|
|
|
|
"git.happydns.org/happyDomain/forms"
|
|
|
|
"git.happydns.org/happyDomain/model"
|
2020-07-18 01:35:27 +00:00
|
|
|
)
|
|
|
|
|
2020-10-10 16:46:28 +00:00
|
|
|
type FormState struct {
|
2023-08-05 16:15:52 +00:00
|
|
|
// Id for an already existing element.
|
|
|
|
Id *happydns.Identifier `json:"_id,omitempty" swaggertype:"string"`
|
|
|
|
|
|
|
|
// User defined name of the element.
|
|
|
|
Name string `json:"_comment"`
|
|
|
|
|
|
|
|
// State is the desired form to shows next (starting at 0).
|
|
|
|
State int32 `json:"state"`
|
|
|
|
|
|
|
|
// Recall is the identifier for a saved FormState you want to retrieve.
|
|
|
|
Recall string `json:"recall,omitempty"`
|
2020-10-10 16:46:28 +00:00
|
|
|
}
|
2020-07-18 01:35:27 +00:00
|
|
|
|
2022-12-22 11:56:24 +00:00
|
|
|
func formDoState(cfg *config.Options, c *gin.Context, fs *FormState, data interface{}, defaultForm func(interface{}) *forms.CustomForm) (form *forms.CustomForm, d map[string]interface{}, err error) {
|
2021-05-05 01:48:16 +00:00
|
|
|
session := c.MustGet("MySession").(*happydns.Session)
|
|
|
|
|
2020-10-10 16:46:28 +00:00
|
|
|
csf, ok := data.(forms.CustomSettingsForm)
|
|
|
|
if !ok {
|
|
|
|
if fs.State == 1 {
|
|
|
|
err = forms.DoneForm
|
2020-07-18 01:35:27 +00:00
|
|
|
} else {
|
2020-10-10 16:46:28 +00:00
|
|
|
form = defaultForm(data)
|
2020-07-18 01:35:27 +00:00
|
|
|
}
|
2020-10-10 16:46:28 +00:00
|
|
|
return
|
|
|
|
} else {
|
2022-12-22 11:56:24 +00:00
|
|
|
return csf.DisplaySettingsForm(fs.State, cfg, session, func() string {
|
|
|
|
return fs.Recall
|
2020-10-10 16:46:28 +00:00
|
|
|
})
|
2020-07-18 01:35:27 +00:00
|
|
|
}
|
|
|
|
}
|