오픈소스 정책

1. 목적

(1) 정책의 목적

이 정책은 OOO 주식회사(이하 “회사"라 함)에서 소프트웨어 개발, 서비스, 배포에 관여하는 전체 조직이 올바르게 오픈소스 소프트웨어(이하 “오픈소스"라 함)를 활용하기 위해 다음과 같은 원칙을 제공합니다.

  1. 오픈소스 라이선스 컴플라이언스 원칙
  2. 오픈소스 보안 보증 원칙
  3. 외부 오픈소스 프로젝트로의 기여 원칙
  4. 사내 프로젝트를 오픈소스로 공개하기 위한 원칙

이러한 원칙은 회사의 모든 프로그램 참여자가 오픈소스의 가치를 이해하고, 오픈소스를 올바르게 사용하며, 오픈소스 커뮤니티에 기여하기 위한 방법을 제공합니다.

이 정책은 ISO/IEC 5230(오픈소스 라이선스 컴플라이언스)과 ISO/IEC 18974(오픈소스 보안 보증)의 요구사항을 충족하도록 설계되었습니다.

회사의 모든 프로그램 참여자는 사내 위키의 다음 링크에서 오픈소스 정책을 확인할 수 있습니다 : [internal_link]

(2) 미준수 시 영향

이 정책을 준수하지 않는다면 다음과 같은 상황이 발생할 수 있습니다.

  • 외부로부터 오픈소스 라이선스 준수 요구를 받을 수 있습니다.
  • 회사가 개발한 소스 코드를 원치 않게 공개해야 할 수 있습니다.
  • 오픈소스 저작권자로부터 법적 소송을 제기당할 수 있습니다.
  • 저작권 침해 및 계약 위반으로 벌금을 부과받거나, 공급 소프트웨어 배포 중지 명령을 받을 수 있습니다.
  • 회사 평판이 손상될 수 있습니다.
  • 공급업체와의 계약 위반이 되어 손해배상 청구를 받을 수 있습니다.
  • 알려진 취약점 또는 새로 발견된 취약점으로 인해 심각한 보안 사고에 노출되어 회사에 막대한 손해를 입힐 수 있습니다.

이러한 이유로 회사는 오픈소스 정책의 위반을 심각하게 간주하며, 이를 위반하는 프로그램 참여자나 조직은 징계 절차에 처할 수 있습니다.

(3) 프로그램 참여자의 기여 방법

회사의 모든 프로그램 참여자는 이 정책의 근거와 내용을 이해하고 필요한 활동을 충실히 수행함으로써 정책의 효과 및 회사의 오픈소스 라이선스 컴플라이언스와 보안 보증 수준 향상에 기여할 수 있습니다. 프로그램 참여자는 오픈소스 정책, 관련 프로그램 목표, 효과적인 프로그램이 되기 위한 참여자의 기여 방법, 그리고 프로그램 요구사항을 준수하지 않을 경우의 영향을 인식해야 합니다.

2. 적용 범위

이 정책은 다음 세 부분에 적용됩니다:

  1. 회사가 외부로 제공하거나 배포하는 모든 공급 소프트웨어에 적용됩니다. 단, 오픈소스를 내부 사용 목적으로만 사용하는 것은 이 정책의 범위에 포함되지 않습니다.
  2. 프로그램 참여자가 외부 오픈소스 프로젝트에 기여할 때 적용됩니다.
  3. 내부 코드를 오픈소스로 공개할 때 적용됩니다.

적용 범위는 회사의 비즈니스 환경에 맞추어 변경할 수 있습니다. 특히, 오픈소스 프로그램 매니저는 지속적인 효과를 보장하기 위해 이 정책이 적용되지 않고 외부로 배포되거나 서비스되는 공급 소프트웨어가 있는지 월 1회 이상 조사합니다. 이를 측정하여 1건이라도 발견 시 적용 범위를 변경해야 하는 기준으로 삼습니다.

적용 범위를 변경하기 위한 절차는 다음과 같습니다:

  1. 오픈소스 프로그램 매니저는 신규사업, 조직개편 등 회사의 비즈니스 환경 변화에 따라 정책의 적용 범위 변경이 필요하다고 판단할 경우, 이를 위한 제안을 OSRB(Open Source Review Board)에 제출합니다.
  2. OSRB에서는 적절한 수준의 적용 범위 변경을 승인합니다.
  3. OSRB는 오픈소스 정책을 수정하여 정책의 적용 범위를 변경합니다.

오픈소스 프로그램 매니저는 지속적으로 월 1회 이상 적용 범위를 개선하기 위해 검토, 업데이트 및 검사 이력을 Jira Issue Tracker를 활용하여 문서화합니다.

