001    /*
002     * CDDL HEADER START
003     *
004     * The contents of this file are subject to the terms of the
005     * Common Development and Distribution License, Version 1.0 only
006     * (the "License").  You may not use this file except in compliance
007     * with the License.
008     *
009     * You can obtain a copy of the license at
010     * docs/licenses/cddl.txt
011     * or http://www.opensource.org/licenses/cddl1.php.
012     * See the License for the specific language governing permissions
013     * and limitations under the License.
014     *
015     * When distributing Covered Code, include this CDDL HEADER in each
016     * file and include the License file at
017     * docs/licenses/cddl.txt.  If applicable,
018     * add the following below this CDDL HEADER, with the fields enclosed
019     * by brackets "[]" replaced with your own identifying information:
020     *      Portions Copyright [yyyy] [name of copyright owner]
021     *
022     * CDDL HEADER END
023     *
024     *
025     *      Copyright 2010-2013 UnboundID Corp.
026     */
027    package com.unboundid.directory.sdk.common.scripting;
028    
029    
030    
031    import java.security.cert.Certificate;
032    import java.util.List;
033    
034    import com.unboundid.directory.sdk.common.config.AccessLoggerConfig;
035    import com.unboundid.directory.sdk.common.internal.Reconfigurable;
036    import com.unboundid.directory.sdk.common.operation.AbandonRequest;
037    import com.unboundid.directory.sdk.common.operation.AddRequest;
038    import com.unboundid.directory.sdk.common.operation.AddResult;
039    import com.unboundid.directory.sdk.common.operation.BindResult;
040    import com.unboundid.directory.sdk.common.operation.CompareRequest;
041    import com.unboundid.directory.sdk.common.operation.CompareResult;
042    import com.unboundid.directory.sdk.common.operation.DeleteRequest;
043    import com.unboundid.directory.sdk.common.operation.DeleteResult;
044    import com.unboundid.directory.sdk.common.operation.ExtendedRequest;
045    import com.unboundid.directory.sdk.common.operation.ExtendedResult;
046    import com.unboundid.directory.sdk.common.operation.GenericResult;
047    import com.unboundid.directory.sdk.common.operation.ModifyRequest;
048    import com.unboundid.directory.sdk.common.operation.ModifyResult;
049    import com.unboundid.directory.sdk.common.operation.ModifyDNRequest;
050    import com.unboundid.directory.sdk.common.operation.ModifyDNResult;
051    import com.unboundid.directory.sdk.common.operation.SASLBindRequest;
052    import com.unboundid.directory.sdk.common.operation.SearchRequest;
053    import com.unboundid.directory.sdk.common.operation.SearchResult;
054    import com.unboundid.directory.sdk.common.operation.SimpleBindRequest;
055    import com.unboundid.directory.sdk.common.operation.UnbindRequest;
056    import com.unboundid.directory.sdk.common.types.ClientContext;
057    import com.unboundid.directory.sdk.common.types.CompletedOperationContext;
058    import com.unboundid.directory.sdk.common.types.CompletedSearchOperationContext;
059    import com.unboundid.directory.sdk.common.types.DisconnectReason;
060    import com.unboundid.directory.sdk.common.types.Entry;
061    import com.unboundid.directory.sdk.common.types.ForwardTarget;
062    import com.unboundid.directory.sdk.common.types.OperationContext;
063    import com.unboundid.directory.sdk.common.types.ServerContext;
064    import com.unboundid.directory.sdk.ds.internal.DirectoryServerExtension;
065    import com.unboundid.directory.sdk.proxy.internal.DirectoryProxyServerExtension;
066    import com.unboundid.directory.sdk.sync.internal.SynchronizationServerExtension;
067    import com.unboundid.ldap.sdk.Control;
068    import com.unboundid.ldap.sdk.IntermediateResponse;
069    import com.unboundid.ldap.sdk.LDAPException;
070    import com.unboundid.ldap.sdk.ResultCode;
071    import com.unboundid.util.Extensible;
072    import com.unboundid.util.ThreadSafety;
073    import com.unboundid.util.ThreadSafetyLevel;
074    import com.unboundid.util.args.ArgumentException;
075    import com.unboundid.util.args.ArgumentParser;
076    
077    
078    
079    /**
080     * This class defines an API that must be implemented by scripted extensions
081     * which record information about interaction with clients, including
082     * connections established and received and operations requested and completed.
083     * <BR><BR>
084     * Access loggers will be invoked for the following events:
085     * <UL>
086     *   <LI>Whenever a new connection is established.</LI>
087     *   <LI>Whenever an existing connection is closed or terminated.</LI>
088     *   <LI>Whenever an abandon, add, bind, compare, delete, extended, modify,
089     *       modify DN, search, or unbind request is received.</LI>
090     *   <LI>Whenever an abandon, add, bind, compare, delete, extended, modify,
091     *       modify DN, or search request is forwarded to another server for
092     *       processing.</LI>
093     *   <LI>If a forwarded add, bind, compare, delete, extended, modify, modify DN,
094     *       or search operation fails.</LI>
095     *   <LI>After sending the result for an add, bind, compare, delete, extended,
096     *       modify, modify DN, or search operation.</LI>
097     *   <LI>After completing processing for an abandon operation.</LI>
098     *   <LI>After sending a search result entry, search result reference, or
099     *       intermediate response message to the client.</LI>
100     * </UL>
101     * <BR><BR>
102     * Each access logger may configured to indicate whether to include or exclude
103     * internal and/or replicated operations, and criteria may be used to provide
104     * filtered logging.  This is handled automatically by the server, so individual
105     * access logger implementations do not need to attempt to perform that
106     * filtering on their own.  However, they may perform additional processing if
107     * desired to further narrow the set of messages that should be logged.
108     * <BR>
109     * <H2>Configuring Groovy-Scripted Access Loggers</H2>
110     * In order to configure a scripted access logger based on this API and written
111     * in the Groovy scripting language, use a command
112     * like:
113     * <PRE>
114     *      dsconfig create-log-publisher \
115     *           --publisher-name "<I>{logger-name}</I>" \
116     *           --type groovy-scripted-access \
117     *           --set enabled:true \
118     *           --set "script-class:<I>{class-name}</I>" \
119     *           --set "script-argument:<I>{name=value}</I>"
120     * </PRE>
121     * where "<I>{logger-name}</I>" is the name to use for the access logger
122     * instance, "<I>{class-name}</I>" is the fully-qualified name of the Groovy
123     * class written using this API, and "<I>{name=value}</I>" represents name-value
124     * pairs for any arguments to provide to the logger.  If multiple arguments
125     * should be provided to the logger, then the
126     * "<CODE>--set script-argument:<I>{name=value}</I></CODE>" option should be
127     * provided multiple times.
128     *
129     * @see  com.unboundid.directory.sdk.common.api.AccessLogger
130     * @see  com.unboundid.directory.sdk.common.api.FileBasedAccessLogger
131     * @see  ScriptedFileBasedAccessLogger
132     */
133    @Extensible()
134    @DirectoryServerExtension()
135    @DirectoryProxyServerExtension(appliesToLocalContent=true,
136         appliesToRemoteContent=false)
137    @SynchronizationServerExtension(appliesToLocalContent=true,
138         appliesToSynchronizedContent=false)
139    @ThreadSafety(level=ThreadSafetyLevel.INTERFACE_THREADSAFE)
140    public abstract class ScriptedAccessLogger
141           implements Reconfigurable<AccessLoggerConfig>
142    {
143      /**
144       * Creates a new instance of this access logger.  All access logger
145       * implementations must include a default constructor, but any initialization
146       * should generally be done in the {@code initializeAccessLogger} method.
147       */
148      public ScriptedAccessLogger()
149      {
150        // No implementation is required.
151      }
152    
153    
154    
155      /**
156       * {@inheritDoc}
157       */
158      public void defineConfigArguments(final ArgumentParser parser)
159             throws ArgumentException
160      {
161        // No arguments will be allowed by default.
162      }
163    
164    
165    
166      /**
167       * Initializes this access logger.
168       *
169       * @param  serverContext  A handle to the server context for the server in
170       *                        which this extension is running.
171       * @param  config         The general configuration for this access logger.
172       * @param  parser         The argument parser which has been initialized from
173       *                        the configuration for this access logger.
174       *
175       * @throws  LDAPException  If a problem occurs while initializing this
176       *                         access logger.
177       */
178      public void initializeAccessLogger(final ServerContext serverContext,
179                                         final AccessLoggerConfig config,
180                                         final ArgumentParser parser)
181             throws LDAPException
182      {
183        // No initialization will be performed by default.
184      }
185    
186    
187    
188      /**
189       * Performs any cleanup which may be necessary when this access logger is to
190       * be taken out of service.
191       */
192      public void finalizeAccessLogger()
193      {
194        // No implementation is required.
195      }
196    
197    
198    
199      /**
200       * {@inheritDoc}
201       */
202      public boolean isConfigurationAcceptable(final AccessLoggerConfig config,
203                          final ArgumentParser parser,
204                          final List<String> unacceptableReasons)
205      {
206        // No extended validation will be performed.
207        return true;
208      }
209    
210    
211    
212      /**
213       * {@inheritDoc}
214       */
215      public ResultCode applyConfiguration(final AccessLoggerConfig config,
216                                           final ArgumentParser parser,
217                                           final List<String> adminActionsRequired,
218                                           final List<String> messages)
219      {
220        // By default, no configuration changes will be applied.  If there are any
221        // arguments, then add an admin action message indicating that the extension
222        // needs to be restarted for any changes to take effect.
223        if (! parser.getNamedArguments().isEmpty())
224        {
225          adminActionsRequired.add(
226               "No configuration change has actually been applied.  The new " +
227                    "configuration will not take effect until this access logger " +
228                    "is disabled and re-enabled or until the server is restarted.");
229        }
230    
231        return ResultCode.SUCCESS;
232      }
233    
234    
235    
236      /**
237       * Logs a message indicating that a new connection has been established.
238       *
239       * @param  clientContext  Information about the client connection that has
240       *                        been accepted.
241       */
242      public void logConnect(final ClientContext clientContext)
243      {
244        // No action will be taken by default.
245      }
246    
247    
248    
249      /**
250       * Logs a message indicating that a connection has been closed.
251       *
252       * @param  clientContext     Information about the client connection that has
253       *                           been closed.
254       * @param  disconnectReason  A general reason that the connection has been
255       *                           closed.
256       * @param  message           A message with additional information about the
257       *                           closure.  It may be {@code null} if none is
258       *                           available.
259       */
260      public void logDisconnect(final ClientContext clientContext,
261                                final DisconnectReason disconnectReason,
262                                final String message)
263      {
264        // No action will be taken by default.
265      }
266    
267    
268    
269      /**
270       * Logs a message about a certificate chain presented by a client.
271       *
272       * @param  clientContext  Information about the client that presented the
273       *                        certificate chain.
274       * @param  certChain      The certificate chain presented by the client.
275       * @param  authDN         The DN of the user as whom the client was
276       *                        automatically authenticated, or {@code null} if the
277       *                        client was not automatically authenticated.
278       */
279      public void logClientCertificateChain(final ClientContext clientContext,
280                                            final Certificate[] certChain,
281                                            final String authDN)
282      {
283        // No action will be taken by default.
284      }
285    
286    
287    
288      /**
289       * Logs a message about an abandon request received from a client.
290       *
291       * @param  opContext  The operation context for the abandon operation.
292       * @param  request    The abandon request that was received.
293       */
294      public void logAbandonRequest(final OperationContext opContext,
295                                    final AbandonRequest request)
296      {
297        // No action will be taken by default.
298      }
299    
300    
301    
302      /**
303       * Logs a message about an abandon request that will be forwarded to another
304       * server.
305       *
306       * @param  opContext  The operation context for the abandon operation.
307       * @param  request    The abandon request that was received.
308       * @param  target     Information about the server to which the request will
309       *                    be forwarded.
310       */
311      public void logAbandonForward(final OperationContext opContext,
312                                    final AbandonRequest request,
313                                    final ForwardTarget target)
314      {
315        // No action will be taken by default.
316      }
317    
318    
319    
320      /**
321       * Logs a message about the result of processing an abandon request.
322       *
323       * @param  opContext  The operation context for the abandon operation.
324       * @param  request    The abandon request that was received.
325       * @param  result     The result of processing the abandon request.
326       */
327      public void logAbandonResult(final CompletedOperationContext opContext,
328                                   final AbandonRequest request,
329                                   final GenericResult result)
330      {
331        // No action will be taken by default.
332      }
333    
334    
335    
336      /**
337       * Logs a message about an add request received from a client.
338       *
339       * @param  opContext  The operation context for the add operation.
340       * @param  request    The add request that was received.
341       */
342      public void logAddRequest(final OperationContext opContext,
343                                final AddRequest request)
344      {
345        // No action will be taken by default.
346      }
347    
348    
349    
350      /**
351       * Logs a message about an add request that will be forwarded to another
352       * server.
353       *
354       * @param  opContext  The operation context for the add operation.
355       * @param  request    The add request that was received.
356       * @param  target     Information about the server to which the request will
357       *                    be forwarded.
358       */
359      public void logAddForward(final OperationContext opContext,
360                                final AddRequest request,
361                                final ForwardTarget target)
362      {
363        // No action will be taken by default.
364      }
365    
366    
367    
368      /**
369       * Logs a message about a failure encountered while attempting to forward an
370       * add request to another server.
371       *
372       * @param  opContext  The operation context for the add operation.
373       * @param  request    The add request that was received.
374       * @param  target     Information about the server to which the request was
375       *                    forwarded.
376       * @param  failure    The exception that was received when attempting to
377       *                    forward the request.
378       */
379      public void logAddForwardFailure(final OperationContext opContext,
380                                       final AddRequest request,
381                                       final ForwardTarget target,
382                                       final LDAPException failure)
383      {
384        // No action will be taken by default.
385      }
386    
387    
388    
389      /**
390       * Logs a message about the result of processing an add request.
391       *
392       * @param  opContext  The operation context for the add operation.
393       * @param  request    The add request that was received.
394       * @param  result     The result of processing the add request.
395       */
396      public void logAddResponse(final CompletedOperationContext opContext,
397                                 final AddRequest request,
398                                 final AddResult result)
399      {
400        // No action will be taken by default.
401      }
402    
403    
404    
405      /**
406       * Logs a message about a simple bind request received from a client.
407       *
408       * @param  opContext  The operation context for the bind operation.
409       * @param  request    The bind request that was received.
410       */
411      public void logBindRequest(final OperationContext opContext,
412                                 final SimpleBindRequest request)
413      {
414        // No action will be taken by default.
415      }
416    
417    
418    
419      /**
420       * Logs a message about a simple bind request that will be forwarded to
421       * another server.
422       *
423       * @param  opContext  The operation context for the bind operation.
424       * @param  request    The bind request that was received.
425       * @param  target     Information about the server to which the request will
426       *                    be forwarded.
427       */
428      public void logBindForward(final OperationContext opContext,
429                                    final SimpleBindRequest request,
430                                    final ForwardTarget target)
431      {
432        // No action will be taken by default.
433      }
434    
435    
436    
437      /**
438       * Logs a message about a failure encountered while attempting to forward a
439       * simple bind request to another server.
440       *
441       * @param  opContext  The operation context for the bind operation.
442       * @param  request    The bind request that was received.
443       * @param  target     Information about the server to which the request was
444       *                    forwarded.
445       * @param  failure    The exception that was received when attempting to
446       *                    forward the request.
447       */
448      public void logBindForwardFailure(final OperationContext opContext,
449                                        final SimpleBindRequest request,
450                                        final ForwardTarget target,
451                                        final LDAPException failure)
452      {
453        // No action will be taken by default.
454      }
455    
456    
457    
458      /**
459       * Logs a message about the result of processing a simple bind request.
460       *
461       * @param  opContext  The operation context for the bind operation.
462       * @param  request    The bind request that was received.
463       * @param  result     The result of processing the bind request.
464       */
465      public void logBindResponse(final CompletedOperationContext opContext,
466                                  final SimpleBindRequest request,
467                                  final BindResult result)
468      {
469        // No action will be taken by default.
470      }
471    
472    
473    
474      /**
475       * Logs a message about a SASL bind request received from a client.
476       *
477       * @param  opContext  The operation context for the bind operation.
478       * @param  request    The bind request that was received.
479       */
480      public void logBindRequest(final OperationContext opContext,
481                                 final SASLBindRequest request)
482      {
483        // No action will be taken by default.
484      }
485    
486    
487    
488      /**
489       * Logs a message about a SASL bind request that will be forwarded to
490       * another server.
491       *
492       * @param  opContext  The operation context for the bind operation.
493       * @param  request    The bind request that was received.
494       * @param  target     Information about the server to which the request will
495       *                    be forwarded.
496       */
497      public void logBindForward(final OperationContext opContext,
498                                    final SASLBindRequest request,
499                                    final ForwardTarget target)
500      {
501        // No action will be taken by default.
502      }
503    
504    
505    
506      /**
507       * Logs a message about a failure encountered while attempting to forward a
508       * SASL bind request to another server.
509       *
510       * @param  opContext  The operation context for the bind operation.
511       * @param  request    The bind request that was received.
512       * @param  target     Information about the server to which the request was
513       *                    forwarded.
514       * @param  failure    The exception that was received when attempting to
515       *                    forward the request.
516       */
517      public void logBindForwardFailure(final OperationContext opContext,
518                                        final SASLBindRequest request,
519                                        final ForwardTarget target,
520                                        final LDAPException failure)
521      {
522        // No action will be taken by default.
523      }
524    
525    
526    
527      /**
528       * Logs a message about the result of processing a SASL bind request.
529       *
530       * @param  opContext  The operation context for the bind operation.
531       * @param  request    The bind request that was received.
532       * @param  result     The result of processing the bind request.
533       */
534      public void logBindResponse(final CompletedOperationContext opContext,
535                                  final SASLBindRequest request,
536                                  final BindResult result)
537      {
538        // No action will be taken by default.
539      }
540    
541    
542    
543      /**
544       * Logs a message about a compare request received from a client.
545       *
546       * @param  opContext  The operation context for the compare operation.
547       * @param  request    The compare request that was received.
548       */
549      public void logCompareRequest(final OperationContext opContext,
550                                    final CompareRequest request)
551      {
552        // No action will be taken by default.
553      }
554    
555    
556    
557      /**
558       * Logs a message about a compare request that will be forwarded to another
559       * server.
560       *
561       * @param  opContext  The operation context for the compare operation.
562       * @param  request    The compare request that was received.
563       * @param  target     Information about the server to which the request will
564       *                    be forwarded.
565       */
566      public void logCompareForward(final OperationContext opContext,
567                                    final CompareRequest request,
568                                    final ForwardTarget target)
569      {
570        // No action will be taken by default.
571      }
572    
573    
574    
575      /**
576       * Logs a message about a failure encountered while attempting to forward a
577       * compare request to another server.
578       *
579       * @param  opContext  The operation context for the compare operation.
580       * @param  request    The compare request that was received.
581       * @param  target     Information about the server to which the request was
582       *                    forwarded.
583       * @param  failure    The exception that was received when attempting to
584       *                    forward the request.
585       */
586      public void logCompareForwardFailure(final OperationContext opContext,
587                                           final CompareRequest request,
588                                           final ForwardTarget target,
589                                           final LDAPException failure)
590      {
591        // No action will be taken by default.
592      }
593    
594    
595    
596      /**
597       * Logs a message about the result of processing a compare request.
598       *
599       * @param  opContext  The operation context for the compare operation.
600       * @param  request    The compare request that was received.
601       * @param  result     The result of processing the compare request.
602       */
603      public void logCompareResponse(final CompletedOperationContext opContext,
604                                     final CompareRequest request,
605                                     final CompareResult result)
606      {
607        // No action will be taken by default.
608      }
609    
610    
611    
612      /**
613       * Logs a message about a delete request received from a client.
614       *
615       * @param  opContext  The operation context for the delete operation.
616       * @param  request    The delete request that was received.
617       */
618      public void logDeleteRequest(final OperationContext opContext,
619                                   final DeleteRequest request)
620      {
621        // No action will be taken by default.
622      }
623    
624    
625    
626      /**
627       * Logs a message about a delete request that will be forwarded to another
628       * server.
629       *
630       * @param  opContext  The operation context for the delete operation.
631       * @param  request    The delete request that was received.
632       * @param  target     Information about the server to which the request will
633       *                    be forwarded.
634       */
635      public void logDeleteForward(final OperationContext opContext,
636                                   final DeleteRequest request,
637                                   final ForwardTarget target)
638      {
639        // No action will be taken by default.
640      }
641    
642    
643    
644      /**
645       * Logs a message about a failure encountered while attempting to forward a
646       * delete request to another server.
647       *
648       * @param  opContext  The operation context for the delete operation.
649       * @param  request    The delete request that was received.
650       * @param  target     Information about the server to which the request was
651       *                    forwarded.
652       * @param  failure    The exception that was received when attempting to
653       *                    forward the request.
654       */
655      public void logDeleteForwardFailure(final OperationContext opContext,
656                                          final DeleteRequest request,
657                                          final ForwardTarget target,
658                                          final LDAPException failure)
659      {
660        // No action will be taken by default.
661      }
662    
663    
664    
665      /**
666       * Logs a message about the result of processing a delete request.
667       *
668       * @param  opContext  The operation context for the delete operation.
669       * @param  request    The delete request that was received.
670       * @param  result     The result of processing the delete request.
671       */
672      public void logDeleteResponse(final CompletedOperationContext opContext,
673                                    final DeleteRequest request,
674                                    final DeleteResult result)
675      {
676        // No action will be taken by default.
677      }
678    
679    
680    
681      /**
682       * Logs a message about an extended request received from a client.
683       *
684       * @param  opContext  The operation context for the extended operation.
685       * @param  request    The extended request that was received.
686       */
687      public void logExtendedRequest(final OperationContext opContext,
688                                     final ExtendedRequest request)
689      {
690        // No action will be taken by default.
691      }
692    
693    
694    
695      /**
696       * Logs a message about an extended request that will be forwarded to another
697       * server.
698       *
699       * @param  opContext  The operation context for the extended operation.
700       * @param  request    The extended request that was received.
701       * @param  target     Information about the server to which the request will
702       *                    be forwarded.
703       */
704      public void logExtendedForward(final OperationContext opContext,
705                                     final ExtendedRequest request,
706                                     final ForwardTarget target)
707      {
708        // No action will be taken by default.
709      }
710    
711    
712    
713      /**
714       * Logs a message about a failure encountered while attempting to forward an
715       * extended request to another server.
716       *
717       * @param  opContext  The operation context for the extended operation.
718       * @param  request    The extended request that was received.
719       * @param  target     Information about the server to which the request was
720       *                    forwarded.
721       * @param  failure    The exception that was received when attempting to
722       *                    forward the request.
723       */
724      public void logExtendedForwardFailure(final OperationContext opContext,
725                                            final ExtendedRequest request,
726                                            final ForwardTarget target,
727                                            final LDAPException failure)
728      {
729        // No action will be taken by default.
730      }
731    
732    
733    
734      /**
735       * Logs a message about the result of processing an extended request.
736       *
737       * @param  opContext  The operation context for the extended operation.
738       * @param  request    The extended request that was received.
739       * @param  result     The result of processing the extended request.
740       */
741      public void logExtendedResponse(final CompletedOperationContext opContext,
742                                      final ExtendedRequest request,
743                                      final ExtendedResult result)
744      {
745        // No action will be taken by default.
746      }
747    
748    
749    
750      /**
751       * Logs a message about a modify request received from a client.
752       *
753       * @param  opContext  The operation context for the modify operation.
754       * @param  request    The modify request that was received.
755       */
756      public void logModifyRequest(final OperationContext opContext,
757                                   final ModifyRequest request)
758      {
759        // No action will be taken by default.
760      }
761    
762    
763    
764      /**
765       * Logs a message about a modify request that will be forwarded to another
766       * server.
767       *
768       * @param  opContext  The operation context for the modify operation.
769       * @param  request    The modify request that was received.
770       * @param  target     Information about the server to which the request will
771       *                    be forwarded.
772       */
773      public void logModifyForward(final OperationContext opContext,
774                                   final ModifyRequest request,
775                                   final ForwardTarget target)
776      {
777        // No action will be taken by default.
778      }
779    
780    
781    
782      /**
783       * Logs a message about a failure encountered while attempting to forward a
784       * modify request to another server.
785       *
786       * @param  opContext  The operation context for the modify operation.
787       * @param  request    The modify request that was received.
788       * @param  target     Information about the server to which the request was
789       *                    forwarded.
790       * @param  failure    The exception that was received when attempting to
791       *                    forward the request.
792       */
793      public void logModifyForwardFailure(final OperationContext opContext,
794                                          final ModifyRequest request,
795                                          final ForwardTarget target,
796                                          final LDAPException failure)
797      {
798        // No action will be taken by default.
799      }
800    
801    
802    
803      /**
804       * Logs a message about the result of processing a modify request.
805       *
806       * @param  opContext  The operation context for the modify operation.
807       * @param  request    The modify request that was received.
808       * @param  result     The result of processing the modify request.
809       */
810      public void logModifyResponse(final CompletedOperationContext opContext,
811                                    final ModifyRequest request,
812                                    final ModifyResult result)
813      {
814        // No action will be taken by default.
815      }
816    
817    
818    
819      /**
820       * Logs a message about a modify DN request received from a client.
821       *
822       * @param  opContext  The operation context for the modify DN operation.
823       * @param  request    The modify DN request that was received.
824       */
825      public void logModifyDNRequest(final OperationContext opContext,
826                                     final ModifyDNRequest request)
827      {
828        // No action will be taken by default.
829      }
830    
831    
832    
833      /**
834       * Logs a message about a modify DN request that will be forwarded to another
835       * server.
836       *
837       * @param  opContext  The operation context for the modify DN operation.
838       * @param  request    The modify DN request that was received.
839       * @param  target     Information about the server to which the request will
840       *                    be forwarded.
841       */
842      public void logModifyDNForward(final OperationContext opContext,
843                                     final ModifyDNRequest request,
844                                     final ForwardTarget target)
845      {
846        // No action will be taken by default.
847      }
848    
849    
850    
851      /**
852       * Logs a message about a failure encountered while attempting to forward a
853       * modify DN request to another server.
854       *
855       * @param  opContext  The operation context for the modify DN operation.
856       * @param  request    The modify DN request that was received.
857       * @param  target     Information about the server to which the request was
858       *                    forwarded.
859       * @param  failure    The exception that was received when attempting to
860       *                    forward the request.
861       */
862      public void logModifyDNForwardFailure(final OperationContext opContext,
863                                            final ModifyDNRequest request,
864                                            final ForwardTarget target,
865                                            final LDAPException failure)
866      {
867        // No action will be taken by default.
868      }
869    
870    
871    
872      /**
873       * Logs a message about the result of processing a modify DN request.
874       *
875       * @param  opContext  The operation context for the modify DN operation.
876       * @param  request    The modify DN request that was received.
877       * @param  result     The result of processing the modify DN request.
878       */
879      public void logModifyDNResponse(final CompletedOperationContext opContext,
880                                      final ModifyDNRequest request,
881                                      final ModifyDNResult result)
882      {
883        // No action will be taken by default.
884      }
885    
886    
887    
888      /**
889       * Logs a message about a search request received from a client.
890       *
891       * @param  opContext  The operation context for the search operation.
892       * @param  request    The search request that was received.
893       */
894      public void logSearchRequest(final OperationContext opContext,
895                                   final SearchRequest request)
896      {
897        // No action will be taken by default.
898      }
899    
900    
901    
902      /**
903       * Logs a message about a search request that will be forwarded to another
904       * server.
905       *
906       * @param  opContext  The operation context for the search operation.
907       * @param  request    The search request that was received.
908       * @param  target     Information about the server to which the request will
909       *                    be forwarded.
910       */
911      public void logSearchForward(final OperationContext opContext,
912                                   final SearchRequest request,
913                                   final ForwardTarget target)
914      {
915        // No action will be taken by default.
916      }
917    
918    
919    
920      /**
921       * Logs a message about a failure encountered while attempting to forward a
922       * search request to another server.
923       *
924       * @param  opContext  The operation context for the search operation.
925       * @param  request    The search request that was received.
926       * @param  target     Information about the server to which the request was
927       *                    forwarded.
928       * @param  failure    The exception that was received when attempting to
929       *                    forward the request.
930       */
931      public void logSearchForwardFailure(final OperationContext opContext,
932                                          final SearchRequest request,
933                                          final ForwardTarget target,
934                                          final LDAPException failure)
935      {
936        // No action will be taken by default.
937      }
938    
939    
940    
941      /**
942       * Logs a message about a search result entry that was returned to the client.
943       *
944       * @param  opContext  The operation context for the search operation.
945       * @param  request    The search request that was received.
946       * @param  entry      The entry that was returned.
947       * @param  controls   The set of controls included with the entry, or an empty
948       *                    list if there were none.
949       */
950      public void logSearchResultEntry(final OperationContext opContext,
951                                       final SearchRequest request,
952                                       final Entry entry,
953                                       final List<Control> controls)
954      {
955        // No action will be taken by default.
956      }
957    
958    
959    
960      /**
961       * Logs a message about a search result reference that was returned to the
962       * client.
963       *
964       * @param  opContext     The operation context for the search operation.
965       * @param  request       The search request that was received.
966       * @param  referralURLs  The referral URLs for the reference that was
967       *                       returned.
968       * @param  controls      The set of controls included with the reference, or
969       *                       an empty list if there were none.
970       */
971      public void logSearchResultReference(final OperationContext opContext,
972                                           final SearchRequest request,
973                                           final List<String> referralURLs,
974                                           final List<Control> controls)
975      {
976        // No action will be taken by default.
977      }
978    
979    
980    
981      /**
982       * Logs a message about the result of processing a search request.
983       *
984       * @param  opContext  The operation context for the search operation.
985       * @param  request    The search request that was received.
986       * @param  result     The result of processing the search request.
987       */
988      public void logSearchResultDone(
989                       final CompletedSearchOperationContext opContext,
990                       final SearchRequest request, final SearchResult result)
991      {
992        // No action will be taken by default.
993      }
994    
995    
996    
997      /**
998       * Logs a message about an unbind request received from a client.
999       *
1000       * @param  opContext  The operation context for the unbind operation.
1001       * @param  request    The unbind request that was received.
1002       */
1003      public void logUnbindRequest(final OperationContext opContext,
1004                                   final UnbindRequest request)
1005      {
1006        // No action will be taken by default.
1007      }
1008    
1009    
1010    
1011      /**
1012       * Logs a message about an intermediate response that was returned to the
1013       * client.
1014       *
1015       * @param  opContext             The operation context for the associated
1016       *                               operation.
1017       * @param  intermediateResponse  The intermediate response that was returned.
1018       */
1019      public void logIntermediateResponse(final OperationContext opContext,
1020                       final IntermediateResponse intermediateResponse)
1021      {
1022        // No action will be taken by default.
1023      }
1024    }