sbcli-hmdi 0.0.13__tar.gz → 0.0.14__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
Files changed (154) hide show
  1. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/PKG-INFO +1 -1
  2. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/sbcli_hmdi.egg-info/PKG-INFO +1 -1
  3. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/lvol_controller.py +66 -42
  4. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/env_var +1 -1
  5. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/storage_node_ops.py +18 -15
  6. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/README.md +0 -0
  7. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/pyproject.toml +0 -0
  8. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/requirements.txt +0 -0
  9. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/sbcli_hmdi.egg-info/SOURCES.txt +0 -0
  10. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/sbcli_hmdi.egg-info/dependency_links.txt +0 -0
  11. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/sbcli_hmdi.egg-info/entry_points.txt +0 -0
  12. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/sbcli_hmdi.egg-info/requires.txt +0 -0
  13. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/sbcli_hmdi.egg-info/top_level.txt +0 -0
  14. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/setup.cfg +0 -0
  15. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/setup.py +0 -0
  16. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_cli/__init__.py +0 -0
  17. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_cli/cli.py +0 -0
  18. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_cli/main.py +0 -0
  19. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/__init__.py +0 -0
  20. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/cluster_ops.py +0 -0
  21. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/cnode_client.py +0 -0
  22. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/constants.py +0 -0
  23. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/__init__.py +0 -0
  24. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/caching_node_controller.py +0 -0
  25. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/cluster_events.py +0 -0
  26. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/device_controller.py +0 -0
  27. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/device_events.py +0 -0
  28. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/events_controller.py +0 -0
  29. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/health_controller.py +0 -0
  30. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/lvol_events.py +0 -0
  31. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/mgmt_events.py +0 -0
  32. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/pool_controller.py +0 -0
  33. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/pool_events.py +0 -0
  34. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/snapshot_controller.py +0 -0
  35. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/snapshot_events.py +0 -0
  36. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/storage_events.py +0 -0
  37. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/tasks_controller.py +0 -0
  38. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/controllers/tasks_events.py +0 -0
  39. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/db_controller.py +0 -0
  40. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/distr_controller.py +0 -0
  41. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/mgmt_node_ops.py +0 -0
  42. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/__init__.py +0 -0
  43. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/base_model.py +0 -0
  44. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/caching_node.py +0 -0
  45. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/cluster.py +0 -0
  46. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/deployer.py +0 -0
  47. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/events.py +0 -0
  48. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/iface.py +0 -0
  49. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/job_schedule.py +0 -0
  50. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/lvol_model.py +0 -0
  51. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/mgmt_node.py +0 -0
  52. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/nvme_device.py +0 -0
  53. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/pool.py +0 -0
  54. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/port_stat.py +0 -0
  55. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/snapshot.py +0 -0
  56. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/stats.py +0 -0
  57. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/models/storage_node.py +0 -0
  58. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/pci_utils.py +0 -0
  59. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/rpc_client.py +0 -0
  60. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/__init__.py +0 -0
  61. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/alerting/alert_resources.yaml.j2 +0 -0
  62. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/alerting/alert_rules.yaml +0 -0
  63. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/clean_local_storage_deploy.sh +0 -0
  64. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/config_docker.sh +0 -0
  65. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/dashboard.yml +0 -0
  66. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/dashboards/cluster.json +0 -0
  67. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/dashboards/devices.json +0 -0
  68. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/dashboards/lvols.json +0 -0
  69. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/dashboards/node-exporter.json +0 -0
  70. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/dashboards/nodes.json +0 -0
  71. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/dashboards/pools.json +0 -0
  72. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/datasource.yml +0 -0
  73. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/db_config_double.sh +0 -0
  74. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/db_config_single.sh +0 -0
  75. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/deploy_fdb.sh +0 -0
  76. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/deploy_stack.sh +0 -0
  77. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/docker-compose-swarm-monitoring.yml +0 -0
  78. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/docker-compose-swarm.yml +0 -0
  79. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/foundation.yml +0 -0
  80. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/haproxy.cfg +0 -0
  81. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/install_deps.sh +0 -0
  82. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/objstore.yml +0 -0
  83. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/prepare_fdb.sh +0 -0
  84. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/prometheus.yml +0 -0
  85. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/run_ssh.sh +0 -0
  86. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/set_db_config.sh +0 -0
  87. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/scripts/stack_deploy_wait.sh +0 -0
  88. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/__init__.py +0 -0
  89. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/cached_lvol_stat_collector.py +0 -0
  90. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/caching_node_monitor.py +0 -0
  91. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/cap_monitor.py +0 -0
  92. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/capacity_and_stats_collector.py +0 -0
  93. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/device_monitor.py +0 -0
  94. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/health_check_service.py +0 -0
  95. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/install_service.sh +0 -0
  96. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/log_agg_service.py +0 -0
  97. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/lvol_monitor.py +0 -0
  98. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/lvol_stat_collector.py +0 -0
  99. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/main_distr_event_collector.py +0 -0
  100. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/mgmt_node_monitor.py +0 -0
  101. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/new_device_discovery.py +0 -0
  102. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/port_stat_collector.py +0 -0
  103. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/remove_service.sh +0 -0
  104. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/service_template.service +0 -0
  105. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/spdk_http_proxy_server.py +0 -0
  106. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/storage_node_monitor.py +0 -0
  107. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/tasks_runner_failed_migration.py +0 -0
  108. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/tasks_runner_migration.py +0 -0
  109. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/tasks_runner_new_dev_migration.py +0 -0
  110. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/tasks_runner_node_add.py +0 -0
  111. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/services/tasks_runner_restart.py +0 -0
  112. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/shell_utils.py +0 -0
  113. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/snode_client.py +0 -0
  114. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/utils.py +0 -0
  115. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_core/workers/cleanup_foundationdb.py +0 -0
  116. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/README.md +0 -0
  117. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/__init__.py +0 -0
  118. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/app.py +0 -0
  119. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/auth_middleware.py +0 -0
  120. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/__init__.py +0 -0
  121. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/caching_node_ops.py +0 -0
  122. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/caching_node_ops_k8s.py +0 -0
  123. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/node_api_basic.py +0 -0
  124. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/node_api_caching_docker.py +0 -0
  125. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/node_api_caching_ks.py +0 -0
  126. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/snode_ops.py +0 -0
  127. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/snode_ops_k8s.py +0 -0
  128. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/web_api_caching_node.py +0 -0
  129. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/web_api_cluster.py +0 -0
  130. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/web_api_deployer.py +0 -0
  131. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/web_api_device.py +0 -0
  132. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/web_api_lvol.py +0 -0
  133. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/web_api_mgmt_node.py +0 -0
  134. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/web_api_pool.py +0 -0
  135. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/web_api_snapshot.py +0 -0
  136. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/blueprints/web_api_storage_node.py +0 -0
  137. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/caching_node_app.py +0 -0
  138. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/caching_node_app_k8s.py +0 -0
  139. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/node_utils.py +0 -0
  140. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/node_webapp.py +0 -0
  141. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/requirements.txt +0 -0
  142. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/snode_app.py +0 -0
  143. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/snode_app_k8s.py +0 -0
  144. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/static/delete.py +0 -0
  145. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/static/deploy.py +0 -0
  146. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/static/deploy_cnode.yaml +0 -0
  147. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/static/deploy_spdk.yaml +0 -0
  148. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/static/is_up.py +0 -0
  149. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/static/list_deps.py +0 -0
  150. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/static/rpac.yaml +0 -0
  151. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/static/tst.py +0 -0
  152. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/templates/caching_deploy_spdk.yaml.j2 +0 -0
  153. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/templates/storage_deploy_spdk.yaml.j2 +0 -0
  154. {sbcli_hmdi-0.0.13 → sbcli_hmdi-0.0.14}/simplyblock_web/utils.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: sbcli-hmdi