3. 용어

  • 공급 소프트웨어: 조직이 제3자(예: 다른 조직 또는 개인)에게 배포하는 소프트웨어입니다.

  • 프로그램: 조직의 오픈소스 라이선스 컴플라이언스 및 보안 보증 활동을 구성하는 정책, 프로세스 및 인력의 집합입니다.

  • 프로그램 참여자: 공급 소프트웨어를 정의하고, 이에 기여하거나 준비할 책임이 있는 모든 조직 구성원 혹은 계약자입니다. 여기에는 소프트웨어 개발자, 릴리스 엔지니어, 품질 엔지니어, 제품 마케팅 및 제품 관리자 등이 포함될 수 있습니다.

  • SBOM (Software Bill of Materials): 소프트웨어 패키지에 대한 정보 교환을 위한 구조화된 형식의 정보입니다. 여기에는 이름, 버전, 출처, 라이선스, 저작권 및 알려진 취약점 정보가 포함될 수 있습니다.

  • 컴플라이언스 산출물: 컴플라이언스 프로그램의 결과물을 나타내며 공급 소프트웨어와 함께 제공해야 하는 산출물의 모음입니다. 여기에는 저작자 고지, 소스 코드, 라이선스 사본, 저작권 고지, 수정 내용 고지, 서면 청약(Written Offer) 등이 포함될 수 있습니다.

  • 식별된 라이선스: 공급 소프트웨어에 포함된 오픈소스 컴포넌트를 식별하기 위한 적절한 방법으로 식별된 일련의 오픈소스 라이선스 집합입니다.

  • 오픈소스: Open Source Initiative에서 만든 Open Source Definition 또는 Free Software Foundation에서 만든 Free Software Definition을 충족하는 라이선스가 하나 이상 적용된 소프트웨어입니다.

  • 알려진 취약점: 오픈소스 소프트웨어 컴포넌트에서 이전에 발견된 공개적으로 사용 가능한 보안 취약점입니다.

  • 새로 발견된 취약점: 오픈소스 소프트웨어 컴포넌트에서 새로 발견된 공개적으로 사용 가능한 보안 취약점입니다.

  • 보안 보증: 시스템이 보안 모범 사례에 대한 요구사항을 충족하고 알려진 취약점에 대해 복원력이 있다는 확신입니다.

  • 검증 자료: 규격의 주어진 요구사항이 충족되었음을 입증하는 자료입니다.

4. 역할, 책임 및 역량

정책의 효과를 보장하기 위해 다음과 같이 역할과 책임 및 각 역할의 담당자가 갖추어야 할 역량을 정의합니다.

각 역할의 담당 조직/담당자와 필요 역량 수준은 [부록 1. 담당자 현황]에서 정의합니다.

  • 오픈소스 프로그램 매니저는 회사의 비즈니스 상황에 맞추어 주기적으로 명단을 업데이트합니다.
  • 각 역할에 대한 담당 조직의 장은 조직 내 담당자를 지정하고, 담당자가 역할을 충실하게 수행할 수 있는 적절한 시간과 예산을 할당합니다.
    • 각 역할의 담당자는 자신이 역할을 수행하면서 적절한 지원이 되지 않는다면 오픈소스 프로그램 매니저에게 문제를 제기해야 합니다.
    • 오픈소스 프로그램 매니저는 해당 조직장과 문제 해결을 논의합니다. 적절하게 해결되지 않는다면, 오픈소스 프로그램 매니저는 OSRB에 문제 해결을 요청할 수 있습니다.
    • OSRB는 상위 조직의 장에게 문제를 공유하고 해결을 요청합니다.

(1) OSRB

OSRB(Open Source Review Board)는 회사의 오픈소스 관리를 위해 오픈소스 프로그램 매니저와 법무팀, 특허팀, 개발팀, 인프라팀 등 관련 조직의 책임자로 구성된 협의체입니다.

  • OSRB는 오픈소스 관리를 위한 정책과 프로세스를 수립하고, 이를 수행하기 위한 회사 내의 역할과 책임을 정의합니다.
  • OSRB는 매년 정기적으로 검토하여 정책과 프로세스를 개선합니다. 모든 개선 과정은 문서화하여 기록합니다.
    • OSRB는 회사의 프로세스 수행 성과와 미흡한 부분, 모범 사례를 분석하고 비즈니스 환경을 반영하여 항상 현행화합니다.
    • 오픈소스 라이선스 컴플라이언스를 위한 정책과 프로세스는 오픈소스 프로그램 매니저가 책임을 갖고 관리합니다.
    • 오픈소스 보안 보증을 위한 정책과 프로세스는 보안 담당이 책임을 갖고 관리합니다.
  • OSRB는 회사 내 오픈소스 이슈 발생 시, 해결 방안을 논의하고, 대응책을 마련합니다.
  • OSRB는 필요 시, 임원진에 이슈를 보고하여 리스크 완화 방안에 대한 피드백을 받습니다.

(2) 오픈소스 프로그램 매니저

