軟件包資料交換規範
軟件包資料交換規範(Software Package Data Exchange)簡稱SPDX,是軟件材料表(SBOM)的開源標準[2] 。SPDX可以說明軟件元件、軟件特許、版權、安全參考資料以及其他有關軟件的元數據[3],其原始的設計目的是要提昇特許條款的相容性[4],之後也增加了額外的使用例,像是供應鏈的透明度以及安全性[5]。SPDX是由Linux基金會主持,由社群驅動的SPDX計劃所撰寫。
狀態 | 已發佈 |
---|---|
首次出版 | 2011年8月 |
最新版本 | 2.3 2022年11月 |
預覽版本 | 3.0 RC[1] 2023年5月16日 |
組織 | Linux基金會 |
委員會 | SPDX Project |
領域 | 軟件材料表 |
特許條款 | CC-BY-3.0 |
縮寫 | SPDX |
網站 | spdx |
SPDX標準目前已到2.3版[6]。
結構
編輯SPDX標準定義了軟件材料表的檔案,其中包括了有關軟件的SPDX元數據。此檔案可以用JSON、YAML、RDF/XML、tag-value及試算表的形式表示。每一份SPDX檔案會敘述一個或多個元件,可能是軟件包、特定的檔案,或是檔案的某一部份。每一個元件都有唯一的識別碼,因此各元件可以互相參照[7]。
歷史
編輯SPDX規格的第1版是在2011年8月發佈的,原始的設計目的是要簡化軟件特許相容確認[4],不過後續的版本加入了可以用在其他用途的功能,例如可以包括已知軟件漏洞的參考資訊[8]。近期的SPDX已符合美國國家電信暨資訊管理局(NTIA)提出的「軟件材料表中的基本元素」[9]。
SPDX 2.2.1於2020年10月提交到國際標準化組織,在2021年8月發行,成為ISO/IEC 5962:2021 Information technology — SPDX® Specification V2.2.1[10][11]。
特許條款語法
編輯特許條款的識別方式為其完整名稱(例如Mozilla Public License 2.0")以及較短的名稱(例如MPL-2.0)。
特許條款可以用運算子AND
或OR
組合,也可以加上分組(
, )
。
例如(Apache-2.0 OR MIT)
表示可以選擇Apache-2.0
(Apache特許條款)或MIT
(MIT特許條款)。而(Apache-2.0 AND MIT)
表示這二個都要符合。
也可使用"+"運算子,配合特許條款使用,表示也可以使用該特許條款較新的版本。例如Apache-1.1+
表示Apache-1.1
、Apache-2.0
、或是更新的版本都可以適用。
SPDX在軟件特許條款的地方,準確的敘述其特許條款。SPDX不打算將特許條款分類,例如將類似BSD特許條款的特許條款分類成"BSD-like"[12]。
歐洲聯盟委員會在2020年發行了Joinup Licensing Assistant[13],可以在超過50種的特許條款之間比較及選擇,可以使用其SPDX識別符以及完整名稱。
已不使用的特許條款識別符
編輯GNU家族的特許條款(例如GNU GPLv2)有選項可以延伸到更新的版本。但對於SPDX表示法,就無法確定GPL-2.0
是指「只有GPL 2.0版」還是「GPL 2.0版或更新版本」[14]。因此,自從SPDX 3.0版的特許條款列表開始,GNU家族的特許條款有新的名稱[15]。GPL-2.0-only
表示「只有GPL 2.0版」,而GPL-2.0-or-later
表示「GPL 2.0版或更新版本」。
使用
編輯特許
編輯SPDX特許條款識別符可以加在原始碼檔案的最前面,用短的字串準確的說明使用的特許條款。SPDX-License-Identifier
語法由Das U-Boot在2013年提出,在2017年成為SPDX 2.1版中的一部份。歐洲自由軟件基金會提出了REUSE,是可以檢查註解,快速的取出特許條款資訊的工具[16]。
SPDX特許條款識別符也用在許多的軟件套件管理系統中,例如Npm[17]、Python[18]及Rust cargo[19]。Fedora Linux裏RPM程式包元數據使用SPDX特許條款識別符,取代較早期使用的Callaway系統[20]。Debian用的則是另一個略有不同的特許條款規格[21]。
相關條目
編輯參考資料
編輯- ^ SPDX Announces 3.0 Release Candidate with New Use Cases. Software Package Data Exchange (SPDX). 16 May 2023 [2024-01-04]. (原始內容存檔於2024-01-04).
- ^ Stewart, Kate. SPDX: It's Already in Use for Global Software Bill of Materials (SBOM) and Supply Chain Security. Linux Foundation. May 25, 2021 [2021-08-13]. (原始內容存檔於2022-08-31).
- ^ Survey of Existing SBOM Formats and Standards (PDF). National Telecommunications and Information Administration: 9. October 25, 2019 [2021-08-13]. (原始內容存檔 (PDF)於2024-02-13).
- ^ 4.0 4.1 Bridgwater, Adrian. Linux Foundation eases open source licensing woes. Computer Weekly. August 19, 2011 [2021-08-13]. (原始內容存檔於2021-11-30).
- ^ Rushgrove, Gareth. Advancing SBOM standards: Snyk and SPDX. June 16, 2021 [2021-08-14]. (原始內容存檔於2024-01-04).
- ^ SPDX Current version. spdx.dev. [2022-11-22]. (原始內容存檔於2023-09-09).
- ^ SPDX and NTIA Minimum Elements for SBOM HOWTO. spdx.github.io. [2024-01-04]. (原始內容存檔於2024-01-04).
- ^ The Linux Foundation's Open Compliance Initiative Releases New SPDX Specification. Linux Foundation. October 4, 2016 [2021-12-01]. (原始內容存檔於2022-05-26).
- ^ The Minimum Elements For a Software Bill of Materials (SBOM) (PDF). National Telecommunications and Information Administration. [2021-12-01]. (原始內容存檔 (PDF)於2024-04-05).
- ^ ISO/IEC 5962:2021 Information technology — SPDX® Specification V2.2.1. iso.org. [2021-12-01]. (原始內容存檔於2024-02-27).
- ^ Bernard, Allen. SPDX becomes internationally recognized standard. TechRepublic. September 9, 2021 [2021-12-01]. (原始內容存檔於2023-03-23).
- ^ Odence, Phil. The Software Package Data Exchange (SPDX) Format. Dr Dobb's. 2010-06-23 [2012-08-31].
- ^ Joinup Licensing Assistant. [31 March 2020]. (原始內容存檔於2020-09-08).
- ^ Richard Stallman. For Clarity's Sake, Please Don't Say "Licensed under GNU GPL 2"!. GNU. [2018-05-24]. (原始內容存檔於2024-04-07).
- ^ Jilayne Lovejoy. License List 3.0 Released!. spdx.dev. 5 January 2018 [2021-09-02]. (原始內容存檔於2018-01-05).
- ^ Solving License Compliance at the Source: Adding SPDX License IDs - Linux Foundation. www.linuxfoundation.org. [2024-01-09]. (原始內容存檔於2024-02-08) (英語).
- ^ package.json | npm Docs. docs.npmjs.com. [2024-01-09]. (原始內容存檔於2024-03-06) (英語).
- ^ PEP 639 – Improving License Clarity with Better Package Metadata | peps.python.org. peps.python.org. [2024-01-09]. (原始內容存檔於2024-02-05).
- ^ The Manifest Format - The Cargo Book. doc.rust-lang.org. [2024-01-09]. (原始內容存檔於2019-08-26).
- ^ License: field in Spec File. Fedora Legal Documentation. [30 July 2023]. (原始內容存檔於2024-03-24).
- ^ Machine-readable debian/copyright file. www.debian.org. [2024-01-09]. (原始內容存檔於2024-04-07).
外部連結
編輯- SPDX on the ISO website (頁面存檔備份,存於互聯網檔案館)
- Linux Foundation Open Compliance Program (頁面存檔備份,存於互聯網檔案館)
- Nathan Willis: A SPDX case study (頁面存檔備份,存於互聯網檔案館) LWN.net