You are on page 1of 20

JERZY'S NOTES

CODE, BUSINESS, STARTUPS, PSYCHOLOGY, & LIFE

THE BEST PGP TUTORIAL FOR MAC OS X, EVER


When I decided to set up my Mac with PGP encrypted communications, I
could not believe how hard it was -- not just to set up the software, but to
understand how to use PGP properly. There was no "PGP for Dummies"
tutorial for OS X on the internet. So I decided to write one. This is my ber
simple, nerd-free tutorial for anyone on Mac. In it, I will:
1. Cover exactly how to install and configure PGP on OS X
2. Demonstrate how to use PGP in real life

Why this tutorial is the best (ever)


1. It works with every app. Unlike other tutorials for PGP, this tutorial
does not care what program you use. If you install or uninstall apps,
PGP will keep working. If you want to encrypt email, you can use any
email program -- Mail.app, Thunderbird, Sparrow, Gmail, Airmail. Or,
you can encrypt something besides email, you can do that too. You can
write an encrypted letter in Word. You can encrypt a formula in Excel.
You can encrypt a URL in Safari. You can encrypt a text with Messages.
You can encrypt a bash command in Terminal. It does not matter.
2. It is Mac friendly. There is a certain way of doing things on a Mac. If
you're not a Mac fan, you won't understand. (That's okay.) Many of the
tutorials I found for OS X are not Mac friendly. Many want you to install
bloated, Windows-like software; or, install questionable add-ons. I've
done the opposite. This PGP tutorial is super Mac friendly. It's PGP,
installed the way Steve Jobs would have done it.
3. Simple. Above all, this PGP setup is simple. Once you understand how
it works, there is nothing you cannot do.
I looked into dozens of ways to set up PGP on my Mac. A lot of them suck

for a plurality of reasons. Across the board, this is the best way for 95% of
use cases.

Step 1: Install the GPGTools GPG Suite for OS X


This step is simple. Visit the GPGTools website and download the GPG Suite
for OS X. Once downloaded, mount the DMG and run the "Install".

Inside the installer, you can stick with all default parameters save one
exception. On the "Installation Type" screen, press "Customize"...

And uncheck the GPGMail package:

Then press "Install."

Step 2: Creating your very own PGP key


When the installer completes, a new app called "GPG Keychain Access" will
launch. A small window will pop up immediately and say: "GPG Keychain
Access would like to access your contacts." Press "OK."

As soon as you press "OK," a second window will pop up that says
"Generate a new key pair." Type in your name and your email address.
Also, check the box that says "Upload public key after generation." Your
window should look like this:

Expand the "Advanced options" section. Incrase the key length to 4096 for
extra NSA-proof'edness. Reduce the "Expiration date" to 1 year from today.
Your window should look like this:

Press "Generate key."


As soon as you press "Generate key," the "Enter passphrase" window will
pop up. Okay, now this is important...

A brief word about your passphrase


The entire PGP encryption will rest on your passphrase. So, first and
foremost... don't use a passphrase that other people know! Pick something
only you will know, and others can't guess. And once you have a
passphrase selected, don't give it to other people.
Second, do not use a password, but rather a passphrase -- a sentence. For
example, "Pennstate55" is less preferable than "I graduated from Penn
State in 1955, ya heard?!" The longer your passphrase, the more secure
your key.
Lastly, make sure your passphrase is something you can remember. Since
it is long, there is a tendancy you might forget it. Don't. The consequences
to that will be dire. Make sure you can remember your passphrase.

Back to Step 2...


Once you decide on your passphrase, type it in the "Enter passphrase"
window. Turn on the "Show typing" option, so you can be 100% sure that
you've typed in your passphrase without any spelling errors. When
everything looks good, press "OK:"

Will be asked to reenter the passphrase. Do it, and press "OK:"

You will then see a message saying, "We need to generate a lot of random
bytes..." Wait for it to complete:

Et voil! Your PGP key is ready to use:

Step 3: Set PGP keyboard shortcuts


Next, you will set up four global keyboard shortcuts in OS X.
Open System Preferences, select the "Keyboard" pane, and go to the
"Shortucts" tab. On the left hand side, select "Services." Then, on the right,
scroll down to the subsection "Text" and look for a bunch of entries that
start with "OpenPGP:"

Go through each OpenPGP entry, unchecking each one and deleting the
keyboard shortcut:

Next, you will enable and set four shortcuts:


Enable "OpenPGP: Decrypt" and set its shortcut to - (i.e., control
option command minus)
Enable "OpenPGP: Encrypt" and set its shortcut to = (i.e., control

option command equals)


Enable "OpenPGP: Sign" and set its shortcut to [ (i.e., control
option command open bracket)
Enable "OpenPGP: Verify" and set its shortcut to ] (i.e., control
option command close bracket)
Your keyboard shortcuts should now look like this:

That's it! You're done setting up PGP with OpenGPG on OS X! Now, we will
discuss how to use what we set up.

Step 4: How to send a secure email


You can encrypt anything with PGP, but most people will want to encrypt
email. So, I will now take a few minutes to explain that. These steps can be
transposed for any kind of encryption, from any app on your computer.
To secure an email in PGP, you will sign and encrypt the body of the
message. You can just sign or just encrypt, but combining both operations
will result in optimum security. Conversely, when you receive a PGPsecured email, you will decrypt and verify it. This is the "opposite" of
signing and encrypting.
Start off by writing your email:

HOME

IL ME

BSITE

TTER

Then, select the entire body of the email and press [ to sign it:

Next, open the GPG Keychain Access app. Press Command-F and type in
the email address of the person you are sending your message to. This will
search the public keyserver for your friend's PGP key:

If your friend has more than one key, select his most recent one:

You will receive a confirmation that your friend's key was successfully
downloaded. You can press "Close:"

You will now see your friend's public key in your keychain:

You can now quit GPG Keychain Access and return to writing the email.
Select the entire body of the email (everything, not just the part you wrote)
and press = to encrypt it. A window will pop up, asking you who the
recipient is. Select the friend's public key you just downloaded, and press
"OK:"

Your entire message is now encrypted! You can press "Send" safely.
N.B. You will only need to download your friend's public key once. After
that, it will always be available in your keychain until the key expires.

Step 4: How to receive a secure email


With our secure message sent, the recipient will now want to unscramble it.
For the sake of this step, I will pretend I am the recipient.
I have recieved the message:

Copy the entire body, from, and including, "-----BEGIN PGP MESSAGE---",
to, and including, "-----END PGP MESSAGE---". Open your favorite text
editor, and paste it:

Now select the entire text, and press - to decrypt the message. You
will immediately be prompted for your PGP passphrase. Type it in and press
"OK:"

You will now see the decrypted message!

Next, you can verify the signature. Highlight the entire text, and press
]. You will see a message confirming the verification:

You can press "OK."

What does encrypt, decrypt, sign, and verify mean?


Now that you know how to sign and encrypt outgoing messages, and
decrypt and verify incoming ones, let us discuss what these terms mean.
Encrypt takes your secret key and the recipient's public key, and scrambles

a message. The scrambled text is secure from prying eyes. The sender
always encrypts.
Decrypt takes an encrypted message, combined with the your secret key
and the sender's public key, and descrambles it. The recipient always
decrypts.
Encrypt and decrypt can be thought of as opposites.
Signing a message lets the recipient know that you (the person with your
email address and public key) acutally authored the message. Signing also
provides additional cryptographic integrity: it ensures that no one has
tampered with the encryption. The sender always signs a message.
Verifying a message is the process of analyzing a signed message, to
determine if the signing is true.
Signing and verifying can be thought of as opposites.

When should I sign? When should I encrypt?


It is unnecessary to sign and encrypt every outgoing email. Well, then:
when should you sign? And when should you encrypt? And when should you
do nothing?
You have three rational choices when you are sending a message:
1. Do nothing. If the contents of the email are public (non-confidential),
and the recipient does not care whether you or an impostor sent the
message, then do nothing. You can send the message as you've sent
messages your whole life: in plain text.
2. Sign, but don't encrypt. If the contents of the email are public (nonconfidential), but the recipient wants assurance that you -- not an
impostor -- actually sent the message, then you should sign but not
encrypt. Simply follow the tutorial above, skipping over the encryption
and decryption steps.
3. Sign and encrypt. If the contents of the email are confidential, sign and
encrypt. It does not matter whether the recipient wants assurance that
you sent the message -- always sign when you encrpt.
I do nothing for 90% of emails I send; security is just not necessary. The
remaining 10% of the time, I sign and encrypt. Whenever there is
confidential information -- business plans, credit card numbers, bank
numbers, social security numbers, corporate strategies, etc. -- I sign and
encrypt. I define confidential information loosely, because I'd rather sign

and encrypt unnecessarily than do nothing and leak sensitive information.


As for the third option, I rarely sign, but do not encrypt. Your profession
may warrant radically different usage of PGP.

Why don't you use PGP MIME attachments? Why don't you use the
Mail.app PGP plugin?
Some PGP nerds prefer sending PGP with attachments (a.k.a., PGP MIME
type), instead of using plain text (a.k.a., PGP INLINE).
Conversely, some PGP n00bs want to know why I don't recommend using a
PGP plugin for their email client (i.e., the Mail.app PGP plugin).
Here's why:
1. Attachments are a pain in the ass.
2. People who use mail plugins for encryption have no idea how they
work; the result is a false sense of security.
3. Inline text works places where attachments don't (the shell, Facebook,
iMessage, etc.).
4. The majority of people who have sent me MIME test emails using the
Mail.app plugins sent undecryptable messages, because they have no
idea what they're doing or how it works.
5. When a plugin generates an attachment and sends it before you can
see what is going on, you have no idea what is happening or if it is
working.
6. Lots of applications and email clients do not have PGP built in, so you
need inline anyway.

Try it out! Email me.


My email address is jerzygangi@gmail.com. Try sending me an encrypted,
signed email. I'll reply.
If my tutorial was helpful, please send me a small donation through PayPal!

Posted on Mar 12, 2014 to GPGTools, OS X, PGP, and Security

Made with Love in Philadelphia. Copyright Jerzy J. Gangi 2011-2015. All rights
Reserved.