- improve mobile usability
- disable error logs in NGINX config
- fix non-greedyness of RegExes
- rewrite environment variable handling
- introduce placeholder support for configuration
- drop
require-sri-for
from Content-Security-Policy
- reorganized the whole sourcecode
- rewrote the configuration handling
- containerized the application
- cleaned up PEM-formatted key handling
- migrated from Bootstrap 3 to Bootstrap 5
- introduced SQLite support as the default
- introduced copy-to-clipboard buttons
- fixed usability bugs in JavaScript
- fixed URI handling for duplicate slashes
- improved styling
- replaced unnecessary
hex2bin()
calls - updated the shell examples on the how page
- updated shell examples in
ENCRYPTION.md
- updated
README.md
to reflect the changes
- prevent deprecation notice in PHP 8.0 and above
- specify columns on insert to be more robust regarding schema changes (thanks to @jonico)
- increased PBKDF2 iteration count for v00 encryption from 10000 to 512000
- introduced support for configuration via environment variables
- introduced support for configuration via .env file
- updated README to document environment variables
- updated jQuery to version 3.6.0
- fixed typo on howto page
- updated README to introduced maintenance information
- updated README to opt out of Google FLoC by default
- introduced
IMPRINT_TEXT
to change the default text of the imprint link - HTML-escape
IMPRINT_TEXT
to prevent the admin from breaking the HTML output - updated jQuery to version 3.5.1
- introduced
JUMBO_SECRETS
to allow secrets of up to 16kb - Beware: Jumbo secret sharing links that exceed 2048 bytes (2k) in size will most likely be incompatible with older Internet Explorer versions.
- fixed selection of keyid for key rollovers
- introduced proper key rollover support by adding the corresponding keyid to the database primary key
- now you do not have to purge the database when switching to a new key as fingerprints will not collide for different keys
- renamed
$checksum
to$fingerprint
to match with the database fields - updated README to provide a best-practice logging configuration
- updated README to reflect the key rollover support
- updated README to address security limitations of this solution
- introduced helper functions
is_privkey()
andis_pubkey()
- as a share-only instance doesn't need the private key,
RSA_PRIVATE_KEYS
can now also hold RSA public keys - creating secret sharing links and downloading the public key now also works when RSA public keys are set as
RSA_PRIVATE_KEYS
- updated README to reflect the new feature
- fixed read-only mode and introduced share-only mode
- introduced human-readable page for downloading the public key under
/pub
- changed the download of the plain public key to
/pub?plain
- on errors the application now returns
403 Forbidden
response codes instead of200 OK
response codes - updated README to reflect the new features
- improved URL parsing
- added support for
plain
GET parameter - updated README to reflect the required configuration change
- added length check to local decryption as has been done for local encryption
- introduced
router.php
for local debugging - changed default value of
DEBUG_MODE
fromtrue
tofalse
- prevent the local encryption with empty secrets and empty passwords
- prevent the encryption of secrets that are too long to be shared
- introduced a JavaScript-based resubmission prevention for supporting browsers
- introduced support for multi-line secrets and added a byte counter
- simplified URL-safe Base64 encoding and decoding
- correct the minimum length of v00 messages from 50 (without the MAC) to 82 (with the MAC) in
lib/shared-secrets.exec.php
- rewrote the application to use OpenSSL instead of GPG fixing indirect integrity vulnerabilities
- rewrote the client-side encryption to be based on the Web Cryptography API
- added
encryption.md
to describe the details of the newly implemented encryption scheme - moved configuration file into the subfolder
config/
- renamed folder
libs/
tolib/
- introduced the possibility to have key roll-overs (encrypt with new key but decrypt with new and old key)
- updated Bootstrap to version 3.4.1
- updated jQuery to version 3.4.1
- Beware: Decrypting old GPG-based URLs is not possible with this version. Due to the new encryption scheme v01 the first 48 bytes of a URL will be the same for all generated URLs therefore it is possible to distinguish with high certainty between old and new URLs so that it is possible for you to redirect old URLs to a read-only instance.
- introduced a read-only mode to simplify the migration to the upcoming release
- introduced
apache_bugfix_encode()
andapache_bugfix_decode()
to prevent "(36) File name too long" errors - SECURITY: prevent whitespace from allowing an attacker to retrieve a secret more than once
- decryption of non-MDC-protected messages is now prevented for older versions of GnuPG that set the return code to 0
- force GnuPG to produce English output as we have to check it against a predefined string
- version bump for legacy-less publication on github
- Beware: Due to security concerns the previously introduced GnuPG PECL interface has been forcecfully deactivated. This change may break installations that currently rely on the functionality of the GnuPG PECL interface.
- activated
ENABLE_PASSWORD_PROTECTION
option by default as the feature has proven to be stable - deactivated
LOG_IP_ADDRESS
option by default to promote data privacy - removed
SUPPORT_LEGACY_LINKS
option because the codebase does not generate legacy links for almost a year now - removed code that handled legacy links and has become obsolete with the removal of the
SUPPORT_LEGACY_LINKS
option - forcefully deactivated the GnuPG PECL interface because php-gnupg/php-gnupg#9 is not handled properly
- updated README to reflect the forcful deactivation of the GnuPG PECL interface which may break installations
- enforced strict base64 decoding
- added info to
config.php.default
and to the README that the GnuPG PECL should currently not be used (thanks to Nikolas Lotz)
- fixed a security bug that allowed to retrieve a secret several times by appending query parameters to the secret (thanks to Nikolas Lotz)
- version bump for interface improvements publication on github
- introduced dynamic indentation for shell command on how page
- tested interface improvements within chroot environment
- introduced dummy parameters to fix cached-subresource-checksum-mismatch problem when changing CSS/JS files
- removed copy-to-clipboard functionality as it proves to be unreliable
- improved style to simplify manual copying of generated shared secret link
- updated readme accordingly
- fixed secret-already-retrieved error message
- introduced the parameter
plain
for the share action to just return the link without surrounding HTML - introduced the parameter
plain
for the read action to just return the secret without surrounding HTML - introduced some minor changes to make parameter constant naming more consistent
- introduced
.htaccess
to simplify installation using Apache HTTPD - updated included libraries to newer releases
- version bump for GnuPG PECL package support publication on github
- Beware: With version 0.8b0 the structure of the secret sharing links has slightly changed. You have to set the
SUPPORT_LEGACY_LINKS
configuration value totrue
if you want to support secret sharing links that have been generated for older versions of Shared-Secrets. Failure to do so will break these legacy links.
- rewrote non-PECL encryption to not use ASCII-armoring anymore
- enhanced non-PECL link generation so that PECL and non-PECL links look the same
- cleaned up PECL and non-PECL encryption/decryption code
- simplified and fixed code for PECL or non-PECL call selection
- introduced new configuration variable
SUPPORT_LEGACY_LINKS
- introduced code that provides backward-compatibility for legacy links
- tested PECL implementation in chroot environment and failed
- updated readme to reflect observations made in chroot environment
- implemented support for the newly released GnuPG PECL version 1.4.0
- introduced homedir support for non-PECL encryption and decryption
- introduced new configuration variable
GPG_HOME_DIR
- implemented handling of equation signs for the URL-safe Base64 encoding and decoding
- tested backward-compatibility so that non-PECL URL don't break
- updated howto website which automatically adjusts when PECL is active
- updated readme to decribe how to install the GnuPG PECL
- fixed some typos in the documentation and in comments
- version bump for url-safe Base64 encoding publication on github
- implemented so-called url-safe Base64 encoding of secrets to reduce URL-encoding junk
- checked backward-compatibility with previous standard URL-encoded URLs
- improved line-break handling in GPG message unstripping
- tested URL-safe Base64 encoding feature within chroot environment
- version bump for increased readability publication on github
- fixed copy-to-clipboard feature when password-protection feature is disabled
- increased readability of optional code that is added for password-protection feature
- version bump for improved Mozilla Observatory rating publication on github
- improved code so that A+ rating in Mozilla Observatory can be achieved
- added HTTP header configuration to readme
- modified the changelog so that it is more consistent
- updated the readme to describe how an A+ rating can be achieved
- tested improved code within chroot environment
- version bump for integrity-checking feature publication on github
- moved inline JavaScript code to separate .js files
- introduced subresource integrity for link and style elements
- added
asmCrypto.js.map
for better debugging support - switched from server-defined PBKDF2 salt to JavaScript-generated salt
- tested implementation of new features within chroot environment
- version bump for password-protection feature publication on github
- improved length and handling of server-defined PBKDF2 salt
- fixed escaping of password-protected secrets
- harmonized variable names of encryption and decryption code
- tested implementation of password-protection feature within chroot environment
- implemented the password-protection feature
- version bump for initial publication on github
- introduce support for GPG passphrase via passphrase file
- simplified index file structure
- fixed message unstripping which produced undecryptable results for certain lengths
- tested implementation of shared-secrets service within chroot environment
- optimized copy-to-clipboard JavaScript integration
- fixed error message handling
- added changelog file
- prepared publication on github
- introduced config parameters for customization
- updated "how" page to be customizable
- added license file
- added readme file
- introduced copy-to-clipboard feature
- disabled auto-form-fill of browsers
- introduced cleaned-up code structure
- introduced action handling code
- introduced page handling code
- introduced template handling code
- introduced separate config.php file
- allowed URL-encoded and URL-unencoded secret URIs (Apple Mail bug)
- published to internal git versioning
- initial PoC release
- tested with first customer