Friday, January 3, 2025

Backup and restore VLC playlists on Android

I had to look all over the internet to cobble together the following information about how VLC stores playlists on Android and how to extract a copy of that information.

VLC stores playlists in a SQLite database (including any .m3u files that you copy to your device). Any edits  that you make on Android are to the database, not to the original .m3u file (which remains unchanged). That database is stored in a folder that only the VLC application can access (unless you "root" your phone).

So, when you replace your phone, you need to move your playlists to your new device. Unfortunately, it's not as simple as it should be.

Through an "advanced" tool inside VLC you can copy your current media database, vlc_media.db, to a place that you can access, the root of your internal memory. Then you can use SQLite to read that database and extract the playlists. Then you can save that data into new .m3u files and upload those to your new phone (along with copying all the data or moving your SD card to the new device).

Here are the details of each step:

1. Backing Up vlc_media.db

Backup playlists and everything else in the file vlc_media.db
  • Launch VLC on your Android device
  • Go to … More
  • Tap on Settings
  • Scroll to Extra settings and tap on Advanced
  • Tap on Dump media database
This will create a backup of the vlc_media.db file in the root of your internal storage. 

2. Transfer the database

  • Connect your Android device to your PC via a USB cable
    • Select "USB for File Transfer" if asked on your Android device
  • Browse to your Android device using Windows file explorer (it will appear on the left as one of the devices)
  • Look in the root of the "phone" (not the "card") device under your phone in explorer
  • Copy the vld_media.db file to your windows download folder

3. Download SQLite

Now you need a copy of the free SQLite database tool. Visit the SQLite download page and grab the "command-line tools" bundle. It should be a zip file named something like sqlite-tools-win-x64-nnnnnnn.zip where the nnnnnnn is a number representing the version.

You'll need to unzip this in your download directory. You actually only need to extract one file out of the zip, sqlite3.exe.

4. Export the playlist data

Now you can do the following in a windows command prompt.

> cd %userprofile%\Downloads

> sqlite3 vlc_media.db
SQLite version 3.47.2 2024-12-07 20:39:59
Enter ".help" for usage hints.
sqlite> .once playlist-raw.txt
sqlite> select pl.name, path||filename from playlist pl inner join playlistmediarelation plr on playlist_id=id_playlist inner join media on id_media=media_id join folder on folder_id=id_folder order by id_playlist, position;


This will generate a list of all the playlists stored in the database and all the paths and filenames of the songs in each playlist. The output will be written to a file named playlist-raw.txt in the current directory.

The format of the output is the playlist_name|path/song.mp3. You will then need to copy each group of songs into a separate playlist (see 4.5 below for a way to export them to individual playlist files).

The playlist-raw.txt file might look something like this:
Handel playlist|Music/CC0Music/handel/handel-largo-in-g-from-the-opera-xerxes-remix-111004.mp3
Bach playlist|Music/CC0Music/Bach/chamber-music-bach-flute-sonata-8-4-114161.mp3
Bach playlist|Music/CC0Music/Bach/chamber-music-bach-viola-da-gamba-sonata-no1-in-g-major-1-114166.mp3
Bach playlist|Music/CC0Music/Bach/johan-sebastian-bach-sonata-largo-e-dolce-remix-111997.mp3
Music of Beethoven|Music/CC0Music/beethoven-symphony-3-eroica-funeral-march-2nd-mov-remix-7401.mp3
Music of Beethoven|Music/CC0Music/chamber-music-beethoven-clarinet-trio-ef-major-op38-1-114126.mp3
Music of Beethoven|Music/CC0Music/ludwig-van-beethoven-moonlight-sonata-classical-remix-8097.mp3

This represents 3 different playlists named: Handel playlist, Bach playlist, and Music of Beethoven. The Handel playlist only has one song. The Bach and Beethoven playlists each have 3 songs.

Handel's music is in the folder Music/CC0Music/handel/
Bach's is in Music/CC0Music/Bach
And Beethoven's music is in the Music/CC0Music folder.

4.5 Export the playlist to multiple files

If you want a single line script that will generate a separate .m3u file for each playlist you can use the following in the windows command prompt.

for /F "usebackq delims=| tokens=1,*" %i in (`sqlite3 -noheader vlc_media.db "select id_playlist,replace(name,'''','_') as newname from playlist order by id_playlist"`) do sqlite3 vlc_media.db ".once '%i-%j.m3u'" "select path||filename from playlistmediarelation plr inner join media on id_media=media_id join folder on folder_id=id_folder where playlist_id=%i order by position;"

This will create an .m3u file in the current directory for each playlist in the database. The file names will be the internal playlist id (a number) followed by a dash followed by the playlist name from the database. It's done this way because it's possible to have multiple playlists with the same name in the database (e.g. "playlist.m3u"). Note that playlists that already have a .m3u on the end will have this repeated in the created filename (e.g. "31-playlist.m3u.m3u").

5. Create new .m3u files

The paths you store in the .m3u file are relative to the directory where the .m3u is stored. If you created a file named "Music of Bach.m3u" and put it in the Music/CC0Music/Bach folder with the following content it would show up as a playlist in VLC named "Music of Bach.m3u":

