-
Notifications
You must be signed in to change notification settings - Fork 47
/
Copy pathbase.py
146 lines (114 loc) · 3.36 KB
/
base.py
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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
#!/usr/bin/env python
# -*- coding: utf-8; -*-
# Copyright (c) 2022, 2023 Oracle and/or its affiliates.
# Licensed under the Universal Permissive License v 1.0 as shown at https://oss.oracle.com/licenses/upl/
from abc import abstractmethod
from typing import Dict, Union
class UnsupportedRuntime(Exception):
def __init__(self, runtime_type: str):
super().__init__(
f"The provided runtime: `{runtime_type}` "
"is not supported by given resource."
)
class Backend:
"""Interface for backend"""
def __init__(self, config: Dict) -> None:
self.config = config
self.auth_type = config["execution"].get("auth", "api_key")
self.profile = config["execution"].get("oci_profile", None)
self.oci_config = config["execution"].get("oci_config", None)
@abstractmethod
def run(self) -> Dict:
"""
Initiate a run.
Returns
-------
Dict
"""
def delete(self) -> None:
"""
Delete a remote run.
Returns
-------
None
"""
def watch(self) -> None:
"""
Stream logs from a remote run.
Returns
-------
None
"""
def cancel(self) -> None:
"""
Cancel a remote run.
Returns
-------
None
"""
def apply(self) -> Dict:
"""
Initiate Data Science service from YAML.
Returns
-------
Dict
"""
def activate(self) -> None:
"""
Activate a remote service.
Returns
-------
None
"""
raise NotImplementedError("`activate` has not been implemented yet.")
def deactivate(self) -> None:
"""
Deactivate a remote service.
Returns
-------
None
"""
raise NotImplementedError("`deactivate` has not been implemented yet.")
def run_diagnostics(self):
"""
Implement Diagnostics check appropriate for the backend
"""
def init(
self, uri: Union[str, None] = None, overwrite: bool = False, **kwargs: Dict
) -> Union[str, None]:
"""Generates a YAML specification for the resource.
Parameters
----------
overwrite: (bool, optional). Defaults to False.
Overwrites the result specification YAML if exists.
uri: (str, optional)
The filename to save the resulting specification template YAML.
**kwargs: Dict
The optional arguments.
runtime_type: str
The resource runtime type.
Returns
-------
Union[str, None]
The YAML specification for the given resource if `uri` was not provided.
`None` otherwise.
"""
raise NotImplementedError(
"The `init` has not been implemented yet for the given resource."
)
def predict(self) -> None:
"""
Run model predict.
Returns
-------
None
"""
raise NotImplementedError("`predict` has not been implemented yet.")
class RuntimeFactory:
"""Base factory for runtime."""
_MAP = {}
@classmethod
def get_runtime(cls, key: str, *args, **kwargs):
if key not in cls._MAP:
raise UnsupportedRuntime(key)
return cls._MAP[key](*args, **kwargs)