오픈소스 프로그램 매니저는 회사의 오픈소스 프로그램에 대한 총괄 책임을 담당합니다. 오픈소스를 사용한 공급 소프트웨어의 오픈소스 관리 활동을 보장하기 위해 다음 사항에 대한 책임이 있습니다.

  • 오픈소스 라이선스 컴플라이언스를 위해 필요한 역할을 정의하고, 각 역할을 책임질 담당 조직 및 담당자를 지정합니다. 필요 시 OSRB와 협의합니다. 오픈소스 보안 보증을 위한 내부 책임은 보안 담당자가 할당합니다.
  • 오픈소스 교육을 주관하고 평가합니다.
  • OSRB의 의장을 맡아서 활동을 지휘합니다.
  • 외부로부터의 오픈소스 사용 및 라이선스 컴플라이언스 관련 문의 및 요청에 대응합니다.
  • 오픈소스 사용 요청을 검토하고 승인합니다.
  • SBOM(Software Bill of Materials) 기록을 유지합니다.
  • 프로그램 참여자가 오픈소스 관련 자문을 받는 방법을 제공합니다.
  • 오픈소스 고지 및 소스 코드 공개를 위한 저장소를 유지합니다.

(3) OSPO

OSPO(Open Source Program Office)는 회사 안팎으로 오픈소스 활동의 성장을 위해 지원하고 육성하는 역할을 합니다.

  • 외부 오픈소스 프로젝트로의 코드 기여를 위한 가이드를 제공합니다.
  • 사내 프로젝트를 오픈소스로 공개하기 위한 가이드를 제공합니다.
  • 오픈소스 포털을 개발하고 운영합니다.
  • 오픈소스 도구를 개발하고 선택합니다.
  • 오픈소스 프로젝트 이벤트를 후원합니다.
  • 오픈소스 커뮤니티와의 관계를 관리합니다.

(4) 법무 담당

법무 담당은 오픈소스 라이선스와 의무를 해석하는 등 오픈소스 활용 과정에서 발생할 수 있는 법적 위험과 완화 방안에 대한 자문을 제공합니다.

  • 프로그램 참여자가 오픈소스 라이선스 컴플라이언스 이슈에 대한 문의를 할 수 있는 합리적인 방법을 제공합니다.
  • 호환되지 않는 오픈소스 라이선스로 인한 충돌을 포함하여 라이선스 및 지식재산권 문제에 대해 자문을 제공합니다.
  • 외부 오픈소스 프로젝트로의 기여 시 오픈소스 라이선스, CLA(Contributor License Agreement) 등 필요한 법적 사항을 검토합니다.
  • 이슈가 첨예한 경우, 오픈소스 전문 변호사를 보유한 외부 법무 법인에 자문을 요청합니다.

(5) IT 담당

IT 담당은 오픈소스 분석 도구를 운영하고 자동화하여 모든 공급 소프트웨어에 대해 오픈소스 분석이 원활히 수행되도록 시스템을 구축합니다.

  • 오픈소스 분석 도구를 운영합니다.
  • DevOps 환경과 통합하여 오픈소스 분석을 자동화합니다.
  • 모든 공급 소프트웨어를 대상으로 오픈소스 분석이 수행되도록 시스템과 프로세스를 구축합니다.
  • 모든 공급 소프트웨어에 대한 SBOM을 확보하고 유지합니다.

(6) 보안 담당

보안 담당은 오픈소스 보안 취약점 분석 도구를 운영하여 모든 공급 소프트웨어에 대해 보안 취약점 분석이 원활히 수행되도록 시스템을 구축합니다.

  • 오픈소스 보안 보증을 성공할 수 있도록 각 업무에 대한 책임을 할당합니다.
  • 오픈소스 보안 취약점 분석 도구를 운영합니다.
  • DevSecOps 환경과 통합하여 오픈소스 보안 취약점 분석을 자동화합니다.
  • 모든 공급 소프트웨어를 대상으로 오픈소스 보안 취약점 분석이 수행되도록 시스템과 프로세스를 구축합니다.
  • 프로그램 참여자가 알려진 취약점 또는 새로 발견된 취약점에 대한 문의를 할 수 있는 합리적인 방법을 제공하고, 취약점 해결을 위해 필요 시 외부 전문 기술 자문을 이용합니다.

(7) 개발 문화 담당

개발 문화 담당은 사내 개발자들이 오픈소스를 적극적으로 활용하고 사내외 커뮤니티에 참여하여 선진 개발 문화를 습득할 수 있도록 지원합니다.

  • 오픈소스 커뮤니티로의 참여를 장려합니다.
  • 활발한 외부 오픈소스 프로젝트 활동을 사내 성과로 인정할 수 있는 문화를 조성합니다.
  • 오픈소스 개발자들에게 매력 있는 회사로 인식될 수 있는 개발 문화를 만들어갑니다.

(8) 품질 담당

QA 등 품질을 담당하는 조직은 공급 소프트웨어 배포 시 오픈소스 라이선스 의무를 적절히 수행하였는지 확인합니다.

  • 개발 프로세스 단계에 맞추어 오픈소스 관리 활동이 수행되었는지 확인합니다.
  • 오픈소스 라이선스가 요구하는 대로 컴플라이언스 산출물을 생성하였는지 확인합니다.
  • 공급 소프트웨어 배포 시 오픈소스 고지문과 공개할 소스 코드를 함께 제공하는지 확인합니다.
  • 이슈가 있으면 소프트웨어 개발/배포 조직에 통보하여 즉시 이슈를 수정하도록 안내합니다.

5. 교육, 평가 및 인식

프로그램 참여자의 역량과 인식을 보장하기 위해 다음과 같은 교육, 평가 및 인식 제고 활동을 수행합니다:

