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