A collection of links, tweets, and other random things that caught my attention in the month of December 2019.
A serverless email server on AWS using S3 and SES. Because, why not?
These are beautiful. They make me want to go visit these cities and explore where the subway takes you.
An interesting set of design principles, resulting in calm technology.
There are numerous articles and blog postings detailing how to install Arch Linux. This one is mine. I’ve been fascinated with Arch Linux for several years. I like that it is very much a “some assembly required” distribution. Nearly every other installer hides away the underlying complexity of installing and configuring an operating system. The Arch installation process exposes you to all the details and lets you determine how much or how little you want to put on your machine. Exposure to all the details can be cause for both excitement and frustration. Fortunately there are excellent resources to help you.
The single best resource is the Arch Linux Installation Guide. You should read that completely before installing Arch Linux. In fact, you should follow that to do your install and not follow my setup.
Arch Linux is a rolling release and a moving target. Rolling release distributions constantly get updates, there is no schedule where once or twice a year a major update to the distribution is released. You can update your install everyday. Sometimes multiple times in a single day. Or you can do it once a week. It’s entirely up to you.
As for being a moving target…. In the time it took me to work through the installation process I
wanted and capture the steps in this posting, the contents of the base
group were changed. It no
longer includes a kernel, or an editor, or other software that you might expect or need. So the
pacstrap command to install the operating system could no longer be just
pacstrap -i /mnt base
But instead needs to be something like
pacstrap -i /mnt base linux linux-firmware mkinitcpio lvm2 vi
All of which leads to this disclaimer. Follow my installation steps at your own risk. Read the
installation guide. Use the Arch Wiki. The answers
to your questions are there. Join the Arch Linux Reddit or go old school and use the #archlinux channel on freenode.
Here are my high-level goals for this Arch installation:
For equipment I have an ASUS Q325UA laptop with a dual-core i7 CPU running at 2.7 GHz, 16 GB of RAM, Intel graphics, a 512 GB SSD, and a 1920x1080 13" screen in a 16:9 ratio. It’s a good little computer that runs Linux rather well.
I am presuming that you have already downloaded the Arch Linux installer and flashed it to a USB drive. If not, there are instructions online describing how to accomplish this step.
Using whatever hot key on your equipment allows you to access the BIOS, ensure that the USB drive with the installer on it is first in the boot order and restart your computer.
My laptop doesn’t have an Ethernet jack, so I use WiFi for connectivity. Use wifi-menu to select
an access point and get connected. Once connected, verify that you have an IP address and can reach
the Internet.
wifi-menu
ip addr show
ping archlinux.org
Now that you have connectivity, update the package repository indexes.
pacman -Syyy
And while we are at it, set the time and date.
timedatactl set-ntp true
I am going to setup three disk partitions:
Start by determining what device you want to use for the install.
fdisk -l
In my case /dev/sda is the disk.
Open the fdisk tool.
fdisk /dev/sda
You can see the current partition scheme by using the p for print command.
p
The EFI partition I created is 500MB in size and has a type of EFI Partition. Here are the
commands I used.
g (creates an empty GPT table)
n (creates a new partition)
<enter> (accept the partition number)
<enter> (accept the starting position)
+500M (set the partition size)
t (set the partition type)
1 (for EFI partition)
I wanted a 500MB boot partition. (I’m obsessive and two 500MB partitions adds up to 1000, which is more pleasing than say a 300M EFI and 400M boot only equaling 700M.)
n
<enter>
<enter>
+500M
By default the partition type is Linux filesystem, so there is no need to change the type of the boot partition.
I used the remainder of the drive space for the LVM partition.
n
<enter>
<enter>
<enter> (use all remaining disk space)
t
<enter> (accept offered (last) partition number)
31 (LVM type partition)
Display (print) the partition scheme and verify that it is what you want.
p
Once this step is completed the partition changes will be written to the drive.
w
The EFI partition wants to use the FAT file system, and boot wants to be ext4.
mkfs.fat -F32 /dev/sda1
mkfs.ext4 /dev/sda2
The entire third disk partition, /dev/sda3, will be encrypted using
LUKS. This is where the
passphrase for the encryption will be set, and where the name of the cryptdevice will be set.
cryptsetup luksFormat /dev/sda3
cryptsetup open --type luks /dev/sda3 lvm
The first command will create the encryption and ask for the passphrase. Make sure you note what the phrase is, losing it means you’ll never be able to open this partition.
The second command opens the newly created encrypted partition and gives it the wildly inventive
name of lvm.
I wanted to have separate logical volumes for root and home. For naming I went as simply as I
could.
/dev/mapper/lvmvglv_root and will be 50G in sizelv_home and will be 250 G in sizeHere are the commands I used to accomplish this LVM configuration.
pvcreate --dataalignment 1m /dev/mapper/lvm
vgcreate vg /dev/mapper/lvm
lvcreate -L 50GB vg -n lv_root
lvcreate -L 250GB vg -n lv_home
Next we need to load the necessary modules
modprobe dm_mod
Finally we have LVM scan for volumes and activate the volume group
vgscan
vgchange -ay
mkfs.ext4 /dev/vg/lv_root
mkfs.ext4 /dev/vg/lv_home
mount /dev/vg/lv_root /mnt
cd /mnt
mkdir boot efi home
mount /dev/sda2 boot
mount /dev/vg/lv_home home
mount /dev/sda1 efi
The root partition mounts to /mnt and the remaining mount points are all contained within root.
For no good reason I’m mounting the EFI partition in /efi rather than /boot/EFI.
Run the mount command to verify that all the mounts are correct
mount
As I mentioned above, due to changes in the base package, the contents of this command changed recently. In addition to base, I’m also installing a kernel, the firmware package, mkinitcpio, and an editor.
pacstrap -i /mnt base linux linux-firmware mkinitcpiio vi
Depending on your connection speed and location in the world this may take a while to complete.
With everything mounted, and an Arch installation located at /mnt I can generate the /etc/fstab
file.
genfstab -U -p /mnt >> /mnt/etc/fstab
Verify the contents of this file. (!$ is bash shorthand for “last argument from previous
command”.)
cat !$
The rest of the steps happen inside the new Arch installation. This command changes root to the new install.
arch-chroot /mnt
The pacstrap command was a good start, but there are more package necessary to complete the
installation.
pacman -S base-devel grub efibootmgr dosfstools openssh os-prober mtools linux-headers networkmanager network-manager-applet wpa_supplicant wireless_tools dialog vim
Once the install is complete, and the machine is rebooted, having NetworkManager ready to use will be helpful.
systemctl enable NetworkManager
In order for the encryption to work, the /etc/mkinitcpio.conf file needs to be edited.
vi /etc/mkinitcpio.conf
Find the HOOKS line (approximately line 51) and add encrypt lvm2 bewteen block and
filesystems. Save the file.
mkinitcpio -p linux
vi /etc/locale.gen (uncomment en_US.UTF-8 - or your locale)
locale-gen
password
useradd -mg users -G wheel <username>
passwd <username>
pacman -S sudo
wheel group to use sudovisudo
Uncomment %wheel ALL=(ALL) ALL line. It’s very near the end of the file.
This step is vitally important. A mistake here will prevent your system from booting. Ask me how I know.
Start by editing the /etc/default/grub file. There are three changes to make here.
GRUB_ENABLE_CRYPTODISK=y linecryptdevice=/dev/sda3:vg:allows-discards to the GRUB_CMDLINE_LINUX_DEFAULT linelvm to the GRUB_PRELOAD_MODULES lineThe first change is made by removing the # at the beginning of the GRUB_ENABLE_CRYPTODISK=y
line.
The second change is the trickiest. Edit the GRUB_CMNLINE_LINUX_DEFAULT line and add
cryptdevice=/dev/sda3:vg:allow-discards to it. In my case I put it just before the quiet
argument that was already there. A typo here, say spelling the argument cryptodevice will render
the configuration inoperable. There won’t be any errors, but the machine will only boot to a grub
prompt.
The third change is to add lvm to the list of preloaded modules. The list is space-delimited. I
put lvm at the end of the list.
Here are those three lines after the edits. The rest of the file is not shown below.
...
GRUB_CMDLINE_LINUX_DEFAULT="loglevel=3 cryptdevice=/dev/sda3:vg:allow-discards quiet"
...
GRUB_PRELOAD_MODULES="part_gpt part_msdos lvm"
...
GRUB_ENABLE_CRYPTODISK=y
...
Once the changes have been made and saved Grub can be installed
grub-install --target=x86_64-efi -efi-directory=/efi --bootloader-id=grub_uefi --recheck
Since I opted to put the EFI partition in a non-standard location, I needed to add the
--efi-directory=/efi directive to the command.
Finally generate the grub configuration file
grub-mkconfig -o /boot/grub/grub.cfg
Rather than have an entire partition devoted to swap, I’m using a swap file instead. Easier to resize and manage.
fallocate -l 4G /swapfile
chmod 600 /swapfile
mkswap /swapfile
And add the new /swapfile to the /etc/fstab file.
echo '/swapfile none swap sw 0 0' | tee -a /etc/fstab
The -a on the tee command is crucial, leave that off and the /etc/fstab file will be
overwritten, not appended to.
At this point the installation process is complete. Exit the chroot, unmount devices, and reboot.
The umount command will likely produce some errors, these can be ignored.
exit
umount -a
reboot
If all has gone well the computer should reboot. It will ask for the passphrase used to encrypt/decrypt the LVM partition. Once that has been entered the bootstrap will complete. If you get the Grub menu and can select Arch Linux, and then end at a login prompt, then the install was successful.
However, the computer is still not completely setup. In my case I chose to install the i3 window manager, and the Sway window manager. I also installed lightdm as a display manager. Below are some additional commands and setup configuration I made immediately following the install. Your mileage may vary, void where prohibited, please hesitate to call.
I like having a record of all the sudo commands I’ve issued. Edit /etc/sudoers using visudo and
add this line
Defaults logfile=/var/log/sudo
sudo ln -sf /usr/share/zoneinfo/America/Chicago /etc/localtime
hwclock --systohc --utc
localectl set-locale LANG="en_US.UFT-8"
hostnamectl set-hostname <hostname>
Run this command to get a list of access points
nmcli d wifi list
And run this command to join one. Yes, the password is in plain text. It gets stored that way too.
nmcli d wifi connect <BSSID> password <password>
ssh-keygen -t rsa -b 4096
The AUR is one of the best features of the Arch ecosystem. Add the following the end of the
/etc/pacman.conf file
[archlinuxfr]
Server = http://repo.archlinux.fr/$arch
By default the pacman mirror list includes all the mirrors, worldwide. pacman performance can be improved by using the Arch Mirrorlist to generate one for you. This will probably be easier to accomplish after you’ve installed a window manager or desktop environment and a browser.
yay for AUR accessyay -S i3-gaps i3blocks i3lock i3status
yay -S xf86-input-libinput xorg-server xorg-xinit xorg-apps mesa xf86-video-intel lib32-intel-dri lib32-mesa lib32-libgl
Create ~/.xinit file and put this line in it
exec i3
Run startx to open i3 session. Note, with no terminal emulator installed, and no typical desktop
tools installed, running i3 may be a bit anti-climactic.
Sway is a Wayland based alternative to i3.
yay -S wlroots-git sway-git
Copy the default sway config. Sway starts from the command line by running sway.
yay -S terminator
Edit i3 and Sway configurations to make terminator the terminal they use.
At the end of this process I have a functioning Arch Linux installation, running on LVM and booting
via EFI. I’ve got separate root and home partitions, and some unallocated drive space to grow
either or both of those logical volumes. Wireless networking is up and running, and I’m able to
search for and manage packages using the yay AUR tool and pacman wrapper. Two tiling window
managers, i3 and Sway, are install and working, and I’ve got lightdm setup as my display manager.
The rest of the setup will evolve over time.
The easiest way to view your bash path is to run
env
Then visually parse the output looking for the PATH entry and then read that line.
A slightly better way to view your bash path is to run
env | grep -i path
This will eliminate all the environment variables that aren’t paths.
$ env | grep -i path
SQLITE_EXEMPT_PATH_FROM_VNODE_GUARDS=/Users/mark/Library/WebKit/Databases
PATH=/Users/mark/.rbenv/shims:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/go/bin:/usr/local/MacGPG2/bin:/opt/X11/bin:/Users/mark/bin:/usr/local/sbin:/usr/local/go/bin:/Users/mark/.cargo/bin
GOPATH=/Users/mark/code/go
Personally I find parsing a list delimited by : to be difficult. So I use a simple function to
break the path apart, displaying each entry on its own line, and color coding it along the way.
Here’s the function:
path() {
local blue="\033[1;34m"
local green="\033[0;32m"
local cyan="\033[0;36m"
local purple="\033[0;35m"
local brown="\033[0;33m"
local reset_color="\033[0m"
echo $PATH | tr ":" "\n" | \
awk "{ sub(\"/usr\", \"$green/usr$reset_color\"); \
sub(\"/bin\", \"$blue/bin$reset_color\"); \
sub(\"/opt\", \"$cyan/opt$reset_color\"); \
sub(\"/sbin\", \"$purple/sbin$reset_color\"); \
sub(\"/local\", \"$brown/local$reset_color\"); \
print }"
}
After setting some local variables to hold bash color codes, the function echoes the $PATH
environment variable, using the tr, or translate command, to convert each : into a new line
character, \n. The output of tr is passed to awk which colorizes the output but substituting
some key words into the same keywords surrounded by color codes.
Here’s a sample output:

