/* NetworkManager -- Network link manager * * Dan Williams * * This program 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 program 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 program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * (C) Copyright 2004 Red Hat, Inc. */ #include #include #include #include "NetworkManager.h" #include "NetworkManagerDevice.h" #include "NetworkManagerWireless.h" #include "NetworkManagerPolicy.h" #include "NetworkManagerUtils.h" extern gboolean debug; /* * nm_wireless_128bit_key_from_passphrase * * From a passphrase, generate a standard 128-bit WEP key using * MD5 algorithm. * */ char *nm_wireless_128bit_key_from_passphrase (char *passphrase) { char temp_buf [65]; char *ascii_key = g_new0 (char, 32); char *raw_key = g_new0 (char, 16); int passphrase_len; MD5_CTX md5_ctx; int i; g_return_val_if_fail (passphrase != NULL, NULL); /* Get at least 64 bits */ passphrase_len = strlen (passphrase); for (i = 0; i < 64; i++) temp_buf [i] = passphrase [i % passphrase_len]; /* Generate the actual WEP key */ MD5_Init (&md5_ctx); MD5_Update (&md5_ctx, (const void *)temp_buf, 64); MD5_Final (raw_key, &md5_ctx); /* Convert raw key into ASCII key. Unfortunately, we must do this * because we cannot deal with raw keys quite yet. */ for (i = 0; i < 16; i++) { char *temp = g_strdup_printf ("%02x", raw_key [i]); strncat (ascii_key, temp+(strlen(temp)-2), 2); g_free (temp); } ascii_key [26] = '\0'; return (ascii_key); } /* * nm_wireless_scan_monitor * * Called every 10s to get a list of access points. * */ gboolean nm_wireless_scan_monitor (gpointer user_data) { NMData *data = (NMData *)user_data; g_return_val_if_fail (data != NULL, TRUE); if (!data->active_device) return (TRUE); /* Attempt to acquire mutex so that data->active_device sticks around. * If the acquire fails, just ignore the scan completely. */ if (nm_try_acquire_mutex (data->dev_list_mutex, __FUNCTION__)) { if (data->active_device && nm_device_is_wireless (data->active_device)) nm_device_do_wireless_scan (data->active_device); nm_unlock_mutex (data->dev_list_mutex, __FUNCTION__); } else syslog( LOG_ERR, "nm_wireless_scan_monitor() could not acquire device list mutex." ); return (TRUE); }