Compare commits
135 Commits
v4-0.3-0.9
...
EXPERIMENT
Author | SHA1 | Date | |
---|---|---|---|
220b6756b6 | |||
7f7f021e45 | |||
f9b02fe13f | |||
6026ee3ec6 | |||
3c508f4190 | |||
91abc574d3 | |||
bae0412ebc | |||
e73a5969db | |||
e764c7b773 | |||
7c62c8ecda | |||
d13e2317dd | |||
7ff4eb5e37 | |||
e6928d64ce | |||
ad373eface | |||
d52e79c72e | |||
71b9b9c6ec | |||
f8ff48f723 | |||
8b089ad49e | |||
afdb51370e | |||
2ff2e462a9 | |||
41f4f80a4d | |||
aee8cdbe5f | |||
15a2386981 | |||
8aefcff4b1 | |||
1b35c8dc8b | |||
e7ea163a64 | |||
2b95573f7a | |||
51aa9a97b1 | |||
8737093b6d | |||
688b9ca309 | |||
ac7336f669 | |||
51a63dfb35 | |||
2c328bec86 | |||
fa54305df3 | |||
d7036f7a96 | |||
111ecebe6c | |||
272ff689e7 | |||
3b544d0e25 | |||
7b24afba86 | |||
5b8c3e4b2a | |||
86b6413a9b | |||
cd15ee07c1 | |||
59ca9d1d7f | |||
94feece528 | |||
fc1cce1f4b | |||
5218f18599 | |||
b79044bcce | |||
8453c4092c | |||
a90e7db310 | |||
eacb19034a | |||
14b40177fe | |||
f54d989ea7 | |||
99f6029578 | |||
50097f335a | |||
d943bf98ca | |||
1504d65ba7 | |||
7ef6e9149d | |||
a8117ce0fc | |||
1430d73103 | |||
b5de7de981 | |||
59dc5d65e0 | |||
6165131c66 | |||
a5db548ad5 | |||
7dfd857b43 | |||
008025d76f | |||
755a47d6f2 | |||
97f3dbd71f | |||
ffd7bfb834 | |||
ab58ec31ff | |||
da9f7695a7 | |||
a6481d7bd7 | |||
d9025e5853 | |||
27328d5141 | |||
b3967525e5 | |||
5e55b9068f | |||
c467296aad | |||
dfe9ff50ee | |||
72ca56e9a1 | |||
b62d64bb0f | |||
8424727dae | |||
10f02140a3 | |||
c66d08d9d8 | |||
bf9e8cae14 | |||
5ce0477d46 | |||
13af013cbd | |||
ff1451c0dc | |||
986b003f20 | |||
9171c454bc | |||
2099c1f5fa | |||
1edb0c3e0e | |||
ca89bc017b | |||
d5fd31eba9 | |||
12f124d259 | |||
55a7be91c6 | |||
98d1a80347 | |||
8aae087969 | |||
d2d272f17a | |||
0429c2bab5 | |||
2d24c57c8e | |||
f0a4001b53 | |||
b678d1434a | |||
ee2a7cc93d | |||
0c3fe5b37d | |||
b8a4633113 | |||
b4b09ea5da | |||
4df405978f | |||
cb821a72ad | |||
8218591986 | |||
9a03137a67 | |||
03bba27c14 | |||
9998692bbd | |||
506d2035cb | |||
5783feb348 | |||
afb3ca87b4 | |||
dc08fda98b | |||
c3c0a8ae28 | |||
2e95100bf4 | |||
cd02426571 | |||
1eece32f73 | |||
a4b99698af | |||
075d5e4181 | |||
8b3d0babda | |||
ac3036e819 | |||
0e60f158ce | |||
e438fff266 | |||
c244dc9fe7 | |||
ddc6704351 | |||
8adf9b83a4 | |||
e22abb872e | |||
8f70bc346d | |||
30909d1353 | |||
a218f0d580 | |||
0a0f063f1b | |||
50ab03e195 | |||
3cdc0d674a |
5
.gitignore
vendored
5
.gitignore
vendored
@ -1,3 +1,8 @@
|
|||||||
build
|
build
|
||||||
*.deb
|
*.deb
|
||||||
*.tgz
|
*.tgz
|
||||||
|
./I2P/
|
||||||
|
i2pversion_override
|
||||||
|
*.crl
|
||||||
|
*.crt
|
||||||
|
*.pem
|
10
Dockerfile
Normal file
10
Dockerfile
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
FROM alpine:latest
|
||||||
|
RUN apk update && apk add firefox make curl musl-locales dbus-x11 font-ubuntu-nerd jq --repository http://dl-cdn.alpinelinux.org/alpine/edge/testing
|
||||||
|
ADD . /src
|
||||||
|
WORKDIR /src
|
||||||
|
RUN make profile.tgz # && \
|
||||||
|
RUN chown -R 1000:1000 /src/build/profile # && \
|
||||||
|
RUN chmod -R +w /src/build/profile
|
||||||
|
RUN ls -lah /src/build/profile
|
||||||
|
#USER 1000
|
||||||
|
CMD sh -c 'cd build/profile && ./i2pbrowser.sh'
|
@ -1 +1 @@
|
|||||||
https://addons.mozilla.org/firefox/downloads/file/3716461/2021.1.27/https_everywhere-2021.1.27-an+fx.xpi
|
https://addons.mozilla.org/firefox/downloads/file/3716461/2021.7.13/https_everywhere-2021.7.13-an+fx.xpi
|
||||||
|
158
Makefile
158
Makefile
@ -1,11 +1,85 @@
|
|||||||
all: profile.tgz app-profile.tgz install.exe
|
-include i2pversion
|
||||||
|
-include i2pversion_override
|
||||||
|
|
||||||
install.exe: profile build/licenses
|
-include config.mk
|
||||||
|
|
||||||
|
preset=`rm .version; make .version`
|
||||||
|
|
||||||
|
include .version
|
||||||
|
|
||||||
|
PROFILE_VERSION=$(MAJOR).$(MINOR).$(BUILD)
|
||||||
|
|
||||||
|
all: .version install.exe
|
||||||
|
|
||||||
|
tag:
|
||||||
|
git tag $(PROFILE_VERSION)
|
||||||
|
|
||||||
|
.version:
|
||||||
|
sed 's|!define VERSION||g' src/nsis/i2pbrowser-version.nsi | sed 's| |=|g' > .version
|
||||||
|
make version.txt src/nsis/i2pbrowser_jpackage.nsi
|
||||||
|
|
||||||
|
version.txt:
|
||||||
|
echo "$(PROFILE_VERSION)" > src/profile/version.txt
|
||||||
|
echo "$(PROFILE_VERSION)" > src/app-profile/version.txt
|
||||||
|
|
||||||
|
src/nsis/i2pbrowser_jpackage.nsi:
|
||||||
|
echo "!define I2P_VERSION $(I2P_VERSION)" > src/nsis/i2pbrowser_jpackage.nsi
|
||||||
|
|
||||||
|
jpackage: .version I2P all
|
||||||
|
|
||||||
|
help: .version
|
||||||
|
@echo "I2P-Profile-Installer-$(PROFILE_VERSION)"
|
||||||
|
@echo "$(SIGNER)"
|
||||||
|
@echo "$(I2P_VERSION)"
|
||||||
|
@echo "$(MAJOR).$(MINOR).$(BUILD)"
|
||||||
|
@echo "$(preset)"
|
||||||
|
|
||||||
|
prep: profile.tgz app-profile.tgz profile build/licenses build/I2P build/I2P/config launchers
|
||||||
cp src/nsis/*.nsi build
|
cp src/nsis/*.nsi build
|
||||||
cp src/nsis/*.nsh build
|
cp src/nsis/*.nsh build
|
||||||
cp src/icons/*.ico build
|
cp src/icons/*.ico build
|
||||||
|
|
||||||
|
install.exe: prep
|
||||||
cd build && makensis i2pbrowser-installer.nsi && cp I2P-Profile-Installer-*.exe ../ && echo "built windows installer"
|
cd build && makensis i2pbrowser-installer.nsi && cp I2P-Profile-Installer-*.exe ../ && echo "built windows installer"
|
||||||
|
|
||||||
|
export RES_DIR="../i2p.i2p/installer/resources"
|
||||||
|
export PKG_DIR="../i2p.i2p/pkg-temp"
|
||||||
|
export I2P_JBIGI="../i2p.i2p/installer/lib/jbigi"
|
||||||
|
|
||||||
|
distclean: clean
|
||||||
|
rm -rf I2P
|
||||||
|
|
||||||
|
I2P:
|
||||||
|
./build.sh
|
||||||
|
|
||||||
|
build/I2P: build
|
||||||
|
rm -rf build/I2P
|
||||||
|
cp -rv I2P build/I2P ; true
|
||||||
|
cp "$(I2P_JBIGI)"/*windows*.dll build/I2P/runtime/lib; true
|
||||||
|
|
||||||
|
configdir: src/I2P/config
|
||||||
|
|
||||||
|
src/I2P/config:
|
||||||
|
mkdir src/I2P/config
|
||||||
|
rm -rf src/I2P/config/geoip src/I2P/config/webapps src/I2P/config/certificates
|
||||||
|
echo true | tee src/I2P/config/jpackaged
|
||||||
|
cp -v $(RES_DIR)/clients.config src/I2P/config/
|
||||||
|
cp -v $(RES_DIR)/i2ptunnel.config src/I2P/config/
|
||||||
|
cp -v $(RES_DIR)/wrapper.config src/I2P/config/
|
||||||
|
#grep -v 'router.updateURL' $(RES_DIR)/router.config > src/I2P/config/router.config
|
||||||
|
cat router.config >> src/I2P/config/router.config
|
||||||
|
cp -v $(RES_DIR)/hosts.txt src/I2P/config/hosts.txt
|
||||||
|
cp -R $(RES_DIR)/certificates src/I2P/config/certificates
|
||||||
|
cp -R $(RES_DIR)/eepsite src/I2P/config/eepsite
|
||||||
|
mkdir -p src/I2P/config/geoip
|
||||||
|
cp -v $(RES_DIR)/GeoLite2-Country.mmdb.gz src/I2P/config/geoip/GeoLite2-Country.mmdb.gz
|
||||||
|
cp -R "$(PKG_DIR)"/webapps src/I2P/config/webapps
|
||||||
|
cd src/I2P/config/geoip && gunzip GeoLite2-Country.mmdb.gz; cd ../../..
|
||||||
|
|
||||||
|
build/I2P/config: build/I2P src/I2P/config
|
||||||
|
cp -rv src/I2P/config build/I2P/config ; true
|
||||||
|
cp -rv src/I2P/config build/I2P/.i2p ; true
|
||||||
|
|
||||||
#
|
#
|
||||||
# Warning: a displayed license file of more than 28752 bytes
|
# Warning: a displayed license file of more than 28752 bytes
|
||||||
# will cause makensis V3.03 to crash.
|
# will cause makensis V3.03 to crash.
|
||||||
@ -14,11 +88,11 @@ install.exe: profile build/licenses
|
|||||||
build/licenses: build
|
build/licenses: build
|
||||||
mkdir -p build/licenses
|
mkdir -p build/licenses
|
||||||
cp license/* build/licenses
|
cp license/* build/licenses
|
||||||
cp LICENSE build/licenses/MIT.txt
|
cp LICENSE.md build/licenses/MIT.txt
|
||||||
unix2dos build/licenses/LICENSE.index
|
unix2dos build/licenses/LICENSE.index
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -rf build app-profile-*.tgz profile-*.tgz I2P-Profile-Installer-*.exe *.deb
|
rm -rf build app-profile-*.tgz profile-*.tgz I2P-Profile-Installer-*.exe *.deb src/I2P/config *.su3
|
||||||
|
|
||||||
build:
|
build:
|
||||||
@echo "creating build directory"
|
@echo "creating build directory"
|
||||||
@ -26,9 +100,10 @@ build:
|
|||||||
|
|
||||||
profile: build/profile/user.js build/profile/prefs.js build/profile/bookmarks.html build/profile/storage-sync.sqlite copy-xpi
|
profile: build/profile/user.js build/profile/prefs.js build/profile/bookmarks.html build/profile/storage-sync.sqlite copy-xpi
|
||||||
|
|
||||||
profile.tgz: profile
|
profile.tgz: .version profile
|
||||||
$(eval PROFILE_VERSION := $(shell cat src/profile/version.txt))
|
# $(eval PROFILE_VERSION := $(shell cat src/profile/version.txt))
|
||||||
@echo "building profile tarball $(PROFILE_VERSION)"
|
@echo "building profile tarball $(PROFILE_VERSION)"
|
||||||
|
sh -c 'ls I2P && cp -rv build/I2P build/profile/I2P'; true
|
||||||
install -m755 src/unix/i2pbrowser.sh build/profile/i2pbrowser.sh
|
install -m755 src/unix/i2pbrowser.sh build/profile/i2pbrowser.sh
|
||||||
cd build && tar -czf profile-$(PROFILE_VERSION).tgz profile && cp profile-$(PROFILE_VERSION).tgz ../
|
cd build && tar -czf profile-$(PROFILE_VERSION).tgz profile && cp profile-$(PROFILE_VERSION).tgz ../
|
||||||
|
|
||||||
@ -44,16 +119,17 @@ build/profile/bookmarks.html: build/profile src/profile/bookmarks.html
|
|||||||
build/profile/storage-sync.sqlite: build/profile src/profile/storage-sync.sqlite
|
build/profile/storage-sync.sqlite: build/profile src/profile/storage-sync.sqlite
|
||||||
cp src/profile/storage-sync.sqlite build/profile/storage-sync.sqlite
|
cp src/profile/storage-sync.sqlite build/profile/storage-sync.sqlite
|
||||||
|
|
||||||
copy-xpi: build/NoScript.xpi build/HTTPSEverywhere.xpi build/i2ppb@eyedeekay.github.io.xpi build/profile/extensions
|
copy-xpi: build/NoScript.xpi build/HTTPSEverywhere.xpi build/i2prhz@eyedeekay.github.io.xpi build/profile/extensions
|
||||||
cp build/NoScript.xpi "build/profile/extensions/{73a6fe31-595d-460b-a920-fcc0f8843232}.xpi"
|
cp build/NoScript.xpi "build/profile/extensions/{73a6fe31-595d-460b-a920-fcc0f8843232}.xpi"
|
||||||
cp build/HTTPSEverywhere.xpi "build/profile/extensions/https-everywhere-eff@eff.org.xpi"
|
cp build/HTTPSEverywhere.xpi "build/profile/extensions/https-everywhere-eff@eff.org.xpi"
|
||||||
cp build/i2ppb@eyedeekay.github.io.xpi build/profile/extensions/i2ppb@eyedeekay.github.io.xpi
|
cp build/i2prhz@eyedeekay.github.io.xpi build/profile/extensions/i2prhz@eyedeekay.github.io.xpi
|
||||||
|
|
||||||
app-profile: build/app-profile/user.js build/app-profile/prefs.js build/app-profile/chrome/userChrome.css build/app-profile/bookmarks.html build/app-profile/storage-sync.sqlite copy-app-xpi
|
app-profile: .version build/app-profile/user.js build/app-profile/prefs.js build/app-profile/chrome/userChrome.css build/app-profile/bookmarks.html build/app-profile/storage-sync.sqlite copy-app-xpi
|
||||||
|
|
||||||
app-profile.tgz: app-profile
|
app-profile.tgz: app-profile
|
||||||
$(eval PROFILE_VERSION := $(shell cat src/app-profile/version.txt))
|
# $(eval PROFILE_VERSION := $(shell cat src/app-profile/version.txt))
|
||||||
@echo "building app-profile tarball $(PROFILE_VERSION)"
|
@echo "building app-profile tarball $(PROFILE_VERSION)"
|
||||||
|
sh -c 'ls I2P && cp -rv build/I2P build/app-profile/I2P'; true
|
||||||
install -m755 src/unix/i2pconfig.sh build/app-profile/i2pconfig.sh
|
install -m755 src/unix/i2pconfig.sh build/app-profile/i2pconfig.sh
|
||||||
cd build && tar -czf app-profile-$(PROFILE_VERSION).tgz app-profile && cp app-profile-$(PROFILE_VERSION).tgz ../
|
cd build && tar -czf app-profile-$(PROFILE_VERSION).tgz app-profile && cp app-profile-$(PROFILE_VERSION).tgz ../
|
||||||
|
|
||||||
@ -72,18 +148,20 @@ build/app-profile/bookmarks.html: build/app-profile src/app-profile/bookmarks.ht
|
|||||||
build/app-profile/storage-sync.sqlite: build/app-profile src/app-profile/storage-sync.sqlite
|
build/app-profile/storage-sync.sqlite: build/app-profile src/app-profile/storage-sync.sqlite
|
||||||
cp src/app-profile/storage-sync.sqlite build/app-profile/storage-sync.sqlite
|
cp src/app-profile/storage-sync.sqlite build/app-profile/storage-sync.sqlite
|
||||||
|
|
||||||
copy-app-xpi: build/NoScript.xpi build/HTTPSEverywhere.xpi build/i2ppb@eyedeekay.github.io.xpi build/app-profile/extensions
|
copy-app-xpi: build/NoScript.xpi build/HTTPSEverywhere.xpi build/i2prhz@eyedeekay.github.io.xpi build/app-profile/extensions
|
||||||
cp build/HTTPSEverywhere.xpi "build/app-profile/extensions/https-everywhere-eff@eff.org.xpi"
|
cp build/HTTPSEverywhere.xpi "build/app-profile/extensions/https-everywhere-eff@eff.org.xpi"
|
||||||
cp build/i2ppb@eyedeekay.github.io.xpi build/app-profile/extensions/i2ppb@eyedeekay.github.io.xpi
|
cp build/i2prhz@eyedeekay.github.io.xpi build/app-profile/extensions/i2prhz@eyedeekay.github.io.xpi
|
||||||
|
|
||||||
build/i2ppb@eyedeekay.github.io.xpi:
|
build-extensions: build/i2prhz@eyedeekay.github.io.xpi build/NoScript.xpi build/HTTPSEverywhere.xpi
|
||||||
curl -L `cat i2psetproxy.url` > build/i2ppb@eyedeekay.github.io.xpi
|
|
||||||
|
build/i2prhz@eyedeekay.github.io.xpi: i2psetproxy.url
|
||||||
|
curl -L `cat i2psetproxy.url` > build/i2prhz@eyedeekay.github.io.xpi
|
||||||
|
|
||||||
build/NoScript.xpi: NoScript.url
|
build/NoScript.xpi: NoScript.url
|
||||||
curl `cat NoScript.url` > build/NoScript.xpi
|
curl -L `cat NoScript.url` > build/NoScript.xpi
|
||||||
|
|
||||||
build/HTTPSEverywhere.xpi: HTTPSEverywhere.url
|
build/HTTPSEverywhere.xpi: HTTPSEverywhere.url
|
||||||
curl `cat HTTPSEverywhere.url` > build/HTTPSEverywhere.xpi
|
curl -L `cat HTTPSEverywhere.url` > build/HTTPSEverywhere.xpi
|
||||||
|
|
||||||
clean-extensions:
|
clean-extensions:
|
||||||
rm -fv i2psetproxy.url NoScript.url HTTPSEverywhere.url
|
rm -fv i2psetproxy.url NoScript.url HTTPSEverywhere.url
|
||||||
@ -97,7 +175,9 @@ NoScript.url:
|
|||||||
@echo "https://addons.mozilla.org/firefox/downloads/file/3534184/"`./amo-version.sh noscript`"/{73a6fe31-595d-460b-a920-fcc0f8843232}.xpi" > NoScript.url
|
@echo "https://addons.mozilla.org/firefox/downloads/file/3534184/"`./amo-version.sh noscript`"/{73a6fe31-595d-460b-a920-fcc0f8843232}.xpi" > NoScript.url
|
||||||
|
|
||||||
i2psetproxy.url:
|
i2psetproxy.url:
|
||||||
@echo "https://addons.mozilla.org/firefox/downloads/file/3674169/"`./amo-version.sh i2p-in-private-browsing`"/i2ppb@eyedeekay.github.io.xpi" > i2psetproxy.url
|
@echo "https://addons.mozilla.org/firefox/downloads/file/3784917/"`./amo-version.sh i2pipb-rhizome-variant`"/i2prhz@eyedeekay.github.io" > i2psetproxy.url
|
||||||
|
|
||||||
|
#i2ppb@eyedeekay.github.io.xpi
|
||||||
|
|
||||||
build/profile/extensions: build/profile
|
build/profile/extensions: build/profile
|
||||||
mkdir -p build/profile/extensions
|
mkdir -p build/profile/extensions
|
||||||
@ -105,6 +185,19 @@ build/profile/extensions: build/profile
|
|||||||
build/profile: build
|
build/profile: build
|
||||||
mkdir -p build/profile
|
mkdir -p build/profile
|
||||||
|
|
||||||
|
build/win:
|
||||||
|
mkdir -p build/win/
|
||||||
|
|
||||||
|
build/win/i2pbrowser.bat:
|
||||||
|
cp src/win/i2pbrowser.bat build/win/i2pbrowser.bat
|
||||||
|
|
||||||
|
build/win/i2pconfig.bat:
|
||||||
|
cp src/win/i2pconfig.bat build/win/i2pconfig.bat
|
||||||
|
|
||||||
|
build/win/i2pbrowser-private.bat:
|
||||||
|
cp src/win/i2pbrowser-private.bat build/win/i2pbrowser-private.bat
|
||||||
|
|
||||||
|
launchers: build/win build/win/i2pbrowser.bat build/win/i2pbrowser-private.bat build/win/i2pconfig.bat
|
||||||
|
|
||||||
build/app-profile/chrome: build/app-profile
|
build/app-profile/chrome: build/app-profile
|
||||||
mkdir -p build/app-profile/chrome
|
mkdir -p build/app-profile/chrome
|
||||||
@ -141,7 +234,7 @@ uninstall:
|
|||||||
/usr/share/applications/i2pbrowser.desktop \
|
/usr/share/applications/i2pbrowser.desktop \
|
||||||
/usr/share/applications/i2pconfig.desktop
|
/usr/share/applications/i2pconfig.desktop
|
||||||
|
|
||||||
checkinstall:
|
checkinstall: version
|
||||||
checkinstall \
|
checkinstall \
|
||||||
--default \
|
--default \
|
||||||
--install=no \
|
--install=no \
|
||||||
@ -151,10 +244,35 @@ checkinstall:
|
|||||||
--pkggroup=net \
|
--pkggroup=net \
|
||||||
--pkgrelease=1 \
|
--pkgrelease=1 \
|
||||||
--pkgsource="https://i2pgit.org/i2p-hackers/i2p.firefox" \
|
--pkgsource="https://i2pgit.org/i2p-hackers/i2p.firefox" \
|
||||||
--maintainer="hankhill19580@gmail.com" \
|
--maintainer="$(SIGNER)" \
|
||||||
--requires="firefox,wget,i2p,i2p-router" \
|
--requires="firefox,wget" \
|
||||||
--suggests="i2p,i2p-router,syndie,tor,tsocks" \
|
--suggests="i2p,i2p-router,syndie,tor,tsocks" \
|
||||||
--nodoc \
|
--nodoc \
|
||||||
--deldoc=yes \
|
--deldoc=yes \
|
||||||
--deldesc=yes \
|
--deldesc=yes \
|
||||||
--backup=no
|
--backup=no
|
||||||
|
|
||||||
|
GOPATH=$(HOME)/go
|
||||||
|
|
||||||
|
$(GOPATH)/src/i2pgit.org/idk/su3-tools/su3-tools:
|
||||||
|
git clone https://i2pgit.org/idk/su3-tools $(GOPATH)/src/i2pgit.org/idk/su3-tools; true
|
||||||
|
git pull --all
|
||||||
|
cd $(GOPATH)/src/i2pgit.org/idk/su3-tools && \
|
||||||
|
go mod vendor && go build
|
||||||
|
|
||||||
|
su3: $(GOPATH)/src/i2pgit.org/idk/su3-tools/su3-tools
|
||||||
|
$(GOPATH)/src/i2pgit.org/idk/su3-tools/su3-tools -name "I2P-Profile-Installer-$(PROFILE_VERSION)" -signer "$(SIGNER)" -version "$(I2P_VERSION)"
|
||||||
|
|
||||||
|
docker:
|
||||||
|
docker build -t geti2p/i2p.firefox .
|
||||||
|
|
||||||
|
xhost:
|
||||||
|
xhost + local:docker
|
||||||
|
|
||||||
|
run: docker xhost
|
||||||
|
docker run -it --rm \
|
||||||
|
--net=host \
|
||||||
|
-e DISPLAY=unix$(DISPLAY) \
|
||||||
|
-v /tmp/.X11-unix:/tmp/.X11-unix \
|
||||||
|
geti2p/i2p.firefox firefox --profile /src/build/profile
|
||||||
|
|
@ -1 +1 @@
|
|||||||
https://addons.mozilla.org/firefox/downloads/file/3534184/11.2.3/{73a6fe31-595d-460b-a920-fcc0f8843232}.xpi
|
https://addons.mozilla.org/firefox/downloads/file/3534184/11.2.11/{73a6fe31-595d-460b-a920-fcc0f8843232}.xpi
|
||||||
|
137
README.md
137
README.md
@ -19,6 +19,7 @@ To build this, you will need the following software packages (all available in D
|
|||||||
* nsis
|
* nsis
|
||||||
* dos2unix
|
* dos2unix
|
||||||
* curl
|
* curl
|
||||||
|
* jq
|
||||||
|
|
||||||
to build a Debian package, you'll also need
|
to build a Debian package, you'll also need
|
||||||
|
|
||||||
@ -89,6 +90,142 @@ with `sudo service i2p start` then you can run the script:
|
|||||||
|
|
||||||
/usr/local/bin/i2p-config-service-setup
|
/usr/local/bin/i2p-config-service-setup
|
||||||
|
|
||||||
|
Including a jpackaged I2P Router(EXPERIMENTAL)
|
||||||
|
----------------------------------------------
|
||||||
|
|
||||||
|
In order to include a jpackaged(dependency-free) I2P router in the Profile
|
||||||
|
Bundle you will need to build the jpackaged I2P router as an "App Image" on
|
||||||
|
a Windows system and place it into a directory called `I2P` in your `i2p.firefox`
|
||||||
|
checkout.
|
||||||
|
|
||||||
|
Assuming a working java and jpackage environment on your Windows system, the
|
||||||
|
following command should generate a suitable "App Image" in a directory
|
||||||
|
called "I2P."
|
||||||
|
|
||||||
|
export I2P_VERSION=0.9.49
|
||||||
|
cp -R ../i2p.i2p/pkg-temp/lib build/lib
|
||||||
|
jpackage --type app-image --name I2P --app-version "$I2P_VERSION" \
|
||||||
|
--verbose \
|
||||||
|
--resource-dir build/lib \
|
||||||
|
--input build/lib --main-jar router.jar --main-class net.i2p.router.RouterLaunch
|
||||||
|
|
||||||
|
Transfer the I2P directory to the machine where you build i2p.firefox if
|
||||||
|
necessary, then complete the regular build instructions. If a jpackaged I2P router
|
||||||
|
isn't present to use at build time, the inclusion will be skipped automatically
|
||||||
|
with a non-fatal warning.
|
||||||
|
|
||||||
|
In the near future, I'll start providing a pre-built app image to ease the
|
||||||
|
build process for non-Windows users.
|
||||||
|
|
||||||
|
End-to-End Windows build process using WSL
|
||||||
|
------------------------------------------
|
||||||
|
|
||||||
|
**If you've already done this once, you can just use:** `./build.sh && wsl make`
|
||||||
|
**in `git bash`** to automatically build an installer.
|
||||||
|
|
||||||
|
**Prerequisites:** You need to have OpenJDK 14 or greater installed and configured
|
||||||
|
with your `%JAVA_HOME%` environment variable configured and `%JAVA_HOME%/bin` on
|
||||||
|
your `%PATH%`. You need to have Apache Ant installed and configured with `%ANT_HOME%`
|
||||||
|
environment variable configured and `%ANT_HOME%/bin` on your `%PATH%`. You must have
|
||||||
|
Cygwin installed. You must have `NSIS.exe` installed and `makensis` available on your
|
||||||
|
`%PATH%`. You must have Git for Windows installed. When installing git for Windows,
|
||||||
|
you should select "Checkout as is, commit as is" and leave line-endings alone.
|
||||||
|
|
||||||
|
1. [Set up Windows Subsystem for Linux per Microsoft's instructions](https://docs.microsoft.com/en-us/windows/wsl/install-win10#manual-installation-steps)
|
||||||
|
2. [Install Ubuntu Focal per Microsoft's instructions](https://www.microsoft.com/store/apps/9n6svws3rx71)
|
||||||
|
3. Open Git Bash.
|
||||||
|
4. Install prerequisites `wsl sudo apt-get update && sudo apt-get install make nsis dos2unix curl jq`
|
||||||
|
5. Clone `i2p.i2p` and `i2p.firefox`
|
||||||
|
|
||||||
|
git clone https://github.com/i2p/i2p.i2p
|
||||||
|
git clone https://github.com/i2p/i2p.firefox
|
||||||
|
|
||||||
|
6. Move to the i2p.i2p directory. Build the .jar files required to build the App Image
|
||||||
|
inside i2p.i2p. Return to home.
|
||||||
|
|
||||||
|
cd i2p.i2p
|
||||||
|
ant clean pkg
|
||||||
|
cd ..
|
||||||
|
|
||||||
|
7. Move into the i2p.firefox directory. Run the `./build.sh` script.
|
||||||
|
|
||||||
|
cd i2p.firefox
|
||||||
|
./build.sh
|
||||||
|
|
||||||
|
8. Compile the NSIS installer using WSL.
|
||||||
|
|
||||||
|
wsl make
|
||||||
|
|
||||||
|
End-to-End Windows build process using Cygwin
|
||||||
|
---------------------------------------------
|
||||||
|
|
||||||
|
**Prerequisites:** You need to have OpenJDK 14 or greater installed and configured
|
||||||
|
with your `%JAVA_HOME%` environment variable configured and `%JAVA_HOME%/bin` on
|
||||||
|
your `%PATH%`. You need to have Apache Ant installed and configured with `%ANT_HOME%`
|
||||||
|
environment variable configured and `%ANT_HOME%/bin` on your `%PATH%`. You must have
|
||||||
|
WSL and git bash installed. You must have `NSIS.exe` installed and `makensis` available on your
|
||||||
|
`%PATH%`. You must have Git for Windows installed. When installing git for Windows, you should
|
||||||
|
select "Checkout as is, commit as is" and leave line-endings alone.
|
||||||
|
|
||||||
|
TODO: Add links to the respective instructions for each of these.
|
||||||
|
|
||||||
|
1. Run the Cygwin `setup-$arch.exe` for your platform to set up new packages.
|
||||||
|
Select the `make` `jq` `dos2unix` and `curl` packages.
|
||||||
|
2. Open a cygwin terminal.
|
||||||
|
3. Clone `i2p.i2p` and `i2p.firefox`
|
||||||
|
|
||||||
|
git clone https://github.com/i2p/i2p.i2p
|
||||||
|
git clone https://github.com/i2p/i2p.firefox
|
||||||
|
|
||||||
|
3. Move to the i2p.i2p directory. Build the .jar files required to build the App Image
|
||||||
|
inside i2p.i2p. Return to home.
|
||||||
|
|
||||||
|
cd i2p.i2p
|
||||||
|
ant clean pkg
|
||||||
|
cd ..
|
||||||
|
|
||||||
|
7. Move into the i2p.firefox directory. Run the `./build.sh` script.
|
||||||
|
|
||||||
|
cd i2p.firefox
|
||||||
|
./build.sh
|
||||||
|
|
||||||
|
5. Run `make` to build the installer.
|
||||||
|
|
||||||
|
Building a signed update file
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
Building a signed update file for automatically updating a Windows I2P router
|
||||||
|
requires you to also have Go installed in your Cygwin or WSL environment.
|
||||||
|
With WSL, you can do this using the command:
|
||||||
|
|
||||||
|
wsl sudo apt-get install golang-go
|
||||||
|
|
||||||
|
With that dependency satisfied, you can then run:
|
||||||
|
|
||||||
|
wsl make su3
|
||||||
|
|
||||||
|
to build the signing tool if necessary and then package the installer in a
|
||||||
|
signed update file.
|
||||||
|
|
||||||
|
Docker Support
|
||||||
|
--------------
|
||||||
|
|
||||||
|
You can use a Docker container to install this browser profile as well. In order
|
||||||
|
to do this, you can run the commands:
|
||||||
|
|
||||||
|
xhost + local:docker
|
||||||
|
docker run -it --rm \
|
||||||
|
--net=host \
|
||||||
|
-e DISPLAY=unix$(DISPLAY) \
|
||||||
|
-v /tmp/.X11-unix:/tmp/.X11-unix \
|
||||||
|
geti2p/i2p.firefox firefox --profile /src/build/profile
|
||||||
|
|
||||||
|
To build and run the container locally, clone this repository and run the
|
||||||
|
|
||||||
|
make run
|
||||||
|
|
||||||
|
target.
|
||||||
|
|
||||||
Issues
|
Issues
|
||||||
------
|
------
|
||||||
|
|
||||||
|
29
UPDATES.md
Normal file
29
UPDATES.md
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
Setting up an Update Server for an I2P Bundle
|
||||||
|
=============================================
|
||||||
|
|
||||||
|
It is important to set up a signed update server so that people are able to
|
||||||
|
safely and anonymously update your I2P bundle.
|
||||||
|
|
||||||
|
The quick way:
|
||||||
|
--------------
|
||||||
|
|
||||||
|
This process depends on my ability to push releases to github. If you are
|
||||||
|
forking, setting up a dev server, or taking over because I got hit by a bus,
|
||||||
|
you'll need to do it the complete way.
|
||||||
|
|
||||||
|
For as long as I am building updates, you will be able to mirror the jpackaged
|
||||||
|
Windows bundle by cloning the repository `https://github.com/eyedeekay/i2p` and
|
||||||
|
running the `make docker run` target in that repository. You can retrieve the
|
||||||
|
base32 address of your update server by viewing the log with
|
||||||
|
`docker logs eephttpd-jpackage | grep b32.i2p | tee eephttpd-address.md`. To
|
||||||
|
update the site, run `./update.site.sh` in that repository.
|
||||||
|
|
||||||
|
Once you have cloned the repository and started the container with
|
||||||
|
`make docker run`, you can simply add `path/to/repo/update-site.sh` to your
|
||||||
|
`crontab` and it will update at an interval of your choosing.
|
||||||
|
|
||||||
|
The complete way:
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
TODO: describe how to do it with less of the awesome fancy stuff I put together
|
||||||
|
to make it easier on myself to keep an update server going.
|
@ -1,3 +1,4 @@
|
|||||||
#! /usr/bin/env sh
|
#! /usr/bin/env sh
|
||||||
|
|
||||||
curl -s https://addons.mozilla.org/api/v5/addons/addon/$1/versions/?page_size=1 | jq '.results | .[0] | .version' | tr -d '"'
|
curl -s "https://addons.mozilla.org/api/v5/addons/addon/$1/versions/?page_size=1" | jq '.results | .[0] | .version' | tr -d '"'
|
||||||
|
|
||||||
|
61
build.sh
Executable file
61
build.sh
Executable file
@ -0,0 +1,61 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
. i2pversion
|
||||||
|
|
||||||
|
if [ -f i2pversion_override ]; then
|
||||||
|
. i2pversion_override
|
||||||
|
fi
|
||||||
|
|
||||||
|
JAVA=$(java --version | tr -d 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ\n' | cut -d ' ' -f 2 | cut -d '.' -f 1 | tr -d '\n\t\- ')
|
||||||
|
|
||||||
|
if [ "$JAVA" -lt "14" ]; then
|
||||||
|
echo "Java 14+ must be used to compile with jpackage, java is $JAVA"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
sleep 2s
|
||||||
|
|
||||||
|
if [ -z "${JAVA_HOME}" ]; then
|
||||||
|
JAVA_HOME=`type -p java|xargs readlink -f|xargs dirname|xargs dirname`
|
||||||
|
echo "Building with: $JAVA, $JAVA_HOME"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "cleaning"
|
||||||
|
./clean.sh
|
||||||
|
|
||||||
|
HERE="$PWD"
|
||||||
|
cd "$HERE/../i2p.i2p/"
|
||||||
|
git checkout "$VERSION"
|
||||||
|
ant distclean preppkg-windows || true
|
||||||
|
|
||||||
|
cd "$HERE"
|
||||||
|
RES_DIR="$HERE/../i2p.i2p/installer/resources"
|
||||||
|
I2P_JARS="$HERE/../i2p.i2p/pkg-temp/lib"
|
||||||
|
I2P_JBIGI="$HERE/../i2p.i2p/installer/lib//jbigi"
|
||||||
|
I2P_PKG="$HERE/../i2p.i2p/pkg-temp"
|
||||||
|
|
||||||
|
echo "compiling custom launcher"
|
||||||
|
mkdir build
|
||||||
|
cp "$I2P_JARS"/*.jar build
|
||||||
|
|
||||||
|
cd java
|
||||||
|
"$JAVA_HOME"/bin/javac -d ../build -classpath "$HERE"/build/i2p.jar:"$HERE"/build/router.jar:"$HERE"/build/routerconsole.jar net/i2p/router/WinLauncher.java net/i2p/router/WindowsUpdatePostProcessor.java net/i2p/router/WinUpdateProcess.java
|
||||||
|
cd ..
|
||||||
|
|
||||||
|
#echo "building launcher.jar"
|
||||||
|
cd build
|
||||||
|
"$JAVA_HOME"/bin/jar -cf launcher.jar net
|
||||||
|
cd ..
|
||||||
|
|
||||||
|
if [ -z $I2P_VERSION ]; then
|
||||||
|
I2P_VERSION=$("$JAVA_HOME"/bin/java -cp build/router.jar net.i2p.router.RouterVersion | sed "s/.*: //" | head -n 1 | sed 's|-|.|g')
|
||||||
|
fi
|
||||||
|
echo "preparing to invoke jpackage for I2P version $I2P_VERSION"
|
||||||
|
|
||||||
|
|
||||||
|
"$JAVA_HOME"/bin/jpackage --type app-image --name I2P --app-version "$I2P_VERSION" \
|
||||||
|
--verbose \
|
||||||
|
$JPACKAGE_OPTS \
|
||||||
|
--resource-dir build \
|
||||||
|
--java-options "--illegal-access=permit" \
|
||||||
|
--input build --main-jar launcher.jar --main-class net.i2p.router.WinLauncher
|
17
clean.sh
Executable file
17
clean.sh
Executable file
@ -0,0 +1,17 @@
|
|||||||
|
#! /usr/bin/env sh
|
||||||
|
|
||||||
|
rm -rf \
|
||||||
|
build \
|
||||||
|
eventlog.txt \
|
||||||
|
hostsdb.blockfile \
|
||||||
|
I2P \
|
||||||
|
i2p_1.0-1_amd64.deb \
|
||||||
|
libjbigi.so \
|
||||||
|
libjcpuid.so \
|
||||||
|
logs \
|
||||||
|
peerProfiles \
|
||||||
|
prngseed.rnd \
|
||||||
|
wrapper.log \
|
||||||
|
*.jar \
|
||||||
|
*.exe \
|
||||||
|
*.dmg
|
2
config.mk
Normal file
2
config.mk
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
SIGNER=hankhill19580@gmail.com
|
||||||
|
export SIGNER=hankhill19580@gmail.com
|
@ -1 +1 @@
|
|||||||
https://addons.mozilla.org/firefox/downloads/file/3674169/0.98/i2ppb@eyedeekay.github.io.xpi
|
https://addons.mozilla.org/firefox/downloads/file/3784917/0.108/i2prhz@eyedeekay.github.io
|
||||||
|
15
i2pversion
Normal file
15
i2pversion
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
#! /usr/bin/env sh
|
||||||
|
|
||||||
|
|
||||||
|
#Comment this out to build from an alternate branch or
|
||||||
|
# the tip of the master branch.
|
||||||
|
#I2P_VERSION=0.9.50
|
||||||
|
#export I2P_VERSION=0.9.50
|
||||||
|
#VERSION=i2p-$I2P_VERSION
|
||||||
|
#export VERSION="$VERSION"
|
||||||
|
|
||||||
|
#Uncomment this to build from the tip of the master.
|
||||||
|
I2P_VERSION=0.9.50
|
||||||
|
export I2P_VERSION=0.9.50
|
||||||
|
VERSION=master
|
||||||
|
export VERSION="$VERSION"
|
108
java/net/i2p/router/WinLauncher.java
Normal file
108
java/net/i2p/router/WinLauncher.java
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
package net.i2p.router;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
|
import net.i2p.crypto.*;
|
||||||
|
|
||||||
|
import net.i2p.app.ClientAppManager;
|
||||||
|
import net.i2p.router.RouterLaunch;
|
||||||
|
import net.i2p.router.Router;
|
||||||
|
import net.i2p.update.UpdateManager;
|
||||||
|
import net.i2p.update.UpdatePostProcessor;
|
||||||
|
import net.i2p.util.SystemVersion;
|
||||||
|
import net.i2p.update.*;
|
||||||
|
|
||||||
|
import static net.i2p.update.UpdateType.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Launches a router from %PROGRAMFILES%/I2P using configuration data in
|
||||||
|
* %LOCALAPPDATA%/I2P.. Uses Java 9 APIs.
|
||||||
|
|
||||||
|
* Sets the following properties:
|
||||||
|
* i2p.dir.base - this points to the (read-only) resources inside the bundle
|
||||||
|
* i2p.dir.config this points to the (read-write) config directory in local appdata
|
||||||
|
* router.pid - the pid of the java process.
|
||||||
|
*/
|
||||||
|
public class WinLauncher {
|
||||||
|
private static WindowsUpdatePostProcessor wupp = new WindowsUpdatePostProcessor();
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
File programs = wupp.selectProgramFile();
|
||||||
|
if (!programs.exists())
|
||||||
|
programs.mkdirs();
|
||||||
|
else if (!programs.isDirectory()) {
|
||||||
|
System.err.println(programs + " exists but is not a directory. Please get it out of the way");
|
||||||
|
System.exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
File home = selectHome();
|
||||||
|
if (!home.exists())
|
||||||
|
home.mkdirs();
|
||||||
|
else if (!home.isDirectory()) {
|
||||||
|
System.err.println(home + " exists but is not a directory. Please get it out of the way");
|
||||||
|
System.exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
System.setProperty("i2p.dir.base", programs.getAbsolutePath());
|
||||||
|
System.setProperty("i2p.dir.config", home.getAbsolutePath());
|
||||||
|
System.setProperty("router.pid", String.valueOf(ProcessHandle.current().pid()));
|
||||||
|
System.out.println("\t"+System.getProperty("i2p.dir.base") +"\n\t"+System.getProperty("i2p.dir.config")+"\n\t"+ System.getProperty("router.pid"));
|
||||||
|
|
||||||
|
wupp.i2pRouter = new Router(System.getProperties());
|
||||||
|
System.out.println("Router is configured");
|
||||||
|
|
||||||
|
Thread registrationThread = new Thread(REGISTER_UPP);
|
||||||
|
registrationThread.setName("UPP Registration");
|
||||||
|
registrationThread.setDaemon(true);
|
||||||
|
registrationThread.start();
|
||||||
|
|
||||||
|
wupp.i2pRouter.runRouter();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Runnable REGISTER_UPP = () -> {
|
||||||
|
|
||||||
|
// first wait for the RouterContext to appear
|
||||||
|
RouterContext ctx;
|
||||||
|
while ((ctx = (RouterContext) wupp.i2pRouter.getContext().getCurrentContext()) == null) {
|
||||||
|
sleep(1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
// then wait for the update manager
|
||||||
|
ClientAppManager cam = ctx.clientAppManager();
|
||||||
|
UpdateManager um;
|
||||||
|
while ((um = (UpdateManager) cam.getRegisteredApp(UpdateManager.APP_NAME)) == null) {
|
||||||
|
sleep(1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
wupp = new WindowsUpdatePostProcessor(ctx);
|
||||||
|
um.register(wupp, UpdateType.ROUTER_SIGNED_SU3, SU3File.TYPE_EXE);
|
||||||
|
um.register(wupp, UpdateType.ROUTER_DEV_SU3, SU3File.TYPE_EXE);
|
||||||
|
};
|
||||||
|
|
||||||
|
private static void sleep(int millis) {
|
||||||
|
try {
|
||||||
|
Thread.sleep(millis);
|
||||||
|
} catch (InterruptedException bad) {
|
||||||
|
bad.printStackTrace();
|
||||||
|
throw new RuntimeException(bad);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static File selectHome() { //throws Exception {
|
||||||
|
if (SystemVersion.isWindows()) {
|
||||||
|
File home = new File(System.getProperty("user.home"));
|
||||||
|
File appData = new File(home, "AppData");
|
||||||
|
File local = new File(appData, "Local");
|
||||||
|
File i2p;
|
||||||
|
i2p = new File(local, "I2P");
|
||||||
|
System.out.println("Windows jpackage wrapper started, using: " + i2p + " as base config");
|
||||||
|
return i2p.getAbsoluteFile();
|
||||||
|
} else {
|
||||||
|
File jrehome = new File(System.getProperty("java.home"));
|
||||||
|
File programs = new File(jrehome.getParentFile().getParentFile(), ".i2p");
|
||||||
|
System.out.println("Linux portable jpackage wrapper started, using: " + programs + " as base config");
|
||||||
|
return programs.getAbsoluteFile();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
72
java/net/i2p/router/WinUpdateProcess.java
Normal file
72
java/net/i2p/router/WinUpdateProcess.java
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
package net.i2p.router;
|
||||||
|
|
||||||
|
import net.i2p.router.*;
|
||||||
|
import net.i2p.I2PAppContext;
|
||||||
|
|
||||||
|
import java.util.function.*;
|
||||||
|
import java.io.*;
|
||||||
|
import net.i2p.util.Log;
|
||||||
|
|
||||||
|
class WinUpdateProcess implements Runnable {
|
||||||
|
private final RouterContext ctx;
|
||||||
|
private final Supplier<String> versionSupplier;
|
||||||
|
private final Supplier<File> fileSupplier;
|
||||||
|
|
||||||
|
WinUpdateProcess(RouterContext ctx, Supplier<String> versionSupplier, Supplier<File> fileSupplier) {
|
||||||
|
this.ctx = ctx;
|
||||||
|
this.versionSupplier = versionSupplier;
|
||||||
|
this.fileSupplier = fileSupplier;
|
||||||
|
}
|
||||||
|
|
||||||
|
private File workDir() throws IOException{
|
||||||
|
if (ctx != null) {
|
||||||
|
File workDir = new File(ctx.getConfigDir().getAbsolutePath(), "i2p_update_win");
|
||||||
|
if (workDir.exists()) {
|
||||||
|
if (workDir.isFile())
|
||||||
|
throw new IOException(workDir + " exists but is a file, get it out of the way");
|
||||||
|
return null;
|
||||||
|
} else {
|
||||||
|
workDir.mkdirs();
|
||||||
|
}
|
||||||
|
return workDir;
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void runUpdateInstaller() throws IOException {
|
||||||
|
String version = versionSupplier.get();
|
||||||
|
File file = fileSupplier.get();
|
||||||
|
if (file == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
var workingDir = workDir();
|
||||||
|
var logFile = new File(workingDir, "log-" + version + ".txt");
|
||||||
|
|
||||||
|
ProcessBuilder pb = new ProcessBuilder(file.getAbsolutePath());
|
||||||
|
var env = pb.environment();
|
||||||
|
env.put("OLD_I2P_VERSION", version);
|
||||||
|
env.remove("RESTART_I2P");
|
||||||
|
|
||||||
|
int exitCode = ctx.router().scheduledGracefulExitCode();
|
||||||
|
if (exitCode == Router.EXIT_HARD_RESTART || exitCode == Router.EXIT_GRACEFUL_RESTART)
|
||||||
|
env.put("RESTART_I2P", "true");
|
||||||
|
|
||||||
|
try {
|
||||||
|
pb.directory(workingDir).
|
||||||
|
redirectErrorStream(true).
|
||||||
|
redirectOutput(logFile).
|
||||||
|
start();
|
||||||
|
} catch (IOException ex) {
|
||||||
|
System.out.println("Unable to run update-program in background. Update will fail.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
runUpdateInstaller();
|
||||||
|
} catch(IOException ioe) {
|
||||||
|
System.out.println("Error running updater, update may fail." + ioe);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
119
java/net/i2p/router/WindowsUpdatePostProcessor.java
Normal file
119
java/net/i2p/router/WindowsUpdatePostProcessor.java
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
package net.i2p.router;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.util.*;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
import java.util.concurrent.atomic.*;
|
||||||
|
|
||||||
|
|
||||||
|
import net.i2p.crypto.*;
|
||||||
|
import static net.i2p.update.UpdateType.*;
|
||||||
|
import net.i2p.I2PAppContext;
|
||||||
|
import net.i2p.update.UpdateType;
|
||||||
|
import net.i2p.update.UpdatePostProcessor;
|
||||||
|
import net.i2p.util.Log;
|
||||||
|
import net.i2p.util.SystemVersion;
|
||||||
|
|
||||||
|
import java.lang.ProcessBuilder;
|
||||||
|
import java.lang.Process;
|
||||||
|
import java.lang.InterruptedException;
|
||||||
|
|
||||||
|
|
||||||
|
public class WindowsUpdatePostProcessor implements UpdatePostProcessor {
|
||||||
|
private final Log _log = I2PAppContext.getGlobalContext().logManager().getLog(WindowsUpdatePostProcessor.class);
|
||||||
|
private final RouterContext ctx;
|
||||||
|
protected static Router i2pRouter = null;
|
||||||
|
|
||||||
|
private final AtomicBoolean hook = new AtomicBoolean();
|
||||||
|
|
||||||
|
private volatile String version;
|
||||||
|
|
||||||
|
private volatile File positionedFile = null;
|
||||||
|
private final String fileName = "i2p-jpackage-update.exe";
|
||||||
|
|
||||||
|
WindowsUpdatePostProcessor() {
|
||||||
|
this.ctx = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
WindowsUpdatePostProcessor(RouterContext ctx) {
|
||||||
|
this.ctx = ctx;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getVersion() {
|
||||||
|
return version;
|
||||||
|
}
|
||||||
|
|
||||||
|
public File getFile() {
|
||||||
|
return positionedFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void updateDownloadedandVerified(UpdateType type, int fileType, String version, File file) throws IOException {
|
||||||
|
_log.info("Got an update to post-process");
|
||||||
|
|
||||||
|
if (type != UpdateType.ROUTER_SIGNED_SU3 && type != UpdateType.ROUTER_DEV_SU3) {
|
||||||
|
_log.warn("Unsupported update type " + type);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fileType != SU3File.TYPE_EXE) {
|
||||||
|
_log.warn("Unsupported file type " + fileType);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.positionedFile = moveUpdateInstaller(file);
|
||||||
|
this.version = version;
|
||||||
|
|
||||||
|
if (!hook.compareAndSet(false,true)) {
|
||||||
|
_log.info("shutdown hook was already set");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
_log.info("adding shutdown hook");
|
||||||
|
ctx.addFinalShutdownTask(new WinUpdateProcess(ctx, this::getVersion, this::getFile));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private File moveUpdateInstaller(File file) throws IOException {
|
||||||
|
RouterContext i2pContext = i2pRouter.getContext();
|
||||||
|
if (i2pContext != null) {
|
||||||
|
File newFile = new File(workDir(), fileName);
|
||||||
|
boolean renamedStatus = file.renameTo(newFile);
|
||||||
|
if (renamedStatus)
|
||||||
|
return newFile;
|
||||||
|
else
|
||||||
|
throw new IOException("WindowsUpdatePostProcesssor unable to move file to working directory, update will fail");
|
||||||
|
}
|
||||||
|
throw new IOException("Router context not available to WindowsUpdatePostProcesssor, unable to find working directory, update will fail");
|
||||||
|
}
|
||||||
|
|
||||||
|
private File workDir() throws IOException{
|
||||||
|
RouterContext i2pContext = i2pRouter.getContext();
|
||||||
|
if (i2pContext != null) {
|
||||||
|
File workDir = new File(i2pContext.getConfigDir().getAbsolutePath(), "i2p_update_win");
|
||||||
|
if (workDir.exists()) {
|
||||||
|
if (workDir.isFile())
|
||||||
|
throw new IOException(workDir + " exists but is a file, get it out of the way");
|
||||||
|
return null;
|
||||||
|
} else {
|
||||||
|
workDir.mkdirs();
|
||||||
|
}
|
||||||
|
return workDir;
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected File selectProgramFile() {
|
||||||
|
if (SystemVersion.isWindows()) {
|
||||||
|
File jrehome = new File(System.getProperty("java.home"));
|
||||||
|
File programs = jrehome.getParentFile();
|
||||||
|
System.out.println("Windows portable jpackage wrapper found, using: " + programs + " as working config");
|
||||||
|
return programs.getAbsoluteFile();
|
||||||
|
} else {
|
||||||
|
File jrehome = new File(System.getProperty("java.home"));
|
||||||
|
File programs = new File(jrehome.getParentFile().getParentFile(), "i2p");
|
||||||
|
System.out.println("Linux portable jpackage wrapper found, using: " + programs + " as working config");
|
||||||
|
return programs.getAbsoluteFile();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
3
router.config
Normal file
3
router.config
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
router.updateURL=http://ekm3fu6fr5pxudhwjmdiea5dovc3jdi66hjgop4c7z7dfaw7spca.b32.i2p/i2pwinupdate.su3
|
||||||
|
router.newsURL=http://tc73n4kivdroccekirco7rhgxdg5f3cjvbaapabupeyzrqwv5guq.b32.i2p/win/stable/news.su3
|
||||||
|
router.backupNewsURL=http://dn3tvalnjz432qkqsvpfdqrwpqkw3ye4n4i2uyfr4jexvo3sp5ka.b32.i2p/news/win/stable/news.su3
|
@ -53,3 +53,10 @@ 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://127.0.0.1:7657/home,http://127.0.0.1:7657/i2psnark/,http://127.0.0.1:7657/susimail/");
|
user_pref("browser.newtabpage.activity-stream.default.sites", "http://127.0.0.1:7657/home,http://127.0.0.1:7657/i2psnark/,http://127.0.0.1:7657/susimail/");
|
||||||
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);
|
||||||
|
@ -216,3 +216,9 @@ 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);
|
||||||
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("dom.w3c_touch_events.enabled", false);
|
||||||
|
@ -1 +1 @@
|
|||||||
0.3
|
0.04.0
|
||||||
|
122
src/nsis/FindProcess.nsh
Normal file
122
src/nsis/FindProcess.nsh
Normal file
@ -0,0 +1,122 @@
|
|||||||
|
/* FindProcess.nsh
|
||||||
|
*
|
||||||
|
* written by Donald Miller
|
||||||
|
* Mar 7, 2007
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
!include LogicLib.nsh
|
||||||
|
!include WordFunc.nsh
|
||||||
|
!insertmacro WordFind
|
||||||
|
|
||||||
|
!ifndef FindProcess
|
||||||
|
!define FindProcess '!insertmacro FindProcess'
|
||||||
|
|
||||||
|
!macro FindProcess ProcessList BoolReturn
|
||||||
|
Push '${ProcessList}'
|
||||||
|
Call FindProcess
|
||||||
|
Pop ${BoolReturn}
|
||||||
|
!macroend
|
||||||
|
|
||||||
|
Function FindProcess
|
||||||
|
# return True if any process in ProcessList is active
|
||||||
|
Exch $0 ; get ProcessList, save $0
|
||||||
|
Push $1
|
||||||
|
Push $2
|
||||||
|
Push $R0
|
||||||
|
Push $R1
|
||||||
|
Push $R2
|
||||||
|
|
||||||
|
StrCpy $2 "$0," ; $2 = ProcessList
|
||||||
|
|
||||||
|
Push 0 ; set return value = False
|
||||||
|
|
||||||
|
# method based upon one by Phoenix1701@gmail.com 1/27/07
|
||||||
|
|
||||||
|
System::Alloc 1024
|
||||||
|
Pop $R0 ; process list buffer
|
||||||
|
|
||||||
|
# get an array of all process ids
|
||||||
|
System::Call "Psapi::EnumProcesses(i R0, i 1024, *i .R1)i .r0"
|
||||||
|
${Unless} $0 = 0
|
||||||
|
|
||||||
|
IntOp $R1 $R1 / 4 ; Divide by sizeof(DWORD) to get $R1 process count
|
||||||
|
IntOp $R1 $R1 - 1 ; decr for 0 base loop
|
||||||
|
|
||||||
|
ClearErrors
|
||||||
|
${For} $R2 0 $R1
|
||||||
|
# get a PID from the array
|
||||||
|
IntOp $0 $R2 << 2
|
||||||
|
IntOp $0 $0 + $R0 ; buffer.dword[i]
|
||||||
|
System::Call "*$0(i .r0)" ; Get next PID
|
||||||
|
|
||||||
|
${Unless} $0 = 0
|
||||||
|
Push $0
|
||||||
|
Call GetProcessName
|
||||||
|
Pop $1
|
||||||
|
|
||||||
|
# is this process one we are looking for?
|
||||||
|
${WordFind} '$2' ',' 'E/$1' $0
|
||||||
|
${Unless} ${Errors}
|
||||||
|
# yes, change return value
|
||||||
|
Pop $0 ; discard old result
|
||||||
|
Push 1 ; set return True
|
||||||
|
|
||||||
|
# exit the loop
|
||||||
|
${Break}
|
||||||
|
${EndUnless}
|
||||||
|
${EndUnless}
|
||||||
|
${Next}
|
||||||
|
|
||||||
|
${EndUnless}
|
||||||
|
|
||||||
|
System::Free $R0
|
||||||
|
|
||||||
|
Pop $0 ; get return value
|
||||||
|
Pop $R2 ; restore registers
|
||||||
|
Pop $R1
|
||||||
|
Pop $R0
|
||||||
|
Pop $2
|
||||||
|
Pop $1
|
||||||
|
Exch $0
|
||||||
|
FunctionEnd
|
||||||
|
|
||||||
|
Function GetProcessName
|
||||||
|
# ( Pid -- ProcessName )
|
||||||
|
Exch $2 ; get Pid, save $2
|
||||||
|
Push $0
|
||||||
|
Push $1
|
||||||
|
Push $3
|
||||||
|
Push $R0
|
||||||
|
|
||||||
|
System::Call "Kernel32::OpenProcess(i 1040, i 0, i r2)i .r3"
|
||||||
|
|
||||||
|
StrCpy $2 "<unknown>" ; set return value
|
||||||
|
|
||||||
|
${Unless} $3 = 0 ; $3 is hProcess
|
||||||
|
# get hMod array
|
||||||
|
System::Alloc 1024
|
||||||
|
Pop $R0
|
||||||
|
|
||||||
|
# params: Pid, &hMod, sizeof(hMod), &cb
|
||||||
|
System::Call "Psapi::EnumProcessModules(i r3, i R0, i 1024, *i .r1)i .r0"
|
||||||
|
|
||||||
|
${Unless} $0 = 0
|
||||||
|
# get first hMod
|
||||||
|
System::Call "*$R0(i .r0)"
|
||||||
|
|
||||||
|
# get BaseName; params: Pid, hMod, szBuffer, sizeof(szBuffer)
|
||||||
|
System::Call "Psapi::GetModuleBaseName(i r3, i r0, t .r2, i 256)i .r0"
|
||||||
|
${EndUnless}
|
||||||
|
|
||||||
|
System::Free $R0
|
||||||
|
System::Call "kernel32::CloseHandle(i r3)"
|
||||||
|
${EndUnless}
|
||||||
|
|
||||||
|
Pop $R0 ; restore registers
|
||||||
|
Pop $3
|
||||||
|
Pop $1
|
||||||
|
Pop $0
|
||||||
|
Exch $2 ; save process name
|
||||||
|
FunctionEnd
|
||||||
|
!endif
|
@ -1,5 +1,5 @@
|
|||||||
# uncomment on v3
|
# This now requires v3
|
||||||
# UniCode true
|
UniCode true
|
||||||
|
|
||||||
!define APPNAME "I2PBrowser-Launcher"
|
!define APPNAME "I2PBrowser-Launcher"
|
||||||
!define COMPANYNAME "I2P"
|
!define COMPANYNAME "I2P"
|
||||||
@ -11,11 +11,14 @@
|
|||||||
!define CONSOLE_URL "http://127.0.0.1:7657/home"
|
!define CONSOLE_URL "http://127.0.0.1:7657/home"
|
||||||
|
|
||||||
!include i2pbrowser-version.nsi
|
!include i2pbrowser-version.nsi
|
||||||
|
!include i2pbrowser-jpackage.nsi
|
||||||
|
!include FindProcess.nsh
|
||||||
|
|
||||||
var FFINSTEXE
|
var FFINSTEXE
|
||||||
var FFNONTORINSTEXE
|
var FFNONTORINSTEXE
|
||||||
var I2PINSTEXE
|
var I2PINSTEXE
|
||||||
|
|
||||||
|
|
||||||
!define FFINSTEXE
|
!define FFINSTEXE
|
||||||
!define FFNONTORINSTEXE
|
!define FFNONTORINSTEXE
|
||||||
!define FFINSTEXE32 "$PROGRAMFILES32\Mozilla Firefox\"
|
!define FFINSTEXE32 "$PROGRAMFILES32\Mozilla Firefox\"
|
||||||
@ -27,14 +30,14 @@ var I2PINSTEXE
|
|||||||
|
|
||||||
!define RAM_NEEDED_FOR_64BIT 0x80000000
|
!define RAM_NEEDED_FOR_64BIT 0x80000000
|
||||||
|
|
||||||
InstallDir "$PROGRAMFILES\${COMPANYNAME}\${APPNAME}"
|
InstallDir "$PROGRAMFILES64\${COMPANYNAME}\${APPNAME}"
|
||||||
|
|
||||||
# rtf or txt file - remember if it is txt, it must be in the DOS text format (\r\n)
|
# rtf or txt file - remember if it is txt, it must be in the DOS text format (\r\n)
|
||||||
LicenseData "licenses\LICENSE.index"
|
LicenseData "licenses\LICENSE.index"
|
||||||
# This will be in the installer/uninstaller's title bar
|
# This will be in the installer/uninstaller's title bar
|
||||||
Name "${COMPANYNAME} - ${APPNAME}"
|
Name "${COMPANYNAME} - ${APPNAME}"
|
||||||
Icon ui2pbrowser_icon.ico
|
Icon ui2pbrowser_icon.ico
|
||||||
OutFile "I2P-Profile-Installer-${VERSIONMAJOR}.${VERSIONMINOR}${VERSIONBUILD}.exe"
|
OutFile "I2P-Profile-Installer-${VERSIONMAJOR}.${VERSIONMINOR}.${VERSIONBUILD}.exe"
|
||||||
|
|
||||||
RequestExecutionLevel admin
|
RequestExecutionLevel admin
|
||||||
|
|
||||||
@ -169,10 +172,11 @@ Function .onInit
|
|||||||
StrCpy $FFINSTEXE "$PROFILE/Desktop/Tor Browser/Browser/"
|
StrCpy $FFINSTEXE "$PROFILE/Desktop/Tor Browser/Browser/"
|
||||||
${EndIf}
|
${EndIf}
|
||||||
${EndIf}
|
${EndIf}
|
||||||
${If} ${FileExists} "${I2PINSTEXE32}"
|
StrCpy $I2PINSTEXE "${I2PINSTEXE64}"
|
||||||
|
${If} ${FileExists} "${I2PINSTEXE32}\i2p.exe"
|
||||||
StrCpy $I2PINSTEXE "${I2PINSTEXE32}"
|
StrCpy $I2PINSTEXE "${I2PINSTEXE32}"
|
||||||
${EndIf}
|
${EndIf}
|
||||||
${If} ${FileExists} "${I2PINSTEXE64}"
|
${If} ${FileExists} "${I2PINSTEXE64}\i2p.exe"
|
||||||
StrCpy $I2PINSTEXE "${I2PINSTEXE64}"
|
StrCpy $I2PINSTEXE "${I2PINSTEXE64}"
|
||||||
${EndIf}
|
${EndIf}
|
||||||
FunctionEnd
|
FunctionEnd
|
||||||
@ -185,6 +189,36 @@ FunctionEnd
|
|||||||
|
|
||||||
Function routerDetect
|
Function routerDetect
|
||||||
${If} ${FileExists} "$I2PINSTEXE"
|
${If} ${FileExists} "$I2PINSTEXE"
|
||||||
|
Abort directory
|
||||||
|
${Else}
|
||||||
|
createDirectory $I2PINSTEXE
|
||||||
|
SetOutPath $I2PINSTEXE
|
||||||
|
File /nonfatal /a /r "I2P\"
|
||||||
|
File /nonfatal "I2P\config\jpackaged"
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE\"
|
||||||
|
SetOutPath "$I2PINSTEXE\"
|
||||||
|
File /nonfatal "I2P\config\clients.config"
|
||||||
|
File /nonfatal "I2P\config\i2ptunnel.config"
|
||||||
|
File /nonfatal "I2P\config\wrapper.config"
|
||||||
|
File /nonfatal "I2P\config\hosts.txt"
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE\webapps\"
|
||||||
|
SetOutPath "$I2PINSTEXE\webapps\"
|
||||||
|
File /nonfatal /a /r "I2P\config\webapps\"
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE\geoip\"
|
||||||
|
SetOutPath "$I2PINSTEXE\geoip\"
|
||||||
|
File /nonfatal /a /r "I2P\config\geoip\"
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE\certificates\"
|
||||||
|
SetOutPath "$I2PINSTEXE\certificates\"
|
||||||
|
File /nonfatal /a /r "I2P\config\certificates\"
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE\eepsite\"
|
||||||
|
SetOutPath "$I2PINSTEXE\eepsite\"
|
||||||
|
File /nonfatal /a /r "I2P\config\eepsite\"
|
||||||
|
|
||||||
Abort directory
|
Abort directory
|
||||||
${EndIf}
|
${EndIf}
|
||||||
FunctionEnd
|
FunctionEnd
|
||||||
@ -192,70 +226,71 @@ FunctionEnd
|
|||||||
# start default section
|
# start default section
|
||||||
Section Install
|
Section Install
|
||||||
|
|
||||||
|
${If} ${Silent}
|
||||||
|
${Do}
|
||||||
|
${FindProcess} "I2P.exe" $0
|
||||||
|
Sleep 500
|
||||||
|
${LoopWhile} $0 <> 0
|
||||||
|
${EndIf}
|
||||||
|
|
||||||
# set the installation directory as the destination for the following actions
|
# set the installation directory as the destination for the following actions
|
||||||
createDirectory $INSTDIR
|
createDirectory $INSTDIR
|
||||||
SetOutPath $INSTDIR
|
SetOutPath $INSTDIR
|
||||||
File ui2pbrowser_icon.ico
|
File ui2pbrowser_icon.ico
|
||||||
|
|
||||||
# Install the launcher scripts: This will need to be it's own section, since
|
# Update jpackaged I2P router, if it exists
|
||||||
# now I think we just need to let the user select if the user is using a non
|
${If} ${FileExists} "$I2PINSTEXE\jpackaged"
|
||||||
# default Firefox path.
|
createDirectory $I2PINSTEXE
|
||||||
FileOpen $0 "$INSTDIR\i2pbrowser.bat" w
|
SetOutPath $I2PINSTEXE
|
||||||
FileWrite $0 "@echo off"
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileWrite $0 'start "" "$I2PINSTEXE\i2p.exe"'
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileWrite $0 'start "" "$FFINSTEXE\firefox.exe" -no-remote -profile "$LOCALAPPDATA\${APPNAME}\firefox.profile.i2p" -url %1'
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileWrite $0 exit
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileClose $0
|
|
||||||
|
|
||||||
FileOpen $0 "$INSTDIR\i2pbrowser-private.bat" w
|
${If} ${Silent}
|
||||||
FileWrite $0 "@echo off"
|
ReadEnvStr $0 OLD_I2P_VERSION
|
||||||
FileWriteByte $0 "13"
|
${If} $0 < ${I2P_VERSION}
|
||||||
FileWriteByte $0 "10"
|
File /nonfatal /a /r "I2P\"
|
||||||
FileWrite $0 'start "" "$I2PINSTEXE\i2p.exe"'
|
File /nonfatal "I2P\config\jpackaged"
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileWrite $0 'start "" "$FFINSTEXE\firefox.exe" -no-remote -profile "$LOCALAPPDATA\${APPNAME}\firefox.profile.i2p" -private-window about:blank'
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileWrite $0 exit
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileClose $0
|
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE\"
|
||||||
|
SetOutPath "$I2PINSTEXE\"
|
||||||
|
|
||||||
# Install the launcher scripts: This will need to be it's own section, since
|
createDirectory "$I2PINSTEXE\webapps\"
|
||||||
# now I think we just need to let the user select if the user is using a non
|
SetOutPath "$I2PINSTEXE\webapps\"
|
||||||
# default Firefox path.
|
File /nonfatal /a /r "I2P\config\webapps\"
|
||||||
FileOpen $0 "$INSTDIR\i2pconfig.bat" w
|
|
||||||
FileWrite $0 "@echo off"
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileWrite $0 'start "" "$I2PINSTEXE\i2p.exe"'
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileWrite $0 'start "" "$FFNONTORINSTEXE\firefox.exe" -no-remote -profile "$LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p" -url %1'
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileWrite $0 exit
|
|
||||||
FileWriteByte $0 "13"
|
|
||||||
FileWriteByte $0 "10"
|
|
||||||
FileClose $0
|
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE\geoip\"
|
||||||
|
SetOutPath "$I2PINSTEXE\geoip\"
|
||||||
|
File /nonfatal /a /r "I2P\config\geoip\"
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE\certificates\"
|
||||||
|
SetOutPath "$I2PINSTEXE\certificates\"
|
||||||
|
File /nonfatal /a /r "I2P\config\certificates\"
|
||||||
|
${EndIf}
|
||||||
|
${Else}
|
||||||
|
File /nonfatal /a /r "I2P\"
|
||||||
|
File /nonfatal "I2P\config\jpackaged"
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE\"
|
||||||
|
SetOutPath "$I2PINSTEXE\"
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE\webapps\"
|
||||||
|
SetOutPath "$I2PINSTEXE\webapps\"
|
||||||
|
File /nonfatal /a /r "I2P\config\webapps\"
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE\geoip\"
|
||||||
|
SetOutPath "$I2PINSTEXE\geoip\"
|
||||||
|
File /nonfatal /a /r "I2P\config\geoip\"
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE\certificates\"
|
||||||
|
SetOutPath "$I2PINSTEXE\certificates\"
|
||||||
|
File /nonfatal /a /r "I2P\config\certificates\"
|
||||||
|
${EndIf}
|
||||||
|
${EndIf}
|
||||||
|
|
||||||
|
# Install the launcher scripts
|
||||||
|
createDirectory "$INSTDIR\licenses"
|
||||||
|
SetOutPath "$INSTDIR"
|
||||||
|
File win/i2pbrowser.bat
|
||||||
|
File win/i2pbrowser-private.bat
|
||||||
|
File win/i2pconfig.bat
|
||||||
|
|
||||||
# Install the licenses
|
# Install the licenses
|
||||||
createDirectory "$INSTDIR\licenses"
|
createDirectory "$INSTDIR\licenses"
|
||||||
@ -263,61 +298,75 @@ Section Install
|
|||||||
File /r licenses\*.*
|
File /r licenses\*.*
|
||||||
|
|
||||||
# Install the profile
|
# Install the profile
|
||||||
createDirectory "$LOCALAPPDATA\${APPNAME}\firefox.profile.i2p"
|
createDirectory "$INSTDIR\firefox.profile.i2p"
|
||||||
SetOutPath "$LOCALAPPDATA\${APPNAME}\firefox.profile.i2p"
|
SetOutPath "$INSTDIR\firefox.profile.i2p"
|
||||||
File profile/user.js
|
File profile\user.js
|
||||||
File profile/prefs.js
|
File profile\prefs.js
|
||||||
File profile/bookmarks.html
|
File profile\bookmarks.html
|
||||||
File profile/storage-sync.sqlite
|
File profile\storage-sync.sqlite
|
||||||
|
|
||||||
# Install the extensions
|
# Install the extensions
|
||||||
createDirectory "$LOCALAPPDATA\${APPNAME}\firefox.profile.i2p\extensions"
|
createDirectory "$INSTDIR\firefox.profile.i2p\extensions"
|
||||||
SetOutPath "$LOCALAPPDATA\${APPNAME}\firefox.profile.i2p\extensions"
|
SetOutPath "$INSTDIR\firefox.profile.i2p\extensions"
|
||||||
File "profile/extensions/{73a6fe31-595d-460b-a920-fcc0f8843232}.xpi"
|
File "profile\extensions\{73a6fe31-595d-460b-a920-fcc0f8843232}.xpi"
|
||||||
File profile/extensions/https-everywhere-eff@eff.org.xpi
|
File profile\extensions\https-everywhere-eff@eff.org.xpi
|
||||||
File profile/extensions/i2ppb@eyedeekay.github.io.xpi
|
File profile\extensions\i2prhz@eyedeekay.github.io.xpi
|
||||||
|
|
||||||
# Install the config profile
|
# Install the config profile
|
||||||
createDirectory "$LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p"
|
createDirectory "$INSTDIR\firefox.profile.config.i2p"
|
||||||
SetOutPath "$LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p"
|
SetOutPath "$INSTDIR\firefox.profile.config.i2p"
|
||||||
File app-profile/user.js
|
File app-profile\user.js
|
||||||
File app-profile/prefs.js
|
File app-profile\prefs.js
|
||||||
File app-profile/bookmarks.html
|
File app-profile\bookmarks.html
|
||||||
File app-profile/storage-sync.sqlite
|
File app-profile\storage-sync.sqlite
|
||||||
|
|
||||||
# Install the config extensions
|
# Install the config extensions
|
||||||
createDirectory "$LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p\extensions"
|
createDirectory "$INSTDIR\firefox.profile.config.i2p\extensions"
|
||||||
SetOutPath "$LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p\extensions"
|
SetOutPath "$INSTDIR\firefox.profile.config.i2p\extensions"
|
||||||
File profile/extensions/https-everywhere-eff@eff.org.xpi
|
File profile\extensions\https-everywhere-eff@eff.org.xpi
|
||||||
File profile/extensions/i2ppb@eyedeekay.github.io.xpi
|
File profile\extensions\i2prhz@eyedeekay.github.io.xpi
|
||||||
|
|
||||||
# Install the config userChrome
|
# Install the config userChrome
|
||||||
createDirectory "$LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p\chrome"
|
createDirectory "$INSTDIR\firefox.profile.config.i2p\chrome"
|
||||||
SetOutPath "$LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p\chrome"
|
SetOutPath "$INSTDIR\firefox.profile.config.i2p\chrome"
|
||||||
File app-profile/chrome/userChrome.css
|
File app-profile\chrome\userChrome.css
|
||||||
|
|
||||||
SetOutPath "$INSTDIR"
|
SetOutPath "$INSTDIR"
|
||||||
createDirectory "$SMPROGRAMS\${APPNAME}"
|
createDirectory "$SMPROGRAMS\${APPNAME}"
|
||||||
CreateShortCut "$SMPROGRAMS\${APPNAME}\${APPNAME}.lnk" "C:\Windows\system32\cmd.exe" "/c $\"$INSTDIR\i2pbrowser.bat$\" ${CONSOLE_URL}" "$INSTDIR\ui2pbrowser_icon.ico"
|
CreateShortCut "$SMPROGRAMS\${APPNAME}\Browse I2P.lnk" "C:\Windows\system32\cmd.exe" "/c $\"$INSTDIR\i2pbrowser.bat$\" ${CONSOLE_URL}" "$INSTDIR\ui2pbrowser_icon.ico"
|
||||||
CreateShortCut "$SMPROGRAMS\${APPNAME}\Private Browsing-${APPNAME}.lnk" "C:\Windows\system32\cmd.exe" "/c $\"$INSTDIR\i2pbrowser-private.bat$\"" "$INSTDIR\ui2pbrowser_icon.ico"
|
CreateShortCut "$SMPROGRAMS\${APPNAME}\Browse I2P - Temporary Identity.lnk" "C:\Windows\system32\cmd.exe" "/c $\"$INSTDIR\i2pbrowser-private.bat$\"" "$INSTDIR\ui2pbrowser_icon.ico"
|
||||||
CreateShortCut "$DESKTOP\${APPNAME}.lnk" "C:\Windows\system32\cmd.exe" "/c $\"$INSTDIR\i2pbrowser.bat$\" ${CONSOLE_URL}" "$INSTDIR\ui2pbrowser_icon.ico"
|
; CreateShortCut "$SMPROGRAMS\${APPNAME}\I2P Applications.lnk" "C:\Windows\system32\cmd.exe" "/c $\"$INSTDIR\i2pconfig.bat$\"" "$INSTDIR\ui2pbrowser_icon.ico"
|
||||||
CreateShortCut "$DESKTOP\Private Browsing-${APPNAME}.lnk" "C:\Windows\system32\cmd.exe" "/c $\"$INSTDIR\i2pbrowser-private.bat$\"" "$INSTDIR\ui2pbrowser_icon.ico"
|
|
||||||
|
|
||||||
|
CreateShortCut "$DESKTOP\Browse I2P.lnk" "C:\Windows\system32\cmd.exe" "/c $\"$INSTDIR\i2pbrowser.bat$\" ${CONSOLE_URL}" "$INSTDIR\ui2pbrowser_icon.ico"
|
||||||
|
CreateShortCut "$DESKTOP\Browse I2P - Temporary Identity.lnk" "C:\Windows\system32\cmd.exe" "/c $\"$INSTDIR\i2pbrowser-private.bat$\"" "$INSTDIR\ui2pbrowser_icon.ico"
|
||||||
|
; CreateShortCut "$DESKTOP\I2P Applications.lnk" "C:\Windows\system32\cmd.exe" "/c $\"$INSTDIR\i2pconfig.bat$\"" "$INSTDIR\ui2pbrowser_icon.ico"
|
||||||
|
|
||||||
|
;# Point the browser config setting in the base router.config
|
||||||
|
FileOpen $0 "$I2PINSTEXE\router.config" a
|
||||||
|
FileSeek $0 0 END
|
||||||
|
FileWriteByte $0 "13"
|
||||||
|
FileWriteByte $0 "10"
|
||||||
|
FileWrite $0 "routerconsole.browser=$\"$INSTDIR\i2pconfig.bat$\""
|
||||||
|
FileWriteByte $0 "13"
|
||||||
|
FileWriteByte $0 "10"
|
||||||
|
FileClose $0
|
||||||
|
|
||||||
SetShellVarContext current
|
SetShellVarContext current
|
||||||
Var /Global I2PAPPDATA
|
Var /Global I2PAPPDATA
|
||||||
|
|
||||||
IfFileExists "$I2PINSTEXE\clients.config" 0 +2
|
IfFileExists "$I2PINSTEXE\clients.config" 0 +2
|
||||||
StrCpy $I2PAPPDATA "$I2PINSTEXE"
|
StrCpy $I2PAPPDATA "$I2PINSTEXE"
|
||||||
IfFileExists "$APPDATA\I2P\clients.config.d" 0 +2
|
IfFileExists "$APPDATA\I2P\clients.config.d" 0 +2
|
||||||
StrCpy $I2PAPPDATA "$APPDATA\I2P\"
|
StrCpy $I2PAPPDATA "$APPDATA\I2P\"
|
||||||
IfFileExists "$LOCALAPPDATA\I2P\clients.config.d" 0 +2
|
IfFileExists "$LOCALAPPDATA\I2P\clients.config.d" 0 +2
|
||||||
StrCpy $I2PAPPDATA "$LOCALAPPDATA\I2P\"
|
StrCpy $I2PAPPDATA "$LOCALAPPDATA\I2P\"
|
||||||
|
IfFileExists "$LOCALAPPDATA\I2P\clients.config" 0 +2
|
||||||
|
StrCpy $I2PAPPDATA "$LOCALAPPDATA\I2P\"
|
||||||
|
|
||||||
createDirectory "$I2PAPPDATA"
|
createDirectory "$I2PAPPDATA"
|
||||||
SetOutPath "$I2PAPPDATA"
|
SetOutPath "$I2PAPPDATA"
|
||||||
|
|
||||||
;# Point the browser config setting
|
;# Point the browser config setting in the working config
|
||||||
FileOpen $0 "$I2PAPPDATA\router.config" a
|
FileOpen $0 "$I2PAPPDATA\router.config" a
|
||||||
FileSeek $0 0 END
|
FileSeek $0 0 END
|
||||||
FileWriteByte $0 "13"
|
FileWriteByte $0 "13"
|
||||||
@ -327,6 +376,9 @@ Section Install
|
|||||||
FileWriteByte $0 "10"
|
FileWriteByte $0 "10"
|
||||||
FileClose $0
|
FileClose $0
|
||||||
|
|
||||||
|
createDirectory "$I2PINSTEXE"
|
||||||
|
SetOutPath "$I2PINSTEXE"
|
||||||
|
|
||||||
SetOutPath "$INSTDIR"
|
SetOutPath "$INSTDIR"
|
||||||
# create the uninstaller
|
# create the uninstaller
|
||||||
WriteUninstaller "$INSTDIR\uninstall-i2pbrowser.exe"
|
WriteUninstaller "$INSTDIR\uninstall-i2pbrowser.exe"
|
||||||
@ -349,25 +401,25 @@ Section "uninstall"
|
|||||||
Delete $INSTDIR\ui2pbrowser_icon.ico
|
Delete $INSTDIR\ui2pbrowser_icon.ico
|
||||||
|
|
||||||
# Uninstall the profile
|
# Uninstall the profile
|
||||||
Delete $LOCALAPPDATA\${APPNAME}\firefox.profile.i2p\prefs.js
|
Delete $INSTDIR\firefox.profile.i2p\prefs.js
|
||||||
Delete $LOCALAPPDATA\${APPNAME}\firefox.profile.i2p\user.js
|
Delete $INSTDIR\firefox.profile.i2p\user.js
|
||||||
Delete $LOCALAPPDATA\${APPNAME}\firefox.profile.i2p\bookmarks.html
|
Delete $INSTDIR\firefox.profile.i2p\bookmarks.html
|
||||||
Delete $LOCALAPPDATA\${APPNAME}\firefox.profile.i2p\storage-sync.sqlite
|
Delete $INSTDIR\firefox.profile.i2p\storage-sync.sqlite
|
||||||
|
|
||||||
Delete $LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p\prefs.js
|
Delete $INSTDIR\firefox.profile.config.i2p\prefs.js
|
||||||
Delete $LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p\user.js
|
Delete $INSTDIR\firefox.profile.config.i2p\user.js
|
||||||
Delete $LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p\bookmarks.html
|
Delete $INSTDIR\firefox.profile.config.i2p\bookmarks.html
|
||||||
Delete $LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p\storage-sync.sqlite
|
Delete $INSTDIR\firefox.profile.config.i2p\storage-sync.sqlite
|
||||||
|
|
||||||
# Uninstall the extensions
|
# Uninstall the extensions
|
||||||
Delete "$LOCALAPPDATA\${APPNAME}\firefox.profile.i2p\extensions\{73a6fe31-595d-460b-a920-fcc0f8843232}.xpi"
|
Delete "$INSTDIR\firefox.profile.i2p\extensions\{73a6fe31-595d-460b-a920-fcc0f8843232}.xpi"
|
||||||
Delete "$LOCALAPPDATA\${APPNAME}\firefox.profile.i2p\extensions\https-everywhere-eff@eff.org.xpi"
|
Delete "$INSTDIR\firefox.profile.i2p\extensions\https-everywhere-eff@eff.org.xpi"
|
||||||
Delete "$LOCALAPPDATA\${APPNAME}\firefox.profile.i2p\extensions\i2ppb@eyedeekay.github.io.xpi"
|
Delete "$INSTDIR\firefox.profile.i2p\extensions\i2prhz@eyedeekay.github.io.xpi"
|
||||||
|
|
||||||
Delete "$LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p\extensions\https-everywhere-eff@eff.org.xpi"
|
Delete "$INSTDIR\firefox.profile.config.i2p\extensions\https-everywhere-eff@eff.org.xpi"
|
||||||
Delete "$LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p\extensions\i2ppb@eyedeekay.github.io.xpi"
|
Delete "$INSTDIR\firefox.profile.config.i2p\extensions\i2prhz@eyedeekay.github.io.xpi"
|
||||||
|
|
||||||
Delete "$LOCALAPPDATA\${APPNAME}\firefox.profile.config.i2p\config\userChrome.css"
|
Delete "$INSTDIR\firefox.profile.config.i2p\config\userChrome.css"
|
||||||
|
|
||||||
# Remove shortcuts and folders
|
# Remove shortcuts and folders
|
||||||
Delete "$SMPROGRAMS\${APPNAME}\${APPNAME}.lnk"
|
Delete "$SMPROGRAMS\${APPNAME}\${APPNAME}.lnk"
|
||||||
@ -376,11 +428,14 @@ Section "uninstall"
|
|||||||
Delete "$DESKTOP\${APPNAME}.lnk"
|
Delete "$DESKTOP\${APPNAME}.lnk"
|
||||||
Delete "$DESKTOP\Private Browsing-${APPNAME}.lnk"
|
Delete "$DESKTOP\Private Browsing-${APPNAME}.lnk"
|
||||||
rmDir "$SMPROGRAMS\${APPNAME}"
|
rmDir "$SMPROGRAMS\${APPNAME}"
|
||||||
rmDir "$LOCALAPPDATA\${APPNAME}\firefox.profile.i2p\extensions"
|
rmDir "$INSTDIR\firefox.profile.i2p\extensions"
|
||||||
rmDir "$LOCALAPPDATA\${APPNAME}\firefox.profile.i2p"
|
rmDir "$INSTDIR\firefox.profile.i2p"
|
||||||
rmDir "$LOCALAPPDATA\${APPNAME}"
|
rmDir "$LOCALAPPDATA\${APPNAME}"
|
||||||
rmDir "$INSTDIR"
|
rmDir "$INSTDIR"
|
||||||
|
|
||||||
|
${If} ${FileExists} "$I2PINSTEXE\jpackaged"
|
||||||
|
rmDir "$I2PINSTEXE"
|
||||||
|
${EndIf}
|
||||||
# delete the uninstaller
|
# delete the uninstaller
|
||||||
Delete "$INSTDIR\uninstall-i2pbrowser.exe"
|
Delete "$INSTDIR\uninstall-i2pbrowser.exe"
|
||||||
|
|
||||||
@ -394,5 +449,12 @@ SectionEnd
|
|||||||
!insertmacro MUI_PAGE_FINISH
|
!insertmacro MUI_PAGE_FINISH
|
||||||
|
|
||||||
Function LaunchLink
|
Function LaunchLink
|
||||||
ExecShell "" "$SMPROGRAMS\${APPNAME}\${APPNAME}.lnk"
|
${If} ${Silent}
|
||||||
|
ReadEnvStr $0 RESTART_I2P
|
||||||
|
${If} $0 != ""
|
||||||
|
Exec "$INSTDIR\i2pbrowser.bat"
|
||||||
|
${EndIf}
|
||||||
|
${Else}
|
||||||
|
Exec "$INSTDIR\i2pbrowser.bat"
|
||||||
|
${EndIf}
|
||||||
FunctionEnd
|
FunctionEnd
|
||||||
|
1
src/nsis/i2pbrowser-jpackage.nsi
Normal file
1
src/nsis/i2pbrowser-jpackage.nsi
Normal file
@ -0,0 +1 @@
|
|||||||
|
!define I2P_VERSION 0.9.50
|
@ -1,3 +1,3 @@
|
|||||||
!define VERSIONMAJOR 0
|
!define VERSIONMAJOR 0
|
||||||
!define VERSIONMINOR 03
|
!define VERSIONMINOR 04
|
||||||
!define VERSIONBUILD
|
!define VERSIONBUILD 0
|
||||||
|
@ -51,3 +51,10 @@ 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);
|
||||||
|
@ -170,7 +170,7 @@ user_pref("dom.serviceWorkers.enabled", false);
|
|||||||
user_pref("dom.serviceWorkers.interception.enabled", false);
|
user_pref("dom.serviceWorkers.interception.enabled", false);
|
||||||
user_pref("dom.storage.enabled", false);
|
user_pref("dom.storage.enabled", false);
|
||||||
user_pref("dom.webaudio.enabled", false);
|
user_pref("dom.webaudio.enabled", false);
|
||||||
user_pref("extensions.autoDisableScopes", 14);
|
user_pref("extensions.autoDisableScopes", 0);
|
||||||
user_pref("extensions.getAddons.cache.enabled", false);
|
user_pref("extensions.getAddons.cache.enabled", false);
|
||||||
user_pref("extensions.getAddons.showPane", false);
|
user_pref("extensions.getAddons.showPane", false);
|
||||||
user_pref("extensions.pocket.enabled", false);
|
user_pref("extensions.pocket.enabled", false);
|
||||||
@ -216,3 +216,9 @@ 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);
|
||||||
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("dom.w3c_touch_events.enabled", false);
|
||||||
|
@ -1 +1 @@
|
|||||||
0.3
|
0.04.0
|
||||||
|
@ -40,4 +40,5 @@ if [ -z $FIREFOX ]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
echo $FIREFOX --profile "$BROWSING_PROFILE" $@
|
||||||
$FIREFOX --profile "$BROWSING_PROFILE" $@
|
$FIREFOX --profile "$BROWSING_PROFILE" $@
|
38
src/win/i2pbrowser-private.bat
Normal file
38
src/win/i2pbrowser-private.bat
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
@echo on
|
||||||
|
|
||||||
|
if not exist "%ProgramFiles%\I2P\" (
|
||||||
|
set "ProgramFiles=C:\Program Files"
|
||||||
|
)
|
||||||
|
|
||||||
|
if exist "%ProgramFiles%\I2P\jpackaged" (
|
||||||
|
start "i2p" /D "%LOCALAPPDATA%\I2P" "%ProgramFiles%\I2P\i2p.exe"
|
||||||
|
) else (
|
||||||
|
start "i2p" "%ProgramFiles%\I2P\i2p.exe"
|
||||||
|
)
|
||||||
|
|
||||||
|
timeout /t 3
|
||||||
|
|
||||||
|
if exist "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p\" (
|
||||||
|
echo "profile is configured, updating extensions"
|
||||||
|
xcopy /s /i /y "%ProgramFiles%\I2P\I2PBrowser-Launcher\firefox.profile.i2p\extensions" "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p\extensions"
|
||||||
|
) else (
|
||||||
|
echo "configuring profile"
|
||||||
|
xcopy /s /i /y "%ProgramFiles%\I2P\I2PBrowser-Launcher\firefox.profile.i2p" "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p"
|
||||||
|
)
|
||||||
|
|
||||||
|
if exist "%USERPROFILE%/Desktop/Tor Browser/Browser/firefox.exe" (
|
||||||
|
start "i2pbrowser" "%USERPROFILE%/Desktop/Tor Browser/Browser/firefox.exe" -no-remote -profile "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p" -private-window about:blank
|
||||||
|
exit
|
||||||
|
)
|
||||||
|
|
||||||
|
if exist "%USERPROFILE%/OneDrive/Desktop/Tor Browser/Browser/firefox.exe" (
|
||||||
|
start "i2pbrowser" "%USERPROFILE%/OneDrive/Desktop/Tor Browser/Browser/firefox.exe" -no-remote -profile "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p" -private-window about:blank
|
||||||
|
exit
|
||||||
|
)
|
||||||
|
|
||||||
|
if exist "%ProgramFiles%\Mozilla Firefox\firefox.exe" (
|
||||||
|
start "i2pbrowser" "%ProgramFiles%\Mozilla Firefox\firefox.exe" -no-remote -profile "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p" -private-window about:blank
|
||||||
|
exit
|
||||||
|
)
|
||||||
|
|
||||||
|
exit
|
38
src/win/i2pbrowser.bat
Normal file
38
src/win/i2pbrowser.bat
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
@echo on
|
||||||
|
|
||||||
|
if not exist "%ProgramFiles%\I2P\" (
|
||||||
|
set "ProgramFiles=C:\Program Files"
|
||||||
|
)
|
||||||
|
|
||||||
|
if exist "%ProgramFiles%\I2P\jpackaged" (
|
||||||
|
start "i2p" /D "%LOCALAPPDATA%\I2P" "%ProgramFiles%\I2P\i2p.exe"
|
||||||
|
) else (
|
||||||
|
start "i2p" "%ProgramFiles%\I2P\i2p.exe"
|
||||||
|
)
|
||||||
|
|
||||||
|
timeout /t 3
|
||||||
|
|
||||||
|
if exist "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p\" (
|
||||||
|
echo "profile is configured, updating extensions"
|
||||||
|
xcopy /s /i /y "%ProgramFiles%\I2P\I2PBrowser-Launcher\firefox.profile.i2p\extensions" "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p\extensions"
|
||||||
|
) else (
|
||||||
|
echo "configuring profile"
|
||||||
|
xcopy /s /i /y "%ProgramFiles%\I2P\I2PBrowser-Launcher\firefox.profile.i2p" "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p"
|
||||||
|
)
|
||||||
|
|
||||||
|
if exist "%USERPROFILE%/Desktop/Tor Browser/Browser/firefox.exe" (
|
||||||
|
start "i2pbrowser" "%USERPROFILE%/Desktop/Tor Browser/Browser/firefox.exe" -no-remote -profile "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p" -url %1
|
||||||
|
exit
|
||||||
|
)
|
||||||
|
|
||||||
|
if exist "%USERPROFILE%/OneDrive/Desktop/Tor Browser/Browser/firefox.exe" (
|
||||||
|
start "i2pbrowser" "%USERPROFILE%/OneDrive/Desktop/Tor Browser/Browser/firefox.exe" -no-remote -profile "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p" -url %1
|
||||||
|
exit
|
||||||
|
)
|
||||||
|
|
||||||
|
if exist "%ProgramFiles%\Mozilla Firefox\firefox.exe" (
|
||||||
|
start "i2pbrowser" "%ProgramFiles%\Mozilla Firefox\firefox.exe" -no-remote -profile "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p" -url %1
|
||||||
|
exit
|
||||||
|
)
|
||||||
|
|
||||||
|
exit
|
13
src/win/i2pconfig.bat
Normal file
13
src/win/i2pconfig.bat
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
@echo off
|
||||||
|
|
||||||
|
if exist "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.config.i2p\" (
|
||||||
|
echo "profile is configured"
|
||||||
|
xcopy /s /i /y "$INSTDIR\firefox.profile.i2p\extensions" "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.i2p\extensions"
|
||||||
|
) else (
|
||||||
|
echo "configuring profile"
|
||||||
|
xcopy /s /i /y "$INSTDIR\firefox.profile.config.i2p" "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.config.i2p"
|
||||||
|
)
|
||||||
|
|
||||||
|
start "i2pconfig" "c:\Program Files\Mozilla Firefox\firefox.exe" -no-remote -profile "%LOCALAPPDATA%\I2PBrowser-Launcher\firefox.profile.config.i2p" -url %1
|
||||||
|
|
||||||
|
exit
|
Reference in New Issue
Block a user