Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Replace Java 1.4 era 'for' loops #955

Open
wants to merge 70 commits into
base: next
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
70 commits
Select commit Hold shift + click to select a range
8991303
Upgrade to Gradle 7.6
Feb 8, 2023
3c83d3f
Simplify string length checks
Juiceman Mar 18, 2024
b44597f
Replace Java 1.4 era 'for' loops
Juiceman Mar 18, 2024
20b27b2
Merge branch 'next' into size-zero-to-isEmpty
Juiceman Mar 21, 2024
ed98d8c
Remove extra parenthesis
Juiceman Mar 21, 2024
c7c3caa
Merge remote-tracking branch 'Juiceman-origin/size-zero-to-isEmpty' i…
Juiceman Mar 21, 2024
5564298
Revert negation of ternary operators
Juiceman Mar 21, 2024
7525573
Revert negation of ternary operator
Juiceman Mar 21, 2024
47525eb
Restore parenthesis
Juiceman Mar 21, 2024
2873fc1
Update NEWS for 1498
ArneBab Apr 1, 2024
0a8d971
organize NEWS by topic
ArneBab Apr 26, 2024
3acf4e8
NEWS: add section high impact tasks
ArneBab Apr 26, 2024
0350536
add note
ArneBab Apr 26, 2024
8318eff
polish
ArneBab Apr 26, 2024
6077de2
NEWS: polish and note viewport
ArneBab Apr 26, 2024
d6d3bd8
removed superfluous -
ArneBab Apr 26, 2024
f3899a0
Added user-facing changelog to NEWS.md
ArneBab Apr 28, 2024
92fc225
Add missing links
ArneBab Apr 28, 2024
8a4311c
NEWS: added more whitespace for structuring
ArneBab Apr 28, 2024
9f42891
Support abridged IPv6 address
torusrxxx May 10, 2024
d05005c
Merge branch 'next' into for-loops
Juiceman May 13, 2024
ed0cc12
Merge branch 'next' into size-zero-to-isEmpty
Juiceman May 13, 2024
4072fb1
Add lossy WebP filter
torusrxxx May 3, 2024
392ce46
Add more tests and fix boundary checks
torusrxxx May 4, 2024
e1fadf5
Fixed processing of unexpected data after valid WebP image
torusrxxx May 5, 2024
f875d4b
Add test for lossy WebP image with alpha
torusrxxx May 6, 2024
523b6f0
Documentation and l10n
torusrxxx May 9, 2024
ac1d25f
Hide new load management statistics
torusrxxx May 19, 2024
fdbe9ae
remove recommendation to turn off javascript helpers in fproxy.
ArneBab Jun 12, 2024
3da0ebd
Don’t skip plugin waiting when loaded plugins change in iteration
ArneBab Apr 28, 2024
a9f7eaf
fix typo
ArneBab Jun 15, 2024
11eb9d7
Fix bugs related to 1:2:3:4:5:6:7: and percentage scope
torusrxxx Jun 17, 2024
f2251de
note the installers and signing
ArneBab Jun 21, 2024
83b892b
Merge branch 'update-news-for-1498' of github.com:ArneBab/fred-stagin…
ArneBab Jun 23, 2024
c5b7946
Update default bookmark editions
ArneBab Jun 23, 2024
6956294
Update default bookmark editions
ArneBab Jun 23, 2024
3bf60cf
Fix indentation
ArneBab Jul 9, 2024
5602d08
Only hand out copies of the set of loading or loaded plugins.
ArneBab Jul 9, 2024
04024cb
fix typo in logging
ArneBab Jul 9, 2024
68e5f33
fix typo in logging
ArneBab Jul 9, 2024
9fe0c1b
Merge branch 'note-the-installers-and-signing' of github.com:ArneBab/…
ArneBab Jul 23, 2024
d204f9f
Merge branch 'do-not-recommend-disabling-js-helpers' of github.com:Ar…
ArneBab Jul 23, 2024
3696f54
Merge branch 'torusrxxx-patch-1' of github.com:torusrxxx/fred into next
ArneBab Jul 23, 2024
76562ef
Merge branch 'size-zero-to-isEmpty' of github.com:Juiceman/fred into …
ArneBab Jul 23, 2024
ff698b8
Merge branch 'IPV6addresses' of github.com:torusrxxx/fred into next
ArneBab Jul 25, 2024
4ebce69
Merge branch 'resilience-against-plugin-list-exception' of github.com…
ArneBab Jul 25, 2024
4c3ffb1
Replace Java 10 Set copy with Java 8 compatible creation
ArneBab Jul 28, 2024
3f0625f
added sha256 for dependencies
chris-ch Aug 6, 2024
4029f51
Merge branch 'chris-ch-next-upgrade-gradle-7.6' into next
ArneBab Aug 7, 2024
1c9e07c
Resolve Gradle Deprecation Warnings
ArneBab Aug 7, 2024
4b8566c
Gradle merge regression: update hamcrest and junit again
ArneBab Aug 8, 2024
f5689d6
update Japanese translation
qupo1 Aug 27, 2024
c186aaf
🐛 Run Git from the project directory
Bombe Sep 1, 2024
e863063
🐛 Build JAR file correctly
Bombe Sep 2, 2024
716196a
🚸 Prevent duplicate files in the JAR file
Bombe Sep 2, 2024
034caf0
🚸 Prevent hashing of files generated by disabled tasks
Bombe Sep 2, 2024
8d29fcc
Update Gradle to 8.9
ArneBab Sep 14, 2024
66815c2
update junit and hamcrest — thanks to Bombe!
ArneBab Sep 16, 2024
4288fe9
Update junit to 4.13.2
ArneBab Sep 16, 2024
a9f8b2b
upgraded dependencies
chris-ch Sep 17, 2024
373ddd6
reordered keys
chris-ch Sep 17, 2024
f8483d2
clean-up
chris-ch Sep 17, 2024
c962f9e
Merge branch 'l10n-ja' of github.com:qupo1/fred into next
ArneBab Sep 22, 2024
c2a0431
Merge branch 'fix/build-info-with-gradle-daemon' of github.com:Bombe/…
ArneBab Sep 22, 2024
6d58bed
Merge branch 'patch-1' of github.com:torusrxxx/fred into next
ArneBab Sep 22, 2024
f6972f1
Merge branch 'gradle-update-to-8.9' into next
ArneBab Sep 22, 2024
5cd3f78
Restore verification data for hamcrest 1.3
ArneBab Sep 22, 2024
523d84b
Merge branch 'fix/include-correct-version-in-jar-file' of github.com:…
ArneBab Sep 22, 2024
6c07706
Replace Java 1.4 era 'for' loops
Juiceman Mar 18, 2024
ee34184
Merge remote-tracking branch 'Juiceman-origin/for-loops' into for-loops
Juiceman Sep 22, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
261 changes: 229 additions & 32 deletions NEWS.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,38 +5,235 @@ next:

