This repository has been archived by the owner on Aug 21, 2023. It is now read-only.
/
model_failure.go
115 lines (93 loc) · 2.92 KB
/
model_failure.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/*
Npcf_EventExposure
PCF Event Exposure Service. © 2022, 3GPP Organizational Partners (ARIB, ATIS, CCSA, ETSI, TSDSI, TTA, TTC). All rights reserved.
API version: 1.3.0-alpha.1
*/
// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
package openapi_Npcf_EventExposure
import (
"encoding/json"
"fmt"
)
// Failure - Possible values are: - UNSPECIFIED: Indicates the PCF received the UE sent UE policy delivery service cause #111 (Protocol error, unspecified). - UE_NOT_REACHABLE: Indicates the PCF received the notification from the AMF that the UE is not reachable. - UNKNOWN: Indicates unknown reasons upon no response from the UE, e.g. UPDS message type is not defined or not implemented by the UE, or not compatible with the UPDS state, in which the UE shall ignore the UPDS message. - UE_TEMP_UNREACHABLE: Indicates the PCF received the notification from the AMF that the UE is not reachable but the PCF will retry again.
type Failure struct {
String *string
}
// stringAsFailure is a convenience function that returns string wrapped in Failure
func StringAsFailure(v *string) Failure {
return Failure{
String: v,
}
}
// Unmarshal JSON data into one of the pointers in the struct
func (dst *Failure) UnmarshalJSON(data []byte) error {
var err error
match := 0
// try to unmarshal data into String
err = newStrictDecoder(data).Decode(&dst.String)
if err == nil {
jsonString, _ := json.Marshal(dst.String)
if string(jsonString) == "{}" { // empty struct
dst.String = nil
} else {
match++
}
} else {
dst.String = nil
}
if match > 1 { // more than 1 match
// reset to nil
dst.String = nil
return fmt.Errorf("data matches more than one schema in oneOf(Failure)")
} else if match == 1 {
return nil // exactly one match
} else { // no match
return fmt.Errorf("data failed to match schemas in oneOf(Failure)")
}
}
// Marshal data from the first non-nil pointers in the struct to JSON
func (src Failure) MarshalJSON() ([]byte, error) {
if src.String != nil {
return json.Marshal(&src.String)
}
return nil, nil // no data in oneOf schemas
}
// Get the actual instance
func (obj *Failure) GetActualInstance() interface{} {
if obj == nil {
return nil
}
if obj.String != nil {
return obj.String
}
// all schemas are nil
return nil
}
type NullableFailure struct {
value *Failure
isSet bool
}
func (v NullableFailure) Get() *Failure {
return v.value
}
func (v *NullableFailure) Set(val *Failure) {
v.value = val
v.isSet = true
}
func (v NullableFailure) IsSet() bool {
return v.isSet
}
func (v *NullableFailure) Unset() {
v.value = nil
v.isSet = false
}
func NewNullableFailure(val *Failure) *NullableFailure {
return &NullableFailure{value: val, isSet: true}
}
func (v NullableFailure) MarshalJSON() ([]byte, error) {
return json.Marshal(v.value)
}
func (v *NullableFailure) UnmarshalJSON(src []byte) error {
v.isSet = true
return json.Unmarshal(src, &v.value)
}