wifi.h 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. #ifndef KBF_WIFI_H
  2. #define KBF_WIFI_H
  3. #include <string>
  4. #include <vector>
  5. #include "net.h"
  6. namespace kbf::wifi {
  7. void stop();
  8. enum class Mode {
  9. OFF,
  10. STA,
  11. AP,
  12. DUAL
  13. };
  14. Mode mode();
  15. class STA;
  16. namespace ap {
  17. void start(
  18. std::string ssid,
  19. std::string password,
  20. net::IP ip = net::IP("192.168.4.1"),
  21. net::IP netmask = net::IP("255.255.255.0")
  22. );
  23. void stop();
  24. [[nodiscard]] const std::string &ssid();
  25. [[nodiscard]] const std::string &password();
  26. extern void (*onConnect)(STA &);
  27. extern void (*onDisconnect)(STA &);
  28. }
  29. struct APInfo {
  30. std::string ssid;
  31. uint8_t rssi;
  32. };
  33. namespace sta {
  34. void start();
  35. void stop();
  36. bool connect(std::string ssid, std::string password, bool async = false, int maxRetry = 3);
  37. void disconnect();
  38. [[nodiscard]] bool connected();
  39. [[nodiscard]] const std::string &ssid();
  40. [[nodiscard]] const std::string &password();
  41. [[nodiscard]] const net::IP &ip();
  42. extern void (*onConnect)();
  43. extern void (*onIp)();
  44. extern void (*onDisconnect)();
  45. void startScan(void *data);
  46. extern void (*onScanDone)(std::vector<APInfo> &apList, void *data);
  47. }
  48. namespace dual {
  49. void start(
  50. std::string ssid,
  51. std::string password,
  52. net::IP ip = net::IP("192.168.4.1"),
  53. net::IP netmask = net::IP("255.255.255.0")
  54. );
  55. }
  56. }
  57. #endif //KBF_WIFI_H