comparison src/login.js.luan @ 3:2c63b10781e1

add login
author Franklin Schmidt <fschmidt@gmail.com>
date Thu, 24 Oct 2024 21:43:44 -0600
parents
children a49866b52cc2
comparison
equal deleted inserted replaced
2:ee1f91e67509 3:2c63b10781e1
1 local Luan = require "luan:Luan.luan"
2 local error = Luan.error
3 local Io = require "luan:Io.luan"
4 local Http = require "luan:http/Http.luan"
5 local Shared = require "site:/lib/Shared.luan"
6 local send_mail_async = Shared.send_mail_async or error()
7 local Utils = require "site:/lib/Utils.luan"
8 local base_url = Utils.base_url or error()
9 local User = require "site:/lib/User.luan"
10
11
12 return function()
13 local email = Http.request.parameters.email or error()
14 local user = User.get_or_create_by_email(email)
15 local url = base_url().."/do_login.html?user="..user.id.."&password="..user.password
16 send_mail_async {
17 From = "Web Chat <chat@reactionary.software>"
18 To = email
19 Subject = "Login"
20 body = `%>
21 Here is the link to login:
22
23 <%= url %>
24 <% `
25 }
26 Io.stdout = Http.response.text_writer()
27 %>
28 location = '/login_sent.html';
29 <%
30 end