|
1 | | -def _model_meta( |
2 | | - user: dict = None, version: str = None, url: str = None, required_pkgs: list = None |
3 | | -): |
4 | | - """Populate relevant metadata for VetiverModel |
5 | | -
|
6 | | - Args |
7 | | - ---- |
8 | | - user: dict |
9 | | - Extra user-defined information |
10 | | - version: str |
11 | | - Model version, generally populated from pins |
12 | | - url: str |
13 | | - Discoverable URL for API |
14 | | - required_pkgs: list |
15 | | - Packages necessary to make predictions |
16 | | - """ |
17 | | - meta = { |
18 | | - "user": user, |
19 | | - "version": version, |
20 | | - "url": url, |
21 | | - "required_pkgs": required_pkgs, |
22 | | - } |
23 | | - return meta |
| 1 | +from dataclasses import dataclass, asdict, field |
| 2 | +from typing import Mapping |
| 3 | + |
| 4 | + |
| 5 | +@dataclass |
| 6 | +class VetiverMeta: |
| 7 | + """Metadata in a VetiverModel""" |
| 8 | + |
| 9 | + user: "dict | None" = field(default_factory=dict) |
| 10 | + version: "str | None" = None |
| 11 | + url: "str | None" = None |
| 12 | + required_pkgs: "list | None" = field(default_factory=list) |
| 13 | + |
| 14 | + def to_dict(self) -> Mapping: |
| 15 | + data = asdict(self) |
| 16 | + |
| 17 | + return data |
| 18 | + |
| 19 | + @classmethod |
| 20 | + def from_dict(cls, metadata, pip_name=None) -> "VetiverMeta": |
| 21 | + |
| 22 | + metadata = {} if metadata is None else metadata |
| 23 | + |
| 24 | + user = metadata.get("user", metadata) |
| 25 | + version = metadata.get("version", None) |
| 26 | + url = metadata.get("url", None) |
| 27 | + required_pkgs = metadata.get("required_pkgs", []) |
| 28 | + |
| 29 | + if pip_name: |
| 30 | + if not list(filter(lambda x: pip_name in x, required_pkgs)): |
| 31 | + required_pkgs = required_pkgs + [f"{pip_name}"] |
| 32 | + |
| 33 | + return cls(user, version, url, required_pkgs) |
0 commit comments