(no commit message)
authorWerner Koch <wk@gnupg.org>
Wed, 3 Aug 2005 10:43:31 +0000 (10:43 +0000)
committerWerner Koch <wk@gnupg.org>
Wed, 3 Aug 2005 10:43:31 +0000 (10:43 +0000)
ChangeLog [new file with mode: 0644]
NEWS [new file with mode: 0644]
README
TODO [new file with mode: 0644]
autogen.sh [new file with mode: 0755]

diff --git a/ChangeLog b/ChangeLog
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/NEWS b/NEWS
new file mode 100644 (file)
index 0000000..1e9b2b4
--- /dev/null
+++ b/NEWS
@@ -0,0 +1,100 @@
+Noteworthy changes for version 0.6.1 (unreleased)\r
+=================================================\r
+\r
+* Fix the problem that the user can just reply with\r
+  the encrypted text.\r
+\r
+* Fixes for a lot of minor problems with NT5 based\r
+  systems and for Outlook version 2003.\r
+\r
+* Support for handling HTML mails.\r
+  This includes the encryption of the contents and\r
+  the proper decryption without losing the special\r
+  (html) text attributes like colors.\r
+\r
+* Support for '%ENV%' strings for the log file.\r
+\r
+\r
+Noteworthy changes for version 0.5.5 (2005-07-12)\r
+=================================================\r
+\r
+* Support to sign all outgoing attachments.\r
+\r
+* Support for logging.\r
+\r
+* Fixed some memory leaks.\r
+\r
+\r
+Noteworthy changes for version 0.5.4 (2005-07-03)\r
+=================================================\r
+\r
+* Support for securing attachments.\r
+  This means the all attachments will be encrypted\r
+  if encryption has been selected for the message.\r
+\r
+* A new option to allow to save decrypted attachments\r
+  to the disk.\r
+\r
+* Several bug fixes all over the place.\r
+\r
+\r
+Noteworthy changes for version 0.5.3 (2005-06-16)\r
+=================================================\r
+\r
+* Allow to set a default key which is used automatically\r
+  for encryption.\r
+\r
+* Handle old V3 keys in the signature verification dialog.\r
+\r
+* Issue and error if the encrypt process returned invalid\r
+  recipients.\r
+\r
+\r
+Noteworthy changes for version 0.5.2 (2005-06-05)\r
+=================================================\r
+\r
+* Differ between possible decryption failures.\r
+  - General errors.\r
+  - No secret key available.\r
+\r
+* Add a 'encrypt-to' listbox to the decryption dialog\r
+  to know the recipients the message was encrypted for.\r
+\r
+* Add some checks to report problems with permissions\r
+  related to the Registry.\r
+\r
+* Fixed a format string problem which was possible for\r
+  crashes when the signature has been expired.\r
+\r
+Noteworthy changes for version 0.5.1 (2005-05-29)\r
+=================================================\r
+\r
+* Issue a warning if the user cancels the sign or\r
+  encryption procedure.\r
+\r
+* Support to read and write X- headers for messages.\r
+\r
+* Fixed a problem which crashes Outlook if the keyManager\r
+  exe did not exist but was set in the registry.\r
+\r
+\r
+Noteworthy changes for version 0.4.0 (2005-05-10)\r
+=================================================\r
+\r
+* Verify dialog is automatically shown whenever needed. Plus it\r
+  contains a hint-label whenever the signature is special. For\r
+  example the signature has expire or it was issued by a key which\r
+  is not trustworthy.\r
+\r
+* Offer a GPG configuration dialog to set the path to GPG, the home\r
+  directory and an optional field to specify a key manager.\r
+\r
+* Common dialogs for the following procedures:\r
+  - verify a clearsign signature\r
+  - decrypt a message (and verify a signature)\r
+  - encrypt a message (and sign the plaintext)\r
+  - clearsign a message\r
+\r
+* Provide a class to encapsulate MAPI messages and high-level functions\r
+  for all crypto operations.\r
+  \r
diff --git a/README b/README
index 513c5b0..5782af7 100644 (file)
--- a/README
+++ b/README
@@ -10,6 +10,7 @@ thus we started to rewrite it from scratch.
 
 src/       The actual code of this plugin.
 