(1) 오픈소스 라이선스 컴플라이언스 교육

  • 모든 프로그램 참여자는 [Learning Portal]에서 제공하는 오픈소스 라이선스 컴플라이언스 교육을 이수해야 합니다.
  • 교육 내용에는 오픈소스 정책, 라이선스 의무 사항, 컴플라이언스 프로세스 등이 포함됩니다.

(2) 오픈소스 보안 보증 교육

  • 모든 프로그램 참여자는 [Learning Portal]에서 제공하는 오픈소스 보안 보증 교육을 이수해야 합니다.
  • 교육 내용에는 알려진 취약점 및 새로 발견된 취약점 관리, 보안 테스트, SBOM 관리 등이 포함됩니다.

(3) 역량 평가

  • 각 역할에 대해 정의된 필요 역량을 바탕으로 프로그램 참여자의 역량을 정기적으로 평가합니다.
  • 평가 결과에 따라 추가 교육이나 지원이 필요한 경우 적절한 조치를 취합니다.

(4) 인식 제고 활동

  • 정기적인 뉴스레터, 워크샵, 세미나 등을 통해 프로그램 참여자의 오픈소스 라이선스 컴플라이언스 및 보안 보증에 대한 인식을 제고합니다.
  • 프로그램의 목표, 각 참여자의 역할의 중요성, 미준수 시의 영향 등에 대한 이해를 증진시킵니다.

모든 교육 이력, 평가 결과 및 인식 제고 활동 참여 기록은 [Learning Portal]에 최소 3년간 보관합니다. 이를 통해 프로그램 참여자가 오픈소스 정책, 프로세스, 그리고 자신의 역할과 책임을 충분히 이해하고 있음을 보장합니다.

오픈소스 프로그램 매니저는 연 1회 이상 교육 내용과 평가 방식을 검토하고 필요시 업데이트하여, 항상 최신의 오픈소스 동향과 조직의 요구사항을 반영할 수 있도록 합니다.

6. 오픈소스 사용

오픈소스를 사용하여 공급 소프트웨어를 개발하고 배포하려면 각 오픈소스 라이선스가 요구하는 의무 사항을 준수해야 합니다. 이를 위한 활동을 오픈소스 라이선스 컴플라이언스라고 합니다.

올바른 오픈소스 라이선스 컴플라이언스 활동과 보안 보증을 위해 소프트웨어 개발/배포 조직은 다음 사항을 준수하고 모든 과정은 Jira Tracker에 기록하여 보존합니다.

(1) 오픈소스 식별 및 라이선스 의무 사항 검토

오픈소스를 공급 소프트웨어 개발에 도입 시, 먼저 오픈소스 라이선스가 무엇인지 식별하고, 라이선스가 요구하는 의무 사항을 검토하고 확인합니다.

회사의 [오픈소스 라이선스 가이드]에는 주요 오픈소스 라이선스 목록이 포함되어 있으며, 라이선스마다 다음의 배포 형태별 요구하는 의무사항을 구분하여 설명합니다.

  • 바이너리 형태
  • 소스 형태
  • 강한/약한 Copyleft
  • SaaS 기반 제공
  • 수정 여부
  • 저작자 표시 요구 오픈소스 포함 등

소프트웨어 개발/배포 조직은 오픈소스 라이선스 의무 검토 시 이 가이드를 참고할 수 있습니다. 이 가이드에서 언급하지 않는 오픈소스 라이선스의 검토가 필요할 경우, 오픈소스 프로그램 매니저에게 문의합니다.

(2) 오픈소스 라이선스 고려 설계

오픈소스의 결합 관계를 파악하여 자사의 코드가 오픈소스 라이선스의 영향을 받지 않도록 소프트웨어 아키텍처를 설계합니다.

회사의 [오픈소스 라이선스 가이드]에서는 오픈소스 라이선스별 소스 코드 공개 범위 및 자사 코드의 공개를 방지하기 위한 설계 방법을 설명합니다.

(3) 오픈소스 컴플라이언스 산출물 생성

오픈소스 라이선스 컴플라이언스 활동의 가장 기본은 공급 소프트웨어에 포함된 오픈소스 현황을 파악하는 것입니다. 이는 바로 오픈소스 라이선스 컴플라이언스의 핵심인 오픈소스 라이선스 요구사항을 올바르게 충족하기 위해서입니다. 즉, 공급 소프트웨어에 포함된 오픈소스에 대한 컴플라이언스 산출물 세트를 생성해야 합니다.

오픈소스 컴플라이언스 산출물은 크게 두 가지로 구분됩니다.

  1. 오픈소스 고지문 : 오픈소스 라이선스 전문과 저작권 정보 제공을 위한 문서
  2. 공개할 소스 코드 패키지 : GPL, LGPL 등 소스 코드 공개를 요구하는 오픈소스 라이선스 의무 이행을 위해 공개할 소스 코드를 취합한 패키지

