Albert Stoune via FreeIPA-users wrote: > Hello! > I encountered a problem when revoking a certificate: "IPA Error 4035: > HTTPRequestError: Request failed with status 500: Non-2xx response from CA > REST API: 500." > > First of all, I looked at the Apache logs in /var/log/httpd/accsess.log and > found next error: > > [08/Dec/2023:13:27:39 +0300] "POST /ca/rest/agent/certs/10/revoke HTTP/1.1" > 500 6504 > > > Then, in /var/log/httpd/error_log: > > ipa: INFO: [jsonserver_session] admin@TEST.LOCAL: cert_revoke('10', > revocation_reason='0', cacn='ipa', version='2.253'): HTTPRequestError > > > And finally I found traceback, which looks like bug in DogTag logs in > /var/log/pki/pki-tomcat/ca/debug.2023-12-08.log: > > 2023-12-08 13:27:39 [ajp-nio-0:0:0:0:0:0:0:1-8009-exec-7] INFO: LDAPSession: > Retrieving cn=10,ou=certificateRepository, ou=ca,o=ipaca > 2023-12-08 13:27:39 [ajp-nio-0:0:0:0:0:0:0:1-8009-exec-7] SEVERE: > Servlet.service() for servlet [Resteasy] in context with path [/ca] threw > exception > org.jboss.resteasy.spi.UnhandledException: java.lang.NullPointerException: > Cannot invoke "String.toLowerCase()" because "<parameter1>" is null > at > org.jboss.resteasy.core.ExceptionHandler.handleApplicationException(ExceptionHandler.java:78) > at > org.jboss.resteasy.core.ExceptionHandler.handleException(ExceptionHandler.java:222) > at > org.jboss.resteasy.core.SynchronousDispatcher.writeException(SynchronousDispatcher.java:179) > at > org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:422) > at > org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:213) > at > org.jboss.resteasy.plugins.server.servlet.ServletContainerDispatcher.service(ServletContainerDispatcher.java:228) > at > org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:56) > at > org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:51) > at javax.servlet.http.HttpServlet.service(HttpServlet.java:764) > at jdk.internal.reflect.GeneratedMethodAccessor42.invoke(Unknown > Source) > at > java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) > at java.base/java.lang.reflect.Method.invoke(Method.java:568) > at > org.apache.catalina.security.SecurityUtil.lambda$execute$0(SecurityUtil.java:280) > at > java.base/java.security.AccessController.doPrivileged(AccessController.java:712) > at > java.base/javax.security.auth.Subject.doAsPrivileged(Subject.java:584) > at > org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:311) > at > org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:170) > at > org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:221) > at > org.apache.catalina.core.ApplicationFilterChain.lambda$doFilter$0(ApplicationFilterChain.java:145) > at > java.base/java.security.AccessController.doPrivileged(AccessController.java:569) > at > org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:143) > at > org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) > at jdk.internal.reflect.GeneratedMethodAccessor41.invoke(Unknown > Source) > at > java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) > at java.base/java.lang.reflect.Method.invoke(Method.java:568) > at > org.apache.catalina.security.SecurityUtil.lambda$execute$0(SecurityUtil.java:280) > at > java.base/java.security.AccessController.doPrivileged(AccessController.java:712) > at > java.base/javax.security.auth.Subject.doAsPrivileged(Subject.java:584) > at > org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:311) > at > org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:253) > at > org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:187) > at > org.apache.catalina.core.ApplicationFilterChain.lambda$doFilter$0(ApplicationFilterChain.java:145) > at > java.base/java.security.AccessController.doPrivileged(AccessController.java:569) > at > org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:143) > at > org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:197) > at > org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97) > at > org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:660) > at > com.netscape.cms.tomcat.ExternalAuthenticationValve.invoke(ExternalAuthenticationValve.java:83) > at > org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:135) > at > org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92) > at > org.apache.catalina.valves.rewrite.RewriteValve.invoke(RewriteValve.java:555) > at > org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:687) > at > org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78) > at > org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:360) > at org.apache.coyote.ajp.AjpProcessor.service(AjpProcessor.java:433) > at > org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) > at > org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:890) > at > org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1743) > at > org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) > at > org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) > at > org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) > at > org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) > at java.base/java.lang.Thread.run(Thread.java:833) > Caused by: java.lang.NullPointerException: Cannot invoke > "String.toLowerCase()" because "<parameter1>" is null > at > org.mozilla.jss.netscape.security.x509.RevocationReason.valueOf(RevocationReason.java:91) > at > org.dogtagpki.server.ca.rest.CertService.revokeCert(CertService.java:180) > at > org.dogtagpki.server.ca.rest.CertService.revokeCert(CertService.java:162) > at > java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) > at > java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77) > at > java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) > at java.base/java.lang.reflect.Method.invoke(Method.java:568) > at > org.jboss.resteasy.core.MethodInjectorImpl.invoke(MethodInjectorImpl.java:140) > at > org.jboss.resteasy.core.ResourceMethodInvoker.invokeOnTarget(ResourceMethodInvoker.java:295) > at > org.jboss.resteasy.core.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:249) > at > org.jboss.resteasy.core.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:236) > at > org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:406) > ... 49 more > > It looks like internal mechanisms in DogTag can't parse some arguments from > LDAP-response. When I'm check similar request to LDAP with ldapsearch I got > response with certificate details. Looks like all correct in LDAP. > > Additional info for debug: command "ipactl status" shows like everything is > good > Directory Service: RUNNING > krb5kdc Service: RUNNING > kadmin Service: RUNNING > named Service: RUNNING > httpd Service: RUNNING > ipa-custodia Service: RUNNING > pki-tomcatd Service: RUNNING > ipa-otpd Service: RUNNING > ipa-dnskeysyncd Service: RUNNING > ipa: INFO: The ipactl command was successful > > Also, I can create new certificates, but can't delete already signed. And > also I can't delete Services with signed certs, and can't delete Hosts with > that Services > > FreeIPA version: VERSION: 4.11.0, API_VERSION: 2.253
This is related to https://pagure.io/freeipa/issue/9345 . PKI for some reason made the API call for revocation case-sensitive. We weren't aware that this code was in the wild yet. What version of PKI are you running and on what distribution? rob -- _______________________________________________ FreeIPA-users mailing list -- freeipa-users@lists.fedorahosted.org To unsubscribe send an email to freeipa-users-le...@lists.fedorahosted.org Fedora Code of Conduct: https://docs.fedoraproject.org/en-US/project/code-of-conduct/ List Guidelines: https://fedoraproject.org/wiki/Mailing_list_guidelines List Archives: https://lists.fedorahosted.org/archives/list/freeipa-users@lists.fedorahosted.org Do not reply to spam, report it: https://pagure.io/fedora-infrastructure/new_issue