projetAnsible/myenv/lib/python3.12/site-packages/pulumi_docker/volume.py
2024-12-09 06:16:28 +01:00

406 lines
15 KiB
Python

# coding=utf-8
# *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
# *** Do not edit by hand unless you're certain you know what you are doing! ***
import copy
import warnings
import sys
import pulumi
import pulumi.runtime
from typing import Any, Mapping, Optional, Sequence, Union, overload
if sys.version_info >= (3, 11):
from typing import NotRequired, TypedDict, TypeAlias
else:
from typing_extensions import NotRequired, TypedDict, TypeAlias
from . import _utilities
from . import outputs
from ._inputs import *
__all__ = ['VolumeArgs', 'Volume']
@pulumi.input_type
class VolumeArgs:
def __init__(__self__, *,
driver: Optional[pulumi.Input[str]] = None,
driver_opts: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]] = None,
labels: Optional[pulumi.Input[Sequence[pulumi.Input['VolumeLabelArgs']]]] = None,
name: Optional[pulumi.Input[str]] = None):
"""
The set of arguments for constructing a Volume resource.
:param pulumi.Input[str] driver: Driver type for the volume. Defaults to `local`.
:param pulumi.Input[Mapping[str, pulumi.Input[str]]] driver_opts: Options specific to the driver.
:param pulumi.Input[Sequence[pulumi.Input['VolumeLabelArgs']]] labels: User-defined key/value metadata
:param pulumi.Input[str] name: The name of the Docker volume (will be generated if not provided).
"""
if driver is not None:
pulumi.set(__self__, "driver", driver)
if driver_opts is not None:
pulumi.set(__self__, "driver_opts", driver_opts)
if labels is not None:
pulumi.set(__self__, "labels", labels)
if name is not None:
pulumi.set(__self__, "name", name)
@property
@pulumi.getter
def driver(self) -> Optional[pulumi.Input[str]]:
"""
Driver type for the volume. Defaults to `local`.
"""
return pulumi.get(self, "driver")
@driver.setter
def driver(self, value: Optional[pulumi.Input[str]]):
pulumi.set(self, "driver", value)
@property
@pulumi.getter(name="driverOpts")
def driver_opts(self) -> Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]]:
"""
Options specific to the driver.
"""
return pulumi.get(self, "driver_opts")
@driver_opts.setter
def driver_opts(self, value: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]]):
pulumi.set(self, "driver_opts", value)
@property
@pulumi.getter
def labels(self) -> Optional[pulumi.Input[Sequence[pulumi.Input['VolumeLabelArgs']]]]:
"""
User-defined key/value metadata
"""
return pulumi.get(self, "labels")
@labels.setter
def labels(self, value: Optional[pulumi.Input[Sequence[pulumi.Input['VolumeLabelArgs']]]]):
pulumi.set(self, "labels", value)
@property
@pulumi.getter
def name(self) -> Optional[pulumi.Input[str]]:
"""
The name of the Docker volume (will be generated if not provided).
"""
return pulumi.get(self, "name")
@name.setter
def name(self, value: Optional[pulumi.Input[str]]):
pulumi.set(self, "name", value)
@pulumi.input_type
class _VolumeState:
def __init__(__self__, *,
driver: Optional[pulumi.Input[str]] = None,
driver_opts: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]] = None,
labels: Optional[pulumi.Input[Sequence[pulumi.Input['VolumeLabelArgs']]]] = None,
mountpoint: Optional[pulumi.Input[str]] = None,
name: Optional[pulumi.Input[str]] = None):
"""
Input properties used for looking up and filtering Volume resources.
:param pulumi.Input[str] driver: Driver type for the volume. Defaults to `local`.
:param pulumi.Input[Mapping[str, pulumi.Input[str]]] driver_opts: Options specific to the driver.
:param pulumi.Input[Sequence[pulumi.Input['VolumeLabelArgs']]] labels: User-defined key/value metadata
:param pulumi.Input[str] mountpoint: The mountpoint of the volume.
:param pulumi.Input[str] name: The name of the Docker volume (will be generated if not provided).
"""
if driver is not None:
pulumi.set(__self__, "driver", driver)
if driver_opts is not None:
pulumi.set(__self__, "driver_opts", driver_opts)
if labels is not None:
pulumi.set(__self__, "labels", labels)
if mountpoint is not None:
pulumi.set(__self__, "mountpoint", mountpoint)
if name is not None:
pulumi.set(__self__, "name", name)
@property
@pulumi.getter
def driver(self) -> Optional[pulumi.Input[str]]:
"""
Driver type for the volume. Defaults to `local`.
"""
return pulumi.get(self, "driver")
@driver.setter
def driver(self, value: Optional[pulumi.Input[str]]):
pulumi.set(self, "driver", value)
@property
@pulumi.getter(name="driverOpts")
def driver_opts(self) -> Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]]:
"""
Options specific to the driver.
"""
return pulumi.get(self, "driver_opts")
@driver_opts.setter
def driver_opts(self, value: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]]):
pulumi.set(self, "driver_opts", value)
@property
@pulumi.getter
def labels(self) -> Optional[pulumi.Input[Sequence[pulumi.Input['VolumeLabelArgs']]]]:
"""
User-defined key/value metadata
"""
return pulumi.get(self, "labels")
@labels.setter
def labels(self, value: Optional[pulumi.Input[Sequence[pulumi.Input['VolumeLabelArgs']]]]):
pulumi.set(self, "labels", value)
@property
@pulumi.getter
def mountpoint(self) -> Optional[pulumi.Input[str]]:
"""
The mountpoint of the volume.
"""
return pulumi.get(self, "mountpoint")
@mountpoint.setter
def mountpoint(self, value: Optional[pulumi.Input[str]]):
pulumi.set(self, "mountpoint", value)
@property
@pulumi.getter
def name(self) -> Optional[pulumi.Input[str]]:
"""
The name of the Docker volume (will be generated if not provided).
"""
return pulumi.get(self, "name")
@name.setter
def name(self, value: Optional[pulumi.Input[str]]):
pulumi.set(self, "name", value)
class Volume(pulumi.CustomResource):
@overload
def __init__(__self__,
resource_name: str,
opts: Optional[pulumi.ResourceOptions] = None,
driver: Optional[pulumi.Input[str]] = None,
driver_opts: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]] = None,
labels: Optional[pulumi.Input[Sequence[pulumi.Input[Union['VolumeLabelArgs', 'VolumeLabelArgsDict']]]]] = None,
name: Optional[pulumi.Input[str]] = None,
__props__=None):
"""
<!-- Bug: Type and Name are switched -->
Creates and destroys a volume in Docker. This can be used alongside Container to prepare volumes that can be shared across containers.
## Example Usage
```python
import pulumi
import pulumi_docker as docker
shared_volume = docker.Volume("shared_volume", name="shared_volume")
```
## Import
### Example
Assuming you created a `volume` as follows
#!/bin/bash
docker volume create
prints the long ID
524b0457aa2a87dd2b75c74c3e4e53f406974249e63ab3ed9bf21e5644f9dc7d
you provide the definition for the resource as follows
terraform
resource "docker_volume" "foo" {
name = "524b0457aa2a87dd2b75c74c3e4e53f406974249e63ab3ed9bf21e5644f9dc7d"
}
then the import command is as follows
#!/bin/bash
```sh
$ pulumi import docker:index/volume:Volume foo 524b0457aa2a87dd2b75c74c3e4e53f406974249e63ab3ed9bf21e5644f9dc7d
```
:param str resource_name: The name of the resource.
:param pulumi.ResourceOptions opts: Options for the resource.
:param pulumi.Input[str] driver: Driver type for the volume. Defaults to `local`.
:param pulumi.Input[Mapping[str, pulumi.Input[str]]] driver_opts: Options specific to the driver.
:param pulumi.Input[Sequence[pulumi.Input[Union['VolumeLabelArgs', 'VolumeLabelArgsDict']]]] labels: User-defined key/value metadata
:param pulumi.Input[str] name: The name of the Docker volume (will be generated if not provided).
"""
...
@overload
def __init__(__self__,
resource_name: str,
args: Optional[VolumeArgs] = None,
opts: Optional[pulumi.ResourceOptions] = None):
"""
<!-- Bug: Type and Name are switched -->
Creates and destroys a volume in Docker. This can be used alongside Container to prepare volumes that can be shared across containers.
## Example Usage
```python
import pulumi
import pulumi_docker as docker
shared_volume = docker.Volume("shared_volume", name="shared_volume")
```
## Import
### Example
Assuming you created a `volume` as follows
#!/bin/bash
docker volume create
prints the long ID
524b0457aa2a87dd2b75c74c3e4e53f406974249e63ab3ed9bf21e5644f9dc7d
you provide the definition for the resource as follows
terraform
resource "docker_volume" "foo" {
name = "524b0457aa2a87dd2b75c74c3e4e53f406974249e63ab3ed9bf21e5644f9dc7d"
}
then the import command is as follows
#!/bin/bash
```sh
$ pulumi import docker:index/volume:Volume foo 524b0457aa2a87dd2b75c74c3e4e53f406974249e63ab3ed9bf21e5644f9dc7d
```
:param str resource_name: The name of the resource.
:param VolumeArgs args: The arguments to use to populate this resource's properties.
:param pulumi.ResourceOptions opts: Options for the resource.
"""
...
def __init__(__self__, resource_name: str, *args, **kwargs):
resource_args, opts = _utilities.get_resource_args_opts(VolumeArgs, pulumi.ResourceOptions, *args, **kwargs)
if resource_args is not None:
__self__._internal_init(resource_name, opts, **resource_args.__dict__)
else:
__self__._internal_init(resource_name, *args, **kwargs)
def _internal_init(__self__,
resource_name: str,
opts: Optional[pulumi.ResourceOptions] = None,
driver: Optional[pulumi.Input[str]] = None,
driver_opts: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]] = None,
labels: Optional[pulumi.Input[Sequence[pulumi.Input[Union['VolumeLabelArgs', 'VolumeLabelArgsDict']]]]] = None,
name: Optional[pulumi.Input[str]] = None,
__props__=None):
opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
if not isinstance(opts, pulumi.ResourceOptions):
raise TypeError('Expected resource options to be a ResourceOptions instance')
if opts.id is None:
if __props__ is not None:
raise TypeError('__props__ is only valid when passed in combination with a valid opts.id to get an existing resource')
__props__ = VolumeArgs.__new__(VolumeArgs)
__props__.__dict__["driver"] = driver
__props__.__dict__["driver_opts"] = driver_opts
__props__.__dict__["labels"] = labels
__props__.__dict__["name"] = name
__props__.__dict__["mountpoint"] = None
super(Volume, __self__).__init__(
'docker:index/volume:Volume',
resource_name,
__props__,
opts)
@staticmethod
def get(resource_name: str,
id: pulumi.Input[str],
opts: Optional[pulumi.ResourceOptions] = None,
driver: Optional[pulumi.Input[str]] = None,
driver_opts: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]] = None,
labels: Optional[pulumi.Input[Sequence[pulumi.Input[Union['VolumeLabelArgs', 'VolumeLabelArgsDict']]]]] = None,
mountpoint: Optional[pulumi.Input[str]] = None,
name: Optional[pulumi.Input[str]] = None) -> 'Volume':
"""
Get an existing Volume resource's state with the given name, id, and optional extra
properties used to qualify the lookup.
:param str resource_name: The unique name of the resulting resource.
:param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
:param pulumi.ResourceOptions opts: Options for the resource.
:param pulumi.Input[str] driver: Driver type for the volume. Defaults to `local`.
:param pulumi.Input[Mapping[str, pulumi.Input[str]]] driver_opts: Options specific to the driver.
:param pulumi.Input[Sequence[pulumi.Input[Union['VolumeLabelArgs', 'VolumeLabelArgsDict']]]] labels: User-defined key/value metadata
:param pulumi.Input[str] mountpoint: The mountpoint of the volume.
:param pulumi.Input[str] name: The name of the Docker volume (will be generated if not provided).
"""
opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
__props__ = _VolumeState.__new__(_VolumeState)
__props__.__dict__["driver"] = driver
__props__.__dict__["driver_opts"] = driver_opts
__props__.__dict__["labels"] = labels
__props__.__dict__["mountpoint"] = mountpoint
__props__.__dict__["name"] = name
return Volume(resource_name, opts=opts, __props__=__props__)
@property
@pulumi.getter
def driver(self) -> pulumi.Output[str]:
"""
Driver type for the volume. Defaults to `local`.
"""
return pulumi.get(self, "driver")
@property
@pulumi.getter(name="driverOpts")
def driver_opts(self) -> pulumi.Output[Optional[Mapping[str, str]]]:
"""
Options specific to the driver.
"""
return pulumi.get(self, "driver_opts")
@property
@pulumi.getter
def labels(self) -> pulumi.Output[Optional[Sequence['outputs.VolumeLabel']]]:
"""
User-defined key/value metadata
"""
return pulumi.get(self, "labels")
@property
@pulumi.getter
def mountpoint(self) -> pulumi.Output[str]:
"""
The mountpoint of the volume.
"""
return pulumi.get(self, "mountpoint")
@property
@pulumi.getter
def name(self) -> pulumi.Output[str]:
"""
The name of the Docker volume (will be generated if not provided).
"""
return pulumi.get(self, "name")