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-2017 Ping Identity Corporation
026 */
027package com.unboundid.directory.sdk.common.scripting;
028
029
030
031import java.security.cert.Certificate;
032import java.util.List;
033import java.util.Map;
034
035import com.unboundid.directory.sdk.broker.internal.BrokerExtension;
036import com.unboundid.directory.sdk.common.config.FileBasedAccessLoggerConfig;
037import com.unboundid.directory.sdk.common.internal.Reconfigurable;
038import com.unboundid.directory.sdk.common.operation.AbandonRequest;
039import com.unboundid.directory.sdk.common.operation.AddRequest;
040import com.unboundid.directory.sdk.common.operation.AddResult;
041import com.unboundid.directory.sdk.common.operation.BindResult;
042import com.unboundid.directory.sdk.common.operation.CompareRequest;
043import com.unboundid.directory.sdk.common.operation.CompareResult;
044import com.unboundid.directory.sdk.common.operation.DeleteRequest;
045import com.unboundid.directory.sdk.common.operation.DeleteResult;
046import com.unboundid.directory.sdk.common.operation.ExtendedRequest;
047import com.unboundid.directory.sdk.common.operation.ExtendedResult;
048import com.unboundid.directory.sdk.common.operation.GenericResult;
049import com.unboundid.directory.sdk.common.operation.ModifyRequest;
050import com.unboundid.directory.sdk.common.operation.ModifyResult;
051import com.unboundid.directory.sdk.common.operation.ModifyDNRequest;
052import com.unboundid.directory.sdk.common.operation.ModifyDNResult;
053import com.unboundid.directory.sdk.common.operation.SASLBindRequest;
054import com.unboundid.directory.sdk.common.operation.SearchRequest;
055import com.unboundid.directory.sdk.common.operation.SearchResult;
056import com.unboundid.directory.sdk.common.operation.SimpleBindRequest;
057import com.unboundid.directory.sdk.common.operation.UnbindRequest;
058import com.unboundid.directory.sdk.common.types.AssuredReplicationResult;
059import com.unboundid.directory.sdk.common.types.ClientContext;
060import com.unboundid.directory.sdk.common.types.CompletedOperationContext;
061import com.unboundid.directory.sdk.common.types.CompletedSearchOperationContext;
062import com.unboundid.directory.sdk.common.types.DisconnectReason;
063import com.unboundid.directory.sdk.common.types.Entry;
064import com.unboundid.directory.sdk.common.types.ForwardTarget;
065import com.unboundid.directory.sdk.common.types.OperationContext;
066import com.unboundid.directory.sdk.common.types.ServerContext;
067import com.unboundid.directory.sdk.ds.internal.DirectoryServerExtension;
068import com.unboundid.directory.sdk.metrics.internal.MetricsEngineExtension;
069import com.unboundid.directory.sdk.proxy.internal.DirectoryProxyServerExtension;
070import com.unboundid.directory.sdk.sync.internal.SynchronizationServerExtension;
071import com.unboundid.ldap.sdk.Control;
072import com.unboundid.ldap.sdk.IntermediateResponse;
073import com.unboundid.ldap.sdk.LDAPException;
074import com.unboundid.ldap.sdk.ResultCode;
075import com.unboundid.ldap.sdk.unboundidds.MoveSubtreeResult;
076import com.unboundid.util.Extensible;
077import com.unboundid.util.ThreadSafety;
078import com.unboundid.util.ThreadSafetyLevel;
079import com.unboundid.util.args.ArgumentException;
080import com.unboundid.util.args.ArgumentParser;
081
082
083
084/**
085 * This class defines an API that may be used to create a specific type of
086 * scripted access logger which is intended to write log messages to text files.
087 * This is a convenience for developers which wish to create custom access
088 * loggers that write to text files and provides support for a wide range of
089 * functionality including high-performance and highly-concurrent logging.  All
090 * of the options available to {@link ScriptedAccessLogger} implementations are
091 * available for file-based access loggers, as well as options for indicating
092 * the log file path, the rotation and retention policies, whether to buffer the
093 * output, etc.
094 * <BR><BR>
095 * Note that scripted file-based access loggers will automatically be registered
096 * within the server as disk space consumers, so there is no need to implement
097 * the {@link com.unboundid.directory.sdk.common.api.DiskSpaceConsumer}
098 * interface.  Also note that configuration change related to the log file
099 * (e.g., the log file path, buffer size, queue size, etc.) will also
100 * automatically be handled by the server, so subclasses only need to be
101 * concerned about changes to the custom arguments they define.
102 * <BR>
103 * <H2>Configuring File-Based Access Loggers</H2>
104 * In order to configure an access logger created using this API, use a command
105 * like:
106 * <PRE>
107 *      dsconfig create-log-publisher \
108 *           --publisher-name "<I>{logger-name}</I>" \
109 *           --type groovy-scripted-file-based-access \
110 *           --set enabled:true \
111 *           --set "log-file:<I>{path}</I>" \
112 *           --set "rotation-policy:<I>{rotation-policy-name}</I>" \
113 *           --set "retention-policy:<I>{retention-policy-name}</I>" \
114 *           --set "script-class:<I>{class-name}</I>" \
115 *           --set "script-argument:<I>{name=value}</I>"
116 * </PRE>
117 * where "<I>{logger-name}</I>" is the name to use for the access logger
118 * instance, "<I>{path}</I>" is the path to the log file to be written,
119 * "<I>{rotation-policy-name}</I>" is the name of the log rotation policy to use
120 * for the log file, "<I>{retention-policy-name}</I>" is the name of the log
121 * retention policy to use for the log file, "<I>{class-name}</I>" is the
122 * fully-qualified name of the Groovy class written using this API, and
123 * "<I>{name=value}</I>" represents name-value pairs for any arguments to
124 * provide to the logger.  If multiple arguments should be provided to the
125 * logger, then the "<CODE>--set script-argument:<I>{name=value}</I></CODE>"
126 * option should be provided multiple times.  It is also possible to specify
127 * multiple log rotation and/or retention policies if desired.
128 *
129 * @see  com.unboundid.directory.sdk.common.api.AccessLogger
130 * @see  com.unboundid.directory.sdk.common.api.FileBasedAccessLogger
131 * @see  ScriptedAccessLogger
132 */
133@Extensible()
134@DirectoryServerExtension()
135@DirectoryProxyServerExtension(appliesToLocalContent=true,
136     appliesToRemoteContent=false)
137@SynchronizationServerExtension(appliesToLocalContent=true,
138     appliesToSynchronizedContent=false)
139@MetricsEngineExtension()
140@BrokerExtension()
141@ThreadSafety(level=ThreadSafetyLevel.INTERFACE_THREADSAFE)
142public abstract class ScriptedFileBasedAccessLogger
143       implements Reconfigurable<FileBasedAccessLoggerConfig>
144{
145  /**
146   * Creates a new instance of this access logger.  All access logger
147   * implementations must include a default constructor, but any initialization
148   * should generally be done in the {@code initializeAccessLogger} method.
149   */
150  public ScriptedFileBasedAccessLogger()
151  {
152    // No implementation is required.
153  }
154
155
156
157  /**
158   * {@inheritDoc}
159   */
160  public void defineConfigArguments(final ArgumentParser parser)
161         throws ArgumentException
162  {
163    // No arguments will be allowed by default.
164  }
165
166
167
168  /**
169   * Initializes this access logger.
170   *
171   * @param  serverContext  A handle to the server context for the server in
172   *                        which this extension is running.
173   * @param  config         The general configuration for this access logger.
174   * @param  parser         The argument parser which has been initialized from
175   *                        the configuration for this access logger.
176   *
177   * @throws  LDAPException  If a problem occurs while initializing this access
178   *                         logger.
179   */
180  public void initializeAccessLogger(final ServerContext serverContext,
181                                     final FileBasedAccessLoggerConfig config,
182                                     final ArgumentParser parser)
183         throws LDAPException
184  {
185    // No initialization will be performed by default.
186  }
187
188
189
190  /**
191   * {@inheritDoc}
192   */
193  public boolean isConfigurationAcceptable(
194                      final FileBasedAccessLoggerConfig config,
195                      final ArgumentParser parser,
196                      final List<String> unacceptableReasons)
197  {
198    // No extended validation will be performed by default.
199    return true;
200  }
201
202
203
204  /**
205   * {@inheritDoc}
206   */
207  public ResultCode applyConfiguration(final FileBasedAccessLoggerConfig config,
208                                       final ArgumentParser parser,
209                                       final List<String> adminActionsRequired,
210                                       final List<String> messages)
211  {
212    // By default, no configuration changes will be applied.  If there are any
213    // arguments, then add an admin action message indicating that the extension
214    // needs to be restarted for any changes to take effect.
215    if (! parser.getNamedArguments().isEmpty())
216    {
217      adminActionsRequired.add(
218           "No configuration change has actually been applied.  The new " +
219                "configuration will not take effect until this access logger " +
220                "is disabled and re-enabled or until the server is restarted.");
221    }
222
223    return ResultCode.SUCCESS;
224  }
225
226
227
228  /**
229   * Performs any cleanup which may be necessary when this access logger is to
230   * be taken out of service.
231   */
232  public void finalizeAccessLogger()
233  {
234    // No implementation is required.
235  }
236
237
238
239  /**
240   * Logs a message indicating that a new connection has been established.
241   *
242   * @param  clientContext  Information about the client connection that has
243   *                        been accepted.
244   *
245   * @return  The content of the log message that should be written.  It may be
246   *          {@code null} or empty if no message should be written.  It may
247   *          optionally include line breaks if the log message should span
248   *          multiple lines.
249   */
250  public CharSequence logConnect(final ClientContext clientContext)
251  {
252    // No log message will be generated by default.
253    return null;
254  }
255
256
257
258  /**
259   * Logs a message indicating that a connection has been closed.
260   *
261   * @param  clientContext     Information about the client connection that has
262   *                           been closed.
263   * @param  disconnectReason  A general reason that the connection has been
264   *                           closed.
265   * @param  message           A message with additional information about the
266   *                           closure.  It may be {@code null} if none is
267   *                           available.
268   *
269   * @return  The content of the log message that should be written.  It may be
270   *          {@code null} or empty if no message should be written.  It may
271   *          optionally include line breaks if the log message should span
272   *          multiple lines.
273   */
274  public CharSequence logDisconnect(final ClientContext clientContext,
275                                    final DisconnectReason disconnectReason,
276                                    final String message)
277  {
278    // No log message will be generated by default.
279    return null;
280  }
281
282
283
284  /**
285   * Logs a message about security negotiation performed by a client.
286   *
287   * @param  clientContext  Information about the client connection on which
288   *                        the negotiation was completed.
289   * @param  protocol       The security protocol selected by the negotiation.
290   *                        It may be {@code null} if no protocol is available.
291   * @param  cipher         The cipher suite selected by the negotiation.  It
292   *                        may be {@code null} if no cipher is available.
293   * @param  properties     A set of additional properties that may be included
294   *                        in the log message.  It may be {@code null} or empty
295   *                        if no additional properties are needed.
296   *
297   * @return  The content of the log message that should be written.  It may be
298   *          {@code null} or empty if no message should be written.  It may
299   *          optionally include line breaks if the log message should span
300   *          multiple lines.
301   */
302  public CharSequence logSecurityNegotiation(final ClientContext clientContext,
303                           final String protocol, final String cipher,
304                           final Map<String,String> properties)
305  {
306    // No log message will be generated by default.
307    return null;
308  }
309
310
311
312  /**
313   * Logs a message about a certificate chain presented by a client.
314   *
315   * @param  clientContext  Information about the client that presented the
316   *                        certificate chain.
317   * @param  certChain      The certificate chain presented by the client.
318   * @param  authDN         The DN of the user as whom the client was
319   *                        automatically authenticated, or {@code null} if the
320   *                        client was not automatically authenticated.
321   *
322   * @return  The content of the log message that should be written.  It may be
323   *          {@code null} or empty if no message should be written.  It may
324   *          optionally include line breaks if the log message should span
325   *          multiple lines.
326   */
327  public CharSequence logClientCertificateChain(
328                           final ClientContext clientContext,
329                           final Certificate[] certChain, final String authDN)
330  {
331    // No log message will be generated by default.
332    return null;
333  }
334
335
336
337  /**
338   * Logs a message about an abandon request received from a client.
339   *
340   * @param  opContext  The operation context for the abandon operation.
341   * @param  request    The abandon request that was received.
342   *
343   * @return  The content of the log message that should be written.  It may be
344   *          {@code null} or empty if no message should be written.  It may
345   *          optionally include line breaks if the log message should span
346   *          multiple lines.
347   */
348  public CharSequence logAbandonRequest(final OperationContext opContext,
349                                        final AbandonRequest request)
350  {
351    // No log message will be generated by default.
352    return null;
353  }
354
355
356
357  /**
358   * Logs a message about an abandon request that will be forwarded to another
359   * server.
360   *
361   * @param  opContext  The operation context for the abandon operation.
362   * @param  request    The abandon request that was received.
363   * @param  target     Information about the server to which the request will
364   *                    be forwarded.
365   *
366   * @return  The content of the log message that should be written.  It may be
367   *          {@code null} or empty if no message should be written.  It may
368   *          optionally include line breaks if the log message should span
369   *          multiple lines.
370   */
371  public CharSequence logAbandonForward(final OperationContext opContext,
372                                        final AbandonRequest request,
373                                        final ForwardTarget target)
374  {
375    // No log message will be generated by default.
376    return null;
377  }
378
379
380
381  /**
382   * Logs a message about the result of processing an abandon request.
383   *
384   * @param  opContext  The operation context for the abandon operation.
385   * @param  request    The abandon request that was received.
386   * @param  result     The result of processing the abandon request.
387   *
388   * @return  The content of the log message that should be written.  It may be
389   *          {@code null} or empty if no message should be written.  It may
390   *          optionally include line breaks if the log message should span
391   *          multiple lines.
392   */
393  public CharSequence logAbandonResult(
394                           final CompletedOperationContext opContext,
395                           final AbandonRequest request,
396                           final GenericResult result)
397  {
398    // No log message will be generated by default.
399    return null;
400  }
401
402
403
404  /**
405   * Logs a message about an add request received from a client.
406   *
407   * @param  opContext  The operation context for the add operation.
408   * @param  request    The add request that was received.
409   *
410   * @return  The content of the log message that should be written.  It may be
411   *          {@code null} or empty if no message should be written.  It may
412   *          optionally include line breaks if the log message should span
413   *          multiple lines.
414   */
415  public CharSequence logAddRequest(final OperationContext opContext,
416                                    final AddRequest request)
417  {
418    // No log message will be generated by default.
419    return null;
420  }
421
422
423
424  /**
425   * Logs a message about an add request that will be forwarded to another
426   * server.
427   *
428   * @param  opContext  The operation context for the add operation.
429   * @param  request    The add request that was received.
430   * @param  target     Information about the server to which the request will
431   *                    be forwarded.
432   *
433   * @return  The content of the log message that should be written.  It may be
434   *          {@code null} or empty if no message should be written.  It may
435   *          optionally include line breaks if the log message should span
436   *          multiple lines.
437   */
438  public CharSequence logAddForward(final OperationContext opContext,
439                                    final AddRequest request,
440                                    final ForwardTarget target)
441  {
442    // No log message will be generated by default.
443    return null;
444  }
445
446
447
448  /**
449   * Logs a message about a failure encountered while attempting to forward an
450   * add request to another server.
451   *
452   * @param  opContext  The operation context for the add operation.
453   * @param  request    The add request that was received.
454   * @param  target     Information about the server to which the request was
455   *                    forwarded.
456   * @param  failure    The exception that was received when attempting to
457   *                    forward the request.
458   *
459   * @return  The content of the log message that should be written.  It may be
460   *          {@code null} or empty if no message should be written.  It may
461   *          optionally include line breaks if the log message should span
462   *          multiple lines.
463   */
464  public CharSequence logAddForwardFailure(final OperationContext opContext,
465                                           final AddRequest request,
466                                           final ForwardTarget target,
467                                           final LDAPException failure)
468  {
469    // No log message will be generated by default.
470    return null;
471  }
472
473
474
475  /**
476   * Logs a message about the result of processing an add request.
477   *
478   * @param  opContext  The operation context for the add operation.
479   * @param  request    The add request that was received.
480   * @param  result     The result of processing the add request.
481   *
482   * @return  The content of the log message that should be written.  It may be
483   *          {@code null} or empty if no message should be written.  It may
484   *          optionally include line breaks if the log message should span
485   *          multiple lines.
486   */
487  public CharSequence logAddResponse(final CompletedOperationContext opContext,
488                                     final AddRequest request,
489                                     final AddResult result)
490  {
491    // No log message will be generated by default.
492    return null;
493  }
494
495
496
497  /**
498   * Logs a message about the result of replication assurance processing for an
499   * add operation.
500   *
501   * @param  opContext        The operation context for the add operation.
502   * @param  request          The add request that was received.
503   * @param  result           The result of processing the add request.
504   * @param  assuranceResult  The replication assurance processing result.
505   *
506   * @return  The content of the log message that should be written.  It may be
507   *          {@code null} or empty if no message should be written.  It may
508   *          optionally include line breaks if the log message should span
509   *          multiple lines.
510   */
511  public CharSequence logAddAssuranceCompleted(
512                           final CompletedOperationContext opContext,
513                           final AddRequest request, final AddResult result,
514                           final AssuredReplicationResult assuranceResult)
515  {
516    // No log message will be generated by default.
517    return null;
518  }
519
520
521
522  /**
523   * Logs a message about a simple bind request received from a client.
524   *
525   * @param  opContext  The operation context for the bind operation.
526   * @param  request    The bind request that was received.
527   *
528   * @return  The content of the log message that should be written.  It may be
529   *          {@code null} or empty if no message should be written.  It may
530   *          optionally include line breaks if the log message should span
531   *          multiple lines.
532   */
533  public CharSequence logBindRequest(final OperationContext opContext,
534                                     final SimpleBindRequest request)
535  {
536    // No log message will be generated by default.
537    return null;
538  }
539
540
541
542  /**
543   * Logs a message about a simple bind request that will be forwarded to
544   * another server.
545   *
546   * @param  opContext  The operation context for the bind operation.
547   * @param  request    The bind request that was received.
548   * @param  target     Information about the server to which the request will
549   *                    be forwarded.
550   *
551   * @return  The content of the log message that should be written.  It may be
552   *          {@code null} or empty if no message should be written.  It may
553   *          optionally include line breaks if the log message should span
554   *          multiple lines.
555   */
556  public CharSequence logBindForward(final OperationContext opContext,
557                                     final SimpleBindRequest request,
558                                     final ForwardTarget target)
559  {
560    // No log message will be generated by default.
561    return null;
562  }
563
564
565
566  /**
567   * Logs a message about a failure encountered while attempting to forward a
568   * simple bind request to another server.
569   *
570   * @param  opContext  The operation context for the bind operation.
571   * @param  request    The bind request that was received.
572   * @param  target     Information about the server to which the request was
573   *                    forwarded.
574   * @param  failure    The exception that was received when attempting to
575   *                    forward the request.
576   *
577   * @return  The content of the log message that should be written.  It may be
578   *          {@code null} or empty if no message should be written.  It may
579   *          optionally include line breaks if the log message should span
580   *          multiple lines.
581   */
582  public CharSequence logBindForwardFailure(final OperationContext opContext,
583                                            final SimpleBindRequest request,
584                                            final ForwardTarget target,
585                                            final LDAPException failure)
586  {
587    // No log message will be generated by default.
588    return null;
589  }
590
591
592
593  /**
594   * Logs a message about the result of processing a simple bind request.
595   *
596   * @param  opContext  The operation context for the bind operation.
597   * @param  request    The bind request that was received.
598   * @param  result     The result of processing the bind request.
599   *
600   * @return  The content of the log message that should be written.  It may be
601   *          {@code null} or empty if no message should be written.  It may
602   *          optionally include line breaks if the log message should span
603   *          multiple lines.
604   */
605  public CharSequence logBindResponse(final CompletedOperationContext opContext,
606                                      final SimpleBindRequest request,
607                                      final BindResult result)
608  {
609    // No log message will be generated by default.
610    return null;
611  }
612
613
614
615  /**
616   * Logs a message about a SASL bind request received from a client.
617   *
618   * @param  opContext  The operation context for the bind operation.
619   * @param  request    The bind request that was received.
620   *
621   * @return  The content of the log message that should be written.  It may be
622   *          {@code null} or empty if no message should be written.  It may
623   *          optionally include line breaks if the log message should span
624   *          multiple lines.
625   */
626  public CharSequence logBindRequest(final OperationContext opContext,
627                                     final SASLBindRequest request)
628  {
629    // No log message will be generated by default.
630    return null;
631  }
632
633
634
635  /**
636   * Logs a message about a SASL bind request that will be forwarded to
637   * another server.
638   *
639   * @param  opContext  The operation context for the bind operation.
640   * @param  request    The bind request that was received.
641   * @param  target     Information about the server to which the request will
642   *                    be forwarded.
643   *
644   * @return  The content of the log message that should be written.  It may be
645   *          {@code null} or empty if no message should be written.  It may
646   *          optionally include line breaks if the log message should span
647   *          multiple lines.
648   */
649  public CharSequence logBindForward(final OperationContext opContext,
650                                     final SASLBindRequest request,
651                                     final ForwardTarget target)
652  {
653    // No log message will be generated by default.
654    return null;
655  }
656
657
658
659  /**
660   * Logs a message about a failure encountered while attempting to forward a
661   * SASL bind request to another server.
662   *
663   * @param  opContext  The operation context for the bind operation.
664   * @param  request    The bind request that was received.
665   * @param  target     Information about the server to which the request was
666   *                    forwarded.
667   * @param  failure    The exception that was received when attempting to
668   *                    forward the request.
669   *
670   * @return  The content of the log message that should be written.  It may be
671   *          {@code null} or empty if no message should be written.  It may
672   *          optionally include line breaks if the log message should span
673   *          multiple lines.
674   */
675  public CharSequence logBindForwardFailure(final OperationContext opContext,
676                                            final SASLBindRequest request,
677                                            final ForwardTarget target,
678                                            final LDAPException failure)
679  {
680    // No log message will be generated by default.
681    return null;
682  }
683
684
685
686  /**
687   * Logs a message about the result of processing a SASL bind request.
688   *
689   * @param  opContext  The operation context for the bind operation.
690   * @param  request    The bind request that was received.
691   * @param  result     The result of processing the bind request.
692   *
693   * @return  The content of the log message that should be written.  It may be
694   *          {@code null} or empty if no message should be written.  It may
695   *          optionally include line breaks if the log message should span
696   *          multiple lines.
697   */
698  public CharSequence logBindResponse(final CompletedOperationContext opContext,
699                                      final SASLBindRequest request,
700                                      final BindResult result)
701  {
702    // No log message will be generated by default.
703    return null;
704  }
705
706
707
708  /**
709   * Logs a message about a compare request received from a client.
710   *
711   * @param  opContext  The operation context for the compare operation.
712   * @param  request    The compare request that was received.
713   *
714   * @return  The content of the log message that should be written.  It may be
715   *          {@code null} or empty if no message should be written.  It may
716   *          optionally include line breaks if the log message should span
717   *          multiple lines.
718   */
719  public CharSequence logCompareRequest(final OperationContext opContext,
720                                        final CompareRequest request)
721  {
722    // No log message will be generated by default.
723    return null;
724  }
725
726
727
728  /**
729   * Logs a message about a compare request that will be forwarded to another
730   * server.
731   *
732   * @param  opContext  The operation context for the compare operation.
733   * @param  request    The compare request that was received.
734   * @param  target     Information about the server to which the request will
735   *                    be forwarded.
736   *
737   * @return  The content of the log message that should be written.  It may be
738   *          {@code null} or empty if no message should be written.  It may
739   *          optionally include line breaks if the log message should span
740   *          multiple lines.
741   */
742  public CharSequence logCompareForward(final OperationContext opContext,
743                                        final CompareRequest request,
744                                        final ForwardTarget target)
745  {
746    // No log message will be generated by default.
747    return null;
748  }
749
750
751
752  /**
753   * Logs a message about a failure encountered while attempting to forward a
754   * compare request to another server.
755   *
756   * @param  opContext  The operation context for the compare operation.
757   * @param  request    The compare request that was received.
758   * @param  target     Information about the server to which the request was
759   *                    forwarded.
760   * @param  failure    The exception that was received when attempting to
761   *                    forward the request.
762   *
763   * @return  The content of the log message that should be written.  It may be
764   *          {@code null} or empty if no message should be written.  It may
765   *          optionally include line breaks if the log message should span
766   *          multiple lines.
767   */
768  public CharSequence logCompareForwardFailure(final OperationContext opContext,
769                                               final CompareRequest request,
770                                               final ForwardTarget target,
771                                               final LDAPException failure)
772  {
773    // No log message will be generated by default.
774    return null;
775  }
776
777
778
779  /**
780   * Logs a message about the result of processing a compare request.
781   *
782   * @param  opContext  The operation context for the compare operation.
783   * @param  request    The compare request that was received.
784   * @param  result     The result of processing the compare request.
785   *
786   * @return  The content of the log message that should be written.  It may be
787   *          {@code null} or empty if no message should be written.  It may
788   *          optionally include line breaks if the log message should span
789   *          multiple lines.
790   */
791  public CharSequence logCompareResponse(
792                           final CompletedOperationContext opContext,
793                           final CompareRequest request,
794                           final CompareResult result)
795  {
796    // No log message will be generated by default.
797    return null;
798  }
799
800
801
802  /**
803   * Logs a message about a delete request received from a client.
804   *
805   * @param  opContext  The operation context for the delete operation.
806   * @param  request    The delete request that was received.
807   *
808   * @return  The content of the log message that should be written.  It may be
809   *          {@code null} or empty if no message should be written.  It may
810   *          optionally include line breaks if the log message should span
811   *          multiple lines.
812   */
813  public CharSequence logDeleteRequest(final OperationContext opContext,
814                                       final DeleteRequest request)
815  {
816    // No log message will be generated by default.
817    return null;
818  }
819
820
821
822  /**
823   * Logs a message about a delete request that will be forwarded to another
824   * server.
825   *
826   * @param  opContext  The operation context for the delete operation.
827   * @param  request    The delete request that was received.
828   * @param  target     Information about the server to which the request will
829   *                    be forwarded.
830   *
831   * @return  The content of the log message that should be written.  It may be
832   *          {@code null} or empty if no message should be written.  It may
833   *          optionally include line breaks if the log message should span
834   *          multiple lines.
835   */
836  public CharSequence logDeleteForward(final OperationContext opContext,
837                                       final DeleteRequest request,
838                                       final ForwardTarget target)
839  {
840    // No log message will be generated by default.
841    return null;
842  }
843
844
845
846  /**
847   * Logs a message about a failure encountered while attempting to forward a
848   * delete request to another server.
849   *
850   * @param  opContext  The operation context for the delete operation.
851   * @param  request    The delete request that was received.
852   * @param  target     Information about the server to which the request was
853   *                    forwarded.
854   * @param  failure    The exception that was received when attempting to
855   *                    forward the request.
856   *
857   * @return  The content of the log message that should be written.  It may be
858   *          {@code null} or empty if no message should be written.  It may
859   *          optionally include line breaks if the log message should span
860   *          multiple lines.
861   */
862  public CharSequence logDeleteForwardFailure(final OperationContext opContext,
863                                              final DeleteRequest request,
864                                              final ForwardTarget target,
865                                              final LDAPException failure)
866  {
867    // No log message will be generated by default.
868    return null;
869  }
870
871
872
873  /**
874   * Logs a message about the result of processing a delete request.
875   *
876   * @param  opContext  The operation context for the delete operation.
877   * @param  request    The delete request that was received.
878   * @param  result     The result of processing the delete request.
879   *
880   * @return  The content of the log message that should be written.  It may be
881   *          {@code null} or empty if no message should be written.  It may
882   *          optionally include line breaks if the log message should span
883   *          multiple lines.
884   */
885  public CharSequence logDeleteResponse(
886                           final CompletedOperationContext opContext,
887                           final DeleteRequest request,
888                           final DeleteResult result)
889  {
890    // No log message will be generated by default.
891    return null;
892  }
893
894
895
896  /**
897   * Logs a message about the result of replication assurance processing for a
898   * delete operation.
899   *
900   * @param  opContext        The operation context for the delete operation.
901   * @param  request          The delete request that was received.
902   * @param  result           The result of processing the delete request.
903   * @param  assuranceResult  The replication assurance processing result.
904   *
905   * @return  The content of the log message that should be written.  It may be
906   *          {@code null} or empty if no message should be written.  It may
907   *          optionally include line breaks if the log message should span
908   *          multiple lines.
909   */
910  public CharSequence logDeleteAssuranceCompleted(
911                           final CompletedOperationContext opContext,
912                           final DeleteRequest request,
913                           final DeleteResult result,
914                           final AssuredReplicationResult assuranceResult)
915  {
916    // No log message will be generated by default.
917    return null;
918  }
919
920
921
922  /**
923   * Logs a message about an extended request received from a client.
924   *
925   * @param  opContext  The operation context for the extended operation.
926   * @param  request    The extended request that was received.
927   *
928   * @return  The content of the log message that should be written.  It may be
929   *          {@code null} or empty if no message should be written.  It may
930   *          optionally include line breaks if the log message should span
931   *          multiple lines.
932   */
933  public CharSequence logExtendedRequest(final OperationContext opContext,
934                                         final ExtendedRequest request)
935  {
936    // No log message will be generated by default.
937    return null;
938  }
939
940
941
942  /**
943   * Logs a message about an extended request that will be forwarded to another
944   * server.
945   *
946   * @param  opContext  The operation context for the extended operation.
947   * @param  request    The extended request that was received.
948   * @param  target     Information about the server to which the request will
949   *                    be forwarded.
950   *
951   * @return  The content of the log message that should be written.  It may be
952   *          {@code null} or empty if no message should be written.  It may
953   *          optionally include line breaks if the log message should span
954   *          multiple lines.
955   */
956  public CharSequence logExtendedForward(final OperationContext opContext,
957                                         final ExtendedRequest request,
958                                         final ForwardTarget target)
959  {
960    // No log message will be generated by default.
961    return null;
962  }
963
964
965
966  /**
967   * Logs a message about a failure encountered while attempting to forward an
968   * extended request to another server.
969   *
970   * @param  opContext  The operation context for the extended operation.
971   * @param  request    The extended request that was received.
972   * @param  target     Information about the server to which the request was
973   *                    forwarded.
974   * @param  failure    The exception that was received when attempting to
975   *                    forward the request.
976   *
977   * @return  The content of the log message that should be written.  It may be
978   *          {@code null} or empty if no message should be written.  It may
979   *          optionally include line breaks if the log message should span
980   *          multiple lines.
981   */
982  public CharSequence logExtendedForwardFailure(
983                           final OperationContext opContext,
984                           final ExtendedRequest request,
985                           final ForwardTarget target,
986                           final LDAPException failure)
987  {
988    // No log message will be generated by default.
989    return null;
990  }
991
992
993
994  /**
995   * Logs a message about the result of processing an extended request.
996   *
997   * @param  opContext  The operation context for the extended operation.
998   * @param  request    The extended request that was received.
999   * @param  result     The result of processing the extended request.
1000   *
1001   * @return  The content of the log message that should be written.  It may be
1002   *          {@code null} or empty if no message should be written.  It may
1003   *          optionally include line breaks if the log message should span
1004   *          multiple lines.
1005   */
1006  public CharSequence logExtendedResponse(
1007                           final CompletedOperationContext opContext,
1008                           final ExtendedRequest request,
1009                           final ExtendedResult result)
1010  {
1011    // No log message will be generated by default.
1012    return null;
1013  }
1014
1015
1016
1017  /**
1018   * Logs a message about a modify request received from a client.
1019   *
1020   * @param  opContext  The operation context for the modify operation.
1021   * @param  request    The modify request that was received.
1022   *
1023   * @return  The content of the log message that should be written.  It may be
1024   *          {@code null} or empty if no message should be written.  It may
1025   *          optionally include line breaks if the log message should span
1026   *          multiple lines.
1027   */
1028  public CharSequence logModifyRequest(final OperationContext opContext,
1029                                       final ModifyRequest request)
1030  {
1031    // No log message will be generated by default.
1032    return null;
1033  }
1034
1035
1036
1037  /**
1038   * Logs a message about a modify request that will be forwarded to another
1039   * server.
1040   *
1041   * @param  opContext  The operation context for the modify operation.
1042   * @param  request    The modify request that was received.
1043   * @param  target     Information about the server to which the request will
1044   *                    be forwarded.
1045   *
1046   * @return  The content of the log message that should be written.  It may be
1047   *          {@code null} or empty if no message should be written.  It may
1048   *          optionally include line breaks if the log message should span
1049   *          multiple lines.
1050   */
1051  public CharSequence logModifyForward(final OperationContext opContext,
1052                                       final ModifyRequest request,
1053                                       final ForwardTarget target)
1054  {
1055    // No log message will be generated by default.
1056    return null;
1057  }
1058
1059
1060
1061  /**
1062   * Logs a message about a failure encountered while attempting to forward a
1063   * modify request to another server.
1064   *
1065   * @param  opContext  The operation context for the modify operation.
1066   * @param  request    The modify request that was received.
1067   * @param  target     Information about the server to which the request was
1068   *                    forwarded.
1069   * @param  failure    The exception that was received when attempting to
1070   *                    forward the request.
1071   *
1072   * @return  The content of the log message that should be written.  It may be
1073   *          {@code null} or empty if no message should be written.  It may
1074   *          optionally include line breaks if the log message should span
1075   *          multiple lines.
1076   */
1077  public CharSequence logModifyForwardFailure(final OperationContext opContext,
1078                                              final ModifyRequest request,
1079                                              final ForwardTarget target,
1080                                              final LDAPException failure)
1081  {
1082    // No log message will be generated by default.
1083    return null;
1084  }
1085
1086
1087
1088  /**
1089   * Logs a message about the result of processing a modify request.
1090   *
1091   * @param  opContext  The operation context for the modify operation.
1092   * @param  request    The modify request that was received.
1093   * @param  result     The result of processing the modify request.
1094   *
1095   * @return  The content of the log message that should be written.  It may be
1096   *          {@code null} or empty if no message should be written.  It may
1097   *          optionally include line breaks if the log message should span
1098   *          multiple lines.
1099   */
1100  public CharSequence logModifyResponse(
1101                           final CompletedOperationContext opContext,
1102                           final ModifyRequest request,
1103                           final ModifyResult result)
1104  {
1105    // No log message will be generated by default.
1106    return null;
1107  }
1108
1109
1110
1111  /**
1112   * Logs a message about the result of replication assurance processing for a
1113   * modify operation.
1114   *
1115   * @param  opContext        The operation context for the modify operation.
1116   * @param  request          The modify request that was received.
1117   * @param  result           The result of processing the modify request.
1118   * @param  assuranceResult  The replication assurance processing result.
1119   *
1120   * @return  The content of the log message that should be written.  It may be
1121   *          {@code null} or empty if no message should be written.  It may
1122   *          optionally include line breaks if the log message should span
1123   *          multiple lines.
1124   */
1125  public CharSequence logModifyAssuranceCompleted(
1126                           final CompletedOperationContext opContext,
1127                           final ModifyRequest request,
1128                           final ModifyResult result,
1129                           final AssuredReplicationResult assuranceResult)
1130  {
1131    // No log message will be generated by default.
1132    return null;
1133  }
1134
1135
1136
1137  /**
1138   * Logs a message about a modify DN request received from a client.
1139   *
1140   * @param  opContext  The operation context for the modify DN operation.
1141   * @param  request    The modify DN request that was received.
1142   *
1143   * @return  The content of the log message that should be written.  It may be
1144   *          {@code null} or empty if no message should be written.  It may
1145   *          optionally include line breaks if the log message should span
1146   *          multiple lines.
1147   */
1148  public CharSequence logModifyDNRequest(final OperationContext opContext,
1149                                         final ModifyDNRequest request)
1150  {
1151    // No log message will be generated by default.
1152    return null;
1153  }
1154
1155
1156
1157  /**
1158   * Logs a message about a modify DN request that will be forwarded to another
1159   * server.
1160   *
1161   * @param  opContext  The operation context for the modify DN operation.
1162   * @param  request    The modify DN request that was received.
1163   * @param  target     Information about the server to which the request will
1164   *                    be forwarded.
1165   *
1166   * @return  The content of the log message that should be written.  It may be
1167   *          {@code null} or empty if no message should be written.  It may
1168   *          optionally include line breaks if the log message should span
1169   *          multiple lines.
1170   */
1171  public CharSequence logModifyDNForward(final OperationContext opContext,
1172                                         final ModifyDNRequest request,
1173                                         final ForwardTarget target)
1174  {
1175    // No log message will be generated by default.
1176    return null;
1177  }
1178
1179
1180
1181  /**
1182   * Logs a message about a failure encountered while attempting to forward a
1183   * modify DN request to another server.
1184   *
1185   * @param  opContext  The operation context for the modify DN operation.
1186   * @param  request    The modify DN request that was received.
1187   * @param  target     Information about the server to which the request was
1188   *                    forwarded.
1189   * @param  failure    The exception that was received when attempting to
1190   *                    forward the request.
1191   *
1192   * @return  The content of the log message that should be written.  It may be
1193   *          {@code null} or empty if no message should be written.  It may
1194   *          optionally include line breaks if the log message should span
1195   *          multiple lines.
1196   */
1197  public CharSequence logModifyDNForwardFailure(
1198                           final OperationContext opContext,
1199                           final ModifyDNRequest request,
1200                           final ForwardTarget target,
1201                           final LDAPException failure)
1202  {
1203    // No log message will be generated by default.
1204    return null;
1205  }
1206
1207
1208
1209  /**
1210   * Logs a message about the result of processing a modify DN request.
1211   *
1212   * @param  opContext  The operation context for the modify DN operation.
1213   * @param  request    The modify DN request that was received.
1214   * @param  result     The result of processing the modify DN request.
1215   *
1216   * @return  The content of the log message that should be written.  It may be
1217   *          {@code null} or empty if no message should be written.  It may
1218   *          optionally include line breaks if the log message should span
1219   *          multiple lines.
1220   */
1221  public CharSequence logModifyDNResponse(
1222                           final CompletedOperationContext opContext,
1223                           final ModifyDNRequest request,
1224                           final ModifyDNResult result)
1225  {
1226    // No log message will be generated by default.
1227    return null;
1228  }
1229
1230
1231
1232  /**
1233   * Logs a message about the result of replication assurance processing for a
1234   * modify DN operation.
1235   *
1236   * @param  opContext        The operation context for the modify DN operation.
1237   * @param  request          The modify DN request that was received.
1238   * @param  result           The result of processing the modify DN request.
1239   * @param  assuranceResult  The replication assurance processing result.
1240   *
1241   * @return  The content of the log message that should be written.  It may be
1242   *          {@code null} or empty if no message should be written.  It may
1243   *          optionally include line breaks if the log message should span
1244   *          multiple lines.
1245   */
1246  public CharSequence logModifyDNAssuranceCompleted(
1247                           final CompletedOperationContext opContext,
1248                           final ModifyDNRequest request,
1249                           final ModifyDNResult result,
1250                           final AssuredReplicationResult assuranceResult)
1251  {
1252    // No log message will be generated by default.
1253    return null;
1254  }
1255
1256
1257
1258  /**
1259   * Logs a message about a search request received from a client.
1260   *
1261   * @param  opContext  The operation context for the search operation.
1262   * @param  request    The search request that was received.
1263   *
1264   * @return  The content of the log message that should be written.  It may be
1265   *          {@code null} or empty if no message should be written.  It may
1266   *          optionally include line breaks if the log message should span
1267   *          multiple lines.
1268   */
1269  public CharSequence logSearchRequest(final OperationContext opContext,
1270                                       final SearchRequest request)
1271  {
1272    // No log message will be generated by default.
1273    return null;
1274  }
1275
1276
1277
1278  /**
1279   * Logs a message about a search request that will be forwarded to another
1280   * server.
1281   *
1282   * @param  opContext  The operation context for the search operation.
1283   * @param  request    The search request that was received.
1284   * @param  target     Information about the server to which the request will
1285   *                    be forwarded.
1286   *
1287   * @return  The content of the log message that should be written.  It may be
1288   *          {@code null} or empty if no message should be written.  It may
1289   *          optionally include line breaks if the log message should span
1290   *          multiple lines.
1291   */
1292  public CharSequence logSearchForward(final OperationContext opContext,
1293                                       final SearchRequest request,
1294                                       final ForwardTarget target)
1295  {
1296    // No log message will be generated by default.
1297    return null;
1298  }
1299
1300
1301
1302  /**
1303   * Logs a message about a failure encountered while attempting to forward a
1304   * search request to another server.
1305   *
1306   * @param  opContext  The operation context for the search operation.
1307   * @param  request    The search request that was received.
1308   * @param  target     Information about the server to which the request was
1309   *                    forwarded.
1310   * @param  failure    The exception that was received when attempting to
1311   *                    forward the request.
1312   *
1313   * @return  The content of the log message that should be written.  It may be
1314   *          {@code null} or empty if no message should be written.  It may
1315   *          optionally include line breaks if the log message should span
1316   *          multiple lines.
1317   */
1318  public CharSequence logSearchForwardFailure(final OperationContext opContext,
1319                                              final SearchRequest request,
1320                                              final ForwardTarget target,
1321                                              final LDAPException failure)
1322  {
1323    // No log message will be generated by default.
1324    return null;
1325  }
1326
1327
1328
1329  /**
1330   * Logs a message about a search result entry that was returned to the client.
1331   *
1332   * @param  opContext  The operation context for the search operation.
1333   * @param  request    The search request that was received.
1334   * @param  entry      The entry that was returned.
1335   * @param  controls   The set of controls included with the entry, or an empty
1336   *                    list if there were none.
1337   *
1338   * @return  The content of the log message that should be written.  It may be
1339   *          {@code null} or empty if no message should be written.  It may
1340   *          optionally include line breaks if the log message should span
1341   *          multiple lines.
1342   */
1343  public CharSequence logSearchResultEntry(final OperationContext opContext,
1344                                           final SearchRequest request,
1345                                           final Entry entry,
1346                                           final List<Control> controls)
1347  {
1348    // No log message will be generated by default.
1349    return null;
1350  }
1351
1352
1353
1354  /**
1355   * Logs a message about a search result reference that was returned to the
1356   * client.
1357   *
1358   * @param  opContext     The operation context for the search operation.
1359   * @param  request       The search request that was received.
1360   * @param  referralURLs  The referral URLs for the reference that was
1361   *                       returned.
1362   * @param  controls      The set of controls included with the reference, or
1363   *                       an empty list if there were none.
1364   *
1365   * @return  The content of the log message that should be written.  It may be
1366   *          {@code null} or empty if no message should be written.  It may
1367   *          optionally include line breaks if the log message should span
1368   *          multiple lines.
1369   */
1370  public CharSequence logSearchResultReference(final OperationContext opContext,
1371                                               final SearchRequest request,
1372                                               final List<String> referralURLs,
1373                                               final List<Control> controls)
1374  {
1375    // No log message will be generated by default.
1376    return null;
1377  }
1378
1379
1380
1381  /**
1382   * Logs a message about the result of processing a search request.
1383   *
1384   * @param  opContext  The operation context for the search operation.
1385   * @param  request    The search request that was received.
1386   * @param  result     The result of processing the search request.
1387   *
1388   * @return  The content of the log message that should be written.  It may be
1389   *          {@code null} or empty if no message should be written.  It may
1390   *          optionally include line breaks if the log message should span
1391   *          multiple lines.
1392   */
1393  public CharSequence logSearchResultDone(
1394                           final CompletedSearchOperationContext opContext,
1395                           final SearchRequest request,
1396                           final SearchResult result)
1397  {
1398    // No log message will be generated by default.
1399    return null;
1400  }
1401
1402
1403
1404  /**
1405   * Logs a message about an unbind request received from a client.
1406   *
1407   * @param  opContext  The operation context for the unbind operation.
1408   * @param  request    The unbind request that was received.
1409   *
1410   * @return  The content of the log message that should be written.  It may be
1411   *          {@code null} or empty if no message should be written.  It may
1412   *          optionally include line breaks if the log message should span
1413   *          multiple lines.
1414   */
1415  public CharSequence logUnbindRequest(final OperationContext opContext,
1416                                       final UnbindRequest request)
1417  {
1418    // No log message will be generated by default.
1419    return null;
1420  }
1421
1422
1423
1424  /**
1425   * Logs a message about an intermediate response that was returned to the
1426   * client.
1427   *
1428   * @param  opContext             The operation context for the associated
1429   *                               operation.
1430   * @param  intermediateResponse  The intermediate response that was returned.
1431   *
1432   * @return  The content of the log message that should be written.  It may be
1433   *          {@code null} or empty if no message should be written.  It may
1434   *          optionally include line breaks if the log message should span
1435   *          multiple lines.
1436   */
1437  public CharSequence logIntermediateResponse(final OperationContext opContext,
1438                           final IntermediateResponse intermediateResponse)
1439  {
1440    // No log message will be generated by default.
1441    return null;
1442  }
1443
1444
1445
1446  /**
1447   * Writes a message to the access logger to indicate that the Directory Proxy
1448   * Server will attempt to perform entry rebalancing by migrating a subtree
1449   * from one backend set to another.
1450   *
1451   * @param  rebalancingOperationID  The unique ID assigned to the entry
1452   *                                 balancing operation.
1453   * @param  triggerOperation        The operation that triggered the entry
1454   *                                 rebalancing.  It may be {@code null} if the
1455   *                                 rebalancing operation wasn't triggered by a
1456   *                                 client request.
1457   * @param  baseDN                  The base DN of the subtree to migrate.
1458   * @param  sizeLimit               The maximum number of entries to migrate.
1459   * @param  sourceBackendSetName    The name of the backend set containing the
1460   *                                 subtree to migrate.
1461   * @param  sourceAddress           The address of the server from which the
1462   *                                 source entries will be read.
1463   * @param  sourcePort              The port of the server from which the
1464   *                                 source entries will be read.
1465   * @param  targetBackendSetName    The name of the backend set to which the
1466   *                                 subtree will be migrated.
1467   * @param  targetAddress           The address of the server to which the
1468   *                                 subtree will be migrated.
1469   * @param  targetPort              The port of the server to which the subtree
1470   *                                 will be migrated.
1471   *
1472   * @return  The content of the log message that should be written.  It may be
1473   *          {@code null} or empty if no message should be written.  It may
1474   *          optionally include line breaks if the log message should span
1475   *          multiple lines.
1476   */
1477  public CharSequence logEntryRebalancingRequest(
1478                           final long rebalancingOperationID,
1479                           final OperationContext triggerOperation,
1480                           final String baseDN, final int sizeLimit,
1481                           final String sourceBackendSetName,
1482                           final String sourceAddress, final int sourcePort,
1483                           final String targetBackendSetName,
1484                           final String targetAddress, final int targetPort)
1485  {
1486    // No log message will be generated by default.
1487    return null;
1488  }
1489
1490
1491
1492  /**
1493   * Writes a message to the access logger to indicate that the Directory Proxy
1494   * Server will attempt to perform entry rebalancing by migrating a subtree
1495   * from one backend set to another.
1496   *
1497   * @param  rebalancingOperationID  The unique ID assigned to the entry
1498   *                                 balancing operation.
1499   * @param  triggerOperation        The operation that triggered the entry
1500   *                                 rebalancing.  It may be {@code null} if the
1501   *                                 rebalancing operation wasn't triggered by a
1502   *                                 client request.
1503   * @param  baseDN                  The base DN of the subtree to migrate.
1504   * @param  sizeLimit               The maximum number of entries to migrate.
1505   * @param  sourceBackendSetName    The name of the backend set containing the
1506   *                                 subtree to migrate.
1507   * @param  sourceAddress           The address of the server from which the
1508   *                                 source entries will be read.
1509   * @param  sourcePort              The port of the server from which the
1510   *                                 source entries will be read.
1511   * @param  targetBackendSetName    The name of the backend set to which the
1512   *                                 subtree will be migrated.
1513   * @param  targetAddress           The address of the server to which the
1514   *                                 subtree will be migrated.
1515   * @param  targetPort              The port of the server to which the subtree
1516   *                                 will be migrated.
1517   * @param  moveSubtreeResult       An object with information about the result
1518   *                                 of the subtree move processing.
1519   *
1520   * @return  The content of the log message that should be written.  It may be
1521   *          {@code null} or empty if no message should be written.  It may
1522   *          optionally include line breaks if the log message should span
1523   *          multiple lines.
1524   */
1525  public CharSequence logEntryRebalancingResult(
1526                           final long rebalancingOperationID,
1527                           final OperationContext triggerOperation,
1528                           final String baseDN, final int sizeLimit,
1529                           final String sourceBackendSetName,
1530                           final String sourceAddress, final int sourcePort,
1531                           final String targetBackendSetName,
1532                           final String targetAddress, final int targetPort,
1533                           final MoveSubtreeResult moveSubtreeResult)
1534  {
1535    // No log message will be generated by default.
1536    return null;
1537  }
1538}