3
- Version: 0.0.13
3
+ Version: 0.0.14
4
4
  Summary: CLI for managing SimplyBlock cluster
5
5
  Home-page: https://www.simplyblock.io/
6
6
  Author: Hamdy
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: sbcli-hmdi
3
- Version: 0.0.13
3
+ Version: 0.0.14
4
4
  Summary: CLI for managing SimplyBlock cluster
5
5
  Home-page: https://www.simplyblock.io/
6
6
  Author: Hamdy
@@ -861,11 +861,6 @@ def delete_lvol(id_or_name, force_delete=False):
861
861
  # lvol.write_to_db(db_controller.kv_store)
862
862
  # return True
863
863
 
864
- if snode.status not in [StorageNode.STATUS_ONLINE, StorageNode.STATUS_REMOVED]:
865
- logger.error(f"Node status is not online or removed, node: {snode.get_id()}, status: {snode.status}")
866
- if not force_delete:
867
- return False
868
-
869
864
  # set status
870
865
  lvol.status = LVol.STATUS_IN_DELETION
871
866
  lvol.write_to_db(db_controller.kv_store)
@@ -878,66 +873,95 @@ def delete_lvol(id_or_name, force_delete=False):
878
873
  caching_node_controller.disconnect(cnode.get_id(), lvol.get_id())
