의존성 디렉터리
- GitLab 14.6에서 소개된 시스템 의존성.
- GitLab 16.2에서 그룹 수준의 의존성 디렉터리,
group_level_dependencies
라는 플래그로 함께 소개됨. 기본적으로 비활성화된 상태.- GitLab 16.4에서 GitLab.com 및 Self-managed에서 그룹 수준의 의존성 디렉터리 활성화.
- GitLab 16.5에서 일반적으로 제공됨. 피처 플래그
group_level_dependencies
가 삭제됨.
프로젝트 또는 그룹의 의존성 및 해당 의존성에 대한 주요 내용을 검토하는 데 의존성 디렉터리을 사용하십시오. 이 디렉터리은 프로젝트의 기존 및 새로운 발견을 포함한 의존성의 모음입니다. 이 정보는 때로는 소프트웨어 자재 디렉터리(Software Bill of Materials, SBOM) 또는 BOM으로 언급됩니다.
개요는 프로젝트 의존성을 참조하세요.
전제 조건
프로젝트의 의존성을 보려면 다음 요구 사항을 충족하는지 확인하세요:
- 프로젝트에 대한 의존성 스캐닝 또는 컨테이너 스캐닝 CI 작업이 구성되어 있어야 합니다.
- 프로젝트가 Gemnasium에서 지원하는 언어 및 패키지 관리자 중 하나를 사용해야 합니다.
- 기본 브랜치에서 성공적인 파이프라인이 실행되었어야 합니다. 애플리케이션 보안 작업을 실패 허용하는 기본 동작을 변경해서는 안 됩니다.
프로젝트 의존성 보기
프로젝트 또는 그룹 내 모든 프로젝트의 의존성을 보려면 다음을 수행하세요:
- 왼쪽 사이드바에서 검색 또는 이동을 선택하고 프로젝트 또는 그룹을 찾습니다.
- 보안 > 의존성 디렉터리을 선택합니다.
각 의존성의 세부 정보는 (있는 경우) 취약점의 심각도에 따라 정렬된 디렉터리으로 표시됩니다. 디렉터리을 컴포넌트 이름 또는 패키저별로 정렬할 수도 있습니다.
필드 | 설명 |
---|---|
컴포넌트 | 의존성의 이름과 버전. |
패키저 | 의존성을 설치하는 패키저. |
위치 | 시스템 의존성의 경우 스캔된 이미지를 나열합니다. 애플리케이션 의존성의 경우 프로젝트의 패키저별 잠금 파일로의 링크를 표시합니다. 또한, (있는 경우) 최상위 의존성까지의 의존성 경로를 지원하는 경우에 대한 링크를 표시합니다. |
라이선스1 | 의존성의 소프트웨어 라이선스로 연결된 링크입니다. 의존성에서 감지된 취약점 수를 포함하는 경고 배지. |
프로젝트2 | 의존성이 포함된 프로젝트로 연결된 링크입니다. 여러 프로젝트가 동일한 의존성을 가지고 있는 경우 이러한 프로젝트의 총 수가 표시됩니다. 이러한 의존성을 가진 프로젝트로 이동하려면 프로젝트 수를 선택한 후 해당 이름을 검색하여 선택합니다. 프로젝트 검색 기능은 그룹 계층 구조에 최대 600개가 있는 그룹에서만 지원됩니다. |
- 프로젝트 수준만 해당됨.
- 그룹 수준만 해당됨.
의존성 디렉터리 필터링
그룹 수준의 의존성 디렉터리에서 다음으로 필터링할 수 있습니다:
- 프로젝트
- 라이선스
의존성 디렉터리을 필터링하려면 다음을 수행하세요:
- 왼쪽 사이드바 상단에서 검색 GitLab()을 선택하여 프로젝트 또는 그룹을 찾습니다.
- 보안 > 의존성 디렉터리을 선택합니다.
- 필터 막대를 선택합니다.
- 필터를 선택한 후 드롭다운 디렉터리에서 하나 이상의 기준을 선택합니다. 드롭다운 디렉터리 바깥쪽을 선택하여 드롭다운 디렉터리을 닫습니다. 추가 필터를 추가하려면 이 단계를 반복합니다.
- 선택한 필터를 적용하려면 Enter를 누릅니다.
의존성 디렉터리에는 선택한 필터와 일치하는 의존성만 표시됩니다.
취약점
의존성에 알려진 취약점이 있는 경우 해당 의존성의 이름 옆의 화살표나 알려진 취약점 수를 나타내는 배지를 선택하여 볼 수 있습니다. 각 취약점에 대해 심각도와 설명이 표시됩니다. 취약점의 세부 정보를 보려면 취약점의 설명을 선택합니다. 취약점의 세부 정보 페이지가 열립니다.
의존성 경로
의존성 디렉터리은 의존성과 연결된 최상위 의존성 사이의 경로를 보여줍니다(있는 경우). 여러 경로가 일회성 의존성들을 최상위 의존성에 연결하지만 UI는 가장 짧은 경로 중 하나만 보여줍니다.
dependency_files
속성을 기반으로 표시되었으며 GitLab 16.9에서 폐기되었으며 17.0에서 제거될 예정입니다.
이는 CycloneDX 보고서의 데이터로 대체될 것입니다.다음 패키지 관리자에서 의존성 경로가 지원됩니다:
라이선스
만약 의존성 스캐닝 CI 작업이 구성되어 있다면, 발견된 라이선스가 이 페이지에 표시됩니다.
의존성 디렉터리 다운로드
전체 의존성 디렉터리과 세부 정보를 JSON 형식으로 다운로드할 수 있습니다. 의존성 디렉터리은 기본 브랜치에서 실행된 마지막 성공한 파이프라인의 결과만 표시됩니다.
의존성 디렉터리을 다운로드하려면:
- 왼쪽 사이드바에서 검색 또는 이동을 선택하고 프로젝트나 그룹을 찾습니다.
- 보안 > 의존성 디렉터리을 선택합니다.
- 내보내기를 선택합니다.
문제 해결
라이선스가 ‘알 수 없음’으로 표시됨
특정 의존성의 라이선스가 알 수 없음
으로 표시될 수 있는 몇 가지 가능한 이유가 있습니다. 이 섹션에서는 특정 의존성의 라이선스가 알려진 이유로 알 수 없음
으로 표시되는지 여부를 확인하는 방법에 대해 설명합니다.
상류의 라이선스가 ‘알 수 없음’
의존성의 상류에 지정된 라이선스를 확인합니다:
- C/C++ 패키지의 경우, Conancenter를 확인합니다.
- npm 패키지의 경우, npmjs.com을 확인합니다.
- Python 패키지의 경우, PyPI를 확인합니다.
- NuGet 패키지의 경우, Nuget를 확인합니다.
- Go 패키지의 경우, pkg.go.dev를 확인합니다.
만약 라이선스가 상류에서 알 수 없음
으로 나타나면, GitLab도 해당 의존성에 대한 라이선스를 알 수 없음
으로 표시할 것으로 예상됩니다.
SPDX 라이선스 표현을 포함하는 라이선스
SPDX 라이선스 표현은 지원되지 않습니다. SPDX 라이선스 표현을 포함하는 의존성은 알 수 없음
으로 나타나는 라이선스가 표시됩니다. SPDX 라이선스 표현의 예는 (MIT 또는 CC0-1.0)
입니다. 이슈 336878에서 자세히 알아보세요.
Package 버전이 Package Metadata DB에 없음
의존성 패키지의 특정 버전은 패키지 메타데이터 데이터베이스에 있어야 합니다. 그렇지 않으면 해당 의존성의 라이선스가 알 수 없음
으로 나타납니다. Go 모듈에 관한 이슈 440218에서 자세히 알아보세요.
패키지 이름에 특수 문자가 포함됨
의존성 패키지의 이름에 하이픈(-
)이 포함되어 있다면 라이선스가 알 수 없음
으로 나타날 수 있습니다. 이는 패키지가 매뉴얼으로 requirements.txt
에 추가되거나 pip-compile
을 사용할 때 발생할 수 있습니다. 이 경우, GitLab은 의존성에 대한 정보를 수집할 때 PEP 503의 정규화된 이름에 따라 Python 패키지 이름을 정규화하지 않기 때문에 발생합니다. Python 패키지 이름에 대한 자세한 내용은 이슈 440391를 참조하세요.