이러한 컴플라이언스 산출물을 취합, 배포, 보관하기 위해 다음 사항을 준수합니다.

  • 오픈소스 고지문이나 공개할 소스 코드 패키지는 각 라이선스가 요구하는 조건대로 취합합니다. 예를 들어, 라이선스가 라이선스 전체 텍스트의 동봉을 요구하는데, 링크만을 제공해서는 안 됩니다.
  • 취합한 산출물은 별도의 저장소에 보관합니다.
  • 공개할 소스 코드를 서면 청약으로 제공할 경우, 취합한 산출물의 저장소를 외부에서 접근할 수 있도록 다운로드 링크를 공개합니다.

회사의 오픈소스 프로세스를 통해 오픈소스 고지문을 발급하고, 공개할 소스 코드 패키지를 취합할 수 있습니다.

(4) SBOM (Software Bill of Materials) 생성

공급 소프트웨어를 구성하는 각 오픈소스 소프트웨어 컴포넌트 내역을 포함하는 SBOM(Software Bill of Materials)을 생성하고 이를 유지하는 프로세스가 있어야 합니다.

회사의 오픈소스 프로세스를 통해 오픈소스 도구를 활용하여 SBOM을 생성하고 보존할 수 있습니다.

(5) 컴플라이언스 이슈 대응 절차

컴플라이언스 이슈가 제기될 경우, 오픈소스 프로그램 매니저는 다음의 절차를 수행하여 신속히 대응합니다.

  1. 문의 접수를 확인하고 적절한 해결 시간을 명시합니다.
  2. 이슈 내용이 실제 문제를 지적하고 있는지를 확인합니다. (아닐 경우, 이슈 제기자에게 문제가 아님을 알립니다.)
  3. 실제 문제인 경우, 우선순위를 정하고 적절한 대응 방안을 결정합니다.
  4. 대응을 수행하고, 필요할 경우, 오픈소스 프로세스를 적절하게 보완합니다.
  5. 위의 내용은 Jira Tracker를 이용하여 보존합니다.

(6) 오픈소스 보안 보증 관리

공급 소프트웨어의 오픈소스 소프트웨어 컴포넌트에 대한 알려진 취약점의 탐지 및 해결을 위한 문서화된 절차를 수립하고 유지해야 합니다. 이 절차에는 다음 사항이 포함되어야 합니다:

  • 알려진 취약점의 존재를 발견하기 위한 방법 적용
  • 각 발견된 취약점에 대한 위험/영향 평가
  • 필요한 경우 고객에게 연락, 소프트웨어 컴포넌트 업그레이드 등 적절한 조치 수행

또한 다음과 같은 프로세스를 구축해야 합니다:

  • 공급 소프트웨어에 대한 구조적 및 기술적 위협 식별
  • 지속적이고 반복적인 보안 테스트 적용
  • 식별된 위험이 공급 소프트웨어의 출시 전에 해결되었는지 확인
  • 공급 소프트웨어가 시장에 출시된 후 모니터링 및 대응 기능 확보

각 오픈소스 소프트웨어 컴포넌트에 대해 식별된 알려진 취약점 및 새로 발견된 취약점, 그리고 수행된 조치에 대한 기록을 유지해야 합니다. 새로 발견된 취약점이 이전에 배포된 공급 소프트웨어에 있는 경우, 위험/영향 점수에 따라 적절한 조치를 취하고 필요한 경우 고객에게 연락해야 합니다.

7. 오픈소스 기여

회사는 오픈소스에서의 비즈니스 가치 창출을 위해 외부 오픈소스 프로젝트로의 참여와 기여를 권장합니다. 그러나 이 과정에서 의도하지 않은 회사의 지식 재산 노출 혹은 제 3자의 권리 침해에 주의해야 합니다. 이를 위해 회사의 프로그램 참여자가 외부 오픈소스 프로젝트로의 기여를 위해서는 다음 사항을 준수해야 합니다.

(1) 리뷰 요청 및 승인

오픈소스 기여는 저작권 관점에서 저작자가 저작물을 수정/사용/배포할 수 있는 권한을 오픈소스 프로젝트에 부여하는 것입니다. 때에 따라서는 오픈소스 프로젝트에 저작권을 양도해야 하기도 합니다. 일반적으로 고용 기간에 만든 저작물의 저작권은 고용주가 소유합니다. 즉, 프로그램 참여자가 만든 저작물은 회사가 소유합니다. 프로그램 참여자가 임의로 저작물을 오픈소스에 기여하는 행위는 불필요한 저작권 침해 이슈를 유발할 수 있습니다.

따라서, 기여하고자 하는 오픈소스 프로젝트가 있다면 오픈소스 기여 프로세스에 따라 최초 기여하기 전에 리뷰 요청 및 승인 절차를 준수합니다.

단, 다음과 같이 단순한 내용일 경우, 저작권 침해 리스크가 크지 않기 때문에 리뷰 절차 없이 프로그램 참여자의 판단에 따라 기여할 수 있습니다.

  • 10 라인 이하의 작은 코드 조각
  • Stack Overflow에서의 문의 / 답변
  • GitHub에서의 관리 활동 : Issue 생성, Pull Request Review / Approve 등

(2) 기여할 권리가 있는 코드만 기여

