1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
|
------------------------------------------------------------------------------
-- Ada Web Server --
-- --
-- Copyright (C) 2003-2004 --
-- ACT-Europe --
-- --
-- This library 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 library 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 library; if not, write to the Free Software Foundation, --
-- Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. --
-- --
------------------------------------------------------------------------------
with AWS.Digest;
package body Auth_CB is
Auth_Username : constant String := "AWS";
Auth_Password : constant String := "letmein";
---------
-- Get --
---------
function Get (Request : in AWS.Status.Data) return AWS.Response.Data is
use type AWS.Response.Authentication_Mode;
use type AWS.Status.Authorization_Type;
Username : constant String := AWS.Status.Authorization_Name (Request);
Client_Mode : constant AWS.Status.Authorization_Type
:= AWS.Status.Authorization_Mode (Request);
begin
if Client_Mode = AWS.Status.Basic -- It is Basic authentication.
and then Username = Auth_Username
and then AWS.Status.Authorization_Password (Request) = Auth_Password
and then (Auth_Mode = AWS.Response.Any
or Auth_Mode = AWS.Response.Basic)
then
return AWS.Response.Build
("text/html",
"<p>Basic authorization OK!");
elsif Client_Mode = AWS.Status.Digest -- It is Digest authentication.
and then Username = Auth_Username
and then AWS.Status.Check_Digest (Request, Auth_Password)
and then (Auth_Mode = AWS.Response.Any
or Auth_Mode = AWS.Response.Digest)
then
if
AWS.Digest.Check_Nonce
(AWS.Digest.Nonce (AWS.Status.Authorization_Nonce (Request)))
then
return AWS.Response.Build
("text/html",
"<p>Digest authorization OK!<br>"
& AWS.Status.Authorization_NC (Request));
else
-- Nonce is stale
return AWS.Response.Authenticate
("AWS restricted usage", Auth_Mode, Stale => True);
end if;
else
-- Unauthorized
return AWS.Response.Authenticate ("AWS restricted usage", Auth_Mode);
end if;
end Get;
end Auth_CB;
|