1498:

- Support Schema hypha[net]
- Update Sharesite to 0.5.1
- Deprecated custom datetime handling class CurrentTimeUTC
- ⚠ The Windows installer is currently not signed!
- Shorten description of sharesite freesite for english
- gzip: replace test workaround by fixing the output of the compressor — thanks to Bombe for the SingleOffsetReplacingOutputStream!
- replace GregorianCalendar with java.time.OffsetDateTime in CurrentTimeUTC — thanks to Veniamin Fernandes
- CSS: Support word-wrap: anywhere and CSS selector focus-within.
- Move UPnP2 to normal plugins. It does not seem broken, but UPnP does
- Move Library plugin to advanced plugins because new users tend to get lost with it
- html-filter: allow summary and details html element. Thanks to naejadu
- 💄 Add a bit of styling to the plugin list (for winterfacey) — thanks to Bombe
- 🔥 Remove option that to load plugins from central server — thanks to Bombe!
- fix: invalid max store size showed bytes with GiB suffix
- polish: show datastore size warning with GiB suffix
- Refine ClientRequestSelectorTest, PersistentJobRunnerImplTest, SplitFileFetcherStorageTest, and SplitFileInserterStorageTest — thanks to Veniamin Fernandes
- Change deprecated jcenter() maven repo to mavenCentral() — thanks to Veniamin Fernandes
- 🐛 Fix JarClassLoader’s ability to work with ServiceLoader — thanks to Bombe!
- refactor the browser warning wizard page
- fix the flag size of nepal — thanks to Percept0r@NYZkOs7eQ…!
- Switch swiss flag to civil and state ensign — thanks to Percept0r@NY
- bookmarks: Add Opennet SeedNodes stats site
- Reorder starting bookmarks: FFS → clean spider → Index of Indexes
- Re-order default software bookmarks by ease of use from fproxy
- Add generate media site to the default bookmarks
- Show the noderef in basic-mode: it is now robust enough
- Added tests for PebbleUtils — thanks to Bombe!
- 🐛 Fix NPE when subsets are not initialized — thanks to Bombe
- reduce logging for too many excluded sub-arrays thanks to Hiina
- disable setting for new-load-management (NLM broke nodes)
- add utility to disable a config option, thanks to Bombe
- merge debian package as default build action thanks to DC*/desyncr! This resolves one of our high impact tasks.
# Short changelog:

