-
Notifications
You must be signed in to change notification settings - Fork 82
/
export.go
119 lines (103 loc) · 5.24 KB
/
export.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
116
117
118
119
// Copyright (c) 2016, 2018, 2020, 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.
// File Storage API
//
// API for the File Storage service. Use this API to manage file systems, mount targets, and snapshots. For more information, see Overview of File Storage (https://docs.cloud.oracle.com/iaas/Content/File/Concepts/filestorageoverview.htm).
//
package filestorage
import (
"github.com/oracle/oci-go-sdk/common"
)
// Export A file system and the path that you can use to mount it. Each export
// resource belongs to exactly one export set.
// The export's path attribute is not a path in the
// referenced file system, but the value used by clients for the path
// component of the remotetarget argument when mounting the file
// system.
// The path must start with a slash (/) followed by a sequence of zero or more
// slash-separated path elements. For any two export resources associated with
// the same export set, except those in a 'DELETED' state, the path element
// sequence for the first export resource can't contain the
// complete path element sequence of the second export resource.
//
// For example, the following are acceptable:
// * /example and /path
// * /example1 and /example2
// * /example and /example1
// The following examples are not acceptable:
// * /example and /example/path
// * / and /example
// Paths may not end in a slash (/). No path element can be a period (.)
// or two periods in sequence (..). All path elements must be 255 bytes or less.
// No two non-'DELETED' export resources in the same export set can
// reference the same file system.
// Use `exportOptions` to control access to an export. For more information, see
// Export Options (https://docs.cloud.oracle.com/Content/File/Tasks/exportoptions.htm).
// **Warning:** Oracle recommends that you avoid using any confidential information when you supply string values using the API.
type Export struct {
// Policies that apply to NFS requests made through this
// export. `exportOptions` contains a sequential list of
// `ClientOptions`. Each `ClientOptions` item defines the
// export options that are applied to a specified
// set of clients.
// For each NFS request, the first `ClientOptions` option
// in the list whose `source` attribute matches the source
// IP address of the request is applied.
// If a client source IP address does not match the `source`
// property of any `ClientOptions` in the list, then the
// export will be invisible to that client. This export will
// not be returned by `MOUNTPROC_EXPORT` calls made by the client
// and any attempt to mount or access the file system through
// this export will result in an error.
// **Exports without defined `ClientOptions` are invisible to all clients.**
// If one export is invisible to a particular client, associated file
// systems may still be accessible through other exports on the same
// or different mount targets.
// To completely deny client access to a file system, be sure that the client
// source IP address is not included in any export for any mount target
// associated with the file system.
ExportOptions []ClientOptions `mandatory:"true" json:"exportOptions"`
// The OCID of this export's export set.
ExportSetId *string `mandatory:"true" json:"exportSetId"`
// The OCID of this export's file system.
FileSystemId *string `mandatory:"true" json:"fileSystemId"`
// The OCID of this export.
Id *string `mandatory:"true" json:"id"`
// The current state of this export.
LifecycleState ExportLifecycleStateEnum `mandatory:"true" json:"lifecycleState"`
// Path used to access the associated file system.
// Avoid entering confidential information.
// Example: `/accounting`
Path *string `mandatory:"true" json:"path"`
// The date and time the export was created, expressed
// in RFC 3339 (https://tools.ietf.org/rfc/rfc3339) timestamp format.
// Example: `2016-08-25T21:10:29.600Z`
TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"`
}
func (m Export) String() string {
return common.PointerString(m)
}
// ExportLifecycleStateEnum Enum with underlying type: string
type ExportLifecycleStateEnum string
// Set of constants representing the allowable values for ExportLifecycleStateEnum
const (
ExportLifecycleStateCreating ExportLifecycleStateEnum = "CREATING"
ExportLifecycleStateActive ExportLifecycleStateEnum = "ACTIVE"
ExportLifecycleStateDeleting ExportLifecycleStateEnum = "DELETING"
ExportLifecycleStateDeleted ExportLifecycleStateEnum = "DELETED"
)
var mappingExportLifecycleState = map[string]ExportLifecycleStateEnum{
"CREATING": ExportLifecycleStateCreating,
"ACTIVE": ExportLifecycleStateActive,
"DELETING": ExportLifecycleStateDeleting,
"DELETED": ExportLifecycleStateDeleted,
}
// GetExportLifecycleStateEnumValues Enumerates the set of values for ExportLifecycleStateEnum
func GetExportLifecycleStateEnumValues() []ExportLifecycleStateEnum {
values := make([]ExportLifecycleStateEnum, 0)
for _, v := range mappingExportLifecycleState {
values = append(values, v)
}
return values
}