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
79
80
81
82
|
.\" $OpenBSD: htpasswd.1,v 1.5 2014/03/24 20:33:01 florian Exp $
.\"
.\" Copyright (c) 2014 Florian Obser <florian@openbsd.org>
.\"
.\" Permission to use, copy, modify, and distribute this software for any
.\" purpose with or without fee is hereby granted, provided that the above
.\" copyright notice and this permission notice appear in all copies.
.\"
.\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
.\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
.\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
.\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
.\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
.\"
.Dd $Mdocdate: March 24 2014 $
.Dt HTPASSWD 1
.Os
.Sh NAME
.Nm htpasswd
.Nd create and update user authentication files
.Sh SYNOPSIS
.Nm
.Op Ar file
.Ar login
.Nm
.Fl I
.Op Ar file
.Sh DESCRIPTION
.Nm
is used to create and update user authentication files for
HTTP daemons such as
.Xr nginx 8 .
.Pp
The options are as follows:
.Bl -tag -width Ds
.It Fl I
Switch to batch mode.
.Nm
reads exactly one line from standard input and splits it at the first
.Qo : Qc .
The first part is the login, the second part is the password which
.Nm
then hashes using
.Xr bcrypt 3 .
.El
.Pp
.Nm
prompts for a password and generates a hash using
.Xr bcrypt 3 .
A line suitable for a password file,
such as
.Ic auth_basic_user_file
in
.Xr nginx 8 ,
is written to standard output.
If invoked with two arguments
.Po
or one argument if the
.Fl I
flag is used
.Pc
user authentication
.Ar file
is updated.
.Sh SEE ALSO
.Xr bcrypt 3 ,
.Xr nginx.conf 5 ,
.Xr nginx 8
.Sh HISTORY
This reimplemented version of
.Nm
has been available since
.Ox 5.6 .
.Sh AUTHORS
.An Florian Obser Aq Mt florian@openbsd.org
implemented
.Nm
from scratch after httpd was removed from
.Ox
base.
|