samgis_core 3.0.9__tar.gz → 3.0.11__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (20) hide show
  1. {samgis_core-3.0.9 → samgis_core-3.0.11}/PKG-INFO +1 -1
  2. {samgis_core-3.0.9 → samgis_core-3.0.11}/pyproject.toml +2 -2
  3. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/utilities/frontend_builder.py +2 -2
  4. samgis_core-3.0.11/samgis_core/utilities/update_requirements_txt.py +103 -0
  5. samgis_core-3.0.9/samgis_core/utilities/update_requirements_txt.py +0 -43
  6. {samgis_core-3.0.9 → samgis_core-3.0.11}/LICENSE +0 -0
  7. {samgis_core-3.0.9 → samgis_core-3.0.11}/README.md +0 -0
  8. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/__init__.py +0 -0
  9. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/__version__.py +0 -0
  10. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/prediction_api/__init__.py +0 -0
  11. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/prediction_api/sam_onnx2.py +0 -0
  12. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/prediction_api/sam_onnx_inference.py +0 -0
  13. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/utilities/__init__.py +0 -0
  14. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/utilities/constants.py +0 -0
  15. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/utilities/create_folders_if_not_exists.py +0 -0
  16. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/utilities/plot_images.py +0 -0
  17. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/utilities/serialize.py +0 -0
  18. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/utilities/session_logger.py +0 -0
  19. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/utilities/type_hints.py +0 -0
  20. {samgis_core-3.0.9 → samgis_core-3.0.11}/samgis_core/utilities/utilities.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: samgis_core
3
- Version: 3.0.9
3
+ Version: 3.0.11
4
4
  Summary: SamGIS CORE
5
5
  License: MIT
6
6
  Author: alessandro trinca tornidor
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "samgis_core"
3
- version = "3.0.9"
3
+ version = "3.0.11"
4
4
  description = "SamGIS CORE"
5
5
  authors = ["alessandro trinca tornidor <alessandro@trinca.tornidor.com>"]
6
6
  license = "MIT license"
@@ -8,7 +8,7 @@ readme = "README.md"
8
8
 
9
9
  [metadata]
10
10
  name = "samgis_core"
11
- version = "3.0.9"
11
+ version = "3.0.11"
12
12
 
13
13
  [tool.poetry.urls]
14
14
  Source = "https://gitlab.com/aletrn/samgis_core"
