/
compression.go
104 lines (89 loc) · 3.67 KB
/
compression.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
// Copyright (c) 2016, 2018, 2024, Oracle and/or its affiliates. All rights reserved.
// This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
// Code generated. DO NOT EDIT.
// Data Integration API
//
// Use the Data Integration API to organize your data integration projects, create data flows, pipelines and tasks, and then publish, schedule, and run tasks that extract, transform, and load data. For more information, see Data Integration (https://docs.oracle.com/iaas/data-integration/home.htm).
//
package dataintegration
import (
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// Compression The optional compression configuration.
type Compression struct {
// Compression algorithm
Codec CompressionCodecEnum `mandatory:"false" json:"codec,omitempty"`
}
func (m Compression) String() string {
return common.PointerString(m)
}
// ValidateEnumValue returns an error when providing an unsupported enum value
// This function is being called during constructing API request process
// Not recommended for calling this function directly
func (m Compression) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if _, ok := GetMappingCompressionCodecEnum(string(m.Codec)); !ok && m.Codec != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for Codec: %s. Supported values are: %s.", m.Codec, strings.Join(GetCompressionCodecEnumStringValues(), ",")))
}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}
// CompressionCodecEnum Enum with underlying type: string
type CompressionCodecEnum string
// Set of constants representing the allowable values for CompressionCodecEnum
const (
CompressionCodecNone CompressionCodecEnum = "NONE"
CompressionCodecAuto CompressionCodecEnum = "AUTO"
CompressionCodecGzip CompressionCodecEnum = "GZIP"
CompressionCodecBzip2 CompressionCodecEnum = "BZIP2"
CompressionCodecDeflate CompressionCodecEnum = "DEFLATE"
CompressionCodecLz4 CompressionCodecEnum = "LZ4"
CompressionCodecSnappy CompressionCodecEnum = "SNAPPY"
)
var mappingCompressionCodecEnum = map[string]CompressionCodecEnum{
"NONE": CompressionCodecNone,
"AUTO": CompressionCodecAuto,
"GZIP": CompressionCodecGzip,
"BZIP2": CompressionCodecBzip2,
"DEFLATE": CompressionCodecDeflate,
"LZ4": CompressionCodecLz4,
"SNAPPY": CompressionCodecSnappy,
}
var mappingCompressionCodecEnumLowerCase = map[string]CompressionCodecEnum{
"none": CompressionCodecNone,
"auto": CompressionCodecAuto,
"gzip": CompressionCodecGzip,
"bzip2": CompressionCodecBzip2,
"deflate": CompressionCodecDeflate,
"lz4": CompressionCodecLz4,
"snappy": CompressionCodecSnappy,
}
// GetCompressionCodecEnumValues Enumerates the set of values for CompressionCodecEnum
func GetCompressionCodecEnumValues() []CompressionCodecEnum {
values := make([]CompressionCodecEnum, 0)
for _, v := range mappingCompressionCodecEnum {
values = append(values, v)
}
return values
}
// GetCompressionCodecEnumStringValues Enumerates the set of values in String for CompressionCodecEnum
func GetCompressionCodecEnumStringValues() []string {
return []string{
"NONE",
"AUTO",
"GZIP",
"BZIP2",
"DEFLATE",
"LZ4",
"SNAPPY",
}
}
// GetMappingCompressionCodecEnum performs case Insensitive comparison on enum value and return the desired enum
func GetMappingCompressionCodecEnum(val string) (CompressionCodecEnum, bool) {
enum, ok := mappingCompressionCodecEnumLowerCase[strings.ToLower(val)]
return enum, ok
}