기여할 권리가 있는 코드만 기여해야 합니다. 즉, 직접 작성한 코드를 기여합니다. 제 3자의 코드를 임의로 기여해서는 안 됩니다.

(3) 지식 재산 노출 주의

민감한 정보, 특허 등 회사의 지식재산 노출이 우려되는 코드, 문서는 기여하지 않습니다.

기여하려는 코드에 회사의 특허가 포함되어 있다면, 이 특허를 오픈소스 라이선스로 프로젝트에 기여해도 되는지 확인해야 합니다. 모호한 부분이 있다면 OSPO에 문의합니다.

(4) CLA 서명 주의

어떤 오픈소스 프로젝트는 모든 기여자에게 CLA(Contributor License Agreement)에 서명할 것을 요구합니다. 이는 프로젝트가 여러 기여자의 저작물을 관리하면서 발생할 수 있는 저작권 분쟁을 줄이기 위해 기여자들에게 동의를 구하는 약정서입니다.

회사는 자사의 지식재산 보호를 위해 저작권 양도를 요구하는 오픈소스 프로젝트로의 기여는 허용하지 않습니다. 이러한 판단을 위해 회사의 프로그램 참여자는 기여하려는 오픈소스 프로젝트에서 CLA 서명을 요구할 경우, 서명하기 전에 반드시 OSPO에 리뷰를 요청합니다.

(5) 저작권 표시

프로그램 참여자가 재직 기간에 생성한 저작물의 지식재산은 기본적으로 회사가 소유합니다. 따라서, 프로그램 참여자는 외부 오픈소스 프로젝트에 코드를 기여할 때 회사의 저작권을 표기해야 합니다.

하나 이상의 파일을 기여할 때, 다음과 같이 파일 상단에 저작권과 라이선스를 표기합니다.

Copyright (c) {$year} {$Company}
SPDX-License-Identifier: {$SPDX_license_name}

여기서 $SPDX_license_name은 해당 오픈소스 프로젝트의 라이선스 정책에 따라 작성합니다.

단, 버그 수정 등의 목적으로 기존 코드를 수정하는 정도라면 해당 코드 수정에 대해 저작권을 표기할 필요는 없습니다.

(6) 회사 이메일 사용

오픈소스 프로젝트에 기여할 때는 개인 이메일을 사용하지 말고, 회사 이메일을 사용합니다. 이를 통해 (1) 프로그램 참여자는 회사를 대표하여 커뮤니티와 커뮤니케이션한다는 책임감을 갖게 되고, (2) 회사가 오픈소스 커뮤니티에 기여 활동을 활발히 하는 회사로 인지도를 개선할 수 있습니다.

8. 오픈소스 공개

회사는 오픈소스 커뮤니티와의 협업의 가치를 존중하고, 내부 소프트웨어를 오픈소스 프로젝트로 공개하는 것을 장려합니다. 하지만, 회사의 지식재산 보호와 의도치 않은 저작권 침해를 방지하기 위해 준수해야 할 몇 가지 규칙이 있습니다.

(1) 승인

오픈소스 공개는 저작권 관점에서 저작자가 저작물을 누구나 수정/사용/배포할 수 있는 권한을 오픈소스 라이선스를 통해 부여하는 것입니다. 일반적으로 고용 기간에 만든 저작물의 저작권은 고용주가 소유합니다. 즉, 프로그램 참여자가 만든 저작물은 회사가 소유합니다. 프로그램 참여자가 임의로 저작물을 오픈소스로 공개하는 행위는 불필요한 저작권 침해 이슈를 유발할 수 있습니다.

따라서, 공급 소프트웨어를 오픈소스로 공개하고자 한다면 회사 오픈소스 공개 정책에 따라 리뷰 요청 및 승인 절차를 따릅니다.

공개하는 과정에서 어느 것이라도 무언가 바람직하지 않아 보이는 상황이 있다면 주저하지 말고 OSPO에 문의합니다.

(2) 공개할 권리가 있는 코드만 공개

오픈소스 프로젝트에서 발생할 수 있는 최악의 상황 중 하나는 법적으로 문제가 있는 코드가 프로젝트에 포함되는 것입니다. 회사가 배포할 권리가 없는 코드이거나, 다른 회사의 특허와 같은 지식재산을 침해하는 코드가 법적인 문제를 유발할 수 있습니다. 따라서, 공개할 코드를 준비하면서 모든 코드의 출처를 확인하고 문제 소지가 있는 코드는 삭제합니다.

(3) 지식 재산 노출에 주의

민감한 정보, 특허 등 기업의 지식재산 노출이 우려되는 코드, 문서는 공개하지 않습니다.

공개하려는 코드에 회사의 특허가 포함되어 있다면, 이 특허를 오픈소스 라이선스로 공개해도 되는지 확인합니다. 모호한 부분이 있다면 OSPO에 문의합니다.

(4) 유용한 코드 공개

성공적인 프로젝트가 되기 위해서는 다른 사람들에게도 유용해야 합니다. 만약, 유사한 프로젝트가 이미 존재한다면, 새로운 프로젝트를 만드는 것보다 기존의 프로젝트에 참여합니다.

