mirror of https://github.com/pulumi/pulumi.git
125 lines
3.9 KiB
Python
125 lines
3.9 KiB
Python
# Copyright 2016-2018, Pulumi Corporation.
|
|
#
|
|
# 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
|
|
#
|
|
# http://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.
|
|
|
|
"""
|
|
Assets are the Pulumi notion of data blobs that can be passed to resources.
|
|
"""
|
|
from os import PathLike, fspath
|
|
from typing import Dict, Union
|
|
|
|
|
|
class Asset:
|
|
"""
|
|
Asset represents a single blob of text or data that is managed as a first
|
|
class entity.
|
|
"""
|
|
|
|
|
|
class FileAsset(Asset):
|
|
"""
|
|
A FileAsset is a kind of asset produced from a given path to a file on
|
|
the local filesystem.
|
|
"""
|
|
|
|
path: str
|
|
|
|
def __init__(self, path: Union[str, PathLike]) -> None:
|
|
if not isinstance(path, (str, PathLike)):
|
|
raise TypeError("FileAsset path must be a string or os.PathLike")
|
|
self.path = fspath(path)
|
|
|
|
|
|
class StringAsset(Asset):
|
|
"""
|
|
A StringAsset is a kind of asset produced from an in-memory UTF-8 encoded string.
|
|
"""
|
|
|
|
text: str
|
|
|
|
def __init__(self, text: str) -> None:
|
|
if not isinstance(text, str):
|
|
raise TypeError("StringAsset data must be a string")
|
|
self.text = text
|
|
|
|
|
|
class RemoteAsset(Asset):
|
|
"""
|
|
A RemoteAsset is a kind of asset produced from a given URI string. The URI's scheme
|
|
dictates the protocol for fetching contents: "file://" specifies a local file, "http://"
|
|
and "https://" specify HTTP and HTTPS, respectively. Note that specific providers may recognize
|
|
alternative schemes; this is merely the base-most set that all providers support.
|
|
"""
|
|
|
|
uri: str
|
|
|
|
def __init__(self, uri: str) -> None:
|
|
if not isinstance(uri, str):
|
|
raise TypeError("RemoteAsset URI must be a string")
|
|
self.uri = uri
|
|
|
|
|
|
class Archive:
|
|
"""
|
|
Archive represents a collection of named assets.
|
|
"""
|
|
|
|
|
|
class AssetArchive(Archive):
|
|
"""
|
|
An AssetArchive is an archive created from an in-memory collection of named assets or other archives.
|
|
"""
|
|
|
|
assets: Dict[str, Union[Asset, Archive]]
|
|
|
|
def __init__(self, assets: Dict[str, Union[Asset, Archive]]) -> None:
|
|
if not isinstance(assets, dict):
|
|
raise TypeError("AssetArchive assets must be a dictionary")
|
|
for k, v in assets.items():
|
|
if not isinstance(k, str):
|
|
raise TypeError("AssetArchive keys must be strings")
|
|
if not isinstance(v, Asset) and not isinstance(v, Archive):
|
|
raise TypeError(
|
|
"AssetArchive assets must contain only Assets or Archives"
|
|
)
|
|
self.assets = assets
|
|
|
|
|
|
class FileArchive(Archive):
|
|
"""
|
|
A FileArchive is a file-based archive, or collection of file-based assets. This can be
|
|
a raw directory or a single archive file in one of the supported formats (.tar, .tar.gz, or .zip).
|
|
"""
|
|
|
|
path: str
|
|
|
|
def __init__(self, path: str) -> None:
|
|
if not isinstance(path, str):
|
|
raise TypeError("FileArchive path must be a string")
|
|
self.path = path
|
|
|
|
|
|
class RemoteArchive(Archive):
|
|
"""
|
|
A RemoteArchive is a file-based archive fetched from a remote location. The URI's scheme dictates
|
|
the protocol for fetching contents: "file://" specifies a local file, "http://" and "https://"
|
|
specify HTTP and HTTPS, respectively, and specific providers may recognize custom schemes.
|
|
"""
|
|
|
|
uri: str
|
|
|
|
def __init__(self, uri: str) -> None:
|
|
if not isinstance(uri, str):
|
|
raise TypeError("RemoteArchive URI must be a string")
|
|
self.uri = uri
|