Skip to content

Latest commit

 

History

History
40 lines (32 loc) · 2.21 KB

02-caterpillar.md

File metadata and controls

40 lines (32 loc) · 2.21 KB

CICD-SEC-4 Poisoned Pipeline Execution (PPE)

Create a pull request originated from a fork and execute a Direct-PPE attack against the Wonderland/Caterpillar repository to elevate your privileges and steal the flag2 secret.

  1. Fork the Wonderland/Caterpillar repository.

  2. Modify the Jenkinsfile in the fork to print the environment variables into the console output, or send it to a server you control.

    stage ('Install_Requirements') {
        steps {
            sh '''
                env
            '''
        }
    }
  3. Create a pull request based on the fork into the main branch of the original repository. The wonderland-caterpillar-test Jenkins pipeline, originally intended to run tests against the repository code, will be executed.

  4. Access the console output of the executed job to get the gitea_token. This token has Write permission on the repository, which effectively allows you to elevate your privileges against the repo.

  5. Clone the repository using the token.

    git clone http://a644940c92efe2d1876e16a5d29e6c6d7e199b68@localhost:3000/Wonderland/caterpillar.git
  6. Modify the Jenkinsfile to load the flag2 secret as an environment variable and print it to the console output (or to send it to a remote host).

    stage('deploy') {
        steps {
            withCredentials([usernamePassword(credentialsId: 'flag2', usernameVariable: 'flag2', passwordVariable: 'TOKEN')]) {
                sh 'echo $TOKEN | base64'
            }
        }
    }
  7. Push the modified Jenkinsfile to the main branch in the repository. The wonderland-caterpillar-prod pipeline will be triggered automatically.

  8. Access the console output of the executed job to get the encoded secret. caterpillar