wmill 1.422.1__tar.gz → 1.450.1__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {wmill-1.422.1 → wmill-1.450.1}/PKG-INFO +1 -1
- {wmill-1.422.1 → wmill-1.450.1}/pyproject.toml +1 -1
- {wmill-1.422.1 → wmill-1.450.1}/wmill/client.py +96 -1
- {wmill-1.422.1 → wmill-1.450.1}/README.md +0 -0
- {wmill-1.422.1 → wmill-1.450.1}/wmill/__init__.py +0 -0
- {wmill-1.422.1 → wmill-1.450.1}/wmill/py.typed +0 -0
- {wmill-1.422.1 → wmill-1.450.1}/wmill/s3_reader.py +0 -0
- {wmill-1.422.1 → wmill-1.450.1}/wmill/s3_types.py +0 -0
@@ -9,6 +9,7 @@ import os
|
|
9
9
|
import random
|
10
10
|
import time
|
11
11
|
import warnings
|
12
|
+
import json
|
12
13
|
from json import JSONDecodeError
|
13
14
|
from typing import Dict, Any, Union, Literal
|
14
15
|
|
@@ -26,7 +27,7 @@ JobStatus = Literal["RUNNING", "WAITING", "COMPLETED"]
|
|
26
27
|
|
27
28
|
class Windmill:
|
28
29
|
def __init__(self, base_url=None, token=None, workspace=None, verify=True):
|
29
|
-
base = base_url or os.environ.get("BASE_INTERNAL_URL")
|
30
|
+
base = base_url or os.environ.get("BASE_INTERNAL_URL") or os.environ.get("WM_BASE_URL")
|
30
31
|
|
31
32
|
self.base_url = f"{base}/api"
|
32
33
|
self.token = token or os.environ.get("WM_TOKEN")
|
@@ -623,6 +624,83 @@ class Windmill:
|
|
623
624
|
params={"approver": approver},
|
624
625
|
).json()
|
625
626
|
|
627
|
+
def request_interactive_slack_approval(
|
628
|
+
self,
|
629
|
+
slack_resource_path: str,
|
630
|
+
channel_id: str,
|
631
|
+
message: str = None,
|
632
|
+
approver: str = None,
|
633
|
+
default_args_json: dict = None,
|
634
|
+
dynamic_enums_json: dict = None,
|
635
|
+
) -> None:
|
636
|
+
"""
|
637
|
+
Sends an interactive approval request via Slack, allowing optional customization of the message, approver, and form fields.
|
638
|
+
|
639
|
+
**[Enterprise Edition Only]** To include form fields in the Slack approval request, use the "Advanced -> Suspend -> Form" functionality.
|
640
|
+
Learn more at: https://www.windmill.dev/docs/flows/flow_approval#form
|
641
|
+
|
642
|
+
:param slack_resource_path: The path to the Slack resource in Windmill.
|
643
|
+
:type slack_resource_path: str
|
644
|
+
:param channel_id: The Slack channel ID where the approval request will be sent.
|
645
|
+
:type channel_id: str
|
646
|
+
:param message: Optional custom message to include in the Slack approval request.
|
647
|
+
:type message: str, optional
|
648
|
+
:param approver: Optional user ID or name of the approver for the request.
|
649
|
+
:type approver: str, optional
|
650
|
+
:param default_args_json: Optional dictionary defining or overriding the default arguments for form fields.
|
651
|
+
:type default_args_json: dict, optional
|
652
|
+
:param dynamic_enums_json: Optional dictionary overriding the enum default values of enum form fields.
|
653
|
+
:type dynamic_enums_json: dict, optional
|
654
|
+
|
655
|
+
:raises Exception: If the function is not called within a flow or flow preview.
|
656
|
+
:raises Exception: If the required flow job or flow step environment variables are not set.
|
657
|
+
|
658
|
+
:return: None
|
659
|
+
|
660
|
+
**Usage Example:**
|
661
|
+
>>> client.request_interactive_slack_approval(
|
662
|
+
... slack_resource_path="/u/alex/my_slack_resource",
|
663
|
+
... channel_id="admins-slack-channel",
|
664
|
+
... message="Please approve this request",
|
665
|
+
... approver="approver123",
|
666
|
+
... default_args_json={"key1": "value1", "key2": 42},
|
667
|
+
... dynamic_enums_json={"foo": ["choice1", "choice2"], "bar": ["optionA", "optionB"]},
|
668
|
+
... )
|
669
|
+
|
670
|
+
**Notes:**
|
671
|
+
- This function must be executed within a Windmill flow or flow preview.
|
672
|
+
- The function checks for required environment variables (`WM_FLOW_JOB_ID`, `WM_FLOW_STEP_ID`) to ensure it is run in the appropriate context.
|
673
|
+
"""
|
674
|
+
workspace = self.workspace
|
675
|
+
flow_job_id = os.environ.get("WM_FLOW_JOB_ID")
|
676
|
+
|
677
|
+
if not flow_job_id:
|
678
|
+
raise Exception(
|
679
|
+
"You can't use 'request_interactive_slack_approval' function in a standalone script or flow step preview. Please use it in a flow or a flow preview."
|
680
|
+
)
|
681
|
+
|
682
|
+
# Only include non-empty parameters
|
683
|
+
params = {}
|
684
|
+
if message:
|
685
|
+
params["message"] = message
|
686
|
+
if approver:
|
687
|
+
params["approver"] = approver
|
688
|
+
if slack_resource_path:
|
689
|
+
params["slack_resource_path"] = slack_resource_path
|
690
|
+
if channel_id:
|
691
|
+
params["channel_id"] = channel_id
|
692
|
+
if os.environ.get("WM_FLOW_STEP_ID"):
|
693
|
+
params["flow_step_id"] = os.environ.get("WM_FLOW_STEP_ID")
|
694
|
+
if default_args_json:
|
695
|
+
params["default_args_json"] = json.dumps(default_args_json)
|
696
|
+
if dynamic_enums_json:
|
697
|
+
params["dynamic_enums_json"] = json.dumps(dynamic_enums_json)
|
698
|
+
|
699
|
+
self.get(
|
700
|
+
f"/w/{workspace}/jobs/slack_approval/{os.environ.get('WM_JOB_ID', 'NO_JOB_ID')}",
|
701
|
+
params=params,
|
702
|
+
)
|
703
|
+
|
626
704
|
def username_to_email(self, username: str) -> str:
|
627
705
|
"""
|
628
706
|
Get email from workspace username
|
@@ -972,6 +1050,23 @@ def get_state_path() -> str:
|
|
972
1050
|
def get_resume_urls(approver: str = None) -> dict:
|
973
1051
|
return _client.get_resume_urls(approver)
|
974
1052
|
|
1053
|
+
@init_global_client
|
1054
|
+
def request_interactive_slack_approval(
|
1055
|
+
slack_resource_path: str,
|
1056
|
+
channel_id: str,
|
1057
|
+
message: str = None,
|
1058
|
+
approver: str = None,
|
1059
|
+
default_args_json: dict = None,
|
1060
|
+
dynamic_enums_json: dict = None,
|
1061
|
+
) -> None:
|
1062
|
+
return _client.request_interactive_slack_approval(
|
1063
|
+
slack_resource_path=slack_resource_path,
|
1064
|
+
channel_id=channel_id,
|
1065
|
+
message=message,
|
1066
|
+
approver=approver,
|
1067
|
+
default_args_json=default_args_json,
|
1068
|
+
dynamic_enums_json=dynamic_enums_json,
|
1069
|
+
)
|
975
1070
|
|
976
1071
|
@init_global_client
|
977
1072
|
def cancel_running() -> dict:
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|