This release resolves the last blocker for Freenet / Hyphanet 0.8 by
providing an official Debian package. Additionally it optimizes the
networking and data transfer core and provides many improvements for
website authors and user experience.


Starting with this release, Freenet / Hyphanet has an official Debian
package built automatically via github actions. This was the most
important [high-impact-task][] and the last release blocker of version
0.8 in our [Roadmap][]. Big thanks go to DC*!

With this finally realized, the next step is to get in contact with
the many privacy focussed distributions which build on Debian to make
`hyphanet-fred` available where it is most important. Once this is
done, tools which build on Hyphanet — like FMS, but also jSite and
tools from pyFreenet — can be packaged to work out of the box, using
Hyphanet as an ordinary background service. That’s a step towards
Hyphanet as decentralized, privacy-preserving communication backend for
other applications.

Another step towards this is accepting the Schema hypha[net] to
simplify writing browser extensions that forward hypha:-links to
Hyphanet.


The networking layer was optimized significantly. Searching packet
types is often stopped early and common or cheaper checks are done
before less common or time-consuming checks. This gives significant
reductions of CPU load, especially for very fast nodes.

Juiceman fixed a bug limiting MTU to 1280 where not needed.

And recently failed and data not found cooldown times were reduced to
5 minutes and 3 minutes, reducing one of the big annoyances when
accessing a site quickly after upload.

On the data transfer layer, healing was optimized. After 1495 strongly
increased the amount of healing to keep large files available for
longer, 1498 specializes healing to keys close to the node location.
This reduces healing per file, but improves privacy, because healing
inserts are then more similar to forwarding — they mostly send data
close to the nodes location — and it reduces the network load of
healing, because the specialized healing inserts need fewer hops to
reach the optimal storage location in the network.


In addition to these changes deep down, there are a number of directly
visible improvements.

The plugins KeepAlive and Sharesite are updated (the latter now uses
the new Night Zen Garden style). The UPnP2 plugin is now visible in
simple mode. It can replace UPnP and should work better. On the
flipside the Library plugin is moved to advanced plugins, because it
does not work reliably enough.

The plugin list is easier to navigate by removing the defunct option
to download plugins from the clearnet and by adding better styling.
Downloading from the clearnet was an unnecessary privacy risk since
we’ve been bundling essential plugins with the installer for a few
years now.


The noderef for friend-to-friend connections is shown in simple mode
again, because it is robust enough with the changes in recent years.
This should remove a barrier to adding direct connections and enabling
fully confidential messages between friends.

There are new configuration options to allow connecting via local
services. That’s a step towards making it easy to add a second layer
of security, for example confining connections to a local network.
Thanks goes to s7r for these changes!

When bandwidth detection fails, the upload bandwidth now defaults to
160KiB/s. Also the NLM config is now disabled statically. This was a
testing setup which could still be active in old nodes, but it would
break connectivity nowadays.