+
 olflange/  Code to build "gpgolfla.dll".  This DLL used to connect the
            actual plugin to Outlook.  This is expected not to change
            too often.  Special tools (read: a native MS Windows
diff --git a/TODO b/TODO
new file mode 100644 (file)
index 0000000..fd8a1d4
--- /dev/null
+++ b/TODO
@@ -0,0 +1,23 @@
+* Show more details in case of some errors.\r
+  For example 'No Secret Key' should contain the key-ID\r
+  and if possible the primary user-ID.\r
+\r
+* much better HTML support.\r
+\r
+* factor out more common code in encrypt, signEncrypt.\r
+\r
+* grep all XXX in the code and provide fixes.\r
+\r
+* provide a general passphrase caching system to allow to store\r
+  more than one passphrase. This can be done with a hash table and\r
+  the key-ID is used as the index to access the passphrase.\r
+\r
+* handle unicode messages and find out why UTF-8 messages cannot be\r
+  manipulated.\r
+\r
+* find out why sometimes the new body cannot set to a MAPI object. In\r
+  this case the body is empty but the W32 API said it was correctly set.\r
+\r
+* implement a static shared section inside the DLL to provide the key cache\r
+  objects. right now we load all keys on demand.\r
+\r
diff --git a/autogen.sh b/autogen.sh
new file mode 100755 (executable)
index 0000000..5591d15
--- /dev/null
@@ -0,0 +1,149 @@
+#! /bin/sh
+# Run this to generate all the initial makefiles, etc. 
+#
+# Copyright (C) 2003 g10 Code GmbH
+#
+# This file is free software; as a special exception the author gives
+# unlimited permission to copy and/or distribute it, with or without
+# modifications, as long as this notice is preserved.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY, to the extent permitted by law; without even the
+# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+
+configure_ac="configure.ac"
+
+cvtver () {
+  awk 'NR==1 {split($NF,A,".");X=1000000*A[1]+1000*A[2]+A[3];print X;exit 0}'
+}
+
+check_version () {
+    if [ `("$1" --version || echo "0") | cvtver` -ge "$2" ]; then
+       return 0
+    fi
+    echo "**Error**: "\`$1\'" not installed or too old." >&2
+    echo '           Version '$3' or newer is required.' >&2
+    [ -n "$4" ] && echo '           Note that this is part of '\`$4\''.' >&2
+    DIE="yes"
+    return 1
+}
+
+# Allow to override the default tool names
+AUTOCONF=${AUTOCONF_PREFIX}${AUTOCONF:-autoconf}${AUTOCONF_SUFFIX}
+AUTOHEADER=${AUTOCONF_PREFIX}${AUTOHEADER:-autoheader}${AUTOCONF_SUFFIX}
+
+AUTOMAKE=${AUTOMAKE_PREFIX}${AUTOMAKE:-automake}${AUTOMAKE_SUFFIX}
+ACLOCAL=${AUTOMAKE_PREFIX}${ACLOCAL:-aclocal}${AUTOMAKE_SUFFIX}
+
+DIE=no
+
+# ***** W32 build script *******
+# Used to cross-compile for Windows.
+if test "$1" = "--build-w32"; then
+    tmp=`dirname $0`
+    tsdir=`cd "$tmp"; pwd`
+    shift
+    if [ ! -f $tsdir/config.guess ]; then
+        echo "$tsdir/config.guess not found" >&2
+        exit 1
+    fi
+    build=`$tsdir/config.guess`
+
+    [ -z "$w32root" ] && w32root="$HOME/w32root"
+    echo "Using $w32root as standard install directory" >&2
+    
+    # See whether we have the Debian cross compiler package or the
+    # old mingw32/cpd system
+    if i586-mingw32msvc-gcc --version >/dev/null 2>&1 ; then
+        host=i586-mingw32msvc
+        crossbindir=/usr/$host/bin
+    else
+       host=i386--mingw32
+       if ! mingw32 --version >/dev/null; then
+          echo "We need at least version 0.3 of MingW32/CPD" >&2
+          exit 1
+       fi
+       crossbindir=`mingw32 --install-dir`/bin
+       # Old autoconf version required us to setup the environment
+       # with the proper tool names.
+       CC=`mingw32 --get-path gcc`
+       CPP=`mingw32 --get-path cpp`
+       AR=`mingw32 --get-path ar`
+       RANLIB=`mingw32 --get-path ranlib`
+       export CC CPP AR RANLIB 
+    fi
+   
+    if [ -f "$tsdir/config.log" ]; then
+        if ! head $tsdir/config.log | grep "$host" >/dev/null; then
+            echo "Pease run a 'make distclean' first" >&2
+            exit 1
+        fi
+    fi
+
+    ./configure --enable-maintainer-mode --prefix=${w32root}  \
+             --host=i586-mingw32msvc --build=${build} \
+             --with-gpg-error-prefix=${w32root} \
+            --with-ksba-prefix=${w32root} \
+            --with-libgcrypt-prefix=${w32root} \
+            --with-libassuan-prefix=${w32root} \
+            --with-zlib=${w32root} \
+             --with-pth-prefix=${w32root} \
+             --disable-gpg
+    rc=$?
+
+    exit $rc
+fi
+# ***** end W32 build script *******
+
+
+
+
+# Grep the required versions from configure.ac
+autoconf_vers=`sed -n '/^AC_PREREQ(/ { 
+s/^.*(\(.*\))/\1/p
+q
+}' ${configure_ac}`
+autoconf_vers_num=`echo "$autoconf_vers" | cvtver`
+
+automake_vers=`sed -n '/^min_automake_version=/ { 
+s/^.*="\(.*\)"/\1/p
+q
+}' ${configure_ac}`
+automake_vers_num=`echo "$automake_vers" | cvtver`
+
+
+if [ -z "$autoconf_vers" -o -z "$automake_vers" ]
+then
+  echo "**Error**: version information not found in "\`${configure_ac}\'"." >&2
+  exit 1
+fi
+
+
+if check_version $AUTOCONF $autoconf_vers_num $autoconf_vers ; then
+    check_version $AUTOHEADER $autoconf_vers_num $autoconf_vers autoconf
+fi
+if check_version $AUTOMAKE $automake_vers_num $automake_vers; then
+  check_version $ACLOCAL $automake_vers_num $autoconf_vers automake
+fi
+
+if test "$DIE" = "yes"; then
+    cat <<EOF
+
+Note that you may use alternative versions of the tools by setting 
+the corresponding environment variables; see README.CVS for details.
+                   
+EOF
+    exit 1
+fi
+
+
+echo "Running aclocal ${ACLOCAL_FLAGS:+$ACLOCAL_FLAGS }..."
+$ACLOCAL $ACLOCAL_FLAGS
+echo "Running autoheader..."
+$AUTOHEADER
+echo "Running automake --gnu ..."
+$AUTOMAKE --gnu;
+echo "Running autoconf..."
+$AUTOCONF
+
+echo "You may now run \"./configure --enable-maintainer-mode && make\"."