Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Software Licensing: A Minefield Guide
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Андрей Листочкин (Andrey Listochkin)
May 13, 2017
Programming
170
0
Share
Software Licensing: A Minefield Guide
Андрей Листочкин (Andrey Listochkin)
May 13, 2017
More Decks by Андрей Листочкин (Andrey Listochkin)
See All by Андрей Листочкин (Andrey Listochkin)
Everybody Stand Back! I Know Regular Expressions
listochkin
0
210
Command-line scripting with Rust. Wait, what?!
listochkin
0
420
Server Memory - BuildStuff Ukraine 2019
listochkin
0
66
Server Memory - Chernivtsi JS 2019
listochkin
1
160
10 Years Later
listochkin
0
390
Managing Managers - DevTalks iHUB
listochkin
0
76
Time, Numbers, Text
listochkin
1
630
We Make Bots. For Real
listochkin
0
460
Devops for A Busy Developer - XP Days 2016
listochkin
0
190
Other Decks in Programming
See All in Programming
L’IA au service des devs : Anatomie d'un assistant de Code Review
toham
0
210
「効かない!」依存性注入(DI)を活用したAPI Platformのエラーハンドリング奮闘記
mkmk884
0
300
AIエージェントで業務改善してみた
taku271
0
480
Geminiをパートナーに神社DXシステムを個人開発した話(いなめぐDX 開発振り返り)
fujiba
0
140
Go_College_最終発表資料__外部公開用_.pdf
xe_pc23
0
130
煩雑なSkills管理をSoC(関心の分離)により解決する――関心を分離し、プロンプトを部品として育てるためのOSSを作った話 / Solving Complex Skills Management Through SoC (Separation of Concerns)
nrslib
3
530
20260313 - Grafana & Friends Taipei #1 - Kubernetes v1.36 的開發雜記:那些困在 Alpha 加護病房太久的 Metrics
tico88612
0
250
Radical Imagining - LIFT 2025-2027 Policy Agenda
lift1998
0
250
forteeの改修から振り返るPHPerKaigi 2026
muno92
PRO
3
240
今年もTECHSCOREブログを書き続けます!
hiraoku101
0
220
PHPで TLSのプロトコルを実装してみる
higaki_program
0
740
Xdebug と IDE による デバッグ実行の仕組みを見る / Exploring-How-Debugging-Works-with-Xdebug-and-an-IDE
shin1x1
0
340
Featured
See All Featured
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
31
10k
End of SEO as We Know It (SMX Advanced Version)
ipullrank
3
4.1k
A Soul's Torment
seathinner
5
2.6k
How to Get Subject Matter Experts Bought In and Actively Contributing to SEO & PR Initiatives.
livdayseo
0
96
Bash Introduction
62gerente
615
210k
Ethics towards AI in product and experience design
skipperchong
2
250
SEO Brein meetup: CTRL+C is not how to scale international SEO
lindahogenes
1
2.5k
Making the Leap to Tech Lead
cromwellryan
135
9.8k
Six Lessons from altMBA
skipperchong
29
4.2k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
133
19k
WCS-LA-2024
lcolladotor
0
520
Side Projects
sachag
455
43k
Transcript
None
@listochkin
This talk is not a legal advice Talk to your
lawyer
Also: In Ukraine I’m not required to make this disclaimer
<3 Ruby
8 days total
No Ruby Today
JavaScript Bash XML Rust
RustFest 2017 Kyiv
Videos are up!
Software Licensing
OpenSource
Which License to Choose?
MIT
End of Story
GPL MPL Apache Eclipse ICS BSD EU-PL CDDL
Facebook PATENTS file Oracle-Google JDK lawsuit Ubuntu ZFS inclusion OpenSSL
licence change etc.
Hard stuff!
Walkthrough
US EU Ukraine …
Trade Secret Trademark Patent Copyright
Trade Secret
Between you and your employer/partner
Trademark
Unregistered™ Registered®
Linux
Come up with the name Check if it is in
use If not you’re good ® and ™ aren’t required
Patents
Software Patents
de jure illegal in Ukraine de facto legal in the
US thus de facto legal in Ukraine, too!
WTO Agreement on Trade-Related Aspects of Intellectual Property Rights (TRIPS)
162 WTO countries Notable exception: Belarus
Software Patents are here
Copyright
Berne Convention © is not required
Author’s rights vs Copyright
You work at X and write code Ukraine: you are
the (co-)author US: X is an author
© 2010-2016 What’s the deal?
Publication date defines Expiry date
Changed file? New edition
Date is not always current! E.g. content hasn’t changed
You have no right to change website copyright year on
January 1st if site content didn’t change
Licensing & Public Domain
Old works transfer to public domain automatically Government code can
be public domain automatically
Dedicate to public domain Can be illegal in many countries
Germany
Unlicense CC0
Who owns copyright?
WFH Work-for-hire
US if no terms are defined in the contract you
give copyright to the company
Licensing
OpenSource
Free Software Foundation OpenSource Initiative Debian, OpenBSD, Apache
Goal?
1. Just share the code 2. Fame and Recognition 3.
Guarantee contributions 4. Allow double-licensing 5. Force OpenSource
1. Just Share the Code
WTFPL Unlicense CC0
WTFPL
No warranty clause
If your WTFPL code doesn’t work I can sue you
and WIN
Unlicense
Public Domain dedication Illegal in some countries
CC0
Falls back from PD to super-permissive license NOT OSI-approved
OMG WTF?!
Dual Licensing
CC0 + ISC + Apache2
CC0 ICS: permissive Apache2: … + patents
What’s up with patents?
Apache All contributors share patents Only the ones that they
have Ones that are required Common defence pool
Don’t own patents? No risk for you
2. Fame and Recognition
ISC + Apache
ICS ≈ MIT ≈ 2-clause BSD
1. State my name 2. No warranty
Why not BSD? Too many variants
Why not MIT? 1. Also many variants! 2. “Use” may
imply patent grant
ISC is the new MIT default on npm
3. Guarantee contributions
LGPL
C/C++ semantics No equivalence in many languages Best to avoid
File Copyleft
MPL2 EPL CDDL
Big issue: GPL compatibility
GPLv2 GPLv2 or later GPLv3 AGPL AGPL or later AGPLv3
with Classpath Exception with Linking Exception …
MPL2 has it built-in!
CDDL and EPL are incompatible
MPL2 EPL + LGPL2^ + AGPL3^
4. Dual-Licensing
OpenSource + Commercial
OpenCore Crippleware
ExtJS MongoDB SugarCRM …
Where is it Deployed?
Client: GPL Server: AGPL Client-Server: AGPL + Apache/ISC
Why not GPL for servers?
GPL provisions trigger on Distribution
20000 engineers write server code Billions of people use this
code 1 company No distribution
Contractor? Distribution
Employee at a service company? Distribution
Contribution License Agreement
You assign copyright to a project Project decides on licensing
terms
5. Force OpenSource
AGPLv3 GPLv3 GPLv2^
CLA
Do you need a CLA on your project?
YES and NO
Project license doesn’t define the license of contributions!
Inbound != Outbound
GitHub ToS has a “CLA” D.6.
Employees
US An employee assignes copyright to the employer by default
You may want a CLA-like
Linux: Developer Certificate of Origin Berneout Pledge AUTHORS Certificate etc.
Other Concerns
License notice in each file Licences in minified JS Licenses
for all deps AUTHORS file CLA/DSO/Pledge
BG // before GitHub AG // after GitHub
We can do better to ease the life of others
and reduce legal risks
CC0 + ISC + Apache2
“Yes, patents exist, we’re all in this together”
“Yes, use it in your closed-source project”
“Yes, I know you’ll forget to put my name and
license into a final build, and that’s OK”
Take Actions!
1. StackOverflow MIT Add CC0/ISC to your profile
2. Read Your Contracts!
3. Don’t be afraid to dual-licence
1. CC0 + ISC + Apache2 2. ISC + Apache2
3. MPL2 4. … 5. …
Or just use MIT because nobody cares anymore
Stories: Facebook PATENTS file Oracle vs Google OpenSSL license change
Ubuntu ZFS