Compare commits
24 Commits
Author | SHA1 | Date | |
---|---|---|---|
5349d0b8bb | |||
9e6dd8a094 | |||
57c7d7d341 | |||
ca91190c63 | |||
bc4dbd4d54 | |||
c5736f51c9 | |||
a274fe4bbc | |||
ee480843d3 | |||
b9711689a7 | |||
03a2105daa | |||
f997171dcc | |||
7ccaec1748 | |||
48869cf2b5 | |||
dcfd991aac | |||
c3136fb4b7 | |||
52086c98df | |||
1bc9894616 | |||
b7bbcf4e4b | |||
b46abac574 | |||
aca1dd618d | |||
9f283c4ef5 | |||
b1a54e0144 | |||
b4c4c20d74 | |||
d874caa490 |
28
.github/workflows/ant.yml
vendored
28
.github/workflows/ant.yml
vendored
@ -24,7 +24,7 @@ jobs:
|
|||||||
echo "build.built-by=GitHub Actions" >> override.properties
|
echo "build.built-by=GitHub Actions" >> override.properties
|
||||||
echo "noExe=true" >> override.properties
|
echo "noExe=true" >> override.properties
|
||||||
- name: install crx3
|
- name: install crx3
|
||||||
run: go install github.com/mediabuyerbot/go-crx3/crx3@latest
|
run: mkdir -p $(go env GOPATH)/bin; wget -O $(go env GOPATH)/bin/crx3 https://github.com/eyedeekay/i2p.plugins.firefox/releases/download/build-tools/crx3-linux; chmod +x $(go env GOPATH)/bin/crx3
|
||||||
- name: install dzip
|
- name: install dzip
|
||||||
run: go install github.com/delicb/dzip@latest
|
run: go install github.com/delicb/dzip@latest
|
||||||
- name: install amo-version
|
- name: install amo-version
|
||||||
@ -76,7 +76,7 @@ jobs:
|
|||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: i2pbrowser_amd64.deb
|
name: i2pbrowser_amd64.deb
|
||||||
path: ./i2pbrowser_1.0.0_amd64.deb
|
path: ./i2pbrowser_${{ github.ref_name }}_amd64.deb
|
||||||
- name: build plugin with Ant
|
- name: build plugin with Ant
|
||||||
run: |
|
run: |
|
||||||
export PATH=$PATH:$(go env GOPATH)/bin
|
export PATH=$PATH:$(go env GOPATH)/bin
|
||||||
@ -107,7 +107,7 @@ jobs:
|
|||||||
- run: echo enabled=1 >> /etc/yum.repos.d/adoptium.repo
|
- run: echo enabled=1 >> /etc/yum.repos.d/adoptium.repo
|
||||||
- run: echo gpgcheck=1 >> /etc/yum.repos.d/adoptium.repo
|
- run: echo gpgcheck=1 >> /etc/yum.repos.d/adoptium.repo
|
||||||
- run: echo gpgkey=https://packages.adoptium.net/artifactory/api/gpg/key/public >> /etc/yum.repos.d/adoptium.repo
|
- run: echo gpgkey=https://packages.adoptium.net/artifactory/api/gpg/key/public >> /etc/yum.repos.d/adoptium.repo
|
||||||
- run: dnf clean all && rm -r /var/cache/dnf && dnf upgrade -y && dnf update -y
|
- run: dnf clean all && rm -rf /var/cache/dnf && dnf upgrade -y && dnf update -y
|
||||||
- run: dnf install -y temurin-21-jdk
|
- run: dnf install -y temurin-21-jdk
|
||||||
- name: Generate override.properties
|
- name: Generate override.properties
|
||||||
run: |
|
run: |
|
||||||
@ -115,7 +115,7 @@ jobs:
|
|||||||
echo "build.built-by=GitHub Actions" >> override.properties
|
echo "build.built-by=GitHub Actions" >> override.properties
|
||||||
echo "noExe=true" >> override.properties
|
echo "noExe=true" >> override.properties
|
||||||
- name: install crx3
|
- name: install crx3
|
||||||
run: go install github.com/mediabuyerbot/go-crx3/crx3@latest
|
run: mkdir -p $(go env GOPATH)/bin; wget -O $(go env GOPATH)/bin/crx3 https://github.com/eyedeekay/i2p.plugins.firefox/releases/download/build-tools/crx3-linux; chmod +x $(go env GOPATH)/bin/crx3
|
||||||
- name: install dzip
|
- name: install dzip
|
||||||
run: go install github.com/delicb/dzip@latest
|
run: go install github.com/delicb/dzip@latest
|
||||||
- name: install amo-version
|
- name: install amo-version
|
||||||
@ -133,7 +133,7 @@ jobs:
|
|||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: i2pbrowser.x86_64.rpm
|
name: i2pbrowser.x86_64.rpm
|
||||||
path: ./i2pbrowser-1.0.0-1.x86_64.rpm
|
path: ./i2pbrowser-${{ github.ref_name }}-1.x86_64.rpm
|
||||||
|
|
||||||
|
|
||||||
buildwin:
|
buildwin:
|
||||||
@ -171,8 +171,8 @@ jobs:
|
|||||||
- name: Upload Firefox Profile EXE Installer
|
- name: Upload Firefox Profile EXE Installer
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: i2pbrowser-1.0.0.exe
|
name: i2pbrowser-${{ github.ref_name }}.exe
|
||||||
path: ./i2pbrowser-1.0.0.exe
|
path: ./i2pbrowser-${{ github.ref_name }}.exe
|
||||||
- name: build msi with Ant
|
- name: build msi with Ant
|
||||||
run: |
|
run: |
|
||||||
ant windows-msi
|
ant windows-msi
|
||||||
@ -180,8 +180,8 @@ jobs:
|
|||||||
- name: Upload Firefox Profile MSI Installer
|
- name: Upload Firefox Profile MSI Installer
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: i2pbrowser-1.0.0.msi
|
name: i2pbrowser-${{ github.ref_name }}.msi
|
||||||
path: ./i2pbrowser-1.0.0.msi
|
path: ./i2pbrowser-${{ github.ref_name }}.msi
|
||||||
- name: build portable zip with Ant
|
- name: build portable zip with Ant
|
||||||
run: |
|
run: |
|
||||||
ant windows-portable
|
ant windows-portable
|
||||||
@ -211,7 +211,7 @@ jobs:
|
|||||||
bash -c 'echo "build.built-by=GitHub Actions" >> override.properties'
|
bash -c 'echo "build.built-by=GitHub Actions" >> override.properties'
|
||||||
bash -c 'echo "noExe=true" >> override.properties'
|
bash -c 'echo "noExe=true" >> override.properties'
|
||||||
- name: install crx3
|
- name: install crx3
|
||||||
run: go install github.com/mediabuyerbot/go-crx3/crx3@latest
|
run: mkdir -p $(go env GOPATH)/bin; wget -O $(go env GOPATH)/bin/crx3 https://github.com/eyedeekay/i2p.plugins.firefox/releases/download/build-tools/crx3-osx; chmod +x $(go env GOPATH)/bin/crx3
|
||||||
- name: install dzip
|
- name: install dzip
|
||||||
run: go install github.com/delicb/dzip@latest
|
run: go install github.com/delicb/dzip@latest
|
||||||
- name: install amo-version
|
- name: install amo-version
|
||||||
@ -227,8 +227,8 @@ jobs:
|
|||||||
- name: Upload Firefox Profile DMG Installer
|
- name: Upload Firefox Profile DMG Installer
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: i2pbrowser-1.0.0.dmg
|
name: i2pbrowser-${{ github.ref_name }}.dmg
|
||||||
path: ./i2pbrowser-1.0.0.dmg
|
path: ./i2pbrowser-${{ github.ref_name }}.dmg
|
||||||
- name: build pkg with Ant
|
- name: build pkg with Ant
|
||||||
run: |
|
run: |
|
||||||
ant macos-pkg
|
ant macos-pkg
|
||||||
@ -236,5 +236,5 @@ jobs:
|
|||||||
- name: Upload Firefox Profile PKG Installer
|
- name: Upload Firefox Profile PKG Installer
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: i2pbrowser-1.0.0.pkg
|
name: i2pbrowser-${{ github.ref_name }}.pkg
|
||||||
path: ./i2pbrowser-1.0.0.pkg
|
path: ./i2pbrowser-${{ github.ref_name }}.pkg
|
81
.github/workflows/nightly.yml
vendored
Normal file
81
.github/workflows/nightly.yml
vendored
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
name: Nightly
|
||||||
|
|
||||||
|
#on: [push]
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- nightly-*
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
permissions:
|
||||||
|
contents: write
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
sparse-checkout: |
|
||||||
|
CHANGES.md
|
||||||
|
sparse-checkout-cone-mode: false
|
||||||
|
- name: sleep 15 minutes
|
||||||
|
run: |
|
||||||
|
echo "sleeping 15 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 14 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 13 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 12 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 11 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 10 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 9 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 8 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 7 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 6 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 5 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 4 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 3 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 2 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
echo "sleeping 1 minutes to wait for artifacts"
|
||||||
|
sleep 1m
|
||||||
|
- name: Download artifacts
|
||||||
|
id: download-artifact
|
||||||
|
uses: dawidd6/action-download-artifact@v3
|
||||||
|
with:
|
||||||
|
skip_unpack: true
|
||||||
|
workflow: ant.yml
|
||||||
|
if_no_artifact_found: fail
|
||||||
|
# remove .zip file extension
|
||||||
|
- run: for f in *.zip; do unzip "$f"; rm "$f"; done
|
||||||
|
- run: echo "" | tee -a CHANGES.md
|
||||||
|
- run: echo "## Checksums" | tee -a CHANGES.md
|
||||||
|
- run: echo "" | tee -a CHANGES.md
|
||||||
|
- run: echo '```' | tee -a CHANGES.md
|
||||||
|
- run: sha256sum * | tee -a CHANGES.md
|
||||||
|
- run: echo '```' | tee -a CHANGES.md
|
||||||
|
- run: echo "" | tee -a CHANGES.md
|
||||||
|
- run: echo '```' | tee -a CHANGES.md
|
||||||
|
- run: file * | tee -a CHANGES.md
|
||||||
|
- run: echo '```' | tee -a CHANGES.md
|
||||||
|
- run: echo "" | tee -a CHANGES.md
|
||||||
|
- name: Upload artifacts
|
||||||
|
uses: ncipollo/release-action@v1
|
||||||
|
with:
|
||||||
|
name: nightly
|
||||||
|
prerelease: true
|
||||||
|
makeLatest: true
|
||||||
|
allowUpdates: true
|
||||||
|
artifacts: "*"
|
||||||
|
bodyFile: "CHANGES.md"
|
11
CHANGES.md
11
CHANGES.md
@ -1,3 +1,14 @@
|
|||||||
|
2025 Tue, January 7
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
- Disable downloading Chrome extensions, begin phasing out Chrome support
|
||||||
|
|
||||||
|
Sat, October 19
|
||||||
|
---------------
|
||||||
|
|
||||||
|
- Ignore most changes when running in Tor Browser, only set the proxy
|
||||||
|
- 2.7.0 release
|
||||||
|
|
||||||
Mon, July 8
|
Mon, July 8
|
||||||
-----------
|
-----------
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@ RUN echo enabled=1 >> /etc/yum.repos.d/adoptium.repo
|
|||||||
RUN echo gpgcheck=1 >> /etc/yum.repos.d/adoptium.repo
|
RUN echo gpgcheck=1 >> /etc/yum.repos.d/adoptium.repo
|
||||||
RUN echo gpgkey=https://packages.adoptium.net/artifactory/api/gpg/key/public >> /etc/yum.repos.d/adoptium.repo
|
RUN echo gpgkey=https://packages.adoptium.net/artifactory/api/gpg/key/public >> /etc/yum.repos.d/adoptium.repo
|
||||||
RUN cat /etc/yum.repos.d/adoptium.repo
|
RUN cat /etc/yum.repos.d/adoptium.repo
|
||||||
RUN dnf clean all && rm -r /var/cache/dnf && dnf upgrade -y && dnf update -y
|
RUN dnf clean all && rm -rf /var/cache/dnf && dnf upgrade -y && dnf update -y
|
||||||
RUN dnf -y install rpm-build temurin-19-jdk
|
RUN dnf -y install rpm-build temurin-19-jdk
|
||||||
ADD . /src/i2p.plugins.firefox
|
ADD . /src/i2p.plugins.firefox
|
||||||
WORKDIR /src/i2p.plugins.firefox
|
WORKDIR /src/i2p.plugins.firefox
|
||||||
|
35
VERSION.md
35
VERSION.md
@ -6,41 +6,26 @@ Extension Versions
|
|||||||
|
|
||||||
```md
|
```md
|
||||||
i2p-in-private-browsing
|
i2p-in-private-browsing
|
||||||
1.48
|
2.7.0
|
||||||
https://addons.mozilla.org/firefox/downloads/file/4123613/i2p_in_private_browsing-1.48.xpi
|
https://addons.mozilla.org/firefox/downloads/file/4364373/i2p_in_private_browsing-2.7.0.xpi
|
||||||
noscript
|
noscript
|
||||||
11.4.29
|
12.1.1
|
||||||
https://addons.mozilla.org/firefox/downloads/file/4206186/noscript-11.4.29.xpi
|
https://addons.mozilla.org/firefox/downloads/file/4411102/noscript-12.1.1.xpi
|
||||||
localcdn-fork-of-decentraleyes
|
localcdn-fork-of-decentraleyes
|
||||||
2.6.69
|
2.6.76
|
||||||
https://addons.mozilla.org/firefox/downloads/file/4303757/localcdn_fork_of_decentraleyes-2.6.69.xpi
|
https://addons.mozilla.org/firefox/downloads/file/4401439/localcdn_fork_of_decentraleyes-2.6.76.xpi
|
||||||
onion-in-container-browsing
|
onion-in-container-browsing
|
||||||
0.82
|
0.82
|
||||||
https://addons.mozilla.org/firefox/downloads/file/3904685/onion_in_container_browsing-0.82.xpi
|
https://addons.mozilla.org/firefox/downloads/file/3904685/onion_in_container_browsing-0.82.xpi
|
||||||
javascript-restrictor
|
javascript-restrictor
|
||||||
0.18.1
|
0.19.1
|
||||||
https://addons.mozilla.org/firefox/downloads/file/4310951/javascript_restrictor-0.18.1.xpi
|
https://addons.mozilla.org/firefox/downloads/file/4352350/javascript_restrictor-0.19.1.xpi
|
||||||
ublock-origin
|
ublock-origin
|
||||||
1.58.0
|
1.61.2
|
||||||
https://addons.mozilla.org/firefox/downloads/file/4290466/ublock_origin-1.58.0.xpi
|
https://addons.mozilla.org/firefox/downloads/file/4391011/ublock_origin-1.61.2.xpi
|
||||||
```
|
```
|
||||||
|
|
||||||
## Chromium
|
## Chromium
|
||||||
|
|
||||||
```md
|
```md
|
||||||
__MSG_extensionName__
|
|
||||||
1.29
|
|
||||||
https://clients2.google.com/service/update2/crx
|
|
||||||
NoScript
|
|
||||||
11.4.30
|
|
||||||
https://clients2.google.com/service/update2/crx
|
|
||||||
LocalCDN
|
|
||||||
2.6.67
|
|
||||||
https://clients2.google.com/service/update2/crx
|
|
||||||
uBlock Origin
|
|
||||||
1.58.0
|
|
||||||
https://clients2.google.com/service/update2/crx
|
|
||||||
__MSG_extensionName__
|
|
||||||
0.18.1
|
|
||||||
https://clients2.google.com/service/update2/crx
|
|
||||||
```
|
```
|
||||||
|
31
build.xml
31
build.xml
@ -522,6 +522,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
<exec executable="rm" failonerror="true" osfamily="windows">
|
<exec executable="rm" failonerror="true" osfamily="windows">
|
||||||
<arg value="-rf" />
|
<arg value="-rf" />
|
||||||
@ -557,6 +558,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--icon"/> <arg value="src/icon.png"/>
|
<arg value="--icon"/> <arg value="src/icon.png"/>
|
||||||
<arg value="--app-version"/> <arg value="1.0.0"/>
|
<arg value="--app-version"/> <arg value="1.0.0"/>
|
||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
</exec>
|
</exec>
|
||||||
@ -574,6 +576,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--icon"/> <arg value="src/icon.png"/>
|
<arg value="--icon"/> <arg value="src/icon.png"/>
|
||||||
<arg value="--app-version"/> <arg value="${release.number}"/>
|
<arg value="--app-version"/> <arg value="${release.number}"/>
|
||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
</exec>
|
</exec>
|
||||||
@ -592,6 +595,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
</target>
|
</target>
|
||||||
<target name="fedora-release" depends="jar">
|
<target name="fedora-release" depends="jar">
|
||||||
@ -608,6 +612,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
</target>
|
</target>
|
||||||
<target name="windows" depends="jar">
|
<target name="windows" depends="jar">
|
||||||
@ -628,6 +633,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
</target>
|
</target>
|
||||||
<target name="windows-release" depends="jar">
|
<target name="windows-release" depends="jar">
|
||||||
@ -648,6 +654,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
</target>
|
</target>
|
||||||
<target name="windows-msi" depends="jar">
|
<target name="windows-msi" depends="jar">
|
||||||
@ -668,6 +675,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
</target>
|
</target>
|
||||||
<target name="windows-msi-release" depends="jar">
|
<target name="windows-msi-release" depends="jar">
|
||||||
@ -688,6 +696,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
</target>
|
</target>
|
||||||
<target name="windows-portable" depends="jar">
|
<target name="windows-portable" depends="jar">
|
||||||
@ -700,6 +709,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
<copy file="LICENSE.md" todir="i2pbrowser-portable" overwrite="true"/>
|
<copy file="LICENSE.md" todir="i2pbrowser-portable" overwrite="true"/>
|
||||||
<delete file="i2pbrowser-portable.zip"/>
|
<delete file="i2pbrowser-portable.zip"/>
|
||||||
@ -719,6 +729,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
<copy file="LICENSE.md" todir="i2pbrowser-portable" overwrite="true"/>
|
<copy file="LICENSE.md" todir="i2pbrowser-portable" overwrite="true"/>
|
||||||
<delete file="i2pbrowser-portable.zip"/>
|
<delete file="i2pbrowser-portable.zip"/>
|
||||||
@ -742,6 +753,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
</target>
|
</target>
|
||||||
<target name="macos-release" depends="jar">
|
<target name="macos-release" depends="jar">
|
||||||
@ -757,6 +769,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
</target>
|
</target>
|
||||||
<target name="macos-pkg" depends="jar">
|
<target name="macos-pkg" depends="jar">
|
||||||
@ -772,6 +785,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
</target>
|
</target>
|
||||||
<target name="macos-pkg-release" depends="jar">
|
<target name="macos-pkg-release" depends="jar">
|
||||||
@ -787,6 +801,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="--input"/> <arg value="src/build"/>
|
<arg value="--input"/> <arg value="src/build"/>
|
||||||
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
<arg value="--main-jar"/> <arg value="i2pfirefox.jar"/>
|
||||||
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
<arg value="--main-class"/> <arg value="net.i2p.i2pfirefox.I2PBrowser"/>
|
||||||
|
<arg value="--add-launcher"/> <arg value="i2pbrowser-usability=src/usability.properties"/>
|
||||||
</exec>
|
</exec>
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
@ -870,7 +885,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<redirector output="VERSION.md" error="VERSION.md" alwayslog="true" append="true"></redirector>
|
<redirector output="VERSION.md" error="VERSION.md" alwayslog="true" append="true"></redirector>
|
||||||
<arg value="```md"/>
|
<arg value="```md"/>
|
||||||
</exec>
|
</exec>
|
||||||
<exec executable="manifest-json-version" failonerror="true">
|
<!--<exec executable="manifest-json-version" failonerror="true">
|
||||||
<redirector output="VERSION.md" error="VERSION.md" alwayslog="true" append="true"></redirector>
|
<redirector output="VERSION.md" error="VERSION.md" alwayslog="true" append="true"></redirector>
|
||||||
<arg value="-mf"/>
|
<arg value="-mf"/>
|
||||||
<arg value="src/i2p.chromium.base.profile/extensions/i2pchrome.js/manifest.json"/>
|
<arg value="src/i2p.chromium.base.profile/extensions/i2pchrome.js/manifest.json"/>
|
||||||
@ -894,7 +909,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<redirector output="VERSION.md" error="VERSION.md" alwayslog="true" append="true"></redirector>
|
<redirector output="VERSION.md" error="VERSION.md" alwayslog="true" append="true"></redirector>
|
||||||
<arg value="-mf"/>
|
<arg value="-mf"/>
|
||||||
<arg value="src/i2p.chromium.usability.profile/extensions/jshelter.js/manifest.json"/>
|
<arg value="src/i2p.chromium.usability.profile/extensions/jshelter.js/manifest.json"/>
|
||||||
</exec>
|
</exec>-->
|
||||||
<exec executable="echo" failonerror="true">
|
<exec executable="echo" failonerror="true">
|
||||||
<redirector output="VERSION.md" error="VERSION.md" alwayslog="true" append="true"></redirector>
|
<redirector output="VERSION.md" error="VERSION.md" alwayslog="true" append="true"></redirector>
|
||||||
<arg value="```"/>
|
<arg value="```"/>
|
||||||
@ -903,20 +918,20 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
|
|
||||||
<target name="i2pChromiumBaseProfile">
|
<target name="i2pChromiumBaseProfile">
|
||||||
<mkdir dir="src/i2p.chromium.base.profile/extensions/" />
|
<mkdir dir="src/i2p.chromium.base.profile/extensions/" />
|
||||||
<exec executable="crx3" failonerror="true">
|
<!--<exec executable="crx3" failonerror="true">
|
||||||
<arg value="download"/>
|
<arg value="download"/>
|
||||||
<arg value="ikdjcmomgldfciocnpekfndklkfgglpe" />
|
<arg value="ikdjcmomgldfciocnpekfndklkfgglpe" />
|
||||||
<arg value="-u=true"/>
|
<arg value="-u=true"/>
|
||||||
<arg value="-o" />
|
<arg value="-o" />
|
||||||
<arg value="src/i2p.chromium.base.profile/extensions/i2pchrome.js.crx" />
|
<arg value="src/i2p.chromium.base.profile/extensions/i2pchrome.js.crx" />
|
||||||
</exec>
|
</exec>-->
|
||||||
<exec executable="crx3" failonerror="true">
|
<!--<exec executable="crx3" failonerror="true">
|
||||||
<arg value="download"/>
|
<arg value="download"/>
|
||||||
<arg value="doojmbjmlfjjnbmnoijecmcbfeoakpjm" />
|
<arg value="doojmbjmlfjjnbmnoijecmcbfeoakpjm" />
|
||||||
<arg value="-u=true"/>
|
<arg value="-u=true"/>
|
||||||
<arg value="-o" />
|
<arg value="-o" />
|
||||||
<arg value="src/i2p.chromium.base.profile/extensions/noscript.js.crx" />
|
<arg value="src/i2p.chromium.base.profile/extensions/noscript.js.crx" />
|
||||||
</exec>
|
</exec>-->
|
||||||
<exec executable="echo" failonerror="true" append="false" output="src/i2p.chromium.base.profile/version.md">
|
<exec executable="echo" failonerror="true" append="false" output="src/i2p.chromium.base.profile/version.md">
|
||||||
<arg value="Profile Version" />
|
<arg value="Profile Version" />
|
||||||
</exec>
|
</exec>
|
||||||
@ -936,7 +951,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
|
|
||||||
<target name="i2pChromiumUsabilityProfile">
|
<target name="i2pChromiumUsabilityProfile">
|
||||||
<mkdir dir="src/i2p.chromium.usability.profile/extensions/" />
|
<mkdir dir="src/i2p.chromium.usability.profile/extensions/" />
|
||||||
<exec executable="crx3" failonerror="true">
|
<!--<exec executable="crx3" failonerror="true">
|
||||||
<arg value="download"/>
|
<arg value="download"/>
|
||||||
<arg value="ikdjcmomgldfciocnpekfndklkfgglpe" />
|
<arg value="ikdjcmomgldfciocnpekfndklkfgglpe" />
|
||||||
<arg value="-u=true"/>
|
<arg value="-u=true"/>
|
||||||
@ -963,7 +978,7 @@ Linux(because the top command will be run and the script will exit).\n\nBoth det
|
|||||||
<arg value="-u=true"/>
|
<arg value="-u=true"/>
|
||||||
<arg value="-o" />
|
<arg value="-o" />
|
||||||
<arg value="src/i2p.chromium.usability.profile/extensions/localcdn.js.crx" />
|
<arg value="src/i2p.chromium.usability.profile/extensions/localcdn.js.crx" />
|
||||||
</exec>
|
</exec>-->
|
||||||
<exec executable="echo" failonerror="true" append="false" output="src/i2p.chromium.usability.profile/version.md">
|
<exec executable="echo" failonerror="true" append="false" output="src/i2p.chromium.usability.profile/version.md">
|
||||||
<arg value="Profile Version" />
|
<arg value="Profile Version" />
|
||||||
</exec>
|
</exec>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#! /usr/bin/env sh
|
#! /usr/bin/env sh
|
||||||
export GITHUB_USER=eyedeekay
|
export GITHUB_USER=eyedeekay
|
||||||
export GITHUB_REPO=i2p.plugins.firefox
|
export GITHUB_REPO=i2p.plugins.firefox
|
||||||
export GITHUB_NAME="Updates extensions, plugin support temporarily removed(Stay on the old version)"
|
export GITHUB_NAME="Fixes the build system"
|
||||||
export GITHUB_DESCRIPTION=$(cat CHANGES.md VERSION.md)
|
export GITHUB_DESCRIPTION=$(cat CHANGES.md VERSION.md)
|
||||||
export GITHUB_TAG=$(git describe --tags --abbrev=0)
|
export GITHUB_TAG=$(git describe --tags --abbrev=0)
|
Binary file not shown.
7
push.sh
Executable file
7
push.sh
Executable file
@ -0,0 +1,7 @@
|
|||||||
|
#! /usr/bin/env sh
|
||||||
|
|
||||||
|
nightly_hash=nightly-$(git log -1 --format=%H)
|
||||||
|
nightly_date=$(date)
|
||||||
|
git tag -m "$nightly_date" -s "$nightly_hash"
|
||||||
|
git push --all
|
||||||
|
git push --tags
|
@ -1,3 +1,3 @@
|
|||||||
#Build Number for ANT. Do not edit!
|
#Build Number for ANT. Do not edit!
|
||||||
#Mon Jul 08 17:35:59 EDT 2024
|
#Tue Jan 07 18:04:41 EST 2025
|
||||||
build.number=726
|
build.number=805
|
||||||
|
@ -26,7 +26,7 @@ import java.util.stream.Stream;
|
|||||||
* @author idk
|
* @author idk
|
||||||
* @since 0.0.1
|
* @since 0.0.1
|
||||||
*/
|
*/
|
||||||
public class I2PChromium extends I2PChromiumProfileUnpacker {
|
public class I2PChromium extends I2PChromiumProfileBuilder {
|
||||||
private final String[] CHROMIUM_SEARCH_PATHS = CHROMIUM_FINDER();
|
private final String[] CHROMIUM_SEARCH_PATHS = CHROMIUM_FINDER();
|
||||||
private Process p = null;
|
private Process p = null;
|
||||||
private String chromePath;
|
private String chromePath;
|
||||||
|
@ -30,8 +30,7 @@ public class I2PChromiumProfileBuilder extends I2PChromiumProfileChecker {
|
|||||||
return profileDir.getAbsolutePath();
|
return profileDir.getAbsolutePath();
|
||||||
} else {
|
} else {
|
||||||
// create the directory
|
// create the directory
|
||||||
I2PChromiumProfileUnpacker unpacker = new I2PChromiumProfileUnpacker();
|
if (!this.unpackProfile(profileDir.getAbsolutePath(), "chromium", mode)) {
|
||||||
if (!unpacker.unpackProfile(profileDir.getAbsolutePath(), mode)) {
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return profileDir.getAbsolutePath();
|
return profileDir.getAbsolutePath();
|
||||||
@ -54,8 +53,7 @@ public class I2PChromiumProfileBuilder extends I2PChromiumProfileChecker {
|
|||||||
if (pdf.exists() && pdf.isDirectory()) {
|
if (pdf.exists() && pdf.isDirectory()) {
|
||||||
return pd;
|
return pd;
|
||||||
} else {
|
} else {
|
||||||
I2PChromiumProfileUnpacker unpacker = new I2PChromiumProfileUnpacker();
|
if (!this.unpackProfile(pdf.getAbsolutePath(), "chromium", mode)) {
|
||||||
if (!unpacker.unpackProfile(pdf.getAbsolutePath(), mode)) {
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,42 +0,0 @@
|
|||||||
package net.i2p.i2pfirefox;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* I2PChromiumProfileUnpacker.java
|
|
||||||
* Copyright (C) 2022 idk <hankhill19580@gmail.com>
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the MIT License. See LICENSE.md for details.
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*
|
|
||||||
* I2PChromiumProfileUnpacker is a class that unpacks the Chromium profile zip
|
|
||||||
* file into the Chromium base profile directory. This is not used by the
|
|
||||||
* Chromium browser instance, it's unpacked to the disk to be copied to the
|
|
||||||
* active profile directory.
|
|
||||||
*
|
|
||||||
* @author idk
|
|
||||||
* @since 0.0.1
|
|
||||||
*/
|
|
||||||
public class I2PChromiumProfileUnpacker extends I2PChromiumProfileBuilder {
|
|
||||||
|
|
||||||
public static void main(String[] args) {
|
|
||||||
I2PChromiumProfileUnpacker pu = new I2PChromiumProfileUnpacker();
|
|
||||||
String profileDirectory = pu.profileDirectory("base");
|
|
||||||
if (profileDirectory == null) {
|
|
||||||
pu.logger.info("No profile directory found");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* unpack the profile directory
|
|
||||||
*
|
|
||||||
* @return true if the profile directory was successfully unpacked
|
|
||||||
* @since 0.0.1
|
|
||||||
*/
|
|
||||||
public boolean unpackProfile(String profileDirectory, String mode) {
|
|
||||||
logger.info("Unpacking base profile to " + profileDirectory);
|
|
||||||
return unpackProfile(profileDirectory, "chromium", mode);
|
|
||||||
}
|
|
||||||
}
|
|
@ -434,7 +434,7 @@ public class I2PCommonBrowser {
|
|||||||
* copied to
|
* copied to
|
||||||
* @throws IOException if an I/O error occurs during the file copy process
|
* @throws IOException if an I/O error occurs during the file copy process
|
||||||
*/
|
*/
|
||||||
private void copyFile(File sourceFile, File destinationFile)
|
public void copyFile(File sourceFile, File destinationFile)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
try (InputStream in = new FileInputStream(sourceFile);
|
try (InputStream in = new FileInputStream(sourceFile);
|
||||||
OutputStream out = new FileOutputStream(destinationFile)) {
|
OutputStream out = new FileOutputStream(destinationFile)) {
|
||||||
|
@ -1,9 +1,11 @@
|
|||||||
package net.i2p.i2pfirefox;
|
package net.i2p.i2pfirefox;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
import java.io.FileWriter;
|
import java.io.FileWriter;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
import java.io.PrintWriter;
|
import java.io.PrintWriter;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@ -27,7 +29,7 @@ import java.util.stream.Stream;
|
|||||||
* @author idk
|
* @author idk
|
||||||
* @since 0.0.1
|
* @since 0.0.1
|
||||||
*/
|
*/
|
||||||
public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
public class I2PFirefox extends I2PFirefoxProfileBuilder {
|
||||||
private final String[] FIREFOX_SEARCH_PATHS = FIREFOX_FINDER();
|
private final String[] FIREFOX_SEARCH_PATHS = FIREFOX_FINDER();
|
||||||
private Process process = null;
|
private Process process = null;
|
||||||
private String firefoxPath;
|
private String firefoxPath;
|
||||||
@ -124,6 +126,7 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
}
|
}
|
||||||
return exePath;
|
return exePath;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String[] firefoxPathsOSX() {
|
public String[] firefoxPathsOSX() {
|
||||||
String firefoxPathsProp = getProperties().getProperty("firefox.paths.osx");
|
String firefoxPathsProp = getProperties().getProperty("firefox.paths.osx");
|
||||||
if (firefoxPathsProp != null)
|
if (firefoxPathsProp != null)
|
||||||
@ -134,6 +137,7 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
"/Applications/Waterfox.app/Contents/MacOS",
|
"/Applications/Waterfox.app/Contents/MacOS",
|
||||||
"/Applications/Librewolf.app/Contents/MacOS"};
|
"/Applications/Librewolf.app/Contents/MacOS"};
|
||||||
}
|
}
|
||||||
|
|
||||||
private String[] FIND_FIREFOX_SEARCH_PATHS_OSX() {
|
private String[] FIND_FIREFOX_SEARCH_PATHS_OSX() {
|
||||||
String[] path = firefoxPathsOSX();
|
String[] path = firefoxPathsOSX();
|
||||||
String[] exes = firefoxBinsUnix();
|
String[] exes = firefoxBinsUnix();
|
||||||
@ -147,6 +151,7 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
}
|
}
|
||||||
return exePath;
|
return exePath;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String[] firefoxPathsWindows() {
|
public String[] firefoxPathsWindows() {
|
||||||
String firefoxPathsProp =
|
String firefoxPathsProp =
|
||||||
getProperties().getProperty("firefox.paths.windows");
|
getProperties().getProperty("firefox.paths.windows");
|
||||||
@ -181,6 +186,7 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
new File(programFiles, "Librewolf/").toString(),
|
new File(programFiles, "Librewolf/").toString(),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
private String[] firefoxBinsWindows() {
|
private String[] firefoxBinsWindows() {
|
||||||
String firefoxPathsProp =
|
String firefoxPathsProp =
|
||||||
getProperties().getProperty("firefox.bins.windows");
|
getProperties().getProperty("firefox.bins.windows");
|
||||||
@ -192,6 +198,7 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
"waterfox.exe", "waterfox-bin.exe", "librewolf.exe",
|
"waterfox.exe", "waterfox-bin.exe", "librewolf.exe",
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
private String[] FIND_FIREFOX_SEARCH_PATHS_WINDOWS() {
|
private String[] FIND_FIREFOX_SEARCH_PATHS_WINDOWS() {
|
||||||
String[] path = firefoxPathsWindows();
|
String[] path = firefoxPathsWindows();
|
||||||
String[] exes = firefoxBinsWindows();
|
String[] exes = firefoxBinsWindows();
|
||||||
@ -226,6 +233,7 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
}
|
}
|
||||||
return exePath;
|
return exePath;
|
||||||
}
|
}
|
||||||
|
|
||||||
private String[] FIND_FIREFOX_SEARCH_PATHS() {
|
private String[] FIND_FIREFOX_SEARCH_PATHS() {
|
||||||
switch (getOperatingSystem()) {
|
switch (getOperatingSystem()) {
|
||||||
case "Windows":
|
case "Windows":
|
||||||
@ -337,6 +345,7 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
|
|
||||||
return new String[] {};
|
return new String[] {};
|
||||||
}
|
}
|
||||||
|
|
||||||
private String[] FIREFOX_FINDER() {
|
private String[] FIREFOX_FINDER() {
|
||||||
String[] nearby = NEARBY_FIREFOX_SEARCH_PATHS();
|
String[] nearby = NEARBY_FIREFOX_SEARCH_PATHS();
|
||||||
String[] all = FIND_FIREFOX_SEARCH_PATHS();
|
String[] all = FIND_FIREFOX_SEARCH_PATHS();
|
||||||
@ -366,9 +375,10 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
if (firefoxFile.exists()) {
|
if (firefoxFile.exists()) {
|
||||||
logger.info("Found valid firefox at " + firefox);
|
logger.info("Found valid firefox at " + firefox);
|
||||||
validFirefoxes.add(firefox);
|
validFirefoxes.add(firefox);
|
||||||
}
|
} else {
|
||||||
logger.info("firefox at " + firefox + "does not exist");
|
logger.info("firefox at " + firefox + "does not exist");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return validFirefoxes.toArray(new String[validFirefoxes.size()]);
|
return validFirefoxes.toArray(new String[validFirefoxes.size()]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -552,9 +562,9 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
* @since 0.0.1
|
* @since 0.0.1
|
||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
public ProcessBuilder processBuilder(String[] args ) {
|
* public ProcessBuilder processBuilder(String[] args ) {
|
||||||
return processBuilder(args, false);
|
* return processBuilder(args, false);
|
||||||
}
|
* }
|
||||||
*/
|
*/
|
||||||
public ProcessBuilder processBuilder(String[] args, boolean app) {
|
public ProcessBuilder processBuilder(String[] args, boolean app) {
|
||||||
String firefox = topFirefox();
|
String firefox = topFirefox();
|
||||||
@ -683,7 +693,7 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
pb.environment().put("TOR_SKIP_CONTROLPORTTEST", "1");
|
pb.environment().put("TOR_SKIP_CONTROLPORTTEST", "1");
|
||||||
pb.environment().put("TOR_NONTOR_PROXY", "1");
|
pb.environment().put("TOR_NONTOR_PROXY", "1");
|
||||||
return pb;
|
return pb;
|
||||||
//}
|
// }
|
||||||
// return null;
|
// return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -693,12 +703,14 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
}
|
}
|
||||||
return "base";
|
return "base";
|
||||||
}
|
}
|
||||||
|
|
||||||
public Process launchAndDetatch(boolean privateWindow, String[] url) {
|
public Process launchAndDetatch(boolean privateWindow, String[] url) {
|
||||||
int privateWindowInt = 0;
|
int privateWindowInt = 0;
|
||||||
if (privateWindow)
|
if (privateWindow)
|
||||||
privateWindowInt = 1;
|
privateWindowInt = 1;
|
||||||
return launchAndDetatch(privateWindowInt, url);
|
return launchAndDetatch(privateWindowInt, url);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Process launchAndDetatch(int privateWindow, String[] url) {
|
public Process launchAndDetatch(int privateWindow, String[] url) {
|
||||||
validateUserDirectory();
|
validateUserDirectory();
|
||||||
boolean app = false;
|
boolean app = false;
|
||||||
@ -706,12 +718,13 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
app = true;
|
app = true;
|
||||||
if (waitForProxy()) {
|
if (waitForProxy()) {
|
||||||
String profileDirectory = this.profileDirectory(app, baseMode());
|
String profileDirectory = this.profileDirectory(app, baseMode());
|
||||||
if (this.validateProfileDirectory(profileDirectory)) {
|
if (this.validateProfileDirectory(profileDirectory) && !isTorBrowser()) {
|
||||||
logger.info("Valid profile directory: " + profileDirectory);
|
logger.info("Valid profile directory: " + profileDirectory);
|
||||||
} else {
|
} else {
|
||||||
logger.info("Invalid profile directory: " + profileDirectory +
|
logger.info("Invalid profile directory: " + profileDirectory +
|
||||||
" rebuilding...");
|
" rebuilding...");
|
||||||
if (!this.copyBaseProfiletoProfile(usabilityMode(), app)) {
|
if (!this.copyBaseProfiletoProfile(usabilityMode(), app,
|
||||||
|
isTorBrowser())) {
|
||||||
logger.info("Failed to rebuild profile directory: " +
|
logger.info("Failed to rebuild profile directory: " +
|
||||||
profileDirectory);
|
profileDirectory);
|
||||||
return null;
|
return null;
|
||||||
@ -720,7 +733,7 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (validateProfileFirstRun(profileDirectory)) {
|
if (validateProfileFirstRun(profileDirectory)) {
|
||||||
if (isWindows()) {
|
if (isWindows() && !isTorBrowser()) {
|
||||||
ProcessBuilder hpb = headlessProcessBuilder(url);
|
ProcessBuilder hpb = headlessProcessBuilder(url);
|
||||||
try {
|
try {
|
||||||
Process hp = hpb.start();
|
Process hp = hpb.start();
|
||||||
@ -797,6 +810,7 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
priv = 1;
|
priv = 1;
|
||||||
launch(priv, url);
|
launch(priv, url);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void launch(int privateWindow, String[] url) {
|
public void launch(int privateWindow, String[] url) {
|
||||||
if (waitForProxy()) {
|
if (waitForProxy()) {
|
||||||
process = launchAndDetatch(privateWindow, url);
|
process = launchAndDetatch(privateWindow, url);
|
||||||
@ -902,12 +916,40 @@ public class I2PFirefox extends I2PFirefoxProfileUnpacker {
|
|||||||
visitURL.toArray(new String[visitURL.size()]));
|
visitURL.toArray(new String[visitURL.size()]));
|
||||||
}
|
}
|
||||||
|
|
||||||
/*private void sleep(int millis) {
|
public boolean isTorBrowser() {
|
||||||
|
String[] args = {"--version"};
|
||||||
|
ProcessBuilder tpb = defaultProcessBuilder(args);
|
||||||
try {
|
try {
|
||||||
Thread.sleep(millis);
|
Process tp = tpb.start();
|
||||||
} catch (InterruptedException bad) {
|
BufferedReader reader =
|
||||||
bad.printStackTrace();
|
new BufferedReader(new InputStreamReader(tp.getInputStream()));
|
||||||
throw new RuntimeException(bad);
|
StringBuilder builder = new StringBuilder();
|
||||||
|
String line = null;
|
||||||
|
while ((line = reader.readLine()) != null) {
|
||||||
|
builder.append(line);
|
||||||
|
builder.append(System.getProperty("line.separator"));
|
||||||
}
|
}
|
||||||
}*/
|
String result = builder.toString().toLowerCase();
|
||||||
|
if (result.contains("tor ")) {
|
||||||
|
logger.info("running in Tor Browser, modifying only required config");
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
logger.info("running in regular Firefox, using extended config");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* private void sleep(int millis) {s
|
||||||
|
* try {
|
||||||
|
* Thread.sleep(millis);
|
||||||
|
* } catch (InterruptedException bad) {
|
||||||
|
* bad.printStackTrace();
|
||||||
|
* throw new RuntimeException(bad);
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package net.i2p.i2pfirefox;
|
package net.i2p.i2pfirefox;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.io.FileWriter;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.StandardCopyOption;
|
import java.nio.file.StandardCopyOption;
|
||||||
@ -25,6 +26,44 @@ import java.nio.file.StandardCopyOption;
|
|||||||
*/
|
*/
|
||||||
public class I2PFirefoxProfileBuilder extends I2PFirefoxProfileChecker {
|
public class I2PFirefoxProfileBuilder extends I2PFirefoxProfileChecker {
|
||||||
private boolean strict;
|
private boolean strict;
|
||||||
|
|
||||||
|
private String TBB_BASE =
|
||||||
|
"user_pref(\"extensions.torbutton.use_nontor_proxy\", true);\n"
|
||||||
|
+ "user_pref(\"extensions.torlauncher.start_tor\", false);\n"
|
||||||
|
+ "user_pref(\"extensions.torlauncher.prompt_at_startup\", false);\n"
|
||||||
|
+
|
||||||
|
"user_pref(\"network.proxy.no_proxies_on\", \"127.0.0.1:7657,localhost:7657,127.0.0.1:7662,localhost:7662,127.0.0.1:7669,localhost:7669\");\n"
|
||||||
|
+ "user_pref(\"network.proxy.type\", 1);\n"
|
||||||
|
+ "user_pref(\"network.proxy.http\", \"127.0.0.1\");\n"
|
||||||
|
+ "user_pref(\"network.proxy.http_port\", 4444);\n"
|
||||||
|
+ "user_pref(\"network.proxy.ssl\", \"127.0.0.1\");\n"
|
||||||
|
+ "user_pref(\"network.proxy.ssl_port\", 4444);\n"
|
||||||
|
+ "user_pref(\"network.proxy.ftp\", \"127.0.0.1\");"
|
||||||
|
+ "user_pref(\"network.proxy.ftp_port\", 4444);\n"
|
||||||
|
+ "user_pref(\"network.proxy.socks\", \"127.0.0.1\");\n"
|
||||||
|
+ "user_pref(\"network.proxy.socks_port\", 4444);\n"
|
||||||
|
+ "user_pref(\"network.proxy.share_proxy_settings\", true);\n"
|
||||||
|
+ "user_pref(\"browser.startup.homepage\", \"about:blank\");\n"
|
||||||
|
+ "user_pref(\"keyword.enabled\", false);\n"
|
||||||
|
+ "user_pref(\"extensions.allowPrivateBrowsingByDefault\", true);\n"
|
||||||
|
+ "user_pref(\"extensions.PrivateBrowsing.notification\", false);\n"
|
||||||
|
+ "user_pref(\"extensions.pocket.enabled\", false);\n"
|
||||||
|
+
|
||||||
|
"user_pref(\"browser.newtabpage.activity-stream.showSponsoredTopSites\", false);\n"
|
||||||
|
+
|
||||||
|
"user_pref(\"browser.newtabpage.activity-stream.showSponsored\", false);\n"
|
||||||
|
+
|
||||||
|
"user_pref(\"services.sync.prefs.sync.browser.newtabpage.activity-stream.showSponsored\", false);\n"
|
||||||
|
+
|
||||||
|
"user_pref(\"browser.newtabpage.activity-stream.feeds.section.highlights\", false);\n"
|
||||||
|
+
|
||||||
|
"user_pref(\"browser.newtabpage.activity-stream.feeds.section.topstories\", false);\n"
|
||||||
|
+
|
||||||
|
"user_pref(\"browser.newtabpage.activity-stream.default.sites\", \"http://planet.i2p/,http://legwork.i2p/,http://i2pwiki.i2p/,http://i2pforums.i2p/,http://zzz.i2p/\");\n"
|
||||||
|
+
|
||||||
|
"user_pref(\"browser.newtabpage.activity-stream.feeds.topsites\", true);\n"
|
||||||
|
+ "user_pref(\"browser.fixup.domainsuffixwhitelist.i2p\", true);\n";
|
||||||
|
|
||||||
private String userChromeCSS() {
|
private String userChromeCSS() {
|
||||||
String ret =
|
String ret =
|
||||||
"@namespace url(\"http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul\")\n";
|
"@namespace url(\"http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul\")\n";
|
||||||
@ -102,17 +141,22 @@ public class I2PFirefoxProfileBuilder extends I2PFirefoxProfileChecker {
|
|||||||
// return profileDirectory("I2P_FIREFOX_PROFILE", "firefox", false);
|
// return profileDirectory("I2P_FIREFOX_PROFILE", "firefox", false);
|
||||||
// }
|
// }
|
||||||
|
|
||||||
private String baseProfileDir(String file, String base) {
|
private String baseProfileDir(String file, String base,
|
||||||
|
boolean isTorBrowser) {
|
||||||
File profileDir = new File(file, "i2p.firefox." + base + ".profile");
|
File profileDir = new File(file, "i2p.firefox." + base + ".profile");
|
||||||
// make sure the directory exists
|
// make sure the directory exists
|
||||||
if (profileDir.exists()) {
|
if (profileDir.exists()) {
|
||||||
return profileDir.getAbsolutePath();
|
return profileDir.getAbsolutePath();
|
||||||
} else {
|
} else {
|
||||||
// create the directory
|
// create the directory
|
||||||
I2PFirefoxProfileUnpacker unpacker = new I2PFirefoxProfileUnpacker();
|
if (!isTorBrowser) {
|
||||||
if (!unpacker.unpackProfile(profileDir.getAbsolutePath(), base)) {
|
if (!this.unpackProfile(profileDir.getAbsolutePath(), "firefox",
|
||||||
|
base)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
makeTBBDirectory(profileDir, profileDir);
|
||||||
|
}
|
||||||
return profileDir.getAbsolutePath();
|
return profileDir.getAbsolutePath();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -122,21 +166,20 @@ public class I2PFirefoxProfileBuilder extends I2PFirefoxProfileChecker {
|
|||||||
*
|
*
|
||||||
* @return the base profile directory, or null if it could not be created
|
* @return the base profile directory, or null if it could not be created
|
||||||
*/
|
*/
|
||||||
public String baseProfileDirectory(String base) {
|
public String baseProfileDirectory(String base, boolean isTorBrowser) {
|
||||||
String pd = System.getenv("I2P_FIREFOX_BASE_PROFILE");
|
String pd = System.getenv("I2P_FIREFOX_BASE_PROFILE");
|
||||||
if (pd != null && !pd.isEmpty()) {
|
if (pd != null && !pd.isEmpty()) {
|
||||||
File pdf = new File(pd);
|
File pdf = new File(pd);
|
||||||
if (pdf.exists() && pdf.isDirectory()) {
|
if (pdf.exists() && pdf.isDirectory()) {
|
||||||
return pd;
|
return pd;
|
||||||
} else {
|
} else {
|
||||||
I2PFirefoxProfileUnpacker unpacker = new I2PFirefoxProfileUnpacker();
|
if (!this.unpackProfile(pdf.getAbsolutePath(), "firefox", base)) {
|
||||||
if (!unpacker.unpackProfile(pdf.getAbsolutePath(), base)) {
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
String rtd = runtimeDirectory();
|
String rtd = runtimeDirectory();
|
||||||
return baseProfileDir(rtd, base);
|
return baseProfileDir(rtd, base, isTorBrowser);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -177,11 +220,10 @@ public class I2PFirefoxProfileBuilder extends I2PFirefoxProfileChecker {
|
|||||||
*
|
*
|
||||||
* @since 0.0.1
|
* @since 0.0.1
|
||||||
*/
|
*/
|
||||||
public boolean copyBaseProfiletoProfile(String base, boolean app) {
|
public boolean copyBaseProfiletoProfile(String base, boolean app,
|
||||||
String baseProfile = baseProfileDirectory(base);
|
boolean isTorBrowser) {
|
||||||
|
String baseProfile = baseProfileDirectory(base, isTorBrowser);
|
||||||
String profile = profileDirectory(app, base);
|
String profile = profileDirectory(app, base);
|
||||||
logger.info("Copying base profile to profile directory: " + baseProfile +
|
|
||||||
" -> " + profile);
|
|
||||||
if (baseProfile.isEmpty() || profile.isEmpty()) {
|
if (baseProfile.isEmpty() || profile.isEmpty()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -190,24 +232,31 @@ public class I2PFirefoxProfileBuilder extends I2PFirefoxProfileChecker {
|
|||||||
|
|
||||||
if (!profileDir.exists()) {
|
if (!profileDir.exists()) {
|
||||||
try {
|
try {
|
||||||
logger.info("Copying base profile to profile directory");
|
if (!isTorBrowser) {
|
||||||
|
logger.info("Copying base profile to profile directory: " +
|
||||||
|
baseProfile + " -> " + profile);
|
||||||
copyDirectory(baseProfileDir, profileDir, "firefox", base);
|
copyDirectory(baseProfileDir, profileDir, "firefox", base);
|
||||||
|
} else {
|
||||||
|
logger.info("Creating base directory for use with Tor Browser");
|
||||||
|
makeTBBDirectory(baseProfileDir, profileDir);
|
||||||
|
}
|
||||||
|
logger.info("Copied base profile to profile directory");
|
||||||
|
return true;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
logger.info("Error copying base profile to profile" + e);
|
logger.info("Error copying base profile to profile" + e);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
logger.info("Copied base profile to profile directory");
|
|
||||||
}
|
}
|
||||||
// if user.js does not exist yet, make an empty one.
|
// if user.js does not exist yet, make an empty one.
|
||||||
// if (!touch(profileDir.toString(), "user.js")) {
|
// if (!touch(profileDir.toString(), "user.js")) {
|
||||||
// return false;
|
// return false;
|
||||||
//}
|
// }
|
||||||
// if extensions does not exist yet, make an empty one.
|
// if extensions does not exist yet, make an empty one.
|
||||||
// if (!mkExtensionsDir(profileDir.toString())){
|
// if (!mkExtensionsDir(profileDir.toString())){
|
||||||
// return false;
|
// return false;
|
||||||
//}
|
// }
|
||||||
|
|
||||||
return copyStrictOptions(base, app);
|
return copyStrictOptions(base, app, isTorBrowser);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected boolean writeAppChrome(String profile) {
|
protected boolean writeAppChrome(String profile) {
|
||||||
@ -223,6 +272,7 @@ public class I2PFirefoxProfileBuilder extends I2PFirefoxProfileChecker {
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected boolean deleteAppChrome(String profile) {
|
protected boolean deleteAppChrome(String profile) {
|
||||||
File dir = new File(profile, "chrome");
|
File dir = new File(profile, "chrome");
|
||||||
if (!dir.exists())
|
if (!dir.exists())
|
||||||
@ -232,15 +282,17 @@ public class I2PFirefoxProfileBuilder extends I2PFirefoxProfileChecker {
|
|||||||
f.delete();
|
f.delete();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Copy the strict options from the base profile to the profile
|
* Copy the strict options from the base profile to the profile
|
||||||
*
|
*
|
||||||
* @return true if successful, false otherwise
|
* @return true if successful, false otherwise
|
||||||
* @since 0.0.1
|
* @since 0.0.1
|
||||||
*/
|
*/
|
||||||
public boolean copyStrictOptions(String base, boolean app) {
|
public boolean copyStrictOptions(String base, boolean app,
|
||||||
|
boolean isTorBrowser) {
|
||||||
logger.info("Checking strict options");
|
logger.info("Checking strict options");
|
||||||
String baseProfile = baseProfileDirectory(base);
|
String baseProfile = baseProfileDirectory(base, isTorBrowser);
|
||||||
String profile = profileDirectory(app, base);
|
String profile = profileDirectory(app, base);
|
||||||
if (baseProfile.isEmpty() || profile.isEmpty()) {
|
if (baseProfile.isEmpty() || profile.isEmpty()) {
|
||||||
logger.info("Empty paths");
|
logger.info("Empty paths");
|
||||||
@ -249,8 +301,8 @@ public class I2PFirefoxProfileBuilder extends I2PFirefoxProfileChecker {
|
|||||||
File baseProfileDir = new File(baseProfile);
|
File baseProfileDir = new File(baseProfile);
|
||||||
File profileDir = new File(profile);
|
File profileDir = new File(profile);
|
||||||
setupUserChrome(profileDir, app);
|
setupUserChrome(profileDir, app);
|
||||||
if (!baseProfileDir.exists() || !profileDir.exists()) {
|
if (!baseProfileDir.exists()) {
|
||||||
logger.info("Empty directories");
|
logger.info("Empty base directories: " + baseProfileDir);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
File baseOverrides = new File(baseProfile, "strict-overrides.js");
|
File baseOverrides = new File(baseProfile, "strict-overrides.js");
|
||||||
@ -317,6 +369,20 @@ public class I2PFirefoxProfileBuilder extends I2PFirefoxProfileChecker {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void makeTBBDirectory(File sourceDir, File destDir) {
|
||||||
|
logger.info("creating TBB directory");
|
||||||
|
if (!destDir.exists())
|
||||||
|
destDir.mkdir();
|
||||||
|
File workUserJs = new File(destDir, "user.js");
|
||||||
|
// Write the value of TBB_BASE to the file workUserJs
|
||||||
|
try (FileWriter writer = new FileWriter(workUserJs)) {
|
||||||
|
logger.info("writing TBB user.js");
|
||||||
|
writer.write(TBB_BASE);
|
||||||
|
} catch (IOException e) {
|
||||||
|
logger.info("Error writing to file: " + e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Construct a new Profile Builder
|
* Construct a new Profile Builder
|
||||||
*
|
*
|
||||||
@ -326,6 +392,7 @@ public class I2PFirefoxProfileBuilder extends I2PFirefoxProfileChecker {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Construct a new Profile Builder
|
* Construct a new Profile Builder
|
||||||
|
*
|
||||||
* @param strict if true, the strict overrides will be copied to the profile
|
* @param strict if true, the strict overrides will be copied to the profile
|
||||||
*
|
*
|
||||||
* @since 0.0.1
|
* @since 0.0.1
|
||||||
|
@ -1,41 +0,0 @@
|
|||||||
package net.i2p.i2pfirefox;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* I2PFirefoxProfileUnpacker.java
|
|
||||||
* Copyright (C) 2022 idk <hankhill19580@gmail.com>
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the MIT License. See LICENSE.md for details.
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*
|
|
||||||
* I2PFirefoxProfileUnpacker is a class that unpacks the I2P Firefox profile
|
|
||||||
* from a zip file embedded in the `jar` file. The zip is unpacked to a base
|
|
||||||
* directory where it is left untouched, and the base profile is copied to the
|
|
||||||
* active profile directory.
|
|
||||||
*
|
|
||||||
* @author idk
|
|
||||||
* @since 0.0.1
|
|
||||||
*/
|
|
||||||
public class I2PFirefoxProfileUnpacker extends I2PFirefoxProfileBuilder {
|
|
||||||
|
|
||||||
public static void main(String[] args) {
|
|
||||||
I2PFirefoxProfileUnpacker up = new I2PFirefoxProfileUnpacker();
|
|
||||||
String profileDirectory = up.profileDirectory(false, "base");
|
|
||||||
if (profileDirectory == null) {
|
|
||||||
up.logger.info("No profile directory found");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* unpack the profile directory
|
|
||||||
*
|
|
||||||
* @return true if the profile directory was successfully unpacked
|
|
||||||
* @since 0.0.1
|
|
||||||
*/
|
|
||||||
public boolean unpackProfile(String profileDirectory, String base) {
|
|
||||||
return unpackProfile(profileDirectory, "firefox", base);
|
|
||||||
}
|
|
||||||
}
|
|
@ -116,7 +116,7 @@ public class I2PBrowserPlugin extends I2PBrowser implements ClientApp {
|
|||||||
_log.info("I2P Browser tray manager not supported");
|
_log.info("I2P Browser tray manager not supported");
|
||||||
try {
|
try {
|
||||||
I2PBrowser i2pBrowser = new I2PBrowser(profileDir.getAbsolutePath());
|
I2PBrowser i2pBrowser = new I2PBrowser(profileDir.getAbsolutePath());
|
||||||
String[] args = {"http://proxy.i2p"};
|
String[] args = {"http://127.0.0.1:7657"};
|
||||||
i2pBrowser.launchFirefox(0, args);
|
i2pBrowser.launchFirefox(0, args);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
_log.error("Error starting I2P Browser", e);
|
_log.error("Error starting I2P Browser", e);
|
||||||
@ -124,7 +124,7 @@ public class I2PBrowserPlugin extends I2PBrowser implements ClientApp {
|
|||||||
} else {
|
} else {
|
||||||
try {
|
try {
|
||||||
_log.info(
|
_log.info(
|
||||||
"Starting I2P Browser tray manager by testing http://proxy.i2p");
|
"Starting I2P Browser tray manager by testing http://127.0.0.1:7657");
|
||||||
MenuService dtg = startTrayApp();
|
MenuService dtg = startTrayApp();
|
||||||
try {
|
try {
|
||||||
Thread.sleep(5000);
|
Thread.sleep(5000);
|
||||||
@ -144,7 +144,7 @@ public class I2PBrowserPlugin extends I2PBrowser implements ClientApp {
|
|||||||
_log.info("I2P Browser tray manager not found");
|
_log.info("I2P Browser tray manager not found");
|
||||||
}
|
}
|
||||||
I2PBrowser i2pBrowser = new I2PBrowser(profileDir.getAbsolutePath());
|
I2PBrowser i2pBrowser = new I2PBrowser(profileDir.getAbsolutePath());
|
||||||
String[] args = {"http://proxy.i2p"};
|
String[] args = {"http://127.0.0.1:7657"};
|
||||||
i2pBrowser.launchFirefox(0, args);
|
i2pBrowser.launchFirefox(0, args);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
_log.error("Error starting I2P Browser tray manager", e);
|
_log.error("Error starting I2P Browser tray manager", e);
|
||||||
@ -190,8 +190,8 @@ public class I2PBrowserPlugin extends I2PBrowser implements ClientApp {
|
|||||||
// Ubuntu GNOME does not work, SystemTray.isSupported() returns false
|
// Ubuntu GNOME does not work, SystemTray.isSupported() returns false
|
||||||
String xdg = System.getenv("XDG_CURRENT_DESKTOP");
|
String xdg = System.getenv("XDG_CURRENT_DESKTOP");
|
||||||
boolean dflt = SystemVersion.isWindows() || SystemVersion.isMac() ||
|
boolean dflt = SystemVersion.isWindows() || SystemVersion.isMac() ||
|
||||||
"XFCE".equals(xdg) ||
|
"XFCE".equals(xdg) || "KDE".equals(xdg) ||
|
||||||
"KDE".equals(xdg) || "LXDE".equals(xdg);
|
"LXDE".equals(xdg);
|
||||||
return _context.getProperty(PROP_DTG_ENABLED, dflt);
|
return _context.getProperty(PROP_DTG_ENABLED, dflt);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -211,7 +211,7 @@ public class I2PBrowserPlugin extends I2PBrowser implements ClientApp {
|
|||||||
_log.info("I2P Browser starting up");
|
_log.info("I2P Browser starting up");
|
||||||
try {
|
try {
|
||||||
I2PBrowser i2pBrowser = new I2PBrowser(profileDir.getAbsolutePath());
|
I2PBrowser i2pBrowser = new I2PBrowser(profileDir.getAbsolutePath());
|
||||||
String[] args = {"http://proxy.i2p"};
|
String[] args = {"http://127.0.0.1:7657"};
|
||||||
i2pBrowser.launchFirefox(0, args);
|
i2pBrowser.launchFirefox(0, args);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
_log.error("Error starting I2P Browser", e);
|
_log.error("Error starting I2P Browser", e);
|
||||||
@ -235,7 +235,7 @@ public class I2PBrowserPlugin extends I2PBrowser implements ClientApp {
|
|||||||
try {
|
try {
|
||||||
I2PBrowser i2pBrowser = new I2PBrowser(profileDir.getAbsolutePath());
|
I2PBrowser i2pBrowser = new I2PBrowser(profileDir.getAbsolutePath());
|
||||||
i2pBrowser.usability = true;
|
i2pBrowser.usability = true;
|
||||||
String[] args = {"http://proxy.i2p"};
|
String[] args = {"http://127.0.0.1:7657"};
|
||||||
i2pBrowser.launchFirefox(0, args);
|
i2pBrowser.launchFirefox(0, args);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
_log.error("Error starting I2P Browser", e);
|
_log.error("Error starting I2P Browser", e);
|
||||||
|
19
src/prefs.js
19
src/prefs.js
@ -19,11 +19,6 @@ user_pref("extensions.torlauncher.start_tor", false);
|
|||||||
//user_pref("extensions.torlauncher.default_bridge_type", "");
|
//user_pref("extensions.torlauncher.default_bridge_type", "");
|
||||||
user_pref("extensions.torlauncher.prompt_at_startup", false);
|
user_pref("extensions.torlauncher.prompt_at_startup", false);
|
||||||
|
|
||||||
// Resist-fingerprinting and first-party isolation enable
|
|
||||||
|
|
||||||
user_pref("privacy.resistFingerprinting", true);
|
|
||||||
user_pref("privacy.firstparty.isolate", true);
|
|
||||||
|
|
||||||
// Use i2p http proxy for all connections and set homepage to safe local form.
|
// Use i2p http proxy for all connections and set homepage to safe local form.
|
||||||
|
|
||||||
// DON'T allow access to the admin panel from the profile we browse i2p with.
|
// DON'T allow access to the admin panel from the profile we browse i2p with.
|
||||||
@ -39,7 +34,6 @@ user_pref("network.proxy.socks", "127.0.0.1");
|
|||||||
user_pref("network.proxy.socks_port", 4444);
|
user_pref("network.proxy.socks_port", 4444);
|
||||||
user_pref("network.proxy.share_proxy_settings", true);
|
user_pref("network.proxy.share_proxy_settings", true);
|
||||||
user_pref("browser.startup.homepage", "about:blank");
|
user_pref("browser.startup.homepage", "about:blank");
|
||||||
user_pref("dom.security.https_only_mode", false);
|
|
||||||
user_pref("keyword.enabled", false);
|
user_pref("keyword.enabled", false);
|
||||||
user_pref("extensions.allowPrivateBrowsingByDefault", true);
|
user_pref("extensions.allowPrivateBrowsingByDefault", true);
|
||||||
user_pref("extensions.PrivateBrowsing.notification", false);
|
user_pref("extensions.PrivateBrowsing.notification", false);
|
||||||
@ -51,17 +45,4 @@ user_pref("browser.newtabpage.activity-stream.feeds.section.highlights", false);
|
|||||||
user_pref("browser.newtabpage.activity-stream.feeds.section.topstories", false);
|
user_pref("browser.newtabpage.activity-stream.feeds.section.topstories", false);
|
||||||
user_pref("browser.newtabpage.activity-stream.default.sites", "http://planet.i2p/,http://legwork.i2p/,http://i2pwiki.i2p/,http://i2pforums.i2p/,http://zzz.i2p/");
|
user_pref("browser.newtabpage.activity-stream.default.sites", "http://planet.i2p/,http://legwork.i2p/,http://i2pwiki.i2p/,http://i2pforums.i2p/,http://zzz.i2p/");
|
||||||
user_pref("browser.newtabpage.activity-stream.feeds.topsites", true);
|
user_pref("browser.newtabpage.activity-stream.feeds.topsites", true);
|
||||||
user_pref("ui.use_standins_for_native_colors", true);
|
|
||||||
user_pref("webgl.disable-extensions", true);
|
|
||||||
user_pref("webgl.min_capability_mode", true);
|
|
||||||
user_pref("webgl.disable-fail-if-major-performance-caveat", true);
|
|
||||||
user_pref("webgl.enable-webgl2", false);
|
|
||||||
user_pref("media.navigator.enabled", false);
|
|
||||||
user_pref("dom.w3c_touch_events.enabled", false);
|
|
||||||
user_pref("browser.privatebrowsing.autostart", false);
|
|
||||||
user_pref("browser.display.use_system_colors", false);
|
|
||||||
user_pref("dom.image-lazy-loading.enabled", false);
|
|
||||||
user_pref("extensions.autoDisableScopes", 0);
|
|
||||||
user_pref("extensions.enabledScopes", 1);
|
|
||||||
user_pref("toolkit.legacyUserProfileCustomizations.stylesheets", false);
|
|
||||||
user_pref("browser.fixup.domainsuffixwhitelist.i2p", true);
|
user_pref("browser.fixup.domainsuffixwhitelist.i2p", true);
|
2
src/usability.properties
Normal file
2
src/usability.properties
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
main-class=net.i2p.i2pfirefox.I2PBrowser
|
||||||
|
arguments=-usability
|
@ -229,3 +229,23 @@ user_pref("browser.privatebrowsing.autostart", false);
|
|||||||
user_pref("browser.display.use_system_colors", false);
|
user_pref("browser.display.use_system_colors", false);
|
||||||
user_pref("toolkit.legacyUserProfileCustomizations.stylesheets", false);
|
user_pref("toolkit.legacyUserProfileCustomizations.stylesheets", false);
|
||||||
user_pref("browser.fixup.domainsuffixwhitelist.i2p", true);
|
user_pref("browser.fixup.domainsuffixwhitelist.i2p", true);
|
||||||
|
|
||||||
|
user_pref("ui.use_standins_for_native_colors", true);
|
||||||
|
user_pref("webgl.disable-extensions", true);
|
||||||
|
user_pref("webgl.min_capability_mode", true);
|
||||||
|
user_pref("webgl.disable-fail-if-major-performance-caveat", true);
|
||||||
|
user_pref("webgl.enable-webgl2", false);
|
||||||
|
user_pref("media.navigator.enabled", false);
|
||||||
|
user_pref("dom.w3c_touch_events.enabled", false);
|
||||||
|
user_pref("browser.privatebrowsing.autostart", false);
|
||||||
|
user_pref("browser.display.use_system_colors", false);
|
||||||
|
user_pref("dom.image-lazy-loading.enabled", false);
|
||||||
|
user_pref("extensions.autoDisableScopes", 0);
|
||||||
|
user_pref("extensions.enabledScopes", 1);
|
||||||
|
user_pref("toolkit.legacyUserProfileCustomizations.stylesheets", false);
|
||||||
|
user_pref("dom.security.https_only_mode", false);
|
||||||
|
|
||||||
|
// Resist-fingerprinting and first-party isolation enable
|
||||||
|
|
||||||
|
user_pref("privacy.resistFingerprinting", true);
|
||||||
|
user_pref("privacy.firstparty.isolate", true);
|
43
tools.sh
Executable file
43
tools.sh
Executable file
@ -0,0 +1,43 @@
|
|||||||
|
#! /usr/bin/env sh
|
||||||
|
|
||||||
|
. ./config.sh
|
||||||
|
#./preprelease.sh
|
||||||
|
github-release release --user "${GITHUB_USER}" \
|
||||||
|
--repo "${GITHUB_REPO}" \
|
||||||
|
--name "Build Tools" \
|
||||||
|
--description "binaries required for generating the profiles" \
|
||||||
|
--tag "build-tools"; true
|
||||||
|
echo "Uploading generated build-tools"
|
||||||
|
sleep 2s
|
||||||
|
torsum=$(sha256sum $HOME/go/bin/crx3 | sed "s|$HOME||g")
|
||||||
|
echo "$torsum"
|
||||||
|
github-release upload --user "${GITHUB_USER}" \
|
||||||
|
--replace \
|
||||||
|
--repo "${GITHUB_REPO}" \
|
||||||
|
--tag "build-tools" \
|
||||||
|
--label "crx3 for Linux. ${torsum}" \
|
||||||
|
--name "crx3-linux" \
|
||||||
|
--file "$HOME/go/bin/crx3"
|
||||||
|
echo "Uploaded crx3 linux package"
|
||||||
|
torsum=$(sha256sum $HOME/go/bin/darwin_amd64/crx3 | sed "s|$HOME||g")
|
||||||
|
echo "$torsum"
|
||||||
|
github-release upload --user "${GITHUB_USER}" \
|
||||||
|
--replace \
|
||||||
|
--repo "${GITHUB_REPO}" \
|
||||||
|
--tag "build-tools" \
|
||||||
|
--label "crx3 for Mac. ${torsum}" \
|
||||||
|
--name "crx3-osx" \
|
||||||
|
--file "$HOME/go/bin/darwin_amd64/crx3"
|
||||||
|
echo "Uploaded crx3 mac package"
|
||||||
|
torsum=$(sha256sum $HOME/go/bin/windows_amd64/crx3.exe | sed "s|$HOME||g")
|
||||||
|
echo "$torsum"
|
||||||
|
github-release upload --user "${GITHUB_USER}" \
|
||||||
|
--replace \
|
||||||
|
--repo "${GITHUB_REPO}" \
|
||||||
|
--tag "build-tools" \
|
||||||
|
--label "crx3 for Windows. ${torsum}" \
|
||||||
|
--name "crx3.exe" \
|
||||||
|
--file "$HOME/go/bin/windows_amd64/crx3.exe"
|
||||||
|
echo "Uploaded crx3 windows package"
|
||||||
|
git pull github --tags
|
||||||
|
git push --all
|
Reference in New Issue
Block a user