공개하려는 오픈소스가 (1) 오픈소스 커뮤니티에 차별화된 가치를 제공하고, (2) 커뮤니티가 해결되지 못했던 문제를 해결하며, (3) 우리의 기술력을 공개함으로 긍정적인 관심을 끌 수 있는 프로젝트가 되기를 기대할 수 있어야 합니다.

  • 실제 공급 소프트웨어에 사용하지 못한 코드라면 오픈소스로도 공개하지 않습니다.
  • 오픈소스 커뮤니티에서 이미 해결한 문제를 다루는 코드는 공개하지 않습니다. 이런 경우라면, 기존의 오픈소스 프로젝트에 기여합니다.

(5) 리소스 확보

프로젝트에 투입해야 할 리소스를 확보합니다.

  • 초기에는 일반적인 사내 프로젝트와 비슷한 수준의 프로그램 참여자가 필요합니다.
  • 외부의 기여를 신속하게 리뷰할 수 있는 프로그램 참여자가 필요합니다.
  • 법무팀과 마케팅팀의 역할도 필요합니다.

프로젝트를 유지하고 관리하는 데 필요한 인프라에 대한 예산을 확보합니다. 여기에는 GitHub와 같은 프로젝트 호스팅 도구가 포함됩니다. 충분한 리소스를 지원할 수 있는 환경을 조성할 수 없다면 오픈소스로 공개하지 않습니다.

(6) 회사 이메일 사용

오픈소스 공개 활동 시 개인 이메일을 사용하지 말고 회사 이메일을 사용합니다. 이를 통해 다음과 같은 이점이 있습니다.

  • 프로그램 참여자는 회사를 대표하여 커뮤니티와 커뮤니케이션한다는 책임감을 갖게 됩니다.
  • 회사는 오픈소스 커뮤니티에 공개 활동을 활발히 하는 기업으로 인지도를 개선할 수 있습니다.

9. 외부 문의 대응

(1) 외부 문의 대응 책임

외부로부터 오픈소스에 대한 문의 및 요청에 대한 대응은 오픈소스 프로그램 매니저가 담당합니다.

  • 오픈소스 프로그램 매니저는 회사 내의 적절한 프로그램 참여자에게 문의에 대한 전체 또는 일부의 처리를 할당할 수 있습니다. 필요할 경우 법률 담당자에게 문의하여 처리합니다.
  • 외부로부터 오픈소스에 대한 문의를 받은 프로그램 참여자는 누구나 이를 오픈소스 프로그램 매니저에게 알려서 신속한 대응이 될 수 있게 합니다.

(2) 연락처 공개

오픈소스 프로그램 매니저는 외부에서 오픈소스 관련한 문의 및 요청을 할 수 있도록 담당자의 연락처를 공개적으로 제공합니다.

  • 오픈소스 고지문에 연락받을 수 있는 이메일 주소 정보를 제공합니다.
  • 오픈소스 웹사이트에 이메일 주소 정보를 제공합니다.
  • Linux Foundation의 Open Compliance Directory에 연락처를 등록합니다.

(3) 외부 문의 대응 절차

외부로부터의 오픈소스 문의에 신속하고 정확하게 대응한다면 클레임이나 법적 소송 위험을 크게 줄일 수 있습니다. 이를 위해 회사는 외부의 오픈소스 문의에 대응하기 위해 회사의 오픈소스 프로세스에서 정의한 외부 문의 대응 절차를 준수합니다.

11. 프로그램 효과성 측정 및 개선

(1) 성과 지표 정의

프로그램의 효과성을 측정하기 위한 객관적인 성과 지표를 정의합니다. 이 지표들은 다음과 같은 항목을 포함할 수 있습니다:

  • 분석한 공급 소프트웨어의 수
  • 해결된 알려진 취약점 및 새로 발견된 취약점의 수
  • 컴플라이언스 산출물 생성 및 배포 수
  • 외부 문의에 대한 응답 시간
  • 프로그램 참여자의 교육 이수율

(2) 정기적인 프로그램 평가

정의된 성과 지표를 바탕으로 프로그램의 효과성을 정기적으로 평가합니다:

  • 최소 연 1회 이상 프로그램 평가를 실시합니다.
  • 평가 결과를 문서화하고 OSRB(Open Source Review Board)에 보고합니다.
  • 평가 과정에서 프로그램 참여자의 피드백을 수집하고 반영합니다.

(3) 지속적 개선 계획

평가 결과를 바탕으로 프로그램의 지속적인 개선을 위한 계획을 수립하고 실행합니다:

  • 개선이 필요한 영역을 식별하고 우선순위를 정합니다.
  • 구체적인 개선 목표와 일정을 설정합니다.
  • 개선 활동의 진행 상황을 모니터링하고 문서화합니다.
  • 개선 결과를 다음 평가 주기에 반영하여 프로그램의 효과성을 지속적으로 향상시킵니다.

이러한 프로세스를 통해 조직은 ISO/IEC 5230과 ISO/IEC 18974의 요구사항을 지속적으로 충족하면서 오픈소스 라이선스 컴플라이언스와 보안 보증 프로그램을 개선할 수 있습니다.

12. ISO 표준 준수 선언과 유지