The default bookmarks include the Opennet SeedNodes statistics,
the generate media site to create decentralized streaming sites, and
the high-impact-tasks. The bookmarks are also re-ordered to be a
better match for newcomers. Starting category: first steps, clean
spider, Index of Indexes. For the software category ordered by ease of
use from fproxy.

For website authors, more CSS elements, selectors and combinators
(`:checked`, `word-wrap: anywhere`, `focus-within`, `^=`, `$=`, `*=`,
`>`, `+`, `~`) and additional HTML elements (`summary`, `details`,
`<meta name="Viewport"...>`) are available. This strongly expands the
possibilities of websites authors in Hyphanet, because Javascript or
webassembly are no viable options in an environment where a privacy
breach could put people at risk. We’ve seen with Java applets, that
untrusted code will always break out of its containment. The CSS
improvements in contrast provide a safe way to enable limited
interactivity.

Streaming support via m3u lists was improved to allow accessing
segments of up to 200MiB.

And using `-1` as version in a USK now properly finds version `0`, if
this is the only existing version.


There were a number of Java 21 fixes, including all our tests (thanks
to Bombe!), and improvement to the github actions (thanks to
AHOHNMYC).

In addition to that there was a lot of polish. Bert Massop and
Veniamin Fernandes replaced our homegrown CurrentTimeUTC with modern
Java options. Alex fixed the pronoun used in strings. Bombe added
getters for all direct field access in the node. Hiina reduced logging
level of store warnings so no unneeded backtraces are created for node
with large stores and Juiceman updated code to use more modern
structures.

Time-dependence of compressor selection was removed. This caused
non-determinism for inserts and could cause keys to be
non-reproducible on systems with faster or slower network.


And finally the new [exe signing workflow][] we built to fulfill the
requirements of SignPath, our new windows installer signing provider
for the upcoming releases, runs the [verify-build script][] on every
release to ensure that the jar we release has actually been built from
the sources. This provides a second safety net, in addition to
anonymous users running the script and posting the results (thanks to
all who did this — please keep it up, otherwise people have to fully
trust github). The release is not yet byte-by-byte reproducible,
because the jar MANIFEST defines among other info the exact java
version used to compile it, and the java version available differs by
distribution and time, so it would get harder over time to verify the
build.


A special thanks goes to Bombe for many careful reviews!

[high-impact-task]: https://github.com/hyphanet/wiki/wiki/High-Impact-tasks
[Roadmap]: https://github.com/hyphanet/wiki/wiki/Roadmap
[exe signing workflow]: https://github.com/hyphanet/sign-windows-installer
[verify-build script]: https://github.com/hyphanet/scripts/blob/master/verify-build

# Full changelog:


## high impact tasks
merge debian package as default build action thanks to DC*/desyncr! This resolves one of our high impact tasks.

## Plugins
Update KeepAlive to commit 86e47a101f26fd1d3be0437681a043aa4ae3f22c
Update Sharesite to 0.5.1
Move UPnP2 to normal plugins. It does not seem broken, but UPnP does
Move Library plugin to advanced plugins because new users tend to get lost with it
💄 Add better styling to the plugin list in winterfacey to make it easier to understand at a glance — thanks to Bombe
🔥 Remove option to load plugins from central server — thanks to Bombe! This was an unnecessary privacy risk, since we’re already bundling essential plugins with the installer, and it made plugin handling harder to understand.

## Bookmarks
Add high-impact-tasks to bookmarks
Add generate media site to the default bookmarks
Add Opennet SeedNodes stats site
Reorder starting bookmarks: FFS → clean spider → Index of Indexes
Reorder default software bookmarks by ease of use from fproxy
Disable activelink for Index of Indexes (workaround, because it fails)

## Optimize networking and transfer layer
break early when condition is met — thanks to Juiceman
Check the HashCode before equals. This saves ~20% method-runtime.
Re-order or’ed MessageFilters so the most likely is checked first
specialize healing to keys close to the node
fix healing decision: do not divide 0-1 by MAX_VALUE — thanks to Bombe for the review!
Reduce recently failed and data not found wait times

