Skip to content

Commit

Permalink
Merge pull request #611 from FarmBot/staging
Browse files Browse the repository at this point in the history
Ignore broken ssids
  • Loading branch information
ConnorRigby authored Aug 9, 2018
2 parents b894a77 + 5cf9401 commit d1c811c
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 20 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ The "brains" of the FarmBot Project
# :floppy_disk: LATEST OS IMAGE DOWNLOADS
<!-- DON'T CHANGE THE TEXT ABOVE. It is used in documentation links. -->

:star: **[RPi 3 (Ships with FarmBot.io kits)](https://github.com/FarmBot/farmbot_os/releases/download/v6.4.5/farmbot-rpi3-6.4.5.img)**
:star: **[RPi 3 (Ships with FarmBot.io kits)](https://github.com/FarmBot/farmbot_os/releases/download/v6.4.7/farmbot-rpi3-6.4.7.img)**
---

## Installation
Expand Down
47 changes: 28 additions & 19 deletions platform/target/network/network.ex
Original file line number Diff line number Diff line change
Expand Up @@ -49,25 +49,7 @@ defmodule Farmbot.Target.Network do
|> String.split("\n")
|> tl()
|> Enum.map(&String.split(&1, "\t"))
|> Enum.map(fn(res) ->
case res do
[bssid, freq, signal, flags, ssid] ->
%{bssid: bssid,
frequency: String.to_integer(freq),
flags: flags,
level: String.to_integer(signal),
ssid: ssid
}

[bssid, freq, signal, flags] ->
%{bssid: bssid,
frequency: String.to_integer(freq),
flags: flags,
level: String.to_integer(signal),
ssid: nil
}
end
end)
|> reduce_decode()
|> case do
[] ->
Process.sleep(500)
Expand All @@ -76,6 +58,33 @@ defmodule Farmbot.Target.Network do
end
end

defp reduce_decode(results, acc \\ [])
defp reduce_decode([], acc), do: Enum.reverse(acc)
defp reduce_decode([ [bssid, freq, signal, flags, ssid] | rest], acc) do
decoded = %{
bssid: bssid,
frequency: String.to_integer(freq),
flags: flags,
level: String.to_integer(signal),
ssid: ssid
}
reduce_decode(rest, [decoded | acc])
end

defp reduce_decode([ [bssid, freq, signal, flags] | rest], acc) do
decoded = %{bssid: bssid,
frequency: String.to_integer(freq),
flags: flags,
level: String.to_integer(signal),
ssid: nil
}
reduce_decode(rest, [decoded | acc])
end

defp reduce_decode([_ | rest], acc) do
reduce_decode(rest, acc)
end

def do_scan(iface) do
pid = :"Nerves.WpaSupplicant.#{iface}"
Nerves.WpaSupplicant.request(pid, :SCAN)
Expand Down

0 comments on commit d1c811c

Please sign in to comment.