Compare commits
No commits in common. "7e00b29d82e1cde70bfbfbe99412946a01dcaf1c" and "6df4788cca5ac1e1159991400186ac8d64302e07" have entirely different histories.
7e00b29d82
...
6df4788cca
|
@ -2,4 +2,3 @@ MODULE_RTD8_LEVELS=01234567 #number of stack level (0-7) not separated
|
||||||
MODULE_REL4HVI4_LEVELS=01234567 #number of stack level (0-7) not separated
|
MODULE_REL4HVI4_LEVELS=01234567 #number of stack level (0-7) not separated
|
||||||
MODULE_INDUSTRIALAUTOMATION_LEVELS=01234567 #number of stack level (0-7) not separated
|
MODULE_INDUSTRIALAUTOMATION_LEVELS=01234567 #number of stack level (0-7) not separated
|
||||||
VARIABLES_SAVE_DIR=variables_storage #path to dir for saving variables
|
VARIABLES_SAVE_DIR=variables_storage #path to dir for saving variables
|
||||||
BACKGROUND_SCRIPTS_RUN=0 #1 - true/enable | 0 - false/disable
|
|
60
pdm.lock
60
pdm.lock
|
@ -4,11 +4,8 @@
|
||||||
[metadata]
|
[metadata]
|
||||||
groups = ["default"]
|
groups = ["default"]
|
||||||
strategy = ["cross_platform", "inherit_metadata"]
|
strategy = ["cross_platform", "inherit_metadata"]
|
||||||
lock_version = "4.5.0"
|
lock_version = "4.4.1"
|
||||||
content_hash = "sha256:32227dab263e3d9c111c4b44bca30eb70535da9978c01c293064ab9bac4cf07d"
|
content_hash = "sha256:3e08a1de12505708e4539230fe7dc372f7fe295cf966f3097b3e2a12fac77e49"
|
||||||
|
|
||||||
[[metadata.targets]]
|
|
||||||
requires_python = ">=3.12"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "annotated-types"
|
name = "annotated-types"
|
||||||
|
@ -16,9 +13,6 @@ version = "0.7.0"
|
||||||
requires_python = ">=3.8"
|
requires_python = ">=3.8"
|
||||||
summary = "Reusable constraint types to use with typing.Annotated"
|
summary = "Reusable constraint types to use with typing.Annotated"
|
||||||
groups = ["default"]
|
groups = ["default"]
|
||||||
dependencies = [
|
|
||||||
"typing-extensions>=4.0.0; python_version < \"3.9\"",
|
|
||||||
]
|
|
||||||
files = [
|
files = [
|
||||||
{file = "annotated_types-0.7.0-py3-none-any.whl", hash = "sha256:1f02e8b43a8fbbc3f3e0d4f0f4bfc8131bcb4eebe8849b8e5c773f3a1c582a53"},
|
{file = "annotated_types-0.7.0-py3-none-any.whl", hash = "sha256:1f02e8b43a8fbbc3f3e0d4f0f4bfc8131bcb4eebe8849b8e5c773f3a1c582a53"},
|
||||||
{file = "annotated_types-0.7.0.tar.gz", hash = "sha256:aff07c09a53a08bc8cfccb9c85b05f1aa9a2a6f23728d790723543408344ce89"},
|
{file = "annotated_types-0.7.0.tar.gz", hash = "sha256:aff07c09a53a08bc8cfccb9c85b05f1aa9a2a6f23728d790723543408344ce89"},
|
||||||
|
@ -31,31 +25,14 @@ requires_python = ">=3.9"
|
||||||
summary = "High level compatibility layer for multiple asynchronous event loop implementations"
|
summary = "High level compatibility layer for multiple asynchronous event loop implementations"
|
||||||
groups = ["default"]
|
groups = ["default"]
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"exceptiongroup>=1.0.2; python_version < \"3.11\"",
|
|
||||||
"idna>=2.8",
|
"idna>=2.8",
|
||||||
"sniffio>=1.1",
|
"sniffio>=1.1",
|
||||||
"typing-extensions>=4.1; python_version < \"3.11\"",
|
|
||||||
]
|
]
|
||||||
files = [
|
files = [
|
||||||
{file = "anyio-4.6.2.post1-py3-none-any.whl", hash = "sha256:6d170c36fba3bdd840c73d3868c1e777e33676a69c3a72cf0a0d5d6d8009b61d"},
|
{file = "anyio-4.6.2.post1-py3-none-any.whl", hash = "sha256:6d170c36fba3bdd840c73d3868c1e777e33676a69c3a72cf0a0d5d6d8009b61d"},
|
||||||
{file = "anyio-4.6.2.post1.tar.gz", hash = "sha256:4c8bc31ccdb51c7f7bd251f51c609e038d63e34219b44aa86e47576389880b4c"},
|
{file = "anyio-4.6.2.post1.tar.gz", hash = "sha256:4c8bc31ccdb51c7f7bd251f51c609e038d63e34219b44aa86e47576389880b4c"},
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "apscheduler"
|
|
||||||
version = "3.11.0"
|
|
||||||
requires_python = ">=3.8"
|
|
||||||
summary = "In-process task scheduler with Cron-like capabilities"
|
|
||||||
groups = ["default"]
|
|
||||||
dependencies = [
|
|
||||||
"backports-zoneinfo; python_version < \"3.9\"",
|
|
||||||
"tzlocal>=3.0",
|
|
||||||
]
|
|
||||||
files = [
|
|
||||||
{file = "APScheduler-3.11.0-py3-none-any.whl", hash = "sha256:fc134ca32e50f5eadcc4938e3a4545ab19131435e851abb40b34d63d5141c6da"},
|
|
||||||
{file = "apscheduler-3.11.0.tar.gz", hash = "sha256:4c622d250b0955a65d5d0eb91c33e6d43fd879834bf541e0a18661ae60460133"},
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "click"
|
name = "click"
|
||||||
version = "8.1.7"
|
version = "8.1.7"
|
||||||
|
@ -64,7 +41,6 @@ summary = "Composable command line interface toolkit"
|
||||||
groups = ["default"]
|
groups = ["default"]
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"colorama; platform_system == \"Windows\"",
|
"colorama; platform_system == \"Windows\"",
|
||||||
"importlib-metadata; python_version < \"3.8\"",
|
|
||||||
]
|
]
|
||||||
files = [
|
files = [
|
||||||
{file = "click-8.1.7-py3-none-any.whl", hash = "sha256:ae74fb96c20a0277a1d615f1e4d73c8414f5a98db8b799a7931d1582f3390c28"},
|
{file = "click-8.1.7-py3-none-any.whl", hash = "sha256:ae74fb96c20a0277a1d615f1e4d73c8414f5a98db8b799a7931d1582f3390c28"},
|
||||||
|
@ -105,9 +81,6 @@ version = "0.14.0"
|
||||||
requires_python = ">=3.7"
|
requires_python = ">=3.7"
|
||||||
summary = "A pure-Python, bring-your-own-I/O implementation of HTTP/1.1"
|
summary = "A pure-Python, bring-your-own-I/O implementation of HTTP/1.1"
|
||||||
groups = ["default"]
|
groups = ["default"]
|
||||||
dependencies = [
|
|
||||||
"typing-extensions; python_version < \"3.8\"",
|
|
||||||
]
|
|
||||||
files = [
|
files = [
|
||||||
{file = "h11-0.14.0-py3-none-any.whl", hash = "sha256:e3fe4ac4b851c468cc8363d500db52c2ead036020723024a109d37346efaa761"},
|
{file = "h11-0.14.0-py3-none-any.whl", hash = "sha256:e3fe4ac4b851c468cc8363d500db52c2ead036020723024a109d37346efaa761"},
|
||||||
{file = "h11-0.14.0.tar.gz", hash = "sha256:8f19fbbe99e72420ff35c00b27a34cb9937e902a8b810e2c88300c6f0a3b699d"},
|
{file = "h11-0.14.0.tar.gz", hash = "sha256:8f19fbbe99e72420ff35c00b27a34cb9937e902a8b810e2c88300c6f0a3b699d"},
|
||||||
|
@ -278,7 +251,6 @@ summary = "The little ASGI library that shines."
|
||||||
groups = ["default"]
|
groups = ["default"]
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyio<5,>=3.4.0",
|
"anyio<5,>=3.4.0",
|
||||||
"typing-extensions>=3.10.0; python_version < \"3.10\"",
|
|
||||||
]
|
]
|
||||||
files = [
|
files = [
|
||||||
{file = "starlette-0.41.3-py3-none-any.whl", hash = "sha256:44cedb2b7c77a9de33a8b74b2b90e9f50d11fcf25d8270ea525ad71a25374ff7"},
|
{file = "starlette-0.41.3-py3-none-any.whl", hash = "sha256:44cedb2b7c77a9de33a8b74b2b90e9f50d11fcf25d8270ea525ad71a25374ff7"},
|
||||||
|
@ -296,33 +268,6 @@ files = [
|
||||||
{file = "typing_extensions-4.12.2.tar.gz", hash = "sha256:1a7ead55c7e559dd4dee8856e3a88b41225abfe1ce8df57b7c13915fe121ffb8"},
|
{file = "typing_extensions-4.12.2.tar.gz", hash = "sha256:1a7ead55c7e559dd4dee8856e3a88b41225abfe1ce8df57b7c13915fe121ffb8"},
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "tzdata"
|
|
||||||
version = "2024.2"
|
|
||||||
requires_python = ">=2"
|
|
||||||
summary = "Provider of IANA time zone data"
|
|
||||||
groups = ["default"]
|
|
||||||
marker = "platform_system == \"Windows\""
|
|
||||||
files = [
|
|
||||||
{file = "tzdata-2024.2-py2.py3-none-any.whl", hash = "sha256:a48093786cdcde33cad18c2555e8532f34422074448fbc874186f0abd79565cd"},
|
|
||||||
{file = "tzdata-2024.2.tar.gz", hash = "sha256:7d85cc416e9382e69095b7bdf4afd9e3880418a2413feec7069d533d6b4e31cc"},
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "tzlocal"
|
|
||||||
version = "5.2"
|
|
||||||
requires_python = ">=3.8"
|
|
||||||
summary = "tzinfo object for the local timezone"
|
|
||||||
groups = ["default"]
|
|
||||||
dependencies = [
|
|
||||||
"backports-zoneinfo; python_version < \"3.9\"",
|
|
||||||
"tzdata; platform_system == \"Windows\"",
|
|
||||||
]
|
|
||||||
files = [
|
|
||||||
{file = "tzlocal-5.2-py3-none-any.whl", hash = "sha256:49816ef2fe65ea8ac19d19aa7a1ae0551c834303d5014c6d5a62e4cbda8047b8"},
|
|
||||||
{file = "tzlocal-5.2.tar.gz", hash = "sha256:8d399205578f1a9342816409cc1e46a93ebd5755e39ea2d85334bea911bf0e6e"},
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "uvicorn"
|
name = "uvicorn"
|
||||||
version = "0.32.1"
|
version = "0.32.1"
|
||||||
|
@ -332,7 +277,6 @@ groups = ["default"]
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"click>=7.0",
|
"click>=7.0",
|
||||||
"h11>=0.8",
|
"h11>=0.8",
|
||||||
"typing-extensions>=4.0; python_version < \"3.11\"",
|
|
||||||
]
|
]
|
||||||
files = [
|
files = [
|
||||||
{file = "uvicorn-0.32.1-py3-none-any.whl", hash = "sha256:82ad92fd58da0d12af7482ecdb5f2470a04c9c9a53ced65b9bbb4a205377602e"},
|
{file = "uvicorn-0.32.1-py3-none-any.whl", hash = "sha256:82ad92fd58da0d12af7482ecdb5f2470a04c9c9a53ced65b9bbb4a205377602e"},
|
||||||
|
|
|
@ -12,7 +12,6 @@ dependencies = [
|
||||||
"SM4relind>=1.0.3",
|
"SM4relind>=1.0.3",
|
||||||
"python-dotenv>=1.0.1",
|
"python-dotenv>=1.0.1",
|
||||||
"SMmegaind>=1.0.3",
|
"SMmegaind>=1.0.3",
|
||||||
"apscheduler>=3.11.0",
|
|
||||||
]
|
]
|
||||||
requires-python = ">=3.12"
|
requires-python = ">=3.12"
|
||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
|
|
|
@ -1,7 +0,0 @@
|
||||||
|
|
||||||
from src.variables.service import get_variables
|
|
||||||
#modules example import: from src.modules.RTD8.service import read_temp
|
|
||||||
|
|
||||||
def test_function():
|
|
||||||
print("Example script")
|
|
||||||
print(f"variables: {" | ".join(get_variables())}")
|
|
|
@ -1 +0,0 @@
|
||||||
Here you can save your own scripts and run them from timer.py by using APScheduler for autostarting scripts in setted interval
|
|
|
@ -1,17 +0,0 @@
|
||||||
from apscheduler.schedulers.background import BackgroundScheduler
|
|
||||||
from apscheduler.triggers.interval import IntervalTrigger
|
|
||||||
from apscheduler.triggers.cron import CronTrigger
|
|
||||||
import os
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
scheduler = BackgroundScheduler()
|
|
||||||
if bool(os.getenv("BACKGROUND_SCRIPTS_RUN", 0)):
|
|
||||||
print("run")
|
|
||||||
scheduler.start()
|
|
||||||
|
|
||||||
|
|
||||||
#example
|
|
||||||
from scripts.example import test_function
|
|
||||||
scheduler.add_job(test_function, trigger=IntervalTrigger(seconds=60))
|
|
||||||
#end example
|
|
|
@ -7,8 +7,6 @@ from fastapi import FastAPI
|
||||||
from src.modules.router import router as modulesrouter
|
from src.modules.router import router as modulesrouter
|
||||||
from src.variables.router import router as variablesrouter
|
from src.variables.router import router as variablesrouter
|
||||||
|
|
||||||
import scripts.timer
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
app = FastAPI(root_path="/api")
|
app = FastAPI(root_path="/api")
|
||||||
|
|
|
@ -10,7 +10,7 @@ for i in stacks:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def read_temp(stack: int, channel: int) -> float:
|
def read_temp(stack: int, channel: int) -> float | str:
|
||||||
"""
|
"""
|
||||||
Read specified channel in Celsius
|
Read specified channel in Celsius
|
||||||
"""
|
"""
|
||||||
|
@ -22,13 +22,13 @@ def read_temp(stack: int, channel: int) -> float:
|
||||||
|
|
||||||
return -512
|
return -512
|
||||||
|
|
||||||
def read_temp_stack(stack: int) -> dict[int, float]:
|
def read_temp_stack(stack: int) -> dict:
|
||||||
"""
|
"""
|
||||||
Read all inputs data in Celsius
|
Read all inputs data in Celsius
|
||||||
"""
|
"""
|
||||||
return {ch: read_temp(stack=stack, channel=ch) for ch in range(1, 9)}
|
return {ch: read_temp(stack=stack, channel=ch) for ch in range(1, 9)}
|
||||||
|
|
||||||
def read_temp_all() -> dict[int, dict[int, float]]:
|
def read_temp_all() -> dict:
|
||||||
"""
|
"""
|
||||||
Read all RTD8 cards inputs in Celsius
|
Read all RTD8 cards inputs in Celsius
|
||||||
"""
|
"""
|
||||||
|
@ -36,7 +36,7 @@ def read_temp_all() -> dict[int, dict[int, float]]:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def read_resistance(stack: int, channel: int) -> float:
|
def read_resistance(stack: int, channel: int) -> float | str:
|
||||||
"""
|
"""
|
||||||
Read specified channel in Ohm
|
Read specified channel in Ohm
|
||||||
"""
|
"""
|
||||||
|
@ -48,13 +48,13 @@ def read_resistance(stack: int, channel: int) -> float:
|
||||||
|
|
||||||
return -512
|
return -512
|
||||||
|
|
||||||
def read_resistance_stack(stack: int) -> dict[int, float]:
|
def read_resistance_stack(stack: int) -> dict:
|
||||||
"""
|
"""
|
||||||
Read all inputs data in Ohm
|
Read all inputs data in Ohm
|
||||||
"""
|
"""
|
||||||
return {ch: read_resistance(stack=stack, channel=ch) for ch in range(1, 9)}
|
return {ch: read_resistance(stack=stack, channel=ch) for ch in range(1, 9)}
|
||||||
|
|
||||||
def read_resistance_all() -> dict[int, dict[int, float]]:
|
def read_resistance_all() -> dict:
|
||||||
"""
|
"""
|
||||||
Read all RTD8 cards inputs in Ohm
|
Read all RTD8 cards inputs in Ohm
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -6,10 +6,10 @@ variables: dict = {}
|
||||||
|
|
||||||
def __save_data(variable, data):
|
def __save_data(variable, data):
|
||||||
with open(variable, "w") as file:
|
with open(variable, "w") as file:
|
||||||
file.write(str(data))
|
file.write(data)
|
||||||
|
|
||||||
|
|
||||||
def __load_data(variable):
|
def __load_data(variable, type):
|
||||||
with open(variable, "r") as file:
|
with open(variable, "r") as file:
|
||||||
return file.read()
|
return file.read()
|
||||||
|
|
||||||
|
@ -52,10 +52,6 @@ def get_variable(variable: str) -> str | None:
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
def get_variables() -> list[str]:
|
|
||||||
return variables.keys()
|
|
||||||
|
|
||||||
|
|
||||||
def remove_variable(variable: str):
|
def remove_variable(variable: str):
|
||||||
if variable in variables:
|
if variable in variables:
|
||||||
variables.pop(variable)
|
variables.pop(variable)
|
||||||
|
|
Loading…
Reference in New Issue