chamber-music-bach-flute-sonata-8-4-114161.mp3
chamber-music-bach-viola-da-gamba-sonata-no1-in-g-major-1-114166.mp3
johan-sebastian-bach-sonata-largo-e-dolce-remix-111997.mp3
      If you wanted to store the same playlist in the Music folder you would need to include the CC0Music/Bach path on the front of each line like this:

      CC0Music/Bach/chamber-music-bach-flute-sonata-8-4-114161.mp3
      CC0Music/Bach/chamber-music-bach-viola-da-gamba-sonata-no1-in-g-major-1-114166.mp3
      CC0Music/Bach/johan-sebastian-bach-sonata-largo-e-dolce-remix-111997.mp3

      Note that FORWARD SLASHES ('/') are required. NOT!!! backslashes as path separators.

      6. Check your work

      Look at each of the generated .m3u files and make sure there aren't any odd path's in the list. If you had a file that was on a different device it might show up with a file:///storage/emulated/... prefix. Make sure you either store the song in that directory or that you edit the path if you moved the song on your new phone.

      7. Upload and test

      Once you store these .m3u files on the new Android device, rescan your media in VLC and it should find them. Dragging down on the VLC playlist view will refresh the view as will clicking on the hamburger menu (top right) and selecting "refresh".

      Hopefully this helps someone down the road figure out how to export the database and turn it into .m3u files that you can import on another device.

      Resources

      Here are some of the resources I used to compile this info:

      Thursday, November 7, 2024

      Arduino DIY booth at UVARC

      Main Arduino site

      https://arduino.cc

      Go here to download the IDE for your preferred OS (Windows, Linux, Mac). You can also buy boards and "shields" here but they are likely cheaper on Amazon. Arduino is an open hardware and open software project so "clone" boards are available as well as the original Arduino boards.

      The Arduino UNO R3 is an excellent choice for prototyping and learning about coding. I strongly encourage you to start here if you are new to embedded programming, Arduino, etc. The boards are inexpensive (under $10 for "clone" board via Amazon).

      The UNO is based on the Atmel ATmega328P processor. It has 14 digital input/output pins (of which 6 can be used as PWM outputs), 6 analog inputs, and runs at 16MHz and 5 volts.


      The UNO board (clone) I was using at the DIY night is (currently, as of Nov 2024) available for $9 via Amazon (affiliate link).






      After you get your project working with the UNO board and a breadboard, it's time to convert it to a permanent project. For this, I'd encourage you to look at some of the smaller Arduino boards:


      The Pro Mini (ignore what the page says, these are still commonly available and in use) is a great board for small projects. It has the same capabilities as the UNO (14 digital input/output pins 6 of which can be used as PWM outputs, 6 analog inputs, 16MHz at 5V) but lacks a USB port. You'll have to buy an adapter to go from USB to the TX/RX pins on the board. It's easy to do and the adapters are commonly available (affiliate link) for a few dollars. Search for "usb to ttl serial" to find them

      Pro Mini's are available for < $5 each on Amazon at 3 for $14, 5 for $18,  (affiliate links) and even cheaper as the quantity goes up.



      Another option is the Pro Micro which has a USB port built in thanks to the 32U4 chip (vs the 328P on the UNO and Pro Mini).

      These boards are basically the same in terms of capabilities: 9 channels of 10-bit ADC, 5 PWM pins, 12 DIOs as well as hardware serial connections Rx and Tx. Running at 16MHz and 5V.

      They are available with USB micro or USB C on Amazon (affiliate links) for slightly more than the Pro Mini. Roughly $19 for 3.




      There are literally dozens of other Arduino boards available, each with their own characteristics and capabilities. Everything from the Nano to the Mega (many more than are shown below). Some with BLE others with WiFi, etc.


      Books about Arduino & Ham Radio

      There are numerous books about using Arduino with ham radio. Here are a couple from ARRL:


      Best of Arduino Projects for Ham Radio by Arduino expert Glen Popiel, KW5GP, includes 17 Arduino projects to build your programming and microcontroller skills. It’s a collection of the best projects presented in Arduino for Ham RadioMore Arduino Projects for Ham Radio, and More Arduino for Ham Radio.




      More Arduino for Ham Radio
       introduces many of the new Arduino boards and add-on modules, followed by an overview of the software, tools, and techniques needed to bring projects to life. 10 practical projects showcase a variety of applications and include detailed descriptions of how the software “sketches” work.




      Other books are available from Amazon (affiliate links):

      Arduino Projects for Amateur Radio 

      Do you want to increase the functionality and value of your ham radio without spending a lot of money? This book will show you how! Arduino Projects for Amateur Radio is filled with step-by-step microcontroller projects you can accomplish on your own--no programming experience necessary.
      This practical guide provides detailed instructions, helpful diagrams, lists of low-cost parts and suppliers, and hardware and software tips that make building your own equipment even more enjoyable. Downloadable code for all of the projects in the book is also available.


      Ham Radio for Arduino and PICAXE

      introduces you to the fun and rewards of experimenting with microcontrollers. Editor Leigh L. Klotz Jr, WA5ZNU, and many other contributors have designed projects that will enhance your ham radio station and operating capabilities. Or, take it to the next step, using these projects as a launch pad for creating your own projects.


      Sites about Arduino & Ham Radio

      DX Zone has a page of over 100 Amateur Radio Arduino Projects (power meters, SDR, antenna analyzer, QRP transceiver, beacons, repeater controller, automatic antenna tuner, antenna rotator controller, etc.) as well as a sub page with dozens of Arduino Morse Code Projects.

      The Instructables site has numerous projects for ham radio many of which use an Arduino.

      The r/amateurradio subreddit has numerous projects and discussions about Arduino and ham radio.

      Searching the Arduino forums returns dozens or discussions about Arduino and ham radio.

      YouTube always has a little something for any subject.

      And, of course, a google search will return a seemingly unending list of Arduino and ham radio pages.

      Multi-function Shield

      If you are interested in the multi-function shield that I was demoing at the DIY night, they are available from Amazon (affiliate link) for $8.


      Documentation and sample programs are available here:

      https://www.mpja.com/download/hackatronics-arduino-multi-function-shield.pdf


      Starter Kits


      If you want an all-in-one starter kit for yourself or perhaps a child or grandchild there are plenty available from Amazon (affiliate link).

      The one shown at left (affiliate link) is one I've purchased before. There are numerous others shown at the link above.

      In my experience ELEGOO is a good company with quality products.







      If you like the idea of a bunch of sensors and other modules, you can buy a collection of them from Amazon (affiliate link).









      Thursday, February 2, 2023

      Node-RED resources

      Node-RED resources

      Node-RED is a tool for easily connecting devices, APIs, and online services to automate tasks, create dashboards, and control your environment.


      Background

      A little background will help you understand the concepts being used in Node-RED and automation in general.

      Node-RED

      Node-RED is a drag-and-drop based programming tool, originally developed as a side project in 2013 by Nick O’Leary and Dave Conway-Jones of IBM’s Emerging Technology Services group and it is now a part of the OpenJS Foundation.

      You create Node-RED programs by dragging different "nodes" from a palette of available functions and then connect these nodes together. Each node has a well defined purpose; it does something with it's input and passes the result onto the next node(s) in the program.

      Node-RED started out as a tool for visualizing and manipulating mapping between MQTT topics. It has grown far beyond that in the decade or so since it was invented. You can read more about Node-RED if you are interested.

      MQTT

      MQTT (Message Queuing Telemetry Transport) was created by Dr. Andy Stanford-Clark and Arlen Nipper in 1999. The original purpose for MQTT was to allow remote monitoring devices used in the oil and gas industry to send their data to servers over expensive satellite connections.

      MQTT is a lightweight machine-to-machine (M2M) messaging protocol for clients that are resource constrained (need a small code and data footprint) and are connected to unreliable networks or networks with limited or expensive bandwidth resources.


      MQTT use a pub-sub (publish / subscribe) architecture. There are two basic components, clients and brokers. Clients connect to brokers and can publish data, subscribe to topics, or both.

      MQTT messages contain a topic and a payload. Both the topic and payload are application defined.

      The topic describes what the data is in a hierarchical format, like the directory structure on a computer.  The '/' character is used to separate each level. Some examples might be home/livingroom/temperaturegarage/temperature, or cabin/bedroom/humidity.

      The payload is the data. Since the payload is application defined it could be an image from a camera, a sensor value (temperature, humidity, brightness level, on, off, etc.), a command ('on', 'off', 'dim', 'bright', etc.), or a collection of information (name: 'Jenny', phone: '888-867-5309', email: 'jenny@example.com'), audio data, and so on. Anything that can be digitized can be sent as a payload in MQTT.

      This ~5 minute video will give you a brief intro to MQTT if you want to know more.





      MQTT Broker (Mosquitto)

      Mosquitto is an open source MQTT broker. Versions are available for a variety of platforms (windows, mac, linux, raspberry pi, etc.). They also host a test instance of their broker that you can use to test clients or just to get familiar with MQTT. They also have clients available for different platforms so you can subscribe to topics or publish messages.


      RTL-SDR Software defined radios

      More and more utilities are moving to "smart meters" that allow reading information without having to physically access the meter. Orem city just moved to smart water meters last year. And Rocky Mountain Power has been using smart power meters for several years.

      The rtl-sdr.com site has a number of tools for reading and decoding data from smart meters, tire pressure sensors in cars, weather sensors and a host of other RF devices. It's a simple matter to start reading and recording your power or water usage.

      Water readings

      Orem's water meters are easy to read via the rtlamr tool using the SCM+ protocol. You just need to open your meter box and look for the number printed in very large text on the side of your device. Put that number into the following command in place of xxxxx and you'll start seeing data within a minute or two.

      rtlamr -format json -msgtype scm+ -filterid xxxxx -agcmode true 

      The meter transmits data once a minute. Depending on the location of your antenna you may get all the messages or only a few of them. Note that even though it sends a message once a minute, the actual meter reading is only updated hourly (unfortunately). Also, the meter reading appears to be in 10ths of a gallon. In other words a value of 10 represents one gallon, not ten gallons.

      Power readings

      Reading your power meter should work very similarly using the rtlamr tool. I have a net meter so I don't have any direct experience here unfortunately (see caveat below). At the top of the power meter, above the display, is a sticker with some FCC info on it and a big long number. That's the device ID you need to filter on.

      I tried reading a meter on a local utility pedestal. I can see the meter and get readings from it in rtlamr, but the readings don't seem to change. Over a three day period, the "consumption" value remained constant even though the actual display on the meter changed.

      One caveat - Rocky Mountain Power seems to have moved their customers with rooftop solar to the new Itron Gen5 Riva meters. These seem to be configured in 2.4GHz mesh mode so you can no longer read the data with the usual rtlamr 900MHz tools. This seems to only apply to net metering solar customers, not non-solar customers.


      Resources


      Basics

      The main Node-RED site: https://nodered.org
      Node-RED Flows
      Node-RED for amateur radio group: nodered-hamradio groups.io
      Mosquitto MQTT broker: https://mosquitto.org/download/


      RTL-SDR - Software defined radio

      RTL-SDR software defined radio news and projects https://www.rtl-sdr.com/
      Quick guide to setup a RTL SDR Server on a Raspberry Pi. https://github.com/c4software/raspberry-rtlsdr-server


      International space station

      🛰 International Space Station announcement when it is about to be overhead (and visible!)


      Additional information


      Flows

      You can copy and "import" these to your node-RED instance. Hit the hamburger menu on the top right, then select "import" from the menu. Copy and paste the text below (without the title) into the box & hit import.


      Air quality flow

      [{"id":"7d0550b4d1c16c24","type":"inject","z":"28053dfef12b07e3","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"600","crontab":"","once":true,"onceDelay":0.1,"topic":"","payload":"","payloadType":"date","x":130,"y":100,"wires":[["b64ff284222e38f2"]]},{"id":"b64ff284222e38f2","type":"http request","z":"28053dfef12b07e3","name":"AQI Lindon","method":"GET","ret":"txt","paytoqs":"ignore","url":"https://air.utah.gov/csvFeed.php?id=ln","tls":"","persist":false,"proxy":"","insecureHTTPParser":false,"authType":"","senderr":false,"headers":[],"x":310,"y":100,"wires":[["d79841da3c713e8b"]]},{"id":"0cb95d9d5e681a42","type":"debug","z":"28053dfef12b07e3","name":"AQI debug","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"true","targetType":"full","statusVal":"","statusType":"auto","x":470,"y":40,"wires":[]},{"id":"d79841da3c713e8b","type":"csv","z":"28053dfef12b07e3","name":"Parse CSV","sep":"\\t","hdrin":true,"hdrout":"none","multi":"mult","ret":"\\n","temp":"","skip":"0","strings":true,"include_empty_strings":"","include_null_values":"","x":490,"y":100,"wires":[["91791c876ea24429"]]},{"id":"91791c876ea24429","type":"change","z":"28053dfef12b07e3","name":"Latest","rules":[{"t":"set","p":"payload","pt":"msg","to":"payload[0]","tot":"msg"}],"action":"","property":"","from":"","to":"","reg":false,"x":130,"y":180,"wires":[["e75db06bac7d35b1","0cb95d9d5e681a42"]]},{"id":"e75db06bac7d35b1","type":"split","z":"28053dfef12b07e3","name":"Split object","splt":"\\n","spltType":"str","arraySplt":1,"arraySpltType":"len","stream":false,"addname":"topic","x":290,"y":180,"wires":[["acdc02d4916b47b1"]]},{"id":"428713f7463a26d0","type":"comment","z":"28053dfef12b07e3","name":"AQI information","info":"Data from https://air.utah.gov/airapi.html\n\n\nAccording to https://air.utah.gov/ the\nfollowing ranges are applicable\n\n| AQI    | PM 2.5     | Ozone       |\n Good      0-12         0-0.054\n Moderate  12.1-35.4    0.055-0.070\n Sensitive 35.5-55.4    0.071-0.085\n Unhealthy 55.5-150.4   0.086-0.105\n Very bad  150.5-250.4  0.106-0.200\n Hazardous 250.5+       0.201+\n \n PM2.5 is in ug/m3 and based on a 24 hour average\n Ozone is in ppm and based on an 8 hour average\n\n NO2 levels from EPA\n https://www.airnow.gov/sites/default/files/2018-06/no2.pdf\n\nPPB (state reports PPM)\nGood 0-50\nModerate 51-100\nSensitive 101-150\nUnhealth 151-200\nVery bad 201-300\n","x":140,"y":40,"wires":[]},{"id":"acdc02d4916b47b1","type":"switch","z":"28053dfef12b07e3","name":"Route messages","property":"topic","propertyType":"msg","rules":[{"t":"eq","v":"dtstamp","vt":"str"},{"t":"eq","v":"ozone","vt":"str"},{"t":"eq","v":"ozone_8hr_avg","vt":"str"},{"t":"eq","v":"pm25","vt":"str"},{"t":"eq","v":"pm25_24hr_avg","vt":"str"},{"t":"eq","v":"no2","vt":"str"},{"t":"eq","v":"co","vt":"str"},{"t":"eq","v":"temp","vt":"str"},{"t":"eq","v":"rh","vt":"str"},{"t":"eq","v":"ws","vt":"str"},{"t":"eq","v":"wd","vt":"str"},{"t":"eq","v":"sr","vt":"str"}],"checkall":"true","repair":false,"outputs":12,"x":170,"y":360,"wires":[["13a54c24be136349"],["c04efbac895729f3","2dfac0064328f31a"],["2dfac0064328f31a"],["d6162e12d5bf363b","73bb8cc649668118"],["73bb8cc649668118"],["fddc52cea250d9b6","d5b05f209645a903"],["90e52970c8438acc","1351cc1cf525fa04"],["9817090a6398563a","77f2c5f9b0041a8b"],["cfbd698e4fc69cbf","5784aae85b3353f1"],["9d44a12ce2fb9447"],["e93c3b9d67b7542f"],["1ebb09c7ebb423fd","3f1c7077656ad8b9"]],"inputLabels":["AQI messages"],"outputLabels":["dtstamp","ozone","ozone_8hr_avg","pm25","pm25_24hr_avg","no2","co","temp","rh","ws","wd","sr"]},{"id":"13a54c24be136349","type":"ui_text","z":"28053dfef12b07e3","group":"f178535d7c428ccf","order":1,"width":0,"height":0,"name":"time","label":"Time","format":"{{msg.payload}}","layout":"row-left","className":"","x":570,"y":200,"wires":[]},{"id":"c04efbac895729f3","type":"ui_gauge","z":"28053dfef12b07e3","name":"Ozone","group":"f178535d7c428ccf","order":2,"width":"3","height":"3","gtype":"gage","title":"Ozone","label":"PPM","format":"{{value}}","min":0,"max":"0.2","colors":["#00b500","#e6e600","#ca3838"],"seg1":"0.055","seg2":"0.086","diff":false,"className":"","x":570,"y":240,"wires":[]},{"id":"2dfac0064328f31a","type":"ui_chart","z":"28053dfef12b07e3","name":"Ozone","group":"f178535d7c428ccf","order":3,"width":"3","height":"3","label":"Ozone","chartType":"line","legend":"false","xformat":"HH:mm","interpolate":"linear","nodata":"","dot":false,"ymin":"","ymax":"","removeOlder":"12","removeOlderPoints":"","removeOlderUnit":"3600","cutout":0,"useOneColor":false,"useUTC":false,"colors":["#1f77b4","#aec7e8","#ff7f0e","#2ca02c","#98df8a","#d62728","#ff9896","#9467bd","#c5b0d5"],"outputs":1,"useDifferentColor":false,"className":"","x":690,"y":260,"wires":[[]]},{"id":"d6162e12d5bf363b","type":"ui_gauge","z":"28053dfef12b07e3","name":"PM2.5","group":"f178535d7c428ccf","order":4,"width":"3","height":"3","gtype":"gage","title":"PM2.5","label":"ug/m3","format":"{{value}}","min":0,"max":"250","colors":["#00b500","#e6e600","#ca3838"],"seg1":"12","seg2":"55.5","diff":false,"className":"","x":570,"y":280,"wires":[]},{"id":"73bb8cc649668118","type":"ui_chart","z":"28053dfef12b07e3","name":"PM2.5","group":"f178535d7c428ccf","order":5,"width":"3","height":"3","label":"PM2.5","chartType":"line","legend":"false","xformat":"HH:mm","interpolate":"linear","nodata":"","dot":false,"ymin":"","ymax":"","removeOlder":"12","removeOlderPoints":"","removeOlderUnit":"3600","cutout":0,"useOneColor":false,"useUTC":false,"colors":["#1f77b4","#aec7e8","#ff7f0e","#2ca02c","#98df8a","#d62728","#ff9896","#9467bd","#c5b0d5"],"outputs":1,"useDifferentColor":false,"className":"","x":690,"y":300,"wires":[[]]},{"id":"fddc52cea250d9b6","type":"ui_gauge","z":"28053dfef12b07e3","name":"NO2","group":"f178535d7c428ccf","order":6,"width":"3","height":"3","gtype":"gage","title":"NO2","label":"PPM","format":"{{value}}","min":0,"max":"0.3","colors":["#00b500","#e6e600","#ca3838"],"seg1":"0.051","seg2":"0.151","diff":false,"className":"","x":570,"y":320,"wires":[]},{"id":"d5b05f209645a903","type":"ui_chart","z":"28053dfef12b07e3","name":"NO2","group":"f178535d7c428ccf","order":7,"width":"3","height":"3","label":"NO2","chartType":"line","legend":"false","xformat":"HH:mm","interpolate":"linear","nodata":"","dot":false,"ymin":"","ymax":"","removeOlder":"12","removeOlderPoints":"","removeOlderUnit":"3600","cutout":0,"useOneColor":false,"useUTC":false,"colors":["#1f77b4","#aec7e8","#ff7f0e","#2ca02c","#98df8a","#d62728","#ff9896","#9467bd","#c5b0d5"],"outputs":1,"useDifferentColor":false,"className":"","x":690,"y":340,"wires":[[]]},{"id":"9817090a6398563a","type":"ui_gauge","z":"28053dfef12b07e3","name":"Temp","group":"2d8b6f8f77619143","order":1,"width":"3","height":"3","gtype":"gage","title":"Temp","label":"F","format":"{{value}}","min":"-10","max":"110","colors":["#00ffee","#00eb1b","#ca3838"],"seg1":"60","seg2":"90","diff":false,"className":"","x":570,"y":440,"wires":[]},{"id":"77f2c5f9b0041a8b","type":"ui_chart","z":"28053dfef12b07e3","name":"Temp","group":"2d8b6f8f77619143","order":2,"width":"3","height":"3","label":"Temp","chartType":"line","legend":"false","xformat":"HH:mm","interpolate":"linear","nodata":"","dot":false,"ymin":"","ymax":"","removeOlder":"12","removeOlderPoints":"","removeOlderUnit":"3600","cutout":0,"useOneColor":false,"useUTC":false,"colors":["#1f77b4","#aec7e8","#ff7f0e","#2ca02c","#98df8a","#d62728","#ff9896","#9467bd","#c5b0d5"],"outputs":1,"useDifferentColor":false,"className":"","x":690,"y":460,"wires":[[]]},{"id":"cfbd698e4fc69cbf","type":"ui_gauge","z":"28053dfef12b07e3","name":"Humid","group":"2d8b6f8f77619143","order":3,"width":"3","height":"3","gtype":"gage","title":"Humid","label":"%rh","format":"{{value}}","min":"0","max":"100","colors":["#00ff2a","#fbff00","#ca3838"],"seg1":"30","seg2":"50","diff":false,"className":"","x":570,"y":480,"wires":[]},{"id":"5784aae85b3353f1","type":"ui_chart","z":"28053dfef12b07e3","name":"Humid","group":"2d8b6f8f77619143","order":4,"width":"3","height":"3","label":"Humid","chartType":"line","legend":"false","xformat":"HH:mm","interpolate":"linear","nodata":"","dot":false,"ymin":"","ymax":"","removeOlder":"12","removeOlderPoints":"","removeOlderUnit":"3600","cutout":0,"useOneColor":false,"useUTC":false,"colors":["#1f77b4","#aec7e8","#ff7f0e","#2ca02c","#98df8a","#d62728","#ff9896","#9467bd","#c5b0d5"],"outputs":1,"useDifferentColor":false,"className":"","x":690,"y":500,"wires":[[]]},{"id":"9d44a12ce2fb9447","type":"ui_gauge","z":"28053dfef12b07e3","name":"Wind","group":"2d8b6f8f77619143","order":5,"width":"3","height":"3","gtype":"gage","title":"Wind","label":"MPH","format":"{{value}}","min":"0","max":"75","colors":["#00ff2a","#fbff00","#ca3838"],"seg1":"30","seg2":"50","diff":false,"className":"","x":570,"y":520,"wires":[]},{"id":"e93c3b9d67b7542f","type":"ui_gauge","z":"28053dfef12b07e3","name":"Dir","group":"2d8b6f8f77619143","order":6,"width":"3","height":"3","gtype":"compass","title":"Dir","label":"","format":"{{value}}","min":"0","max":"75","colors":["#00ff2a","#fbff00","#ca3838"],"seg1":"30","seg2":"50","diff":false,"className":"","x":690,"y":540,"wires":[]},{"id":"90e52970c8438acc","type":"ui_gauge","z":"28053dfef12b07e3","name":"CO","group":"f178535d7c428ccf","order":8,"width":"3","height":"3","gtype":"gage","title":"CO","label":"PPM","format":"{{value}}","min":0,"max":"1","colors":["#00b500","#e6e600","#ca3838"],"seg1":"","seg2":"","diff":false,"className":"","x":570,"y":360,"wires":[]},{"id":"1351cc1cf525fa04","type":"ui_chart","z":"28053dfef12b07e3","name":"CO","group":"f178535d7c428ccf","order":9,"width":"3","height":"3","label":"CO","chartType":"line","legend":"false","xformat":"HH:mm","interpolate":"linear","nodata":"","dot":false,"ymin":"","ymax":"","removeOlder":"12","removeOlderPoints":"","removeOlderUnit":"3600","cutout":0,"useOneColor":false,"useUTC":false,"colors":["#1f77b4","#aec7e8","#ff7f0e","#2ca02c","#98df8a","#d62728","#ff9896","#9467bd","#c5b0d5"],"outputs":1,"useDifferentColor":false,"className":"","x":690,"y":380,"wires":[[]]},{"id":"1ebb09c7ebb423fd","type":"ui_gauge","z":"28053dfef12b07e3","name":"Solar","group":"2d8b6f8f77619143","order":9,"width":"3","height":"3","gtype":"gage","title":"Solar","label":"w/m2","format":"{{value}}","min":"0","max":"500","colors":["#00ff2a","#fbff00","#ca3838"],"seg1":"","seg2":"","diff":false,"className":"","x":570,"y":560,"wires":[]},{"id":"3f1c7077656ad8b9","type":"ui_chart","z":"28053dfef12b07e3","name":"Solar","group":"2d8b6f8f77619143","order":10,"width":"3","height":"3","label":"Solar","chartType":"line","legend":"false","xformat":"HH:mm","interpolate":"linear","nodata":"","dot":false,"ymin":"","ymax":"","removeOlder":"12","removeOlderPoints":"","removeOlderUnit":"3600","cutout":0,"useOneColor":false,"useUTC":false,"colors":["#1f77b4","#aec7e8","#ff7f0e","#2ca02c","#98df8a","#d62728","#ff9896","#9467bd","#c5b0d5"],"outputs":1,"useDifferentColor":false,"className":"","x":690,"y":580,"wires":[[]]},{"id":"f178535d7c428ccf","type":"ui_group","name":"Lindon","tab":"9d16aed7861d445a","order":3,"disp":true,"width":"6","collapse":true,"className":""},{"id":"2d8b6f8f77619143","type":"ui_group","name":"Weather","tab":"9d16aed7861d445a","order":2,"disp":true,"width":"6","collapse":true,"className":""},{"id":"9d16aed7861d445a","type":"ui_tab","name":"Air Quality","icon":"wi-darksky-wind","order":1,"disabled":false,"hidden":false}]


      ISS

      [{"id":"1da6e3bdacaca0f9","type":"worldmap","z":"9a8c4b547b38e156","name":"ISS map","lat":"","lon":"","zoom":"3","layer":"EsriS","cluster":"","maxage":"90","usermenu":"show","layers":"show","panit":"true","panlock":"false","zoomlock":"false","hiderightclick":"true","coords":"utm","showgrid":"true","showruler":"true","allowFileDrop":"false","path":"/iss","overlist":"RA,DN,TL","maplist":"OSMG,OSMC,EsriS","mapname":"","mapurl":"","mapopt":"","mapwms":false,"x":300,"y":280,"wires":[]},{"id":"cd15dbc58a3a4e01","type":"http request","z":"9a8c4b547b38e156","name":"Get ISS position","method":"GET","ret":"obj","paytoqs":"ignore","url":"http://api.open-notify.org/iss-now.json","tls":"","persist":false,"proxy":"","authType":"","senderr":false,"x":300,"y":120,"wires":[["01020efb56ca3c3e"]]},{"id":"3fec0a7643a12c76","type":"inject","z":"9a8c4b547b38e156","name":"Every minute","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"60","crontab":"","once":true,"onceDelay":0.1,"topic":"","payload":"","payloadType":"date","x":120,"y":120,"wires":[["cd15dbc58a3a4e01"]]},{"id":"01020efb56ca3c3e","type":"change","z":"9a8c4b547b38e156","name":"Convert to worldmap","rules":[{"t":"set","p":"payload.lat","pt":"msg","to":"payload.iss_position.latitude","tot":"msg"},{"t":"set","p":"payload.lon","pt":"msg","to":"payload.iss_position.longitude","tot":"msg"},{"t":"set","p":"payload.name","pt":"msg","to":"International Space Station","tot":"str"},{"t":"set","p":"payload.icon","pt":"msg","to":"iss","tot":"str"},{"t":"set","p":"payload.iconColor","pt":"msg","to":"red","tot":"str"},{"t":"set","p":"payload.label","pt":"msg","to":"ISS","tot":"str"},{"t":"set","p":"payload.layer","pt":"msg","to":"ISS","tot":"str"},{"t":"set","p":"payload.weblink","pt":"msg","to":"[{\"name\":\"Next pass\",\"url\":\"https://spotthestation.nasa.gov/sightings/view.cfm?country=United_States&region=Utah&city=Orem\",\"target\":\"_new\"},{\"name\":\"Mission info\",\"url\":\"https://www.nasa.gov/mission_pages/station/main/index.html\",\"target\":\"_new\"}]","tot":"json"},{"t":"delete","p":"payload.iss_position","pt":"msg"},{"t":"delete","p":"payload.message","pt":"msg"},{"t":"delete","p":"payload.timestamp","pt":"msg"}],"action":"","property":"","from":"","to":"","reg":false,"x":300,"y":200,"wires":[["5cf81bf789afe7be","1da6e3bdacaca0f9"]]},{"id":"212a437e52c23cb1","type":"comment","z":"9a8c4b547b38e156","name":"ISS info & resources","info":"Next time ISS is overhead from NASA\nhttps://spotthestation.nasa.gov/sightings/view.cfm?country=United_States&region=Utah&city=Orem\n\nTracking the ISS with Node-RED on a Raspberry Pi\nhttps://pycrocoding.medium.com/tracking-the-iss-with-node-red-on-a-raspberry-pi-4-5a23d9362caa\n\nISS announcement when it is about to be overhead (and visible!)\nhttps://community.home-assistant.io/t/international-space-station-announcement-when-it-is-about-to-be-overhead-and-visible/397431\n","x":110,"y":40,"wires":[]},{"id":"5cf81bf789afe7be","type":"worldmap-tracks","z":"9a8c4b547b38e156","name":"ISS track","depth":"30","layer":"combined","smooth":true,"x":100,"y":280,"wires":[["1da6e3bdacaca0f9"]]}]


      Ham DB lookup with map

      [{"id":"5543b7dc63ef1bca","type":"ui_text_input","z":"134851ca88c24fe4","name":"Call sign","label":"Callsign","tooltip":"Enter the station call sign","group":"d9b5c411da0c8d24","order":0,"width":0,"height":0,"passthru":false,"mode":"text","delay":"0","topic":"callsign","sendOnBlur":false,"className":"","topicType":"str","x":100,"y":180,"wires":[["4dd7ff27f9fbf929","30acc081a38c741a"]]},{"id":"3d493dacd1cdafba","type":"http request","z":"134851ca88c24fe4","name":"hamdb lookup","method":"GET","ret":"obj","paytoqs":"ignore","url":"","tls":"","persist":false,"proxy":"","insecureHTTPParser":false,"authType":"","senderr":false,"headers":[],"x":480,"y":180,"wires":[["3c9e94c07a6eace1","379a1c3a2cb8c3ec"]]},{"id":"09d31ff412eb9d94","type":"worldmap","z":"134851ca88c24fe4","name":"Ham lookup","lat":"40.2605215","lon":"-111.7005643","zoom":"11","layer":"OSMC","cluster":"","maxage":"90","usermenu":"show","layers":"show","panit":"true","panlock":"false","zoomlock":"false","hiderightclick":"false","coords":"utm","showgrid":"true","showruler":"true","allowFileDrop":"false","path":"/ham","overlist":"RA,DN,TL","maplist":"OSMG,OSMC,EsriS","mapname":"","mapurl":"","mapopt":"","mapwms":false,"x":550,"y":380,"wires":[]},{"id":"95478a0270885a54","type":"change","z":"134851ca88c24fe4","name":"Convert to worldmap","rules":[{"t":"set","p":"payload","pt":"msg","to":"payload.hamdb.callsign","tot":"msg","dc":true},{"t":"set","p":"payload.label","pt":"msg","to":"payload.call","tot":"msg"},{"t":"set","p":"payload.name","pt":"msg","to":"$.payload.call & \": \" & $.payload.fname & \" \" & $.payload.mi & \" \" & $.payload.name & \" \" & $.payload.suffix","tot":"jsonata"},{"t":"set","p":"payload.icon","pt":"msg","to":"fa-user-circle-o","tot":"str"},{"t":"set","p":"payload.weblink","pt":"msg","to":"{\"name\":\"QRZ\",\"url\":\"http://www.qrz.com/db/\" & $.payload.call & \"/\",\"target\":\"_new\"}","tot":"jsonata"},{"t":"set","p":"payload.layer","pt":"msg","to":"hams","tot":"str"},{"t":"delete","p":"payload.fname","pt":"msg"},{"t":"delete","p":"payload.mi","pt":"msg"},{"t":"delete","p":"payload.suffix","pt":"msg"}],"action":"","property":"","from":"","to":"","reg":false,"x":320,"y":300,"wires":[["09d31ff412eb9d94","23caf401.9d6d4c","7602a9da7abfc7d7"]]},{"id":"4dd7ff27f9fbf929","type":"template","z":"134851ca88c24fe4","name":"Convert to API","field":"url","fieldType":"msg","format":"handlebars","syntax":"mustache","template":"http://api.hamdb.org/{{payload}}/json/uvarcdemo","output":"str","x":280,"y":180,"wires":[["3d493dacd1cdafba"]]},{"id":"379a1c3a2cb8c3ec","type":"change","z":"134851ca88c24fe4","name":"blank string","rules":[{"t":"set","p":"payload","pt":"msg","to":"","tot":"str"}],"action":"","property":"","from":"","to":"","reg":false,"x":150,"y":60,"wires":[["0a7906eba955ab06"]]},{"id":"4deeb220be58cf5a","type":"ui_toast","z":"134851ca88c24fe4","position":"top right","displayTime":"3","highlight":"","sendall":true,"outputs":0,"ok":"OK","cancel":"","raw":false,"className":"","topic":"HamDB","name":"toast","x":750,"y":300,"wires":[]},{"id":"7602a9da7abfc7d7","type":"template","z":"134851ca88c24fe4","name":"Format toast","field":"payload","fieldType":"msg","format":"handlebars","syntax":"mustache","template":"{{payload.name}}","output":"str","x":570,"y":300,"wires":[["4deeb220be58cf5a"]]},{"id":"86b1f299b0b23707","type":"ui_template","z":"134851ca88c24fe4","group":"1671379f30926081","name":"hamqsl Band conditions","order":1,"width":"9","height":"4","format":"<center>\n    <a href=\"https://www.hamqsl.com/solar.html\"\n        title=\"Click to add Solar-Terrestrial Data to your website!\" target=\"_new\"><img src=\"https://www.hamqsl.com/solar101vhf.php\"></a>\n</center>","storeOutMessages":true,"fwdInMessages":true,"resendOnRefresh":false,"templateScope":"local","className":"","x":330,"y":560,"wires":[[]]},{"id":"6a245d48aeabd4c3","type":"ui_template","z":"134851ca88c24fe4","group":"1671379f30926081","name":"RigRef Band conditions","order":2,"width":"9","height":"3","format":"<center><a href=\"https://rigreference.com/solar\"\n target=\"_blank\"><img src=\"https://rigreference.com/solar/img/wide\" border=\"0\"></a></center>","storeOutMessages":true,"fwdInMessages":true,"resendOnRefresh":false,"templateScope":"local","className":"","x":330,"y":600,"wires":[[]]},{"id":"7db57965.76d468","type":"ui_button","z":"134851ca88c24fe4","name":"Open ISS tab","group":"93eb817c13fb862d","order":1,"width":"3","height":"1","passthru":true,"label":"ISS","tooltip":"Open the ISS tab","color":"","bgcolor":"","className":"","icon":"satellite","payload":"iss","payloadType":"str","topic":"change-tab","topicType":"str","x":360,"y":500,"wires":[["6d6a371c653a1e38"]]},{"id":"5e1f0081.6dc3c","type":"ui_template","z":"134851ca88c24fe4","group":"93eb817c13fb862d","name":"window redirect","order":3,"width":0,"height":0,"format":"<script>\n(function(scope) {\n    scope.$watch('msg.payload', function(data) {\n      if (data == \"empty\" || data == \"\" || data == \"0\" || data === undefined)\n        return;\n\n      window.open(\"http://localhost:1880/\" + data, data + \"_tab\");\n      /*\n      if (data == \"Node-RED\") {\n        window.open(\"https://www.nodered.org\", \"nodered_tab\");\n        //window.location.href = \"https://www.nodered.org\";\n      } \n      if (data == \"GitHub\") {\n        window.open(\"https://github.com/node-red\", \"github_tab\");\n        //window.location.href = \"https://github.com/node-red\";\n      } \n      */\n    });\n})(scope);\n</script>","storeOutMessages":false,"fwdInMessages":true,"resendOnRefresh":false,"templateScope":"local","className":"","x":720,"y":480,"wires":[[]]},{"id":"23caf401.9d6d4c","type":"ui_button","z":"134851ca88c24fe4","name":"Open ham tab","group":"93eb817c13fb862d","order":2,"width":"3","height":"1","passthru":true,"label":"Ham DB","tooltip":"Open the HAM DB tab","color":"","bgcolor":"","className":"","icon":"fa-id-card-o","payload":"ham","payloadType":"str","topic":"change-tab","topicType":"str","x":360,"y":460,"wires":[["6d6a371c653a1e38"]]},{"id":"6d6a371c653a1e38","type":"trigger","z":"134851ca88c24fe4","name":"reset","op1":"","op2":"","op1type":"pay","op2type":"str","duration":"250","extend":false,"overrideDelay":false,"units":"ms","reset":"","bytopic":"all","topic":"topic","outputs":1,"x":550,"y":480,"wires":[["5e1f0081.6dc3c"]],"info":"This is necessary or the window code won't move to the same window twice in a row"},{"id":"3c9e94c07a6eace1","type":"switch","z":"134851ca88c24fe4","name":"Success or fail","property":"payload.hamdb.messages.status","propertyType":"msg","rules":[{"t":"eq","v":"OK","vt":"str"},{"t":"else"}],"checkall":"true","repair":false,"outputs":2,"x":700,"y":180,"wires":[["95478a0270885a54"],["fc65050e80308d0a"]],"outputLabels":["success","fail"]},{"id":"fc65050e80308d0a","type":"change","z":"134851ca88c24fe4","name":"fail - show status","rules":[{"t":"set","p":"payload","pt":"msg","to":"$flowContext('callsign') & \" \" & $.payload.hamdb.messages.status","tot":"jsonata"}],"action":"","property":"","from":"","to":"","reg":false,"x":830,"y":240,"wires":[["4deeb220be58cf5a"]]},{"id":"0a7906eba955ab06","type":"delay","z":"134851ca88c24fe4","name":"delay .25 sec","pauseType":"delay","timeout":"250","timeoutUnits":"milliseconds","rate":"1","nbRateUnits":"1","rateUnits":"second","randomFirst":"1","randomLast":"5","randomUnits":"seconds","drop":false,"allowrate":false,"outputs":1,"x":330,"y":60,"wires":[["5543b7dc63ef1bca"]]},{"id":"30acc081a38c741a","type":"change","z":"134851ca88c24fe4","name":"Save call sign","rules":[{"t":"set","p":"callsign","pt":"flow","to":"payload","tot":"msg"}],"action":"","property":"","from":"","to":"","reg":false,"x":280,"y":220,"wires":[[]]},{"id":"d9b5c411da0c8d24","type":"ui_group","name":"HamDB","tab":"5af3bc9c93f141e7","order":2,"disp":true,"width":"6","collapse":true,"className":""},{"id":"1671379f30926081","type":"ui_group","name":"Band conditions","tab":"5af3bc9c93f141e7","order":3,"disp":true,"width":"9","collapse":true,"className":""},{"id":"93eb817c13fb862d","type":"ui_group","name":"Default","tab":"5af3bc9c93f141e7","order":1,"disp":true,"width":"6","collapse":true,"className":""},{"id":"5af3bc9c93f141e7","type":"ui_tab","name":"Home","icon":"dashboard","order":2,"disabled":false,"hidden":false}] 

       

      Thursday, June 23, 2022

      Update the default list of search engines in Chrome

      Update the default list of search engines in Chrome

      Chrome allows you to manage the list of searches available via the address bar. You can add new site searches and such by clicking the Add button. What you can't do is move a search engine from the "Site search" section to the "Search engines" section. You are effectively stuck with the list that Google curated. Here's how to fix that.

      Side note: The data we want to edit is stored in a SQLite database. You'll need a copy of the SQLite command line tool for your OS in order to edit this database. Good news, SQLite is free software! Just run on over to the SQLite home page at https://sqlite.org and hit the download button.

      In your browser go to chrome://settings/searchEngines



      Click the "Add" button (highlighted above) to add your new search engine. You could also search the list of engines and see if it's already there (use the search box in the top right, also highlighted above).

      Once you've added or activated your desired search engine, you need to EXIT chrome. That includes all instances that might be running. I don't just mean close the settings tab, I mean completely exit all running instances of Chrome. This is necessary because the file storing this information is locked when Chrome is running.

      Now we need to edit the database storing this info. Go to your Chrome profile directory. In Windows 10 it is located in the C:\Users\%UserName%\AppData\Local\Google\Chrome\User Data\Default directory in the "Web Data" file.

      >cd "\Users\%UserName%\AppData\Local\Google\Chrome\User Data\Default"
      >sqlite3 "Web Data"
      sqlite> .mode line
      sqlite> select * from keywords where url like '%brave%'
                           id = 632
                   short_name = Brave
                      keyword = b
                  favicon_url =
                          url = https://search.brave.com/search?q={searchTerms}
         safe_for_autoreplace = 0
              originating_url =
                 date_created = 13300482199622719
                  usage_count = 0
              input_encodings =
                  suggest_url =
               prepopulate_id = 0
            created_by_policy = 0
                last_modified = 13300482199622719
                    sync_guid = 680f8753-590d-4cc6-8be5-ca0154aa3f2a
               alternate_urls = []
                    image_url =
       search_url_post_params =
      suggest_url_post_params =
        image_url_post_params =
                  new_tab_url =
                 last_visited = 0
        created_from_play_api = 0
                    is_active = 1
              starter_pack_id = 0
      sqlite> update keywords set prepopulate_id=id where url like '%brave%';
      sqlite> .q

      In this case I added the Brave search engine to my list of default search engines by updating the "prepopulate_id" field to a non-zero value. To search for your preferred engine, substitute the domain or some other unique part for the word brave in the queries above. Note that you need to keep the single quotes and the percent signs. The single quote tells SQLite that this is a string value. The percent signs are wildcards for characters before and after the keyword you are looking for.

      You could also remove search engines from the default list by, you guessed it, setting the prepopulate_id to zero.

      sqlite> update keywords set prepopulate_id=0 where url like '%ecosia%';

      Now start Chrome again and your selected search engines should show up in the list of default search engines.

      Thursday, July 29, 2021

      CDC guidance isn't internally consistent

       

      CDC guidance isn't internally consistent

      Yesterday the CDC released new guidance on masks. The new rules call for everyone to wear masks whether vaccinated or not. This is based on secret data that the CDC has thus far refused to release (citing "CDC COVID-19 Response Team, unpublished data, 2021"). They've promised this data "real soon now" but thus far they have not been forthcoming with this crucial information.

      Let's leave aside the lack of any supporting data for the moment and just focus on the policy. So the original theory was that the "vaccine" (see more about why it's not really a vaccine below) would allow us to "return to normal". Now, however, the CDC cryptically says that those who are vaccinated are still catching and transmitting the virus. Thus, everyone needs to wear masks again.

      The CDC wants everyone to get vaccinated but they acknowledge that this won't prevent you from getting or transmitting the virus. So how, exactly, will everyone getting vaccinated help? Their "logic" defies ... well ... logic if we're honest about it.

      Since the vaccine doesn't stop the virus we want everyone, including those who are vaccinated, to return to wearing masks. And since the virus isn't stopped by the vaccine, the only logical conclusion is that we will all be wearing masks forever.

      But let's not forget, if masks worked we would have crushed this virus the last time we went through this charade. If masks stopped the virus, we wouldn't need an untested, experimental vaccine.

      The "vaccine" wont stop the virus (according to CDC's unpublished data). Wearing masks also wont stop the virus (as we've already proven for the past year). Where does that leave us?

      The real answer is what medical professionals said from the beginning. We need actual heard immunity. And that comes from a majority of the population getting the disease (not a vaccine that doesn't provide immunity or masks that don't slow or stop the spread).

      Why it isn't a "vaccine"

      Vaccine (noun): a substance used to stimulate the production of antibodies and provide immunity against one or several diseases, prepared from the causative agent of a disease, its products, or a synthetic substitute, treated to act as an antigen without inducing the disease.
      Definition of "vaccine" from Oxford Languages

      Vaccines, by definition, confer immunity (think MMR, DTAP, etc.). As we've seen, that's not the case with this "vaccine". Rather the COVID vaccines are more properly classified as therapeutics since all they actually do is reduce symptom severity. This is the same benefit provided by other therapeutics such as Hydroxychloroquine and Ivermectin.

      Saturday, November 3, 2018

      Soldering Resources

      This article was originally written in 2018. It was updated with new prices and information in 2022.

      Articles and Information

      The following articles include basic information about how to solder and what tools you need. Many of these include videos and links to other resources.


      Equipment


      Note that if you use the links below, I may get an Amazon affiliate commission. This in no way influences my recommendations.

      Technically only 2 things are required to solder, a soldering iron and solder (there are even some soldering strips that you can activate with a match, but that's getting a bit out there). So let's talk briefly about solder then soldering irons. After that we'll look at some clamping options to hold things in place and then some other tools you might want to consider.

      Solder

      Solder comes in basically two varieties, rosin core and acid core. Acid core solder is for plumbing, NOT for electronics. DO NOT use acid core solder for electronics! Pretty much any rosin core solder will work just fine. I personally prefer lead-free solder in a small plastic tube (rather than on a roll). While slightly more expense, it is much easier to work with, and easier to carry for field work. You should avoid breathing solder fumes no matter what kind of solder you use, but this is especially important if you buy the (generally) less expensive tin-lead solder.

      Soldering Irons


      Irons can range from the cheap (sub $10) versions that plug directly into the wall up to thousands of dollars for high end soldering and rework stations. If you are just getting started, you don't need to spend a fortune to get a reasonable piece of equipment. At the end of this section are some soldering options for emergency and field use.


      Save yourself some frustration and don’t buy a cheaper soldering iron from Radio Shack or Harbor Freight. Especially if you are just starting out, at least invest in a descent tool.  For $32 you can get the Velleman VTSS5U adjustable temperature soldering station. It has an analog temperature control with no display so you don’t know exactly where it is set, but at least it’s adjustable.



      Hakko FX-888D digital soldering station ($106) is an excellent tool for hobbyists. This is the iron I'd recommend if you have any intention of soldering more than one or two small projects. This kit comes with a pair of the best cutters you’ll ever use. I love my Hakko cutters. I have several of them and I use them all the time.

      For emergency / field use (only) there are some alternative soldering irons:


      Clamps


      If you plan to solder much at all, you are going to want some way to clamp things in place while you solder them. This is true whether you are soldering wires together, soldering parts on a board, or soldering wires to a connector. Again, it doesn't have to be super expensive to be effective. Start with putty and clothespins and then move up to a vice if you find you are doing more soldering.


      Plasti-Tak (poster putty, adhesive putty, mounting putty, reusable putty) is a great and cheap way to hold parts to boards, hold boards still, or hold wires and or connectors in place while soldering. The cheapest you can find should work just fine (Elmers $6.50, or Loctite $2). Try this video if you want to see it in action (“Blu-Tack” is the same as poster putty, Plasti-Tak, etc.). Some people use Silly Putty instead. That works too but I prefer the extra stick and stiffness of the poster putty.



      Wooden (not plastic; they melt) clothespins make a great inexpensive clamp for holding wires, boards, or small parts when soldering.  You can cut the angled ends off to make a ‘flush’ or ‘flat’ face to your “clamp” (see picture above). Combine clothespins with reusable putty (previous tip) and you have a very portable, inexpensive, and versatile clamping system.  This guy made a fixture to hold the clothespins in place. You could do the same with a piece of scrap wood (1x6, etc.) for essentially free.



      The Stick Vise ($35) is a great little portable vice for soldering. Takes almost no space and you can 3D print your own jaws if you are so inclined.





      There are some 3D printable clamps you might consider as well.


      Tools


      In addition to clamps, there are a number of other tools you might consider. Three of the most useful are wire cutters, pliers, and a soldering mat.


        






      As I mentioned previously, I love my Hakko CHP-170 micro cutters ($9). They are relatively inexpensive, and worth every penny. I have several pair that I keep stashed around so a pair is always within easy reach.


      Hakko long nose pliers ($15) are just a pleasure to use. The jaws close nice and flat and they hold parts very nicely.



      A silicone mat ($8) is one of the best investments you can make. They are very inexpensive but make it much easier to work. It helps you keep track of parts and, unlike your kitchen table, you can’t burn the mat with your soldering iron.



      Safety



      A fume extractor / air filter ($26) is a great piece of safety equipment, especially if you use lead based solder. The fumes given off during soldering are toxic and should be avoided. You should also clean the table or other areas where you soldered with wet wipes to remove any dust or debris.




      As with most projects, safety glasses ($2) are also recommended. Solder can pop and spatter, especially when desoldering or soldering wires.