1 package org.apache.maven.plugin.gpg;
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 import java.io.File;
23 import java.io.IOException;
24 import java.util.List;
25
26 import org.apache.maven.plugin.AbstractMojo;
27 import org.apache.maven.plugin.MojoExecutionException;
28 import org.apache.maven.plugin.MojoFailureException;
29 import org.apache.maven.plugins.annotations.Component;
30 import org.apache.maven.plugins.annotations.Parameter;
31 import org.apache.maven.project.MavenProject;
32 import org.apache.maven.settings.Server;
33 import org.apache.maven.settings.Settings;
34 import org.codehaus.plexus.util.StringUtils;
35 import org.sonatype.plexus.components.sec.dispatcher.SecDispatcher;
36 import org.sonatype.plexus.components.sec.dispatcher.SecDispatcherException;
37
38
39
40
41 public abstract class AbstractGpgMojo
42 extends AbstractMojo
43 {
44
45
46
47
48
49
50
51 @Parameter( property = "gpg.homedir" )
52 private File homedir;
53
54
55
56
57
58 @Parameter( property = "gpg.passphrase" )
59 private String passphrase;
60
61
62
63
64
65 @Parameter( property = "gpg.passphraseServerId", defaultValue = "gpg.passphrase" )
66 private String passphraseServerId;
67
68
69
70
71 @Parameter( property = "gpg.keyname" )
72 private String keyname;
73
74
75
76
77
78
79 @Parameter( property = "gpg.useagent", defaultValue = "true" )
80 private boolean useAgent;
81
82
83
84 @Parameter( defaultValue = "${settings.interactiveMode}", readonly = true )
85 private boolean interactive;
86
87
88
89
90
91
92
93 @Parameter( property = "gpg.executable" )
94 private String executable;
95
96
97
98
99
100
101 @Parameter( property = "gpg.defaultKeyring", defaultValue = "true" )
102 private boolean defaultKeyring;
103
104
105
106
107
108
109
110
111
112 @Parameter( property = "gpg.secretKeyring" )
113 private String secretKeyring;
114
115
116
117
118
119
120
121
122 @Parameter( property = "gpg.publicKeyring" )
123 private String publicKeyring;
124
125
126
127
128
129
130
131
132
133
134 @Parameter( property = "gpg.lockMode" )
135 private String lockMode;
136
137
138
139
140
141
142
143
144
145
146
147
148
149 @Parameter
150 private List<String> gpgArguments;
151
152
153
154
155
156
157 @Parameter( defaultValue = "${settings}", readonly = true )
158 private Settings settings;
159
160
161
162
163
164
165 @Component( hint = "mng-4384" )
166 private SecDispatcher securityDispatcher;
167
168 AbstractGpgSigner newSigner( MavenProject project )
169 throws MojoExecutionException, MojoFailureException
170 {
171 AbstractGpgSigner signer = new GpgSigner( executable );
172
173 signer.setLog( getLog() );
174 signer.setInteractive( interactive );
175 signer.setKeyName( keyname );
176 signer.setUseAgent( useAgent );
177 signer.setHomeDirectory( homedir );
178 signer.setDefaultKeyring( defaultKeyring );
179 signer.setSecretKeyring( secretKeyring );
180 signer.setPublicKeyring( publicKeyring );
181 signer.setLockMode( lockMode );
182 signer.setArgs( gpgArguments );
183
184 loadGpgPassphrase();
185
186 signer.setPassPhrase( passphrase );
187 if ( null == passphrase && !useAgent )
188 {
189 if ( !interactive )
190 {
191 throw new MojoFailureException( "Cannot obtain passphrase in batch mode" );
192 }
193 try
194 {
195 signer.setPassPhrase( signer.getPassphrase( project ) );
196 }
197 catch ( IOException e )
198 {
199 throw new MojoExecutionException( "Exception reading passphrase", e );
200 }
201 }
202
203 return signer;
204 }
205
206
207
208
209
210
211 private void loadGpgPassphrase()
212 throws MojoFailureException
213 {
214 if ( StringUtils.isEmpty( this.passphrase ) )
215 {
216 Server server = this.settings.getServer( passphraseServerId );
217
218 if ( server != null )
219 {
220 if ( server.getPassphrase() != null )
221 {
222 try
223 {
224 this.passphrase = securityDispatcher.decrypt( server.getPassphrase() );
225 }
226 catch ( SecDispatcherException e )
227 {
228 throw new MojoFailureException( "Unable to decrypt gpg passphrase", e );
229 }
230 }
231 }
232 }
233 }
234 }