Azure Pipelines의 보안 허점?

Aug 16 2020

저는 Azure DevOps를 연구 해 왔으며 Azure 파이프 라인에서 매우 명백한 보안 허점을 발견했습니다.

그래서 저는 파이프 라인을 YAML로 생성하고 빌드 단계와 배포 단계의 두 단계를 정의하고 있습니다. 배포 단계는 다음과 같습니다.

- stage: deployApiProdStage
  displayName: 'Deploy API to PROD'
  dependsOn: buildTestApiStage
  jobs:
  - deployment: deployApiProdJob
    displayName: 'Deploy API to PROD'
    timeoutInMinutes: 10
    condition: and(succeeded(), eq(variables.isRelease, true))
    environment: PROD
    strategy:
      runOnce:
        deploy:
          steps:
          - task: AzureWebApp@1
            displayName: 'Deploy Azure web app'
            inputs:
              azureSubscription: '(service connection to production web app)'
              appType: 'webAppLinux'
              appName: 'my-web-app'
              package: '$(Pipeline.Workspace)/$(artifactName)/**/*.zip'
              runtimeStack: 'DOTNETCORE|3.1'
              startUpCommand: 'dotnet My.Api.dll'

Microsoft 문서에서는 환경에 승인 및 검사를 추가하여이를 보호하는 방법에 대해 설명합니다. 위의 경우 PROD 환경입니다. 내 PROD 웹앱에 게시 할 수있는 보호 된 리소스 (azureSubscription의 서비스 연결)를 PROD 환경에서 가져온 경우에는 문제가되지 않습니다. 불행히도 제가 말할 수있는 한 그렇지 않습니다. 대신 파이프 라인 자체와 연결됩니다.

즉, 파이프 라인이 처음 실행될 때 Azure DevOps UI 는 모든 배포가 발생하는 데 필요한 서비스 연결에 대한 파이프 라인 액세스를 허용하라는 메시지를 표시합니다 . 액세스가 허용되면 해당 파이프 라인은 해당 서비스 연결에 계속 액세스 할 수 있습니다. 이는 그때부터 작업에 지정된 환경에 관계없이 해당 서비스 연결을 사용할 수 있음을 의미합니다. 더 나쁜 것은, 인식되지 않는 지정된 환경 이름은 오류를 일으키지 않지만 기본적으로 빈 환경이 생성되도록한다는 것입니다!

따라서 PROD 환경에 대한 수동 승인을 설정하더라도 조직의 누군가가 Azure에서 환경 이름을 'NewPROD'로 변경하는 코드 검토 (정기적 인 대규모 코드 검토를 통해 가능)를 통해 변경 사항을 적용 할 수있는 경우 -pipelines.yml 파일이 있으면 CI / CD가 새 환경을 만들고 새 환경에 확인이나 승인이 없기 때문에 즉시 PROD에 배포합니다!

확실히 서비스 연결이 환경과 연관되는 것이 이치에 맞을 것입니다. 새로운 환경의 자동 생성을 금지 할 수있는 옵션이있는 것도 이치에 맞을 것입니다. 어쨌거나 이것이 어떻게 특히 유용한 지 잘 모르겠습니다. 지금 당장은 리포지토리에 대한 커밋 액세스 권한이 있거나 승인 프로세스를 통해 azure-pipelines.yml 파일에 변경 사항을 적용하는 모든 사람이 중요한 환경에 배포 할 수있는 거대한 보안 허점입니다. , 주요 단일 실패 / 약점 지점을 소개합니다. 파이프 라인 보안에 대한 많은 찬사를받은 점진적 접근 방식은 어떻게 되었습니까? 여기에 뭔가 빠졌나요, 아니면이 보안 허점이 생각만큼 나쁜가요?

답변

1 CeceDong-MSFT Aug 17 2020 at 16:04

귀하의 예에서는 빈 환경을 생성 / 사용한 것처럼 보였으며 배포 대상이 없습니다. 현재 환경에서는 Kubernetes 리소스가상 머신 리소스 유형 만 지원됩니다.

https://docs.microsoft.com/en-us/azure/devops/pipelines/process/environments?view=azure-devops

예제의 리소스는 서비스 연결이므로 서비스 연결로 이동하여이 서비스 연결에 대한 검사를 정의해야합니다.

https://docs.microsoft.com/en-us/azure/devops/pipelines/process/approvals?view=azure-devops&tabs=check-pass