class org.springframework.orm.hibernate5.support.AsyncRequestInterceptor implements org.springframework.web.context.request.async.CallableProcessingInterceptor, org.springframework.web.context.request.async.DeferredResultProcessingInterceptor
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: org.springframework.orm.hibernate5.support.AsyncRequestInterceptor
  super_class: java.lang.Object
{
  private static final org.apache.commons.logging.Log logger;
    descriptor: Lorg/apache/commons/logging/Log;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private final org.hibernate.SessionFactory sessionFactory;
    descriptor: Lorg/hibernate/SessionFactory;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.springframework.orm.hibernate5.SessionHolder sessionHolder;
    descriptor: Lorg/springframework/orm/hibernate5/SessionHolder;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private volatile boolean timeoutInProgress;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile boolean errorInProgress;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 46
            ldc Lorg/springframework/orm/hibernate5/support/AsyncRequestInterceptor;
            invokestatic org.apache.commons.logging.LogFactory.getLog:(Ljava/lang/Class;)Lorg/apache/commons/logging/Log;
            putstatic org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.logger:Lorg/apache/commons/logging/Log;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(org.hibernate.SessionFactory, org.springframework.orm.hibernate5.SessionHolder);
    descriptor: (Lorg/hibernate/SessionFactory;Lorg/springframework/orm/hibernate5/SessionHolder;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
        start local 1 // org.hibernate.SessionFactory sessionFactory
        start local 2 // org.springframework.orm.hibernate5.SessionHolder sessionHolder
         0: .line 57
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 58
            aload 0 /* this */
            aload 1 /* sessionFactory */
            putfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.sessionFactory:Lorg/hibernate/SessionFactory;
         2: .line 59
            aload 0 /* this */
            aload 2 /* sessionHolder */
            putfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.sessionHolder:Lorg/springframework/orm/hibernate5/SessionHolder;
         3: .line 60
            return
        end local 2 // org.springframework.orm.hibernate5.SessionHolder sessionHolder
        end local 1 // org.hibernate.SessionFactory sessionFactory
        end local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    4     0            this  Lorg/springframework/orm/hibernate5/support/AsyncRequestInterceptor;
            0    4     1  sessionFactory  Lorg/hibernate/SessionFactory;
            0    4     2   sessionHolder  Lorg/springframework/orm/hibernate5/SessionHolder;
    MethodParameters:
                Name  Flags
      sessionFactory  
      sessionHolder   

  public <T> void preProcess(org.springframework.web.context.request.NativeWebRequest, java.util.concurrent.Callable<T>);
    descriptor: (Lorg/springframework/web/context/request/NativeWebRequest;Ljava/util/concurrent/Callable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=3, args_size=3
        start local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
        start local 1 // org.springframework.web.context.request.NativeWebRequest request
        start local 2 // java.util.concurrent.Callable task
         0: .line 65
            aload 0 /* this */
            invokevirtual org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.bindSession:()V
         1: .line 66
            return
        end local 2 // java.util.concurrent.Callable task
        end local 1 // org.springframework.web.context.request.NativeWebRequest request
        end local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/springframework/orm/hibernate5/support/AsyncRequestInterceptor;
            0    2     1  request  Lorg/springframework/web/context/request/NativeWebRequest;
            0    2     2     task  Ljava/util/concurrent/Callable<TT;>;
    Signature: <T:Ljava/lang/Object;>(Lorg/springframework/web/context/request/NativeWebRequest;Ljava/util/concurrent/Callable<TT;>;)V
    MethodParameters:
         Name  Flags
      request  
      task     

  public void bindSession();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
         0: .line 69
            aload 0 /* this */
            iconst_0
            putfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.timeoutInProgress:Z
         1: .line 70
            aload 0 /* this */
            iconst_0
            putfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.errorInProgress:Z
         2: .line 71
            aload 0 /* this */
            getfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.sessionFactory:Lorg/hibernate/SessionFactory;
            aload 0 /* this */
            getfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.sessionHolder:Lorg/springframework/orm/hibernate5/SessionHolder;
            invokestatic org.springframework.transaction.support.TransactionSynchronizationManager.bindResource:(Ljava/lang/Object;Ljava/lang/Object;)V
         3: .line 72
            return
        end local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/springframework/orm/hibernate5/support/AsyncRequestInterceptor;

  public <T> void postProcess(org.springframework.web.context.request.NativeWebRequest, java.util.concurrent.Callable<T>, );
    descriptor: (Lorg/springframework/web/context/request/NativeWebRequest;Ljava/util/concurrent/Callable;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=4, args_size=4
        start local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
        start local 1 // org.springframework.web.context.request.NativeWebRequest request
        start local 2 // java.util.concurrent.Callable task
        start local 3 // java.lang.Object concurrentResult
         0: .line 76
            aload 0 /* this */
            getfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.sessionFactory:Lorg/hibernate/SessionFactory;
            invokestatic org.springframework.transaction.support.TransactionSynchronizationManager.unbindResource:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 77
            return
        end local 3 // java.lang.Object concurrentResult
        end local 2 // java.util.concurrent.Callable task
        end local 1 // org.springframework.web.context.request.NativeWebRequest request
        end local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    2     0              this  Lorg/springframework/orm/hibernate5/support/AsyncRequestInterceptor;
            0    2     1           request  Lorg/springframework/web/context/request/NativeWebRequest;
            0    2     2              task  Ljava/util/concurrent/Callable<TT;>;
            0    2     3  concurrentResult  Ljava/lang/Object;
    Signature: <T:Ljava/lang/Object;>(Lorg/springframework/web/context/request/NativeWebRequest;Ljava/util/concurrent/Callable<TT;>;Ljava/lang/Object;)V
    MethodParameters:
                  Name  Flags
      request           
      task              
      concurrentResult  

  public <T>  handleTimeout(org.springframework.web.context.request.NativeWebRequest, java.util.concurrent.Callable<T>);
    descriptor: (Lorg/springframework/web/context/request/NativeWebRequest;Ljava/util/concurrent/Callable;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
        start local 1 // org.springframework.web.context.request.NativeWebRequest request
        start local 2 // java.util.concurrent.Callable task
         0: .line 81
            aload 0 /* this */
            iconst_1
            putfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.timeoutInProgress:Z
         1: .line 82
            getstatic org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.RESULT_NONE:Ljava/lang/Object;
            areturn
        end local 2 // java.util.concurrent.Callable task
        end local 1 // org.springframework.web.context.request.NativeWebRequest request
        end local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/springframework/orm/hibernate5/support/AsyncRequestInterceptor;
            0    2     1  request  Lorg/springframework/web/context/request/NativeWebRequest;
            0    2     2     task  Ljava/util/concurrent/Callable<TT;>;
    Signature: <T:Ljava/lang/Object;>(Lorg/springframework/web/context/request/NativeWebRequest;Ljava/util/concurrent/Callable<TT;>;)Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      request  
      task     

  public <T>  handleError(org.springframework.web.context.request.NativeWebRequest, java.util.concurrent.Callable<T>, java.lang.Throwable);
    descriptor: (Lorg/springframework/web/context/request/NativeWebRequest;Ljava/util/concurrent/Callable;Ljava/lang/Throwable;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
        start local 1 // org.springframework.web.context.request.NativeWebRequest request
        start local 2 // java.util.concurrent.Callable task
        start local 3 // java.lang.Throwable t
         0: .line 87
            aload 0 /* this */
            iconst_1
            putfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.errorInProgress:Z
         1: .line 88
            getstatic org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.RESULT_NONE:Ljava/lang/Object;
            areturn
        end local 3 // java.lang.Throwable t
        end local 2 // java.util.concurrent.Callable task
        end local 1 // org.springframework.web.context.request.NativeWebRequest request
        end local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/springframework/orm/hibernate5/support/AsyncRequestInterceptor;
            0    2     1  request  Lorg/springframework/web/context/request/NativeWebRequest;
            0    2     2     task  Ljava/util/concurrent/Callable<TT;>;
            0    2     3        t  Ljava/lang/Throwable;
    Signature: <T:Ljava/lang/Object;>(Lorg/springframework/web/context/request/NativeWebRequest;Ljava/util/concurrent/Callable<TT;>;Ljava/lang/Throwable;)Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      request  
      task     
      t        

  public <T> void afterCompletion(org.springframework.web.context.request.NativeWebRequest, java.util.concurrent.Callable<T>);
    descriptor: (Lorg/springframework/web/context/request/NativeWebRequest;Ljava/util/concurrent/Callable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=3, args_size=3
        start local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
        start local 1 // org.springframework.web.context.request.NativeWebRequest request
        start local 2 // java.util.concurrent.Callable task
         0: .line 93
            aload 0 /* this */
            invokevirtual org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.closeSession:()V
         1: .line 94
            return
        end local 2 // java.util.concurrent.Callable task
        end local 1 // org.springframework.web.context.request.NativeWebRequest request
        end local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/springframework/orm/hibernate5/support/AsyncRequestInterceptor;
            0    2     1  request  Lorg/springframework/web/context/request/NativeWebRequest;
            0    2     2     task  Ljava/util/concurrent/Callable<TT;>;
    Exceptions:
      throws java.lang.Exception
    Signature: <T:Ljava/lang/Object;>(Lorg/springframework/web/context/request/NativeWebRequest;Ljava/util/concurrent/Callable<TT;>;)V
    MethodParameters:
         Name  Flags
      request  
      task     

  private void closeSession();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
         0: .line 97
            aload 0 /* this */
            getfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.timeoutInProgress:Z
            ifne 1
            aload 0 /* this */
            getfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.errorInProgress:Z
            ifeq 3
         1: .line 98
      StackMap locals:
      StackMap stack:
            getstatic org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.logger:Lorg/apache/commons/logging/Log;
            ldc "Closing Hibernate Session after async request timeout/error"
            invokeinterface org.apache.commons.logging.Log.debug:(Ljava/lang/Object;)V
         2: .line 99
            aload 0 /* this */
            getfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.sessionHolder:Lorg/springframework/orm/hibernate5/SessionHolder;
            invokevirtual org.springframework.orm.hibernate5.SessionHolder.getSession:()Lorg/hibernate/Session;
            invokestatic org.springframework.orm.hibernate5.SessionFactoryUtils.closeSession:(Lorg/hibernate/Session;)V
         3: .line 101
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/springframework/orm/hibernate5/support/AsyncRequestInterceptor;

  public <T> boolean handleTimeout(org.springframework.web.context.request.NativeWebRequest, org.springframework.web.context.request.async.DeferredResult<T>);
    descriptor: (Lorg/springframework/web/context/request/NativeWebRequest;Lorg/springframework/web/context/request/async/DeferredResult;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
        start local 1 // org.springframework.web.context.request.NativeWebRequest request
        start local 2 // org.springframework.web.context.request.async.DeferredResult deferredResult
         0: .line 108
            aload 0 /* this */
            iconst_1
            putfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.timeoutInProgress:Z
         1: .line 109
            iconst_1
            ireturn
        end local 2 // org.springframework.web.context.request.async.DeferredResult deferredResult
        end local 1 // org.springframework.web.context.request.NativeWebRequest request
        end local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            this  Lorg/springframework/orm/hibernate5/support/AsyncRequestInterceptor;
            0    2     1         request  Lorg/springframework/web/context/request/NativeWebRequest;
            0    2     2  deferredResult  Lorg/springframework/web/context/request/async/DeferredResult<TT;>;
    Signature: <T:Ljava/lang/Object;>(Lorg/springframework/web/context/request/NativeWebRequest;Lorg/springframework/web/context/request/async/DeferredResult<TT;>;)Z
    MethodParameters:
                Name  Flags
      request         
      deferredResult  

  public <T> boolean handleError(org.springframework.web.context.request.NativeWebRequest, org.springframework.web.context.request.async.DeferredResult<T>, java.lang.Throwable);
    descriptor: (Lorg/springframework/web/context/request/NativeWebRequest;Lorg/springframework/web/context/request/async/DeferredResult;Ljava/lang/Throwable;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
        start local 1 // org.springframework.web.context.request.NativeWebRequest request
        start local 2 // org.springframework.web.context.request.async.DeferredResult deferredResult
        start local 3 // java.lang.Throwable t
         0: .line 114
            aload 0 /* this */
            iconst_1
            putfield org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.errorInProgress:Z
         1: .line 115
            iconst_1
            ireturn
        end local 3 // java.lang.Throwable t
        end local 2 // org.springframework.web.context.request.async.DeferredResult deferredResult
        end local 1 // org.springframework.web.context.request.NativeWebRequest request
        end local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            this  Lorg/springframework/orm/hibernate5/support/AsyncRequestInterceptor;
            0    2     1         request  Lorg/springframework/web/context/request/NativeWebRequest;
            0    2     2  deferredResult  Lorg/springframework/web/context/request/async/DeferredResult<TT;>;
            0    2     3               t  Ljava/lang/Throwable;
    Signature: <T:Ljava/lang/Object;>(Lorg/springframework/web/context/request/NativeWebRequest;Lorg/springframework/web/context/request/async/DeferredResult<TT;>;Ljava/lang/Throwable;)Z
    MethodParameters:
                Name  Flags
      request         
      deferredResult  
      t               

  public <T> void afterCompletion(org.springframework.web.context.request.NativeWebRequest, org.springframework.web.context.request.async.DeferredResult<T>);
    descriptor: (Lorg/springframework/web/context/request/NativeWebRequest;Lorg/springframework/web/context/request/async/DeferredResult;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=3, args_size=3
        start local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
        start local 1 // org.springframework.web.context.request.NativeWebRequest request
        start local 2 // org.springframework.web.context.request.async.DeferredResult deferredResult
         0: .line 120
            aload 0 /* this */
            invokevirtual org.springframework.orm.hibernate5.support.AsyncRequestInterceptor.closeSession:()V
         1: .line 121
            return
        end local 2 // org.springframework.web.context.request.async.DeferredResult deferredResult
        end local 1 // org.springframework.web.context.request.NativeWebRequest request
        end local 0 // org.springframework.orm.hibernate5.support.AsyncRequestInterceptor this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            this  Lorg/springframework/orm/hibernate5/support/AsyncRequestInterceptor;
            0    2     1         request  Lorg/springframework/web/context/request/NativeWebRequest;
            0    2     2  deferredResult  Lorg/springframework/web/context/request/async/DeferredResult<TT;>;
    Signature: <T:Ljava/lang/Object;>(Lorg/springframework/web/context/request/NativeWebRequest;Lorg/springframework/web/context/request/async/DeferredResult<TT;>;)V
    MethodParameters:
                Name  Flags
      request         
      deferredResult  
}
SourceFile: "AsyncRequestInterceptor.java"