One advantage to this output is it is far easier to find duplicates or path elements that are out of order.
macOS includes a utility called path_helper. The utility hopes to simplify management of your path. Knowing about it, and working with it, is the key to simplifying your path.
path_helper relies upon two sets of information. First is a list of standard paths found in
/etc/paths. On my macOS computer /etc/paths contains:
$ cat /etc/paths
/usr/local/bin
/usr/bin
/bin
/usr/sbin
/sbin
The second set of information used is the /etc/paths.d directory. Applications that make use of
path_helper know to put a file at this location that contains their path element. Again from my
computer, the contents of /etc/paths.d
$ ls -al /etc/paths.d
total 24
drwxr-xr-x 5 root wheel 160B Sep 30 2018 ./
drwxr-xr-x 126 root wheel 3.9K Sep 19 14:10 ../
-rw-r--r-- 1 root wheel 13B Oct 26 2016 40-XQuartz
-rw-r--r-- 1 root wheel 23B Feb 2 2015 MacGPG2
-rw-r--r-- 1 root wheel 17B Oct 25 2017 go
Looking at the go entry, for example, we see:
/usr/local/go/bin
Returning to the image showing the output of my path function, you can see the Go entry in the list.
As well as entries for X-Quartz and MacGPG2. Also you can see the five standard path elements in
positions 2 - 6. Obviously the /Users/mark/.rbenv/shims entry was pre-pended to $PATH. And it is
also obvious that some things are getting added to the list twice.
Understanding that path_helper will seed $PATH with the standard elements, and any elements found
in /etc/paths.d, it is now possible to clean up what is added to $PATH, and in what order they
are added, in the bash configuration.
My bash configuration is broken up into several files as the outgrowth of near constant tinkering and tweaking.
la -la ~/.dotfiles/bash/
total 136
drwxr-xr-x@ 12 mark staff 384B Sep 19 14:12 ./
drwxr-xr-x@ 40 mark staff 1.3K Aug 15 22:33 ../
-rw-rw-r-- 1 mark staff 7.3K Aug 25 22:11 bash_aliases
-rw-rw-r--@ 1 mark staff 389B May 5 2016 bash_bindkeys
-rw-rw-r--@ 1 mark staff 1.9K Jan 20 2016 bash_colors
-rw-rw-r--@ 1 mark staff 1.8K Mar 22 2016 bash_docker_functions
-rw-rw-r-- 1 mark staff 16K Aug 15 22:33 bash_functions
-rw-rw-r-- 1 mark staff 2.1K Sep 19 14:12 bash_profile
-rw-rw-r-- 1 mark staff 5.1K Sep 19 14:12 bashrc
(It is worth noting that the files are in my $HOME via symlinks.) The bash_profile file contains all the additions to my path.
I start off by clearing my $PATH and executing path_helper to seed to with the contents of
/etc/paths and /etc/paths.d.
if [ -x /usr/libexec/path_helper ]; then
PATH=""
eval `/usr/libexec/path_helper -s`
fi
The -x conditional looks for an executable file; this allows the same bash_profile to be used on
Linux machines without throwing errors.
For each element I want to add to $PATH I follow a similar pattern: test for the presence of the
directory to be added, and if it is there, append it (or pre-pend it) to the variable. For example:
# set PATH so it includes user's private bin if it exists
if [ -d $HOME/bin ] ; then
PATH="${PATH}:${HOME}/bin"
fi
Will add my personal bin directory to the list, at the end of the current list.
You can see my current bash_profile, and the rest of my bash configuration, in my GitHub
dotfile repository. Here’s a sample from
my bash_profile:
# set PATH so it includes user's private bin if it exists
if [ -d $HOME/bin ] ; then
PATH="${PATH}:${HOME}/bin"
fi
# add Go path for Linux
if [ -d /usr/local/go/bin ] ; then
PATH="${PATH}:/usr/local/go/bin"
export GOPATH=$HOME/code/go
fi
# Enable path for Rust
if [ -d $HOME/.cargo/bin ] ; then
PATH="${PATH}:$HOME/.cargo/bin"
fi
export PATH
Close reading of the path function output in the image above, and of the contents of /etc/paths.d,
and of the sample bash_profile above, will show that the path for Go is in my $PATH twice. Once
from the entry in /etc/paths.d and once from the lines in my bash_profile.
I have, and use, multiple computers running macOS. At work I have a pair of desktops and a laptop,
and at home I have my personal laptop. Apparently I used a different method to install Go at work
than I did at home. The method I used on my personal laptop created the /etc/paths.d entry, while
the method I used at work did not. I can either remove the lines from bash_profile or add an entry
to /etc/paths.d. Since I maintain my bash configuration I’ve decided to remove the entry
/etc/paths.d (on any machine I find it) and rely upon the code in my bash_profile.
Here are my tips for keeping your path up to date and easy to work with.
path_helper and add what you need in your $PATH to that initial set of elements.path function, and address anything the strikes you as out of place or
no longer needed.
Both my wife and I recently signed up for and got Apple Cards. The process was stunningly simple and quick. From our phones, and in about 2 minutes time, we were able to complete the application process, get approved, and have the new card in our respective digital wallets. In my case I had ordered an audio book a day or two earlier and within an hour or two of getting the Apple Card that charge happened on the new card generating 3% cash back.
The Apple Card application and approval process is fantastic. Using the card is also very nice. I’m rapidly learning which stores and restaurants accept Apple Pay. Starbucks can do Apple Pay at their drive through. Jimmy John’s can’t, so I park and go in side there. That way I get the card-less transaction 2%; at the drive through I’d only get 1% since I’d have to hand them my physical card.
Prior to getting these cards, both of us had a debit card with our bank, and we both have a VISA card through the bank too. We don’t use the VISA cards. For travel or large purchases we have a Citibank MasterCard. The Citi card is in my name. My wife’s Apple Card application resulted in a higher interest rate than I was offered. We both decided this was due to a lack of credit history under her name. Toward that end she applied for an Amazon VISA card in her name. This card offers 5% cash back on purchases made at Amazon or Whole Foods. We do a fair amount of shopping on an annual basis at Amazon, so 5% back on those purchases is a good deal.
The contrast in the process to get the card and have it fully setup is stark. While she was approved immediately, and was able add it to her Amazon account, she was not able setup an account with Chase until she had the physical card in her possession. While she can, and does, keep track of purchases, there was no way to see the account.
The new card arrived in the mail today - six days after she applied. This is actually pretty good,
since at the time she was told it could be two weeks. After dinner she sat down to create her
account. The first hurdle was creating a password. Banks have gotten nutty with password
requirements, and Chase is no different in this regard. The password had to be 8 - 32 characters
long, had to have a number and a capital letter, couldn’t have two or more letters in a sequence
(e.g., abc), and couldn’t have more than two of the same letter.
This meant that trying to use a pass phrase, something
NIST now suggests, wasn’t possible. The pass phrase she tried had three
occurrences of the letter “a”. The web form didn’t display a message it just made the heading over
the first password field red. Once we abandoned the pass phrase and used the Chrome suggested
password we still couldn’t get the form to submit. Turns out that using auto fill for the phone
number resulted in an unformatted number: 3335551212. The form wanted a formatted number:
333-555-1212. Really Chase? Really? It isn’t hard to do a little processing of the digits in the
field to format the number for the customer. Again, the only hint the number was the problem was a
red heading.
Using color as the only means of conveying information violates user accessibility. It’s also just plain rude. Eventually, after several frustrating attempts, after being made to feel stupid by not being able to fill in a simple form, the “Next” button was enabled.
At which point she was informed that access to the agreements was currently unavailable and she’d have to try again later. This is adding insult to injury. She wants to be a good customer. She wants to setup an account and play by the rules. Unfortunately the rules are obscure, poorly communicated, and seemingly arbitrary.
After signing out and signing back in, she was presented with the agreements, and she was able to digitally sign. Her account is now active and she can finally see a list of purchases.
To recap; the Apple Card application was simple and fast. It required a minimum of information. Approval was instantaneous and came with a fully functioning digital card. Within seconds of any purchase you get a notification on your phone showing you the merchant and the amount. Opening the card in the Wallet app lets you see spending by the week or month. You can see spending categories or spending by merchant. It. Just. Works. Oh, and you can pay any amount you want, at any time, toward your outstanding balance.
The Amazon VISA application process was fairly easy too. Where the process fell apart was having to wait a week to setup the account, and then having to jump through hoops to complete that process. I’ve been creating software for 4 decades now. I know what it takes to design and implement interfaces and back-end processes alike. Interfaces like the one at Chase rely too much on the developer and not enough on feedback driven design. Not providing messages to indicate when a field hasn’t been filled in properly, and relying only on a color change of the heading is a failure. Not formatting user inputs is a failure. Allowing the entire process to complete only to present the customer with a message saying, “Sorry. We can’t finish now because our systems aren’t available” is a failure.
My sincere hope is that the Apple Card is hugely successful. That its ease of use and clear concise reporting of expenditures, and the protection of customer information, sets an example that people begin to demand of other credit providers. Apple disrupted home computing with the Macintosh in 1984. They disrupted portable music, and indeed the music industry, with the iPod in 2001. They completely redefined cell phones with the iPhone release in 2007. Now I hope they are on the cusp of disrupting the credit industry.
If you have an iPhone and want a good credit card experience, go get an Apple Card.
For the past eight or so years I’ve been using 1Password as my password manager. It works both on my Macs and on my iOS devices. The browser extension on the Macs has always been good, and the iOS one has gotten better. I like that it stores more than just passwords; email account, credit cards, passports, and secure notes to name a few. At last count I have nearly 600 total items stored in my 1Password vault.
Recently I’ve been exploring other password options. I have a laptop running Arch Linux, and a NUC that has Ubuntu 18 installed on it. I’d like to have password management there too. After a lot of research, and some experimentation, I’ve switched to Bitwarden.
Bitwarden is free, has a hosted or a self-hosted option, works on Windows, Linux, and macOS, and has browser extensions for Google Chrome, Mozilla Firefox, Safari, Vivaldi, Opera, Brave, Microsoft Edge, and even Tor Browser. There are mobile apps for iOS and Android, and there is a command line interface. Oh, and you can access your vault via the web as well.
The types of objects Bitwarden knows about out of the box include Logins, Cards, Identity, and Secure Notes. The Secure Notes object allows you to define new field to hold text, boolean values, or hidden text (think passwords). The interface is clean and lightweight.
While it is possible to export your 1Password vault and import it into Bitwarden, and even though I initially did just that, I decided to take a more curated approach. I deleted all the entries from the import and manually created entries for those items I wanted and frequently used in 1Password. Spread out over a couple of days it took me perhaps 4 hours to create 130 entries in my new Bitwarden vault. Along the way I made use Bitwarden’s password generator and cleaned up some weaker passwords, and some duplicate passwords.
On the 1Password side I added two “smart folders”: one called 1Password and one called Bitwarden.
The 1Password folder displays all the items that do not have a tag with the value bitwarden. The
Bitwarden folder does the opposite; it shows only items that do have a bitwarden tag. This allows
me to know which 1Password entries I’ve moved.
Initially I setup the browser extension for Firefox. I use Firefox primary for work; it holds all the web applications I use as a part of my job. One option the extension has that is very nice is automatic fill. Open a page that has a recognizable login form and Bitwarden will pre-fill the user and password fields for you. All you need to do is press enter. Very nice.
Getting the Safari extension installed was more problematic. Every time I clicked on the link I was take to the Safari Extension Gallery, where there was no evidence of Bitwarden. After several attempts from different computers I finally did a search and found this issue on the Bitwarden GitHub account: Publish Safari Extensions as a Safari App Extensions. Toward the bottom of the comments there is a link to a new beta version of the desktop app that includes a working Safari extension. As Apple works to protect individual privacy they are changing underlying frameworks and altering long standing protocols, which in turn requires the developer put in extra effort in order to support what is likely a small(er) audience.
With the new extension in place, Safari (my primary browser) now auto-fills login forms and works as expected. I’ve also installed Bitwarden and the Firefox and Vivaldi extension on my Arch Linux laptop, and I’ve setup the iOS app and it’s extension on my iPhone and iPad.
I am pleased with Bitwarden, and I’m also pleased to have started reviewing and cleaning up my password vault. For now I’m keeping 1Password installed as I am sure there will be seldom used accounts that I’ll want to migrate. However, I’ve disabled the browser extensions for 1Password so that I’m only using the Bitwarden one.
Applications like Bitwarden and 1Password make good password hygiene possible and practical. If you aren’t using a password manager, I highly recommend either of these two applications.
A directory of direct links to delete your account from web services.
Today I learned (TIL) what the rc in bashrc means.