Pulp Licensing FAQ » History » Sprint/Milestone 7
bmbouter, 02/28/2019 10:32 PM
1 | 1 | bmbouter | # Pulp3 Licensing FAQ |
---|---|---|---|
2 | |||
3 | 4 | bmbouter | ### What license does pulpcore and pulpcore-plugin use? |
4 | 1 | bmbouter | |
5 | The pulpcore and pulpcore-plugin packages both extend their license to users a "GPLv2 or later". |
||
6 | |||
7 | 6 | bmbouter | https://github.com/pulp/pulpcore/blob/master/COPYRIGHT#L5 |
8 | 1 | bmbouter | https://github.com/pulp/pulpcore-plugin/blob/master/COPYRIGHT#L5 |
9 | |||
10 | So a plugin can choose the license they want to use as either GPLv2 or GPLv3. |
||
11 | 5 | bmbouter | |
12 | ### Why would Pulp3 Plugins be affected by the license of the pulpcore-plugin package? |
||
13 | |||
14 | The GPL FAQ states that subclassing as a mechanism is creating a derivative work. https://www.gnu.org/licenses/gpl-faq.en.html#OOPLang |
||
15 | |||
16 | Coupled with the fact that the plugin API uses subclassing as a mechanism ( https://docs.pulpproject.org/en/pulpcore-plugin/nightly/plugin-writer/concepts/index.html#subclassing ) plugin code must be a "GPLv2 or later" compatible license. |
||
17 | 2 | bmbouter | |
18 | 1 | bmbouter | ### Why does the pulpcore package matter? Plugin code is only imported from pulpcore-plugin, not pulpcore? |
19 | |||
20 | For technical reasons, many of the objects in pulpcore-plugin are imported and offered from the pulpcore asset itself. There are enough of these cases that offering pulpcore and pulpcore-plugin as separate license types is infeasible. |
||
21 | |||
22 | 2 | bmbouter | ### Can I combine GPLv2 or GPLv3 licensed code with other license types? |
23 | 1 | bmbouter | |
24 | 2 | bmbouter | It depends on if the other license is "compatible" with GPLv2 or GPLv3. https://www.gnu.org/licenses/gpl-faq.html#WhatDoesCompatMean |
25 | |||
26 | ### Can I combine GPLv2 or GPLv3 licensed code with Apache 2.0 licensed code? |
||
27 | |||
28 | 7 | bmbouter | Yes, you can combine GPLv3 and Apache 2.0 licensed code together into a larger program. You can do this because Apache v2 is compatible with GPLv3: https://www.gnu.org/licenses/license-list.html#apache2 |
29 | 2 | bmbouter | |
30 | 7 | bmbouter | You cannot combine GPLv2 and Apache 2.0 licensed code also as stated here: https://www.gnu.org/licenses/license-list.html#apache2 |