@@ -123,7 +123,7 @@ def build_frontend(
123
123
  app_logger.info(f"current_folder:{current_folder}, install pnpm...")
124
124
  run_command(["which", "npm"])
125
125
  run_command(["npm", "install", "-g", "npm", "pnpm"])
126
- app_logger.info(f"install pnpm dependencies...")
126
+ app_logger.info("install pnpm dependencies...")
127
127
  run_command(["pnpm", "install"])
128
128
 
129
129
  # build frontend dist and assert for its correct build
@@ -139,7 +139,7 @@ def build_frontend(
139
139
  run_command(["pnpm", "tailwindcss", "-i", str(input_css_path), "-o", output_css])
140
140
  app_logger.info(f"pnpm: ls -l {output_css}:")
141
141
  run_command(["ls", "-l", output_css])
142
- app_logger.info(f"end!")
142
+ app_logger.info("end!")
143
143
  return True
144
144
 
145
145
 
@@ -0,0 +1,103 @@
1
+ import argparse
2
+ import sys
3
+ from pathlib import Path
4
+ import structlog
5
+
6
+ from samgis_core.utilities import session_logger
7
+
8
+ session_logger.setup_logging(json_logs=False, log_level="INFO")
9
+ logger = structlog.stdlib.get_logger(__name__)
10
+
11
+
12
+ def get_dependencies_freeze() -> dict:
13
+ """get a 'freeze.txt'-like dict of 'name':'version' metadata about installed packages."""
14
+ from importlib import metadata
15
+ return {dist.metadata["name"]: dist.version for dist in metadata.distributions()}
16
+
17
+
18
+ def sanitize_path(filename: str | Path, strict_on_filename: bool = True) -> Path:
19
+ filename = Path(filename)
20
+ base_path = Path.cwd().resolve(strict=True)
21
+ logger.info(f"base_path (current working folder):{base_path} ...")
22
+ try:
23
+ safe_path = filename.resolve(strict=strict_on_filename)
24
+ except FileNotFoundError as fnfe:
25
+ logger.error(f"filename not found:{filename.absolute()}.")
26
+ logger.error(f"fnfe:{fnfe}.")
27
+ raise fnfe
28
+ try:
29
+ assert base_path / filename.name == safe_path
30
+ except AssertionError:
31
+ msg = f"""
32
+ Basename of resolved path {safe_path} doesn't matches original file {filename},
33
+ or filename {filename} isn't within the current directory {base_path} ...
34
+ """
35
+ raise OSError(msg)
36
+ return Path(safe_path)
37
+
38
+
39
+ def get_requirements_txt(requirements_no_versions_filename: str | Path, requirements_output_filename: str | Path):
40
+ """
41
+ Write on disk a requirements.txt file with an updated list of dependencies from installed python packages.
42
+ Both input and output requirements files must be within the folder from which the current command is executed.
43
+
44
+ Args:
45
+ requirements_no_versions_filename: input requirements filename with no specified versions
46
+ requirements_output_filename: output requirements.txt filename
47
+
48
+ Returns:
49
+
50
+ """
51
+ logger.info("start requirements.txt update...")
52
+ freeze_dict = get_dependencies_freeze()
53
+ logger.debug(f"freeze_dict:{freeze_dict}.")
54
+ logger.debug(f"requirements_no_versions_filename:{requirements_no_versions_filename}.")
55
+ requirements_no_versions_filename_sanitized = sanitize_path(requirements_no_versions_filename)
56
+ logger.info(f"requirements_no_versions_filename_sanitized:{requirements_no_versions_filename_sanitized}.")
57
+ with open(requirements_no_versions_filename_sanitized) as req_src:
58
+ packages_no_requirements = req_src.read().split("\n")
59
+ requirements_output = {
60
+ name: version for name, version in sorted(freeze_dict.items()) if name in packages_no_requirements
61
+ }
62
+ logger.debug(f"requirements to write:{requirements_output}.")
63
+ requirements_output_filename_sanitized = sanitize_path(requirements_output_filename, strict_on_filename=False)
64
+ logger.debug(f"requirements_output_filename_sanitized:{requirements_output_filename_sanitized}.")
65
+ with open(requirements_output_filename_sanitized, "w") as dst:
66
+ out = ""
67
+ for name, version in requirements_output.items():
68
+ out += f"{name}=={version}\n"
69
+ logger.info(f"output requirements content:\n{out}!")
70
+ dst.write(out)
71
+ logger.info(f"written requirements to file:{requirements_output_filename}!")
72
+
73
+
74
+ def get_args(current_args: list) -> argparse.Namespace:
75
+ warning = "This file must be within the current folder."
76
+ logger.info(f"current_args:{current_args}.")
77
+ parser = argparse.ArgumentParser(description="Update requirements.txt from current installed packages.")
78
+ parser.add_argument(
79
+ "--req_no_version_path", required=True,
80
+ help=f"file path for requirements list packages without versions. {warning}."
81
+ )
82
+ parser.add_argument(
83
+ "--req_output_path", required=True,
84
+ help=f"file path for output requirements. {warning}."
85
+ )
86
+ parser.add_argument(
87
+ "--loglevel", required=False,
88
+ default="INFO",
89
+ choices=["DEBUG", "INFO"],
90
+ help=f"log level (default INFO)."
91
+ )
92
+ args = parser.parse_args(current_args)
93
+ logger.debug(f"args:{args}.")
94
+ return args
95
+
96
+
97
+ if __name__ == '__main__':
98
+ args = get_args(sys.argv[1:])
99
+ session_logger.setup_logging(json_logs=False, log_level=args.loglevel)
100
+ get_requirements_txt(
101
+ requirements_no_versions_filename=args.req_no_version_path,
102
+ requirements_output_filename=args.req_output_path
103
+ )
@@ -1,43 +0,0 @@
1
- from pathlib import Path
2
- import structlog
3
-
4
- from samgis_core.utilities import session_logger
5
-
6
-
7
- session_logger.setup_logging(json_logs=False, log_level="INFO")
8
- logger = structlog.stdlib.get_logger(__name__)
9
-
10
-
11
- def get_dependencies_freeze() -> dict:
12
- """get a 'freeze.txt'-like dict of 'name':'version' metadata about installed packages."""
13
- from importlib import metadata
14
- return {dist.metadata["name"]: dist.version for dist in metadata.distributions()}
15
-
16
-
17
- def get_requirements_txt(requirements_no_versions_filename: str | Path, requirements_output_filename: str | Path):
18
- """
19
- Write on disk a requirements.txt file with an updated list of dependencies from installed python packages.
20
-
21
- Args:
22
- requirements_no_versions_filename: full path of input requirements filename with no specified versions
23
- requirements_output_filename: full path of output requirements.txt filename
24
-
25
- Returns:
26
-
27
- """
28
- logger.info("start requirements.txt update...")
29
- freeze_dict = get_dependencies_freeze()
30
- logger.debug(f"freeze_dict:{freeze_dict}.")
31
- with open(requirements_no_versions_filename) as req_src:
32
- packages_no_requirements = req_src.read().split("\n")
33
- requirements_output = {
34
- name: version for name, version in sorted(freeze_dict.items()) if name in packages_no_requirements
35
- }
36
- logger.info(f"requirements to write:{requirements_output}.")
37
- with open(requirements_output_filename, "w") as dst:
38
- out = ""
39
- for name, version in requirements_output.items():
40
- out += f"{name}=={version}\n"
41
- logger.debug(f"output requirements content:\n{out}!")
42
- dst.write(out)
43
- logger.info(f"written requirements to file:{requirements_output_filename}!")
File without changes
File without changes