mirror of
https://github.com/hatchet-dev/hatchet.git
synced 2026-01-28 03:38:52 -06:00
* feat: add flag to handle disabling fork support * chore: version * chore: changelog * feat: allow TypedDict return from tasks * chore: changelog * feat: add poll strategy, change type
90 lines
2.9 KiB
Python
90 lines
2.9 KiB
Python
import os
|
|
from typing import Literal, cast, overload
|
|
|
|
import grpc
|
|
|
|
from hatchet_sdk.config import ClientConfig
|
|
|
|
|
|
@overload
|
|
def new_conn(config: ClientConfig, aio: Literal[False]) -> grpc.Channel: ...
|
|
|
|
|
|
@overload
|
|
def new_conn(config: ClientConfig, aio: Literal[True]) -> grpc.aio.Channel: ...
|
|
|
|
|
|
def new_conn(config: ClientConfig, aio: bool) -> grpc.Channel | grpc.aio.Channel:
|
|
credentials: grpc.ChannelCredentials | None = None
|
|
|
|
# load channel credentials
|
|
if config.tls_config.strategy == "tls":
|
|
root: bytes | None = None
|
|
|
|
if config.tls_config.root_ca_file:
|
|
with open(config.tls_config.root_ca_file, "rb") as f:
|
|
root = f.read()
|
|
|
|
credentials = grpc.ssl_channel_credentials(root_certificates=root)
|
|
elif config.tls_config.strategy == "mtls":
|
|
assert config.tls_config.root_ca_file
|
|
assert config.tls_config.key_file
|
|
assert config.tls_config.cert_file
|
|
|
|
with open(config.tls_config.root_ca_file, "rb") as f:
|
|
root = f.read()
|
|
|
|
with open(config.tls_config.key_file, "rb") as f:
|
|
private_key = f.read()
|
|
|
|
with open(config.tls_config.cert_file, "rb") as f:
|
|
certificate_chain = f.read()
|
|
|
|
credentials = grpc.ssl_channel_credentials(
|
|
root_certificates=root,
|
|
private_key=private_key,
|
|
certificate_chain=certificate_chain,
|
|
)
|
|
|
|
start = grpc if not aio else grpc.aio
|
|
|
|
channel_options: list[tuple[str, str | int]] = [
|
|
("grpc.max_send_message_length", config.grpc_max_send_message_length),
|
|
("grpc.max_receive_message_length", config.grpc_max_recv_message_length),
|
|
("grpc.keepalive_time_ms", 10 * 1000),
|
|
("grpc.keepalive_timeout_ms", 60 * 1000),
|
|
("grpc.client_idle_timeout_ms", 60 * 1000),
|
|
("grpc.http2.max_pings_without_data", 0),
|
|
("grpc.keepalive_permit_without_calls", 1),
|
|
]
|
|
|
|
# Set environment variable to disable fork support. Reference: https://github.com/grpc/grpc/issues/28557
|
|
# When steps execute via os.fork, we see `TSI_DATA_CORRUPTED` errors.
|
|
# needs to be the string "True" or "False"
|
|
os.environ["GRPC_ENABLE_FORK_SUPPORT"] = str(config.grpc_enable_fork_support)
|
|
|
|
if config.grpc_enable_fork_support:
|
|
# See discussion: https://github.com/hatchet-dev/hatchet/pull/2057#discussion_r2243233357
|
|
os.environ["GRPC_POLL_STRATEGY"] = "poll"
|
|
|
|
if config.tls_config.strategy == "none":
|
|
conn = start.insecure_channel(
|
|
target=config.host_port,
|
|
options=channel_options,
|
|
)
|
|
else:
|
|
channel_options.append(
|
|
("grpc.ssl_target_name_override", config.tls_config.server_name)
|
|
)
|
|
|
|
conn = start.secure_channel(
|
|
target=config.host_port,
|
|
credentials=credentials,
|
|
options=channel_options,
|
|
)
|
|
|
|
return cast(
|
|
grpc.Channel | grpc.aio.Channel,
|
|
conn,
|
|
)
|