회사는 소프트웨어 공급망에서의 오픈소스 라이선스 컴플라이언스와 보안 보증 수준 향상을 위해 Linux Foundation의 OpenChain 프로젝트의 정신을 지지하며 적극적으로 참여합니다.

  • 회사는 이 오픈소스 정책을 적용하여 ISO/IEC 5230:2020(오픈소스 라이선스 컴플라이언스)과 ISO/IEC 18974(오픈소스 보안 보증)를 준수함을 보장합니다.

  • 회사는 적합성 인증을 획득한 후 18개월 이상 ISO/IEC 5230:2020과 ISO/IEC 18974의 모든 요구사항을 충족함을 보장합니다.

  • 회사는 최소 18개월 간격으로 적합성을 검토하고 필요에 따라 정책을 변경 및 갱신합니다. 이는 다음 사항을 포함합니다:

    1. 프로그램이 ISO/IEC 5230:2020과 ISO/IEC 18974의 모든 요구사항을 충족하는지 확인하는 문서화된 증거 유지

    2. 프로그램의 지속적인 효과성을 보장하기 위한 정기적인 내부 검토 수행

    3. 오픈소스 라이선스 컴플라이언스와 보안 보증 관련 새로운 위험이나 기회를 식별하고 대응하기 위한 프로세스 구현

    4. 프로그램 참여자의 역량과 인식을 지속적으로 향상시키기 위한 교육 및 훈련 제공

  • 회사는 ISO/IEC 5230:2020과 ISO/IEC 18974 준수에 관한 외부 문의에 효과적으로 대응하기 위한 절차를 유지합니다.

이러한 노력을 통해 회사는 오픈소스 소프트웨어의 라이선스 컴플라이언스와 보안 보증에 대한 지속적인 개선과 투명성을 보장하며, 소프트웨어 공급망에서의 신뢰를 구축하고자 합니다.

Appendix 1. 담당자 현황

No역할책임필요 역량담당 조직담당자
1오픈소스 프로그램 매니저회사의 오픈소스 프로그램에 대한 총괄 책임을 담당한다.1. 소프트웨어 개발 프로세스 이해
2. 저작권, 특허 등 오픈소스 라이선스와 관련한 지식재산 이해
3. 오픈소스 라이선스 컴플라이언스에 대한 전문 지식
4. 오픈소스 개발 경험
5. 커뮤니케이션 스킬
6. 오픈소스 보안 보증에 대한 기본 지식
CTOOOO
2법무 담당오픈소스 라이선스와 의무를 해석한다. 이러한 의무를 실제 이행하는 등 오픈소스 활용을 위해 발생할 수 있는 법적 위험의 완화를 위한 자문을 제공한다.1. 오픈소스 생태계에 대한 기본 지식
2. 소프트웨어 저작권에 대한 전문 지식
3. 오픈소스 라이선스에 대한 전문 지식
4. 오픈소스 관련 법적 위험 평가 능력
법무팀OOO
3IT 담당오픈소스 분석 도구를 운영하고 자동화하여 모든 공급 소프트웨어에 대해 오픈소스 분석이 원활히 수행되도록 시스템을 구축한다.1. 오픈소스 라이선스 컴플라이언스 프로세스에 대한 기본 지식
2. 오픈소스 분석 도구에 대한 이해
3. IT 인프라에 대한 전문 지식
4. 자동화 및 CI/CD 파이프라인에 대한 이해
IT 인프라팀OOO
4보안 보증 담당오픈소스 보안 취약점 분석 도구를 운영하여 모든 공급 소프트웨어에 대해 보안 취약점 분석이 수행되도록 시스템을 구축하고 알려진 취약점 또는 새로 발견된 취약점이 기준에 맞게 보완되도록 조치한다.1. DevSecOps에 대한 폭넓은 이해
2. 오픈소스 보안 취약점 분석 도구에 대한 이해
3. 알려진 취약점 및 새로 발견된 취약점에 대한 전문 지식
4. 커뮤니케이션 스킬
5. 위험 평가 및 관리 능력
보안팀OOO
5개발 문화 담당프로그램 참여자들이 오픈소스를 적극적으로 활용하고 사내외 커뮤니티에 참여하여 선진 개발 문화를 습득할 수 있도록 지원한다.1. 소프트웨어 개발 프로세스 이해
2. 오픈소스 라이선스 컴플라이언스에 대한 기본 지식
3. 오픈소스 정책에 대한 이해
4. 교육 및 트레이닝 설계 능력
5. 오픈소스 커뮤니티 참여 경험
DROOO
6사업 부서공급 소프트웨어 개발/배포 조직은 올바른 오픈소스 활용을 위해 오픈소스 정책 및 프로세스를 준수한다.1. 소프트웨어 개발 프로세스 이해
2. 오픈소스 라이선스 컴플라이언스에 대한 기본 지식
3. 오픈소스 정책에 대한 이해
4. 오픈소스 라이선스에 대한 기본 지식
5. 오픈소스 보안 보증에 대한 기본 이해
개발팀전원
최종 수정 2025년 1일 6월: update open source guide 2025 (6c4dd4892)