happyDomain/model/correction.go
Pierre-Olivier Mercier 7081f3d571 Add binding:required tags and narrow input types for API endpoints
Introduce dedicated input types (DomainUpdateInput, SessionInput) to limit
writable fields on update endpoints, and add binding:required tags across
model structs to improve validation and Swagger documentation accuracy.
2026-04-04 22:05:28 +07:00

43 lines
1.5 KiB
Go

// This file is part of the happyDomain (R) project.
// Copyright (c) 2020-2024 happyDomain
// Authors: Pierre-Olivier Mercier, et al.
//
// This program is offered under a commercial and under the AGPL license.
// For commercial licensing, contact us at <contact@happydomain.org>.
//
// 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.
//
// 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.
//
// 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/>.
package happydns
import ()
type CorrectionKind uint8
const (
_ CorrectionKind = iota // Skip 0
CorrectionKindAddition
CorrectionKindUpdate
CorrectionKindDeletion
CorrectionKindOther CorrectionKind = 99
)
type Correction struct {
F func() error `json:"-"`
Id Identifier `json:"id,omitempty" swaggertype:"string"`
Msg string `json:"msg" binding:"required"`
Kind CorrectionKind `json:"kind" binding:"required"`
OldRecords []Record `json:"-"`
NewRecords []Record `json:"-"`
}