From ab5347d907e696c024fe17bf75cd92e5483e2f14 Mon Sep 17 00:00:00 2001 From: "Yuri (solarw) Turchenkov" Date: Tue, 18 Jun 2024 15:47:31 +0300 Subject: [PATCH 1/3] pause all service on startup --- operate/cli.py | 17 +++++++++++++++++ operate/services/service.py | 4 ++-- 2 files changed, 19 insertions(+), 2 deletions(-) diff --git a/operate/cli.py b/operate/cli.py index 821fa88ac..646435a33 100644 --- a/operate/cli.py +++ b/operate/cli.py @@ -179,6 +179,23 @@ def cancel_funding_job(service: str) -> None: if not status: logger.info(f"Funding job cancellation for {service} failed") + def pause_all_services_on_startup(): + logger.info(f"stopping services on startup") + services = [i["hash"] for i in operate.service_manager().json] + + for service in services: + if not operate.service_manager().exists(service=service): + continue + logger.info(f"stopping service {service}") + deployment = operate.service_manager().create_or_load(service).deployment + deployment.stop(force=True) + logger.info(f"Cancelling funding job for {service}") + cancel_funding_job(service=service) + logger.info(f"stopping services on startup: done") + + # on backend app started we assume there are now started agents, so we force to pause all + pause_all_services_on_startup() + app = FastAPI() app.add_middleware( diff --git a/operate/services/service.py b/operate/services/service.py index 1f03d93ab..2f05c6d9e 100644 --- a/operate/services/service.py +++ b/operate/services/service.py @@ -822,9 +822,9 @@ def start(self, use_docker: bool = False) -> None: self.status = DeploymentStatus.DEPLOYED self.store() - def stop(self, use_docker: bool = False) -> None: + def stop(self, use_docker: bool = False, force: bool=False) -> None: """Stop the deployment.""" - if self.status != DeploymentStatus.DEPLOYED: + if self.status != DeploymentStatus.DEPLOYED and not force: return self.status = DeploymentStatus.STOPPING From cbdf9ff3fe938b9cdad34febe29564b8d014c430 Mon Sep 17 00:00:00 2001 From: "Yuri (solarw) Turchenkov" Date: Tue, 18 Jun 2024 16:02:00 +0300 Subject: [PATCH 2/3] deleted state check added for pause services on startup --- operate/cli.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/operate/cli.py b/operate/cli.py index 646435a33..64a7bfd21 100644 --- a/operate/cli.py +++ b/operate/cli.py @@ -42,7 +42,7 @@ from operate.account.user import UserAccount from operate.constants import KEY, KEYS, OPERATE, SERVICES from operate.ledger import get_ledger_type_from_chain_type -from operate.types import ChainType +from operate.types import ChainType, DeploymentStatus from operate.wallet.master import MasterWalletManager @@ -186,8 +186,10 @@ def pause_all_services_on_startup(): for service in services: if not operate.service_manager().exists(service=service): continue - logger.info(f"stopping service {service}") deployment = operate.service_manager().create_or_load(service).deployment + if deployment.status == DeploymentStatus.DELETED: + continue + logger.info(f"stopping service {service}") deployment.stop(force=True) logger.info(f"Cancelling funding job for {service}") cancel_funding_job(service=service) From d46d371016df8e6ce1880f10b4b7b55a514ac74e Mon Sep 17 00:00:00 2001 From: truemiller Date: Tue, 18 Jun 2024 15:28:52 +0100 Subject: [PATCH 3/3] bump to rc50 --- electron/install.js | 2 +- package.json | 2 +- pyproject.toml | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/electron/install.js b/electron/install.js index 1d32a2351..158918c40 100644 --- a/electron/install.js +++ b/electron/install.js @@ -16,7 +16,7 @@ const { BrewScript } = require('./scripts'); * - use "" (nothing as a suffix) for latest release candidate, for example "0.1.0rc26" * - use "alpha" for alpha release, for example "0.1.0rc26-alpha" */ -const OlasMiddlewareVersion = '0.1.0rc47'; +const OlasMiddlewareVersion = '0.1.0rc50'; const OperateDirectory = `${os.homedir()}/.operate`; const VenvDir = `${OperateDirectory}/venv`; const TempDir = `${OperateDirectory}/temp`; diff --git a/package.json b/package.json index 3cb35748b..7a22390d0 100644 --- a/package.json +++ b/package.json @@ -3,7 +3,7 @@ "main": "electron/main.js", "name": "olas-operate-app", "productName": "Pearl", - "version": "0.1.0-rc47", + "version": "0.1.0-rc50", "dependencies": { "@ant-design/cssinjs": "^1.18.4", "@ant-design/icons": "^5.3.0", diff --git a/pyproject.toml b/pyproject.toml index 9473b8574..b4c266b81 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "olas-operate-middleware" -version = "0.1.0-rc47" +version = "0.1.0-rc50" description = "" authors = ["David Vilela ", "Viraj Patel "] readme = "README.md"