This project has retired. For details please refer to its
Attic page.
AuditEvent xref
1 package org.apache.archiva.metadata.model.facets;
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 import org.apache.archiva.metadata.model.MetadataFacet;
23
24 import java.text.ParseException;
25 import java.text.SimpleDateFormat;
26 import java.util.Calendar;
27 import java.util.Date;
28 import java.util.HashMap;
29 import java.util.Map;
30 import java.util.TimeZone;
31
32
33
34
35
36
37 public class AuditEvent
38 implements MetadataFacet
39 {
40 public static final String TIMESTAMP_FORMAT = "yyyy/MM/dd/HHmmss.SSS";
41
42 public static final String CREATE_DIR = "Created Directory";
43
44 public static final String CREATE_FILE = "Created File";
45
46 public static final String REMOVE_DIR = "Removed Directory";
47
48 public static final String REMOVE_FILE = "Removed File";
49
50 public static final String MODIFY_FILE = "Modified File";
51
52 public static final String MOVE_FILE = "Moved File";
53
54 public static final String MOVE_DIRECTORY = "Moved Directory";
55
56 public static final String COPY_DIRECTORY = "Copied Directory";
57
58 public static final String COPY_FILE = "Copied File";
59
60 public static final String UPLOAD_FILE = "Uploaded File";
61
62 public static final String ADD_LEGACY_PATH = "Added Legacy Artifact Path";
63
64 public static final String REMOVE_LEGACY_PATH = "Removed Legacy Artifact Path";
65
66 public static final String PURGE_ARTIFACT = "Purged Artifact";
67
68 public static final String PURGE_FILE = "Purged Support File";
69
70 public static final String REMOVE_SCANNED = "Removed in Filesystem";
71
72 public static final String MERGING_REPOSITORIES = "Merged Artifact";
73
74
75
76 public static final String ADD_MANAGED_REPO = "Added Managed Repository";
77
78 public static final String MODIFY_MANAGED_REPO = "Updated Managed Repository";
79
80 public static final String DELETE_MANAGED_REPO = "Deleted Managed Repository";
81
82 public static final String ADD_REMOTE_REPO = "Added Remote Repository";
83
84 public static final String MODIFY_REMOTE_REPO = "Updated Remote Repository";
85
86 public static final String DELETE_REMOTE_REPO = "Deleted Remote Repository";
87
88 public static final String ADD_REPO_GROUP = "Added Repository Group";
89
90 public static final String DELETE_REPO_GROUP = "Deleted Repository Group";
91
92 public static final String MODIFY_REPO_GROUP = "Modify Repository Group";
93
94 public static final String ADD_REPO_TO_GROUP = "Added Repository to Group";
95
96 public static final String DELETE_REPO_FROM_GROUP = "Deleted Repository from Group";
97
98 public static final String ENABLE_REPO_CONSUMER = "Enabled Content Consumer";
99
100 public static final String DISABLE_REPO_CONSUMER = "Disabled Content Consumer";
101
102 public static final String ADD_PATTERN = "Added File Type Pattern";
103
104 public static final String REMOVE_PATTERN = "Removed File Type Pattern";
105
106 public static final String MERGE_REPO_REMOTE = "Merged Staging Repository Triggered Remotely";
107
108 public static final String ADD_PROXY_CONNECTOR = "Added Proxy Connector";
109
110 public static final String DELETE_PROXY_CONNECTOR = "Deleted Proxy Connector";
111
112 public static final String MODIFY_PROXY_CONNECTOR = "Updated Proxy Connector";
113
114 public static final String ADD_NETWORK_PROXY = "Added Network Proxy";
115
116 public static final String DELETE_NETWORK_PROXY = "Deleted Network Proxy";
117
118 public static final String MODIFY_NETWORK_PROXY = "Updated Network Proxy";
119
120 private String repositoryId;
121
122 private String userId;
123
124 private String remoteIP;
125
126
127
128 private String resource;
129
130 private String action;
131
132 private Date timestamp;
133
134 public static final String FACET_ID = "org.apache.archiva.audit";
135
136 private static final TimeZone UTC_TIME_ZONE = TimeZone.getTimeZone( "UTC" );
137
138 private static final int TS_LENGTH = TIMESTAMP_FORMAT.length();
139
140 public AuditEvent()
141 {
142
143 }
144
145 public AuditEvent( String name, String repositoryId )
146 {
147 String ts = name.substring( 0, TS_LENGTH );
148 try
149 {
150 timestamp = createNameFormat().parse( ts );
151 }
152 catch ( ParseException e )
153 {
154 throw new IllegalArgumentException( "Improperly formatted timestamp for audit log event: " + ts, e);
155 }
156
157 if ( name.length() > TS_LENGTH )
158 {
159 if ( name.charAt( TS_LENGTH ) != '/' )
160 {
161 throw new IllegalArgumentException(
162 "Improperly formatted name for audit log event, no / separator between timestamp and resource: " +
163 name );
164 }
165 }
166
167 this.repositoryId = repositoryId;
168 }
169
170 public AuditEvent( String repoId, String user, String resource, String action )
171 {
172 this.repositoryId = repoId;
173 this.userId = user;
174 this.resource = resource;
175 this.action = action;
176 this.timestamp = Calendar.getInstance().getTime();
177 }
178
179 public String getRepositoryId()
180 {
181 return repositoryId;
182 }
183
184 public void setRepositoryId( String repositoryId )
185 {
186 this.repositoryId = repositoryId;
187 }
188
189 public String getUserId()
190 {
191 return userId;
192 }
193
194 public void setUserId( String userId )
195 {
196 this.userId = userId;
197 }
198
199 public String getResource()
200 {
201 return resource;
202 }
203
204 public void setResource( String resource )
205 {
206 this.resource = resource;
207 }
208
209 public String getAction()
210 {
211 return action;
212 }
213
214 public void setAction( String action )
215 {
216 this.action = action;
217 }
218
219 public String getRemoteIP()
220 {
221 return remoteIP;
222 }
223
224 public void setRemoteIP( String remoteIP )
225 {
226 this.remoteIP = remoteIP;
227 }
228
229 public Date getTimestamp()
230 {
231 return timestamp;
232 }
233
234 public void setTimestamp( Date timestamp )
235 {
236 this.timestamp = timestamp;
237 }
238
239 @Override
240 public String getFacetId()
241 {
242 return FACET_ID;
243 }
244
245 @Override
246 public String getName()
247 {
248
249
250 return createNameFormat().format( timestamp ) + "/" + Integer.toHexString( hashCode() );
251
252
253 }
254
255 private static SimpleDateFormat createNameFormat()
256 {
257 SimpleDateFormat fmt = new SimpleDateFormat( TIMESTAMP_FORMAT );
258 fmt.setTimeZone( UTC_TIME_ZONE );
259 return fmt;
260 }
261
262 @Override
263 public Map<String, String> toProperties()
264 {
265 Map<String, String> properties = new HashMap<>();
266 properties.put( "action", this.action );
267 if ( this.userId != null )
268 {
269 properties.put( "user", this.userId );
270 }
271 if ( this.remoteIP != null )
272 {
273 properties.put( "remoteIP", this.remoteIP );
274 }
275 if ( this.resource != null )
276 {
277 properties.put( "resource", this.resource );
278 }
279 return properties;
280 }
281
282 @Override
283 public void fromProperties( Map<String, String> properties )
284 {
285 this.action = properties.get( "action" );
286 this.remoteIP = properties.get( "remoteIP" );
287 this.userId = properties.get( "user" );
288 this.resource = properties.get( "resource" );
289 }
290
291 @Override
292 public boolean equals( Object o )
293 {
294 if ( this == o )
295 {
296 return true;
297 }
298 if ( o == null || getClass() != o.getClass() )
299 {
300 return false;
301 }
302
303 AuditEvent that = (AuditEvent) o;
304
305 if ( !action.equals( that.action ) )
306 {
307 return false;
308 }
309 if ( remoteIP != null ? !remoteIP.equals( that.remoteIP ) : that.remoteIP != null )
310 {
311 return false;
312 }
313 if ( repositoryId != null ? !repositoryId.equals( that.repositoryId ) : that.repositoryId != null )
314 {
315 return false;
316 }
317 if ( resource != null ? !resource.equals( that.resource ) : that.resource != null )
318 {
319 return false;
320 }
321 if ( !timestamp.equals( that.timestamp ) )
322 {
323 return false;
324 }
325 if ( userId != null ? !userId.equals( that.userId ) : that.userId != null )
326 {
327 return false;
328 }
329
330 return true;
331 }
332
333 @Override
334 public int hashCode()
335 {
336 int result = repositoryId != null ? repositoryId.hashCode() : 0;
337 result = 31 * result + ( userId != null ? userId.hashCode() : 0 );
338 result = 31 * result + ( remoteIP != null ? remoteIP.hashCode() : 0 );
339 result = 31 * result + ( resource != null ? resource.hashCode() : 0 );
340 result = 31 * result + action.hashCode();
341 result = 31 * result + timestamp.hashCode();
342 return result;
343 }
344
345 @Override
346 public String toString()
347 {
348 final StringBuilder sb = new StringBuilder();
349 sb.append( "AuditEvent" );
350 sb.append( "{repositoryId='" ).append( repositoryId ).append( '\'' );
351 sb.append( ", userId='" ).append( userId ).append( '\'' );
352 sb.append( ", remoteIP='" ).append( remoteIP ).append( '\'' );
353 sb.append( ", resource='" ).append( resource ).append( '\'' );
354 sb.append( ", action='" ).append( action ).append( '\'' );
355 sb.append( ", timestamp=" ).append( timestamp );
356 sb.append( '}' );
357 return sb.toString();
358 }
359
360
361 }