gpgme/lang/js
raimund.renkert@intevation.de eef3a509fa
js: Initial commit for JavaScript Native Messaging API
--

Note this code misses all the legal boilerplate; please add this as
soon as possible and provide a DCO so we can merge it into master.

I also removed the dist/ directory because that was not source code.
2018-04-10 18:47:59 +02:00
..
src js: Initial commit for JavaScript Native Messaging API 2018-04-10 18:47:59 +02:00
CHECKLIST js: Initial commit for JavaScript Native Messaging API 2018-04-10 18:47:59 +02:00
CHECKLIST_build js: Initial commit for JavaScript Native Messaging API 2018-04-10 18:47:59 +02:00
manifest.json js: Initial commit for JavaScript Native Messaging API 2018-04-10 18:47:59 +02:00
package.json js: Initial commit for JavaScript Native Messaging API 2018-04-10 18:47:59 +02:00
README js: Initial commit for JavaScript Native Messaging API 2018-04-10 18:47:59 +02:00
testapplication.js js: Initial commit for JavaScript Native Messaging API 2018-04-10 18:47:59 +02:00
testicon.png js: Initial commit for JavaScript Native Messaging API 2018-04-10 18:47:59 +02:00
ui.css js: Initial commit for JavaScript Native Messaging API 2018-04-10 18:47:59 +02:00
ui.html js: Initial commit for JavaScript Native Messaging API 2018-04-10 18:47:59 +02:00
webpack.conf.js js: Initial commit for JavaScript Native Messaging API 2018-04-10 18:47:59 +02:00

This is an example app for gpgme-json.
As of now, it only encrypts a given text.

Installation
-------------

gpgmejs uses webpack, the builds can be found in dist/
(the testapplication uses that script at that location). To create a new
package, the command is npx webpack --config webpack.conf.js.
If you want a more debuggable (i.e. not minified) build, just change the mode
in webpack.conf.js.

Demo WebExtension:
As soon as a bundled webpack is in dist/ (TODO: .gitignore or not?),
the gpgmejs folder can just be included in the extensions tab of the browser in
questions (extension debug mode needs to be active). For chrome, selecting the
folder is sufficient, for firefox, the manifest.json needs to be selected.

In the browsers' nativeMessaging configuration folder a file 'gpgmejs.json'
is needed, with the following content:

(The path to the native app gpgme-json may need adaption)

Chromium:
~/.config/chromium/NativeMessagingHosts/gpgmejson.json

{
  "name": "gpgmejson",
  "description": "This is a test application for gpgmejs",
  "path": "/usr/bin/gpgme-json",
  "type": "stdio",
  "allowed_origins": ["chrome-extension://ExtensionIdentifier/"]
}
The ExtensionIdentifier can be seen on the chrome://extensions page, and
changes on each reinstallation. Note the slashes in allowed_origins.


Firefox:
~/.mozilla/native-messaging-hosts/gpgmejson.json
{
  "name": "gpgmejson",
  "description": "This is a test application for gpgmejs",
  "path": "/usr/bin/gpgme-json",
  "type": "stdio",
  "allowed_extensions": ["ExtensionIdentifier@temporary-addon"]
}
The ExtensionIdentifier can be seen as Extension ID on the about:addons page if
addon-debugging is active. In firefox, the temporary addon is removed once
firefox exits, and the identifier will need to be changed more often.

For testing purposes, it could be a good idea to change the keyID in the
ui.html, to not having to type it every time.