mirror of
https://github.com/processone/ejabberd.git
synced 2024-11-24 16:23:40 +01:00
Remove cyrsasl elixir tests, we no longer have it
This commit is contained in:
parent
11811e5f48
commit
b2b29269ec
@ -1,171 +0,0 @@
|
||||
# ----------------------------------------------------------------------
|
||||
#
|
||||
# ejabberd, Copyright (C) 2002-2017 ProcessOne
|
||||
#
|
||||
# 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.
|
||||
#
|
||||
# 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.,
|
||||
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
#
|
||||
# ----------------------------------------------------------------------
|
||||
|
||||
defmodule EjabberdCyrsaslTest do
|
||||
@author "pawel@process-one.net"
|
||||
|
||||
use ExUnit.Case, async: true
|
||||
|
||||
setup_all do
|
||||
:ok = :ejabberd.start_app(:lager)
|
||||
:p1_sha.load_nif()
|
||||
:mnesia.start
|
||||
:ejabberd_mnesia.start
|
||||
:ok = start_module(:stringprep)
|
||||
start_module(:jid)
|
||||
:ejabberd_hooks.start_link
|
||||
:ok = :ejabberd_config.start(["domain1"], [])
|
||||
{:ok, _} = :xmpp_sasl.start_link
|
||||
cyrstate = :xmpp_sasl.server_new("domain1", "domain1", "domain1", :ok, &get_password/1,
|
||||
&check_password/3, &check_password_digest/5)
|
||||
setup_anonymous_mocks()
|
||||
{:ok, cyrstate: cyrstate}
|
||||
end
|
||||
|
||||
test "Plain text (correct user and pass)", context do
|
||||
step1 = :xmpp_sasl.server_start(context[:cyrstate], "PLAIN", <<0,"user1",0,"pass">>)
|
||||
assert {:ok, _} = step1
|
||||
{:ok, kv} = step1
|
||||
assert kv[:authzid] == "user1", "got correct user"
|
||||
end
|
||||
|
||||
test "Plain text (correct user wrong pass)", context do
|
||||
step1 = :xmpp_sasl.server_start(context[:cyrstate], "PLAIN", <<0,"user1",0,"badpass">>)
|
||||
assert step1 == {:error, :not_authorized, "user1"}
|
||||
end
|
||||
|
||||
test "Plain text (wrong user wrong pass)", context do
|
||||
step1 = :xmpp_sasl.server_start(context[:cyrstate], "PLAIN", <<0,"nouser1",0,"badpass">>)
|
||||
assert step1 == {:error, :not_authorized, "nouser1"}
|
||||
end
|
||||
|
||||
test "Anonymous", context do
|
||||
step1 = :xmpp_sasl.server_start(context[:cyrstate], "ANONYMOUS", "domain1")
|
||||
assert {:ok, _} = step1
|
||||
end
|
||||
|
||||
test "Digest-MD5 (correct user and pass)", context do
|
||||
assert {:ok, _list} = process_digest_md5(context[:cyrstate], "user1", "domain1", "pass")
|
||||
end
|
||||
|
||||
test "Digest-MD5 (correct user wrong pass)", context do
|
||||
assert {:error, :not_authorized, "user1"} = process_digest_md5(context[:cyrstate], "user1", "domain1", "badpass")
|
||||
end
|
||||
|
||||
test "Digest-MD5 (wrong user correct pass)", context do
|
||||
assert {:error, :not_authorized, "baduser"} = process_digest_md5(context[:cyrstate], "baduser", "domain1", "pass")
|
||||
end
|
||||
|
||||
test "Digest-MD5 (wrong user and pass)", context do
|
||||
assert {:error, :not_authorized, "baduser"} = process_digest_md5(context[:cyrstate], "baduser", "domain1", "badpass")
|
||||
end
|
||||
|
||||
defp process_digest_md5(cyrstate, user, domain, pass) do
|
||||
assert {:continue, init_str, state1} = :xmpp_sasl.server_start(cyrstate, "DIGEST-MD5", "")
|
||||
assert [_, nonce] = Regex.run(~r/nonce="(.*?)"/, init_str)
|
||||
digest_uri = "xmpp/#{domain}"
|
||||
cnonce = "abcd"
|
||||
nc = "00000001"
|
||||
response_hash = calc_digest_md5(user, domain, pass, nc, nonce, cnonce)
|
||||
response = "username=\"#{user}\",realm=\"#{domain}\",nonce=\"#{nonce}\",cnonce=\"#{cnonce}\"," <>
|
||||
"nc=\"#{nc}\",qop=auth,digest-uri=\"#{digest_uri}\",response=\"#{response_hash}\"," <>
|
||||
"charset=utf-8,algorithm=md5-sess"
|
||||
case :xmpp_sasl.server_step(state1, response) do
|
||||
{:continue, _calc_str, state2} -> :xmpp_sasl.server_step(state2, "")
|
||||
other -> other
|
||||
end
|
||||
end
|
||||
|
||||
defp calc_digest_md5(user, domain, pass, nc, nonce, cnonce) do
|
||||
digest_uri = "xmpp/#{domain}"
|
||||
a0 = "#{user}:#{domain}:#{pass}"
|
||||
a1 = "#{str_md5(a0)}:#{nonce}:#{cnonce}"
|
||||
a2 = "AUTHENTICATE:#{digest_uri}"
|
||||
hex_md5("#{hex_md5(a1)}:#{nonce}:#{nc}:#{cnonce}:auth:#{hex_md5(a2)}")
|
||||
end
|
||||
|
||||
defp str_md5(str) do
|
||||
:erlang.md5(str)
|
||||
end
|
||||
|
||||
defp hex_md5(str) do
|
||||
:p1_sha.to_hexlist(:erlang.md5(str))
|
||||
end
|
||||
|
||||
defp setup_anonymous_mocks() do
|
||||
:meck.unload
|
||||
mock(:ejabberd_auth_anonymous, :is_sasl_anonymous_enabled,
|
||||
fn (_host) ->
|
||||
true
|
||||
end)
|
||||
mock(:ejabberd_auth, :user_exists,
|
||||
fn (user, domain) ->
|
||||
domain == "domain1" and get_password(user) != {:false, :internal}
|
||||
end)
|
||||
end
|
||||
|
||||
defp start_module(module) do
|
||||
case apply(module, :start, []) do
|
||||
:ok -> :ok
|
||||
{:error, {:already_started, _}} -> :ok
|
||||
other -> other
|
||||
end
|
||||
end
|
||||
|
||||
defp get_password(user) do
|
||||
if user == "user1" or user == "user2" do
|
||||
{"pass", :internal}
|
||||
else
|
||||
{:false, :internal}
|
||||
end
|
||||
end
|
||||
|
||||
defp check_password(_user, authzid, pass) do
|
||||
case get_password(authzid) do
|
||||
{^pass, mod} ->
|
||||
{true, mod}
|
||||
_ ->
|
||||
false
|
||||
end
|
||||
end
|
||||
|
||||
defp check_password_digest(_user, authzid, _pass, digest, digest_gen) do
|
||||
case get_password(authzid) do
|
||||
{:false, _} ->
|
||||
false
|
||||
{spass, mod} ->
|
||||
v = digest_gen.(spass)
|
||||
if v == digest do
|
||||
{true, mod}
|
||||
else
|
||||
false
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
defp mock(module, function, fun) do
|
||||
try do
|
||||
:meck.new(module, [:non_strict])
|
||||
catch
|
||||
:error, {:already_started, _pid} -> :ok
|
||||
end
|
||||
:meck.expect(module, function, fun)
|
||||
end
|
||||
end
|
Loading…
Reference in New Issue
Block a user