-
Notifications
You must be signed in to change notification settings - Fork 6
Expand file tree
/
Copy pathruntime.py
More file actions
100 lines (83 loc) · 3.61 KB
/
Copy pathruntime.py
File metadata and controls
100 lines (83 loc) · 3.61 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
# Copyright (c) 2025, Salesforce, Inc.
# SPDX-License-Identifier: Apache-2
#
# 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.
import threading
from typing import Optional
from datacustomcode.einstein_predictions.base import EinsteinPredictions
from datacustomcode.einstein_predictions_config import einstein_predictions_config
from datacustomcode.file.path.default import DefaultFindFilePath
from datacustomcode.function.base import BaseRuntime
from datacustomcode.llm_gateway.base import LLMGateway
from datacustomcode.llm_gateway_config import llm_gateway_config
class Runtime(BaseRuntime):
"""Client for Function code type.
NOTE: Do not instantiate this class directly.
It will be provided to your function by the SDK:
def function(request: dict, runtime: RunTime) -> dict:
response = {...}
return response
"""
_instance: Optional["Runtime"] = None
_lock = threading.Lock()
def __new__(cls):
"""Create singleton instance (thread-safe)."""
with cls._lock:
if cls._instance is not None:
raise RuntimeError(
"Runtime can only be instantiated once by the SDK.\n\n"
"Do not instantiate it yourself. Accept it as a parameter:\n\n"
" from datacustomcode.function.runtime import Runtime\n"
" \n"
" def function(request: dict, runtime: Runtime) -> dict:\n"
" response = {...}\n"
" return response"
)
cls._instance = super().__new__(cls)
return cls._instance
def __init__(self) -> None:
# Prevent re-initialization
if hasattr(self, "_initialized"):
return
self._initialized = True
super().__init__()
# Initialize resources
self._llm_gateway: Optional[LLMGateway] = None
self._file = DefaultFindFilePath()
self._einstein_predictions: Optional[EinsteinPredictions] = None
@property
def llm_gateway(self) -> LLMGateway:
if self._llm_gateway is None:
if llm_gateway_config.llm_gateway_config is None:
raise RuntimeError(
"LLM Gateway is not configured. "
"Add 'llm_gateway_config' section to config.yaml"
)
self._llm_gateway = llm_gateway_config.llm_gateway_config.to_object()
return self._llm_gateway
@property
def file(self) -> DefaultFindFilePath:
"""Access file operations."""
return self._file
@property
def einstein_predictions(self) -> EinsteinPredictions:
if self._einstein_predictions is None:
if einstein_predictions_config.einstein_predictions_config is None:
raise RuntimeError(
"Einstein Predictions is not configured. Add "
"'einstein_predictions_config' section to config.yaml"
)
self._einstein_predictions = (
einstein_predictions_config.einstein_predictions_config.to_object()
)
return self._einstein_predictions