btpin.c revision 1.1 1 1.1 gdamore /* $NetBSD: btpin.c,v 1.1 2006/06/19 15:44:56 gdamore Exp $ */
2 1.1 gdamore
3 1.1 gdamore /*-
4 1.1 gdamore * Copyright (c) 2006 Itronix Inc.
5 1.1 gdamore * All rights reserved.
6 1.1 gdamore *
7 1.1 gdamore * Written by Iain Hibbert for Itronix Inc.
8 1.1 gdamore *
9 1.1 gdamore * Redistribution and use in source and binary forms, with or without
10 1.1 gdamore * modification, are permitted provided that the following conditions
11 1.1 gdamore * are met:
12 1.1 gdamore * 1. Redistributions of source code must retain the above copyright
13 1.1 gdamore * notice, this list of conditions and the following disclaimer.
14 1.1 gdamore * 2. Redistributions in binary form must reproduce the above copyright
15 1.1 gdamore * notice, this list of conditions and the following disclaimer in the
16 1.1 gdamore * documentation and/or other materials provided with the distribution.
17 1.1 gdamore * 3. The name of Itronix Inc. may not be used to endorse
18 1.1 gdamore * or promote products derived from this software without specific
19 1.1 gdamore * prior written permission.
20 1.1 gdamore *
21 1.1 gdamore * THIS SOFTWARE IS PROVIDED BY ITRONIX INC. ``AS IS'' AND
22 1.1 gdamore * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
23 1.1 gdamore * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
24 1.1 gdamore * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL ITRONIX INC. BE LIABLE FOR ANY
25 1.1 gdamore * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
26 1.1 gdamore * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
27 1.1 gdamore * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
28 1.1 gdamore * ON ANY THEORY OF LIABILITY, WHETHER IN
29 1.1 gdamore * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30 1.1 gdamore * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31 1.1 gdamore * POSSIBILITY OF SUCH DAMAGE.
32 1.1 gdamore */
33 1.1 gdamore
34 1.1 gdamore #include <sys/cdefs.h>
35 1.1 gdamore __COPYRIGHT("@(#) Copyright (c) 2006 Itronix, Inc\n"
36 1.1 gdamore "All rights reserved.\n");
37 1.1 gdamore __RCSID("$NetBSD: btpin.c,v 1.1 2006/06/19 15:44:56 gdamore Exp $");
38 1.1 gdamore
39 1.1 gdamore #include <sys/types.h>
40 1.1 gdamore #include <sys/un.h>
41 1.1 gdamore #include <bluetooth.h>
42 1.1 gdamore #include <err.h>
43 1.1 gdamore #include <stdlib.h>
44 1.1 gdamore #include <string.h>
45 1.1 gdamore #include <time.h>
46 1.1 gdamore #include <unistd.h>
47 1.1 gdamore
48 1.1 gdamore #include "bthcid.h"
49 1.1 gdamore
50 1.1 gdamore int main(int, char *[]);
51 1.1 gdamore void usage(void);
52 1.1 gdamore
53 1.1 gdamore int
54 1.1 gdamore main(int ac, char *av[])
55 1.1 gdamore {
56 1.1 gdamore client_pin_response_t rp;
57 1.1 gdamore struct sockaddr_un un;
58 1.1 gdamore char *pin = NULL;
59 1.1 gdamore int ch, s, len;
60 1.1 gdamore
61 1.1 gdamore memset(&rp, 0, sizeof(rp));
62 1.1 gdamore len = -1;
63 1.1 gdamore
64 1.1 gdamore memset(&un, 0, sizeof(un));
65 1.1 gdamore un.sun_len = sizeof(un);
66 1.1 gdamore un.sun_family = AF_LOCAL;
67 1.1 gdamore strlcpy(un.sun_path, BTHCID_SOCKET_NAME, sizeof(un.sun_path));
68 1.1 gdamore
69 1.1 gdamore while ((ch = getopt(ac, av, "a:d:l:p:rs:")) != EOF) {
70 1.1 gdamore switch (ch) {
71 1.1 gdamore case 'a':
72 1.1 gdamore if (!bt_aton(optarg, &rp.raddr)) {
73 1.1 gdamore struct hostent *he = NULL;
74 1.1 gdamore
75 1.1 gdamore if ((he = bt_gethostbyname(optarg)) == NULL)
76 1.1 gdamore errx(EXIT_FAILURE, "%s: %s", optarg,
77 1.1 gdamore hstrerror(h_errno));
78 1.1 gdamore
79 1.1 gdamore bdaddr_copy(&rp.raddr, (bdaddr_t *)he->h_addr);
80 1.1 gdamore }
81 1.1 gdamore break;
82 1.1 gdamore
83 1.1 gdamore case 'd':
84 1.1 gdamore if (!bt_devaddr(optarg, &rp.laddr))
85 1.1 gdamore err(EXIT_FAILURE, "%s", optarg);
86 1.1 gdamore
87 1.1 gdamore break;
88 1.1 gdamore
89 1.1 gdamore case 'l':
90 1.1 gdamore len = atoi(optarg);
91 1.1 gdamore if (len < 1 || len > HCI_PIN_SIZE)
92 1.1 gdamore errx(EXIT_FAILURE, "Invalid PIN length");
93 1.1 gdamore
94 1.1 gdamore break;
95 1.1 gdamore
96 1.1 gdamore case 'p':
97 1.1 gdamore pin = optarg;
98 1.1 gdamore break;
99 1.1 gdamore
100 1.1 gdamore case 'r':
101 1.1 gdamore if (len == -1)
102 1.1 gdamore len = 4;
103 1.1 gdamore
104 1.1 gdamore break;
105 1.1 gdamore
106 1.1 gdamore case 's':
107 1.1 gdamore strlcpy(un.sun_path, optarg, sizeof(un.sun_path));
108 1.1 gdamore break;
109 1.1 gdamore
110 1.1 gdamore default:
111 1.1 gdamore usage();
112 1.1 gdamore }
113 1.1 gdamore }
114 1.1 gdamore
115 1.1 gdamore if (bdaddr_any(&rp.raddr))
116 1.1 gdamore usage();
117 1.1 gdamore
118 1.1 gdamore if (pin == NULL) {
119 1.1 gdamore if (len == -1)
120 1.1 gdamore usage();
121 1.1 gdamore
122 1.1 gdamore srandom(time(NULL));
123 1.1 gdamore
124 1.1 gdamore pin = (char *)rp.pin;
125 1.1 gdamore while (len-- > 0)
126 1.1 gdamore *pin++ = '0' + (random() % 10);
127 1.1 gdamore
128 1.1 gdamore printf("PIN: %.*s\n", HCI_PIN_SIZE, rp.pin);
129 1.1 gdamore } else {
130 1.1 gdamore if (len != -1)
131 1.1 gdamore usage();
132 1.1 gdamore
133 1.1 gdamore strncpy((char *)rp.pin, pin, HCI_PIN_SIZE);
134 1.1 gdamore }
135 1.1 gdamore
136 1.1 gdamore s = socket(PF_LOCAL, SOCK_STREAM, 0);
137 1.1 gdamore if (s < 0)
138 1.1 gdamore err(EXIT_FAILURE, "socket");
139 1.1 gdamore
140 1.1 gdamore if (connect(s, (struct sockaddr *)&un, sizeof(un)) < 0)
141 1.1 gdamore err(EXIT_FAILURE, "connect(\"%s\")", un.sun_path);
142 1.1 gdamore
143 1.1 gdamore if (send(s, &rp, sizeof(rp), 0) != sizeof(rp))
144 1.1 gdamore err(EXIT_FAILURE, "send");
145 1.1 gdamore
146 1.1 gdamore close(s);
147 1.1 gdamore exit(EXIT_SUCCESS);
148 1.1 gdamore }
149 1.1 gdamore
150 1.1 gdamore void
151 1.1 gdamore usage(void)
152 1.1 gdamore {
153 1.1 gdamore
154 1.1 gdamore fprintf(stderr,
155 1.1 gdamore "usage: %s [-d device] [-s socket] [-p pin | -r [-l len]] -a addr\n"
156 1.1 gdamore "", getprogname());
157 1.1 gdamore
158 1.1 gdamore exit(EXIT_FAILURE);
159 1.1 gdamore }
160