mirror of
https://github.com/processone/ejabberd.git
synced 2024-12-30 17:43:57 +01:00
108 lines
4.2 KiB
Elixir
108 lines
4.2 KiB
Elixir
# ----------------------------------------------------------------------
|
|
#
|
|
# 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 EjabberdCommandsTest do
|
|
@author "mremond@process-one.net"
|
|
|
|
use ExUnit.Case, async: true
|
|
|
|
require Record
|
|
Record.defrecord :ejabberd_commands, Record.extract(:ejabberd_commands, from_lib: "ejabberd/include/ejabberd_commands.hrl")
|
|
|
|
setup_all do
|
|
:mnesia.start
|
|
:stringprep.start
|
|
:ok = :ejabberd_config.start(["localhost"], [])
|
|
{:ok, _} = :ejabberd_access_permissions.start_link()
|
|
|
|
:ejabberd_commands.init
|
|
:ok
|
|
end
|
|
|
|
test "Check that we can register a command" do
|
|
:ok = :ejabberd_commands.register_commands([user_test_command])
|
|
commands = :ejabberd_commands.list_commands
|
|
assert Enum.member?(commands, {:test_user, [], "Test user"})
|
|
end
|
|
|
|
test "get_exposed_commands/0 returns registered commands" do
|
|
commands = [open_test_command]
|
|
:ok = :ejabberd_commands.register_commands(commands)
|
|
:ok = :ejabberd_commands.expose_commands(commands)
|
|
exposed_commands = :ejabberd_commands.get_exposed_commands
|
|
assert Enum.member?(exposed_commands, :test_open)
|
|
end
|
|
|
|
test "Check that admin commands are rejected with noauth credentials" do
|
|
:ok = :ejabberd_commands.register_commands([admin_test_command])
|
|
|
|
assert catch_throw(:ejabberd_commands.execute_command(:undefined, :noauth, :test_admin, [])) == {:error, :account_unprivileged}
|
|
|
|
# Command executed from ejabberdctl passes anyway with access commands trick
|
|
# TODO: We should refactor to have explicit call when bypassing auth check for command-line
|
|
:ok = :ejabberd_commands.execute_command([], :noauth, :test_admin, [])
|
|
end
|
|
|
|
# TODO Test that we can add command to list of expose commands
|
|
# This can be done with:
|
|
# ejabberd_config:add_local_option(commands, [[{add_commands, [open_cmd]}]]).
|
|
|
|
# test "Check that a user can use a user command" do
|
|
# [Command] = ets:lookup(ejabberd_commands, test_user),
|
|
# AccessCommands = ejabberd_commands:get_access_commands(undefined),
|
|
# ejabberd_commands:check_access_commands(AccessCommands, {<<"test">>,<<"localhost">>, {oauth,<<"MyToken">>}, false}, test_user, Command, []).
|
|
# end
|
|
|
|
defp user_test_command do
|
|
ejabberd_commands(name: :test_user, tags: [:roster],
|
|
desc: "Test user",
|
|
policy: :user,
|
|
module: __MODULE__,
|
|
function: :test_user,
|
|
args: [],
|
|
result: {:contacts, {:list, {:contact, {:tuple, [
|
|
{:jid, :string},
|
|
{:nick, :string}
|
|
]}}}})
|
|
end
|
|
|
|
defp open_test_command do
|
|
ejabberd_commands(name: :test_open, tags: [:test],
|
|
desc: "Test open",
|
|
policy: :open,
|
|
module: __MODULE__,
|
|
function: :test_open,
|
|
args: [],
|
|
result: {:res, :rescode})
|
|
end
|
|
|
|
defp admin_test_command do
|
|
ejabberd_commands(name: :test_admin, tags: [:roster],
|
|
desc: "Test admin",
|
|
policy: :restricted,
|
|
module: __MODULE__,
|
|
function: :test_admin,
|
|
args: [],
|
|
result: {:res, :rescode})
|
|
end
|
|
|
|
def test_admin, do: :ok
|
|
end
|