2020-02-28 14:09:46 +02:00
// Code generated by piper's step-generator. DO NOT EDIT.
package cmd
import (
"fmt"
"os"
"time"
"github.com/SAP/jenkins-library/pkg/config"
"github.com/SAP/jenkins-library/pkg/log"
2021-05-17 12:14:04 +02:00
"github.com/SAP/jenkins-library/pkg/splunk"
2020-02-28 14:09:46 +02:00
"github.com/SAP/jenkins-library/pkg/telemetry"
2021-10-01 12:49:05 +02:00
"github.com/SAP/jenkins-library/pkg/validation"
2020-02-28 14:09:46 +02:00
"github.com/spf13/cobra"
)
type mavenExecuteOptions struct {
PomPath string ` json:"pomPath,omitempty" `
Goals [ ] string ` json:"goals,omitempty" `
Defines [ ] string ` json:"defines,omitempty" `
Flags [ ] string ` json:"flags,omitempty" `
ReturnStdout bool ` json:"returnStdout,omitempty" `
2020-03-17 13:09:08 +02:00
ProjectSettingsFile string ` json:"projectSettingsFile,omitempty" `
GlobalSettingsFile string ` json:"globalSettingsFile,omitempty" `
M2Path string ` json:"m2Path,omitempty" `
LogSuccessfulMavenTransfers bool ` json:"logSuccessfulMavenTransfers,omitempty" `
2020-02-28 14:09:46 +02:00
}
// MavenExecuteCommand This step allows to run maven commands
func MavenExecuteCommand ( ) * cobra . Command {
2020-04-28 07:42:02 +02:00
const STEP_NAME = "mavenExecute"
2020-02-28 14:09:46 +02:00
metadata := mavenExecuteMetadata ( )
var stepConfig mavenExecuteOptions
var startTime time . Time
2021-05-17 12:14:04 +02:00
var logCollector * log . CollectorHook
2020-02-28 14:09:46 +02:00
var createMavenExecuteCmd = & cobra . Command {
2020-04-28 07:42:02 +02:00
Use : STEP_NAME ,
2020-02-28 14:09:46 +02:00
Short : "This step allows to run maven commands" ,
Long : ` This step runs a maven command based on the parameters provided to the step. ` ,
2020-06-23 18:05:21 +02:00
PreRunE : func ( cmd * cobra . Command , _ [ ] string ) error {
2020-02-28 14:09:46 +02:00
startTime = time . Now ( )
2020-04-28 07:42:02 +02:00
log . SetStepName ( STEP_NAME )
2020-02-28 14:09:46 +02:00
log . SetVerbose ( GeneralConfig . Verbose )
2020-04-28 07:42:02 +02:00
2021-07-08 15:26:07 +02:00
GeneralConfig . GitHubAccessTokens = ResolveAccessTokens ( GeneralConfig . GitHubTokens )
2020-04-28 07:42:02 +02:00
path , _ := os . Getwd ( )
fatalHook := & log . FatalHook { CorrelationID : GeneralConfig . CorrelationID , Path : path }
log . RegisterHook ( fatalHook )
err := PrepareConfig ( cmd , & metadata , STEP_NAME , & stepConfig , config . OpenPiperFile )
2020-04-16 14:37:45 +02:00
if err != nil {
2020-06-24 10:04:05 +02:00
log . SetErrorCategory ( log . ErrorConfiguration )
2020-04-16 14:37:45 +02:00
return err
}
2020-05-05 08:36:24 +02:00
if len ( GeneralConfig . HookConfig . SentryConfig . Dsn ) > 0 {
sentryHook := log . NewSentryHook ( GeneralConfig . HookConfig . SentryConfig . Dsn , GeneralConfig . CorrelationID )
log . RegisterHook ( & sentryHook )
}
2021-05-17 12:14:04 +02:00
if len ( GeneralConfig . HookConfig . SplunkConfig . Dsn ) > 0 {
logCollector = & log . CollectorHook { CorrelationID : GeneralConfig . CorrelationID }
log . RegisterHook ( logCollector )
}
2021-10-01 12:49:05 +02:00
validation , err := validation . New ( validation . WithJSONNamesForStructFields ( ) , validation . WithPredefinedErrorMessages ( ) )
if err != nil {
return err
}
if err = validation . ValidateStruct ( stepConfig ) ; err != nil {
log . SetErrorCategory ( log . ErrorConfiguration )
return err
}
2020-04-16 14:37:45 +02:00
return nil
2020-02-28 14:09:46 +02:00
} ,
2020-06-23 18:05:21 +02:00
Run : func ( _ * cobra . Command , _ [ ] string ) {
2020-02-28 14:09:46 +02:00
telemetryData := telemetry . CustomData { }
telemetryData . ErrorCode = "1"
handler := func ( ) {
2020-10-26 15:20:04 +02:00
config . RemoveVaultSecretFiles ( )
2020-02-28 14:09:46 +02:00
telemetryData . Duration = fmt . Sprintf ( "%v" , time . Since ( startTime ) . Milliseconds ( ) )
2020-09-29 13:49:40 +02:00
telemetryData . ErrorCategory = log . GetErrorCategory ( ) . String ( )
2020-02-28 14:09:46 +02:00
telemetry . Send ( & telemetryData )
2021-05-17 12:14:04 +02:00
if len ( GeneralConfig . HookConfig . SplunkConfig . Dsn ) > 0 {
splunk . Send ( & telemetryData , logCollector )
}
2020-02-28 14:09:46 +02:00
}
log . DeferExitHandler ( handler )
defer handler ( )
2020-04-28 07:42:02 +02:00
telemetry . Initialize ( GeneralConfig . NoTelemetry , STEP_NAME )
2021-05-17 12:14:04 +02:00
if len ( GeneralConfig . HookConfig . SplunkConfig . Dsn ) > 0 {
splunk . Initialize ( GeneralConfig . CorrelationID ,
GeneralConfig . HookConfig . SplunkConfig . Dsn ,
GeneralConfig . HookConfig . SplunkConfig . Token ,
GeneralConfig . HookConfig . SplunkConfig . Index ,
GeneralConfig . HookConfig . SplunkConfig . SendLogs )
}
2020-02-28 14:09:46 +02:00
mavenExecute ( stepConfig , & telemetryData )
telemetryData . ErrorCode = "0"
2020-05-18 21:52:54 +02:00
log . Entry ( ) . Info ( "SUCCESS" )
2020-02-28 14:09:46 +02:00
} ,
}
addMavenExecuteFlags ( createMavenExecuteCmd , & stepConfig )
return createMavenExecuteCmd
}
func addMavenExecuteFlags ( cmd * cobra . Command , stepConfig * mavenExecuteOptions ) {
cmd . Flags ( ) . StringVar ( & stepConfig . PomPath , "pomPath" , os . Getenv ( "PIPER_pomPath" ) , "Path to the pom file that should be used." )
cmd . Flags ( ) . StringSliceVar ( & stepConfig . Goals , "goals" , [ ] string { } , "Maven goals that should be executed." )
cmd . Flags ( ) . StringSliceVar ( & stepConfig . Defines , "defines" , [ ] string { } , "Additional properties in form of -Dkey=value." )
cmd . Flags ( ) . StringSliceVar ( & stepConfig . Flags , "flags" , [ ] string { } , "Flags to provide when running mvn." )
cmd . Flags ( ) . BoolVar ( & stepConfig . ReturnStdout , "returnStdout" , false , "Returns the output of the maven command for further processing." )
2020-03-17 13:09:08 +02:00
cmd . Flags ( ) . StringVar ( & stepConfig . ProjectSettingsFile , "projectSettingsFile" , os . Getenv ( "PIPER_projectSettingsFile" ) , "Path to the mvn settings file that should be used as project settings file." )
cmd . Flags ( ) . StringVar ( & stepConfig . GlobalSettingsFile , "globalSettingsFile" , os . Getenv ( "PIPER_globalSettingsFile" ) , "Path to the mvn settings file that should be used as global settings file." )
cmd . Flags ( ) . StringVar ( & stepConfig . M2Path , "m2Path" , os . Getenv ( "PIPER_m2Path" ) , "Path to the location of the local repository that should be used." )
cmd . Flags ( ) . BoolVar ( & stepConfig . LogSuccessfulMavenTransfers , "logSuccessfulMavenTransfers" , false , "Configures maven to log successful downloads. This is set to `false` by default to reduce the noise in build logs." )
2020-02-28 14:09:46 +02:00
cmd . MarkFlagRequired ( "goals" )
}
// retrieve step metadata
func mavenExecuteMetadata ( ) config . StepData {
var theMetaData = config . StepData {
2020-03-19 18:24:35 +02:00
Metadata : config . StepMetadata {
2020-11-20 09:13:59 +02:00
Name : "mavenExecute" ,
Aliases : [ ] config . Alias { } ,
Description : "This step allows to run maven commands" ,
2020-03-19 18:24:35 +02:00
} ,
2020-02-28 14:09:46 +02:00
Spec : config . StepSpec {
Inputs : config . StepInputs {
Parameters : [ ] config . StepParameters {
{
Name : "pomPath" ,
ResourceRef : [ ] config . ResourceReference { } ,
Scope : [ ] string { "PARAMETERS" , "STEPS" } ,
Type : "string" ,
Mandatory : false ,
Aliases : [ ] config . Alias { } ,
2021-06-16 08:43:30 +02:00
Default : os . Getenv ( "PIPER_pomPath" ) ,
2020-02-28 14:09:46 +02:00
} ,
{
2020-03-17 13:09:08 +02:00
Name : "goals" ,
2020-02-28 14:09:46 +02:00
ResourceRef : [ ] config . ResourceReference { } ,
2020-03-17 13:09:08 +02:00
Scope : [ ] string { "PARAMETERS" } ,
Type : "[]string" ,
Mandatory : true ,
2020-02-28 14:09:46 +02:00
Aliases : [ ] config . Alias { } ,
2021-06-16 08:43:30 +02:00
Default : [ ] string { } ,
2020-02-28 14:09:46 +02:00
} ,
{
2020-03-17 13:09:08 +02:00
Name : "defines" ,
2020-02-28 14:09:46 +02:00
ResourceRef : [ ] config . ResourceReference { } ,
2020-03-17 13:09:08 +02:00
Scope : [ ] string { "PARAMETERS" } ,
Type : "[]string" ,
2020-02-28 14:09:46 +02:00
Mandatory : false ,
Aliases : [ ] config . Alias { } ,
2021-06-16 08:43:30 +02:00
Default : [ ] string { } ,
2020-02-28 14:09:46 +02:00
} ,
{
2020-03-17 13:09:08 +02:00
Name : "flags" ,
2020-02-28 14:09:46 +02:00
ResourceRef : [ ] config . ResourceReference { } ,
Scope : [ ] string { "PARAMETERS" , "STEPS" } ,
2020-03-17 13:09:08 +02:00
Type : "[]string" ,
2020-02-28 14:09:46 +02:00
Mandatory : false ,
Aliases : [ ] config . Alias { } ,
2021-06-16 08:43:30 +02:00
Default : [ ] string { } ,
2020-02-28 14:09:46 +02:00
} ,
{
2020-03-17 13:09:08 +02:00
Name : "returnStdout" ,
2020-02-28 14:09:46 +02:00
ResourceRef : [ ] config . ResourceReference { } ,
Scope : [ ] string { "PARAMETERS" } ,
2020-03-17 13:09:08 +02:00
Type : "bool" ,
Mandatory : false ,
2020-02-28 14:09:46 +02:00
Aliases : [ ] config . Alias { } ,
2021-06-16 08:43:30 +02:00
Default : false ,
2020-02-28 14:09:46 +02:00
} ,
{
2020-03-17 13:09:08 +02:00
Name : "projectSettingsFile" ,
2020-02-28 14:09:46 +02:00
ResourceRef : [ ] config . ResourceReference { } ,
2020-03-17 13:09:08 +02:00
Scope : [ ] string { "GENERAL" , "STEPS" , "STAGES" , "PARAMETERS" } ,
Type : "string" ,
2020-02-28 14:09:46 +02:00
Mandatory : false ,
2020-03-17 13:09:08 +02:00
Aliases : [ ] config . Alias { { Name : "maven/projectSettingsFile" } } ,
2021-06-16 08:43:30 +02:00
Default : os . Getenv ( "PIPER_projectSettingsFile" ) ,
2020-02-28 14:09:46 +02:00
} ,
{
2020-03-17 13:09:08 +02:00
Name : "globalSettingsFile" ,
2020-02-28 14:09:46 +02:00
ResourceRef : [ ] config . ResourceReference { } ,
2020-03-17 13:09:08 +02:00
Scope : [ ] string { "GENERAL" , "STEPS" , "STAGES" , "PARAMETERS" } ,
Type : "string" ,
2020-02-28 14:09:46 +02:00
Mandatory : false ,
2020-03-17 13:09:08 +02:00
Aliases : [ ] config . Alias { { Name : "maven/globalSettingsFile" } } ,
2021-06-16 08:43:30 +02:00
Default : os . Getenv ( "PIPER_globalSettingsFile" ) ,
2020-02-28 14:09:46 +02:00
} ,
{
2020-03-17 13:09:08 +02:00
Name : "m2Path" ,
2020-02-28 14:09:46 +02:00
ResourceRef : [ ] config . ResourceReference { } ,
2020-03-17 13:09:08 +02:00
Scope : [ ] string { "GENERAL" , "STEPS" , "STAGES" , "PARAMETERS" } ,
Type : "string" ,
2020-02-28 14:09:46 +02:00
Mandatory : false ,
2020-03-17 13:09:08 +02:00
Aliases : [ ] config . Alias { { Name : "maven/m2Path" } } ,
2021-06-16 08:43:30 +02:00
Default : os . Getenv ( "PIPER_m2Path" ) ,
2020-02-28 14:09:46 +02:00
} ,
{
2020-03-17 13:09:08 +02:00
Name : "logSuccessfulMavenTransfers" ,
2020-02-28 14:09:46 +02:00
ResourceRef : [ ] config . ResourceReference { } ,
2020-03-17 13:09:08 +02:00
Scope : [ ] string { "GENERAL" , "STEPS" , "STAGES" , "PARAMETERS" } ,
2020-02-28 14:09:46 +02:00
Type : "bool" ,
Mandatory : false ,
2020-03-17 13:09:08 +02:00
Aliases : [ ] config . Alias { { Name : "maven/logSuccessfulMavenTransfers" } } ,
2021-06-16 08:43:30 +02:00
Default : false ,
2020-02-28 14:09:46 +02:00
} ,
} ,
} ,
2020-11-20 09:13:59 +02:00
Containers : [ ] config . Container {
{ Name : "mvn" , Image : "maven:3.6-jdk-8" } ,
} ,
2020-02-28 14:09:46 +02:00
} ,
}
return theMetaData
}