summaryrefslogtreecommitdiff
path: root/package/source
diff options
context:
space:
mode:
authorMartin Gallwey <mtg@openoffice.org>2001-04-27 13:56:07 +0000
committerMartin Gallwey <mtg@openoffice.org>2001-04-27 13:56:07 +0000
commitfa2de5099c00fabb952c039269f23f7f3689c586 (patch)
tree0476064e5fcd36451648736e4dcb6fccafd1f062 /package/source
parent7ddd39239c37d8a9b58f4c8fc17ff2b47fe0a20b (diff)
#86409# Support encryption in package files + a couple of optimisations
Diffstat (limited to 'package/source')
-rw-r--r--package/source/manifest/ManifestDefines.hxx9
-rw-r--r--package/source/manifest/ManifestExport.cxx83
-rw-r--r--package/source/manifest/ManifestImport.cxx71
-rw-r--r--package/source/manifest/ManifestImport.hxx15
-rw-r--r--package/source/manifest/ManifestReader.cxx5
-rw-r--r--package/source/manifest/makefile.mk5
-rw-r--r--package/source/zipapi/EntryInputStream.cxx96
-rw-r--r--package/source/zipapi/EntryInputStream.hxx30
-rw-r--r--package/source/zipapi/Inflater.cxx39
-rw-r--r--package/source/zipapi/ZipEnumeration.cxx22
-rw-r--r--package/source/zipapi/ZipFile.cxx175
-rw-r--r--package/source/zipapi/ZipOutputStream.cxx135
-rw-r--r--package/source/zipapi/makefile.mk18
-rw-r--r--package/source/zippackage/ZipPackage.cxx158
-rw-r--r--package/source/zippackage/ZipPackageEntry.cxx58
-rw-r--r--package/source/zippackage/ZipPackageEntry.hxx14
-rw-r--r--package/source/zippackage/ZipPackageFolder.cxx194
-rw-r--r--package/source/zippackage/ZipPackageFolderEnumeration.hxx6
-rw-r--r--package/source/zippackage/ZipPackageSink.hxx6
-rw-r--r--package/source/zippackage/ZipPackageStream.cxx130
-rw-r--r--package/source/zippackage/ZipPackageStream.hxx49
21 files changed, 800 insertions, 518 deletions
diff --git a/package/source/manifest/ManifestDefines.hxx b/package/source/manifest/ManifestDefines.hxx
index b3c1c7af6dd8..3fcf3e4d3ce2 100644
--- a/package/source/manifest/ManifestDefines.hxx
+++ b/package/source/manifest/ManifestDefines.hxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ManifestDefines.hxx,v $
*
- * $Revision: 1.1 $
+ * $Revision: 1.2 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:09:35 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:05 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -63,8 +63,13 @@
#define ELEMENT_MANIFEST "manifest:manifest"
#define ELEMENT_FILE_ENTRY "manifest:file-entry"
+#define ELEMENT_ENCRYPTION_DATA "manifest:encryption-data"
+#define ELEMENT_INITIALISATION_VECTOR "manifest:initialisation-vector"
#define ATTRIBUTE_FULL_PATH "manifest:full-path"
#define ATTRIBUTE_MEDIA_TYPE "manifest:media-type"
+#define ATTRIBUTE_ALGORITHM "manifest:algorithm"
+#define ATTRIBUTE_SALT "manifest:salt"
+#define ATTRIBUTE_ITERATION_COUNT "manifest:iteration-count"
#define ATTRIBUTE_CDATA "CDATA"
#define ATTRIBUTE_XMLNS "xmlns:manifest"
#define MANIFEST_NAMESPACE "http://openoffice.org/2001/manifest"
diff --git a/package/source/manifest/ManifestExport.cxx b/package/source/manifest/ManifestExport.cxx
index be4fe22ffacf..6685b5ba1ca1 100644
--- a/package/source/manifest/ManifestExport.cxx
+++ b/package/source/manifest/ManifestExport.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ManifestExport.cxx,v $
*
- * $Revision: 1.1 $
+ * $Revision: 1.2 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:09:35 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:05 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -71,6 +71,12 @@
#ifndef _COM_SUN_STAR_XML_SAX_XATTRIBUTELIST_HXX
#include <com/sun/star/xml/sax/XAttributeList.hpp>
#endif
+#ifndef _RTL_USTRBUF_HXX_
+#include <rtl/ustrbuf.hxx>
+#endif
+#ifndef _BASE64_CODEC_HXX_
+#include <Base64Codec.hxx>
+#endif
using namespace rtl;
using namespace std;
@@ -80,14 +86,23 @@ using namespace com::sun::star::xml::sax;
ManifestExport::ManifestExport(Reference < XDocumentHandler > xHandler, const Sequence < Sequence < PropertyValue > > &rManList)
{
- const OUString sFileEntryElement ( RTL_CONSTASCII_USTRINGPARAM ( ELEMENT_FILE_ENTRY ) );
- const OUString sManifestElement ( RTL_CONSTASCII_USTRINGPARAM ( ELEMENT_MANIFEST ) );
- const OUString sCdataAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_CDATA ) );
- const OUString sMediaTypeAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_MEDIA_TYPE ) );
- const OUString sFullPathAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_FULL_PATH ) );
+ const OUString sFileEntryElement ( RTL_CONSTASCII_USTRINGPARAM ( ELEMENT_FILE_ENTRY ) );
+ const OUString sManifestElement ( RTL_CONSTASCII_USTRINGPARAM ( ELEMENT_MANIFEST ) );
+ const OUString sInitialisationVectorElement ( RTL_CONSTASCII_USTRINGPARAM ( ELEMENT_INITIALISATION_VECTOR ) );
+ const OUString sEncryptionDataElement ( RTL_CONSTASCII_USTRINGPARAM ( ELEMENT_ENCRYPTION_DATA ) );
+ const OUString sCdataAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_CDATA ) );
+ const OUString sMediaTypeAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_MEDIA_TYPE ) );
+ const OUString sFullPathAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_FULL_PATH ) );
+ const OUString sAlgorithmAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_ALGORITHM ) );
+ const OUString sSaltAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_SALT ) );
+ const OUString sIterationCountAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_ITERATION_COUNT ) );
- const OUString sFullPath ( RTL_CONSTASCII_USTRINGPARAM ( "FullPath" ) );
- const OUString sMediaType ( RTL_CONSTASCII_USTRINGPARAM ( "MediaType" ) );
+ const OUString sFullPath ( RTL_CONSTASCII_USTRINGPARAM ( "FullPath" ) );
+ const OUString sMediaType ( RTL_CONSTASCII_USTRINGPARAM ( "MediaType" ) );
+ const OUString sBlowfish ( RTL_CONSTASCII_USTRINGPARAM ( "Blowfish" ) );
+ const OUString sIterationCount ( RTL_CONSTASCII_USTRINGPARAM ( "IterationCount" ) );
+ const OUString sSalt ( RTL_CONSTASCII_USTRINGPARAM ( "Salt" ) );
+ const OUString sInitialisationVector( RTL_CONSTASCII_USTRINGPARAM ( "InitialisationVector" ) );
AttributeList * pRootAttrList = new AttributeList;
pRootAttrList->AddAttribute ( OUString( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_XMLNS ) ),
@@ -104,16 +119,64 @@ ManifestExport::ManifestExport(Reference < XDocumentHandler > xHandler, const S
AttributeList *pAttrList = new AttributeList;
const PropertyValue *pValue = pSequence->getConstArray();
OUString aString;
+ const PropertyValue *pVector = NULL, *pSalt = NULL, *pIterationCount = NULL;
for (sal_uInt32 j = 0, nNum = pSequence->getLength(); j < nNum; j++, pValue++)
{
- pValue->Value >>= aString;
if (pValue->Name.equals (sMediaType) )
+ {
+ pValue->Value >>= aString;
pAttrList->AddAttribute ( sMediaTypeAttribute, sCdataAttribute, aString );
+ }
else if (pValue->Name.equals (sFullPath) )
+ {
+ pValue->Value >>= aString;
pAttrList->AddAttribute ( sFullPathAttribute, sCdataAttribute, aString );
+ }
+ else if (pValue->Name.equals (sInitialisationVector) )
+ pVector = pValue;
+ else if (pValue->Name.equals (sSalt) )
+ pSalt = pValue;
+ else if (pValue->Name.equals (sIterationCount) )
+ pIterationCount = pValue;
}
Reference < XAttributeList > xAttrList = pAttrList;
xHandler->startElement( sFileEntryElement , xAttrList);
+ if ( pVector )
+ {
+ AttributeList * pAttrList = new AttributeList;
+ pAttrList->AddAttribute ( sAlgorithmAttribute, sCdataAttribute, sBlowfish );
+ if ( pIterationCount )
+ {
+ sal_Int64 nValue;
+ pIterationCount->Value >>= nValue;
+ OUStringBuffer aBuffer;
+ aBuffer.append (nValue);
+ pAttrList->AddAttribute ( sIterationCountAttribute, sCdataAttribute, aBuffer.makeStringAndClear() );
+ }
+ if ( pSalt )
+ {
+ OUStringBuffer aBuffer;
+ Sequence < sal_Int8 > aSequence;
+ pSalt->Value >>= aSequence;
+ Base64Codec::encodeBase64 ( aBuffer, aSequence );
+ pAttrList->AddAttribute ( sSaltAttribute, sCdataAttribute, aBuffer.makeStringAndClear() );
+ }
+ Reference < XAttributeList > xAttrList (pAttrList);
+ xHandler->startElement( sEncryptionDataElement , xAttrList);
+ if ( pVector )
+ {
+ AttributeList * pAttrList = new AttributeList;
+ Reference < XAttributeList > xAttrList (pAttrList);
+ OUStringBuffer aBuffer;
+ Sequence < sal_Int8 > aSequence;
+ pVector->Value >>= aSequence;
+ Base64Codec::encodeBase64 ( aBuffer, aSequence );
+ xHandler->startElement ( sInitialisationVectorElement, xAttrList);
+ xHandler->characters ( aBuffer.makeStringAndClear() );
+ xHandler->endElement ( sInitialisationVectorElement );
+ }
+ xHandler->endElement( sEncryptionDataElement );
+ }
xHandler->endElement( sFileEntryElement );
pSequence++;
}
diff --git a/package/source/manifest/ManifestImport.cxx b/package/source/manifest/ManifestImport.cxx
index b77265c52956..b163ba09eff8 100644
--- a/package/source/manifest/ManifestImport.cxx
+++ b/package/source/manifest/ManifestImport.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ManifestImport.cxx,v $
*
- * $Revision: 1.1 $
+ * $Revision: 1.2 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:09:35 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:05 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -65,6 +65,9 @@
#ifndef _MANIFEST_DEFINES_HXX
#include <ManifestDefines.hxx>
#endif
+#ifndef _BASE64_CODEC_HXX_
+#include <Base64Codec.hxx>
+#endif
using namespace com::sun::star::uno;
using namespace com::sun::star::beans;
using namespace com::sun::star;
@@ -73,6 +76,7 @@ using namespace std;
ManifestImport::ManifestImport( vector < Sequence < PropertyValue > > & rNewManVector )
: rManVector ( rNewManVector )
+, nNumProperty (0)
{
}
ManifestImport::~ManifestImport (void )
@@ -89,31 +93,78 @@ void SAL_CALL ManifestImport::endDocument( )
void SAL_CALL ManifestImport::startElement( const OUString& aName, const uno::Reference< xml::sax::XAttributeList >& xAttribs )
throw(xml::sax::SAXException, uno::RuntimeException)
{
- static const OUString sFileEntryElement ( RTL_CONSTASCII_USTRINGPARAM ( ELEMENT_FILE_ENTRY ) );
+ static const OUString sEncryptionDataElement ( RTL_CONSTASCII_USTRINGPARAM ( ELEMENT_ENCRYPTION_DATA ) );
+ static const OUString sInitialisationVectorElement ( RTL_CONSTASCII_USTRINGPARAM ( ELEMENT_INITIALISATION_VECTOR ) );
+ static const OUString sAlgorithmAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ELEMENT_INITIALISATION_VECTOR ) );
+ static const OUString sSaltAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_SALT ) );
+ static const OUString sIterationCountAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_ITERATION_COUNT ) );
static const OUString sManifestElement ( RTL_CONSTASCII_USTRINGPARAM ( ELEMENT_MANIFEST ) );
+ static const OUString sFileEntryElement ( RTL_CONSTASCII_USTRINGPARAM ( ELEMENT_FILE_ENTRY ) );
static const OUString sCdataAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_CDATA ) );
static const OUString sMediaTypeAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_MEDIA_TYPE ) );
static const OUString sFullPathAttribute ( RTL_CONSTASCII_USTRINGPARAM ( ATTRIBUTE_FULL_PATH ) );
static const OUString sMediaTypeProperty ( RTL_CONSTASCII_USTRINGPARAM ( "MediaType" ) );
static const OUString sFullPathProperty ( RTL_CONSTASCII_USTRINGPARAM ( "FullPath" ) );
+ static const OUString sSaltProperty ( RTL_CONSTASCII_USTRINGPARAM ( "Salt" ) );
+ static const OUString sAlgorithmProperty ( RTL_CONSTASCII_USTRINGPARAM ( "Algorithm" ) );
+ static const OUString sIterationCountProperty ( RTL_CONSTASCII_USTRINGPARAM ( "IterationCount" ) );
if (aName == sFileEntryElement)
{
- Sequence < PropertyValue > aPropSeq ( 2 );
- aPropSeq[0].Name = sMediaTypeProperty;
- aPropSeq[0].Value <<= xAttribs->getValueByName( sMediaTypeAttribute );
- aPropSeq[1].Name = sFullPathProperty;
- aPropSeq[1].Value <<= xAttribs->getValueByName( sFullPathAttribute );
- rManVector.push_back ( aPropSeq );
+ aStack.push( e_FileEntry );
+ aSequence.realloc ( 2 );
+ aSequence[0].Name = sMediaTypeProperty;
+ aSequence[0].Value <<= xAttribs->getValueByName( sMediaTypeAttribute );
+ aSequence[1].Name = sFullPathProperty;
+ aSequence[1].Value <<= xAttribs->getValueByName( sFullPathAttribute );
+ nNumProperty=2;
+ }
+ else if (!aStack.empty())
+ {
+ if (aStack.top() == e_FileEntry && aName == sEncryptionDataElement)
+ {
+ aSequence.realloc (nNumProperty+3);
+ aStack.push (e_EncryptionData );
+ aSequence[nNumProperty].Name = sAlgorithmProperty;
+ aSequence[nNumProperty].Value <<= xAttribs->getValueByName( sAlgorithmAttribute );
+ aSequence[nNumProperty+1].Name = sSaltProperty;
+ OUString aString;
+ aString = xAttribs->getValueByName ( sSaltAttribute );
+ Sequence < sal_Int8 > aDecodeBuffer;
+ Base64Codec::decodeBase64 (aDecodeBuffer, aString);
+ aSequence[nNumProperty+1].Value <<= aDecodeBuffer;
+ aSequence[nNumProperty+2].Name = sIterationCountProperty;
+ aSequence[nNumProperty+2].Value <<= xAttribs->getValueByName( sIterationCountAttribute );
+ nNumProperty+=3;
+ }
+ else if (aStack.top() == e_EncryptionData && aName == sInitialisationVectorElement)
+ {
+ aStack.push (e_InitialisationVector);
+ aSequence.realloc (++nNumProperty);
+ }
}
}
void SAL_CALL ManifestImport::endElement( const OUString& aName )
- throw(xml::sax::SAXException, uno::RuntimeException)
+ throw(xml::sax::SAXException, uno::RuntimeException)
{
+ if ( !aStack.empty() )
+ {
+ if (aStack.top() == e_FileEntry)
+ rManVector.push_back ( aSequence );
+ aStack.pop();
+ }
}
void SAL_CALL ManifestImport::characters( const OUString& aChars )
throw(xml::sax::SAXException, uno::RuntimeException)
{
+ if (!aStack.empty() && aStack.top() == e_InitialisationVector)
+ {
+ const OUString sAlgorithmProperty ( RTL_CONSTASCII_USTRINGPARAM ( "Algorithm" ) );
+ Sequence < sal_Int8 > aDecodeBuffer;
+ Base64Codec::decodeBase64 (aDecodeBuffer, aChars);
+ aSequence[nNumProperty-1].Name = sAlgorithmProperty;
+ aSequence[nNumProperty-1].Value <<= aDecodeBuffer;
+ }
}
void SAL_CALL ManifestImport::ignorableWhitespace( const OUString& aWhitespaces )
throw(xml::sax::SAXException, uno::RuntimeException)
diff --git a/package/source/manifest/ManifestImport.hxx b/package/source/manifest/ManifestImport.hxx
index 91bc91647fdf..51968e482838 100644
--- a/package/source/manifest/ManifestImport.hxx
+++ b/package/source/manifest/ManifestImport.hxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ManifestImport.hxx,v $
*
- * $Revision: 1.1 $
+ * $Revision: 1.2 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:09:35 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:05 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -75,10 +75,21 @@
#include <com/sun/star/beans/PropertyValue.hpp>
#endif
#include <vector>
+#include <stack>
+enum ElementNames
+{
+ e_Manifest,
+ e_FileEntry,
+ e_EncryptionData,
+ e_InitialisationVector
+};
class ManifestImport : public cppu::WeakImplHelper1 < com::sun::star::xml::sax::XDocumentHandler >
{
private:
+ com::sun::star::uno::Sequence < com::sun::star::beans::PropertyValue > aSequence;
+ sal_Int16 nNumProperty;
+ ::std::stack < ElementNames > aStack;
std::vector < ::com::sun::star::uno::Sequence < ::com::sun::star::beans::PropertyValue > > & rManVector;
public:
ManifestImport( std::vector < ::com::sun::star::uno::Sequence < ::com::sun::star::beans::PropertyValue > > & rNewVector );
diff --git a/package/source/manifest/ManifestReader.cxx b/package/source/manifest/ManifestReader.cxx
index 4dce8a1129ef..cd02600a8661 100644
--- a/package/source/manifest/ManifestReader.cxx
+++ b/package/source/manifest/ManifestReader.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ManifestReader.cxx,v $
*
- * $Revision: 1.2 $
+ * $Revision: 1.3 $
*
- * last change: $Author: vg $ $Date: 2001-04-23 15:52:53 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:05 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -159,6 +159,7 @@ Sequence< Sequence< PropertyValue > > SAL_CALL ManifestReader::readManifestSeque
{
}
}
+ xParser->setDocumentHandler ( Reference < XDocumentHandler > () );
return aManifestSequence;
}
// Component functions
diff --git a/package/source/manifest/makefile.mk b/package/source/manifest/makefile.mk
index fed7d3947a12..a8ff5d916402 100644
--- a/package/source/manifest/makefile.mk
+++ b/package/source/manifest/makefile.mk
@@ -2,9 +2,9 @@
#
# $RCSfile: makefile.mk,v $
#
-# $Revision: 1.1 $
+# $Revision: 1.2 $
#
-# last change: $Author: mtg $ $Date: 2001-04-19 14:09:35 $
+# last change: $Author: mtg $ $Date: 2001-04-27 14:56:05 $
#
# The Contents of this file are made available subject to the terms of
# either of the following licenses
@@ -81,6 +81,7 @@ SLOFILES= \
$(SLO)$/ManifestImport.obj \
$(SLO)$/ManifestExport.obj \
$(SLO)$/AttributeList.obj \
+ $(SLO)$/Base64Codec.obj \
$(SLO)$/UnoRegister.obj
# --- UNO stuff ---------------------------------------------------
diff --git a/package/source/zipapi/EntryInputStream.cxx b/package/source/zipapi/EntryInputStream.cxx
index efb893439bb6..023dd53f6989 100644
--- a/package/source/zipapi/EntryInputStream.cxx
+++ b/package/source/zipapi/EntryInputStream.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: EntryInputStream.cxx,v $
*
- * $Revision: 1.12 $
+ * $Revision: 1.13 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:13:40 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:06 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -59,55 +59,59 @@
*
************************************************************************/
#ifndef _ENTRY_INPUT_STREAM_HXX
-#include "EntryInputStream.hxx"
+#include <EntryInputStream.hxx>
#endif
#ifndef _COM_SUN_STAR_PACKAGES_ZIPCONSTANTS_HPP_
#include <com/sun/star/packages/ZipConstants.hpp>
#endif
+#ifndef _RTL_CIPHER_H_
+#include <rtl/cipher.h>
+#endif
#include <memory.h> // for memcpy
using namespace rtl;
using namespace com::sun::star;
+using namespace com::sun::star::uno;
+using namespace com::sun::star::packages::ZipConstants;
/** Provides access to the compressed data in a zipfile.
*
* 04/12/00 - uncompresses the stream into memory and seeks on it 'in memory'
- * This is a "temporary" fix which will be changed ASAP (read 2001)
+ * This and the ZipPackageBuffer used in the ZipOutputStream are memory hogs
+ * and will hopefully be replaced eventually
*
* Acts on the same underlying XInputStream as both the full Zip File and other
* EntryInputStreams, and thus must maintain its current position in the stream and
* seek to it before performing any reads.
*/
-EntryInputStream::EntryInputStream( uno::Reference < io::XInputStream > xNewInput,
- sal_Int64 nNewBegin,
- sal_Int64 nNewEnd,
- sal_Int64 nNewUncompressedSize,
+EntryInputStream::EntryInputStream( Reference < io::XInputStream > xNewInput,
+ const packages::ZipEntry & rNewEntry,
+ const vos::ORef < EncryptionData > &xEncryptData,
sal_Bool bIsDeflated)
: xStream( xNewInput )
-, xSeek( xNewInput, uno::UNO_QUERY )
-, nBegin( nNewBegin )
-, nEnd ( nNewEnd )
+, xSeek( xNewInput, UNO_QUERY )
+, rEntry (rNewEntry )
, nCurrent( 0 )
-, nUncompressedSize (nNewUncompressedSize)
, aSequence ( 0 )
-, bReachEOF ( sal_False )
, bHaveInMemory ( sal_False )
, aInflater( sal_True )
, aBuffer( 0 )
, bDeflated ( bIsDeflated )
+, xEncryptionData (xEncryptData)
{
+ nEnd = rEntry.nMethod == DEFLATED ? rEntry.nOffset + rEntry.nCompressedSize : rEntry.nOffset + rEntry.nSize;
}
void EntryInputStream::readIntoMemory()
{
if (!bHaveInMemory)
{
- aBuffer.realloc ( static_cast < sal_Int32 > ( nUncompressedSize ) );
+ aBuffer.realloc ( static_cast < sal_Int32 > ( rEntry.nSize ) );
if (bDeflated)
{
- sal_Int32 nSize = static_cast < sal_Int32 > (nEnd - nBegin );
+ sal_Int32 nSize = static_cast < sal_Int32 > (nEnd - rEntry.nOffset );
aSequence.realloc( nSize );
- xSeek->seek(nBegin);
+ xSeek->seek(rEntry.nOffset);
xStream->readBytes(aSequence, nSize );
aInflater.setInputSegment(aSequence, 0, nSize );
aInflater.doInflate(aBuffer);
@@ -116,26 +120,46 @@ void EntryInputStream::readIntoMemory()
}
else
{
- xSeek->seek(nBegin);
- xStream->readBytes(aBuffer, static_cast < sal_Int32 > (nUncompressedSize));
+ xSeek->seek(rEntry.nOffset);
+ xStream->readBytes(aBuffer, static_cast < sal_Int32 > (rEntry.nSize));
}
bHaveInMemory = sal_True;
+
+ /*
+ * Don't have the decryption code yet...
+ if (rEncryptionKey.getLength())
+ {
+ // An encrypted entry!
+ rtlCipherError aResult;
+ aSequence.realloc ( rEntry.nSize );
+ rtlCipher aCipher = rtl_cipher_create (rtl_Cipher_AlgorithmBF, rtl_Cipher_ModeStream);
+ aResult = rtl_cipher_init( aCipher, rtl_Cipher_DirectionDecode,
+ reinterpret_cast < const sal_uInt8 * > ( rEncryptionKey.getConstArray()),
+ rEncryptionKey.getLength(),
+ reinterpret_cast < const sal_uInt8 * > ( rVector.getConstArray()),
+ rVector.getLength() );
+ OSL_ASSERT (aResult == rtl_Cipher_E_None);
+ aBuffer.realloc ( 0 );
+ aBuffer = aSequence;
+ aSequence.realloc ( 0 );
+ }
+ */
}
}
EntryInputStream::~EntryInputStream( void )
{
}
-sal_Int32 SAL_CALL EntryInputStream::readBytes( uno::Sequence< sal_Int8 >& aData,
+sal_Int32 SAL_CALL EntryInputStream::readBytes( Sequence< sal_Int8 >& aData,
sal_Int32 nBytesToRead )
- throw(io::NotConnectedException, io::BufferSizeExceededException, io::IOException, uno::RuntimeException)
+ throw(io::NotConnectedException, io::BufferSizeExceededException, io::IOException, RuntimeException)
{
if (nBytesToRead <0)
throw io::BufferSizeExceededException(::rtl::OUString(), *this);
if (!bHaveInMemory)
readIntoMemory();
- if (nBytesToRead + nCurrent > nUncompressedSize)
- nBytesToRead = static_cast < sal_Int32> (nUncompressedSize - nCurrent);
+ if (nBytesToRead + nCurrent > rEntry.nSize)
+ nBytesToRead = static_cast < sal_Int32> (rEntry.nSize - nCurrent);
aData.realloc( nBytesToRead );
memcpy(aData.getArray(), aBuffer.getConstArray() + nCurrent, nBytesToRead);
@@ -143,49 +167,49 @@ sal_Int32 SAL_CALL EntryInputStream::readBytes( uno::Sequence< sal_Int8 >& aData
return nBytesToRead;
}
-sal_Int32 SAL_CALL EntryInputStream::readSomeBytes( uno::Sequence< sal_Int8 >& aData,
+sal_Int32 SAL_CALL EntryInputStream::readSomeBytes( Sequence< sal_Int8 >& aData,
sal_Int32 nMaxBytesToRead )
- throw(io::NotConnectedException, io::BufferSizeExceededException, io::IOException, uno::RuntimeException)
+ throw(io::NotConnectedException, io::BufferSizeExceededException, io::IOException, RuntimeException)
{
return readBytes( aData, nMaxBytesToRead );
}
void SAL_CALL EntryInputStream::skipBytes( sal_Int32 nBytesToSkip )
- throw(io::NotConnectedException, io::BufferSizeExceededException, io::IOException, uno::RuntimeException)
+ throw(io::NotConnectedException, io::BufferSizeExceededException, io::IOException, RuntimeException)
{
if (nBytesToSkip < 0)
throw io::BufferSizeExceededException(::rtl::OUString(), *this);
- if (nBytesToSkip + nCurrent > nUncompressedSize )
- nBytesToSkip = static_cast < sal_Int32 > (nUncompressedSize - nCurrent);
+ if (nBytesToSkip + nCurrent > rEntry.nSize )
+ nBytesToSkip = static_cast < sal_Int32 > (rEntry.nSize - nCurrent);
nCurrent+=nBytesToSkip;
}
sal_Int32 SAL_CALL EntryInputStream::available( )
- throw(io::NotConnectedException, io::IOException, uno::RuntimeException)
+ throw(io::NotConnectedException, io::IOException, RuntimeException)
{
- return static_cast < sal_Int32 > (nUncompressedSize - nCurrent);
+ return static_cast < sal_Int32 > (rEntry.nSize - nCurrent);
}
void SAL_CALL EntryInputStream::closeInput( )
- throw(io::NotConnectedException, io::IOException, uno::RuntimeException)
+ throw(io::NotConnectedException, io::IOException, RuntimeException)
{
}
void SAL_CALL EntryInputStream::seek( sal_Int64 location )
- throw(lang::IllegalArgumentException, io::IOException, uno::RuntimeException)
+ throw(lang::IllegalArgumentException, io::IOException, RuntimeException)
{
- if (location > nUncompressedSize)
- location = nUncompressedSize;
+ if (location > rEntry.nSize)
+ location = rEntry.nSize;
if (location <0)
location = 0;
nCurrent = location;
}
sal_Int64 SAL_CALL EntryInputStream::getPosition( )
- throw(io::IOException, uno::RuntimeException)
+ throw(io::IOException, RuntimeException)
{
return nCurrent;
}
sal_Int64 SAL_CALL EntryInputStream::getLength( )
- throw(io::IOException, uno::RuntimeException)
+ throw(io::IOException, RuntimeException)
{
- return nUncompressedSize;
+ return rEntry.nSize;
}
diff --git a/package/source/zipapi/EntryInputStream.hxx b/package/source/zipapi/EntryInputStream.hxx
index d1a7fd128917..82463f4158f9 100644
--- a/package/source/zipapi/EntryInputStream.hxx
+++ b/package/source/zipapi/EntryInputStream.hxx
@@ -2,9 +2,9 @@
*
* $RCSfile: EntryInputStream.hxx,v $
*
- * $Revision: 1.1 $
+ * $Revision: 1.2 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:12:53 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:06 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -73,23 +73,33 @@
#ifndef _INFLATER_HXX_
#include <Inflater.hxx>
#endif
-
+#ifndef _COM_SUN_STAR_PACKAGES_ZIPENTRY_HPP_
+#include <com/sun/star/packages/ZipEntry.hpp>
+#endif
+#ifndef _VOS_REF_H_
+#include <vos/ref.hxx>
+#endif
+#ifndef _ENCRYPTION_DATA_HXX
+#include <EncryptionData.hxx>
+#endif
class EntryInputStream : public cppu::WeakImplHelper2< com::sun::star::io::XInputStream,
com::sun::star::io::XSeekable >
{
private:
com::sun::star::uno::Reference< com::sun::star::io::XInputStream > xStream;
com::sun::star::uno::Reference< com::sun::star::io::XSeekable > xSeek;
- sal_Int64 nBegin, nEnd, nCurrent, nUncompressedSize;
- sal_Bool bReachEOF;
- sal_Bool bDeflated;
- sal_Bool bHaveInMemory;
- com::sun::star::uno::Sequence < sal_Int8 > aSequence;
- com::sun::star::uno::Sequence < sal_Int8 > aBuffer;
+ sal_Int64 nEnd, nCurrent;
+ sal_Bool bDeflated, bHaveInMemory, bEncrypted;
+ com::sun::star::uno::Sequence < sal_Int8 > aSequence, aBuffer;
+ const vos::ORef < EncryptionData > xEncryptionData;
+ const com::sun::star::packages::ZipEntry & rEntry;
Inflater aInflater;
void readIntoMemory();
public:
- EntryInputStream( com::sun::star::uno::Reference < com::sun::star::io::XInputStream > xInput, sal_Int64 nBegin, sal_Int64 nEnd, sal_Int64 nNewUncompressedSize, sal_Bool bIsDeflated);
+ EntryInputStream( com::sun::star::uno::Reference < com::sun::star::io::XInputStream > xInput,
+ const com::sun::star::packages::ZipEntry &rNewEntry,
+ const vos::ORef < EncryptionData > &xEncryptData,
+ sal_Bool bIsDeflated );
virtual ~EntryInputStream();
// XInputStream
diff --git a/package/source/zipapi/Inflater.cxx b/package/source/zipapi/Inflater.cxx
index e58067a6ee38..bcc6f64c43ec 100644
--- a/package/source/zipapi/Inflater.cxx
+++ b/package/source/zipapi/Inflater.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: Inflater.cxx,v $
*
- * $Revision: 1.7 $
+ * $Revision: 1.8 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:13:40 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:06 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -74,13 +74,21 @@
/** Provides general purpose decompression using the ZLIB library */
-void Inflater::init (sal_Bool bNowrap)
+
+Inflater::Inflater(sal_Bool bNoWrap)
+: bFinish(sal_False),
+ bFinished(sal_False),
+ bSetParams(sal_False),
+ bNeedDict(sal_False),
+ nOffset(0),
+ nLength(0),
+ pStream(NULL)
{
pStream = new z_stream;
/* memset to 0 to set zalloc/opaque etc */
memset (pStream, 0, sizeof(*pStream));
sal_Int32 nRes;
- nRes = inflateInit2(pStream, bNowrap ? -MAX_WBITS : MAX_WBITS);
+ nRes = inflateInit2(pStream, bNoWrap ? -MAX_WBITS : MAX_WBITS);
switch (nRes)
{
case Z_OK:
@@ -99,29 +107,6 @@ void Inflater::init (sal_Bool bNowrap)
}
}
-Inflater::Inflater(sal_Bool bNoWrap)
-: bFinish(sal_False),
- bFinished(sal_False),
- bSetParams(sal_False),
- bNeedDict(sal_False),
- nOffset(0),
- nLength(0),
- pStream(NULL)
-{
- init(bNoWrap);
-}
-
-Inflater::Inflater()
-: bFinish(sal_False),
- bFinished(sal_False),
- bSetParams(sal_False),
- bNeedDict(sal_False),
- nOffset(0),
- nLength(0),
- pStream(NULL)
-{
- init(sal_False);
-}
Inflater::~Inflater()
{
end();
diff --git a/package/source/zipapi/ZipEnumeration.cxx b/package/source/zipapi/ZipEnumeration.cxx
index e5c373d4a6c4..dedd320b1d3a 100644
--- a/package/source/zipapi/ZipEnumeration.cxx
+++ b/package/source/zipapi/ZipEnumeration.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ZipEnumeration.cxx,v $
*
- * $Revision: 1.8 $
+ * $Revision: 1.9 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:13:40 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:06 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -61,12 +61,10 @@
#ifndef _ZIP_ENUMERATION_HXX
#include <ZipEnumeration.hxx>
#endif
-#ifndef _COM_SUN_STAR_PACKAGES_ZIPCONSTANTS_HPP_
-#include <com/sun/star/packages/ZipConstants.hpp>
-#endif
using namespace rtl;
using namespace com::sun::star;
+using namespace com::sun::star::packages;
/** Provides an Enumeration over the contents of a Zip file */
@@ -78,17 +76,15 @@ ZipEnumeration::ZipEnumeration( EntryHash & rNewEntryHash)
ZipEnumeration::~ZipEnumeration( void )
{
}
-sal_Bool SAL_CALL ZipEnumeration::hasMoreElements() throw (uno::RuntimeException)
+sal_Bool SAL_CALL ZipEnumeration::hasMoreElements()
{
return (aIterator != rEntryHash.end());
}
-uno::Any SAL_CALL ZipEnumeration::nextElement() throw (uno::RuntimeException)
+const ZipEntry* SAL_CALL ZipEnumeration::nextElement()
{
- uno::Any aAny;
- if (aIterator == rEntryHash.end())
- throw container::NoSuchElementException();
- aAny <<= (*aIterator).second;
- aIterator++;
- return aAny;
+ if (aIterator != rEntryHash.end())
+ return &((*aIterator++).second);
+ else
+ return NULL;
}
diff --git a/package/source/zipapi/ZipFile.cxx b/package/source/zipapi/ZipFile.cxx
index 23c45905011a..87a6081653eb 100644
--- a/package/source/zipapi/ZipFile.cxx
+++ b/package/source/zipapi/ZipFile.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ZipFile.cxx,v $
*
- * $Revision: 1.19 $
+ * $Revision: 1.20 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:13:40 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:06 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -78,12 +78,14 @@
using namespace rtl;
using namespace com::sun::star;
+using namespace com::sun::star::uno;
+using namespace com::sun::star::packages;
using namespace com::sun::star::packages::ZipConstants;
/** This class is used to read entries from a zip file
*/
-ZipFile::ZipFile( uno::Reference < io::XInputStream > &xInput, sal_Bool bInitialise)
- throw(io::IOException, packages::ZipException, uno::RuntimeException)
+ZipFile::ZipFile( Reference < io::XInputStream > &xInput, sal_Bool bInitialise)
+ throw(io::IOException, ZipException, RuntimeException)
: xStream(xInput)
, aGrabber(xInput)
, aInflater (sal_True)
@@ -91,7 +93,7 @@ ZipFile::ZipFile( uno::Reference < io::XInputStream > &xInput, sal_Bool bInitial
if (bInitialise)
readCEN();
}
-void ZipFile::setInputStream ( uno::Reference < io::XInputStream > xNewStream )
+void ZipFile::setInputStream ( Reference < io::XInputStream > xNewStream )
{
xStream = xNewStream;
aGrabber.setInputStream ( xStream );
@@ -107,7 +109,7 @@ void ZipFile::updateFromManList(std::vector < ManifestEntry * > &rManList)
// I'm not sure how evil this is in this case...
for (;i < nSize ; i++)
{
- packages::ZipEntry * pEntry = &rManList[i]->aEntry;
+ ZipEntry * pEntry = &rManList[i]->aEntry;
aEntries[pEntry->sName] = *pEntry;
}
}
@@ -118,145 +120,91 @@ ZipFile::~ZipFile()
}
void SAL_CALL ZipFile::close( )
- throw(io::IOException, uno::RuntimeException)
+ throw(io::IOException, RuntimeException)
{
}
-uno::Reference< container::XEnumeration > SAL_CALL ZipFile::entries( )
- throw(uno::RuntimeException)
+ZipEnumeration * SAL_CALL ZipFile::entries( )
{
- uno::Reference< container::XEnumeration> xEnumRef = new ZipEnumeration( aEntries );
- return xEnumRef;
+ return new ZipEnumeration ( aEntries );
}
::rtl::OUString SAL_CALL ZipFile::getName( )
- throw(uno::RuntimeException)
+ throw(RuntimeException)
{
return sName;
}
sal_Int32 SAL_CALL ZipFile::getSize( )
- throw(uno::RuntimeException)
+ throw(RuntimeException)
{
return aEntries.size();
}
-uno::Type SAL_CALL ZipFile::getElementType( )
- throw(uno::RuntimeException)
+Type SAL_CALL ZipFile::getElementType( )
+ throw(RuntimeException)
{
- return ::getCppuType((packages::ZipEntry *) 0);
+ return ::getCppuType((ZipEntry *) 0);
}
sal_Bool SAL_CALL ZipFile::hasElements( )
- throw(uno::RuntimeException)
+ throw(RuntimeException)
{
return (aEntries.size()>0);
}
-uno::Any SAL_CALL ZipFile::getByName( const ::rtl::OUString& aName )
- throw(container::NoSuchElementException, lang::WrappedTargetException, uno::RuntimeException)
+Any SAL_CALL ZipFile::getByName( const ::rtl::OUString& aName )
+ throw(container::NoSuchElementException, lang::WrappedTargetException, RuntimeException)
{
- uno::Any aAny;
- if (!aEntries.count(sName))
- throw container::NoSuchElementException();
+ Any aAny;
EntryHash::const_iterator aCI = aEntries.find(sName);
+ if (aCI == aEntries.end())
+ throw container::NoSuchElementException();
aAny <<= (*aCI).second;
return aAny;
}
-uno::Sequence< ::rtl::OUString > SAL_CALL ZipFile::getElementNames( )
- throw(uno::RuntimeException)
+Sequence< ::rtl::OUString > SAL_CALL ZipFile::getElementNames( )
+ throw(RuntimeException)
{
sal_uInt32 i=0, nSize = aEntries.size();
OUString *pNames = new OUString[aEntries.size()];
for (EntryHash::const_iterator aIterator = aEntries.begin(); aIterator != aEntries.end(); aIterator++,i++)
pNames[i] = (*aIterator).first;
- return uno::Sequence<OUString> (pNames, nSize);
+ return Sequence<OUString> (pNames, nSize);
}
sal_Bool SAL_CALL ZipFile::hasByName( const ::rtl::OUString& aName )
- throw(uno::RuntimeException)
+ throw(RuntimeException)
{
- return aEntries.count(aName);
+ return aEntries.find(aName) != aEntries.end();
}
-uno::Reference< io::XInputStream > SAL_CALL ZipFile::getInputStream( const packages::ZipEntry& rEntry )
- throw(io::IOException, packages::ZipException, uno::RuntimeException)
+Reference< io::XInputStream > SAL_CALL ZipFile::getInputStream( ZipEntry& rEntry,
+ const vos::ORef < EncryptionData > &rData)
+ throw(io::IOException, ZipException, RuntimeException)
{
sal_Int64 nSize = rEntry.nMethod == DEFLATED ? rEntry.nCompressedSize : rEntry.nSize;
if (rEntry.nOffset <= 0)
readLOC(rEntry);
- uno::Reference< io::XInputStream > xStreamRef =
- new EntryInputStream(xStream,
- rEntry.nOffset,
- rEntry.nOffset + nSize,
- rEntry.nSize,
- rEntry.nMethod == DEFLATED );
+ Reference< io::XInputStream > xStreamRef = new EntryInputStream(xStream, rEntry, rData, rEntry.nMethod == DEFLATED );
return xStreamRef;
}
-sal_uInt32 SAL_CALL ZipFile::getHeader(const packages::ZipEntry& rEntry)
- throw(io::IOException, packages::ZipException, uno::RuntimeException)
-{
- uno::Sequence < sal_Int8 > aSequence (4);
-
- try
- {
- if (rEntry.nOffset <= 0)
- readLOC(rEntry);
- }
- catch (packages::ZipException&)
- {
- VOS_ENSURE(0, "Zip file bug!");
- return 0;
- }
-
- aGrabber.seek(rEntry.nOffset);
- if (rEntry.nMethod == STORED)
- {
- if (xStream->readBytes(aSequence, 4) < 4)
- return 0;
- }
- else if (rEntry.nMethod == DEFLATED)
- {
- /*
- uno::Reference < io::XInputStream > xEntryStream = getInputStream (rEntry);
- if (xEntryStream->readBytes(aSequence, 4) < 4)
- return 0;
- */
- sal_Int32 nSize = rEntry.nCompressedSize < 32768 ? rEntry.nCompressedSize : 32768;
- uno::Sequence < sal_Int8 > aCompSeq (nSize );
- if (xStream->readBytes(aCompSeq, nSize) < nSize)
- return 0;
- aInflater.finish();
- aInflater.setInput(aCompSeq);
- aInflater.doInflate(aSequence);
- aInflater.reset();
- }
- return (static_cast < sal_uInt32 >
- (static_cast < sal_uInt8> (aSequence[0]& 0xFF)
- | static_cast < sal_uInt8> (aSequence[1]& 0xFF) << 8
- | static_cast < sal_uInt8> (aSequence[2]& 0xFF) << 16
- | static_cast < sal_uInt8> (aSequence[3]& 0xFF) << 24));
-}
-
-uno::Reference< io::XInputStream > SAL_CALL ZipFile::getRawStream( const packages::ZipEntry& rEntry )
- throw(io::IOException, packages::ZipException, uno::RuntimeException)
+Reference< io::XInputStream > SAL_CALL ZipFile::getRawStream( ZipEntry& rEntry,
+ const vos::ORef < EncryptionData > &rData)
+ throw(io::IOException, ZipException, RuntimeException)
{
sal_Int64 nSize = rEntry.nMethod == DEFLATED ? rEntry.nCompressedSize : rEntry.nSize;
if (rEntry.nOffset <= 0)
readLOC(rEntry);
- uno::Reference< io::XInputStream > xStreamRef =
- new EntryInputStream(xStream,
- rEntry.nOffset,
- rEntry.nOffset + nSize,
- nSize,
- sal_False );
+ Reference< io::XInputStream > xStreamRef =
+ new EntryInputStream(xStream, rEntry, rData, sal_False );
return xStreamRef;
}
-sal_Bool ZipFile::readLOC(const packages::ZipEntry &rEntry)
- throw(io::IOException, packages::ZipException, uno::RuntimeException)
+sal_Bool ZipFile::readLOC( ZipEntry &rEntry )
+ throw(io::IOException, ZipException, RuntimeException)
{
sal_uInt32 nTestSig, nTime, nCRC, nSize, nCompressedSize;
sal_uInt16 nVersion, nFlag, nHow, nNameLen, nExtraLen;
@@ -266,7 +214,7 @@ sal_Bool ZipFile::readLOC(const packages::ZipEntry &rEntry)
aGrabber >> nTestSig;
if (nTestSig != LOCSIG)
- throw packages::ZipException( OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid LOC header (bad signature") ), uno::Reference < uno::XInterface > () );
+ throw ZipException( OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid LOC header (bad signature") ), Reference < XInterface > () );
aGrabber >> nVersion;
aGrabber >> nFlag;
aGrabber >> nHow;
@@ -276,21 +224,20 @@ sal_Bool ZipFile::readLOC(const packages::ZipEntry &rEntry)
aGrabber >> nSize;
aGrabber >> nNameLen;
aGrabber >> nExtraLen;
- packages::ZipEntry *pNonConstEntry = const_cast < packages::ZipEntry* > (&rEntry);
- pNonConstEntry->nOffset = static_cast < sal_Int32 > (aGrabber.getPosition()) + nNameLen + nExtraLen;
+ rEntry.nOffset = static_cast < sal_Int32 > (aGrabber.getPosition()) + nNameLen + nExtraLen;
return sal_True;
}
sal_Int32 ZipFile::findEND( )
- throw(io::IOException, packages::ZipException, uno::RuntimeException)
+ throw(io::IOException, ZipException, RuntimeException)
{
sal_Int32 nLength=0, nPos=0;
- uno::Sequence < sal_Int8 > aByteSeq;
+ Sequence < sal_Int8 > aByteSeq;
nLength = nPos = static_cast <sal_Int32 > (aGrabber.getLength());
if (nLength == 0)
return -1;
- //throw (packages::ZipException( OUString::createFromAscii("Trying to find Zip END signature in a zero length file!"), uno::Reference < uno::XInterface> () ));
+ //throw (ZipException( OUString::createFromAscii("Trying to find Zip END signature in a zero length file!"), Reference < XInterface> () ));
aGrabber.seek( nLength );
@@ -317,7 +264,7 @@ sal_Int32 ZipFile::findEND( )
if (nCommentLength>0)
{
aByteSeq.realloc(nCommentLength+1);
- aGrabber.readBytes(uno::Sequence< sal_Int8>(aByteSeq.getArray(), nCommentLength), nCommentLength);
+ aGrabber.readBytes(Sequence< sal_Int8>(aByteSeq.getArray(), nCommentLength), nCommentLength);
aByteSeq[nCommentLength]='\0';
sComment = OUString((sal_Char*)aByteSeq.getConstArray(), nCommentLength+1, RTL_TEXTENCODING_ASCII_US);
@@ -327,11 +274,11 @@ sal_Int32 ZipFile::findEND( )
}
}
}
- throw packages::ZipException( OUString( RTL_CONSTASCII_USTRINGPARAM ( "Zip END signature not found!") ), uno::Reference < uno::XInterface> () );
+ throw ZipException( OUString( RTL_CONSTASCII_USTRINGPARAM ( "Zip END signature not found!") ), Reference < XInterface> () );
}
sal_Int32 ZipFile::readCEN()
- throw(io::IOException, packages::ZipException, uno::RuntimeException)
+ throw(io::IOException, ZipException, RuntimeException)
{
sal_Int32 nEndPos, nLocPos;
sal_Int16 nCount, nTotal;
@@ -346,23 +293,23 @@ sal_Int32 ZipFile::readCEN()
aGrabber >> nCenOff;
if (nTotal<0 || nTotal * CENHDR > nCenLen)
- throw packages::ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "invalid END header (bad entry count)") ), uno::Reference < uno::XInterface > ());
+ throw ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "invalid END header (bad entry count)") ), Reference < XInterface > ());
if (nTotal > ZIP_MAXENTRIES)
- throw packages::ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "too many entries in ZIP File") ), uno::Reference < uno::XInterface > ());
+ throw ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "too many entries in ZIP File") ), Reference < XInterface > ());
if (nCenLen < 0 || nCenLen > nEndPos)
- throw packages::ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid END header (bad central directory size)") ), uno::Reference < uno::XInterface > ());
+ throw ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid END header (bad central directory size)") ), Reference < XInterface > ());
nCenPos = nEndPos - nCenLen;
if (nCenOff < 0 || nCenOff > nCenPos)
- throw packages::ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid END header (bad central directory size)") ), uno::Reference < uno::XInterface > ());
+ throw ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid END header (bad central directory size)") ), Reference < XInterface > ());
nLocPos = nCenPos - nCenOff;
aGrabber.seek(nCenPos);
- packages::ZipEntry *pEntry = new packages::ZipEntry;
+ ZipEntry *pEntry = new ZipEntry;
for (nCount = 0 ; nCount < nTotal; nCount++)
{
sal_Int32 nTestSig, nCRC, nCompressedSize, nTime, nSize, nExtAttr, nOffset;
@@ -370,21 +317,21 @@ sal_Int32 ZipFile::readCEN()
sal_Int16 nDisk, nIntAttr;
if (aGrabber.getPosition() - nCenPos + CENHDR > nCenLen)
- throw packages::ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid CEN header (bad header size check 1)") ), uno::Reference < uno::XInterface > ());
+ throw ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid CEN header (bad header size check 1)") ), Reference < XInterface > ());
aGrabber >> nTestSig;
if (nTestSig != CENSIG)
- throw packages::ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid CEN header (bad signature)") ), uno::Reference < uno::XInterface > ());
+ throw ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid CEN header (bad signature)") ), Reference < XInterface > ());
aGrabber >> nVerMade;
aGrabber >> nVersion;
if ((nVersion & 1) == 1)
- throw packages::ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid CEN header (encrypted entry)") ), uno::Reference < uno::XInterface > ());
+ throw ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid CEN header (encrypted entry)") ), Reference < XInterface > ());
aGrabber >> nFlag;
aGrabber >> nHow;
if (nHow != STORED && nHow != DEFLATED)
- throw packages::ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid CEN header (bad compression method)") ), uno::Reference < uno::XInterface > ());
+ throw ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid CEN header (bad compression method)") ), Reference < XInterface > ());
aGrabber >> nTime;
aGrabber >> nCRC;
@@ -399,13 +346,13 @@ sal_Int32 ZipFile::readCEN()
aGrabber >> nOffset;
if (aGrabber.getPosition() - nCenPos + nNameLen + nExtraLen + nCommentLen > nCenLen)
- throw packages::ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid CEN header (bad header size check 2)") ), uno::Reference < uno::XInterface > ());
+ throw ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Invalid CEN header (bad header size check 2)") ), Reference < XInterface > ());
if (nNameLen > ZIP_MAXNAMELEN)
- throw packages::ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "name length exceeds 512 bytes" ) ), uno::Reference < uno::XInterface > ());
+ throw ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "name length exceeds 512 bytes" ) ), Reference < XInterface > ());
if (nExtraLen > ZIP_MAXEXTRA)
- throw packages::ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "extra header info exceeds 256 bytes") ), uno::Reference < uno::XInterface > ());
+ throw ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "extra header info exceeds 256 bytes") ), Reference < XInterface > ());
pEntry->nTime = nTime;
pEntry->nCrc = nCRC;
@@ -421,14 +368,14 @@ sal_Int32 ZipFile::readCEN()
if (nHow == STORED)
pEntry->nCompressedSize = 0;
*/
- uno::Sequence < sal_Int8> aSequence (nNameLen);
+ Sequence < sal_Int8> aSequence (nNameLen);
aGrabber.readBytes(aSequence, nNameLen);
pEntry->sName = OUString((sal_Char*)aSequence.getConstArray(), nNameLen, RTL_TEXTENCODING_ASCII_US);
aGrabber.seek(aGrabber.getPosition() + nExtraLen);
if (nCommentLen>0)
{
- uno::Sequence < sal_Int8 > aCommentSeq( nCommentLen );
+ Sequence < sal_Int8 > aCommentSeq( nCommentLen );
aGrabber.readBytes(aCommentSeq, nCommentLen);
pEntry->sComment = OUString((sal_Char*)aCommentSeq.getConstArray(), nNameLen, RTL_TEXTENCODING_ASCII_US);
}
@@ -437,7 +384,7 @@ sal_Int32 ZipFile::readCEN()
delete pEntry;
if (nCount != nTotal)
- throw packages::ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Count != Total") ), uno::Reference < uno::XInterface > ());
+ throw ZipException(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Count != Total") ), Reference < XInterface > ());
return nCenPos;
}
diff --git a/package/source/zipapi/ZipOutputStream.cxx b/package/source/zipapi/ZipOutputStream.cxx
index d8078ca0dcbf..ee0ef68f6660 100644
--- a/package/source/zipapi/ZipOutputStream.cxx
+++ b/package/source/zipapi/ZipOutputStream.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ZipOutputStream.cxx,v $
*
- * $Revision: 1.24 $
+ * $Revision: 1.25 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:13:40 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:06 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -64,14 +64,19 @@
#ifndef _VOS_DIAGNOSE_H_
#include <vos/diagnose.hxx>
#endif
+#ifndef _VOS_REF_H_
+#include <vos/ref.hxx>
+#endif
#ifndef _COM_SUN_STAR_PACKAGES_ZIPCONSTANTS_HPP_
#include <com/sun/star/packages/ZipConstants.hpp>
#endif
-#include <time.h>
-#include <utime.h>
+#ifndef _OSL_TIME_H_
+#include <osl/time.h>
+#endif
using namespace rtl;
using namespace com::sun::star;
+using namespace com::sun::star::uno;
using namespace com::sun::star::packages::ZipConstants;
/** This class is used to write Zip files
@@ -82,6 +87,7 @@ ZipOutputStream::ZipOutputStream( uno::Reference < io::XOutputStream > &xOStream
, nMethod(DEFLATED)
, pCurrentEntry(NULL)
, bFinished(sal_False)
+, bEncryptCurrentEntry(sal_False)
, aBuffer(nNewBufferSize)
, aDeflater(DEFAULT_COMPRESSION, sal_True)
{
@@ -108,30 +114,64 @@ void SAL_CALL ZipOutputStream::setLevel( sal_Int32 nNewLevel )
{
aDeflater.setLevel( nNewLevel);
}
-void SAL_CALL ZipOutputStream::putNextEntry( const packages::ZipEntry& rEntry )
+
+Sequence < sal_Int8 > ZipOutputStream::getInitialisationVector()
+{
+ Sequence < sal_Int8 > aSequence( 8 );
+ TimeValue aTimeVal;
+ sal_Int8 * pVector = aSequence.getArray();
+ osl_getSystemTime( &aTimeVal );
+
+ pVector[0] = static_cast < sal_Int8 > ( (aTimeVal.Seconds >> 0 ) & 0xFF );
+ pVector[1] = static_cast < sal_Int8 > ( (aTimeVal.Seconds >> 8 ) & 0xFF );
+ pVector[2] = static_cast < sal_Int8 > ( (aTimeVal.Seconds >> 16 ) & 0xFF );
+ pVector[3] = static_cast < sal_Int8 > ( (aTimeVal.Seconds >> 24 ) & 0xFF );
+ pVector[4] = static_cast < sal_Int8 > ( (aTimeVal.Nanosec >> 0 ) & 0xFF );
+ pVector[5] = static_cast < sal_Int8 > ( (aTimeVal.Nanosec >> 8 ) & 0xFF );
+ pVector[6] = static_cast < sal_Int8 > ( (aTimeVal.Nanosec >> 16 ) & 0xFF );
+ pVector[7] = static_cast < sal_Int8 > ( (aTimeVal.Nanosec >> 24 ) & 0xFF );
+ return aSequence;
+}
+
+void SAL_CALL ZipOutputStream::putNextEntry( packages::ZipEntry& rEntry,
+ const vos::ORef < EncryptionData > &xEncryptData,
+ sal_Bool bEncrypt)
throw(io::IOException, uno::RuntimeException)
{
- packages::ZipEntry *pNonConstEntry = const_cast < packages::ZipEntry* >(&rEntry);
if (pCurrentEntry != NULL)
closeEntry();
- if (pNonConstEntry->nTime == -1)
- pNonConstEntry->nTime = getCurrentDosTime();
- if (pNonConstEntry->nMethod == -1)
- {
- pNonConstEntry->nMethod = nMethod;
- }
- pNonConstEntry->nVersion = 20;
- if (pNonConstEntry->nSize == -1 || pNonConstEntry->nCompressedSize == -1 ||
- pNonConstEntry->nCrc == -1)
- pNonConstEntry->nFlag = 8;
- else if (pNonConstEntry->nSize != -1 && pNonConstEntry->nCompressedSize != -1 &&
- pNonConstEntry->nCrc != -1)
- pNonConstEntry->nFlag = 0;
+ if (rEntry.nTime == -1)
+ rEntry.nTime = getCurrentDosTime();
+ if (rEntry.nMethod == -1)
+ rEntry.nMethod = nMethod;
+ rEntry.nVersion = 20;
+ if (rEntry.nSize == -1 || rEntry.nCompressedSize == -1 ||
+ rEntry.nCrc == -1)
+ rEntry.nFlag = 8;
+ else if (rEntry.nSize != -1 && rEntry.nCompressedSize != -1 &&
+ rEntry.nCrc != -1)
+ rEntry.nFlag = 0;
- pNonConstEntry->nOffset = static_cast < sal_Int32 > (aChucker.getPosition());
+ rEntry.nOffset = static_cast < sal_Int32 > (aChucker.getPosition());
writeLOC(rEntry);
- aZipList.push_back( pNonConstEntry );
- pCurrentEntry=pNonConstEntry;
+ aZipList.push_back( &rEntry );
+ pCurrentEntry = &rEntry;
+ /* Don't have encryption code yet...
+ if (bEncrypt)
+ {
+
+ bEncryptCurrentEntry = sal_True;
+ rtlCipherError aResult;
+
+ aCipher = rtl_cipher_create ( rtl_Cipher_AlgorithmBF, rtl_Cipher_ModeStream);
+ aResult = rtl_cipher_init( aCipher, rtl_Cipher_DirectionEncode,
+ reinterpret_cast < const sal_uInt8 *> (rKey.getConstArray()),
+ rKey.getLength(),
+ reinterpret_cast < const sal_uInt8 *> (rVector.getConstArray()),
+ rVector.getLength());
+ OSL_ASSERT( aResult == rtl_Cipher_E_None );
+ }
+ */
}
void SAL_CALL ZipOutputStream::close( )
throw(io::IOException, uno::RuntimeException)
@@ -220,6 +260,11 @@ void SAL_CALL ZipOutputStream::closeEntry( )
break;
}
aCRC.reset();
+ if (bEncryptCurrentEntry)
+ {
+ aEncryptionBuffer.realloc ( 0 );
+ bEncryptCurrentEntry = sal_False;
+ }
pCurrentEntry = NULL;
}
}
@@ -241,7 +286,17 @@ void SAL_CALL ZipOutputStream::write( const uno::Sequence< sal_Int8 >& rBuffer,
sal_Int32 nOldLength = rBuffer.getLength();
uno::Sequence < sal_Int8 > *pBuffer = const_cast < uno::Sequence < sal_Int8 > *> (&rBuffer);
pBuffer->realloc(nNewLength);
- aChucker.writeBytes(*pBuffer);
+ if (bEncryptCurrentEntry)
+ {
+ rtlCipherError aResult;
+ aEncryptionBuffer.realloc ( nNewLength );
+ aResult = rtl_cipher_encode ( aCipher, static_cast < const void * > (pBuffer->getConstArray()),
+ nNewLength, reinterpret_cast < sal_uInt8 * > (aEncryptionBuffer.getArray()), nNewLength );
+ aChucker.writeBytes ( aEncryptionBuffer );
+ aEncryptionBuffer.realloc ( nOldLength );
+ }
+ else
+ aChucker.writeBytes( *pBuffer );
pBuffer->realloc(nOldLength);
break;
}
@@ -286,7 +341,17 @@ void ZipOutputStream::doDeflate()
if (nLength> 0 )
{
aBuffer.realloc(nLength);
- aChucker.writeBytes(aBuffer);
+ if (bEncryptCurrentEntry)
+ {
+ rtlCipherError aResult;
+ aEncryptionBuffer.realloc ( nLength );
+ aResult = rtl_cipher_encode ( aCipher, static_cast < const void * > (aBuffer.getConstArray()),
+ nLength, reinterpret_cast < sal_uInt8 * > (aEncryptionBuffer.getArray()), nLength );
+ aChucker.writeBytes ( aEncryptionBuffer );
+ aEncryptionBuffer.realloc ( nOldLength );
+ }
+ else
+ aChucker.writeBytes(aBuffer);
aBuffer.realloc(nOldLength);
}
}
@@ -421,22 +486,23 @@ void ZipOutputStream::writeLOC( const packages::ZipEntry &rEntry )
}
sal_uInt32 ZipOutputStream::getCurrentDosTime( )
{
- time_t nTime = time (NULL);
- // pTime is a static internal to the time library and shouldn't be deleted
- struct tm *pTime = localtime ( &nTime);
+ oslDateTime aDateTime;
+ TimeValue aTimeValue;
+ osl_getSystemTime ( &aTimeValue );
+ osl_getDateTimeFromTimeValue( &aTimeValue, &aDateTime);
- sal_uInt32 nYear = static_cast <sal_uInt32> (pTime->tm_year);
+ sal_uInt32 nYear = static_cast <sal_uInt32> (aDateTime.Year);
if (nYear>1980)
nYear-=1980;
else if (nYear>80)
nYear-=80;
- sal_uInt32 nResult = static_cast < sal_uInt32>( ( ( ( pTime->tm_mday) +
- ( 32 * (pTime->tm_mon+1)) +
+ sal_uInt32 nResult = static_cast < sal_uInt32>( ( ( ( aDateTime.Day) +
+ ( 32 * (aDateTime.Month)) +
( 512 * nYear ) ) << 16) |
- ( ( pTime->tm_sec/2) +
- ( 32 * pTime->tm_min) +
- ( 2048 * static_cast <sal_uInt32 > (pTime->tm_hour) ) ) );
+ ( ( aDateTime.Seconds/2) +
+ ( 32 * aDateTime.Minutes) +
+ ( 2048 * static_cast <sal_uInt32 > (aDateTime.Hours) ) ) );
return nResult;
}
/*
@@ -444,6 +510,9 @@ sal_uInt32 ZipOutputStream::getCurrentDosTime( )
This is actually never used, so I removed it, but thought that the
implementation details may be useful in the future...mtg 20010307
+ I stopped using the time library and used the OSL version instead, but
+ it might still be useful to have this code here..
+
void ZipOutputStream::dosDateToTMDate ( tm &rTime, sal_uInt32 nDosDate)
{
sal_uInt32 nDate = static_cast < sal_uInt32 > (nDosDate >> 16);
diff --git a/package/source/zipapi/makefile.mk b/package/source/zipapi/makefile.mk
index 5bda73ee2225..389c46e7dd95 100644
--- a/package/source/zipapi/makefile.mk
+++ b/package/source/zipapi/makefile.mk
@@ -2,9 +2,9 @@
#
# $RCSfile: makefile.mk,v $
#
-# $Revision: 1.7 $
+# $Revision: 1.8 $
#
-# last change: $Author: mtg $ $Date: 2001-04-19 14:13:40 $
+# last change: $Author: mtg $ $Date: 2001-04-27 14:56:06 $
#
# The Contents of this file are made available subject to the terms of
# either of the following licenses
@@ -97,15 +97,15 @@ UNOUCRDEP= $(SOLARBINDIR)$/applicat.rdb
UNOUCRRDB= $(SOLARBINDIR)$/applicat.rdb
UNOTYPES=\
- com.sun.star.packages.XChecksum \
- com.sun.star.packages.XInflater \
- com.sun.star.packages.XDeflater \
- com.sun.star.packages.XZipFile \
- com.sun.star.packages.XZipInputStream \
- com.sun.star.packages.XZipOutputStream \
- com.sun.star.packages.ZipConstants \
com.sun.star.packages.ZipEntry \
+ com.sun.star.packages.ZipConstants \
com.sun.star.packages.ZipException
+# com.sun.star.packages.XChecksum \
+# com.sun.star.packages.XInflater \
+# com.sun.star.packages.XDeflater \
+# com.sun.star.packages.XZipFile \
+# com.sun.star.packages.XZipInputStream \
+# com.sun.star.packages.XZipOutputStream \
# --- Targets ------------------------------------------------------
diff --git a/package/source/zippackage/ZipPackage.cxx b/package/source/zippackage/ZipPackage.cxx
index f1ec914f77a7..e3a775fb4b1b 100644
--- a/package/source/zippackage/ZipPackage.cxx
+++ b/package/source/zippackage/ZipPackage.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ZipPackage.cxx,v $
*
- * $Revision: 1.39 $
+ * $Revision: 1.40 $
*
- * last change: $Author: mtg $ $Date: 2001-04-23 15:34:21 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:07 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -64,6 +64,9 @@
#ifndef _ZIP_PACKAGE_SINK_HXX
#include <ZipPackageSink.hxx>
#endif
+#ifndef _ZIP_ENUMERATION_HXX
+#include <ZipEnumeration.hxx>
+#endif
#ifndef _ZIP_PACKAGE_STREAM_HXX
#include <ZipPackageStream.hxx>
#endif
@@ -112,7 +115,6 @@ ZipPackage::ZipPackage (const Reference < XMultiServiceFactory > &xNewFactory)
, xContentStream (NULL)
, xContentSeek (NULL)
, xRootFolder (NULL)
-, xZipFile (NULL)
, xFactory(xNewFactory)
{
pRootFolder = new ZipPackageFolder();
@@ -121,8 +123,8 @@ ZipPackage::ZipPackage (const Reference < XMultiServiceFactory > &xNewFactory)
ZipPackage::~ZipPackage( void )
{
- if (pContent)
- delete pContent;
+ delete pContent;
+ delete pZipFile;
// As all folders and streams contain references to their parents,
// we must remove these references so that they will be deleted when
// the hash_map of the root folder is cleared, releasing all subfolders
@@ -135,19 +137,18 @@ ZipPackage::~ZipPackage( void )
void ZipPackage::getZipFileContents()
{
- Reference< XEnumeration > xEnum = pZipFile->entries();
+ ZipEnumeration *pEnum = pZipFile->entries();
Reference< XNameContainer > xCurrent;
ZipPackageStream *pPkgStream;
ZipPackageFolder *pPkgFolder;
- ZipEntry aEntry;
Any aAny;
- while (xEnum->hasMoreElements())
+
+ while (pEnum->hasMoreElements())
{
xCurrent = xRootFolder;
- sal_Int32 nOldIndex =0,nIndex = 0;
- aAny = xEnum->nextElement();
- aAny >>= aEntry;
- OUString &rName = aEntry.sName;
+ sal_Int32 nOldIndex = 0,nIndex = 0;
+ const ZipEntry & rEntry = *pEnum->nextElement();
+ const OUString &rName = rEntry.sName;
if (rName.lastIndexOf('/') == rName.getLength()-1)
{
@@ -212,9 +213,9 @@ void ZipPackage::getZipFileContents()
nOldIndex = nIndex+1;
}
OUString sStreamName = rName.copy( nOldIndex, rName.getLength() - nOldIndex);
- pPkgStream = new ZipPackageStream( pZipFile );
- pPkgStream->bPackageMember = sal_True;
- pPkgStream->setZipEntry( aEntry );
+ pPkgStream = new ZipPackageStream( *this );
+ pPkgStream->SetPackageMember( sal_True );
+ pPkgStream->setZipEntry( rEntry );
pPkgStream->setName( sStreamName );
try
{
@@ -241,32 +242,69 @@ void ZipPackage::getZipFileContents()
{
const OUString sFullPath ( RTL_CONSTASCII_USTRINGPARAM ( "FullPath" ) );
const OUString sMediaType ( RTL_CONSTASCII_USTRINGPARAM ( "MediaType" ) );
+ const OUString sInitialisationVector ( RTL_CONSTASCII_USTRINGPARAM ( "InitialisationVector" ) );
+ const OUString sSalt ( RTL_CONSTASCII_USTRINGPARAM ( "Salt" ) );
+ const OUString sIterationCount ( RTL_CONSTASCII_USTRINGPARAM ( "IterationCount" ) );
Sequence < Sequence < PropertyValue > > aManifestSequence = xReader->readManifestSequence ( xSink->getInputStream() );
sal_Int32 nLength = aManifestSequence.getLength();
const Sequence < PropertyValue > *pSequence = aManifestSequence.getConstArray();
+ ZipPackageStream *pStream = NULL;
+ ZipPackageFolder *pFolder = NULL;
for (sal_Int32 i = 0; i < nLength ; i++, pSequence++)
{
- OUString sPath;
- Any aValueAny;
+ OUString sPath, sMediaType;
const PropertyValue *pValue = pSequence->getConstArray();
for (sal_Int32 j = 0, nNum = pSequence->getLength(); j < nNum; j++ )
{
if (pValue[j].Name.equals( sFullPath ) )
pValue[j].Value >>= sPath;
else if (pValue[j].Name.equals( sMediaType ) )
- aValueAny = pValue[j].Value;
+ pValue[j].Value >>= sMediaType;
}
- if (sPath.getLength() && aValueAny.getValueTypeClass() == TypeClass_STRING)
+ if (sPath.getLength() && hasByHierarchicalName ( sPath ) )
{
- if ( hasByHierarchicalName ( sPath ) )
+ Any aAny = getByHierarchicalName( sPath );
+ Reference < XUnoTunnel > xTunnel;
+ aAny >>= xTunnel;
+ sal_Int64 nTest=0;
+ if ((nTest = xTunnel->getSomething(ZipPackageFolder::getUnoTunnelImplementationId())) != 0)
+ {
+ pFolder = reinterpret_cast < ZipPackageFolder* > ( nTest );
+ pFolder->SetMediaType ( sMediaType );
+ }
+ else
{
- Any aAny = getByHierarchicalName( sPath );
- Reference < XUnoTunnel > xTunnel;
- aAny >>= xTunnel;
- Reference < XPropertySet > xProps ( xTunnel, UNO_QUERY );
- xProps->setPropertyValue ( sMediaType, aValueAny );
+ pStream = reinterpret_cast < ZipPackageStream* > ( xTunnel->getSomething(ZipPackageStream::getUnoTunnelImplementationId()));
+ pStream->SetMediaType ( sMediaType );
+ pValue = pSequence->getConstArray();
+ sal_Bool bSetEncrypted = sal_False;
+ for (sal_Int32 j = 0, nNum = pSequence->getLength(); j < nNum; j++ )
+ {
+ Sequence < sal_Int8 > aSequence;
+ if (pValue[j].Name.equals( sSalt ) )
+ {
+ pValue[j].Value >>= aSequence;
+ pStream->setSalt ( aSequence );
+ bSetEncrypted = sal_True;
+ }
+ else if (pValue[j].Name.equals( sInitialisationVector ) )
+ {
+ pValue[j].Value >>= aSequence;
+ pStream->setInitialisationVector ( aSequence );
+ bSetEncrypted = sal_True;
+ }
+ else if (pValue[j].Name.equals( sIterationCount ) )
+ {
+ sal_Int64 nCount;
+ pValue[j].Value >>= nCount;
+ pStream->setIterationCount ( nCount );
+ bSetEncrypted = sal_True;
+ }
+ }
+ if (bSetEncrypted)
+ pStream->SetToBeEncrypted ( sal_True );
}
}
}
@@ -290,7 +328,6 @@ void SAL_CALL ZipPackage::initialize( const Sequence< Any >& aArguments )
try
{
pZipFile = new ZipFile(xContentStream, sal_True);
- xZipFile = Reference < XZipFile > ( pZipFile );
getZipFileContents();
}
catch (ZipException&)// rException)
@@ -479,7 +516,7 @@ sal_Bool SAL_CALL ZipPackage::hasByHierarchicalName( const OUString& aName )
Reference< XInterface > SAL_CALL ZipPackage::createInstance( )
throw(Exception, RuntimeException)
{
- Reference < XInterface > xRef = *(new ZipPackageStream ( pZipFile ));
+ Reference < XInterface > xRef = *(new ZipPackageStream ( *this ));
return xRef;
}
Reference< XInterface > SAL_CALL ZipPackage::createInstanceWithArguments( const Sequence< Any >& aArguments )
@@ -491,7 +528,7 @@ Reference< XInterface > SAL_CALL ZipPackage::createInstanceWithArguments( const
if (bArg)
xRef = *new ZipPackageFolder ( );
else
- xRef = *new ZipPackageStream ( pZipFile );
+ xRef = *new ZipPackageStream ( *this );
return xRef;
}
@@ -508,17 +545,14 @@ void SAL_CALL ZipPackage::commitChanges( )
ZipPackageBuffer *pZipBuffer = new ZipPackageBuffer( 65535 );
Reference < XOutputStream > xOutStream (pZipBuffer);
- ZipOutputStream *pZipOut = new ZipOutputStream( xOutStream, 65535 );
+ ZipOutputStream aZipOut ( xOutStream, 65535 );
// Make a reference to the manifest output stream so it persists
// until the call to ZipOutputStream->finish()
Reference < XOutputStream > xManOutStream;
- ZipPackageStream *pManifestStream = NULL;
-
- Reference < XZipOutputStream > xZipOut (pZipOut);
- pZipOut->setMethod(DEFLATED);
- pZipOut->setLevel(DEFAULT_COMPRESSION);
+ aZipOut.setMethod(DEFLATED);
+ aZipOut.setLevel(DEFAULT_COMPRESSION);
// Remove the old META-INF directory as this will be re-generated below.
// Pass save-contents a vector which will be used to store the entries which
@@ -533,12 +567,12 @@ void SAL_CALL ZipPackage::commitChanges( )
Sequence < PropertyValue > aPropSeq ( 2 );
aPropSeq [0].Name = sMediaType;
- aPropSeq [0].Value <<= pRootFolder->getPropertyValue( sMediaType ) ;
+ aPropSeq [0].Value <<= pRootFolder->GetMediaType( );
aPropSeq [1].Name = sFullPath;
aPropSeq [1].Value <<= OUString ( RTL_CONSTASCII_USTRINGPARAM ( "/" ) );
aManList.push_back( aPropSeq );
- pRootFolder->saveContents(OUString(), aManList, *pZipOut);
+ pRootFolder->saveContents(OUString(), aManList, aZipOut);
OUString sManifestWriter( RTL_CONSTASCII_USTRINGPARAM ( "com.sun.star.packages.manifest.ManifestWriter" ) );
Reference < XManifestWriter > xWriter (xFactory->createInstance( sManifestWriter ), UNO_QUERY );
@@ -567,9 +601,10 @@ void SAL_CALL ZipPackage::commitChanges( )
try
{
- pZipOut->putNextEntry(*pEntry);
- pZipOut->write(pBuffer->aBuffer, 0, pEntry->nSize);
- pZipOut->closeEntry();
+ vos::ORef < EncryptionData > xEmpty;
+ aZipOut.putNextEntry(*pEntry, xEmpty);
+ aZipOut.write(pBuffer->aBuffer, 0, pEntry->nSize);
+ aZipOut.closeEntry();
}
catch (::com::sun::star::io::IOException & )
{
@@ -578,7 +613,7 @@ void SAL_CALL ZipPackage::commitChanges( )
}
try
{
- pZipOut->finish();
+ aZipOut.finish();
}
catch (::com::sun::star::io::IOException & )
{
@@ -666,6 +701,7 @@ Any SAL_CALL ZipPackage::queryInterface( const Type& rType )
static_cast< XSingleServiceFactory* > ( this ) ,
static_cast< XUnoTunnel* > ( this ) ,
static_cast< XHierarchicalNameAccess* > ( this ) ,
+ static_cast< XPropertySet* > ( this ) ,
static_cast< XChangesBatch* > ( this ) );
}
@@ -705,3 +741,45 @@ sal_Int64 SAL_CALL ZipPackage::getSomething( const Sequence< sal_Int8 >& aIdenti
return 0;
}
+Reference< XPropertySetInfo > SAL_CALL ZipPackage::getPropertySetInfo( )
+ throw(RuntimeException)
+{
+ return Reference < XPropertySetInfo > (NULL);
+}
+void SAL_CALL ZipPackage::setPropertyValue( const OUString& aPropertyName, const Any& aValue )
+ throw(UnknownPropertyException, PropertyVetoException, IllegalArgumentException, WrappedTargetException, RuntimeException)
+{
+ if (aPropertyName.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("EncryptionKey") ) )
+ if (!( aValue >>= aEncryptionKey ) )
+ throw IllegalArgumentException();
+ else
+ throw UnknownPropertyException();
+}
+Any SAL_CALL ZipPackage::getPropertyValue( const OUString& PropertyName )
+ throw(UnknownPropertyException, WrappedTargetException, RuntimeException)
+{
+ Any aAny;
+ if (PropertyName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "EncryptionKey" ) ) )
+ {
+ aAny <<= aEncryptionKey;
+ return aAny;
+ }
+ else
+ throw UnknownPropertyException();
+}
+void SAL_CALL ZipPackage::addPropertyChangeListener( const OUString& aPropertyName, const Reference< XPropertyChangeListener >& xListener )
+ throw(UnknownPropertyException, WrappedTargetException, RuntimeException)
+{
+}
+void SAL_CALL ZipPackage::removePropertyChangeListener( const OUString& aPropertyName, const Reference< XPropertyChangeListener >& aListener )
+ throw(UnknownPropertyException, WrappedTargetException, RuntimeException)
+{
+}
+void SAL_CALL ZipPackage::addVetoableChangeListener( const OUString& PropertyName, const Reference< XVetoableChangeListener >& aListener )
+ throw(UnknownPropertyException, WrappedTargetException, RuntimeException)
+{
+}
+void SAL_CALL ZipPackage::removeVetoableChangeListener( const OUString& PropertyName, const Reference< XVetoableChangeListener >& aListener )
+ throw(UnknownPropertyException, WrappedTargetException, RuntimeException)
+{
+}
diff --git a/package/source/zippackage/ZipPackageEntry.cxx b/package/source/zippackage/ZipPackageEntry.cxx
index 4276d4b80318..6559464d7db8 100644
--- a/package/source/zippackage/ZipPackageEntry.cxx
+++ b/package/source/zippackage/ZipPackageEntry.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ZipPackageEntry.cxx,v $
*
- * $Revision: 1.16 $
+ * $Revision: 1.17 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:16:31 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:07 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -73,8 +73,6 @@ using namespace com::sun::star::packages::ZipConstants;
using namespace rtl;
ZipPackageEntry::ZipPackageEntry (void)
-: bPackageMember ( sal_False )
-, bToBeCompressed ( sal_True )
{
}
@@ -147,58 +145,6 @@ uno::Reference< beans::XPropertySetInfo > SAL_CALL ZipPackageEntry::getPropertyS
{
return uno::Reference < beans::XPropertySetInfo > (NULL);
}
-void SAL_CALL ZipPackageEntry::setPropertyValue( const ::rtl::OUString& aPropertyName, const uno::Any& aValue )
- throw(beans::UnknownPropertyException, beans::PropertyVetoException, lang::IllegalArgumentException, lang::WrappedTargetException, uno::RuntimeException)
-{
- if (aPropertyName.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("MediaType")))
- {
- aValue >>= sMediaType;
-
- if (sMediaType.getLength() > 0)
- {
- if ( sMediaType.indexOf (OUString( RTL_CONSTASCII_USTRINGPARAM ( "text" ) ) ) != -1)
- bToBeCompressed = sal_True;
- else
- bToBeCompressed = sal_False;
- }
- }
- else if (aPropertyName.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("Size") ) )
- aValue >>= aEntry.nSize;
-#if SUPD>617
- else if (aPropertyName.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("Compressed") ) )
-#else
- else if (aPropertyName.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("Compress") ) )
-#endif
- aValue >>= bToBeCompressed;
- else
- throw beans::UnknownPropertyException();
-}
-uno::Any SAL_CALL ZipPackageEntry::getPropertyValue( const ::rtl::OUString& PropertyName )
- throw(beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException)
-{
- uno::Any aAny;
- if (PropertyName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "MediaType" ) ) )
- {
- aAny <<= sMediaType;
- return aAny;
- }
- else if (PropertyName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "Size" ) ) )
- {
- aAny <<= aEntry.nSize;
- return aAny;
- }
-#if SUPD>617
- else if (PropertyName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "Compressed" ) ) )
-#else
- else if (PropertyName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "Compress" ) ) )
-#endif
- {
- aAny <<= bToBeCompressed;
- return aAny;
- }
- else
- throw beans::UnknownPropertyException();
-}
void SAL_CALL ZipPackageEntry::addPropertyChangeListener( const ::rtl::OUString& aPropertyName, const uno::Reference< beans::XPropertyChangeListener >& xListener )
throw(beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException)
{
diff --git a/package/source/zippackage/ZipPackageEntry.hxx b/package/source/zippackage/ZipPackageEntry.hxx
index a89e75d250c1..ef2e41bec7d5 100644
--- a/package/source/zippackage/ZipPackageEntry.hxx
+++ b/package/source/zippackage/ZipPackageEntry.hxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ZipPackageEntry.hxx,v $
*
- * $Revision: 1.1 $
+ * $Revision: 1.2 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:15:42 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:07 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -85,13 +85,13 @@ class ZipPackageEntry : public com::sun::star::container::XNamed,
public com::sun::star::lang::XUnoTunnel,
public com::sun::star::beans::XPropertySet
{
-private:
+protected:
com::sun::star::uno::Reference < com::sun::star::uno::XInterface > xParent;
::rtl::OUString sMediaType;
- sal_Bool bToBeCompressed;
public:
com::sun::star::packages::ZipEntry aEntry;
- sal_Bool bPackageMember;
+ ::rtl::OUString & GetMediaType () { return sMediaType; }
+ void SetMediaType ( ::rtl::OUString & sNewType) { sMediaType = sNewType; }
ZipPackageEntry (void);
virtual ~ZipPackageEntry( void );
@@ -124,9 +124,9 @@ public:
virtual ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySetInfo > SAL_CALL getPropertySetInfo( )
throw(::com::sun::star::uno::RuntimeException);
virtual void SAL_CALL setPropertyValue( const ::rtl::OUString& aPropertyName, const ::com::sun::star::uno::Any& aValue )
- throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::beans::PropertyVetoException, ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException);
+ throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::beans::PropertyVetoException, ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) = 0;
virtual ::com::sun::star::uno::Any SAL_CALL getPropertyValue( const ::rtl::OUString& PropertyName )
- throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException);
+ throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) = 0;
virtual void SAL_CALL addPropertyChangeListener( const ::rtl::OUString& aPropertyName, const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertyChangeListener >& xListener )
throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException);
virtual void SAL_CALL removePropertyChangeListener( const ::rtl::OUString& aPropertyName, const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertyChangeListener >& aListener )
diff --git a/package/source/zippackage/ZipPackageFolder.cxx b/package/source/zippackage/ZipPackageFolder.cxx
index cf25ae64fa19..1ec2cf5f097d 100644
--- a/package/source/zippackage/ZipPackageFolder.cxx
+++ b/package/source/zippackage/ZipPackageFolder.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ZipPackageFolder.cxx,v $
*
- * $Revision: 1.35 $
+ * $Revision: 1.36 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:16:31 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:07 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -79,6 +79,12 @@
#ifndef _VOS_DIAGNOSE_H_
#include <vos/diagnose.hxx>
#endif
+#ifndef _RTL_RANDOM_H_
+#include <rtl/random.h>
+#endif
+#ifndef _OSL_TIME_H_
+#include <osl/time.h>
+#endif
using namespace com::sun::star::packages::ZipConstants;
using namespace com::sun::star::container;
@@ -92,7 +98,6 @@ using namespace rtl;
using namespace std;
ZipPackageFolder::ZipPackageFolder (void)
-: pPackage( NULL )
{
aEntry.nVersion = -1;
aEntry.nFlag = 0;
@@ -225,10 +230,11 @@ Any SAL_CALL ZipPackageFolder::getByName( const OUString& aName )
sName = aName.copy(1, aName.getLength());
else
sName = aName;
- if (!aContents.count(sName))
+ TunnelHash::const_iterator aCI = aContents.find(sName);
+
+ if (aCI == aContents.end())
throw NoSuchElementException();
- TunnelHash::const_iterator aCI = aContents.find(sName);
aAny <<= (*aCI).second;
return aAny;
}
@@ -275,6 +281,15 @@ void ZipPackageFolder::saveContents(OUString &rPath, std::vector < Sequence < Pr
TunnelHash::const_iterator aCI = aContents.begin(), aEnd = aContents.end();
const OUString sMediaType ( RTL_CONSTASCII_USTRINGPARAM ( "MediaType" ) );
const OUString sFullPath ( RTL_CONSTASCII_USTRINGPARAM ( "FullPath" ) );
+ const OUString sInitialisationVector ( RTL_CONSTASCII_USTRINGPARAM ( "InitialisationVector" ) );
+ const OUString sSalt ( RTL_CONSTASCII_USTRINGPARAM ( "Salt" ) );
+ const OUString sIterationCount ( RTL_CONSTASCII_USTRINGPARAM ( "IterationCount" ) );
+
+ // Get a random number generator and seed it with current timestamp
+ TimeValue aTime;
+ osl_getSystemTime( &aTime );
+ rtlRandomPool aRandomPool = rtl_random_createPool ();
+ rtl_random_addBytes ( aRandomPool, &aTime, 8 );
for (; aCI!=aEnd ; aCI++)
{
@@ -314,35 +329,24 @@ void ZipPackageFolder::saveContents(OUString &rPath, std::vector < Sequence < Pr
try
{
- rZipOut.putNextEntry(*pTempEntry);
+ vos::ORef < EncryptionData > xEmpty;
+ rZipOut.putNextEntry(*pTempEntry, xEmpty);
rZipOut.closeEntry();
}
catch (IOException & )
{
VOS_ENSURE( 0, "Error writing ZipOutputStream" );
}
- try
- {
- aPropSet[1].Name = sMediaType;
- aPropSet[1].Value <<= pFolder->getPropertyValue(OUString( RTL_CONSTASCII_USTRINGPARAM ( "MediaType") ) );
- }
- catch (UnknownPropertyException & )
- {
- VOS_ENSURE( 0, "MediaType is an unknown property!!" );
- }
- // Then copy it back
+ aPropSet[0].Name = sMediaType;
+ aPropSet[0].Value <<= pFolder->GetMediaType();
+ aPropSet[1].Name = sFullPath;
+ aPropSet[1].Value <<= pFolder->aEntry.sName;
+
+ // Copy back the zip entry and make the offset negative so that we
+ // know it's point at the beginning of the LOC
ZipPackageFolder::copyZipEntry ( pFolder->aEntry, *pTempEntry );
pFolder->aEntry.nOffset *= -1;
- try
- {
- aPropSet[0].Name = sFullPath;
- aPropSet[0].Value <<= pFolder->aEntry.sName;
- }
- catch (UnknownPropertyException & )
- {
- VOS_ENSURE( 0, "MediaType is an unknown property!!" );
- }
pFolder->saveContents(pFolder->aEntry.sName, rManList, rZipOut);
pFolder->aEntry.sName = (*aCI).first;
}
@@ -351,20 +355,39 @@ void ZipPackageFolder::saveContents(OUString &rPath, std::vector < Sequence < Pr
// In case the entry we are reading is also the entry we are writing, we will
// store the ZipEntry data in pTempEntry
-#if SUPD>617
- Any aAny = pStream->getPropertyValue(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Compressed") ) );
-#else
- Any aAny = pStream->getPropertyValue(OUString( RTL_CONSTASCII_USTRINGPARAM ( "Compress") ) );
-#endif
- sal_Bool bToBeCompressed;
- aAny >>= bToBeCompressed;
-
ZipPackageFolder::copyZipEntry ( *pTempEntry, pStream->aEntry );
pTempEntry->sName = rPath + (*aCI).first;
+ sal_Bool bToBeCompressed = pStream->IsToBeCompressed();
+ sal_Bool bToBeEncrypted = pStream->IsToBeEncrypted();
+
+ aPropSet[0].Name = sMediaType;
+ aPropSet[0].Value <<= pStream->GetMediaType( );
+ aPropSet[1].Name = sFullPath;
+ aPropSet[1].Value <<= pStream->aEntry.sName;
+
+ if ( bToBeEncrypted)
+ {
+ Sequence < sal_Int8 > aSalt ( 16 ), aVector ( 8 );
+ rtl_random_getBytes ( aRandomPool, aSalt.getArray(), 16 );
+ rtl_random_getBytes ( aRandomPool, aVector.getArray(), 8 );
+ sal_Int64 nIterationCount = 1024;
+
+ pStream->setInitialisationVector ( aVector );
+ pStream->setSalt ( aSalt );
+ pStream->setIterationCount ( nIterationCount );
+
+ aPropSet.realloc(5);
+ aPropSet[2].Name = sInitialisationVector;
+ aPropSet[2].Value <<= aVector;
+ aPropSet[3].Name = sSalt;
+ aPropSet[3].Value <<= aSalt;
+ aPropSet[4].Name = sIterationCount;
+ aPropSet[4].Value <<= nIterationCount;
+ }
// If the entry is already stored in the zip file in the format we
// want for this write...copy it raw
- if (pStream->bPackageMember &&
+ if (pStream->IsPackageMember() &&
( (pTempEntry->nMethod == DEFLATED && bToBeCompressed) ||
(pTempEntry->nMethod == STORED && !bToBeCompressed) ) )
{
@@ -373,7 +396,7 @@ void ZipPackageFolder::saveContents(OUString &rPath, std::vector < Sequence < Pr
Reference < XInputStream > xStream = pStream->getRawStream( *pTempEntry );
try
{
- rZipOut.putNextEntry ( *pTempEntry );
+ rZipOut.putNextEntry ( *pTempEntry, pStream->getEncryptionData(), bToBeEncrypted );
while (1)
{
Sequence < sal_Int8 > aSeq (65535);
@@ -405,11 +428,7 @@ void ZipPackageFolder::saveContents(OUString &rPath, std::vector < Sequence < Pr
pTempEntry->nCrc = -1;
pTempEntry->nSize = -1;
pTempEntry->nCompressedSize = -1;
-
- if (bToBeCompressed)
- pTempEntry->nMethod = DEFLATED;
- else
- pTempEntry->nMethod = STORED;
+ pTempEntry->nMethod = bToBeCompressed ? DEFLATED : STORED;
if (xSeek.is())
{
@@ -426,7 +445,7 @@ void ZipPackageFolder::saveContents(OUString &rPath, std::vector < Sequence < Pr
try
{
- rZipOut.putNextEntry ( *pTempEntry );
+ rZipOut.putNextEntry ( *pTempEntry, pStream->getEncryptionData(), bToBeEncrypted );
while (1)
{
Sequence < sal_Int8 > aSeq (65535);
@@ -442,7 +461,7 @@ void ZipPackageFolder::saveContents(OUString &rPath, std::vector < Sequence < Pr
}
if (bTrackLength)
pTempEntry->nCompressedSize = pStream->aEntry.nSize;
- pStream->bPackageMember = sal_True;
+ pStream->SetPackageMember ( sal_True );
rZipOut.closeEntry();
}
catch (IOException & )
@@ -451,32 +470,12 @@ void ZipPackageFolder::saveContents(OUString &rPath, std::vector < Sequence < Pr
}
}
- try
- {
- aPropSet[0].Name = sFullPath;
- aPropSet[0].Value <<= pStream->aEntry.sName;
- }
- catch (UnknownPropertyException & )
- {
- VOS_ENSURE( 0, "MediaType is an unknown property!!" );
- }
- try
- {
- aPropSet[1].Name = sMediaType;
- aPropSet[1].Value <<= pStream->getPropertyValue( sMediaType );
- }
- catch (UnknownPropertyException & )
- {
- VOS_ENSURE( 0, "MediaType is an unknown property!!" );
- }
+
// Then copy it back afterwards...
ZipPackageFolder::copyZipEntry ( pStream->aEntry, *pTempEntry );
pStream->aEntry.sName = (*aCI).first;
pStream->aEntry.nOffset *= -1;
}
- OUString aString, bString;
- aPropSet[0].Value >>= aString;
- aPropSet[1].Value >>= bString;
rManList.push_back (aPropSet);
}
}
@@ -514,48 +513,6 @@ void ZipPackageFolder::releaseUpwardRef( void )
pStream->clearParent();
}
}
-void ZipPackageFolder::updateReferences( ZipFile * pNewZipFile)
-{
- Reference < XUnoTunnel > xTunnel;
- ZipPackageFolder *pFolder = NULL;
- ZipPackageStream *pStream = NULL;
- sal_Bool bIsFolder;
- TunnelHash::const_iterator aCI = aContents.begin();
-
- for (;aCI!=aContents.end();aCI++)
- {
- xTunnel = Reference < XUnoTunnel> ((*aCI).second, UNO_QUERY);
- sal_Int64 nTest=0;
- if ((nTest = xTunnel->getSomething(ZipPackageFolder::getUnoTunnelImplementationId())) != 0)
- {
- pFolder = reinterpret_cast < ZipPackageFolder* > ( nTest );
- bIsFolder = sal_True;
- }
- else
- {
- // If this getSomething call returns 0, it means that
- // something evil has crept into the contents hash_map, which
- // should mean that something has gone very wrong somewhere, and someone
- // else should deal with it
-
- nTest = xTunnel->getSomething(ZipPackageStream::getUnoTunnelImplementationId());
- if (nTest == 0)
- throw RuntimeException();
- pStream = reinterpret_cast < ZipPackageStream* > ( nTest );
- bIsFolder = sal_False;
- }
-
- if (bIsFolder)
- {
- //if pPackage is set,then this is the root folder of a different ZipPackage and
- // should not be changed
- if (!pFolder->pPackage)
- pFolder->updateReferences(pNewZipFile);
- }
- else
- pStream->pZipFile = pNewZipFile;
- }
-}
Sequence< sal_Int8 > ZipPackageFolder::getUnoTunnelImplementationId( void )
throw (RuntimeException)
@@ -581,3 +538,30 @@ sal_Int64 SAL_CALL ZipPackageFolder::getSomething( const Sequence< sal_Int8 >& a
return 0;
}
+void SAL_CALL ZipPackageFolder::setPropertyValue( const OUString& aPropertyName, const Any& aValue )
+ throw(UnknownPropertyException, PropertyVetoException, IllegalArgumentException, WrappedTargetException, RuntimeException)
+{
+ if (aPropertyName.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("MediaType")))
+ aValue >>= sMediaType;
+ else if (aPropertyName.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("Size") ) )
+ aValue >>= aEntry.nSize;
+ else
+ throw UnknownPropertyException();
+}
+Any SAL_CALL ZipPackageFolder::getPropertyValue( const OUString& PropertyName )
+ throw(UnknownPropertyException, WrappedTargetException, RuntimeException)
+{
+ Any aAny;
+ if (PropertyName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "MediaType" ) ) )
+ {
+ aAny <<= sMediaType;
+ return aAny;
+ }
+ else if (PropertyName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "Size" ) ) )
+ {
+ aAny <<= aEntry.nSize;
+ return aAny;
+ }
+ else
+ throw UnknownPropertyException();
+}
diff --git a/package/source/zippackage/ZipPackageFolderEnumeration.hxx b/package/source/zippackage/ZipPackageFolderEnumeration.hxx
index dcffd3d51c8e..49b8fa09a22e 100644
--- a/package/source/zippackage/ZipPackageFolderEnumeration.hxx
+++ b/package/source/zippackage/ZipPackageFolderEnumeration.hxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ZipPackageFolderEnumeration.hxx,v $
*
- * $Revision: 1.1 $
+ * $Revision: 1.2 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:15:53 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:07 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -75,7 +75,7 @@ class ZipPackageFolderEnumeration : public cppu::WeakImplHelper1<
com::sun::star::container::XEnumeration
>
{
-private:
+protected:
TunnelHash &rContents;
TunnelHash::const_iterator aIterator;
public:
diff --git a/package/source/zippackage/ZipPackageSink.hxx b/package/source/zippackage/ZipPackageSink.hxx
index 3e1cf1802b00..80bfde7a3c0c 100644
--- a/package/source/zippackage/ZipPackageSink.hxx
+++ b/package/source/zippackage/ZipPackageSink.hxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ZipPackageSink.hxx,v $
*
- * $Revision: 1.1 $
+ * $Revision: 1.2 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:15:31 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:07 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -71,7 +71,7 @@
class ZipPackageSink : public com::sun::star::io::XActiveDataSink,
public cppu::OWeakObject
{
-private:
+protected:
com::sun::star::uno::Reference < com::sun::star::io::XInputStream > xStream;
public:
ZipPackageSink(void);
diff --git a/package/source/zippackage/ZipPackageStream.cxx b/package/source/zippackage/ZipPackageStream.cxx
index b68e3f217c87..ea82be5a0212 100644
--- a/package/source/zippackage/ZipPackageStream.cxx
+++ b/package/source/zippackage/ZipPackageStream.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ZipPackageStream.cxx,v $
*
- * $Revision: 1.15 $
+ * $Revision: 1.16 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:16:31 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:07 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -62,6 +62,9 @@
#ifndef _ZIP_PACKAGE_STREAM_HXX
#include <ZipPackageStream.hxx>
#endif
+#ifndef _ZIP_PACKAGE_HXX
+#include <ZipPackage.hxx>
+#endif
#ifndef _ZIP_FILE_HXX
#include <ZipFile.hxx>
#endif
@@ -69,13 +72,18 @@
#include <vos/diagnose.hxx>
#endif
-
-
+using namespace com::sun::star::uno;
+using namespace com::sun::star::lang;
using namespace com::sun::star;
using namespace cppu;
+using namespace rtl;
-ZipPackageStream::ZipPackageStream (ZipFile *pInFile)
-: pZipFile(pInFile)
+ZipPackageStream::ZipPackageStream (ZipPackage & rNewPackage )
+: rZipPackage(rNewPackage)
+, bToBeCompressed ( sal_False )
+, bToBeEncrypted ( sal_False )
+, bPackageMember ( sal_False )
+, xEncryptionData ( new EncryptionData )
{
aEntry.nVersion = -1;
aEntry.nFlag = 0;
@@ -106,17 +114,17 @@ void ZipPackageStream::setZipEntry( const packages::ZipEntry &rInEntry)
aEntry.sComment = rInEntry.sComment;
}
//XInterface
-uno::Any SAL_CALL ZipPackageStream::queryInterface( const uno::Type& rType )
- throw(uno::RuntimeException)
+Any SAL_CALL ZipPackageStream::queryInterface( const Type& rType )
+ throw(RuntimeException)
{
return ( ::cppu::queryInterface ( rType ,
// OWeakObject interfaces
- reinterpret_cast< uno::XInterface* > ( this ) ,
- static_cast< uno::XWeak* > ( this ) ,
+ reinterpret_cast< XInterface* > ( this ) ,
+ static_cast< XWeak* > ( this ) ,
// ZipPackageEntry interfaces
static_cast< container::XNamed* > ( this ) ,
static_cast< container::XChild* > ( this ) ,
- static_cast< lang::XUnoTunnel* > ( this ) ,
+ static_cast< XUnoTunnel* > ( this ) ,
// My own interfaces
static_cast< io::XActiveDataSink* > ( this ) ,
static_cast< beans::XPropertySet* > ( this ) ) );
@@ -135,53 +143,55 @@ void SAL_CALL ZipPackageStream::release( )
}
// XActiveDataSink
-void SAL_CALL ZipPackageStream::setInputStream( const uno::Reference< io::XInputStream >& aStream )
- throw(uno::RuntimeException)
+void SAL_CALL ZipPackageStream::setInputStream( const Reference< io::XInputStream >& aStream )
+ throw(RuntimeException)
{
xStream = aStream;
- bPackageMember = sal_False;
+ SetPackageMember ( sal_False );
aEntry.nTime = -1;
}
-uno::Reference< io::XInputStream > SAL_CALL ZipPackageStream::getRawStream( com::sun::star::packages::ZipEntry &rEntry )
- throw(uno::RuntimeException)
+Reference< io::XInputStream > SAL_CALL ZipPackageStream::getRawStream( com::sun::star::packages::ZipEntry &rEntry )
+ throw(RuntimeException)
{
- if (bPackageMember)
+ if (IsPackageMember())
{
try
{
- return pZipFile->getRawStream(rEntry);
+ return rZipPackage.getZipFile().getRawStream(rEntry, xEncryptionData);
}
catch (packages::ZipException &)//rException)
{
VOS_ENSURE( 0, "ZipException thrown");//rException.Message);
- return uno::Reference < io::XInputStream > ();
+ return Reference < io::XInputStream > ();
}
}
else
return xStream;
}
-uno::Reference< io::XInputStream > SAL_CALL ZipPackageStream::getInputStream( )
- throw(uno::RuntimeException)
+Reference< io::XInputStream > SAL_CALL ZipPackageStream::getInputStream( )
+ throw(RuntimeException)
{
- if (bPackageMember)
+ if (IsPackageMember())
{
try
{
- return pZipFile->getInputStream(aEntry);
+ return rZipPackage.getZipFile().getInputStream( aEntry, xEncryptionData);
}
catch (packages::ZipException &)//rException)
{
VOS_ENSURE( 0,"ZipException thrown");//rException.Message);
- return uno::Reference < io::XInputStream > ();
+ return Reference < io::XInputStream > ();
}
}
else
return xStream;
}
-uno::Sequence< sal_Int8 > ZipPackageStream::getUnoTunnelImplementationId( void )
- throw (uno::RuntimeException)
+
+// XPropertySet
+Sequence< sal_Int8 > ZipPackageStream::getUnoTunnelImplementationId( void )
+ throw (RuntimeException)
{
static ::cppu::OImplementationId * pId = 0;
if (! pId)
@@ -196,8 +206,8 @@ uno::Sequence< sal_Int8 > ZipPackageStream::getUnoTunnelImplementationId( void )
return pId->getImplementationId();
}
-sal_Int64 SAL_CALL ZipPackageStream::getSomething( const uno::Sequence< sal_Int8 >& aIdentifier )
- throw(uno::RuntimeException)
+sal_Int64 SAL_CALL ZipPackageStream::getSomething( const Sequence< sal_Int8 >& aIdentifier )
+ throw(RuntimeException)
{
if (aIdentifier.getLength() == 16 &&
0 == rtl_compareMemory(getUnoTunnelImplementationId().getConstArray(),
@@ -206,3 +216,67 @@ sal_Int64 SAL_CALL ZipPackageStream::getSomething( const uno::Sequence< sal_Int8
return 0;
}
+void SAL_CALL ZipPackageStream::setPropertyValue( const OUString& aPropertyName, const Any& aValue )
+ throw(beans::UnknownPropertyException, beans::PropertyVetoException, IllegalArgumentException, WrappedTargetException, RuntimeException)
+{
+ if (aPropertyName.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("MediaType")))
+ {
+ aValue >>= sMediaType;
+
+ if (sMediaType.getLength() > 0)
+ {
+ if ( sMediaType.indexOf (OUString( RTL_CONSTASCII_USTRINGPARAM ( "text" ) ) ) != -1)
+ bToBeCompressed = sal_True;
+ else
+ bToBeCompressed = sal_False;
+ }
+ }
+ else if (aPropertyName.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("Size") ) )
+ aValue >>= aEntry.nSize;
+ else if (aPropertyName.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("Encrypted") ) )
+ aValue >>= bToBeEncrypted;
+#if SUPD>617
+ else if (aPropertyName.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("Compressed") ) )
+#else
+ else if (aPropertyName.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("Compress") ) )
+#endif
+ aValue >>= bToBeCompressed;
+ else
+ throw beans::UnknownPropertyException();
+}
+Any SAL_CALL ZipPackageStream::getPropertyValue( const OUString& PropertyName )
+ throw(beans::UnknownPropertyException, WrappedTargetException, RuntimeException)
+{
+ Any aAny;
+ if (PropertyName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "MediaType" ) ) )
+ {
+ aAny <<= sMediaType;
+ return aAny;
+ }
+ else if (PropertyName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "Size" ) ) )
+ {
+ aAny <<= aEntry.nSize;
+ return aAny;
+ }
+ else if (PropertyName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "Encrypted" ) ) )
+ {
+ aAny <<= bToBeEncrypted;
+ return aAny;
+ }
+#if SUPD>617
+ else if (PropertyName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "Compressed" ) ) )
+#else
+ else if (PropertyName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "Compress" ) ) )
+#endif
+ {
+ aAny <<= bToBeCompressed;
+ return aAny;
+ }
+ else
+ throw beans::UnknownPropertyException();
+}
+
+const com::sun::star::uno::Sequence < sal_Int8 >& ZipPackageStream::getEncryptionKey ()
+{
+ return rZipPackage.getEncryptionKey();
+}
diff --git a/package/source/zippackage/ZipPackageStream.hxx b/package/source/zippackage/ZipPackageStream.hxx
index 5cf456905cb5..75524abfee30 100644
--- a/package/source/zippackage/ZipPackageStream.hxx
+++ b/package/source/zippackage/ZipPackageStream.hxx
@@ -2,9 +2,9 @@
*
* $RCSfile: ZipPackageStream.hxx,v $
*
- * $Revision: 1.1 $
+ * $Revision: 1.2 $
*
- * last change: $Author: mtg $ $Date: 2001-04-19 14:15:10 $
+ * last change: $Author: mtg $ $Date: 2001-04-27 14:56:07 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -73,17 +73,48 @@
#ifndef _ZIP_PACKAGE_ENTRY_HXX
#include <ZipPackageEntry.hxx>
#endif
+#ifndef _VOS_REF_H_
+#include <vos/ref.hxx>
+#endif
+#ifndef _ENCRYPTION_DATA_HXX_
+#include <EncryptionData.hxx>
+#endif
-class ZipFile;
+class ZipPackage;
class ZipPackageStream : public ZipPackageEntry,
public ::cppu::OWeakObject,
public ::com::sun::star::io::XActiveDataSink
{
-private:
+protected:
com::sun::star::uno::Reference < com::sun::star::io::XInputStream > xStream;
+ ZipPackage &rZipPackage;
+ sal_Bool bToBeCompressed, bToBeEncrypted, bPackageMember;
+ vos::ORef < EncryptionData > xEncryptionData;
public:
- ZipFile *pZipFile;
- ZipPackageStream (ZipFile *pInFile);
+ inline sal_Bool IsToBeCompressed () { return bToBeCompressed;}
+ inline sal_Bool IsToBeEncrypted () { return bToBeEncrypted;}
+ inline sal_Bool IsPackageMember () { return bPackageMember;}
+ const com::sun::star::uno::Sequence < sal_Int8 >& getEncryptionKey ();
+ const vos::ORef < EncryptionData > & getEncryptionData ()
+ { return xEncryptionData;}
+ const com::sun::star::uno::Sequence < sal_Int8 >& getInitialisationVector ()
+ { return xEncryptionData->aInitVector;}
+ const com::sun::star::uno::Sequence < sal_Int8 >& getSalt ()
+ { return xEncryptionData->aSalt;}
+ const sal_Int64 getIterationCount ()
+ { return xEncryptionData->nIterationCount;}
+
+ inline void SetToBeCompressed (sal_Bool bNewValue) { bToBeCompressed = bNewValue;}
+ inline void SetToBeEncrypted (sal_Bool bNewValue) { bToBeEncrypted = bNewValue;}
+ inline void SetPackageMember (sal_Bool bNewValue) { bPackageMember = bNewValue;}
+ inline void setInitialisationVector (const com::sun::star::uno::Sequence < sal_Int8 >& rNewVector )
+ { xEncryptionData->aInitVector = rNewVector;}
+ inline void setSalt (const com::sun::star::uno::Sequence < sal_Int8 >& rNewSalt )
+ { xEncryptionData->aSalt = rNewSalt;}
+ inline void setIterationCount (const sal_Int64 nNewCount)
+ { xEncryptionData->nIterationCount = nNewCount;}
+
+ ZipPackageStream (ZipPackage & rNewPackage);
virtual ~ZipPackageStream( void );
void setZipEntry( const com::sun::star::packages::ZipEntry &rInEntry);
@@ -109,5 +140,11 @@ public:
throw(::com::sun::star::uno::RuntimeException);
virtual sal_Int64 SAL_CALL getSomething( const ::com::sun::star::uno::Sequence< sal_Int8 >& aIdentifier )
throw(::com::sun::star::uno::RuntimeException);
+
+ // XPropertySet
+ virtual void SAL_CALL setPropertyValue( const ::rtl::OUString& aPropertyName, const ::com::sun::star::uno::Any& aValue )
+ throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::beans::PropertyVetoException, ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException);
+ virtual ::com::sun::star::uno::Any SAL_CALL getPropertyValue( const ::rtl::OUString& PropertyName )
+ throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException);
};
#endif