AGPL-3.0 가이드
SPDX Identifier: AGPL-3.0-only 또는 AGPL-3.0-or-later
- 소스 형태로 재배포
- 고지 의무 : 소스 코드 내 명시된 저작권/라이선스 정보를 그대로 유지한 상태로 재배포합니다.
- 수정시 의무사항
- 추가/수정한 부분에 AGPL-3.0을 적용합니다.
- 수정 사항에 대한 고지를 포함합니다. (예: 수정일, 수정내용을 주석 형태로 포함)
- 바이너리 형태로 재배포
- 고지 의무 : 오픈소스 고지문을 생성하여 바이너리 재배포 시 동봉합니다.
- 수정시 의무사항
- 추가/수정한 부분에 AGPL-3.0을 적용합니다.
- 수정 사항에 대한 고지를 포함합니다. (예: 오픈소스 고지문에 수정일, 수정내용을 포함)
- 소스 코드 제공 의무
- 바이너리에 해당하는 전체 소스 코드를 제공합니다.
- AGPL-3.0은 파생저작물에 대해서도 AGPL-3.0을 적용하여 소스 코드를 공개할 것을 요구합니다.
- 바이너리 사용자가 공개된 소스 코드로 동일한 바이너리를 만들 수 있는 빌드 환경을 제공합니다.
- 설치 정보 제공 의무 : 바이너리를 User Product와 배포한다면 설치 정보(Installation Information)를 제공합니다.
- 원격 네트워크 상호 작용
- 수정한 버전을 네트워크를 통해 원격의 사용자와 상호 작용하게 사용하는 경우, 원격 사용자가 수정된 버전의 소스 코드를 제공해야 합니다.
AGPL-3.0은 가장 강력한 Copyleft 라이선스입니다. 바이너리 배포뿐만 아니라 네트워크를 통한 SaaS 제공 시에도 소스 코드 공개 의무가 발생합니다. 상용 소프트웨어 및 클라우드 서비스 개발 시 사용에 특히 주의가 필요합니다.
소스 코드 내 라이선스 문구
AGPL-3.0 라이선스 하의 오픈소스는 일반적으로 소스 코드 상단에 다음과 같은 문구가 있습니다.
Copyright (C) <year> <name of author>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
사용 사례별 의무사항
Case 1. 소스 형태로 재배포
AGPL-3.0 라이선스 하의 오픈소스를 소스 형태로 재배포 시 다음 사항을 준수합니다.
1-1 고지 의무
- 저작권 고지 제공
- 보증 부인 제공
- 라이선스 사본 제공
즉, 소스 코드 내 명시된 저작권/라이선스 정보를 그대로 유지한 상태로 재배포합니다.
오픈소스의 소스 코드를 일부 추가/수정하였을 경우, 다음 사항을 준수합니다.
- 추가/수정한 부분에 AGPL-3.0을 적용합니다.
- 수정 사항에 대한 고지를 포함합니다. (예: 수정일, 수정내용을 주석 형태로 포함)
Case 2. 바이너리 형태로 재배포
AGPL-3.0 라이선스 하의 오픈소스를 빌드하여 바이너리 형태로만 재배포 시 다음 사항을 준수합니다.
2-1 고지 의무
- 저작권 고지 제공
- 보증 부인 제공
- 라이선스 사본 제공
이상의 내용을 포함하는 오픈소스 고지문을 생성하여 바이너리 재배포 시 동봉합니다.
오픈소스의 소스 코드를 일부 추가/수정하였을 경우, 다음 사항을 준수합니다.
- 추가/수정한 부분에 AGPL-3.0을 적용합니다.
- 수정 사항에 대한 고지를 포함합니다. (예: 오픈소스 고지문에 수정일, 수정내용을 포함)
2-2 소스 코드 제공 의무
바이너리에 해당하는 소스 코드를 제공합니다. 이때 다음 사항을 준수합니다.
- AGPL-3.0은 파생저작물에 대해서도 AGPL-3.0을 적용하여 소스 코드를 공개할 것을 요구합니다. 아래 내용을 참고하여 AGPL-3.0 하의 오픈소스와 파생저작물의 소스 코드를 공개합니다.
일반적인 AGPL-3.0의 파생저작물 범위는 다음과 같습니다.
- 수정 코드
- AGPL 프로그램과 동일한 프로세스에서 동작하는 Module
- AGPL 프로그램과 링크로 연결한 Library
- AGPL 프로그램을 상속한 Class
다음의 경우 GPL의 파생저작물로 보지 않습니다.
- CD와 같은 매체에 함께 존재하지만 AGPL 프로그램과 전혀 연동하지 않는 독립 프로그램 (#MereAggregation)
- AGPL 프로그램과는 별도의 프로그램으로써 Pipe, Socket, IPC, Command Line Arguments로 AGPL 프로그램과 통신하는 경우
- 바이너리 사용자가 공개된 소스 코드로 동일한 바이너리를 만들 수 있는 빌드 환경을 제공합니다. 여기에는 다음 사항이 포함됩니다.
- Tool chain 정보
- 빌드 스크립트
- 빌드 방법 (README)
소스 코드 대신 서면 약정서(Written Offer)를 제공할 수 있습니다. 여기에는 다음 진술이 포함되어야 합니다.
- 서면 약정서는 제품 판매 후 3년간 유효합니다.
- 누구에게나 제공합니다.
- 비용 청구를 하지 않습니다. (소스 전달을 위해 발생하는 비용 제외)
이후 외부로부터 서면 약정서를 근거로 소스 코드 제공을 요청 받을 경우, 위에서 언급한 바이너리에 해당하는 소스 코드를 제공해야 합니다. 따라서 회사는 제품 판매 후 최소 3년간 소스 코드를 보관해야 합니다.
2-3 설치 정보 제공 의무
바이너리를 User Product와 배포한다면 설치 정보(Installation Information)를 제공합니다.
- User Product : 전자 기기와 같은 Embedded Device
- 설치 정보(Installation Information) : 사용자가 소스 코드를 빌드하여 다시 제품에 설치하기 위해 필요한 모든 정보 및 방법
대부분의 User Product는 보안상의 이유로 설치 정보를 제공하는 것이 불가능합니다. 따라서 User Product로 배포하는 소프트웨어에는 AGPL-3.0의 오픈소스를 사용하지 않아야 합니다.
Case 3. 원격 네트워크 상호 작용
AGPL-3.0 하의 오픈소스를 (1) 수정하고, (2) 수정한 버전이 네트워크를 통해 원격의 사용자와 상호 작용하는 경우:
- 원격 사용자가 수정된 버전의 소스 코드를 다운 받을 수 있도록 네트워크 서버를 제공해야 합니다.
- 여기서의 소스 코드는 위의 “2-2. 소스 코드 제공 의무"에서 요구하는 범위와 동일합니다.
바이너리를 배포하지 않는 네트워크 서버(SaaS, 클라우드 서비스) 개발 시에도 AGPL-3.0 하의 오픈소스를 사용할 경우에는 소스 코드 공개가 필요하기 때문에 가능한 사용하지 않아야 합니다.
GPL-3.0과의 차이점
AGPL-3.0은 GPL-3.0에 네트워크 사용 조항을 추가한 라이선스입니다.
- GPL-3.0: 바이너리 배포 시에만 소스 코드 공개 의무
- AGPL-3.0: 바이너리 배포 + 네트워크를 통한 서비스 제공 시에도 소스 코드 공개 의무
이는 SaaS나 클라우드 서비스로 소프트웨어를 제공하면서 GPL의 소스 코드 공개 의무를 회피하는 것을 방지하기 위한 조항입니다.
라이선스 호환성
주요 라이선스와의 호환성
| 결합 대상 라이선스 | 호환 여부 | 비고 |
|---|---|---|
| MIT | 호환 | 전체 프로젝트가 AGPL-3.0이 됨 |
| Apache-2.0 | 호환 | 전체 프로젝트가 AGPL-3.0이 됨 |
| GPL-3.0 | 호환 | 전체 프로젝트가 AGPL-3.0이 됨 |
| LGPL-3.0 | 호환 | LGPL 부분은 LGPL 유지 가능 |
| Proprietary | 비호환 | 상용 소프트웨어/SaaS에 사용 불가 |
AGPL-3.0은 가장 강력한 Copyleft 조항을 가지고 있습니다. 다른 GPL 계열 라이선스와 결합 시 전체 프로젝트가 AGPL-3.0을 따라야 합니다.
참고 자료
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.