Pieces OS Client Python SDK Assets
Use the following methods to manage your assets with the Pieces OS Client Python SDK.
Asset Management
create_asset()
Creates a new asset.
create_asset(content, metadata)
Parameters
Param Name | Param Type | Param Notes |
---|---|---|
content | string | [required] |
metadata | FragmentMetadata | [optional] |
Example
from pieces_os_client.wrapper import PiecesClient
from pieces_os_client import ClassificationSpecificEnum, FragmentMetadata
# Replace 'your_base_url' with the base URL of your Pieces OS server
pieces_client = PiecesClient(config={'host': 'your_base_url'})
# Set the content and metadata for the new asset
content = "print('Hello, World!')"
metadata = FragmentMetadata(ext=ClassificationSpecificEnum.PY) # optional metadata
# Create the new asset using the content and metadata
new_asset_id = pieces_client.create_asset(content, metadata)
print(f"Created asset with ID: {new_asset_id}")
# Close the client
pieces_client.close()
asset()
Gets a specific asset.
asset(asset_id)
Parameters
Param Name | Param Type | Param Notes |
---|---|---|
asset_id | string | [required] |
Example
from pieces_os_client.wrapper import PiecesClient
# Replace 'your_base_url' with the base URL of your Pieces OS server
pieces_client = PiecesClient(config={'host': 'your_base_url'})
# Get the asset ID
asset_id = "your_asset_id"
# Retrieve the asset
asset = pieces_client.asset(asset_id)
# Close the client
pieces_client.close()
assets()
Gets all your assets.
assets()
Example
from pieces_os_client.wrapper import PiecesClient
# Replace 'your_base_url' with the base URL of your Pieces OS server
pieces_client = PiecesClient(config={'host': 'your_base_url'})
# Get all assets and print their names
assets = pieces_client.assets()
for asset in assets:
print(f"Asset Name: {asset.name}")
# Close the client
pieces_client.close()
BasicAsset Class
The BasicAsset
class provides a way to manage assets with various properties and methods.
Properties
Property Name | Property Description |
---|---|
id | The ID of the asset. |
asset | The full Asset object. Should only be used for properties not available in the BasicAsset class. |
raw_content | The content of the asset. |
is_image | Boolean indicating if the asset is an image. |
classification | The specific classification of the asset (e.g., py ). |
name | The name of the asset. |
description | The description of the asset. |
annotations | The annotations of the asset. |
Methods
create()
Creates a new asset.
Parameters
Param Name | Param Type | Param Description |
---|---|---|
raw_content | string | The raw content of the asset. |
metadata | Optional[FragmentMetadata] | The metadata of the asset. |
Returns
Return Type | Return Description |
---|---|
string | The ID of the created asset. |
Example
from pieces_os_client.wrapper import PiecesClient
from pieces_os_client.wrapper.basic_identifier.asset import BasicAsset
from pieces_os_client import ClassificationSpecificEnum, FragmentMetadata
# Replace 'your_base_url' with the base URL of your Pieces OS server
pieces_client = PiecesClient(config={'host': 'http://localhost:1000'})
# Create a new asset
content = "print('Hello, World!')"
metadata = FragmentMetadata(ext=ClassificationSpecificEnum.PY)
new_asset_id = BasicAsset.create(content, metadata)
print(f"New Asset ID: {new_asset_id}")
# Close the client
pieces_client.close()
delete()
Deletes the asset.
Example
# Retrieve the asset
asset = pieces_client.asset(asset_id)
# Delete the asset
asset.delete()
# Close the client
pieces_client.close()
raw_content
Updates the raw content of the asset.
Example
# Retrieve the asset
asset = pieces_client.asset(new_asset_id)
# Get the asset content
content = asset.raw_content
print(f"Original Content: {content}")
# Update the content
asset.raw_content = content + "\n# This is a comment"
print(f"Updated Content: {asset.raw_content}")
# Close the client
pieces_client.close()
classification
Updates the classification of the asset.
Example
# Retrieve the asset
asset = pieces_client.asset(new_asset_id)
# Get the asset classification
classification = asset.classification.value if asset.classification else "None"
print(f"Asset Classification: {classification}")
# Update the classification
asset.classification = ClassificationSpecificEnum.SH # Reclassify to shell
print(f"New Classification: {classification}")
# Close the client
pieces_client.close()
name
Updates the name of the asset.
Example
# Retrieve the asset
asset = pieces_client.asset(new_asset_id)
# Get the asset name
print(f"Current Asset Name: {asset.name}")
# Update the name
asset.name = "Updated Asset Name"
print(f"Updated Asset Name: {asset.name}")
# Close the client
pieces_client.close()
Full Example
from pieces_os_client.wrapper import PiecesClient
from pieces_os_client.basic_asset import BasicAsset
from pieces_os_client import ClassificationSpecificEnum
# Replace 'your_base_url' with your actual base URL
pieces_client = PiecesClient(config={'host': 'your_base_url'})
asset = pieces_client.assets()[0]
# Get the asset ID
asset_id = asset.id
print(f"Asset ID: {asset_id}")
# Get the full asset object (only for properties not available in BasicAsset)
full_asset = asset.asset
print(f"Full Asset Object: {full_asset}")
# Check if the asset is an image
if asset.is_image:
print("The asset is an image.")
else:
print("The asset is not an image.")
# Get and set the asset name
print(f"Current Asset Name: {asset.name}")
asset.name = "Updated Asset Name"
print(f"Updated Asset Name: {asset.name}")
# Retrieve and modify the asset content
content = asset.raw_content
print(f"Original Content: {content}")
asset.raw_content = content + "\n# This is a comment"
print(f"Updated Content: {asset.raw_content}")
# Get the asset classification
classification = asset.classification.value if asset.classification else "None"
print(f"Asset Classification: {classification}")
asset.classification = ClassificationSpecificEnum.SH # Reclassify to shell
print(f"New Classification: {classification}")
# Get the asset description
description = asset.description if asset.description else "No description available."
print(f"Asset Description: {description}")
# Get the asset annotations
annotations = asset.annotations if asset.annotations else "No annotations available."
print(f"Asset Annotations: {annotations}")
# Delete the asset
asset.delete()
print("Asset deleted.")
# Create a new asset
new_asset_id = BasicAsset.create("New Asset content")
print(f"New Asset ID: {new_asset_id}")
pieces_client.close()