879
874
 
880
875
  if lvol.ha_type == 'single':
876
+ if snode.status != StorageNode.STATUS_ONLINE:
877
+ logger.error(f"Node status is not online, node: {snode.get_id()}, status: {snode.status}")
878
+ if not force_delete:
879
+ return False
880
+
881
881
  ret = delete_lvol_from_node(lvol.get_id(), lvol.node_id)
882
882
  if not ret:
883
883
  return False
884
+
885
+
884
886
  elif lvol.ha_type == "ha":
885
887
 
886
888
  sec_node = db_controller.get_storage_node_by_id(snode.secondary_node_id)
887
889
 
888
- if sec_node.status not in [StorageNode.STATUS_ONLINE, StorageNode.STATUS_OFFLINE, StorageNode.STATUS_REMOVED]:
889
- logger.error(f"Secondary node status is not online or offline, node: {sec_node.get_id()}, status: {sec_node.status}")
890
- if not force_delete:
891
- return False
892
-
893
890
  sec_rpc_client = RPCClient(
894
891
  sec_node.mgmt_ip,
895
892
  sec_node.rpc_port,
896
893
  sec_node.rpc_username,
897
894
  sec_node.rpc_password, timeout=5, retry=1)
898
895
 
899
- ret = sec_rpc_client.subsystem_delete(lvol.nqn)
900
- ret = sec_rpc_client.bdev_lvol_set_leader(False, lvs_name=lvol.lvs_name)
901
- if not ret:
902
- logger.error(f"Failed to set leader for secondary node: {sec_node.get_id()}")
903
- if not force_delete:
904
- return False
896
+ if snode.status != StorageNode.STATUS_ONLINE:
905
897
 
906
- time.sleep(1)
907
- rpc_client.subsystem_delete(lvol.nqn)
908
- rpc_client.bdev_lvol_set_leader(True, lvs_name=lvol.lvs_name)
909
- if not ret:
910
- logger.error(f"Failed to set leader for primary node: {snode.get_id()}")
911
- if not force_delete:
912
- return False
898
+ if sec_node.status != StorageNode.STATUS_ONLINE:
899
+ logger.error(f"Secondary node status is not online or offline, node: {sec_node.get_id()}, status: {sec_node.status}")
900
+ if not force_delete:
901
+ return False
913
902
 
