Software /
code /
prosody-modules
File
mod_measure_modules/mod_measure_modules.lua @ 6112:4c0e3fe57e92
mod_compliance_latest: Gracefull error logging on missing dependency.
diff --git a/mod_compliance_latest/README.md b/mod_compliance_latest/README.md
--- a/mod_compliance_latest/README.md
+++ b/mod_compliance_latest/README.md
@@ -9,13 +9,15 @@ rockspec:
# Introduction
-This module will always require and load to the lastest compliance tester we have in the community modules.
-Currently this is [mod_compliance_2023].
+This meta-module will always `require` (and therefore auto-load) the lastest compliance tester we have in the community modules.
+Currently this is [mod_compliance_2023]. See the linked module for further details.
+
+If you do not use the *Prosody plugin installer* this module will likely have limited value to you.
+You can also just install the current compliance tester manually.
# Configuration
-Just load this module as any other module and it will automatically install [mod_compliance_2023] if you use the Prosody plugin installer.
-See the linked module for further details.
+Just load this module as any other module and it will automatically install and load [mod_compliance_2023] if you use the *Prosody plugin installer*.
# Compatibility
diff --git a/mod_compliance_latest/mod_compliance_latest.lua b/mod_compliance_latest/mod_compliance_latest.lua
--- a/mod_compliance_latest/mod_compliance_latest.lua
+++ b/mod_compliance_latest/mod_compliance_latest.lua
@@ -1,1 +1,6 @@
-module:depends("compliance_2023");
+local success, err = pcall(function() module:depends("compliance_2023") end)
+
+if not success then
+ module:log("error", "Error, can't load module: mod_compliance_2023. Is this module downloaded in a folder readable by prosody?")
+ return 1, "Error: Couldn't load dependency mod_compliance_2023."
+end
author | Menel <menel@snikket.de> |
---|---|
date | Mon, 23 Dec 2024 12:58:03 +0100 |
parent | 5691:ecfd7aece33b |
line wrap: on
line source
module:set_global(); local mm = require "core.modulemanager"; local sm = require "core.statsmanager"; local measure_status = sm.metric("gauge", "prosody_module_status", "", "Prosody module status", { "host"; "module" }); local status_priorities = { error = 3; warn = 2; info = 1; core = 0 }; function module.add_host(module) local measure = measure_status:with_partial_label(module.host); if module.global then measure = measure_status:with_partial_label(":global"); end -- Already loaded modules local modules = mm.get_modules(module.host); for name, mod in pairs(modules) do measure:with_labels(name):set(status_priorities[mod.module.status_type] or 0); end -- TODO hook module load and unload -- Future changes module:hook("module-status/updated", function(event) local mod = mm.get_module(event.name); measure:with_labels(event.name):set(status_priorities[mod and mod.module.status_type] or 0); end); end module:add_host(); -- Initialize global context