aboutsummaryrefslogtreecommitdiffstats
path: root/org.eclipse.jgit/src/org/eclipse/jgit
diff options
context:
space:
mode:
Diffstat (limited to 'org.eclipse.jgit/src/org/eclipse/jgit')
-rw-r--r--org.eclipse.jgit/src/org/eclipse/jgit/JGitText.java2
-rw-r--r--org.eclipse.jgit/src/org/eclipse/jgit/errors/TooLargeObjectInPackException.java82
-rw-r--r--org.eclipse.jgit/src/org/eclipse/jgit/transport/PackParser.java46
-rw-r--r--org.eclipse.jgit/src/org/eclipse/jgit/transport/ReceivePack.java17
4 files changed, 145 insertions, 2 deletions
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/JGitText.java b/org.eclipse.jgit/src/org/eclipse/jgit/JGitText.java
index e64534753e..fcc6cafd5e 100644
--- a/org.eclipse.jgit/src/org/eclipse/jgit/JGitText.java
+++ b/org.eclipse.jgit/src/org/eclipse/jgit/JGitText.java
@@ -419,6 +419,8 @@ public class JGitText extends TranslationBundle {
/***/ public String rawLogMessageDoesNotParseAsLogEntry;
/***/ public String readTimedOut;
/***/ public String readingObjectsFromLocalRepositoryFailed;
+ /***/ public String receivePackObjectTooLarge1;
+ /***/ public String receivePackObjectTooLarge2;
/***/ public String receivingObjects;
/***/ public String refAlreadyExists;
/***/ public String refNotResolved;
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/errors/TooLargeObjectInPackException.java b/org.eclipse.jgit/src/org/eclipse/jgit/errors/TooLargeObjectInPackException.java
new file mode 100644
index 0000000000..dbe480ab90
--- /dev/null
+++ b/org.eclipse.jgit/src/org/eclipse/jgit/errors/TooLargeObjectInPackException.java
@@ -0,0 +1,82 @@
+/*
+ * Copyright (C) 2011, Sasa Zivkov <sasa.zivkov@sap.com>
+ * and other copyright owners as documented in the project's IP log.
+ *
+ * This program and the accompanying materials are made available
+ * under the terms of the Eclipse Distribution License v1.0 which
+ * accompanies this distribution, is reproduced below, and is
+ * available at http://www.eclipse.org/org/documents/edl-v10.php
+ *
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or
+ * without modification, are permitted provided that the following
+ * conditions are met:
+ *
+ * - Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ *
+ * - Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ *
+ * - Neither the name of the Eclipse Foundation, Inc. nor the
+ * names of its contributors may be used to endorse or promote
+ * products derived from this software without specific prior
+ * written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
+ * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
+ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+package org.eclipse.jgit.errors;
+
+import java.io.IOException;
+import java.text.MessageFormat;
+
+import org.eclipse.jgit.JGitText;
+
+/** Thrown when PackParser finds an object larger than a predefined limit */
+public class TooLargeObjectInPackException extends IOException {
+ private static final long serialVersionUID = 1L;
+
+ /**
+ * Construct a too large object in pack exception when the exact size of the
+ * too large object is not available. This will be used when we find out
+ * that a delta sequence is already larger than the maxObjectSizeLimit but
+ * don't want to inflate the delta just to find out the exact size of the
+ * resulting object.
+ *
+ * @param maxObjectSizeLimit
+ * the maximum object size limit
+ */
+ public TooLargeObjectInPackException(long maxObjectSizeLimit) {
+ super(MessageFormat.format(JGitText.get().receivePackObjectTooLarge1,
+ maxObjectSizeLimit));
+ }
+
+ /**
+ * Construct a too large object in pack exception when the exact size of the
+ * too large object is known.
+ *
+ * @param objectSize
+ * @param maxObjectSizeLimit
+ */
+ public TooLargeObjectInPackException(long objectSize,
+ long maxObjectSizeLimit) {
+ super(MessageFormat.format(JGitText.get().receivePackObjectTooLarge2,
+ objectSize, maxObjectSizeLimit));
+ }
+} \ No newline at end of file
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/transport/PackParser.java b/org.eclipse.jgit/src/org/eclipse/jgit/transport/PackParser.java
index 1b30e859ec..c62959565f 100644
--- a/org.eclipse.jgit/src/org/eclipse/jgit/transport/PackParser.java
+++ b/org.eclipse.jgit/src/org/eclipse/jgit/transport/PackParser.java
@@ -61,6 +61,7 @@ import java.util.zip.Inflater;
import org.eclipse.jgit.JGitText;
import org.eclipse.jgit.errors.CorruptObjectException;
import org.eclipse.jgit.errors.MissingObjectException;
+import org.eclipse.jgit.errors.TooLargeObjectInPackException;
import org.eclipse.jgit.lib.AnyObjectId;
import org.eclipse.jgit.lib.BatchingProgressMonitor;
import org.eclipse.jgit.lib.Constants;
@@ -180,6 +181,9 @@ public abstract class PackParser {
/** Message to protect the pack data from garbage collection. */
private String lockMessage;
+ /** Git object size limit */
+ private long maxObjectSizeLimit;
+
/**
* Initialize a pack parser.
*
@@ -366,6 +370,19 @@ public abstract class PackParser {
}
/**
+ * Set the maximum allowed Git object size.
+ * <p>
+ * If an object is larger than the given size the pack-parsing will throw an
+ * exception aborting the parsing.
+ *
+ * @param limit
+ * the Git object size limit. If zero then there is not limit.
+ */
+ public void setMaxObjectSizeLimit(long limit) {
+ maxObjectSizeLimit = limit;
+ }
+
+ /**
* Get the number of objects in the stream.
* <p>
* The object count is only available after {@link #parse(ProgressMonitor)}
@@ -584,8 +601,11 @@ public abstract class PackParser {
JGitText.get().unknownObjectType, info.type));
}
- visit.data = BinaryDelta.apply(visit.parent.data, //
- inflateAndReturn(Source.DATABASE, info.size));
+ byte[] delta = inflateAndReturn(Source.DATABASE, info.size);
+ checkIfTooLarge(type, BinaryDelta.getResultSize(delta));
+
+ visit.data = BinaryDelta.apply(visit.parent.data, delta);
+ delta = null;
if (!checkCRC(visit.delta.crc))
throw new IOException(MessageFormat.format(
@@ -613,6 +633,26 @@ public abstract class PackParser {
} while (visit != null);
}
+ private final void checkIfTooLarge(int typeCode, long size)
+ throws IOException {
+ if (0 < maxObjectSizeLimit && maxObjectSizeLimit < size)
+ switch (typeCode) {
+ case Constants.OBJ_COMMIT:
+ case Constants.OBJ_TREE:
+ case Constants.OBJ_BLOB:
+ case Constants.OBJ_TAG:
+ throw new TooLargeObjectInPackException(size, maxObjectSizeLimit);
+
+ case Constants.OBJ_OFS_DELTA:
+ case Constants.OBJ_REF_DELTA:
+ throw new TooLargeObjectInPackException(maxObjectSizeLimit);
+
+ default:
+ throw new IOException(MessageFormat.format(
+ JGitText.get().unknownObjectType, typeCode));
+ }
+ }
+
/**
* Read the header of the current object.
* <p>
@@ -856,6 +896,8 @@ public abstract class PackParser {
shift += 7;
}
+ checkIfTooLarge(typeCode, sz);
+
switch (typeCode) {
case Constants.OBJ_COMMIT:
case Constants.OBJ_TREE:
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/transport/ReceivePack.java b/org.eclipse.jgit/src/org/eclipse/jgit/transport/ReceivePack.java
index c6fe4d18c1..04f8946b2a 100644
--- a/org.eclipse.jgit/src/org/eclipse/jgit/transport/ReceivePack.java
+++ b/org.eclipse.jgit/src/org/eclipse/jgit/transport/ReceivePack.java
@@ -193,6 +193,9 @@ public class ReceivePack {
private boolean checkReferencedIsReachable;
+ /** Git object size limit */
+ private long maxObjectSizeLimit;
+
/**
* Create a new pack receive for an open repository.
*
@@ -493,6 +496,19 @@ public class ReceivePack {
timeout = seconds;
}
+ /**
+ * Set the maximum allowed Git object size.
+ * <p>
+ * If an object is larger than the given size the pack-parsing will throw an
+ * exception aborting the receive-pack operation.
+ *
+ * @param limit
+ * the Git object size limit. If zero then there is not limit.
+ */
+ public void setMaxObjectSizeLimit(final long limit) {
+ maxObjectSizeLimit = limit;
+ }
+
/** @return all of the command received by the current request. */
public List<ReceiveCommand> getAllCommands() {
return Collections.unmodifiableList(commands);
@@ -829,6 +845,7 @@ public class ReceivePack {
parser.setCheckEofAfterPackFooter(!biDirectionalPipe);
parser.setObjectChecking(isCheckReceivedObjects());
parser.setLockMessage(lockMsg);
+ parser.setMaxObjectSizeLimit(maxObjectSizeLimit);
packLock = parser.parse(receiving, resolving);
ins.flush();
} finally {