Skip to content

My Linux and Mac stations config files

Notifications You must be signed in to change notification settings

yevgenykuz/.dotfiles

Repository files navigation

Initial setup and configuration

This is my initial setup procedure of a my development machine.
It supports the following flavours:
  • A home box running Linux Mint >20 machine with Cinnamon, including visual aspects like applets and themes, i/o drivers, cinnamon configuration
  • Minimal procedure suitable for virtual machines
  • Minimal procedure suitable for WSL on windows
  • A home box running MacOS
Perform the steps in the following order.
If used for a virtual machine or WSL, skip SSH and GPG keys creation and start from Install Git.

See Appendix: MacOS.

See Appendix: Linux Mint.

See Appendix: SSH and GPG keys.

# linux:
sudo apt install -y git
# mac:
brew install git
rm -rf ~/.dotfiles
# if you've set up an SSH key and have access to this repository, you can use ssh:
git clone [email protected]:yevgenykuz/.dotfiles.git ~/.dotfiles
# otherwise, use https:
git clone https://github.com/yevgenykuz/.dotfiles.git ~/.dotfiles
# make sure all .sh files have execute permission. If not, give it with:
chmod +x ~/.dotfiles/*.sh
chmod +x ~/.dotfiles/scripts/*.sh
Run and select between a full installation for a desktop environment or a minimal installation for a virtual machine.
WSL or MacOS is detected automatically.

bash ~/.dotfiles/install.sh
# this script may take some time, resulting in multiple requests for sudo password
  • Create an Apple ID, login to apple music once to add shipping and payment addresses (without credit card)
  • Login to App Store, update everything

Install homebrew:

  • Get it (accept xcode cmd tools, type password for sudo): /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
  • Follow instructions to add to path and then test it: brew doctor

Bash and iTerm2:

  • Update bash before running install.sh: brew install bash
  • Install iTerm2: brew install --cask iterm2

Go to "System Preferences":

  • [General] Language & Region > Add your language(s) and update units
  • [General] Date & Time > Set time zone automatically using your current location (enable location services if needed)
  • [General] Sharing > Local hostname > Edit if needed
  • [Appearance] Appearance > Dark
  • [Control Center] Bluetooth > Show in Menu Bar
  • [Control Center] Sound > Always Show in Menu Bar
  • [Control Center] Spotlight > Don't Show in Menu Bar
  • [Privacy & Security] Analytics & Improvments > Disable all
  • [Privacy & Security] Apple Advertising > Disable all
  • [Desktop & Dock] Adjust dock size
  • [Desktop & Dock] Automatically hide and show the Dock
  • [Desktop & Dock] Show suggested and recent apps in Dock - Disable
  • [Desktop & Dock] Shortcuts > Disable all
  • [Desktop & Dock] Hot Corners > Disable all
  • [Displays] Night Shift > Set a custum schedule from 6:00AM to 5:55AM
  • [Touch ID & Password] Setup new fingerprint, use for all
  • [Users & Groups] Disable guest user login
  • [Keyboard] Key Repeat > Fast
  • [Keyboard] Delay Until Repeat > Short
  • [Keyboard] Press fn key to > Show Emoji & Symbols
  • [Keyboard] Keyboard navigation > Enable
  • [Keyboard] Keyboard shortcuts > Disable all
  • [Trackpad] Point & Click > Tap to click
  • [Trackpad] More Gestures > Enable all

Finder:

  • Settings > General > Set default directory to home directory
  • Settings > General > Use windows to open new folders
  • Settings > Sidebar > Edit sidebar items
  • Settings > Advanced > Show all filename extensions
  • View > Show Path Bar
  • Show hidden files, open terminal and: defaults write com.apple.finder AppleShowAllFiles -boolean true; killall Finder;

Screenshot:

  • Change screenshot save location - open the app > Options > Select folder under Save to

iTerm2 (do these after running install.sh):

  • Click in menu bar > Make iTerm2 default Term
  • Settings > General > Selection > Copy to pasteboard on selection
  • Settings > General > Selection > Applications in terminal may access clipboard
  • Settings > General > Closing > Disable all
  • Settings > Appearance > General > Theme > Minimal
  • Settings > Profiles > Other Actions... > Import JSON profiles > import from file in ~/.dotfiles/.local/iterm2-profiles and set as default (Command+Shift+. to show hidden files)
  • Settings > Pointer > General > Three-finger tap emulates middle click
  • Settings > Pointer > General > Focus follows mouse
  • Now restart iterm2 (click the icon in the dock it the window doesn't show up), and then > Window > Save window arrangement
  • Settings > General > Startup > Window restoration policy > Open default window arrangement
  • To allow touch ID with sudo - edit /etc/pam.d/sudo and add auth sufficient pam_tid.so at the top
  • Settings > Advanced > Allow sessions to survive logging out and back in > set to No
  • Restart to apply
  • IntelliJ
  • Slack

Go to "System Settings":

  • [Keyboard] Add keyboard layouts and set switching shortcut to "Alt+Shift"
  • [Preferred Applications] Configure preferred applications
  • [Applets/Extensions] Configure applets and extensions
  • [Desktop] Remove "Computer" and "Home" shortcuts from desktop
  • Complete Linux Mint system report tasks
  • Creation:
ssh-keygen -t rsa -b 4096 -C "[email protected]"
# Accept default file location, and then type a pass phrase
# --> Done
# To use it, copy your public key to system clipboard:
xclip -sel clip < ~/.ssh/id_rsa.pub
# or, if xclip complains about "Error: Can't open display: (null)" just cat the contents and copy manually
cat ~/.ssh/id_rsa.pub
# Paste into target location
  • Deletion:
rm ~/.ssh/id_rsa*
  • Password testing:
# Load it into your SSH agent:
ssh-add
# If it was loaded, unload it:
ssh-add -d
  • MacOS integration:
# Add to macos keychain:
ssh-add --apple-use-keychain ~/.ssh/id_rsa
# Add the following to ~/.ssh/config to persist after reboot
Host *
  ServerAliveInterval 60
  UseKeychain yes
  AddKeysToAgent yes
  IdentityFile ~/.ssh/id_rsa
  • Creation:
gpg --full-generate-key
# Select key kind - RSA and RSA
# Set key size to 4096
# Set key expiration 1y
# Set name to "Yevgeny Kuznetsov"
# Set email to "[email protected]"
# Leave comment empty
# Type a pass phrase
# --> Done (move mouse during key generation)
# To use it, get ID for created key (can be found after "sec   rsa4096/<KEYID>":
gpg --list-secret-keys --keyid-format LONG
# Copy GPG public key to system clipboard:
gpg --armor --export <KEYID> | xclip -sel clip
# or, if xclip complains about "Error: Can't open display: (null)" just show the contents and copy manually
gpg --armor --export <KEYID>
# Paste into target location
  • Current key ID retrieval:
gpg --list-secret-keys --keyid-format LONG
  • Deletion:
# Get current key ID, and then delete the secret key:
gpg --delete-secret-key <KEYID>
# Confirm multiple times
# Delete the public key too:
gpg --delete-keys <KEYID>
  • Password testing:
# Get current key ID, and then try with the key:
echo "Test" | gpg --no-use-agent -o /dev/null --local-user <KEYID> -as - && echo "OK"
  • Key publishing:
# Get current key ID, and upload it to the following key servers:
gpg --keyserver keyserver.ubuntu.com --send-keys <KEYID>
gpg --keyserver keys.openpgp.org --send-keys <KEYID>
gpg --keyserver pgp.mit.edu --send-keys <KEYID>
  • MacOS integration:
# After installing pinentry-mac add the following to ~/.gnupg/gpg-agent.conf (validate with "which pinentry-mac"):
pinentry-program /opt/homebrew/bin/pinentry-mac
# Then run:
gpgconf --kill gpg-agent

yevgenykuz


About

My Linux and Mac stations config files

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published