Mercurial > prosody-modules
view mod_password_policy/mod_password_policy.lua @ 3223:9a89ec5030b5
mod_auth_http_cookie: Try to get HTTP request from array on BOSH sessions
This looks like a cleaner way. `session.requests` appears to have been
around a longer time than `_http_open_response`.
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Fri, 10 Aug 2018 06:10:38 +0200 |
parents | 1c14edca74a4 |
children | cb26d04b391c |
line wrap: on
line source
-- Password policy enforcement for Prosody -- -- Copyright (C) 2012 Waqas Hussain -- -- -- Configuration: -- password_policy = { -- length = 8; -- } local options = module:get_option("password_policy"); options = options or {}; options.length = options.length or 8; local st = require "util.stanza"; function check_password(password) return #password >= options.length; end function handler(event) local origin, stanza = event.origin, event.stanza; if stanza.attr.type == "set" then local query = stanza.tags[1]; local passwords = {}; local dataform = query:get_child("x", "jabber:x:data"); if dataform then for _,tag in ipairs(dataform.tags) do if tag.attr.var == "password" then table.insert(passwords, tag:get_child_text("value")); end end end table.insert(passwords, query:get_child_text("password")); for _,password in ipairs(passwords) do if password and not check_password(password) then origin.send(st.error_reply(stanza, "cancel", "not-acceptable", "Please use a longer password.")); return true; end end end end module:hook("iq/self/jabber:iq:register:query", handler, 10); module:hook("iq/host/jabber:iq:register:query", handler, 10); module:hook("stanza/iq/jabber:iq:register:query", handler, 10);