914
- time.sleep(1)
903
+ ret = sec_rpc_client.bdev_lvol_set_leader(True, lvs_name=lvol.lvs_name)
904
+ if not ret:
905
+ logger.error(f"Failed to set leader for secondary node: {sec_node.get_id()}")
906
+ if not force_delete:
907
+ return False
908
+ ret = delete_lvol_from_node(lvol.get_id(), sec_node.get_id())
909
+ if not ret:
910
+ logger.error(f"Failed to delete lvol from node: {sec_node.get_id()}")
911
+ if not force_delete:
912
+ return False
913
+
914
+ else:
915
+
916
+
917
+ if sec_node.status == StorageNode.STATUS_ONLINE:
918
+ ret = sec_rpc_client.subsystem_delete(lvol.nqn)
919
+
920
+
921
+ # ret = sec_rpc_client.bdev_lvol_set_leader(False, lvs_name=lvol.lvs_name)
922
+ # if not ret:
923
+ # logger.error(f"Failed to set leader for secondary node: {sec_node.get_id()}")
924
+ # if not force_delete:
925
+ # return False
926
+ #
927
+ # time.sleep(1)
928
+ # rpc_client.subsystem_delete(lvol.nqn)
929
+ # rpc_client.bdev_lvol_set_leader(True, lvs_name=lvol.lvs_name)
930
+ # if not ret:
931
+ # logger.error(f"Failed to set leader for primary node: {snode.get_id()}")
932
+ # if not force_delete:
933
+ # return False
934
+ #
935
+ # time.sleep(1)
915
936
  ret = delete_lvol_from_node(lvol.get_id(), lvol.node_id)
916
937
  if not ret:
917
938
  logger.error(f"Failed to delete lvol from node: {snode.get_id()}")
918
939
  if not force_delete:
919
940
  return False
920
941
 
921
- time.sleep(1)
922
- ret = delete_lvol_from_node(lvol.get_id(), snode.secondary_node_id)
923
- if not ret:
924
- logger.error(f"Failed to delete lvol from node: {sec_node.get_id()}")
925
- if not force_delete:
926
- return False
942
+ # time.sleep(1)
927
943
 
928
- time.sleep(1)
929
- ret = sec_rpc_client.bdev_lvol_set_leader(False, lvs_name=lvol.lvs_name)
930
- if not ret:
931
- logger.error(f"Failed to set leader for secondary node: {sec_node.get_id()}")
932
- if not force_delete:
933
- return False
944
+ if sec_node.status == StorageNode.STATUS_ONLINE:
934
945
 
935
- time.sleep(1)
936
- ret = rpc_client.bdev_lvol_set_leader(True, lvs_name=lvol.lvs_name)
937
- if not ret:
938
- logger.error(f"Failed to set leader for primary node: {snode.get_id()}")
939
- if not force_delete:
940
- return False
946
+ ret = delete_lvol_from_node(lvol.get_id(), snode.secondary_node_id)
947
+ if not ret:
948
+ logger.error(f"Failed to delete lvol from node: {sec_node.get_id()}")
949
+ if not force_delete:
950
+ return False
951
+ #
952
+ # time.sleep(1)
953
+ # ret = sec_rpc_client.bdev_lvol_set_leader(False, lvs_name=lvol.lvs_name)
954
+ # if not ret:
955
+ # logger.error(f"Failed to set leader for secondary node: {sec_node.get_id()}")
956
+ # if not force_delete:
957
+ # return False
958
+ #
959
+ # time.sleep(1)
960
+ # ret = rpc_client.bdev_lvol_set_leader(True, lvs_name=lvol.lvs_name)
961
+ # if not ret:
962
+ # logger.error(f"Failed to set leader for primary node: {snode.get_id()}")
963
+ # if not force_delete:
964
+ # return False
941
965
 
942
966
  lvol_events.lvol_delete(lvol)
943
967
  lvol.remove(db_controller.kv_store)
