Versions Compared
Version | Old Version 16 | New Version 17 |
---|---|---|
Changes made by | ||
Saved on |
Key
- This line was added.
- This line was removed.
- Formatting was changed.
Introduction
From the Git User Manual:
Git is cryptographically secure, but it’s not foolproof. If you’re taking work from others on the internet and want to verify that commits are actually from a trusted source, Git has a few ways to sign and verify work using GPG.
As Ed-Fi source repositories have embraced the Apache License, it is more important than ever that we ensure pull requests and commits are well identified. Although anyone can submit a pull request, we only want to accept the pull request if the contributor has accepted the Contributor License Agreement (CLA). Signing Git commits allows us to both verify the identity of the developer and to verify that the developer has signed the CLA.
Expand | ||
---|---|---|
| ||
Thank you for your interest in the Ed-Fi Alliance (the "Alliance"). In order to clarify the intellectual property license granted with Contributions from any person or entity, the Alliance must have a Contributor License Agreement ("CLA") on file that has been signed by each Contributor, indicating agreement to the license terms below. This license is for your protection as a Contributor as well as the protection of the Alliance and its users; it does not change your rights to use your own Contributions for any other purpose. You accept and agree to the following terms and conditions for Your present and future Contributions submitted to the Alliance. In return, the Alliance shall not use Your Contributions in a way that is contrary to the public benefit or inconsistent with its nonprofit status and bylaws in effect at the time of the Contribution. Except for the license granted herein to the Alliance and recipients of software distributed by the Alliance, You reserve all right, title, and interest in and to Your Contributions. 1. Definitions. "You" (or "Your") shall mean the copyright owner or legal entity authorized by the copyright owner that is making this Agreement with the Alliance. For legal entities, the entity making a Contribution and all other entities that control, are controlled by, or are under common control with that entity are considered to be a single Contributor. For the purposes of this definition, "control" means (i) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the outstanding shares, or (iii) beneficial ownership of such entity. "Contribution" shall mean any original work of authorship, including any modifications or additions to an existing work, that is intentionally submitted by You to the Alliance for inclusion in, or documentation of, any of the products owned or managed by the Alliance (the "Work"). For the purposes of this definition, "submitted" means any form of electronic, verbal, or written communication sent to the Alliance or its representatives, including but not limited to communication on electronic mailing lists, source code control systems, and issue tracking systems that are managed by, or on behalf of, the Alliance for the purpose of discussing and improving the Work, but excluding communication that is conspicuously marked or otherwise designated in writing by You as "Not a Contribution. 2. Grant of Copyright License. Subject to the terms and conditions of this Agreement, You hereby grant to the Alliance and to recipients of software distributed by the Alliance a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license to reproduce, prepare derivative works of, publicly display, publicly perform, sublicense, and distribute Your Contributions and such derivative works. 3. Grant of Patent License. Subject to the terms and conditions of this Agreement, You hereby grant to the Alliance and to recipients of software distributed by the Alliance a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable (except as stated in this section) patent license to make, have made, use, offer to sell, sell, import, and otherwise transfer the Work, where such license applies only to those patent claims licensable by You that are necessarily infringed by Your Contribution(s) alone or by combination of Your Contribution(s) with the Work to which such Contribution(s) was submitted. If any entity institutes patent litigation against You or any other entity (including a cross-claim or counterclaim in a lawsuit) alleging that your Contribution, or the Work to which you have contributed, constitutes direct or contributory patent infringement, then any patent licenses granted to that entity under this Agreement for that Contribution or Work shall terminate as of the date such litigation is filed. 4. You represent that you are legally entitled to grant the above license. If your employer(s) has rights to intellectual property that you create that includes your Contributions, you represent that you have received permission to make Contributions on behalf of that employer, that your employer has waived such rights for your Contributions to the Alliance, or that your employer has executed a separate Corporate CLA with the Alliance. 5. You represent that each of Your Contributions is Your original creation (see section 7 for submissions on behalf of others). You represent that Your Contribution submissions include complete details of any third-party license or other restriction (including, but not limited to, related patents and trademarks) of which you are personally aware and which are associated with any part of Your Contributions. 6. You are not expected to provide support for Your Contributions, except to the extent You desire to provide support. You may provide support for free, for a fee, or not at all. Unless required by applicable law or agreed to in writing, You provide Your Contributions on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. 7. Should You wish to submit work that is not Your original creation, You may submit it to the Alliance separately from any Contribution, identifying the complete details of its source and of any license or other restriction (including, but not limited to, related patents, trademarks, and license agreements) of which you are personally aware, and conspicuously marking the work as "Submitted on behalf of a third-party: [named here]". 8. You agree to notify the Alliance of any facts or circumstances of which you become aware that would make these representations inaccurate in any respect. |
One-Time Setup on Windows
1. Install Gnu Privacy Guard (GPG)
If you use Git Bash, then you already have GPG at path /usr/bin/gpg
.
If you use PowerShell or cmd.exe, then you will need to install GPG. The simplest way to install GPG is with chocolatey:
Code Block |
---|
> choco install -y gpg4win |
Alternately, you can download and install from https://www.gpg4win.org/.
2. Generate a Key
The default key length is 2048 bit. 4096 is even better. You'll be prompted for name and email. You should use the same information that is associated with your GitHub account.
Code Block |
---|
> gpg --default-new-key-algo rsa4096 --gen-key |
Note |
---|
This key will expire after two years. |
3. Configure Git to Always Sign
You will need the key ID for this. In the following example from the Git manual, the id is "E1E474F2023B5ABFF8752630BB4".
Code Block |
---|
> gpg --list-keys C:/Users/jon.doe/AppData/Roaming/gnupg/pubring.kbx ------------------------------------------------ pub rsa4096 2020-05-24 [SC] [expires: 2022-04-22] E1E474F2023B5ABFF8752630BB4 uid [ultimate] Jon Doe <jon.doe@examppppppplllleeeee.com> |
Configure this globally, or set it up one repository at a time by omitting the --global
argument. Additionally, configure the GPG.exe to be used by Git. GPG is usually found at C:\Program Files (x86)\GnuPG\bin\gpg.exe
. In some installations, it might instead be in %LOCALAPPDATA%\Local\Programs\GnuPG\bin\gpg.exe
Code Block |
---|
> git config --global user.signingkey E1E474F2023B5ABFF8752630BB4 > git config --global gpg.program "C:\Program Files (x86)\GnuPG\bin\gpg.exe" > git config --global commit.gpgsign true > git config --global tag.gpgsign true |
Tip |
---|
If you would prefer to take manual control of when to sign a commit or tag, you can skip the the With the configuration settings above, you have no need to add the s/S flag. |
4. Upload the Key to GitHub
Export the key using that same key id from above.
Code Block |
---|
> gpg --armor --export E1E474F2023B5ABFF8752630BB4 |
This will display your PGP Public Key Block. Copy the text, beginning with -----BEGIN PGP PUBLIC KEY BLOCK-----
and ending with -----END PGP PUBLIC KEY BLOCK-----
.
Open https://github.com/settings/keys, click the "New GPGP Key" button, and then paste and save the copied public key.
One-Time Setup on Linux and Mac
Please see GPG2 (GnuGP 2) Guide, then see step 4 above.
One-Time Setup in Windows Sub-system for Linux (WSL)
As the Alliance deepens its use of pure open source systems, including support for running applications in Linux, some development practices might benefit from running on the Windows Sub-system for Linux (WSL). The following notes were written while using Ubuntu and they assume that the Windows instructions above have already been completed.
Pure Linux-developers probably know these commands or can easily follow along.
1. Install Git
See Get started using Git on Windows Subsystem for Linux
2. Copy the Key Created in Windows
To reuse the same key that you already configured in Windows, open Ubuntu and run:
Code Block | ||
---|---|---|
| ||
$ cp /mnt/c/users/john.doe/AppData/Roaming/gnupg ~/.gnupg -r $ rm ~/.gnupg/*.lock |
3. Configure Git to Always Sign
You will need the key ID for this. In the following example from the Git manual, the id is "E1E474F2023B5ABFF8752630BB4".
Code Block | ||
---|---|---|
| ||
$ gpg --list-keys /home/john.doe/.gnupg/pubring.kbx ------------------------------------------------ pub rsa4096 2020-05-24 [SC] [expires: 2022-04-22] E1E474F2023B5ABFF8752630BB4 uid [ultimate] Jon Doe <jon.doe@examppppppplllleeeee.com> |
Configure this globally, or set it up one repository at a time by omitting the --global
argument. Additionally, configure the GPG.exe to be used by Git.
Code Block | ||
---|---|---|
| ||
$ git config --global user.signingkey E1E474F2023B5ABFF8752630BB4 $ git config --global commit.gpgsign true $ git config --global tag.gpgsign true |
4. Configure the GPG Agent
original source of instructions
Create a new gpg-agent.conf
file by entering the following command in your Bash prompt:
Code Block | ||
---|---|---|
| ||
$ cat > ~/.gnupg/gpg-agent.conf <<EOF default-cache-ttl 34560000 max-cache-ttl 34560000 pinentry-program "/mnt/c/Program Files (x86)/GnuPG/bin/pinentry-basic.exe" EOF |
Now restart the GPG Agent. You might need to close the Ubuntu terminal window as well.
Code Block | ||
---|---|---|
| ||
$ gpgconf --kill gpg-agent |
5. Switch to Windows GPG If Needed
The instructions above do not always work. If you get a message like this:
Code Block |
---|
error: gpg failed to sign the data fatal: failed to write commit object |
Then try configuring Git to use the Windows version of gpg, instead of using the WSL copy.
Code Block |
---|
$ git config --global gpg.program "/mnt/c/Program Files (x86)/GnuPG/bin/gpg.exe" |
Practice
For those who are just starting out with using git commit signatures, we've created a simple training repository in Git which you can use to practice:
- Fork the repository and clone it locally.
- Make a small change to the
test.md
file. - Commit it, using the signature process described above.
- Push your commit to your fork.
- Create a pull request back to the main repository.
- Reach out to the Ed-Fi Alliance tech team or a solution architect for help in verifying and accepting the pull request.
Troubleshooting
Need to Sign Previous Commit(s)
If your last commit was not signed, you can use git commit -S --amend --no-edit
to fix it. If you have multiple old commits that now need to be signed, you can try rebasing them and amending. See https://stackoverflow.com/a/54987693/30384.
Error Message: "cannot open '/dev/tty'"
Atlassian SourceTree may have a problem with the instructions above, giving you an error message like:
Code Block |
---|
gpg: cannot open '/dev/tty': Device not configured error: gpg failed to sign the data fatal: failed to write commit object |
To resolve, either Setup GPG to sign commits in SourceTree or disable tty:
Code Block |
---|
echo 'no-tty' >> ~/.gnupg/gpg.conf |
Error Message: "No secret key"
If the following error message occurs after attempting a commit:
Code Block |
---|
gpg: skipped "xxxxxxxxxxxxxxxxxx": No secret key gpg: signing failed: No secret key error: gpg failed to sign the data fatal: failed to write commit object |
Open a Git Bash session and type find the location of gpg on the command line:
Code Block |
---|
# If using separate install $ where gpg C:\Program Files\Git\usr\bin\gpg.exe # If using version that comes with Git-bash $ which gpg /usr/bin/gpg |
Next, set gpg.program to the path returned from the where command:
Code Block |
---|
$ git config --global gpg.program "C:\Program Files\Git\usr\bin\gpg.exe" # Or $ git config --global gpg.program "/usr/bin/gpg" |
Error Message: "No agent running"
On rare occasions the commit signing might fail with a message like this:
Code Block |
---|
$ git commit -m "my commit message" gpg: can't connect to the agent: IPC connect call failed gpg: keydb_search failed: No agent running gpg: signing failed: No agent running error: gpg failed to sign the data fatal: failed to write commit object |
The reason for this failure is not clear. The solution seems to be to run the gpg-agent from the command line, at least temporarily. Assuming you are using Windows, open a new prompt (cmd, PowerShell, or Git-bash - but not a WSL prompt) and run this:
Code Block |
---|
$ gpg-agent --daemon |
Now return to your IDE or other command prompt and re-try the git commit
command. If it is successful, you might be able to return to the second window and Control-C out of the daemon.
Error Message: "Unusable Secret Key"
This likely means that your key has expired and needs to be replaced, following the directions above. You can check the expiration at the command line:
Code Block | ||
---|---|---|
| ||
PS C:\> gpg --list-keys gpg: checking the trustdb gpg: marginals needed: 3 completes needed: 1 trust model: pgp gpg: depth: 0 valid: 3 signed: 0 trust: 0-, 0q, 0n, 0m, 0f, 3u gpg: next trustdb check due at 2024-09-20 C:/Users/<username>/AppData/Roaming/gnupg/pubring.kbx -------------------------------------------------------- pub rsa4096 2021-02-27 [SC] [expired: 2023-02-27] 252F4DBC8A0D31955DA7207A3001A25B6798D8E9 uid [ expired] <...> |
Contents
Table of Contents |
---|