Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Stack + stack component creation, updates and deletion #29

Merged
merged 46 commits into from
Jul 25, 2024
Merged
Show file tree
Hide file tree
Changes from 39 commits
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
2be54b2
feat: move panel observer code from DagRenderer to Panel
ErikWiens Jul 16, 2024
78128c9
feat: add panel opens when click on plus icon to create a new stack
ErikWiens Jul 17, 2024
e42f90c
add install script
strickvl Jul 16, 2024
ddc2cc4
Bump version
strickvl Jul 16, 2024
962ad91
Bump and remove preview setting
strickvl Jul 16, 2024
749b35f
fix: added dag-packed.js.map to gitignore
Christopher-R-Perkins Jul 17, 2024
87d38fe
fix: handled error when trying to stop a LS that is not running while…
Christopher-R-Perkins Jul 17, 2024
eecef5f
bump version
strickvl Jul 17, 2024
59e9909
fix: removed use of pydantic json() call from get_server_info due to …
Christopher-R-Perkins Jul 17, 2024
8e6127e
fix: Updated getGlobalConfig to not use pydantic json() call like get…
Christopher-R-Perkins Jul 17, 2024
70109cc
Bump version to 0.0.10
strickvl Jul 18, 2024
f019708
feat: Added Stack Components view to activity bar
Christopher-R-Perkins Jul 18, 2024
47cc7bd
feat: Added Refresh and ItemsPerPage commands to Components View
Christopher-R-Perkins Jul 18, 2024
ed47209
chore: Refactored Pagination in DataProviders to base class
Christopher-R-Perkins Jul 18, 2024
0dc748a
feature: Added listFlavors command to LS
Christopher-R-Perkins Jul 18, 2024
b8c172b
chore: Moved extension context functionality to new base class for Da…
Christopher-R-Perkins Jul 19, 2024
c6034f0
feat: Stack Form is now being rendered
Christopher-R-Perkins Jul 19, 2024
82cda5d
feat: move panel observer code from DagRenderer to Panel
ErikWiens Jul 16, 2024
dfc34cc
feat: add panel opens when click on plus icon to create a new stack
ErikWiens Jul 17, 2024
8b67d44
feat: Added Stack Components view to activity bar
Christopher-R-Perkins Jul 18, 2024
85dd63c
feat: Added Refresh and ItemsPerPage commands to Components View
Christopher-R-Perkins Jul 18, 2024
47af9e7
chore: Refactored Pagination in DataProviders to base class
Christopher-R-Perkins Jul 18, 2024
b62ee9c
feature: Added listFlavors command to LS
Christopher-R-Perkins Jul 18, 2024
7366ff0
chore: Moved extension context functionality to new base class for Da…
Christopher-R-Perkins Jul 19, 2024
c01a62f
feat: Stack Form is now being rendered
Christopher-R-Perkins Jul 19, 2024
ebbf5d4
Merge branch 'zenml-io-develop' into feature/mlstacks
Christopher-R-Perkins Jul 19, 2024
90b223c
feature: Added ability to Create/Update Stacks
Christopher-R-Perkins Jul 19, 2024
0d43baf
feat: Added create_component to zenml wrapper
Christopher-R-Perkins Jul 21, 2024
60a845c
feat: createComponent command added to component view
Christopher-R-Perkins Jul 21, 2024
453d7ad
feat: create component form is functional
Christopher-R-Perkins Jul 22, 2024
d076333
feat: improvements to validating and data types when submititing new …
Christopher-R-Perkins Jul 23, 2024
109551e
feat: added ability to update stack components
Christopher-R-Perkins Jul 23, 2024
55cfa65
feat: Added ability to delete stack components
Christopher-R-Perkins Jul 23, 2024
3c6636d
fix: Added page navigation when page is no longer valid on paginated …
Christopher-R-Perkins Jul 23, 2024
b0c7366
feat: Added ability to delete stacks.
Christopher-R-Perkins Jul 23, 2024
0238218
chore: Removed opening empty optional fields when updating a component.
Christopher-R-Perkins Jul 23, 2024
5758fec
chore: Added documentation to wrapper functions.
Christopher-R-Perkins Jul 23, 2024
07e0259
chore: Added documentation to added typescript features
Christopher-R-Perkins Jul 23, 2024
d6caec2
chore: Updated README description of features
Christopher-R-Perkins Jul 24, 2024
0cbacf0
chore: implemented code rabbit suggestions
Christopher-R-Perkins Jul 24, 2024
2d11525
chore: Added license to files missing it.
Christopher-R-Perkins Jul 24, 2024
ad400c3
fix: Added check if updated stack component data differs from schema …
Christopher-R-Perkins Jul 24, 2024
a033c0f
chore: Fixed typo contianing to containing
Christopher-R-Perkins Jul 24, 2024
6ed6acb
chore: replaced all mention of create with register
Christopher-R-Perkins Jul 24, 2024
ac4ec98
fix: Updated Content-Security-Policy on all three webviews and set pr…
Christopher-R-Perkins Jul 24, 2024
1bb20f9
chore: Changed create verbage in README to register
Christopher-R-Perkins Jul 24, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,8 @@ this extension and your Python version needs to be 3.8 or greater.
## Using ZenML in VSCode

