This is the top level project for the GlobalPlatform library for providing access to OpenPlatform 2.0.1' and GlobalPlatform 2.1.1 conforming smart cards and later, the command line shell GPShell using the GlobalPlatform library and the PC/SC connection plugin for the GlobalPlatform Library.
There are Homebrew packages for Linux and MacOS
Windows binaries can be downloaded from the GitHub release page or from SourceForge.
There are 2 versions of GPShell. The new GPShell 3+, using a concise, task-oriented command line, and the older GPShell 1+ using script files chaining multiple commands into one session.
Please read also the manual of GPShell3 or if used the manual of the manual of GPShell1.
A quick demo video showcasing the most useful features in action:
For GPShell1+ there are several script examples available. See the .txt files or look into the local file systems
under /usr/share/doc/gpshell2 or /usr/local/share/doc/gpshell2 or home/linuxbrew/.linuxbrew/share/doc/gpshell2/.
Clone the project from GitHub or download the zip file (also available under the Clone tab).
Consult the individual subprojects for further instructions and prerequisites. It is also possible to compile the sub projects individually.
Use a suitable packet manager for your OS or install the programs and libraries manually if applicable.
- Compiler Suite:
- Linux: Termed
build-essentialin Debian based distributions (gcc, make) - macOS: Xcode
- Windows: Visual Studio and SDK
- Linux: Termed
- CMake 3.10 or higher is needed
- PC/SC Lite (only for UNIXes, Windows and macOS are already including this)
- Doxygen for generating the documentation
- Graphviz for generating graphics in the documentation
- OpenSSL (Use OpenSSL 3)
- zlib (macOS should already bundle this, for Windows a pre-built version is included)
- cmocka for running the tests
- Pandoc for generating the man page the tests
Install the dependencies with brew or your distribution's package manager:
brew install openssl doxygen pandoc cmake cmocka zlib graphviz pcsc-liteUbuntu:
apt-get install libssl-dev doxygen cmake libcmocka0 zlib1g-dev graphviz pcscd libpcsclite-dev pkg-configNOTE: If using Homebrew in parallel and having not used Homebrew for installing the dependencies but the distribution's package manager then several tools and libraries can be hidden by Homebrew or are not installed in Homebrew (pkgconfig, PC/SC Lite, cmocka, ...). One option is to install these tools and libraries with brew or remove the Homebrew path from the PATH variable temporarily
(which should be ./home/linuxbrew/.linuxbrew/bin:/home/linuxbrew/.linuxbrew/sbin).
cd \path\to\globalplatform
cmake -B build -DCMAKE_BUILD_TYPE=Release.
cd build
make
make doc
make install
NOTE: The Homebrew version of pcsc-lite is not a fully functional version. It is missing the USB drivers and is also not started as a system service. The distribution's version of pcscd should be installed. Under Linux the Homebrew version of pcsc-lite must be unlinked:
brew remove --ignore-dependencies pcsc-lite
The compilation was executed on a system with Homebrew as a package manager.
Install the dependencies with brew:
brew install openssl@3 doxygen cmocka pandoc cmake graphviz
It is necessary to set the OPENSSL_ROOT_DIR. In the case regarding the usage of Homebrew, this works:
cd \path\to\globalplatform
cmake -B build -DCMAKE_BUILD_TYPE=Release -DCMAKE_C_COMPILER=/usr/bin/gcc -DOPENSSL_ROOT_DIR=$(brew --prefix openssl@3) .
cd build
make
make installNOTE: CMAKE_C_COMPILER is required if Xcode is installed. CMake would favor the Xcode compiler, leading to potential runtime errors.
Install the dependencies with Chocolatey in an administrator's PowerShell or install the dependencies manually:
choco install cmake doxygen.install graphviz- For CMocka a pre-built version is used from the
cmock-cmocka-1.1.5directory. - For
zliba pre-built version is used thezlib-1.2.8directory. - OpenSSL must be installed manually. Chocolatey is using the systems architecture, which is nowadays 64 bit, but the compilation needs the 32 bit version. Download OpenSSL and choose the Win32 bit version and no light version.
Launch Visual Studio Command Prompt / Developer Command Prompt / Developer PowerShell.
It will be necessary to set the ZLIB_ROOT and CMOCKA_ROOT and OPENSSL_ROOT_DIR. Use the pre-built versions of the project for convenience.
cd \path\to\globalplatform
cmake -G "NMake Makefiles" -DCMAKE_BUILD_TYPE=Release -DOPENSSL_ROOT_DIR="C:\Program Files (x86)\OpenSSL-Win32" -DZLIB_ROOT="C:\Users\john\Desktop\globalplatform\zlib-1.2.8\win32-build" -DCMOCKA_ROOT="C:\Users\john\Desktop\globalplatform\cmocka-cmocka-1.1.5\build-w32"
nmakeNOTE: Read also the Windows-specific part in the GlobalPlatform subproject.
Execute:
make/nmake doc
Execute:
make/nmake package
Execute:
make/nmake package_source
To be able to debug the library, enable the debug symbols:
cmake -B build .
To generate the tests, execute:
cmake -B build -DTESTING=ON -DINTEGRATION_TESTING=ON .
cd build
make
make test-unit
# with a recent JCOP test card with default keys
export OPGP_PLUGIN_PATH=$(pwd)/gppcscconnectionplugin/src
make test-integrationNOTE: On Windows: When using the Visual Studio command line, the necessary mock functions are not supported by the linker and tests cannot be executed.
The variable GLOBALPLATFORM_DEBUG=1 in the environment must be set. The logfile can be set with GLOBALPLATFORM_LOGFILE=<file>.
Under Windows by default C:\Temp\GlobalPlatform.log is chosen, under Unix systems if syslog is available it will be used by default.
The default log file under Unix systems is /tmp/GlobalPlatform.log if syslog is not available.
cpack is used for packaging.
If only GPShell is in focus, a static build is recommended:
cmake -B build -DCMAKE_BUILD_TYPE=Release -DSTATIC=ONFor the packaging process run inside the build directory after the build:
cpack- On Linux, cpack creates both DEB and RPM. You need dpkg-deb and rpmbuild installed.
- Windows MSI (WIX) is generated on Windows with WiX installed.
- macOS DragNDrop is generated on macOS.
The GitHub documentation is located under the docs folder and is using Jekyll.
Installation:
cd docs
gem uninstall jekyll
# select all
gem install jekyll -v 3.9.0
gem uninstall bundler
gem install bundler
bundle
bundle update github-pagesUseful commands inside the docs folder:
- Cleaning local generated site:
bundle exec jekyll clean - Serving site in a local browser updating automatically on content changes:
bundle exec jekyll serve - Update configuration in the Gemfile:
bundle update
For issues please use the GitHub issue tracker.
You can also use the Mailing List or ask a question on Stack Overflow assigning the tags gpshell or globalplatform.