## Filters
CSS: Fix: checked only the first char of the key part of CSS selectors, Add test that would catch too lax filtering.
CSS: Support pseudo-element checked. This enables limited interactivity via CSS.
CSS: Support the attribute selectors ^= $= *=, Add tests.
CSS: Support Combinators > + and ~, add test for ~ and simplify the implementation
CSS: Support word-wrap: anywhere and CSS selector focus-within.
HTML: allow summary and details html element. Thanks to naejadu
HTML: accept <meta name="Viewport" ...>, thanks to torusrxxx

## Constants
Show the noderef in basic-mode: it is now robust enough

## Configuration
accepting localhost in NodeIPPortDetector and allowBindToLocalhost configurable — thanks to s7r!
Provide static methods for simpler boolean config creation
Increase default bandwidth to 160KiB upload, when detection fails
disable setting for new-load-management (NLM broke nodes)
add utility to disable a config option, thanks to Bombe

## Misc
add m3u-player insertion test: is added at end of body
[CI] Update actions, fix actions cache
♻️ add and use getters and setters for access to node fields
Increase max transparent passthrough to 200MiB links in m3u-lists.
Remove time-dependence of compressor selection. This caused
non-determinism for inserts and could cause keys to be
non-reproducible.
improve date object construction in CurrentTimeUTC.get()
Support Schema hypha[net] to simplify writing browser extensions that forward hypha://-links to Hyphanet.
polish: show datastore size warning with GiB suffix
Remove hash generation to native big integer to reduce dependencies. This had come in when merging an old pull request and added a new dependency without need.

## Polish
Replace indexOf with .contains()
Change more string comparisons into .isEmpty() checks
Capitalize L in literal longs
Add missing Global flag to GetFailed FCP message. Thanks to oishii and Bombe!
Fix links to mailing lists and IRC in CONTRIBUTING.md — thanks to Juiceman!
Deprecated custom datetime handling class CurrentTimeUTC
replace GregorianCalendar with java.time.OffsetDateTime in CurrentTimeUTC — thanks to Veniamin Fernandes
Refine ClientRequestSelectorTest, PersistentJobRunnerImplTest, SplitFileFetcherStorageTest, and SplitFileInserterStorageTest — thanks to Veniamin Fernandes
Change deprecated jcenter() maven repo to mavenCentral() — thanks to Veniamin Fernandes
Added tests for PebbleUtils — thanks to Bombe!
🐛 Fix NPE when subsets are not initialized — thanks to Bombe
reduce logging for too many excluded sub-arrays thanks to Hiina
fix the flag size of nepal — thanks to Percept0r@NYZkOs7eQ…!
Switch swiss flag to civil and state ensign — thanks to Percept0r@NY

## Fixes
Thanks to Bombe all our tests work again on Java 21!
🐛 Fix JarClassLoader’s ability to work with ServiceLoader — thanks to Bombe!
gzip: replace test workaround by fixing the output of the compressor — thanks to Bombe for the SingleOffsetReplacingOutputStream!
fix: invalid max store size showed bytes with GiB suffix


Also a special thanks to Bombe for many careful reviews!


1497:
Expand Down
10 changes: 10 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,16 @@ of the archive it downloads from `https://services.gradle.org`.
$ mkdir -p lib; cd lib && grep -o CHK.* ../dependencies.properties | xargs -P16 -I {} bash -c 'fcpget -v {} "$(echo {} | sed s,^.*/,,)"'
$ ant -propertyfile build.properties -f build-clean.xml -Dtest.skip=true -Dfindbugs.skip=true

## Building the installers

The installers are built from specialized repositories:

- The GNU/Linux, macOS and *nix installer is built from [hyphanet/java_installer](https://github.com/hyphanet/java_installer).
- The Windows installer is built from [hyphanet/wininstaller-innosetup](https://github.com/hyphanet/wininstaller-innosetup) and signed with [hyphanet/sign-windows-installer](https://github.com/hyphanet/sign-windows-installer).

Free code signing for the Windows installer is provided by [SignPath.io](https://about.signpath.io/?), the certificate by the [SignPath Foundation](https://signpath.org/).


## Testing

### Run Tests
Expand Down
Loading