You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@geode.apache.org by "Kirk Lund (JIRA)" <ji...@apache.org> on 2016/03/01 00:14:18 UTC

[jira] [Comment Edited] (GEODE-1024) NotAuthorizedException fails serialization because Principal member field is not serializable

    [ https://issues.apache.org/jira/browse/GEODE-1024?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15172832#comment-15172832 ] 

Kirk Lund edited comment on GEODE-1024 at 2/29/16 11:13 PM:
------------------------------------------------------------

New unit test for NotAuthroizedException reproduces the failure with a mock Principal. See attachment.


was (Author: klund):
New unit test for NotAuthroizedException reproduces the failure with a mock Principal.

> NotAuthorizedException fails serialization because Principal member field is not serializable
> ---------------------------------------------------------------------------------------------
>
>                 Key: GEODE-1024
>                 URL: https://issues.apache.org/jira/browse/GEODE-1024
>             Project: Geode
>          Issue Type: Bug
>          Components: management
>            Reporter: Kirk Lund
>         Attachments: NotAuthorizedExceptionTest.java
>
>
> While running Geode with LDAP security, I hit this failure:
> {noformat}
> 7420-2: [warning 2016/02/25 19:24:34.134 PST bridgegemfire1_latvia_7420 <ServerConnection on port 26419 Thread 19> tid=0xa5] Server connection from [identity(latvia(invalidgemfire1_latvia_7480:7480:loner):49923:843f9b1b:invalidgemfire1_latvia_7480,connection=1; port=49924]: Unexpected Exception
> com.gemstone.gemfire.SerializationException: failed serializing object
>         at com.gemstone.gemfire.internal.cache.tier.sockets.Message.serializeAndAddPart(Message.java:371)
>         at com.gemstone.gemfire.internal.cache.tier.sockets.Message.addObjPart(Message.java:302)
>         at com.gemstone.gemfire.internal.cache.tier.sockets.Message.addObjPart(Message.java:285)
>         at com.gemstone.gemfire.internal.cache.tier.sockets.BaseCommand.writeException(BaseCommand.java:636)
>         at com.gemstone.gemfire.internal.cache.tier.sockets.BaseCommand.writeException(BaseCommand.java:620)
>         at com.gemstone.gemfire.internal.cache.tier.sockets.command.PutUserCredentials.cmdExecute(PutUserCredentials.java:61)
>         at com.gemstone.gemfire.internal.cache.tier.sockets.BaseCommand.execute(BaseCommand.java:175)
>         at com.gemstone.gemfire.internal.cache.tier.sockets.ServerConnection.doNormalMsg(ServerConnection.java:796)
>         at com.gemstone.gemfire.internal.cache.tier.sockets.ServerConnection.doOneMessage(ServerConnection.java:923)
>         at com.gemstone.gemfire.internal.cache.tier.sockets.ServerConnection.run(ServerConnection.java:1168)
>         at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
>         at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
>         at com.gemstone.gemfire.internal.cache.tier.sockets.AcceptorImpl$1$1.run(AcceptorImpl.java:561)
>         at java.lang.Thread.run(Thread.java:745)
> Caused by: java.io.NotSerializableException: com.sun.jndi.ldap.LdapCtx
>         at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1184)
>         at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1548)
>         at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1509)
>         at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1432)
>         at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1178)
>         at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1548)
>         at java.io.ObjectOutputStream.defaultWriteObject(ObjectOutputStream.java:441)
>         at java.lang.Throwable.writeObject(Throwable.java:985)
>         at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>         at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
>         at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
>         at java.lang.reflect.Method.invoke(Method.java:497)
>         at java.io.ObjectStreamClass.invokeWriteObject(ObjectStreamClass.java:1028)
>         at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1496)
>         at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1432)
>         at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1178)
>         at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:348)
>         at com.gemstone.gemfire.internal.InternalDataSerializer.writeSerializableObject(InternalDataSerializer.java:2364)
>         at com.gemstone.gemfire.internal.InternalDataSerializer.basicWriteObject(InternalDataSerializer.java:2229)
>         at com.gemstone.gemfire.DataSerializer.writeObject(DataSerializer.java:3241)
>         at com.gemstone.gemfire.internal.util.BlobHelper.serializeTo(BlobHelper.java:76)
>         at com.gemstone.gemfire.internal.cache.tier.sockets.Message.serializeAndAddPart(Message.java:369)
>         ... 13 more
> {noformat}
> While troubleshooting, I found that NotAuthroizedException has a non-serializable member field of type java.security.Principal.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)