From a7af012b92f0dfd90cc3eb570e03144016646180 Mon Sep 17 00:00:00 2001 From: Melonai Date: Mon, 16 Aug 2021 18:17:06 +0200 Subject: Ability to pass request info through pipeline --- lib/rook_web/channels/request_channel.ex | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) (limited to 'lib/rook_web/channels/request_channel.ex') diff --git a/lib/rook_web/channels/request_channel.ex b/lib/rook_web/channels/request_channel.ex index cc84b0f..9773d30 100644 --- a/lib/rook_web/channels/request_channel.ex +++ b/lib/rook_web/channels/request_channel.ex @@ -1,10 +1,18 @@ defmodule RookWeb.RequestChannel do use RookWeb, :channel - def join("request:" <> token, %{"share" => share_token}, socket) do + def join("request:" <> token, %{"share" => share_token, "user_agent" => user_agent}, socket) do if Rook.Token.match?(token, socket) do if Rook.Share.exists?(share_token) do - Rook.Request.Actions.start(token, share_token) + ip = socket.assigns[:ip] + + info = %{ + ip: ip, + location: Rook.Identity.get_location_from_ip(ip), + client: Rook.Identity.get_client_from_user_agent(user_agent) + } + + Rook.Request.Actions.start(token, share_token, info) {:ok, socket} else {:error, %{reason: "No such share exists."}} -- cgit 1.4.1