很多从事开源人可能会注意到有些开源项目要求贡献者在提交 PR 前首先签署 CLA,只有签署了 CLA 之后 PR 才可以合并。
下面列举了开源贡献协议的一些简介:
开源社区的贡献者协议一般分为两种 CLA 和 DCO,这两种协议各有优缺点如下。
特性 | CLA | DCO |
---|---|---|
社区属性 | 弱 | 强 |
签署方式 | 一次性 | 每次提交时在 commit 信息里追加 Signed-off-by: email 信息 |
法律责任 | 明确法律义务 | 无声明,用来限制提交者遵守开源 license |
是否可自定义 | 公司或组织可自行定义 | 否 |
使用案例 | Google、Pivotal、CNCF、阿里巴巴、Apache SkyWalking | GitLab、Chef、Harbor、TiKV |
公司属性 | 强,可以签署公司级别的 CLA | 弱 |
CLA 是 Contributor License Agreement 的缩写,CLA 可以看做是对开源软件本身采用的开源协议的补充。一般分为公司级和个人级别的 CLA,所谓公司级即某公司代表签署 CLA 后即可代表该公司所有员工都签署了该 CLA,而个人级别 CLA 只代表个人认可该 CLA。
因为 CLA 是每个公司或组织自定义的,在细节上可能稍有不同,不过总体都包含以下内容:
对于主体在中国的企业,还加入了一些本地化的内容,如 Alibaba Open Source Individual CLA。
因为 CLA 分别为个人级和公司级,所以对于不同名义签署时需要提供不同的信息。签署个人级 CLA 的时候需要提供个人信息(姓名、地址、邮箱、电话等),签署公司级 CLA 还需要提供公司信息(名称、地址、联系电话、邮箱、传真等);
DCO 是 Developer Certificate of Origin 的缩写,由 Linux Foundation 于 2004 年制定。DCO 最大的优点是可以减轻开发者贡献的阻碍,不用阅读冗长的 CLA 法律条文,只需要在提交的时候签署邮件地址即可。Chef 和 GitLab 已分别于 2016 年和 2017 年从 CLA 迁移到 DCO。
如 CNCF 的 Sandbox 项目 harbor 就是使用的 DCO。
DCO 目前是 1.1 版本,内容很简单,开源项目的贡献者只需要保证以下四点:
Kubernetes 社区中有过讨论将 Kubernetes 贡献者从 CLA 迁移到 DCO,最后 TOC 成员 Tim Hockin 觉得签署 CLA 对于贡献者只需要痛苦一次,每次提交都签署 DCO 是持续的痛苦,因此最后还是坚持使用 CLA。参考Move from CLA to DCO #2649。
2018 年 CNCF 对其托管的项目的 Maintainer 做了调研,从反馈来看,Maintainer 对 DCO 是存在痛点的,并希望 CNCF 投入更多的 PR 和市场力量来对抗具有全职 PR/marketing 的初创公司。
如果为了更注重个人贡献者,考虑社区属性,可以使用 DCO,这样对于开源项目的管理者来说就不用指定复杂的 CLA 了,但是对于大型项目由众多合作方的项目,建议使用 CLA。
阿里巴巴只提供个人级别的 CLA 签署:https://cla-assistant.io/alibaba/weex
CLA 内容见:https://github.com/aliyun/cla
阿里巴巴的 CLA 是参照 Apache CLA 撰写的,最后加上两条补充,协议受中国杭州的法院监管,同时提供双语版本,如中引文版本有冲突以英文版本为准。
Google 的 CLA 也是仿照 Apache CLA 撰写的,Google 开源的一些列项目如 Istio、TensorFlow、Knative 等都是需要签署 Google CLA。
参考:解读:Google Software Grant and Corporate Contributor License Agreement
Pivotal 的 CLA 也是仿照 Apache CLA 撰写的,唯一增加了一点是协议受美国加州法律监管。签署个人级协议的时候需要提供姓名、邮箱、邮寄地址(可选)、国家(可选)、电话(可选),签署公司级别的 CLA 的条款了还增加了一条对于签名者必须有权利代表整个公司,要求的信息也更加详细,包括姓名、邮箱、邮寄地址、国家、电话、公司名称、GitHub 组织、头衔等。参与贡献 Pivotal 主导的 Spring 社区和 CloudFoundry 里的项目需要签署 Pivotal CLA。
如果你的开源项目可能会有公司间合作或者要贡献给基金会,为了防范法律风险,请直接使用 CLA;如果更看重社区内的合作,可以使用 DCO。
最后更新于 2024/12/11