1
0
wiki/FormalSciences/ComputerScience/SoftwareEngineering/1.Collaboration/3.贡献者协议(Contributing).md
2024-10-14 16:48:38 +08:00

105 lines
6.8 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

---
title: 贡献者协议Contributing
description: 本文讨论了开源项目中贡献者协议的重要性比较了CLA和DCO两种协议并提供了贡献者协议的模板。
keywords:
- 贡献者协议
- CLA
- DCO
- 开源协作
tags:
- FormalSciences/ComputerScience
- SoftwareEngineering/Collaboration
- Git
author: 7Wate
date: 2023-06-26
---
开源项目的成功在很大程度上取决于社区的参与和贡献。然而这种参与经常涉及到一些复杂的法律问题尤其是与知识产权有关的问题。为了解决这些问题开源社区引入了两种主要的贡献者协议CLA (Contributor License Agreement) 和 DCO (Developer Certificate of Origin)。这两种协议在法律义务和责任方面有着显著的不同。
## CLA
CLA (Contributor License Agreement) 是开源协议的补充它明确了贡献者和项目所有者之间的法律关系。CLA 协议包括公司级别和个人级别的 CLA公司级别的 CLA 允许一个公司代表其所有员工签署,而个人级别的 CLA 则只针对个人贡献者。
CLA 协议主要涵盖以下几点:
- 签署该 CLA 的主体和贡献的定义;
- 授予著作权给拥有该软件知识产权的公司或组织;
- 专利许可的授予;
- 签署者保证依法有权授予上述许可;
- 签署者确保所有的贡献内容均为原创作品;
- 签署者为贡献内容支持的免责描述;
- 说明贡献者提交非原创作品应该采用的方式;
- 保证在获悉任何方面不准确的事实或情况之时通知签约方。
对于在中国的企业,他们还会在 CLA 协议中加入一些本地化的内容,比如阿里巴巴的 [Alibaba Open Source Individual CLA](https://github.com/aliyun/cla)。
## DCO
DCO (Developer Certificate of Origin) 是由 Linux Foundation 制定的,它并不是一个法律协议,而是一种证明。开源贡献者只需要在提交时签署邮件地址,就相当于确认了他们对提交的贡献拥有相应的权利,并同意该贡献在该项目或涉及的开源许可下公开发布。
DCO 包含以下四点保证:
1. 贡献全部或部分由我创建,我有权根据文件中指明的开源许可提交;
2. 贡献是基于以前的工作,这些工作属于适当的开源许可,无论这些工作全部还是部分由我完成,我有权根据相同的开源许可证(除非我被允许根据不同的许可证提交)提交修改后的工作;
3. 贡献由 1、2、或 3 证明的其他人直接提供给我,而我没有对其进行修改。
4. 我理解并同意该项目和贡献是公开的,并且该贡献的记录(包括我随之提交的所有个人信息,包括我的签字)将无限期保留,并且可以与本项目或涉及的开源许可证保持一致或者重新分配。
## CLA 与 DCO 的比较
下表对比了 CLA 和 DCO 的特性,可以看出两者在法律责任、社区属性、签署方式等方面都有不同。这就需要根据项目的特点和需求来选择合适的贡献协议。
| 特性 | CLA | DCO |
| :----------- | :------------------------------------------------- | :--------------------------------------------------------- |
| 社区属性 | 弱 | 强 |
| 签署方式 | 一次性 | 每次提交时在 commit 信息里追加 `Signed-off-by: email` 信息 |
| 法律责任 | 明确法律义务 | 无声明,用来限制提交者遵守开源 license |
| 是否可自定义 | 公司或组织可自行定义 | 否 |
| 使用案例 | Google、Pivotal、CNCF、阿里巴巴、Apache SkyWalking | GitLab、Chef、Harbor、TiKV |
| 公司属性 | 强,可以签署公司级别的 CLA | 弱 |
在选择合适的贡献协议时不仅要考虑法律问题也要考虑社区的文化和参与者的需求。例如对于大型跨公司开源项目来说CLA 可能更适合因为它可以让项目更加正规并且更符合长期发展的需求。而对于那些更依赖社区的项目来说DCO 由于其简洁和易于理解的优点,可能会是更好的选择。
## 贡献者协议
文件通常被命名为 `CONTRIBUTING.md`,这个文件通常位于项目的根目录中。有一些项目可能会使用不同的文件名,例如 `CONTRIBUTORS.txt``CONTRIBUTE.md`,但是 `CONTRIBUTING.md` 是最常见的约定。
### 中文模板
```markdown
贡献者许可协议
本贡献者许可协议(以下简称“协议”)由签署下列的一方(以下简称“贡献者”)同意,并向[项目名称]授予对由[项目名称]管理的软件项目的某些许可权。本协议自下列最新的签名日期起生效。
1. 定义:
“代码”指的是在此协议下由贡献者交付给[项目名称]的计算机软件代码,无论是以人类可读形式还是机器可执行形式。
2. 版权授予:在此协议的条款和条件下,贡献者特此向[项目名称]和[项目名称]分发的软件的接收者授予永久的,全球性的,非独占的,免费的,免版税的,不可撤销的版权许可,用于复制,准备衍生作品,公开展示,公开表演,再许可,和分发代码及其衍生作品。
贡献者声明贡献者有法律权利授予上述许可。
贡献者名称__________
签名__________
日期__________
```
### 英文模板
```markdown
Contributor License Agreement
This Contributor License Agreement ("Agreement") is agreed to by the party signing below ("Contributor"), and conveys certain license rights to [Project Name] for software projects managed by [Project Name]. This Agreement is effective as of the latest signature date below.
1. Definitions:
"Code" means the computer software code, whether in human-readable or machine-executable form, that is delivered by Contributor to [Project Name] under this Agreement.
2. Copyright Grant: Subject to the terms and conditions of this Agreement, Contributor hereby grants to [Project Name] and to recipients of software distributed by [Project Name], 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 Code and such derivative works.
Contributor represents that Contributor is legally entitled to grant the above license.
Contributor Name: __________
Signature: __________
Date: __________
```