1
0
mirror of https://github.com/arduino/Arduino.git synced 2025-01-18 07:52:14 +01:00
Arduino/WiFi/WiFi.h

169 lines
4.0 KiB
C
Raw Normal View History

2011-02-28 13:49:08 +01:00
#ifndef WiFi_h
#define WiFi_h
#include <inttypes.h>
extern "C" {
#include "utility/wl_definitions.h"
#include "utility/wl_types.h"
2011-02-28 13:49:08 +01:00
}
#include "IPAddress.h"
#include "WiFiClient.h"
#include "WiFiServer.h"
2011-02-28 13:49:08 +01:00
class WiFiClass
{
private:
static void init();
2011-02-28 13:49:08 +01:00
public:
static int16_t _state[MAX_SOCK_NUM];
2011-02-28 13:49:08 +01:00
static uint16_t _server_port[MAX_SOCK_NUM];
2011-03-01 19:38:14 +01:00
2011-02-28 13:49:08 +01:00
WiFiClass();
2012-03-07 00:05:54 +01:00
/*
* Get the first socket available
*/
static uint8_t getSocket();
/* Start Wifi connection for OPEN networks
*
* param ssid: Pointer to the SSID string.
*/
int begin(char* ssid);
2011-02-28 13:49:08 +01:00
/* Start Wifi connection with WEP encryption.
* Configure a key into the device. The key type (WEP-40, WEP-104)
* is determined by the size of the key (5 bytes for WEP-40, 13 bytes for WEP-104).
*
* param ssid: Pointer to the SSID string.
* param key_idx: The key index to set. Valid values are 0-3.
* param key: Key input buffer.
*/
int begin(char* ssid, uint8_t key_idx, const char* key);
2011-02-28 13:49:08 +01:00
/* Start Wifi connection with passphrase
* the most secure supported mode will be automatically selected
*
2012-03-07 00:05:54 +01:00
* param ssid: Pointer to the SSID string.
* param passphrase: Passphrase. Valid characters in a passphrase
* must be between ASCII 32-126 (decimal).
*/
int begin(char* ssid, const char *passphrase);
2011-02-28 13:49:08 +01:00
2012-03-07 00:05:54 +01:00
/*
* Disconnect from the network
*
* return: one value of wl_status_t enum
*/
int disconnect(void);
2011-02-28 13:49:08 +01:00
2012-03-07 00:05:54 +01:00
/*
* Get the interface MAC address.
*
* return: pointer to uint8_t array with length WL_MAC_ADDR_LENGTH
*/
uint8_t* macAddress(uint8_t* mac);
2011-02-28 13:49:08 +01:00
2012-03-07 00:05:54 +01:00
/*
* Get the interface IP address.
*
* return: Ip address value
*/
2011-06-06 01:27:45 +02:00
IPAddress localIP();
2011-02-28 13:49:08 +01:00
2012-03-07 00:05:54 +01:00
/*
* Get the interface subnet mask address.
*
* return: subnet mask address value
*/
IPAddress subnetMask();
2011-02-28 13:49:08 +01:00
2012-03-07 00:05:54 +01:00
/*
* Get the gateway ip address.
*
* return: gateway ip address value
*/
IPAddress gatewayIP();
2011-02-28 13:49:08 +01:00
2012-03-07 00:05:54 +01:00
/*
* Return the current SSID associated with the network
*
* return: ssid string
*/
char* SSID();
2011-02-28 13:49:08 +01:00
2012-03-07 00:05:54 +01:00
/*
* Return the current BSSID associated with the network.
* It is the MAC address of the Access Point
*
* return: pointer to uint8_t array with length WL_MAC_ADDR_LENGTH
*/
uint8_t* BSSID(uint8_t* bssid);
2011-02-28 13:49:08 +01:00
2012-03-07 00:05:54 +01:00
/*
* Return the current RSSI /Received Signal Strength in dBm)
* associated with the network
*
* return: signed value
*/
int32_t RSSI();
2012-03-07 00:05:54 +01:00
/*
* Return the Encryption Type associated with the network
*
* return: one value of wl_enc_type enum
*/
uint8_t encryptionType();
2011-02-28 13:49:08 +01:00
2012-03-07 00:05:54 +01:00
/*
* Start scan WiFi networks available
*
* return: Number of discovered networks
*/
uint8_t scanNetworks();
2012-03-07 00:05:54 +01:00
/*
* Return the SSID discovered during the network scan.
*
* param networkItem: specify from which network item want to get the information
*
* return: ssid string of the specified item on the networks scanned list
*/
char* SSID(uint8_t networkItem);
2012-03-07 00:05:54 +01:00
/*
* Return the encryption type of the networks discovered during the scanNetworks
*
* param networkItem: specify from which network item want to get the information
*
* return: encryption type (enum wl_enc_type) of the specified item on the networks scanned list
*/
uint8_t encryptionType(uint8_t networkItem);
2012-03-07 00:05:54 +01:00
/*
* Return the RSSI of the networks discovered during the scanNetworks
*
* param networkItem: specify from which network item want to get the information
*
* return: signed value of RSSI of the specified item on the networks scanned list
*/
int32_t RSSI(uint8_t networkItem);
2011-02-28 13:49:08 +01:00
2012-03-07 00:05:54 +01:00
/*
* Return Connection status.
*
* return: one of the value defined in wl_status_t
*/
2011-04-05 23:24:17 +02:00
uint8_t status();
friend class WiFiClient;
friend class WiFiServer;
2011-02-28 13:49:08 +01:00
};
extern WiFiClass WiFi;
#endif