aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/mongooseim/mongoose_im_controller.ex
diff options
context:
space:
mode:
authorrinpatch <rinpatch@sdf.org>2019-06-01 16:29:58 +0300
committerrinpatch <rinpatch@sdf.org>2019-06-01 16:29:58 +0300
commit65db5e9f528a3f8d8b3c81953fd160a6744dfffd (patch)
tree9da5234f8a9dd411b59e839eeb38254822939e2f /lib/pleroma/web/mongooseim/mongoose_im_controller.ex
parent300d94c62829d0ec961f3ed6c0242dea102ab0ad (diff)
parentf8d4c02431aa634dc74074b93d1cb522e47056ce (diff)
downloadpleroma-65db5e9f528a3f8d8b3c81953fd160a6744dfffd.tar.gz
Resolve merge conflicts
Diffstat (limited to 'lib/pleroma/web/mongooseim/mongoose_im_controller.ex')
-rw-r--r--lib/pleroma/web/mongooseim/mongoose_im_controller.ex41
1 files changed, 41 insertions, 0 deletions
diff --git a/lib/pleroma/web/mongooseim/mongoose_im_controller.ex b/lib/pleroma/web/mongooseim/mongoose_im_controller.ex
new file mode 100644
index 000000000..489d5d3a5
--- /dev/null
+++ b/lib/pleroma/web/mongooseim/mongoose_im_controller.ex
@@ -0,0 +1,41 @@
+# Pleroma: A lightweight social networking server
+# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
+# SPDX-License-Identifier: AGPL-3.0-only
+
+defmodule Pleroma.Web.MongooseIM.MongooseIMController do
+ use Pleroma.Web, :controller
+ alias Comeonin.Pbkdf2
+ alias Pleroma.Repo
+ alias Pleroma.User
+
+ def user_exists(conn, %{"user" => username}) do
+ with %User{} <- Repo.get_by(User, nickname: username, local: true) do
+ conn
+ |> json(true)
+ else
+ _ ->
+ conn
+ |> put_status(:not_found)
+ |> json(false)
+ end
+ end
+
+ def check_password(conn, %{"user" => username, "pass" => password}) do
+ with %User{password_hash: password_hash} <-
+ Repo.get_by(User, nickname: username, local: true),
+ true <- Pbkdf2.checkpw(password, password_hash) do
+ conn
+ |> json(true)
+ else
+ false ->
+ conn
+ |> put_status(403)
+ |> json(false)
+
+ _ ->
+ conn
+ |> put_status(:not_found)
+ |> json(false)
+ end
+ end
+end