2002-12-20 21:42:08 +01:00
|
|
|
%%%----------------------------------------------------------------------
|
|
|
|
%%% File : sha.erl
|
2007-12-24 13:58:05 +01:00
|
|
|
%%% Author : Alexey Shchepin <alexey@process-one.net>
|
2002-12-20 21:42:08 +01:00
|
|
|
%%% Purpose :
|
2007-12-24 13:58:05 +01:00
|
|
|
%%% Created : 20 Dec 2002 by Alexey Shchepin <alexey@process-one.net>
|
|
|
|
%%%
|
|
|
|
%%%
|
2011-02-14 13:47:22 +01:00
|
|
|
%%% ejabberd, Copyright (C) 2002-2011 ProcessOne
|
2007-12-24 13:58:05 +01:00
|
|
|
%%%
|
|
|
|
%%% This program is free software; you can redistribute it and/or
|
|
|
|
%%% modify it under the terms of the GNU General Public License as
|
|
|
|
%%% published by the Free Software Foundation; either version 2 of the
|
|
|
|
%%% License, or (at your option) any later version.
|
|
|
|
%%%
|
|
|
|
%%% This program is distributed in the hope that it will be useful,
|
|
|
|
%%% but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
%%% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
%%% General Public License for more details.
|
2009-01-12 15:44:42 +01:00
|
|
|
%%%
|
2007-12-24 13:58:05 +01:00
|
|
|
%%% You should have received a copy of the GNU General Public License
|
|
|
|
%%% along with this program; if not, write to the Free Software
|
|
|
|
%%% Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
|
|
|
%%% 02111-1307 USA
|
|
|
|
%%%
|
2002-12-20 21:42:08 +01:00
|
|
|
%%%----------------------------------------------------------------------
|
|
|
|
|
|
|
|
-module(sha).
|
2007-12-24 13:58:05 +01:00
|
|
|
-author('alexey@process-one.net').
|
2002-12-20 21:42:08 +01:00
|
|
|
|
2010-06-21 18:57:58 +02:00
|
|
|
-export([start/0, sha/1, sha1/1, sha224/1, sha256/1, sha384/1,
|
2010-08-07 14:28:48 +02:00
|
|
|
sha512/1]).
|
|
|
|
|
|
|
|
-ifdef(HAVE_MD2).
|
|
|
|
-export([md2/1]).
|
|
|
|
-endif.
|
2010-06-21 18:34:27 +02:00
|
|
|
|
|
|
|
-include("ejabberd.hrl").
|
|
|
|
|
|
|
|
-define(DRIVER, sha_drv).
|
2002-12-20 21:42:08 +01:00
|
|
|
|
|
|
|
start() ->
|
2010-06-21 18:34:27 +02:00
|
|
|
crypto:start(),
|
|
|
|
Res = case erl_ddll:load_driver(ejabberd:get_so_path(), ?DRIVER) of
|
|
|
|
ok -> ok;
|
|
|
|
{error, already_loaded} -> ok;
|
|
|
|
Err -> Err
|
|
|
|
end,
|
|
|
|
case Res of
|
|
|
|
ok ->
|
2010-08-13 17:01:08 +02:00
|
|
|
Port = open_port({spawn, atom_to_list(?DRIVER)}, [binary]),
|
2010-06-21 18:34:27 +02:00
|
|
|
register(?DRIVER, Port);
|
|
|
|
{error, Reason} ->
|
|
|
|
?CRITICAL_MSG("unable to load driver '~s': ~s",
|
|
|
|
[driver_path(), erl_ddll:format_error(Reason)])
|
|
|
|
end.
|
2002-12-20 21:42:08 +01:00
|
|
|
|
2003-01-09 20:59:16 +01:00
|
|
|
digit_to_xchar(D) when (D >= 0) and (D < 10) ->
|
|
|
|
D + 48;
|
|
|
|
digit_to_xchar(D) ->
|
|
|
|
D + 87.
|
2002-12-20 21:42:08 +01:00
|
|
|
|
|
|
|
sha(Text) ->
|
2003-01-09 20:59:16 +01:00
|
|
|
Bin = crypto:sha(Text),
|
|
|
|
lists:reverse(ints_to_rxstr(binary_to_list(Bin), [])).
|
|
|
|
|
|
|
|
ints_to_rxstr([], Res) ->
|
|
|
|
Res;
|
|
|
|
ints_to_rxstr([N | Ns], Res) ->
|
|
|
|
ints_to_rxstr(Ns, [digit_to_xchar(N rem 16),
|
|
|
|
digit_to_xchar(N div 16) | Res]).
|
2002-12-20 21:42:08 +01:00
|
|
|
|
2010-06-21 18:34:27 +02:00
|
|
|
sha1(Text) ->
|
|
|
|
crypto:sha(Text).
|
|
|
|
|
|
|
|
sha224(Text) ->
|
|
|
|
erlang:port_control(?DRIVER, 224, Text).
|
|
|
|
|
|
|
|
sha256(Text) ->
|
|
|
|
erlang:port_control(?DRIVER, 256, Text).
|
|
|
|
|
|
|
|
sha384(Text) ->
|
|
|
|
erlang:port_control(?DRIVER, 384, Text).
|
|
|
|
|
|
|
|
sha512(Text) ->
|
|
|
|
erlang:port_control(?DRIVER, 512, Text).
|
|
|
|
|
2010-08-07 14:28:48 +02:00
|
|
|
-ifdef(HAVE_MD2).
|
2010-06-21 18:57:58 +02:00
|
|
|
md2(Text) ->
|
|
|
|
erlang:port_control(?DRIVER, 2, Text).
|
2010-08-07 14:28:48 +02:00
|
|
|
-endif.
|
2010-06-21 18:57:58 +02:00
|
|
|
|
2010-06-21 18:34:27 +02:00
|
|
|
driver_path() ->
|
|
|
|
Suffix = case os:type() of
|
|
|
|
{win32, _} -> ".dll";
|
|
|
|
_ -> ".so"
|
|
|
|
end,
|
|
|
|
filename:join(ejabberd:get_so_path(), atom_to_list(?DRIVER) ++ Suffix).
|