DEV Community

Cover image for Veracode Upload & Scan Deep Dive
Ivo Dias for M3Corp

Posted on • Edited on

Veracode Upload & Scan Deep Dive

Por Veracode Upload & Scan, ou apenas U&S, vamos entender o processo feito pelo Wrapper ao utilizar a ação composta "Upload & Scan", responsável por fazer todo o processo de carregamento dos arquivos, organização e validação.

Como dá a entender o termo "ação composta", conforme a documentação podemos ver que existem ações independentes para fazer cada uma das etapas mas para simplificar, vamos utilizar essa ação conjunta. Caso em seu projeto exista alguma necessidade muito específica não coberta por ela, recomendo ler a seção das ações para criar um caminho personalizado.

Ao utilizar o U&S vamos fazer em conjunto a análise de código próprio, ou SAST, e a análise de componentes de terceiros, ou SCA.

O arquivo que precisamos enviar varia conforme a linguagem e sempre recomendamos a leitura do guia de empacotamento.

Para as credenciais, podemos passá-las diretamente como parâmetros ou criar um arquivo de credenciais, já que o Wrapper primeiramente busca por ele para validar se tem as informações necessárias.

Em algumas ferramentas de CI/CD, temos tarefas/plugins que abstraem o uso do Wrapper, como é o caso do Jenkins e do Azure DevOps. Para os outros casos, ou caso não queira instalar esses plugins, pode executar o Wrapper em sistemas Linux, Mac ou Windows, tendo ele versões em Java e em EXE.
Existe também uma imagem Docker já configurada, que pode ser utilizada.

Como implementar o U&S em uma esteira ou terminal
Para esse exemplo, vamos pensar na versão em Java, já que ele funciona em todos os sistemas da mesma forma. Para ambientes Windows, recomendo usar a versão EXE dele, já que assim não precisa instalar o Java. Clique aqui para saber exatamente quais são as dependências do Wrapper.

Basicamente, vamos precisar apenas fazer o download do Wrapper e utilizá-lo. Pode definir um processo para sempre efetuar esse download, ou no caso de uma infraestrutura que se mantem, pode salva-lo em algum ponto que possa ser consultado.

Em Linux/Mac, podemos fazer esse processo de download dessa forma:

curl -o veracode-wrapper.jar https://repo1.maven.org/maven2/com/veracode/vosp/api/wrappers/vosp-api-wrappers-java/23.4.11.2/vosp-api-wrappers-java-23.4.11.2.jar
Enter fullscreen mode Exit fullscreen mode

Para a implementação, vamos chamar o Wrapper e passar os parâmetros:

java -jar veracode-wrapper.jar -vid ${VeracodeID} -vkey ${VeracodeKey} -action uploadandscan -appname ${VeracodeProfile} -createprofile true  -version $(date +%H%M%s%d%m%y) -filepath ${CaminhoPacote}
Enter fullscreen mode Exit fullscreen mode

Ou caso use um arquivo de credenciais, pode simplificar para:

java -jar veracode-wrapper.jar -action uploadandscan -appname ${VeracodeProfile} -createprofile true  -version $(date +%H%M%s%d%m%y) -filepath ${CaminhoPacote}
Enter fullscreen mode Exit fullscreen mode

Como parâmetros temos:

# A ação conjunta que explicamos
-action uploadandscan

# Nome conforme o perfil de aplicação
-appname ${VeracodeProfile}

# Caso queira fazer a criação dinamicamente
-createprofile true

# Identificador do scan dentro do perfil, recomendo sincronizar com uma data ou com um número de versão/build
-version $(date +%H%M%s%d%m%y)

# Caminho do arquivo que vai ser analisado, criado conforme o guia de empacotamento
-filepath ${CaminhoPacote}
Enter fullscreen mode Exit fullscreen mode

Executado dessa forma, vamos ter o U&S iniciando o processo, jogando os resultados para o que chamamos de Policy Scan e não aguardando os resultados. Caso queira que ele aguarde a conclusão do processo, basta adicionar o parâmetro:

# Onde X é o número de minutos limite para aguardar a conclusão
-scantimeout X
Enter fullscreen mode Exit fullscreen mode

Para saber todas as opções, clique aqui.

Consultando os resultados
O retorno do Wrapper é bem protocolar, basicamente nos retornando apenas o status geral, como "scan concluído" ou "Não foi possível iniciar devido a problema x".

Para de fato consultar os resultados temos algumas opções:

Para esse artigo, vamos pensar na última opção, mas na lista deixei links para saber sobre os outros caminhos.

Dentro de um perfil de aplicação, temos alguns locais diferentes para consultar, para facilitar, recomendo que veja nosso vídeo tutorial explicando exatamente quais são as telas e o que temos nelas:

Mas de uma maneira bem rápida, caso não possa ver o vídeo, temos no canto esquerdo as seções dentro de um determinado scan, sendo cada uma um tipo de visão diferente.

Em View Report, temos uma visão mais resumida e executiva, junto ao controle de políticas e a opção de fazer o download no formato PDF ou XML:
View Report

Como comentamos, ao usar o U&S fazemos tanto SCA quanto SAST de forma unificada, mas na plataforma separamos os resultados para melhor organização. Em Software Composition Analysis temos os componentes de terceiros, caso queira ver mais detalhes deles, basta clicar em seu nome:
Software Composition Analysis

Os resultados de código próprio ficam na seção Triage Flaws:
Triage Flaws

Caso existam pontos de falha que gerem mais de um problema, eles vão aparecer em Flaw Sources:
Flaw Sources

E por fim, caso queira saber o que foi considerado no scan, pode acessar os módulos clicando no nome do scan e em Review Modules:
Review Modules

Top comments (0)