Ошибка Play & Deadbolt

Я получаю следующую трассировку стека (не на загруженной странице!) Всякий раз, когда я устанавливаю любой из моих методов с помощью

@SubjectRequired или же @SubjectNotRequired аннотации:

play.api.http.HttpErrorHandlerExceptions$$anon$1: Execution exception[[CompletionException: java.lang.NullPointerException]]
    at play.api.http.HttpErrorHandlerExceptions$.throwableToUsefulException(HttpErrorHandler.scala:293)
    at play.api.http.DefaultHttpErrorHandler.onServerError(HttpErrorHandler.scala:220)
    at play.api.GlobalSettings$class.onError(GlobalSettings.scala:160)
    at play.api.DefaultGlobal$.onError(GlobalSettings.scala:188)
    at play.api.http.GlobalSettingsHttpErrorHandler.onServerError(HttpErrorHandler.scala:100)
    at play.core.server.netty.PlayRequestHandler$$anonfun$2$$anonfun$apply$1.applyOrElse(PlayRequestHandler.scala:100)
    at play.core.server.netty.PlayRequestHandler$$anonfun$2$$anonfun$apply$1.applyOrElse(PlayRequestHandler.scala:99)
    at scala.concurrent.Future$$anonfun$recoverWith$1.apply(Future.scala:344)
    at scala.concurrent.Future$$anonfun$recoverWith$1.apply(Future.scala:343)
    at scala.concurrent.impl.CallbackRunnable.run(Promise.scala:32)
Caused by: java.util.concurrent.CompletionException: java.lang.NullPointerException
    at java.util.concurrent.CompletableFuture.encodeThrowable(CompletableFuture.java:273)
    at java.util.concurrent.CompletableFuture.completeThrowable(CompletableFuture.java:280)
    at java.util.concurrent.CompletableFuture.uniCompose(CompletableFuture.java:961)
    at java.util.concurrent.CompletableFuture$UniCompose.tryFire(CompletableFuture.java:926)
    at java.util.concurrent.CompletableFuture$Completion.run(CompletableFuture.java:442)
    at play.core.j.HttpExecutionContext$$anon$2.run(HttpExecutionContext.scala:56)
    at play.core.j.HttpExecutionContext$$anon$2.run(HttpExecutionContext.scala:56)
    at akka.dispatch.TaskInvocation.run(AbstractDispatcher.scala:39)
    at akka.dispatch.ForkJoinExecutorConfigurator$AkkaForkJoinTask.exec(AbstractDispatcher.scala:415)
    at scala.concurrent.forkjoin.ForkJoinTask.doExec(ForkJoinTask.java:260)
Caused by: java.lang.NullPointerException: null
    at be.objectify.deadbolt.java.cache.DefaultSubjectCache.apply(DefaultSubjectCache.java:80)
    at be.objectify.deadbolt.java.cache.DefaultSubjectCache.apply(DefaultSubjectCache.java:38)
    at be.objectify.deadbolt.java.ConstraintLogic.getSubject(ConstraintLogic.java:348)
    at be.objectify.deadbolt.java.ConstraintLogic.subjectTest(ConstraintLogic.java:116)
    at be.objectify.deadbolt.java.ConstraintLogic.subjectPresent(ConstraintLogic.java:72)
    at be.objectify.deadbolt.java.actions.SubjectPresentAction.lambda$testSubject$129(SubjectPresentAction.java:91)
    at java.util.Optional.orElseGet(Optional.java:267)
    at be.objectify.deadbolt.java.actions.AbstractSubjectAction.lambda$execute$118(AbstractSubjectAction.java:76)
    at java.util.concurrent.CompletableFuture.uniCompose(CompletableFuture.java:952)
    at java.util.concurrent.CompletableFuture$UniCompose.tryFire(CompletableFuture.java:926)

Мой код выглядит так:

В классе реализации DeadboltHandler

@Override
public CompletionStage<Optional<? extends Subject>> getSubject(Context elContext) {
    return CompletableFuture.supplyAsync(
        () -> {
            try {
                return Optional.ofNullable(da.getUser(Integer.parseInt( elContext.session().get("userId"))));
            } catch (Exception e) {
                e.printStackTrace();
                return null;
            } 
        });
}

где есть конструктор:

DataAccess da;

DeadboltSecureHandler(Database db){
    da = new DataAccess(db);
}

И в классе реализации HandlerCache

@Inject 
public DeadboltHandlerCache(Database db){
    DeadboltHandler defaultHandler = new DeadboltSecureHandler(db);
    handlers.put(HandlerKeys.DEFAULT.key, defaultHandler);
}

@Override
public DeadboltHandler apply(final String key){
    return handlers.get(key);
}

@Override
public DeadboltHandler get(){
    return defaultHandler;
}

Есть идеи, что я испортил?

1 ответ

Решение

Несколько вещей...

deadboltHandler вы используете ноль, и наиболее вероятное объяснение этого HandlerKeys.DEFAULT.key это не то же самое, что be.objectify.deadbolt.java.ConfigKeys.DEFAULT_HANDLER_KEY,

Если вы посмотрите документацию, то обнаружите следующее (что заставляет меня догадываться, что вы используете версию Deadbolt старше 2.5.3):

Обратите внимание на использование ConfigKeys.DEFAULT_HANDLER_KEY - это ключ обработчика по умолчанию, указанный во всех аннотациях. В предыдущих версиях Deadbolt ограничения на основе аннотаций использовались HandlerCache#apply(DEFAULT_HANDLER_KEY) чтобы получить обработчик и поэтому обработчик по умолчанию должен быть связан с DEFAULT_HANDLER_KEY, Начиная с Deadbolt 2.5.3, это было улучшено, и вместо этого любое ограничение на основе аннотаций, использующее ключ обработчика по умолчанию, будет использовать HandlerCache#get,

Следующая проблема, с которой вы столкнетесь с вашим текущим кодом:

Когда ты вернешься nullты нарушаешь контракт getSubject метод. Всякий раз, когда что-то возвращается CompletionStage<Optional<? extends Subject>>, CompletionStage должен содержать Optional, Вместо возвращения null, вернуть Optional.empty(),

Другие вопросы по тегам