public class org.apache.logging.log4j.core.jmx.StatusLoggerAdmin extends javax.management.NotificationBroadcasterSupport implements org.apache.logging.log4j.status.StatusListener, org.apache.logging.log4j.core.jmx.StatusLoggerAdminMBean
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.logging.log4j.core.jmx.StatusLoggerAdmin
  super_class: javax.management.NotificationBroadcasterSupport
{
  private final java.util.concurrent.atomic.AtomicLong sequenceNo;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final javax.management.ObjectName objectName;
    descriptor: Ljavax/management/ObjectName;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.String contextName;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private org.apache.logging.log4j.Level level;
    descriptor: Lorg/apache/logging/log4j/Level;
    flags: (0x0002) ACC_PRIVATE

  public void <init>(java.lang.String, java.util.concurrent.Executor);
    descriptor: (Ljava/lang/String;Ljava/util/concurrent/Executor;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=3
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
        start local 1 // java.lang.String contextName
        start local 2 // java.util.concurrent.Executor executor
         0: .line 58
            aload 0 /* this */
            aload 2 /* executor */
            iconst_1
            anewarray javax.management.MBeanNotificationInfo
            dup
            iconst_0
            invokestatic org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.createNotificationInfo:()Ljavax/management/MBeanNotificationInfo;
            aastore
            invokespecial javax.management.NotificationBroadcasterSupport.<init>:(Ljava/util/concurrent/Executor;[Ljavax/management/MBeanNotificationInfo;)V
         1: .line 39
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
            putfield org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.sequenceNo:Ljava/util/concurrent/atomic/AtomicLong;
         2: .line 42
            aload 0 /* this */
            getstatic org.apache.logging.log4j.Level.WARN:Lorg/apache/logging/log4j/Level;
            putfield org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.level:Lorg/apache/logging/log4j/Level;
         3: .line 59
            aload 0 /* this */
            aload 1 /* contextName */
            putfield org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.contextName:Ljava/lang/String;
         4: .line 61
            ldc "org.apache.logging.log4j2:type=%s,component=StatusLogger"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 1 /* contextName */
            invokestatic org.apache.logging.log4j.core.jmx.Server.escape:(Ljava/lang/String;)Ljava/lang/String;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            astore 3 /* mbeanName */
        start local 3 // java.lang.String mbeanName
         5: .line 62
            aload 0 /* this */
            new javax.management.ObjectName
            dup
            aload 3 /* mbeanName */
            invokespecial javax.management.ObjectName.<init>:(Ljava/lang/String;)V
            putfield org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.objectName:Ljavax/management/ObjectName;
        end local 3 // java.lang.String mbeanName
         6: .line 63
            goto 9
      StackMap locals: org.apache.logging.log4j.core.jmx.StatusLoggerAdmin java.lang.String java.util.concurrent.Executor
      StackMap stack: java.lang.Exception
         7: astore 3 /* e */
        start local 3 // java.lang.Exception e
         8: .line 64
            new java.lang.IllegalStateException
            dup
            aload 3 /* e */
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.lang.Exception e
         9: .line 66
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* contextName */
            invokevirtual org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.removeListeners:(Ljava/lang/String;)V
        10: .line 67
            invokestatic org.apache.logging.log4j.status.StatusLogger.getLogger:()Lorg/apache/logging/log4j/status/StatusLogger;
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.status.StatusLogger.registerListener:(Lorg/apache/logging/log4j/status/StatusListener;)V
        11: .line 68
            return
        end local 2 // java.util.concurrent.Executor executor
        end local 1 // java.lang.String contextName
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   12     0         this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;
            0   12     1  contextName  Ljava/lang/String;
            0   12     2     executor  Ljava/util/concurrent/Executor;
            5    6     3    mbeanName  Ljava/lang/String;
            8    9     3            e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           4     6       7  Class java.lang.Exception
    MethodParameters:
             Name  Flags
      contextName  final
      executor     final

  private void removeListeners(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=7, args_size=2
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
        start local 1 // java.lang.String ctxName
         0: .line 76
            invokestatic org.apache.logging.log4j.status.StatusLogger.getLogger:()Lorg/apache/logging/log4j/status/StatusLogger;
            astore 2 /* logger */
        start local 2 // org.apache.logging.log4j.status.StatusLogger logger
         1: .line 77
            aload 2 /* logger */
            invokevirtual org.apache.logging.log4j.status.StatusLogger.getListeners:()Ljava/lang/Iterable;
            astore 3 /* listeners */
        start local 3 // java.lang.Iterable listeners
         2: .line 79
            aload 3 /* listeners */
            invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
            astore 5
            goto 8
      StackMap locals: org.apache.logging.log4j.core.jmx.StatusLoggerAdmin java.lang.String org.apache.logging.log4j.status.StatusLogger java.lang.Iterable top java.util.Iterator
      StackMap stack:
         3: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.logging.log4j.status.StatusListener
            astore 4 /* statusListener */
        start local 4 // org.apache.logging.log4j.status.StatusListener statusListener
         4: .line 80
            aload 4 /* statusListener */
            instanceof org.apache.logging.log4j.core.jmx.StatusLoggerAdmin
            ifeq 8
         5: .line 81
            aload 4 /* statusListener */
            checkcast org.apache.logging.log4j.core.jmx.StatusLoggerAdmin
            astore 6 /* adminListener */
        start local 6 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin adminListener
         6: .line 82
            aload 1 /* ctxName */
            ifnull 8
            aload 1 /* ctxName */
            aload 6 /* adminListener */
            getfield org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.contextName:Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 8
         7: .line 83
            aload 2 /* logger */
            aload 6 /* adminListener */
            invokevirtual org.apache.logging.log4j.status.StatusLogger.removeListener:(Lorg/apache/logging/log4j/status/StatusListener;)V
        end local 6 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin adminListener
        end local 4 // org.apache.logging.log4j.status.StatusListener statusListener
         8: .line 79
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         9: .line 87
            return
        end local 3 // java.lang.Iterable listeners
        end local 2 // org.apache.logging.log4j.status.StatusLogger logger
        end local 1 // java.lang.String ctxName
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   10     0            this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;
            0   10     1         ctxName  Ljava/lang/String;
            1   10     2          logger  Lorg/apache/logging/log4j/status/StatusLogger;
            2   10     3       listeners  Ljava/lang/Iterable<Lorg/apache/logging/log4j/status/StatusListener;>;
            4    8     4  statusListener  Lorg/apache/logging/log4j/status/StatusListener;
            6    8     6   adminListener  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;
    MethodParameters:
         Name  Flags
      ctxName  final

  private static javax.management.MBeanNotificationInfo createNotificationInfo();
    descriptor: ()Ljavax/management/MBeanNotificationInfo;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=2, args_size=0
         0: .line 90
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
         1: .line 91
            ldc "com.apache.logging.log4j.core.jmx.statuslogger.data"
            aastore
            dup
            iconst_1
         2: .line 92
            ldc "com.apache.logging.log4j.core.jmx.statuslogger.message"
            aastore
         3: .line 90
            astore 0 /* notifTypes */
        start local 0 // java.lang.String[] notifTypes
         4: .line 93
            ldc Ljavax/management/Notification;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            astore 1 /* name */
        start local 1 // java.lang.String name
         5: .line 95
            new javax.management.MBeanNotificationInfo
            dup
            aload 0 /* notifTypes */
            aload 1 /* name */
            ldc "StatusLogger has logged an event"
            invokespecial javax.management.MBeanNotificationInfo.<init>:([Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
            areturn
        end local 1 // java.lang.String name
        end local 0 // java.lang.String[] notifTypes
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            4    6     0  notifTypes  [Ljava/lang/String;
            5    6     1        name  Ljava/lang/String;

  public java.lang.String[] getStatusDataHistory();
    descriptor: ()[Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
         0: .line 100
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.getStatusData:()Ljava/util/List;
            astore 1 /* data */
        start local 1 // java.util.List data
         1: .line 101
            aload 1 /* data */
            invokeinterface java.util.List.size:()I
            anewarray java.lang.String
            astore 2 /* result */
        start local 2 // java.lang.String[] result
         2: .line 102
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         3: goto 6
         4: .line 103
      StackMap locals: java.util.List java.lang.String[] int
      StackMap stack:
            aload 2 /* result */
            iload 3 /* i */
            aload 1 /* data */
            iload 3 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.logging.log4j.status.StatusData
            invokevirtual org.apache.logging.log4j.status.StatusData.getFormattedStatus:()Ljava/lang/String;
            aastore
         5: .line 102
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
         6: iload 3 /* i */
            aload 2 /* result */
            arraylength
            if_icmplt 4
        end local 3 // int i
         7: .line 105
            aload 2 /* result */
            areturn
        end local 2 // java.lang.String[] result
        end local 1 // java.util.List data
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;
            1    8     1    data  Ljava/util/List<Lorg/apache/logging/log4j/status/StatusData;>;
            2    8     2  result  [Ljava/lang/String;
            3    7     3       i  I

  public java.util.List<org.apache.logging.log4j.status.StatusData> getStatusData();
    descriptor: ()Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
         0: .line 110
            invokestatic org.apache.logging.log4j.status.StatusLogger.getLogger:()Lorg/apache/logging/log4j/status/StatusLogger;
            invokevirtual org.apache.logging.log4j.status.StatusLogger.getStatusData:()Ljava/util/List;
            areturn
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;
    Signature: ()Ljava/util/List<Lorg/apache/logging/log4j/status/StatusData;>;

  public java.lang.String getLevel();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
         0: .line 115
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.level:Lorg/apache/logging/log4j/Level;
            invokevirtual org.apache.logging.log4j.Level.name:()Ljava/lang/String;
            areturn
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;

  public org.apache.logging.log4j.Level getStatusLevel();
    descriptor: ()Lorg/apache/logging/log4j/Level;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
         0: .line 120
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.level:Lorg/apache/logging/log4j/Level;
            areturn
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;

  public void setLevel(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
        start local 1 // java.lang.String level
         0: .line 125
            aload 0 /* this */
            aload 1 /* level */
            getstatic org.apache.logging.log4j.Level.ERROR:Lorg/apache/logging/log4j/Level;
            invokestatic org.apache.logging.log4j.Level.toLevel:(Ljava/lang/String;Lorg/apache/logging/log4j/Level;)Lorg/apache/logging/log4j/Level;
            putfield org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.level:Lorg/apache/logging/log4j/Level;
         1: .line 126
            return
        end local 1 // java.lang.String level
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;
            0    2     1  level  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      level  final

  public java.lang.String getContextName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
         0: .line 130
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.contextName:Ljava/lang/String;
            areturn
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;

  public void log(org.apache.logging.log4j.status.StatusData);
    descriptor: (Lorg/apache/logging/log4j/status/StatusData;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=9, locals=4, args_size=2
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
        start local 1 // org.apache.logging.log4j.status.StatusData data
         0: .line 142
            new javax.management.Notification
            dup
            ldc "com.apache.logging.log4j.core.jmx.statuslogger.message"
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.getObjectName:()Ljavax/management/ObjectName;
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.nextSeqNo:()J
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.nowMillis:()J
         1: .line 143
            aload 1 /* data */
            invokevirtual org.apache.logging.log4j.status.StatusData.getFormattedStatus:()Ljava/lang/String;
         2: .line 142
            invokespecial javax.management.Notification.<init>:(Ljava/lang/String;Ljava/lang/Object;JJLjava/lang/String;)V
            astore 2 /* notifMsg */
        start local 2 // javax.management.Notification notifMsg
         3: .line 144
            aload 0 /* this */
            aload 2 /* notifMsg */
            invokevirtual org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.sendNotification:(Ljavax/management/Notification;)V
         4: .line 146
            new javax.management.Notification
            dup
            ldc "com.apache.logging.log4j.core.jmx.statuslogger.data"
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.getObjectName:()Ljavax/management/ObjectName;
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.nextSeqNo:()J
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.nowMillis:()J
            invokespecial javax.management.Notification.<init>:(Ljava/lang/String;Ljava/lang/Object;JJ)V
            astore 3 /* notifData */
        start local 3 // javax.management.Notification notifData
         5: .line 147
            aload 3 /* notifData */
            aload 1 /* data */
            invokevirtual javax.management.Notification.setUserData:(Ljava/lang/Object;)V
         6: .line 148
            aload 0 /* this */
            aload 3 /* notifData */
            invokevirtual org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.sendNotification:(Ljavax/management/Notification;)V
         7: .line 149
            return
        end local 3 // javax.management.Notification notifData
        end local 2 // javax.management.Notification notifMsg
        end local 1 // org.apache.logging.log4j.status.StatusData data
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    8     0       this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;
            0    8     1       data  Lorg/apache/logging/log4j/status/StatusData;
            3    8     2   notifMsg  Ljavax/management/Notification;
            5    8     3  notifData  Ljavax/management/Notification;
    MethodParameters:
      Name  Flags
      data  final

  public javax.management.ObjectName getObjectName();
    descriptor: ()Ljavax/management/ObjectName;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
         0: .line 159
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.objectName:Ljavax/management/ObjectName;
            areturn
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;

  private long nextSeqNo();
    descriptor: ()J
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
         0: .line 163
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.jmx.StatusLoggerAdmin.sequenceNo:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.getAndIncrement:()J
            lreturn
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;

  private long nowMillis();
    descriptor: ()J
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
         0: .line 167
            invokestatic java.lang.System.currentTimeMillis:()J
            lreturn
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;

  public void close();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=0, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
         0: .line 173
            return
        end local 0 // org.apache.logging.log4j.core.jmx.StatusLoggerAdmin this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/jmx/StatusLoggerAdmin;
    Exceptions:
      throws java.io.IOException
}
SourceFile: "StatusLoggerAdmin.java"