Size: 2863
Comment: added python-gnupg
|
Size: 3829
Comment: New maintainer. New license.
|
Deletions are marked like this. | Additions are marked like this. |
Line 4: | Line 4: |
Here is the [[https://www.gnupg.org/documentation/manuals/gpgme/|online version of the manual (maybe out of date)]]. | Here is the [[https://www.gnupg.org/documentation/manuals/gpgme/|online version of the manual]]. |
Line 14: | Line 14: |
== C++ wrappers == | === GPGME bindings |
Line 16: | Line 16: |
A number of language bindings are maintained within the ~G~PGME repository. If possible, try to use these bindings. * C++: Based upon the code previously maintained by KDE. * Qt: Based upon the code previously maintained by KDE. * Python: Based upon the 'pyme' bindings, should be backwards compatible. * Common Lisp === Third-party GPGME bindings ==== C++ wrappers == |
|
Line 19: | Line 29: |
== C# (c-sharp) wrappers | ==== C# (c-sharp) wrappers * [[https://github.com/wget/gpgme-sharp|gpgme-sharp]] originally developed by Daniel Mueller in 2009 under LGPL, now under MIT and maintainership taken over by William Gathoye with the intention of being integrated to [[https://github.com/chocolatey/choco|Chocolatey]], the package manager for Windows. The code quality was considered "experimental" and made for 32bits for Windows, but [[https://stackoverflow.com/questions/4156819/using-the-gpgme-library-from-net|some reported success]]. |
Line 21: | Line 34: |
* [[http://danm.de/index.php?action=source|gpgme-sharp]] in alpha for 32bit windows (as of 2014-09). == Java wrappers == |
==== Java wrappers == |
Line 27: | Line 38: |
* [[https://github.com/guardianproject/gnupg-for-android|Gnu Privacy Guard]] is an Android app based [[https://github.com/guardianproject/gnupg-for-java|GnuPG-for-Java]] and gpgme to provide a GnuPG engine in Android | * [[https://github.com/guardianproject/gnupg-for-android|Gnu Privacy Guard]] is an Android app based [[https://github.com/guardianproject/gnupg-for-java|GnuPG-for-Java]] and uses gpgme to provide a GnuPG engine in Android |
Line 32: | Line 43: |
== Python wrappers == | ==== Python wrappers == |
Line 35: | Line 46: |
* [[http://git.gnupg.org/cgi-bin/gitweb.cgi?p=gpgme.git;a=shortlog;h=refs/heads/pyme|pyme for python3]] ~SWIG generated wrapper for python3, port of pyme 0.9 (see gnupg-devel mailinglist 2015-05 and newer) * https://launchpad.net/pygpgme manually written wrapper in C |
* [[https://git.gnupg.org/cgi-bin/gitweb.cgi?p=gpgme.git;a=tree;f=lang/python;hb=refs/heads/master|pyme for python3]] ~SWIG generated wrapper for python3, port of pyme 0.9, included in G~P~GME v>=1.7. * https://launchpad.net/pygpgme manually written wrapper in C for python2 and python3. GNU ~LGPL v?=2. Packaged for Debian and Ubuntu. |
Line 38: | Line 49: |
== Ruby wrappers == | ==== Ruby wrappers == |
Line 49: | Line 60: |
== C# (c-sharp) * [[https://github.com/WilliamDunne/SharpGPG|SharpGPG]] a GPG wrapper for C# using GPGAPI. |
|
Line 50: | Line 64: |
Line 53: | Line 66: |
== Python * https://bitbucket.org/vinay.sajip/python-gnupg using the subprocess module to call the gpg executables (not using the recommended gpgme for python alternatives, see above). Xorg Style license. |
== Python * [[https://pypi.python.org/pypi/python-gnupg|python-gnupg]] using the subprocess module to call the gpg executables (not using the recommended gpgme for python alternatives, see above). Xorg Style license. |
GPGME - an API to GnuPG
The recommended way to use the GnuPG crypto stack from your application is GPGME, which is written in C. Here is the online version of the manual.
A number of GPGME bindings for other programming languages/environments exist (Please point us to missing entries or corrections or add them directly in the wiki.):
All / C
- gpgme (GPG Made Easy) is the official GnuPG API. It is implemented in C itself, but this is what you should use from your language as well.
GPGME bindings
A number of language bindings are maintained within the GPGME repository. If possible, try to use these bindings.
- C++: Based upon the code previously maintained by KDE.
- Qt: Based upon the code previously maintained by KDE.
- Python: Based upon the 'pyme' bindings, should be backwards compatible.
- Common Lisp
Third-party GPGME bindings
C++ wrappers
- http://quickgit.kde.org/?p=kdepimlibs.git gpgme++ is a wrapper for gpgme in kdepimlibs
C# (c-sharp) wrappers
- gpgme-sharp originally developed by Daniel Mueller in 2009 under LGPL, now under MIT and maintainership taken over by William Gathoye with the intention of being integrated to Chocolatey, the package manager for Windows. The code quality was considered "experimental" and made for 32bits for Windows, but some reported success.
Java wrappers
- GnuPG-for-Java is a Java wrapper for gpgme >=1.5 and GnuPG >=2.x
- GnuPG-for-Java is a Java wrapper for gpgme and GnuPG 1.x
- Gnu Privacy Guard is an Android app based GnuPG-for-Java and uses gpgme to provide a GnuPG engine in Android
Python wrappers
- pyme SWIG generated wrapper for python2 (continuation of the old version)
- pyme for python3 SWIG generated wrapper for python3, port of pyme 0.9, included in GPGME v>=1.7.
- https://launchpad.net/pygpgme manually written wrapper in C for python2 and python3. GNU LGPL v?=2. Packaged for Debian and Ubuntu.
Ruby wrappers
- ruby-gpgme is a ruby wrapper, which can be installed with: gem install gpgme.
(not recommended) calling executables directly
A number of elder applications call GnuPG executables in a subprocess and interact with them via command line arguments and file-descriptors. This is less perferable to GPGME, because the command line arguments and text outputs are not an (official) API to GnuPG. While there is an effort made to keep them stable, using the official GPGME API can manage this more precisely and thus you end up with a more robust solution.
C# (c-sharp)
Objective-C
- Libmacgpg is a Mac OS X Framework built on top of GnuPG (but not gpgme), used as part of the GPGTools suite.
Python
- python-gnupg using the subprocess module to call the gpg executables (not using the recommended gpgme for python alternatives, see above). Xorg Style license.