2010-07-16 20:13:12 +00:00
|
|
|
/*
|
2017-12-15 15:16:48 +01:00
|
|
|
* Copyright (C) 2017 Schürmann & Breitmoser GbR
|
2010-07-16 20:13:12 +00:00
|
|
|
*
|
2014-04-08 11:37:38 +02:00
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
|
* (at your option) any later version.
|
2010-07-16 20:13:12 +00:00
|
|
|
*
|
2014-04-08 11:37:38 +02:00
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU General Public License for more details.
|
2010-07-16 20:13:12 +00:00
|
|
|
*
|
2014-04-08 11:37:38 +02:00
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2010-07-16 20:13:12 +00:00
|
|
|
*/
|
|
|
|
|
|
2013-01-16 14:31:16 +01:00
|
|
|
package org.sufficientlysecure.keychain;
|
2010-07-16 20:13:12 +00:00
|
|
|
|
2018-10-22 12:49:52 +02:00
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
|
import java.net.Proxy;
|
|
|
|
|
|
2022-12-22 14:47:04 +01:00
|
|
|
import android.app.PendingIntent;
|
|
|
|
|
import android.os.Build;
|
2010-07-16 20:13:12 +00:00
|
|
|
import android.os.Environment;
|
|
|
|
|
|
2017-01-05 13:40:40 +01:00
|
|
|
import org.bouncycastle.bcpg.sig.KeyFlags;
|
2016-02-09 00:24:46 +01:00
|
|
|
import org.bouncycastle.jce.provider.BouncyCastleProvider;
|
2017-01-05 13:40:40 +01:00
|
|
|
import org.sufficientlysecure.keychain.securitytoken.KeyFormat;
|
2021-03-16 17:07:56 +01:00
|
|
|
import org.sufficientlysecure.keychain.securitytoken.RsaKeyFormat;
|
2017-01-05 13:40:40 +01:00
|
|
|
import org.sufficientlysecure.keychain.service.SaveKeyringParcel;
|
2017-05-22 13:44:58 +02:00
|
|
|
import org.sufficientlysecure.keychain.service.SaveKeyringParcel.SubkeyAdd;
|
2014-03-13 21:39:14 +02:00
|
|
|
|
2014-06-22 16:31:28 +02:00
|
|
|
|
2010-07-16 20:13:12 +00:00
|
|
|
public final class Constants {
|
2012-03-09 16:27:29 +01:00
|
|
|
|
2013-09-09 14:03:58 +02:00
|
|
|
public static final boolean DEBUG = BuildConfig.DEBUG;
|
2015-08-19 01:13:12 +05:30
|
|
|
public static final boolean DEBUG_KEYSERVER_SYNC = false;
|
2012-11-16 02:34:21 +01:00
|
|
|
|
2018-07-04 22:09:52 +02:00
|
|
|
public static final boolean IS_RUNNING_UNITTEST = isRunningUnitTest();
|
|
|
|
|
|
2015-06-10 19:47:29 +02:00
|
|
|
public static final String TAG = DEBUG ? "Keychain D" : "Keychain";
|
2012-06-20 15:55:36 +03:00
|
|
|
|
2013-01-16 14:31:16 +01:00
|
|
|
public static final String PACKAGE_NAME = "org.sufficientlysecure.keychain";
|
2013-01-08 12:58:21 +01:00
|
|
|
|
2015-07-30 04:39:38 +05:30
|
|
|
public static final String PROVIDER_AUTHORITY = BuildConfig.PROVIDER_CONTENT_AUTHORITY;
|
2015-10-15 20:11:58 +02:00
|
|
|
public static final String TEMP_FILE_PROVIDER_AUTHORITY = BuildConfig.APPLICATION_ID + ".tempstorage";
|
2015-06-10 19:47:29 +02:00
|
|
|
|
2015-07-05 21:49:02 +02:00
|
|
|
public static final String CLIPBOARD_LABEL = "Keychain";
|
|
|
|
|
|
2015-03-15 21:17:24 +01:00
|
|
|
// as defined in http://tools.ietf.org/html/rfc3156
|
2015-10-15 19:56:04 +02:00
|
|
|
public static final String MIME_TYPE_KEYS = "application/pgp-keys";
|
|
|
|
|
// NOTE: Non-standard alternative, better use this, because application/octet-stream is too unspecific!
|
|
|
|
|
// also see https://tools.ietf.org/html/draft-bray-pgp-message-00
|
|
|
|
|
public static final String MIME_TYPE_ENCRYPTED_ALTERNATE = "application/pgp-message";
|
|
|
|
|
public static final String MIME_TYPE_TEXT = "text/plain";
|
2015-03-15 21:17:24 +01:00
|
|
|
|
2015-10-15 17:26:51 +02:00
|
|
|
public static final String FILE_EXTENSION_PGP_MAIN = ".pgp";
|
2015-03-17 13:22:13 +01:00
|
|
|
public static final String FILE_EXTENSION_ASC = ".asc";
|
|
|
|
|
|
2015-10-15 21:56:23 +02:00
|
|
|
public static final String FILE_BACKUP_PREFIX = "backup_";
|
|
|
|
|
public static final String FILE_EXTENSION_BACKUP_SECRET = ".sec.asc";
|
|
|
|
|
public static final String FILE_EXTENSION_BACKUP_PUBLIC = ".pub.asc";
|
|
|
|
|
public static final String FILE_ENCRYPTED_BACKUP_PREFIX = "backup_";
|
2015-10-15 23:40:35 +02:00
|
|
|
// actually it is ASCII Armor, so .asc would be more accurate, but Android displays a nice icon for .pgp files!
|
|
|
|
|
public static final String FILE_EXTENSION_ENCRYPTED_BACKUP_SECRET = ".sec.pgp";
|
|
|
|
|
public static final String FILE_EXTENSION_ENCRYPTED_BACKUP_PUBLIC = ".pub.pgp";
|
2015-10-15 21:56:23 +02:00
|
|
|
|
2017-01-14 11:38:05 +01:00
|
|
|
// used by QR Codes (Guardian Project, Monkeysphere compatibility)
|
2014-02-01 16:34:42 +01:00
|
|
|
public static final String FINGERPRINT_SCHEME = "openpgp4fpr";
|
|
|
|
|
|
2016-02-09 00:34:16 +01:00
|
|
|
public static final String BOUNCY_CASTLE_PROVIDER_NAME = BouncyCastleProvider.PROVIDER_NAME;
|
2013-09-15 16:42:08 +02:00
|
|
|
|
2014-09-07 18:26:43 +02:00
|
|
|
// prefix packagename for exported Intents
|
|
|
|
|
// as described in http://developer.android.com/guide/components/intents-filters.html
|
2013-01-16 14:31:16 +01:00
|
|
|
public static final String INTENT_PREFIX = PACKAGE_NAME + ".action.";
|
2014-09-07 18:26:43 +02:00
|
|
|
public static final String EXTRA_PREFIX = PACKAGE_NAME + ".";
|
2012-06-20 15:27:45 +03:00
|
|
|
|
2014-09-04 12:54:16 +02:00
|
|
|
public static final int TEMPFILE_TTL = 24 * 60 * 60 * 1000; // 1 day
|
|
|
|
|
|
2015-10-21 21:54:39 +02:00
|
|
|
// the maximal length of plaintext to read in encrypt/decrypt text activities
|
|
|
|
|
public static final int TEXT_LENGTH_LIMIT = 1024 * 50;
|
|
|
|
|
|
2017-02-07 21:17:15 +01:00
|
|
|
// Intents API
|
|
|
|
|
public static final String ENCRYPT_TEXT = INTENT_PREFIX + "ENCRYPT_TEXT";
|
|
|
|
|
public static final String ENCRYPT_EXTRA_TEXT = EXTRA_PREFIX + "EXTRA_TEXT"; // String
|
|
|
|
|
public static final String ENCRYPT_DATA = INTENT_PREFIX + "ENCRYPT_DATA";
|
|
|
|
|
public static final String ENCRYPT_EXTRA_ASCII_ARMOR = EXTRA_PREFIX + "EXTRA_ASCII_ARMOR"; // boolean
|
|
|
|
|
public static final String DECRYPT_DATA = INTENT_PREFIX + "DECRYPT_DATA";
|
|
|
|
|
public static final String IMPORT_KEY = INTENT_PREFIX + "IMPORT_KEY";
|
|
|
|
|
public static final String IMPORT_EXTRA_KEY_EXTRA_KEY_BYTES = EXTRA_PREFIX + "EXTRA_KEY_BYTES"; // byte[]
|
|
|
|
|
public static final String IMPORT_KEY_FROM_KEYSERVER = INTENT_PREFIX + "IMPORT_KEY_FROM_KEYSERVER";
|
|
|
|
|
public static final String IMPORT_KEY_FROM_KEYSERVER_EXTRA_QUERY = EXTRA_PREFIX + "EXTRA_QUERY"; // String
|
|
|
|
|
public static final String IMPORT_KEY_FROM_KEYSERVER_EXTRA_FINGERPRINT = EXTRA_PREFIX + "EXTRA_FINGERPRINT"; // String
|
|
|
|
|
public static final String IMPORT_KEY_FROM_QR_CODE = INTENT_PREFIX + "IMPORT_KEY_FROM_QR_CODE";
|
|
|
|
|
|
2014-03-13 21:39:14 +02:00
|
|
|
public static final class Path {
|
2014-06-22 16:31:28 +02:00
|
|
|
public static final File APP_DIR = new File(Environment.getExternalStorageDirectory(), "OpenKeychain");
|
2010-07-16 20:13:12 +00:00
|
|
|
}
|
|
|
|
|
|
2022-12-22 14:47:04 +01:00
|
|
|
public static final int FLAG_IMMUTABLE_COMPAT =
|
|
|
|
|
Build.VERSION.SDK_INT >= Build.VERSION_CODES.M ? PendingIntent.FLAG_IMMUTABLE : 0;
|
|
|
|
|
|
2018-06-13 18:20:41 +02:00
|
|
|
public static final class NotificationIds {
|
2015-07-27 14:10:26 +05:30
|
|
|
public static final int PASSPHRASE_CACHE = 1;
|
|
|
|
|
public static final int KEYSERVER_SYNC_FAIL_ORBOT = 2;
|
2018-06-13 18:20:41 +02:00
|
|
|
public static final int KEYSERVER_SYNC = 3;
|
|
|
|
|
}
|
|
|
|
|
|
2014-03-13 21:39:14 +02:00
|
|
|
public static final class Pref {
|
2014-09-23 15:56:48 +02:00
|
|
|
public static final String PASSPHRASE_CACHE_SUBS = "passphraseCacheSubs";
|
2017-09-20 17:01:49 +02:00
|
|
|
public static final String PASSPHRASE_CACHE_LAST_TTL = "passphraseCacheLastTtl";
|
2012-03-09 18:43:10 +01:00
|
|
|
public static final String LANGUAGE = "language";
|
|
|
|
|
public static final String KEY_SERVERS = "keyServers";
|
2016-10-27 17:01:22 +02:00
|
|
|
public static final String PREF_VERSION = "keyServersDefaultVersion";
|
2017-11-28 14:46:22 +01:00
|
|
|
// false if first time wizard has been finished
|
|
|
|
|
public static final String FIRST_TIME_WIZARD = "firstTime";
|
|
|
|
|
// false if app has been started at least once (also from background etc)
|
|
|
|
|
public static final String FIRST_TIME_APP = "firstTimeApp";
|
2014-08-19 15:45:42 +02:00
|
|
|
public static final String CACHED_CONSOLIDATE = "cachedConsolidate";
|
2014-09-12 08:34:51 -07:00
|
|
|
public static final String SEARCH_KEYSERVER = "search_keyserver_pref";
|
2018-05-22 21:46:31 +02:00
|
|
|
public static final String SEARCH_WEB_KEY_DIRECTORY = "search_wkd_pref";
|
2016-01-10 17:17:57 +01:00
|
|
|
public static final String USE_NUMKEYPAD_FOR_SECURITY_TOKEN_PIN = "useNumKeypadForYubikeyPin";
|
2015-05-31 04:05:15 +02:00
|
|
|
public static final String ENCRYPT_FILENAMES = "encryptFilenames";
|
2015-06-03 01:21:06 +02:00
|
|
|
public static final String FILE_USE_COMPRESSION = "useFileCompression";
|
2018-03-05 13:54:31 +01:00
|
|
|
public static final String FILE_SELF_ENCRYPT = "fileSelfEncrypt";
|
2015-06-03 01:21:06 +02:00
|
|
|
public static final String TEXT_USE_COMPRESSION = "useTextCompression";
|
2018-03-05 14:02:48 +01:00
|
|
|
public static final String TEXT_SELF_ENCRYPT = "textSelfEncrypt";
|
2015-05-31 04:05:15 +02:00
|
|
|
public static final String USE_ARMOR = "useArmor";
|
2015-06-05 05:39:12 +05:30
|
|
|
// proxy settings
|
|
|
|
|
public static final String USE_NORMAL_PROXY = "useNormalProxy";
|
|
|
|
|
public static final String USE_TOR_PROXY = "useTorProxy";
|
|
|
|
|
public static final String PROXY_HOST = "proxyHost";
|
|
|
|
|
public static final String PROXY_PORT = "proxyPort";
|
2015-06-06 15:26:22 +05:30
|
|
|
public static final String PROXY_TYPE = "proxyType";
|
2015-06-25 15:17:32 +02:00
|
|
|
public static final String THEME = "theme";
|
2015-08-17 03:08:42 +05:30
|
|
|
// keyserver sync settings
|
|
|
|
|
public static final String SYNC_KEYSERVER = "syncKeyserver";
|
2016-03-15 23:07:27 +05:30
|
|
|
public static final String ENABLE_WIFI_SYNC_ONLY = "enableWifiSyncOnly";
|
2018-07-19 11:32:12 +02:00
|
|
|
public static final String SYNC_WORK_UUID = "syncWorkUuid";
|
2015-08-27 12:24:37 +02:00
|
|
|
// other settings
|
2017-11-22 16:04:25 +01:00
|
|
|
public static final String EXPERIMENTAL_USB_ALLOW_UNTESTED = "experimentalUsbAllowUntested";
|
2016-10-25 16:45:46 +02:00
|
|
|
public static final String EXPERIMENTAL_SMARTPGP_VERIFY_AUTHORITY = "smartpgp_authorities_pref";
|
|
|
|
|
public static final String EXPERIMENTAL_SMARTPGP_AUTHORITIES = "smartpgp_authorities";
|
2015-07-04 19:30:25 +02:00
|
|
|
|
2017-09-23 01:00:14 +02:00
|
|
|
public static final String KEY_SIGNATURES_TABLE_INITIALIZED = "key_signatures_table_initialized";
|
|
|
|
|
|
2015-07-04 19:30:25 +02:00
|
|
|
public static final class Theme {
|
2021-09-20 20:02:53 +02:00
|
|
|
public static final String AUTO = "auto";
|
2015-07-04 19:30:25 +02:00
|
|
|
public static final String DARK = "dark";
|
2024-02-13 07:07:00 +02:00
|
|
|
public static final String LIGHT = "light";
|
2022-12-27 22:33:16 +01:00
|
|
|
public static final String DEFAULT = Constants.Pref.Theme.AUTO;
|
2015-07-04 19:30:25 +02:00
|
|
|
}
|
2015-08-24 00:37:38 +02:00
|
|
|
|
|
|
|
|
public static final class ProxyType {
|
|
|
|
|
public static final String TYPE_HTTP = "proxyHttp";
|
|
|
|
|
public static final String TYPE_SOCKS = "proxySocks";
|
|
|
|
|
}
|
2010-08-17 21:49:34 +00:00
|
|
|
}
|
|
|
|
|
|
2015-06-06 19:56:07 +05:30
|
|
|
/**
|
2017-07-25 15:02:46 +02:00
|
|
|
* Orbot's default localhost HTTP proxy
|
|
|
|
|
* Orbot's SOCKS proxy is not fully supported by OkHttp
|
2015-06-06 19:56:07 +05:30
|
|
|
*/
|
|
|
|
|
public static final class Orbot {
|
|
|
|
|
public static final String PROXY_HOST = "127.0.0.1";
|
|
|
|
|
public static final int PROXY_PORT = 8118;
|
|
|
|
|
public static final Proxy.Type PROXY_TYPE = Proxy.Type.HTTP;
|
|
|
|
|
}
|
|
|
|
|
|
2014-03-13 21:39:14 +02:00
|
|
|
public static final class Defaults {
|
2021-01-29 12:36:34 +01:00
|
|
|
public static final String KEY_SERVERS = "hkps://keys.openpgp.org;hkp://zkaan2xfbuxia2wpf7ofnkbz6r5zdbbvxbunvp5g2iebopbfc4iqmbad.onion";
|
2019-06-15 19:11:07 +02:00
|
|
|
public static final int PREF_CURRENT_VERSION = 10;
|
2010-07-16 20:13:12 +00:00
|
|
|
}
|
2010-09-11 23:21:53 +00:00
|
|
|
|
2014-04-14 13:48:20 +02:00
|
|
|
public static final class key {
|
2015-12-03 09:20:34 +00:00
|
|
|
public static final long none = 0;
|
|
|
|
|
public static final long symmetric = -1;
|
2014-04-14 13:48:20 +02:00
|
|
|
}
|
2015-03-05 10:49:57 +01:00
|
|
|
|
2017-01-05 13:40:40 +01:00
|
|
|
/**
|
2023-03-18 10:47:31 +08:00
|
|
|
* Default key configuration: EDDSA (certify + sign), Curve25519 ECDH (encrypt)
|
2017-01-05 13:40:40 +01:00
|
|
|
*/
|
2017-05-23 02:23:03 +02:00
|
|
|
public static void addDefaultSubkeys(SaveKeyringParcel.Builder builder) {
|
2023-03-18 10:47:31 +08:00
|
|
|
builder.addSubkeyAdd(SubkeyAdd.createSubkeyAdd(SaveKeyringParcel.Algorithm.EDDSA,
|
|
|
|
|
null, null, KeyFlags.CERTIFY_OTHER | KeyFlags.SIGN_DATA, 0L));
|
|
|
|
|
builder.addSubkeyAdd(SubkeyAdd.createSubkeyAdd(SaveKeyringParcel.Algorithm.ECDH,
|
|
|
|
|
null, SaveKeyringParcel.Curve.CV25519, KeyFlags.ENCRYPT_COMMS | KeyFlags.ENCRYPT_STORAGE, 0L));
|
2017-01-05 13:40:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Default key format for OpenPGP smart cards v2: 2048 bit RSA (sign+certify, decrypt, auth)
|
|
|
|
|
*/
|
|
|
|
|
private static final int ELEN = 17; //65537
|
2021-03-16 17:07:56 +01:00
|
|
|
public static final KeyFormat SECURITY_TOKEN_V2_SIGN = RsaKeyFormat.getInstance(2048, ELEN, RsaKeyFormat.RsaImportFormat.CRT_WITH_MODULUS);
|
|
|
|
|
public static final KeyFormat SECURITY_TOKEN_V2_DEC = RsaKeyFormat.getInstance(2048, ELEN, RsaKeyFormat.RsaImportFormat.CRT_WITH_MODULUS);
|
|
|
|
|
public static final KeyFormat SECURITY_TOKEN_V2_AUTH = RsaKeyFormat.getInstance(2048, ELEN, RsaKeyFormat.RsaImportFormat.CRT_WITH_MODULUS);
|
2017-01-05 13:40:40 +01:00
|
|
|
|
2018-07-04 22:09:52 +02:00
|
|
|
private static boolean isRunningUnitTest() {
|
|
|
|
|
try {
|
|
|
|
|
Class.forName("org.sufficientlysecure.keychain.KeychainTestRunner");
|
|
|
|
|
return true;
|
|
|
|
|
} catch (ClassNotFoundException e) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
2010-07-16 20:13:12 +00:00
|
|
|
}
|