@@ -1,5 +1,5 @@
1
1
  SIMPLY_BLOCK_COMMAND_NAME=sbcli-hmdi
2
- SIMPLY_BLOCK_VERSION=0.0.13
2
+ SIMPLY_BLOCK_VERSION=0.0.14
3
3
 
4
4
  SIMPLY_BLOCK_DOCKER_IMAGE=public.ecr.aws/simply-block/simplyblock:hmdi
5
5
  DOCKER_USER=hamdysimplyblock
@@ -2868,15 +2868,15 @@ def recreate_lvstore(snode):
2868
2868
  elif sec_node.status == StorageNode.STATUS_ONLINE:
2869
2869
  sec_rpc_client = RPCClient(sec_node.mgmt_ip, sec_node.rpc_port, sec_node.rpc_username, sec_node.rpc_password)
2870
2870
 
2871
- for lvol in lvol_list:
2872
- if lvol.ha_type == "ha":
2873
- for iface in sec_node.data_nics:
2874
- if iface.ip4_address:
2875
- ret = sec_rpc_client.nvmf_subsystem_listener_set_ana_state(
2876
- lvol.nqn, iface.ip4_address, lvol.subsys_port, False, "inaccessible")
2871
+ # for lvol in lvol_list:
2872
+ # if lvol.ha_type == "ha":
2873
+ # for iface in sec_node.data_nics:
2874
+ # if iface.ip4_address:
2875
+ # ret = sec_rpc_client.nvmf_subsystem_listener_set_ana_state(
2876
+ # lvol.nqn, iface.ip4_address, lvol.subsys_port, False, "inaccessible")
2877
2877
 
2878
- # sec_node_api = SNodeClient(sec_node.api_endpoint)
2879
- # sec_node_api.firewall_set_port(snode.lvol_subsys_port, "tcp", "block")
2878
+ sec_node_api = SNodeClient(sec_node.api_endpoint)
2879
+ sec_node_api.firewall_set_port(snode.lvol_subsys_port, "tcp", "block")
2880
2880
 
2881
2881
  sec_rpc_client.bdev_lvol_set_leader(False, lvs_name=snode.lvstore)
2882
2882
  sec_rpc_client.bdev_distrib_force_to_non_leader(snode.jm_vuid)
@@ -2954,13 +2954,16 @@ def recreate_lvstore(snode):
2954
2954
 
2955
2955
  if sec_node and sec_node.status == StorageNode.STATUS_ONLINE:
2956
2956
  time.sleep(10)
2957
- sec_rpc_client = RPCClient(sec_node.mgmt_ip, sec_node.rpc_port, sec_node.rpc_username, sec_node.rpc_password, timeout=3, retry=2)
2958
- for lvol in lvol_list:
2959
- if lvol.ha_type == "ha":
2960
- for iface in sec_node.data_nics:
2961
- if iface.ip4_address:
2962
- ret = sec_rpc_client.nvmf_subsystem_listener_set_ana_state(
2963
- lvol.nqn, iface.ip4_address, lvol.subsys_port, False)
2957
+ sec_node_api = SNodeClient(sec_node.api_endpoint)
2958
+ sec_node_api.firewall_set_port(snode.lvol_subsys_port, "tcp", "allow")
2959
+
2960
+ # sec_rpc_client = RPCClient(sec_node.mgmt_ip, sec_node.rpc_port, sec_node.rpc_username, sec_node.rpc_password, timeout=3, retry=2)
2961
+ # for lvol in lvol_list:
2962
+ # if lvol.ha_type == "ha":
2963
+ # for iface in sec_node.data_nics:
2964
+ # if iface.ip4_address:
2965
+ # ret = sec_rpc_client.nvmf_subsystem_listener_set_ana_state(
2966
+ # lvol.nqn, iface.ip4_address, lvol.subsys_port, False)
2964
2967
  return True
2965
2968
 
2966
2969
 
File without changes
File without changes
File without changes
File without changes