a37f44ed20 | ||
---|---|---|
.. | ||
conf | ||
lib | ||
COPYING | ||
README.md | ||
mod_captcha_rust.spec |
README.md
mod_captcha_rust - Generate CAPTCHAs using Rust library
Requires:
- ejabberd 23.xx or higher compiled with Elixir
- Erlang/OTP and Elixir to ompile the
captcha_nif
Elixir library - Rust compiler (package
rustc
in some package managers)
This small module generates CAPTCHA images suitable for ejabberd's CAPTCHA feature, thanks to the captcha Elixir library, which internally uses the captcha Rust library.
Get captcha_nif library
This module depends on an Elixir library, and there are two ways to get it installed, depending if you compile ejabberd from source code or installed in binary:
A) ejabberd source code
If you compile ejabberd from source code, go to the path with your ejabberd source code and apply this small patch:
--- a/mix.exs
+++ b/mix.exs
@@ -99,6 +99,7 @@ defmodule Ejabberd.MixProject do
defp deps do
[{:base64url, "~> 1.0"},
+ {:captcha_nif, "~> 0.1", hex: :captcha_nif},
{:cache_tab, "~> 1.0"},
{:eimp, "~> 1.0"},
{:ex_doc, ">= 0.0.0", only: :dev},
Then get the new dependecies, and compile as usual:
mix deps.get
make
Install ejabberd as usual, restart it
and now you can proceed to install mod_captchanif
.
B) ejabberd with binary installer
If you installed ejabberd using some kind of binary installer, you can download, compile and install the required library manually:
git clone https://github.com/feng19/captcha.git
cd captcha/
mix deps.get
mix
mix release
Copy all the directories from _build/dev/rel/captcha/lib
to the path where you have ejabberd lib directories installed.
Now you can restart ejabberd and proceed to install mod_captchanif
.
Basic Configuration
The minimal configuration required to get this module working is:
captcha_cmd: 'Elixir.ModCaptchaRust'
captcha_url: http://localhost:5280/captcha
listen:
-
port: 5280
module: ejabberd_http
request_handlers:
/captcha: ejabberd_captcha
Options
This module supports those configurable options:
-
difficulty
Sets the CAPTCHA difficulty, it can be
easy
,medium
orhard
. Default value:easy
. -
color
Sets the CAPTCHA color, as a list of RGB integers from 0 to 255. Default value:
[0, 0, 0]
.
Example of module configuration:
modules:
'Elixir.ModCaptchaRust':
difficulty: hard
color: [255, 0, 0]