- **Manage Server Connections**: Connect or disconnect from ZenML servers and refresh server status.
- **Stack Operations**: View stack details, rename, copy, or set active stacks directly from VSCode.
- **Stack Operations**: View stack details, create, update, delete, copy, or set active stacks directly from VSCode.
- **Stack Component Operations**: View stack component details, create, update, or delete stack components directly from VSCode.
- **Pipeline Runs**: Monitor and manage pipeline runs, including deleting runs from the system and rendering DAGs.
- **Environment Information**: Get detailed snapshots of the development environment, aiding troubleshooting.

Expand Down
94 changes: 82 additions & 12 deletions bundled/tool/lsp_zenml.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,9 @@
from zen_watcher import ZenConfigWatcher
from zenml_client import ZenMLClient

zenml_init_error = {"error": "ZenML is not initialized. Please check ZenML version requirements."}
zenml_init_error = {
"error": "ZenML is not initialized. Please check ZenML version requirements."
}


class ZenLanguageServer(LanguageServer):
Expand All @@ -58,7 +60,9 @@ async def is_zenml_installed(self) -> bool:
if process.returncode == 0:
self.show_message_log("✅ ZenML installation check: Successful.")
return True
self.show_message_log("❌ ZenML installation check failed.", lsp.MessageType.Error)
self.show_message_log(
"❌ ZenML installation check failed.", lsp.MessageType.Error
)
return False
except Exception as e:
self.show_message_log(
Expand Down Expand Up @@ -93,7 +97,9 @@ async def initialize_zenml_client(self):
# initialize watcher
self.initialize_global_config_watcher()
except Exception as e:
self.notify_user(f"Failed to initialize ZenML client: {str(e)}", lsp.MessageType.Error)
self.notify_user(
f"Failed to initialize ZenML client: {str(e)}", lsp.MessageType.Error
)

def initialize_global_config_watcher(self):
"""Sets up and starts the Global Configuration Watcher."""
Expand Down Expand Up @@ -133,7 +139,9 @@ def wrapper(*args, **kwargs):

with suppress_stdout_temporarily():
if wrapper_name:
wrapper_instance = getattr(self.zenml_client, wrapper_name, None)
wrapper_instance = getattr(
self.zenml_client, wrapper_name, None
)
if not wrapper_instance:
return {"error": f"Wrapper '{wrapper_name}' not found."}
return func(wrapper_instance, *args, **kwargs)
Expand Down Expand Up @@ -177,25 +185,33 @@ def _construct_version_validation_response(self, meets_requirement, version_str)

def send_custom_notification(self, method: str, args: dict):
"""Sends a custom notification to the LSP client."""
self.show_message_log(f"Sending custom notification: {method} with args: {args}")
self.show_message_log(
f"Sending custom notification: {method} with args: {args}"
)
self.send_notification(method, args)

def update_python_interpreter(self, interpreter_path):
"""Updates the Python interpreter path and handles errors."""
try:
self.python_interpreter = interpreter_path
self.show_message_log(f"LSP_Python_Interpreter Updated: {self.python_interpreter}")
self.show_message_log(
f"LSP_Python_Interpreter Updated: {self.python_interpreter}"
)
# pylint: disable=broad-exception-caught
except Exception as e:
self.show_message_log(
f"Failed to update Python interpreter: {str(e)}", lsp.MessageType.Error
)

def notify_user(self, message: str, msg_type: lsp.MessageType = lsp.MessageType.Info):
def notify_user(
self, message: str, msg_type: lsp.MessageType = lsp.MessageType.Info
):
"""Logs a message and also notifies the user."""
self.show_message(message, msg_type)

def log_to_output(self, message: str, msg_type: lsp.MessageType = lsp.MessageType.Log) -> None:
def log_to_output(
self, message: str, msg_type: lsp.MessageType = lsp.MessageType.Log
) -> None:
"""Log to output."""
self.show_message_log(message, msg_type)

Expand Down Expand Up @@ -261,6 +277,60 @@ def rename_stack(wrapper_instance, args):
def copy_stack(wrapper_instance, args):
"""Copies a specified ZenML stack to a new stack."""
return wrapper_instance.copy_stack(args)

@self.command(f"{TOOL_MODULE_NAME}.createStack")
@self.zenml_command(wrapper_name="stacks_wrapper")
def create_stack(wrapper_instance, args):
"""Creates a new ZenML stack."""
return wrapper_instance.create_stack(args)
strickvl marked this conversation as resolved.
Show resolved Hide resolved

@self.command(f"{TOOL_MODULE_NAME}.updateStack")
@self.zenml_command(wrapper_name="stacks_wrapper")
def update_stack(wrapper_instance, args):
"""Updates a specified ZenML stack ."""
return wrapper_instance.update_stack(args)

@self.command(f"{TOOL_MODULE_NAME}.deleteStack")
@self.zenml_command(wrapper_name="stacks_wrapper")
def delete_stack(wrapper_instance, args):
"""Deletes a specified ZenML stack ."""
return wrapper_instance.delete_stack(args)

@self.command(f"{TOOL_MODULE_NAME}.createComponent")
@self.zenml_command(wrapper_name="stacks_wrapper")
def create_component(wrapper_instance, args):
"""Creates a Zenml stack component"""
return wrapper_instance.create_component(args)
strickvl marked this conversation as resolved.
Show resolved Hide resolved

@self.command(f"{TOOL_MODULE_NAME}.updateComponent")
@self.zenml_command(wrapper_name="stacks_wrapper")
def update_component(wrapper_instance, args):
"""Updates a ZenML stack component"""
return wrapper_instance.update_component(args)

@self.command(f"{TOOL_MODULE_NAME}.deleteComponent")
@self.zenml_command(wrapper_name="stacks_wrapper")
def delete_component(wrapper_instance, args):
"""Deletes a specified ZenML stack component"""
return wrapper_instance.delete_component(args)

@self.command(f"{TOOL_MODULE_NAME}.listComponents")
@self.zenml_command(wrapper_name="stacks_wrapper")
def list_components(wrapper_instance, args):
"""Get paginated list of stack components from ZenML"""
return wrapper_instance.list_components(args)

@self.command(f"{TOOL_MODULE_NAME}.getComponentTypes")
@self.zenml_command(wrapper_name="stacks_wrapper")
def get_component_types(wrapper_instance, args):
"""Get list of component types from ZenML"""
return wrapper_instance.get_component_types()

@self.command(f"{TOOL_MODULE_NAME}.listFlavors")
@self.zenml_command(wrapper_name="stacks_wrapper")
def list_flavors(wrapper_instance, args):
"""Get paginated list of component flavors from ZenML"""
return wrapper_instance.list_flavors(args)

@self.command(f"{TOOL_MODULE_NAME}.getPipelineRuns")
@self.zenml_command(wrapper_name="pipeline_runs_wrapper")
Expand All @@ -273,13 +343,13 @@ def fetch_pipeline_runs(wrapper_instance, args):
def delete_pipeline_run(wrapper_instance, args):
"""Deletes a specified ZenML pipeline run."""
return wrapper_instance.delete_pipeline_run(args)

@self.command(f"{TOOL_MODULE_NAME}.getPipelineRun")
@self.zenml_command(wrapper_name="pipeline_runs_wrapper")
def get_pipeline_run(wrapper_instance, args):
"""Gets a specified ZenML pipeline run."""
return wrapper_instance.get_pipeline_run(args)

@self.command(f"{TOOL_MODULE_NAME}.getPipelineRunStep")
@self.zenml_command(wrapper_name="pipeline_runs_wrapper")
def get_run_step(wrapper_instance, args):
Expand All @@ -291,9 +361,9 @@ def get_run_step(wrapper_instance, args):
def get_run_artifact(wrapper_instance, args):
"""Gets a specified ZenML pipeline artifact"""
return wrapper_instance.get_run_artifact(args)

@self.command(f"{TOOL_MODULE_NAME}.getPipelineRunDag")
@self.zenml_command(wrapper_name="pipeline_runs_wrapper")
def get_run_dag(wrapper_instance, args):
"""Gets graph data for a specified ZenML pipeline run"""
return wrapper_instance.get_pipeline_run_graph(args)
return wrapper_instance.get_pipeline_run_graph(args)
47 changes: 39 additions & 8 deletions bundled/tool/type_hints.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
from typing import Any, TypedDict, Dict, List, Union
from typing import Any, TypedDict, Dict, List, Optional
from uuid import UUID


Expand All @@ -20,8 +20,6 @@ class GraphEdge(TypedDict):
source: str
target: str



class GraphResponse(TypedDict):
nodes: List[GraphNode]
edges: List[GraphEdge]
Expand All @@ -37,9 +35,9 @@ class RunStepResponse(TypedDict):
id: str
status: str
author: Dict[str, str]
startTime: Union[str, None]
endTime: Union[str, None]
duration: Union[str, None]
startTime: Optional[str]
endTime: Optional[str]
duration: Optional[str]
stackName: str
orchestrator: Dict[str, str]
pipeline: Dict[str, str]
Expand Down Expand Up @@ -71,7 +69,7 @@ class ZenmlStoreInfo(TypedDict):
class ZenmlStoreConfig(TypedDict):
type: str
url: str
api_token: Union[str, None]
api_token: Optional[str]

class ZenmlServerInfoResp(TypedDict):
store_info: ZenmlStoreInfo
Expand All @@ -84,4 +82,37 @@ class ZenmlGlobalConfigResp(TypedDict):
version: str
active_stack_id: str
active_workspace_name: str
store: ZenmlStoreConfig
store: ZenmlStoreConfig

class StackComponent(TypedDict):
id: str
name: str
flavor: str
type: str
config: Dict[str, Any]

class ListComponentsResponse(TypedDict):
index: int
max_size: int
total_pages: int
total: int
items: List[StackComponent]

class Flavor(TypedDict):
id: str
name: str
type: str
logo_url: str
config_schema: Dict[str, Any]
docs_url: Optional[str]
sdk_docs_url: Optional[str]
connector_type: Optional[str]
connector_resource_type: Optional[str]
connector_resource_id_attr: Optional[str]

class ListFlavorsResponse(TypedDict):
index: int
max_size: int
total_pages: int
total: int
items: List[Flavor]
Loading