fhunleth

fhunleth

Co-author of Nerves

VintageNet - A new network configuration library for Nerves

VintageNet is new network configuration library built specifically for Nerves Project devices. It addresses shortcomings with NervesNetwork that made that library difficult to maintain and extend.

We’ve been working on VintageNet for a while and we’re finally ready for more people to try it out.

Currently, the library supports:

  1. Configuration for wired Ethernet, WiFi, and direct connections (to support USB gadget mode networking)
  2. WiFi AP mode use
  3. Network status and events via a simple get/subscribe interface
  4. Saving and restoring network configurations across reboots (you can turn this off if your application wants to take care of this)
  5. Connection monitoring and automatic switching between working interfaces. For example, you could set it up to prefer WiFi/Ethernet for internet access, but fail over to a metered connection should they not work.

If you would like to learn more about VintageNet, take a look at the following posts:

VintageNet is currently in production use. It is not yet in the Nerves documentation, examples, and new project generator. We will be working on making it easier to use in your projects over the coming months.

There are some caveats:

  1. VintageNet is not compatible with the nerves_init_gadget project. See nerves_pack for something similar.
  2. VintageNet requires minor Linux kernel and Busybox updates. We’ve updated the official Nerves systems, but if you’ve made a custom system, please see these notes. The error messages if you’re missing the updates are not easy to understand.
  3. Networking is harder than it looks especially when you need it to work unattended. If something seems weird or wrong, let us know. It could be in an area we haven’t verified (for example, WPA-EAP has a LOT of options and we’ve only deployed to two types of WPA-EAP setups so far).
  4. While not specifically VintageNet, if you’re using mDNS for discovery and it doesn’t work on WiFi, please check if your admin disabled multicast.

I’ve been wanting to update NervesNetwork for years, but it took SmartRent having a business need to make it happen. Thanks also to Connor Rigby, Matt Ludwigs, Jon Carstens and Justin Schneck, and also thanks to Le Tote and FarmBot who both put VintageNet into production early on and provided useful feedback.

Stay tuned for updates and let us know if you want to collaborate on supporting new types of networks or features.

Most Liked

fhunleth

fhunleth

Co-author of Nerves

We’ve made quite a bit of progress since the previous VintageNet. The current release is 0.7.7. While it’s currently pre-1.0, it is being used in production and API changes are expected to be small in the future. With the Nerves 1.6 release, it became the default network configuration library for new projects.

Since the previous announcement, the following are new:

  1. Cellular modem support via vintage_net_mobile - Several modems are supported out-of-the-box including ones supporting LTE CAT M1 and NB1 service. That’s the “IoT” form of LTE (basically slower and less expensive than the data service that you get on your phone).
  2. Enterprise WiFi support (WPA-EAP PEAP) in vintage_net_wifi and vintage_net_wizard
  3. WiFi captive portal creation - This is the network side. You’ll need to supply the webserver. The vintage_net_wizard is an example.
  4. Bug fixes and reliability improvements throughout

While the project README.md’s have the primary documentation, if you’re looking for copy-and-paste configuration examples, check out the cookbook.md.

fhunleth

fhunleth

Co-author of Nerves

My experience has been that the USB-based modems that support QMI tend to all basically work. The BG96 is a CAT-M1 modem so you might run into issues with service providers. The CAT-1 and better modules (EC21, EC25, etc) all should be low effort. I say “should” since error messages aren’t great for things like inactivated SIM cards or APN typos that will prevent the modem from connecting.

fhunleth

fhunleth

Co-author of Nerves

None of the SIMCom chipsets are currently supported. That doesn’t mean that you can’t use them, but they would require some work. It’s really hard to tell the level of effort until you plug a modem in since it could “just work” or require getting into Linux kernel drivers and usb_modeswitch. If you post a GitHub issue/PR to vintage_net_mobile, I can try to help.

At the moment, Quectel BG96 and EC25 modems are the best supported.

Where Next?

Popular in Announcing Top

seancribbs
Today I released a new dialyzer Mix task as the dialyzex package! At the time we started writing this task, the existing dialyzer integra...
New
dbern
I’m excited to announce that TaxJar has developed and open-sourced DateTimeParser. We developed it because we found a need to parse user ...
New
pkrawat1
Presenting Aviacommerce, open source e-commerce platform in Elixir Aviacommerce is an open source e-commerce platform in Elixir. We at...
New
devonestes
Introducing assertions, the library that helps you write really great test assertions! GitHub: GitHub - devonestes/assertions: Helpful a...
New
deadtrickster
I’ve just released stable versions of my Prometheus Elixir libs: Elixir client [docs]; Ecto collector [docs]; Plugs instrumenter/Export...
New
bryanjos
Hi, I just published version 0.23.0 of Elixirscript. https://github.com/bryanjos/elixirscript/blob/master/CHANGELOG.md Most of the chan...
New
cjen07
parameterized pipe in elixir: |n> edit: negative index in |n> and mixed usage with |> are supported example: use ParamPipe ...
New
kip
ex_cldr provides localisation and internationalisation support based upon the data from the Unicode CLDR project. Unicode released CLDR ...
407 12840 120
New
hpopp
After just over two years in development, this latest version of Pigeon is what I finally consider done in regards to my original vision ...
New
wfgilman
I’ve cleaned up and open sourced three financial libraries I was using for my company. They are bindings for the APIs of these three comp...
New

Other popular topics Top

sorentwo
Hello! tl;dr Announcing Oban, an Ecto based job processing library with a focus on reliability and historical observability. After spen...
985 42920 311
New
skosch
To my knowledge, put_in, Map.update etc. all have the one limitation of not automatically creating intermediate keys when needed (for exa...
New
albydarned
Hello all! I am typing this post from my new MacBook Pro with the M1 chip. I’m loving it so far, and will probably use it as my daily dr...
New
chrismccord
Phoenix 1.4.0 released Phoenix 1.4 is out! This release ships with exciting new features, most notably with HTTP2 support, improved deve...
688 30877 112
New
jononomo
I am trying to figure out how Mix knows whether the environment is test, dev, or prod – where is this set? Thanks.
New
minhajuddin
I have seen a lot of code which picks the first element from a list using Enum.at(0) instead of List.first. Is there a reason why people ...
New
AngeloChecked
What learn first? Rust or Elixir Hi Elixir community! I’m here because i want learn a new language. I’m a junior developer and mainly i ...
New
rms.mrcs
Hi, I need to transform a list of numbers into a map where the keys are the indexes and the values are the original values of the list. ...
New
axelson
This post is a wiki (feel free to hit the edit button near the bottom right of this post to add your own changes!) This post collects co...
239 47930 226
New
vonH
In asking this question I am more interested about the expressiveness of the language itself and less concerned about the availability of...
New

We're in Beta

About us Mission Statement