Copyright is a thing, and whoever wrote the code in your repository holds an exclusive copyright over it unless an agreement has been made otherwise.
While git-authorship
does not help with managing copyright agreements from
contributors (see
cla-assistant and its
corresponding GitHub
Action for that
functionality), it does help you clearly identify who your contributors are and
the exact lines of code they wrote.
To support libraries undergoing re-licensing, git-authorship
includes config
files for labelling the licenses under which contributors have shared their code.
-
Clone this repository:
git clone https://github.com/thehale/git-authorship
-
Install Python Poetry
curl -sSL https://install.python-poetry.org | python3 -
-
Create a virtual environment and install dependencies
poetry config virtualenvs.in-project true poetry shell poetry install
-
Clone the repository you wish to analyze into the included
repo
folder. -
Make copies of the files in the
config
folder without thedist
extension. -
Run the analyzer with
make run
- The first run will take a while as it computes an accurate
git blame
for every file in your repository. At the end of the run, a cached blame file will be generated in thebuild
directory to speed up future runs.
- The first run will take a while as it computes an accurate
If you want to include information about the OSS license offered by each
contributor, simply add a line for each author to config/author-licenses.txt
in the following format:
author-name|license-SPDX-id
The author-name
will be matched to the values shown in the generated
authorship report.
A list of SPDX license identifiers can be found here: https://spdx.org/licenses/
If certain files are being attributed to an unexpected author (e.g. if a
contributor copied code from another project, the blame
would show the
contributor instead of the original author), you can manually override the
blame
and licensing information using the config/pseudonyms.txt
file. Use
one line per override in the following format:
target-path|actual-author|actual-email|license-SPDX-id
All files with a file path containing target-path
as a substring will be
attributed to the named actual-author
under the named software license.
A list of SPDX license identifiers can be found here: https://spdx.org/licenses/
Copyright (c) 2022 Joseph Hale, All Rights Reserved
Provided under the terms of the Mozilla Public License, version 2.0
What does the MPL-2.0 license allow/require?
You can use files from this project in both open source and proprietary applications, provided you include the above attribution. However, if you modify any code in this project, or copy blocks of it into your own code, you must publicly share the resulting files (note, not your whole program) under the MPL-2.0. The best way to do this is via a Pull Request back into this project.
If you have any other questions, you may also find Mozilla's official FAQ for the MPL-2.0 license insightful.
If you dislike this license, you can contact me about negotiating a paid contract with different terms.
Disclaimer: This TL;DR is just a summary. All legal questions
regarding usage of this project must be handled according to the
official terms specified in the LICENSE
file.
I believe that an open-source software license should ensure that code can be used everywhere.
Strict copyleft licenses, like the GPL family of licenses, fail to fulfill that vision because they only permit code to be used in other GPL-licensed projects. Permissive licenses, like the MIT and Apache licenses, allow code to be used everywhere but fail to prevent proprietary or GPL-licensed projects from limiting access to any improvements they make.
In contrast, the MPL-2.0 license allows code to be used in any software project, while ensuring that any improvements remain available for everyone.