Return-Path: X-Original-To: apmail-ignite-commits-archive@minotaur.apache.org Delivered-To: apmail-ignite-commits-archive@minotaur.apache.org Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by minotaur.apache.org (Postfix) with SMTP id ECFDD107DA for ; Thu, 14 May 2015 13:28:27 +0000 (UTC) Received: (qmail 48109 invoked by uid 500); 14 May 2015 13:28:27 -0000 Delivered-To: apmail-ignite-commits-archive@ignite.apache.org Received: (qmail 48077 invoked by uid 500); 14 May 2015 13:28:27 -0000 Mailing-List: contact commits-help@ignite.incubator.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@ignite.incubator.apache.org Delivered-To: mailing list commits@ignite.incubator.apache.org Received: (qmail 48068 invoked by uid 99); 14 May 2015 13:28:27 -0000 Received: from Unknown (HELO spamd1-us-west.apache.org) (209.188.14.142) by apache.org (qpsmtpd/0.29) with ESMTP; Thu, 14 May 2015 13:28:27 +0000 Received: from localhost (localhost [127.0.0.1]) by spamd1-us-west.apache.org (ASF Mail Server at spamd1-us-west.apache.org) with ESMTP id 5779AC4D5A for ; Thu, 14 May 2015 13:28:27 +0000 (UTC) X-Virus-Scanned: Debian amavisd-new at spamd1-us-west.apache.org X-Spam-Flag: NO X-Spam-Score: 1.771 X-Spam-Level: * X-Spam-Status: No, score=1.771 tagged_above=-999 required=6.31 tests=[KAM_ASCII_DIVIDERS=0.8, KAM_LAZY_DOMAIN_SECURITY=1, RCVD_IN_MSPIKE_H3=-0.01, RCVD_IN_MSPIKE_WL=-0.01, T_RP_MATCHES_RCVD=-0.01, URIBL_BLOCKED=0.001] autolearn=disabled Received: from mx1-eu-west.apache.org ([10.40.0.8]) by localhost (spamd1-us-west.apache.org [10.40.0.7]) (amavisd-new, port 10024) with ESMTP id cZQJBraNUPSj for ; Thu, 14 May 2015 13:28:26 +0000 (UTC) Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by mx1-eu-west.apache.org (ASF Mail Server at mx1-eu-west.apache.org) with SMTP id 9CC2623164 for ; Thu, 14 May 2015 13:28:25 +0000 (UTC) Received: (qmail 48057 invoked by uid 99); 14 May 2015 13:28:24 -0000 Received: from git1-us-west.apache.org (HELO git1-us-west.apache.org) (140.211.11.23) by apache.org (qpsmtpd/0.29) with ESMTP; Thu, 14 May 2015 13:28:24 +0000 Received: by git1-us-west.apache.org (ASF Mail Server at git1-us-west.apache.org, from userid 33) id 73E91DFFEF; Thu, 14 May 2015 13:28:24 +0000 (UTC) Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: sboikov@apache.org To: commits@ignite.incubator.apache.org Date: Thu, 14 May 2015 13:28:24 -0000 Message-Id: <630d86d111da4af99a1bef6030a932ed@git.apache.org> X-Mailer: ASF-Git Admin Mailer Subject: [1/3] incubator-ignite git commit: ignite-471: fixed buffer overflow exception in optimizedmarshaller Repository: incubator-ignite Updated Branches: refs/heads/ignite-471 505dc6286 -> 1f021a734 ignite-471: fixed buffer overflow exception in optimizedmarshaller Project: http://git-wip-us.apache.org/repos/asf/incubator-ignite/repo Commit: http://git-wip-us.apache.org/repos/asf/incubator-ignite/commit/887cb015 Tree: http://git-wip-us.apache.org/repos/asf/incubator-ignite/tree/887cb015 Diff: http://git-wip-us.apache.org/repos/asf/incubator-ignite/diff/887cb015 Branch: refs/heads/ignite-471 Commit: 887cb01544555e506f34ac69196e3cd83296f9d7 Parents: 505dc62 Author: Denis Magda Authored: Thu May 14 09:54:53 2015 +0300 Committer: Denis Magda Committed: Thu May 14 09:54:53 2015 +0300 ---------------------------------------------------------------------- .../GridClientOptimizedMarshaller.java | 2 +- .../optimized/OptimizedMarshaller.java | 22 +++++++++++++++++++- 2 files changed, 22 insertions(+), 2 deletions(-) ---------------------------------------------------------------------- http://git-wip-us.apache.org/repos/asf/incubator-ignite/blob/887cb015/modules/core/src/main/java/org/apache/ignite/internal/client/marshaller/optimized/GridClientOptimizedMarshaller.java ---------------------------------------------------------------------- diff --git a/modules/core/src/main/java/org/apache/ignite/internal/client/marshaller/optimized/GridClientOptimizedMarshaller.java b/modules/core/src/main/java/org/apache/ignite/internal/client/marshaller/optimized/GridClientOptimizedMarshaller.java index ff77177..9fd6bbc 100644 --- a/modules/core/src/main/java/org/apache/ignite/internal/client/marshaller/optimized/GridClientOptimizedMarshaller.java +++ b/modules/core/src/main/java/org/apache/ignite/internal/client/marshaller/optimized/GridClientOptimizedMarshaller.java @@ -67,7 +67,7 @@ public class GridClientOptimizedMarshaller implements GridClientMarshaller { throw new IOException("Message serialization of given type is not supported: " + obj.getClass().getName()); - return opMarsh.marshal(obj); + return opMarsh.marshal(obj, off); } catch (IgniteCheckedException e) { throw new IOException(e); http://git-wip-us.apache.org/repos/asf/incubator-ignite/blob/887cb015/modules/core/src/main/java/org/apache/ignite/marshaller/optimized/OptimizedMarshaller.java ---------------------------------------------------------------------- diff --git a/modules/core/src/main/java/org/apache/ignite/marshaller/optimized/OptimizedMarshaller.java b/modules/core/src/main/java/org/apache/ignite/marshaller/optimized/OptimizedMarshaller.java index a29bda2..28433ec 100644 --- a/modules/core/src/main/java/org/apache/ignite/marshaller/optimized/OptimizedMarshaller.java +++ b/modules/core/src/main/java/org/apache/ignite/marshaller/optimized/OptimizedMarshaller.java @@ -172,6 +172,18 @@ public class OptimizedMarshaller extends AbstractMarshaller { /** {@inheritDoc} */ @Override public ByteBuffer marshal(@Nullable Object obj) throws IgniteCheckedException { + return marshal(obj, 0); + } + + /** + * Marshals object to bytes. + * + * @param obj Object to marshal. + * @param offset Position where to start marshalling the object. + * @return Byte buffer. + * @throws IgniteCheckedException If marshalling failed. + */ + public ByteBuffer marshal(@Nullable Object obj, int offset) throws IgniteCheckedException { OptimizedObjectOutputStream objOut = null; try { @@ -182,7 +194,15 @@ public class OptimizedMarshaller extends AbstractMarshaller { objOut.writeObject(obj); - return ByteBuffer.wrap(objOut.out().internalArray(), 0, objOut.out().offset()); + ByteBuffer buffer = ByteBuffer.allocate(objOut.out().offset() + offset); + + buffer.position(offset); + + buffer.put(objOut.out().internalArray(), 0, objOut.out().offset()); + + buffer.flip(); + + return buffer; } catch (IOException e) { throw new IgniteCheckedException("Failed to serialize object: " + obj, e);