jcs
/wifi_da
/amendments
/27
*: Add dialog to manually specify another/hidden SSID
jcs made amendment 27 4 months ago
--- README Sun Jan 28 00:05:35 2024
+++ README Tue Sep 17 20:46:39 2024
@@ -18,6 +18,11 @@ To install on System 6, use the Font/DA Mover utility:
There should now be a Wi-Fi option in the Apple menu.
+Change history:
+
+1.2 - 2024-09-18
+ - Add option to manually specify another (possibly hidden) SSID
+
1.1 - 2024-01-29
- Fix password entry in connection dialog on Mac OS 8+
--- wi-fi.h Sat Jan 27 23:43:26 2024
+++ wi-fi.h Tue Sep 17 20:22:36 2024
@@ -35,6 +35,9 @@
#define ABOUT_DIALOG_ID 2
+#define SSID_DIALOG_ID 3
+#define SSID_DIALOG_NAME_FIELD_ID 3
+
#define BLUESCSI_NETWORK_WIFI_CMD 0x1c
#define BLUESCSI_NETWORK_WIFI_CMD_SCAN 0x01
#define BLUESCSI_NETWORK_WIFI_CMD_COMPLETE 0x02
@@ -73,7 +76,8 @@ struct wifi_network_entry {
char rssi;
unsigned char channel;
unsigned char flags;
-#define WIFI_NETWORK_FLAG_AUTH 0x1
+#define WIFI_NETWORK_FLAG_AUTH (1 << 1)
+#define WIFI_NETWORK_FLAG_HIDDEN (1 << 2)
char _padding;
};
--- Wi-Fi DA.π.r Sun Jan 28 00:11:11 2024
+++ Wi-Fi DA.π.r Tue Sep 17 20:45:37 2024
@@ -8,7 +8,7 @@ data 'DITL' (-16000) {
$"5E30 5E31 5E32 5E33" /* ^0^1^2^3 */
};
-data 'DITL' (-15999, "CONNECT") {
+data 'DITL' (-15999, "PASSWORD") {
$"0005 0000 0000 0050 0136 0064 017F 0407" /* .......P.6.d.... */
$"436F 6E6E 6563 745B 0000 0000 0050 00E6" /* Connect[.....P.. */
$"0064 012F 0406 4361 6E63 656C 0000 0000" /* .d./..Cancel.... */
@@ -28,6 +28,17 @@ data 'DITL' (-15998, "ABOUT", purgeable, preload) {
$"0000 FFD8 0106 011E C002 C180" /* ...ÿ....¿.¡Ä */
};
+data 'DITL' (-15997, "SSID") {
+ $"0004 0000 0000 0041 0136 0055 017F 0408" /* .......A.6.U.... */
+ $"436F 6E74 696E 7565 0000 0000 0041 00E6" /* Continue.....A.. */
+ $"0055 012F 0406 4361 6E63 656C 0000 0000" /* .U./..Cancel.... */
+ $"0023 005A 0033 017D 1000 0000 0000 0023" /* .#.Z.3.}.......# */
+ $"000A 0033 0055 8805 5353 4944 3A00 0000" /* ...3.Uà.SSID:... */
+ $"0000 000A 000A 001C 0105 881D 456E 7465" /* ..........à.Ente */
+ $"7220 7468 6520 5769 2D46 6920 6E65 7477" /* r the Wi-Fi netw */
+ $"6F72 6B20 5353 4944 3A00" /* ork SSID:. */
+};
+
data 'MENU' (-15999) {
$"C181 0000 0000 0000 0000 FFFF FFFF 0557" /* ¡Å.............W */
$"692D 4669 0E41 626F 7574 2057 692D 4669" /* i-Fi.About Wi-Fi */
@@ -50,6 +61,12 @@ data 'DLOG' (-15998) {
$"0000 C182 0000 280A" /* ..¡Ç..(. */
};
+data 'DLOG' (-15997) {
+ $"0076 0036 00D4 01C4 0010 0000 0100 0000" /* .v.6.‘.ƒ........ */
+ $"0000 C183 0A57 692D 4669 2053 5349 4477" /* ..¡É.Wi-Fi SSIDw */
+ $"680A" /* h. */
+};
+
data 'SICN' (-16000) {
$"0000 6006 700E 3FFC 1FF8 3E7C 67E6 4FF2" /* ..`.p.?...>|g.O. */
$"1BD8 17E8 0FF0 1C38 399C 718E 6006 0000" /* .ÿ.....89úqé`... */
@@ -92,7 +109,7 @@ data 'BNDL' (-16000) {
};
data 'vers' (1) {
- $"0110 8000 0000 0331 2E31 2B31 2E31 20A9" /* ..Ä....1.1+1.1 © */
+ $"0120 8000 0000 0331 2E32 2B31 2E32 20A9" /* . Ä....1.2+1.2 © */
$"2032 3032 332D 3230 3234 2C20 6A6F 7368" /* 2023-2024, josh */
$"7561 2073 7465 696E 203C 6A63 7340 6A63" /* ua stein <jcs@jc */
$"732E 6F72 673E" /* s.org> */
@@ -531,7 +548,7 @@ data 'PICT' (-16000) {
};
data 'dast' (-16000) {
- $"5D76 312E 310D 4465 736B 2041 6363 6573" /* ]v1.1¬Desk Acces */
+ $"5D76 312E 320D 4465 736B 2041 6363 6573" /* ]v1.2¬Desk Acces */
$"736F 7279 2066 6F72 2042 6C75 6553 4353" /* sory for BlueSCS */
$"490D A920 3230 3234 2C20 6A6F 7368 7561" /* I© 2024, joshua */
$"2073 7465 696E 0D0D 5765 623A 2068 7474" /* stein¬¬Web: htt */
--- window.c Sat Jan 27 23:53:39 2024
+++ window.c Tue Sep 17 20:38:48 2024
@@ -20,6 +20,7 @@
#define NO_DEVICE_TEXT "\pNo Device Found"
#define NO_NETWORK_TEXT "(No Network)"
+#define OTHER_NETWORK_TEXT "(Other Network)"
#define DA_HEIGHT 25
#define DA_WIDTH 180
@@ -240,7 +241,7 @@ update_wifi_ssid_list(bool update_networks)
nwifi_menu_networks = nitems(wifi_menu_networks);
DEBUG_LOG(("capping nets to %d", nwifi_menu_networks));
}
-
+
/* add each additional network from the scan, excluding current */
for (n = 0, m = 1; n < nwifi_menu_networks; n++) {
if (strcmp(wifi_scan_networks[n].ssid,
@@ -258,9 +259,17 @@ update_wifi_ssid_list(bool update_networks)
nwifi_menu_networks = m;
- if (wifi_menu_networks[0].ssid[0] == '\0')
+ if (wifi_menu_networks[0].ssid[0] == '\0') {
strlcpy(wifi_menu_networks[0].ssid, NO_NETWORK_TEXT,
sizeof(wifi_menu_networks[0].ssid));
+ nwifi_menu_networks++;
+ }
+
+ /* keep "other network" as last entry */
+ strlcpy(wifi_menu_networks[nwifi_menu_networks - 1].ssid,
+ OTHER_NETWORK_TEXT, sizeof(wifi_menu_networks[0].ssid));
+ wifi_menu_networks[nwifi_menu_networks - 1].flags =
+ WIFI_NETWORK_FLAG_AUTH | WIFI_NETWORK_FLAG_HIDDEN;
/* leave the first item and we'll set its text later */
while (CountMItems(ssid_menu) > 1)
@@ -289,7 +298,7 @@ update_wifi_ssid_list(bool update_networks)
mitem++;
}
-
+
update_window(true);
}
@@ -325,8 +334,7 @@ destroy_window(void)
void
window_mousedown(Point p)
{
- Str255 password;
- char ssid[64];
+ Str255 password, ssid;
Rect r, irect;
GrafPtr savePort;
short mitems, n, selitem, hit, itype;
@@ -373,10 +381,46 @@ window_mousedown(Point p)
net = &wifi_menu_networks[loword(new_net) - 1];
memset(&wjr, 0, sizeof(wjr));
- strlcpy(wjr.ssid, net->ssid, sizeof(wjr.ssid));
+
+ if (net->flags & WIFI_NETWORK_FLAG_HIDDEN) {
+ dg = GetNewDialog(OwnedResourceID(SSID_DIALOG_ID), 0L,
+ (WindowPtr)-1L);
+ center_in_screen(((DialogPeek)dg)->window.port.portRect.right,
+ ((DialogPeek)dg)->window.port.portRect.bottom, false, &r);
+ MoveWindow(dg, r.left, r.top, false);
+
+ ShowWindow(dg);
+ SetPort(dg);
+
+ /* outline continue button */
+ GetDItem(dg, ok, &itype, &ihandle, &irect);
+ PenSize(3, 3);
+ InsetRect(&irect, -4, -4);
+ FrameRoundRect(&irect, 16, 16);
+ PenNormal();
+
+ for (;;) {
+ ModalDialog(WiFiPasswordDialogFieldFilter, &hit);
+ if (hit == ok || hit == cancel)
+ break;
+ }
+
+ if (hit != ok) {
+ DisposDialog(dg);
+ goto menu_done;
+ }
+
+ GetDItem(dg, SSID_DIALOG_NAME_FIELD_ID, &itype, &ihandle, &irect);
+ GetIText(ihandle, &ssid);
+ PtoCstr(ssid);
+ strlcpy(wjr.ssid, (char *)ssid, sizeof(wjr.ssid));
+
+ DisposDialog(dg);
+ } else
+ strlcpy(wjr.ssid, net->ssid, sizeof(wjr.ssid));
if (net->flags & WIFI_NETWORK_FLAG_AUTH) {
- strlcpy(ssid, net->ssid, sizeof(ssid));
+ strlcpy((char *)ssid, wjr.ssid, sizeof(ssid));
CtoPstr(ssid);
ParamText(ssid, "\p", "\p", "\p");
PtoCstr(ssid);