Search code examples
gnupgopenpgpgpgme

Check if config file was set successfully for GnuPG in GPGME


For specifying the preferenced order of encryption algorithms in GPG I use

gpgme_set_engine_info(GPGME_PROTOCOL_OpenPGP, NULL, CONFIG_DIR);

to set a custom config file. However how can I check if this operation was successful? home_dir is set to the given value, but this also happens if I pass a directory without a config file. I can't see any function or call in the documentation to evaluate if the config file was loaded OR what the current preference order is.


Solution

  • The function returns an error value if a problem occured. From the documentation:

    This function returns the error code GPG_ERR_NO_ERROR if successful, or an eror code on failure.

    You observed unexpected behavior with setting a home directory without a configuration file:

    home_dir is set to the given value, but this also happens if I pass a directory without a config file.

    This is expected behavior in GnuPG. An empty configuration file is not an error, but simply means no other configuration but the defaults is in place. Similar things happen if you pass --homedir to GnuPG with a reference to an empty folder: GnuPG will try to initialize this folder as a home directory, but print an information message:

    $ LANG=C gpg --homedir /tmp
    gpg: keyring `/tmp/secring.gpg' created
    gpg: keyring `/tmp/pubring.gpg' created
    gpg: Go ahead and type your message ...
    

    If you want to verify the folder is already set up, I'd propose to verify some options you'd expect, or test for a configuration file (or whatever you expect to be available) on your own.