public class org.apache.shiro.realm.GetAuthorizationsHack
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.shiro.realm.GetAuthorizationsHack
  super_class: java.lang.Object
{
  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.shiro.realm.GetAuthorizationsHack this
         0: .line 19
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.apache.shiro.realm.GetAuthorizationsHack this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/shiro/realm/GetAuthorizationsHack;

  public static java.util.Set<io.vertx.ext.auth.authorization.Authorization> getAuthorizations(org.apache.shiro.mgt.SecurityManager, org.apache.shiro.subject.Subject);
    descriptor: (Lorg/apache/shiro/mgt/SecurityManager;Lorg/apache/shiro/subject/Subject;)Ljava/util/Set;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=12, args_size=2
        start local 0 // org.apache.shiro.mgt.SecurityManager securityManager
        start local 1 // org.apache.shiro.subject.Subject subject
         0: .line 22
            aload 0 /* securityManager */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 24
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            astore 2 /* result */
        start local 2 // java.util.Set result
         2: .line 25
            aload 1 /* subject */
            invokeinterface org.apache.shiro.subject.Subject.getPrincipals:()Lorg/apache/shiro/subject/PrincipalCollection;
            ifnull 32
         3: .line 26
            aload 0 /* securityManager */
            instanceof org.apache.shiro.mgt.AuthorizingSecurityManager
            ifeq 32
         4: .line 27
            aload 0 /* securityManager */
            checkcast org.apache.shiro.mgt.AuthorizingSecurityManager
            astore 3 /* authorizingSecurityManager */
        start local 3 // org.apache.shiro.mgt.AuthorizingSecurityManager authorizingSecurityManager
         5: .line 28
            aload 3 /* authorizingSecurityManager */
            invokevirtual org.apache.shiro.mgt.AuthorizingSecurityManager.getAuthorizer:()Lorg/apache/shiro/authz/Authorizer;
            instanceof org.apache.shiro.authz.ModularRealmAuthorizer
            ifeq 32
         6: .line 29
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 2 /* result */
         7: .line 30
            aload 3 /* authorizingSecurityManager */
            invokevirtual org.apache.shiro.mgt.AuthorizingSecurityManager.getAuthorizer:()Lorg/apache/shiro/authz/Authorizer;
            checkcast org.apache.shiro.authz.ModularRealmAuthorizer
            astore 4 /* modularRealmAuthorizer */
        start local 4 // org.apache.shiro.authz.ModularRealmAuthorizer modularRealmAuthorizer
         8: .line 31
            aload 4 /* modularRealmAuthorizer */
            invokevirtual org.apache.shiro.authz.ModularRealmAuthorizer.getRealms:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 6
            goto 31
      StackMap locals: org.apache.shiro.mgt.SecurityManager org.apache.shiro.subject.Subject java.util.Set org.apache.shiro.mgt.AuthorizingSecurityManager org.apache.shiro.authz.ModularRealmAuthorizer top java.util.Iterator
      StackMap stack:
         9: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.shiro.realm.Realm
            astore 5 /* realm */
        start local 5 // org.apache.shiro.realm.Realm realm
        10: .line 32
            aload 5 /* realm */
            instanceof org.apache.shiro.realm.AuthorizingRealm
            ifeq 31
        11: .line 33
            aload 5 /* realm */
            checkcast org.apache.shiro.realm.AuthorizingRealm
            astore 7 /* authorizingRealm */
        start local 7 // org.apache.shiro.realm.AuthorizingRealm authorizingRealm
        12: .line 34
            aload 7 /* authorizingRealm */
            aload 1 /* subject */
            invokeinterface org.apache.shiro.subject.Subject.getPrincipals:()Lorg/apache/shiro/subject/PrincipalCollection;
            invokevirtual org.apache.shiro.realm.AuthorizingRealm.getAuthorizationInfo:(Lorg/apache/shiro/subject/PrincipalCollection;)Lorg/apache/shiro/authz/AuthorizationInfo;
            astore 8 /* authorizationInfo */
        start local 8 // org.apache.shiro.authz.AuthorizationInfo authorizationInfo
        13: .line 35
            aload 8 /* authorizationInfo */
            ifnull 31
        14: .line 36
            aload 8 /* authorizationInfo */
            invokeinterface org.apache.shiro.authz.AuthorizationInfo.getRoles:()Ljava/util/Collection;
            ifnull 19
        15: .line 37
            aload 8 /* authorizationInfo */
            invokeinterface org.apache.shiro.authz.AuthorizationInfo.getRoles:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 10
            goto 18
      StackMap locals: org.apache.shiro.mgt.SecurityManager org.apache.shiro.subject.Subject java.util.Set org.apache.shiro.mgt.AuthorizingSecurityManager org.apache.shiro.authz.ModularRealmAuthorizer org.apache.shiro.realm.Realm java.util.Iterator org.apache.shiro.realm.AuthorizingRealm org.apache.shiro.authz.AuthorizationInfo top java.util.Iterator
      StackMap stack:
        16: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 9 /* role */
        start local 9 // java.lang.String role
        17: .line 38
            aload 2 /* result */
            aload 9 /* role */
            invokestatic io.vertx.ext.auth.authorization.RoleBasedAuthorization.create:(Ljava/lang/String;)Lio/vertx/ext/auth/authorization/RoleBasedAuthorization;
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 9 // java.lang.String role
        18: .line 37
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 16
        19: .line 41
      StackMap locals: org.apache.shiro.mgt.SecurityManager org.apache.shiro.subject.Subject java.util.Set org.apache.shiro.mgt.AuthorizingSecurityManager org.apache.shiro.authz.ModularRealmAuthorizer org.apache.shiro.realm.Realm java.util.Iterator org.apache.shiro.realm.AuthorizingRealm org.apache.shiro.authz.AuthorizationInfo
      StackMap stack:
            aload 8 /* authorizationInfo */
            invokeinterface org.apache.shiro.authz.AuthorizationInfo.getStringPermissions:()Ljava/util/Collection;
            ifnull 24
        20: .line 42
            aload 8 /* authorizationInfo */
            invokeinterface org.apache.shiro.authz.AuthorizationInfo.getStringPermissions:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 10
            goto 23
      StackMap locals: org.apache.shiro.mgt.SecurityManager org.apache.shiro.subject.Subject java.util.Set org.apache.shiro.mgt.AuthorizingSecurityManager org.apache.shiro.authz.ModularRealmAuthorizer org.apache.shiro.realm.Realm java.util.Iterator org.apache.shiro.realm.AuthorizingRealm org.apache.shiro.authz.AuthorizationInfo top java.util.Iterator
      StackMap stack:
        21: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 9 /* permission */
        start local 9 // java.lang.String permission
        22: .line 43
            aload 2 /* result */
            aload 9 /* permission */
            invokestatic io.vertx.ext.auth.authorization.WildcardPermissionBasedAuthorization.create:(Ljava/lang/String;)Lio/vertx/ext/auth/authorization/WildcardPermissionBasedAuthorization;
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 9 // java.lang.String permission
        23: .line 42
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 21
        24: .line 46
      StackMap locals: org.apache.shiro.mgt.SecurityManager org.apache.shiro.subject.Subject java.util.Set org.apache.shiro.mgt.AuthorizingSecurityManager org.apache.shiro.authz.ModularRealmAuthorizer org.apache.shiro.realm.Realm java.util.Iterator org.apache.shiro.realm.AuthorizingRealm org.apache.shiro.authz.AuthorizationInfo
      StackMap stack:
            aload 8 /* authorizationInfo */
            invokeinterface org.apache.shiro.authz.AuthorizationInfo.getObjectPermissions:()Ljava/util/Collection;
            ifnull 31
        25: .line 47
            aload 8 /* authorizationInfo */
            invokeinterface org.apache.shiro.authz.AuthorizationInfo.getObjectPermissions:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 10
            goto 30
      StackMap locals: org.apache.shiro.mgt.SecurityManager org.apache.shiro.subject.Subject java.util.Set org.apache.shiro.mgt.AuthorizingSecurityManager org.apache.shiro.authz.ModularRealmAuthorizer org.apache.shiro.realm.Realm java.util.Iterator org.apache.shiro.realm.AuthorizingRealm org.apache.shiro.authz.AuthorizationInfo top java.util.Iterator
      StackMap stack:
        26: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.shiro.authz.Permission
            astore 9 /* permission */
        start local 9 // org.apache.shiro.authz.Permission permission
        27: .line 48
            aload 9 /* permission */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            astore 11 /* stringPermission */
        start local 11 // java.lang.String stringPermission
        28: .line 49
            aload 11 /* stringPermission */
            ldc "["
            ldc ""
            invokevirtual java.lang.String.replace:(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
            ldc "]"
            ldc ""
            invokevirtual java.lang.String.replace:(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
            astore 11 /* stringPermission */
        29: .line 50
            aload 2 /* result */
            aload 11 /* stringPermission */
            invokestatic io.vertx.ext.auth.authorization.WildcardPermissionBasedAuthorization.create:(Ljava/lang/String;)Lio/vertx/ext/auth/authorization/WildcardPermissionBasedAuthorization;
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 11 // java.lang.String stringPermission
        end local 9 // org.apache.shiro.authz.Permission permission
        30: .line 47
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 26
        end local 8 // org.apache.shiro.authz.AuthorizationInfo authorizationInfo
        end local 7 // org.apache.shiro.realm.AuthorizingRealm authorizingRealm
        end local 5 // org.apache.shiro.realm.Realm realm
        31: .line 31
      StackMap locals: org.apache.shiro.mgt.SecurityManager org.apache.shiro.subject.Subject java.util.Set org.apache.shiro.mgt.AuthorizingSecurityManager org.apache.shiro.authz.ModularRealmAuthorizer top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        end local 4 // org.apache.shiro.authz.ModularRealmAuthorizer modularRealmAuthorizer
        end local 3 // org.apache.shiro.mgt.AuthorizingSecurityManager authorizingSecurityManager
        32: .line 60
      StackMap locals: org.apache.shiro.mgt.SecurityManager org.apache.shiro.subject.Subject java.util.Set
      StackMap stack:
            aload 2 /* result */
            areturn
        end local 2 // java.util.Set result
        end local 1 // org.apache.shiro.subject.Subject subject
        end local 0 // org.apache.shiro.mgt.SecurityManager securityManager
      LocalVariableTable:
        Start  End  Slot                        Name  Signature
            0   33     0             securityManager  Lorg/apache/shiro/mgt/SecurityManager;
            0   33     1                     subject  Lorg/apache/shiro/subject/Subject;
            2   33     2                      result  Ljava/util/Set<Lio/vertx/ext/auth/authorization/Authorization;>;
            5   32     3  authorizingSecurityManager  Lorg/apache/shiro/mgt/AuthorizingSecurityManager;
            8   32     4      modularRealmAuthorizer  Lorg/apache/shiro/authz/ModularRealmAuthorizer;
           10   31     5                       realm  Lorg/apache/shiro/realm/Realm;
           12   31     7            authorizingRealm  Lorg/apache/shiro/realm/AuthorizingRealm;
           13   31     8           authorizationInfo  Lorg/apache/shiro/authz/AuthorizationInfo;
           17   18     9                        role  Ljava/lang/String;
           22   23     9                  permission  Ljava/lang/String;
           27   30     9                  permission  Lorg/apache/shiro/authz/Permission;
           28   30    11            stringPermission  Ljava/lang/String;
    Signature: (Lorg/apache/shiro/mgt/SecurityManager;Lorg/apache/shiro/subject/Subject;)Ljava/util/Set<Lio/vertx/ext/auth/authorization/Authorization;>;
    MethodParameters:
                 Name  Flags
      securityManager  
      subject          
}
SourceFile: "GetAuthorizationsHack.java"