Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pfirmstone/jgdms
Infrastructure for providing secured micro services, that are dynamically discoverable and searchable over ipv6 networks
https://github.com/pfirmstone/jgdms
distributed-computing iot java osgi-services security
Last synced: 3 months ago
JSON representation
Infrastructure for providing secured micro services, that are dynamically discoverable and searchable over ipv6 networks
- Host: GitHub
- URL: https://github.com/pfirmstone/jgdms
- Owner: pfirmstone
- License: apache-2.0
- Created: 2016-01-09T12:47:11.000Z (almost 9 years ago)
- Default Branch: trunk
- Last Pushed: 2023-11-27T23:34:11.000Z (about 1 year ago)
- Last Synced: 2023-11-28T00:29:19.484Z (about 1 year ago)
- Topics: distributed-computing, iot, java, osgi-services, security
- Language: HTML
- Homepage: https://pfirmstone.github.io/JGDMS/
- Size: 75.2 MB
- Stars: 13
- Watchers: 8
- Forks: 4
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# JGDMS - Java/Jini Global Distributed Micro Services.
## Build instructions
From command or shell prompt:$ mvn -f JGDMS/pom.xml package
For unit tests:
$mvn -f JGDMS/pom.xml test
After successfully testing the above, integration and regression tests can be run by:
$ cd qa
$ ant run-all
$ ant jtreg
The regression tests ($ ant run-all) take approximately 24 hours to complete.
The jtreg tests take about half an hour to complete, you'll need to manually install jtreg, refer to http://openjdk.java.net/jtreg/
## This software is forked from Apache River trunk, it is designed with internet security in mind and provides:
* ObjectInput and ObjectOutput implementations for hardening deserialization in the presence of untrusted input.
* TLSv1.3 Stateless Encrypted endpoints for RPC communication over untrusted networks.
* IPv6 Multicast Discovery using X500 distinguished names with various integrity checking hash functions provided.
* Unicast Discovery over a TLSv1.3 connection with an SHA-224, SHA-256, SHA-384 or SHA-512 hash function to validate data sent and received at both ends prior to sending a response.
* Dynamically granting DownloadPermission and DeSerialization permission to trusted authenticated lookup services during unicast discovery.
* Lookup Service registrar to search services available from various arbitrary third parties.
* Lookup method that allows authentication of third parties, using a bootstrap proxy, prior granting DownloadPermission and DeSerialization permission for service utilisation.
* Invocation and Method constraints.## Old Discussion forum (please use github Discussions):
https://groups.google.com/forum/#!forum/river-secure-ipv6-discovery## Notables:
* Worlds fastest, highly scalable, Java security policy provider.
* RFC3986URLClassLoader is much faster than Java's built in URLClassLoader.
* RFC3986 compliant Uri.
* Atomic Serialization outperforms standard Java.
* JERI (Jini Extensible Remote Invocation) outperforms java RMI.
* Unnecessary DNS calls have been eliminated.
* Hi performance lookup service method delays or avoids unnecessary codebase downloads.## A footnote on JEP411
In years to come, when Java deployments are sufferring from multiple vulnerabilities, the decision to remove Authorization from Java will be seen with hindsight as one of the biggest blunders made by the OpenJDK team. Java might have avoided a number of vulnerabilities, had Java's trusted computing base remained small, had permission checks been made for enabling data parsing, and the work of Li Gong been properly maintained. I strongly advise against running without a SecurityManager, JGDMS has for many years been run with the SecurityManager enabled. Statments made on the JEP411 page, are simply incorrect. The time will come when this footnote is proven correct.
* https://youtu.be/uVob-4aXbxY