-
Notifications
You must be signed in to change notification settings - Fork 264
Expand file tree
/
Copy pathUnixSocketConfiguration.swift
More file actions
70 lines (61 loc) · 2.62 KB
/
UnixSocketConfiguration.swift
File metadata and controls
70 lines (61 loc) · 2.62 KB
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
//===----------------------------------------------------------------------===//
// Copyright © 2025 Apple Inc. and the Containerization project authors.
// All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//===----------------------------------------------------------------------===//
import Foundation
import SystemPackage
/// Represents a UnixSocket that can be shared into or out of a container/guest.
public struct UnixSocketConfiguration: Sendable {
// TODO: Realistically, we can just hash this struct and use it as the "id".
package var id: String {
_id
}
private let _id = UUID().uuidString
/// The path to the socket you'd like relayed. For .into
/// direction this should be the path on the host to a unix socket.
/// For direction .outOf this should be the path in the container/guest
/// to a unix socket.
public var from: URL
/// The path you'd like the socket to be relayed to. For .into
/// direction this should be ther path in the container/guest. For
/// direction .outOf this should be the path on your host.
public var to: URL
/// What to set the file permissions of the unix socket being created
/// to. For .into direction this will be the socket in the guest. For
/// .outOf direction this will be the socket on the host.
public var permissions: FilePermissions?
/// The direction of the relay. `.into` for sharing a unix socket on your
/// host into the container/guest. `outOf` shares a socket in the container/guest
/// onto your host.
public var direction: Direction
/// Type that denotes the direction of the unix socket relay.
public enum Direction: Sendable {
/// Share the socket into the container/guest.
case into
/// Share a socket in the container/guest onto the host.
case outOf
}
public init(
host: URL,
destination: URL,
permissions: FilePermissions? = nil,
direction: Direction = .into
) {
self.from = host
self.to = destination
self.permissions = permissions
self.direction = direction
}
}