1package org.apache.archiva.audit;
23/*4 * Licensed to the Apache Software Foundation (ASF) under one5 * or more contributor license agreements. See the NOTICE file6 * distributed with this work for additional information7 * regarding copyright ownership. The ASF licenses this file8 * to you under the Apache License, Version 2.0 (the9 * "License"); you may not use this file except in compliance10 * with the License. You may obtain a copy of the License at11 *12 * http://www.apache.org/licenses/LICENSE-2.013 *14 * Unless required by applicable law or agreed to in writing,15 * software distributed under the License is distributed on an16 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY17 * KIND, either express or implied. See the License for the18 * specific language governing permissions and limitations19 * under the License.20 */2122import org.apache.archiva.metadata.model.facets.AuditEvent;
23import org.apache.archiva.repository.events.AuditListener;
24import org.slf4j.Logger;
25import org.slf4j.LoggerFactory;
26import org.springframework.stereotype.Service;
2728/**29 * AuditLog - Audit Log.30 * 31 *32 *33 */34 @Service("auditListener#logging")
35publicclassAuditLog36implementsAuditListener37 {
38publicstaticfinal Logger logger = LoggerFactory.getLogger( "org.apache.archiva.AuditLog" );
3940privatestaticfinal String NONE = "-";
4142privatestaticfinalchar DELIM = ' ';
4344/**45 * Creates a log message in the following format ...46 * "{repository_id} {user_id} {remote_ip} \"{resource}\" \"{action}\""47 */48 @Override
49publicvoid auditEvent( AuditEvent event )
50 {
51 StringBuilder msg = new StringBuilder();
52 msg.append( checkNull( event.getRepositoryId() ) ).append( DELIM );
53 msg.append( event.getUserId() ).append( DELIM );
54 msg.append( checkNull( event.getRemoteIP() ) ).append( DELIM );
55 msg.append( '\"' ).append( checkNull( event.getResource() ) ).append( '\"' ).append( DELIM );
56 msg.append( '\"' ).append( event.getAction() ).append( '\"' );
57 logger.info( msg.toString() );
58 }
5960private String checkNull( String s )
61 {
62return s != null ? s : NONE;
63 }
64 }