initial checkin
only works for standalone tests, plugin not supported yet
This commit is contained in:
2
CHANGES.txt
Normal file
2
CHANGES.txt
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
2023-12-17 0.0.1
|
||||||
|
- Initial checkin
|
17
LICENSE.txt
Normal file
17
LICENSE.txt
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
|
||||||
|
========================================================================
|
||||||
|
|
||||||
|
Includes code from syndie 1.107 (Public Domain)
|
||||||
|
|
||||||
|
Includes sqlite-jdbc-3.44.0.0.jar from https://github.com/xerial/sqlite-jdbc (Apache 2.0)
|
108
build.xml
Normal file
108
build.xml
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
<?xml version="1.0" encoding="ISO-8859-1"?>
|
||||||
|
<project basedir="." default="all" name="sqldb">
|
||||||
|
|
||||||
|
<property file="override.properties"/>
|
||||||
|
|
||||||
|
<property name="release.number" value="0.1.0" />
|
||||||
|
<property name="jdbc.version" value="3.44.1.0" />
|
||||||
|
<property name="jdbc.lib" value="lib/sqlite-jdbc-${jdbc.version}.jar" />
|
||||||
|
<property name="jdbc.url" value="https://github.com/xerial/sqlite-jdbc/releases/download/${jdbc.version}/sqlite-jdbc-${jdbc.version}.jar" />
|
||||||
|
<condition property="lib.available" >
|
||||||
|
<available file="${jdbc.lib}" type="file" />
|
||||||
|
</condition>
|
||||||
|
|
||||||
|
<target name="all" depends="clean,plugin" />
|
||||||
|
|
||||||
|
<target name="jar" >
|
||||||
|
<ant dir="src" target="build" />
|
||||||
|
</target>
|
||||||
|
|
||||||
|
<target name="plugin" depends="fetchlib, jar">
|
||||||
|
<mkdir dir="plugin/" />
|
||||||
|
<mkdir dir="plugin/lib/" />
|
||||||
|
<delete>
|
||||||
|
<!-- in installer but not update -->
|
||||||
|
<fileset dir="plugin/lib/" includes="sqlite-jdbc.jar" />
|
||||||
|
</delete>
|
||||||
|
<!-- get version number -->
|
||||||
|
<buildnumber file="scripts/build.number" />
|
||||||
|
|
||||||
|
<!-- make the update xpi2p -->
|
||||||
|
<!-- this contains everything except i2ptunnel.config -->
|
||||||
|
<copy file="LICENSE.txt" todir="plugin/" overwrite="true" />
|
||||||
|
<copy file="README.txt" todir="plugin/" overwrite="true" />
|
||||||
|
<copy file="CHANGES.txt" todir="plugin/" overwrite="true" />
|
||||||
|
<copy file="scripts/plugin.config" todir="plugin/" overwrite="true" />
|
||||||
|
<exec executable="echo" osfamily="unix" failonerror="true" output="plugin/plugin.config" append="true">
|
||||||
|
<arg value="update-only=true" />
|
||||||
|
</exec>
|
||||||
|
<exec executable="echo" osfamily="unix" failonerror="true" output="plugin/plugin.config" append="true">
|
||||||
|
<arg value="version=${release.number}-b${build.number}" />
|
||||||
|
</exec>
|
||||||
|
<!-- pull out musl and android -->
|
||||||
|
<jar destfile="plugin/lib/sqlite-jdbc.jar" manifest="${jdbc.lib}" filesetmanifest="mergewithoutmain" >
|
||||||
|
<zipfileset excludes="org/sqlite/native/Linux-Android org/sqlite/native/Linux-Android/**/* org/sqlite/native/Linux-Musl org/sqlite/native/Linux-Musl/**/* org/sqlite/native/Linux/ppc64 org/sqlite/native/Linux/ppc64/* org/sqlite/native/*/x86/ org/sqlite/native/*/x86/*" src="${jdbc.lib}" />
|
||||||
|
</jar>
|
||||||
|
<copy file="src/build/sqldb.jar" todir="plugin/lib/" />
|
||||||
|
<copy file="/usr/share/java/slf4j-api.jar" todir="plugin/lib/" />
|
||||||
|
<input message="Enter su3 signing key password:" addproperty="release.password.su3" />
|
||||||
|
<fail message="You must enter a password." >
|
||||||
|
<condition>
|
||||||
|
<equals arg1="${release.password.su3}" arg2=""/>
|
||||||
|
</condition>
|
||||||
|
</fail>
|
||||||
|
<!-- this will fail if no su3 keys exist, as it needs the password twice -->
|
||||||
|
<exec executable="scripts/makeplugin.sh" inputstring="${release.password.su3}" failonerror="true" >
|
||||||
|
<arg value="plugin" />
|
||||||
|
</exec>
|
||||||
|
<move file="sqldb.su3" tofile="sqldb-update.su3" overwrite="true" />
|
||||||
|
|
||||||
|
<!-- make the install xpi2p -->
|
||||||
|
<copy file="scripts/plugin.config" todir="plugin/" overwrite="true" />
|
||||||
|
<!-- Files in installer but not update. Be sure to Add to delete fileset above and clean target below -->
|
||||||
|
<exec executable="echo" osfamily="unix" failonerror="true" output="plugin/plugin.config" append="true">
|
||||||
|
<arg value="version=${release.number}-b${build.number}" />
|
||||||
|
</exec>
|
||||||
|
<exec executable="scripts/makeplugin.sh" inputstring="${release.password.su3}" failonerror="true" >
|
||||||
|
<arg value="plugin" />
|
||||||
|
</exec>
|
||||||
|
</target>
|
||||||
|
|
||||||
|
<target name="fetchlib" unless="lib.available" >
|
||||||
|
<echo message="It seems that you don't have '${jdbc.lib}' deployed." />
|
||||||
|
<echo message="The build script can download this file for you automatically," />
|
||||||
|
<echo message="or alternatively you can obtain it manually from:" />
|
||||||
|
<echo message="${jdbc.url}" />
|
||||||
|
<echo message="" />
|
||||||
|
<input message="Download JDBC library automatically?" validargs="y,n" addproperty="jdbc.download" />
|
||||||
|
<fail message="Aborting as requested. Please deploy the Jetty archive manually." >
|
||||||
|
<condition>
|
||||||
|
<equals arg1="${jdbc.download}" arg2="n"/>
|
||||||
|
</condition>
|
||||||
|
</fail>
|
||||||
|
<mkdir dir="lib/" />
|
||||||
|
<get src="${jdbc.url}" verbose="true" dest="${jdbc.lib}" />
|
||||||
|
</target>
|
||||||
|
|
||||||
|
<target name="distclean" depends="clean" />
|
||||||
|
|
||||||
|
<target name="clean" >
|
||||||
|
<ant dir="src" target="clean" />
|
||||||
|
<defaultexcludes remove="**/*~"/>
|
||||||
|
<delete>
|
||||||
|
<fileset dir="." includes="*/*.~ **/*.*~ */**/*.*~ *.*~" />
|
||||||
|
</delete>
|
||||||
|
<delete file="plugin/plugin.config" />
|
||||||
|
<delete dir="plugin/lib/" />
|
||||||
|
<delete file="plugin/CHANGES.txt" />
|
||||||
|
<delete file="plugin/LICENSE.txt" />
|
||||||
|
<delete file="plugin/README.txt" />
|
||||||
|
<delete file="sqldb.xpi2p" />
|
||||||
|
<delete file="sqldb-update.xpi2p" />
|
||||||
|
<delete file="sqldb.su3" />
|
||||||
|
<delete file="sqldb-update.su3" />
|
||||||
|
<delete file="plugin.zip" />
|
||||||
|
<delete dir="plugin/" />
|
||||||
|
</target>
|
||||||
|
|
||||||
|
</project>
|
47
resources/ddl_update0.txt
Normal file
47
resources/ddl_update0.txt
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
--
|
||||||
|
-- Version 1 sqlite3 database schema
|
||||||
|
--
|
||||||
|
|
||||||
|
-- this is the magic that makes it not dog slow
|
||||||
|
-- https://www.sqlite.org/wal.html
|
||||||
|
PRAGMA journal_mode = WAL;
|
||||||
|
|
||||||
|
BEGIN TRANSACTION;
|
||||||
|
|
||||||
|
-- info table
|
||||||
|
CREATE TABLE info ("key" TEXT PRIMARY KEY NOT NULL, "value" TEXT NOT NULL);
|
||||||
|
INSERT INTO info VALUES('version', '1');
|
||||||
|
INSERT INTO info VALUES('created', unixepoch("now"));
|
||||||
|
INSERT INTO info VALUES('upgraded', unixepoch("now"));
|
||||||
|
|
||||||
|
-- lists table
|
||||||
|
-- dots in a table name is really bad
|
||||||
|
-- there must be a way to escape it but let's just map to an internal name
|
||||||
|
CREATE TABLE lists ("list" TEXT PRIMARY KEY NOT NULL, "internal" TEXT NOT NULL);
|
||||||
|
INSERT INTO lists VALUES('privatehosts.txt', 'privatehoststxt');
|
||||||
|
INSERT INTO lists VALUES('userhosts.txt', 'userhoststxt');
|
||||||
|
INSERT INTO lists VALUES('hosts.txt', 'hoststxt');
|
||||||
|
|
||||||
|
-- list tables
|
||||||
|
-- hostname to primary entry (preferred, usually non-DSA) and optional alt (DSA) entry numbers
|
||||||
|
CREATE TABLE "privatehoststxt" ("hostname" TEXT PRIMARY KEY NOT NULL, "entry" INTEGER NOT NULL, "alt" INTEGER);
|
||||||
|
CREATE TABLE "userhoststxt" ("hostname" TEXT PRIMARY KEY NOT NULL, "entry" INTEGER NOT NULL, "alt" INTEGER);
|
||||||
|
CREATE TABLE "hoststxt" ("hostname" TEXT PRIMARY KEY NOT NULL, "entry" INTEGER NOT NULL, "alt" INTEGER);
|
||||||
|
|
||||||
|
-- entry table
|
||||||
|
-- id to dest, added time, modified time, notes, source, verified
|
||||||
|
-- Don't use AUTOINCREMENT
|
||||||
|
-- https://www.sqlite.org/autoinc.html
|
||||||
|
-- CREATE TABLE entries ("id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "dest" BLOB NOT NULL, "a" DATETIME NOT NULL, "m" DATETIME, "notes" TEXT, "s" TEXT, "v" BOOLEAN NOT NULL);
|
||||||
|
CREATE TABLE entries ("id" INTEGER PRIMARY KEY NOT NULL, "dest" BLOB NOT NULL, "a" DATETIME NOT NULL, "m" DATETIME, "notes" TEXT, "s" TEXT, "v" BOOLEAN NOT NULL);
|
||||||
|
|
||||||
|
-- reverse lookup table
|
||||||
|
-- first 8 bytes of hash to comma separated list of hostnames
|
||||||
|
CREATE TABLE "reverse" ("hash" INTEGER PRIMARY KEY NOT NULL, "hostnames" TEXT NOT NULL);
|
||||||
|
|
||||||
|
COMMIT TRANSACTION;
|
||||||
|
|
||||||
|
-- https://www.sqlite.org/pragma.html#synchronous
|
||||||
|
PRAGMA main.synchronous = NORMAL;
|
||||||
|
-- https://www.sqlite.org/pragma.html#pragma_wal_checkpoint
|
||||||
|
PRAGMA main.wal_checkpoint(FULL);
|
147
scripts/makeplugin.sh
Executable file
147
scripts/makeplugin.sh
Executable file
@ -0,0 +1,147 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
#
|
||||||
|
# basic packaging up of a plugin
|
||||||
|
#
|
||||||
|
# usage: makeplugin.sh plugindir
|
||||||
|
#
|
||||||
|
# zzz 2010-02
|
||||||
|
# zzz 2014-08 added support for su3 files
|
||||||
|
#
|
||||||
|
|
||||||
|
if [ -z "$I2P" -a -d "$PWD/../i2p.i2p/pkg-temp" ]; then
|
||||||
|
export I2P=../i2p.i2p/pkg-temp
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -d "$I2P" ]; then
|
||||||
|
echo "Can't locate your I2P installation. Please add a environment variable named I2P with the path to the folder as value"
|
||||||
|
echo "On OSX this solved with running: export I2P=/Applications/i2p if default install directory is used."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
PUBKEYDIR=$HOME/.i2p-plugin-keys
|
||||||
|
PUBKEYFILE=$PUBKEYDIR/plugin-public-signing.key
|
||||||
|
PRIVKEYFILE=$PUBKEYDIR/plugin-private-signing.key
|
||||||
|
B64KEYFILE=$PUBKEYDIR/plugin-public-signing.txt
|
||||||
|
PUBKEYSTORE=$PUBKEYDIR/plugin-su3-public-signing.crt
|
||||||
|
PRIVKEYSTORE=$PUBKEYDIR/plugin-su3-keystore.ks
|
||||||
|
KEYTYPE=RSA_SHA512_4096
|
||||||
|
|
||||||
|
PLUGINDIR=${1:-plugin}
|
||||||
|
|
||||||
|
PC=plugin.config
|
||||||
|
PCT=${PC}.tmp
|
||||||
|
|
||||||
|
if [ ! -d $PLUGINDIR ]
|
||||||
|
then
|
||||||
|
echo "You must have a $PLUGINDIR directory"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -f $PLUGINDIR/$PC ]
|
||||||
|
then
|
||||||
|
echo "You must have a $PLUGINDIR/$PC file"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
SIGNER=`grep '^signer=' $PLUGINDIR/$PC`
|
||||||
|
if [ "$?" -ne "0" ]
|
||||||
|
then
|
||||||
|
echo "You must have a plugin name in $PC"
|
||||||
|
echo 'For example name=foo'
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
SIGNER=`echo $SIGNER | cut -f 2 -d '='`
|
||||||
|
|
||||||
|
if [ ! -f $PRIVKEYFILE ]
|
||||||
|
then
|
||||||
|
echo "Creating new XPI2P DSA keys"
|
||||||
|
mkdir -p $PUBKEYDIR || exit 1
|
||||||
|
java -cp $I2P/lib/i2p.jar net.i2p.crypto.TrustedUpdate keygen $PUBKEYFILE $PRIVKEYFILE || exit 1
|
||||||
|
java -cp $I2P/lib/i2p.jar net.i2p.data.Base64 encode $PUBKEYFILE $B64KEYFILE || exit 1
|
||||||
|
rm -rf logs/
|
||||||
|
chmod 444 $PUBKEYFILE $B64KEYFILE
|
||||||
|
chmod 400 $PRIVKEYFILE
|
||||||
|
echo "Created new XPI2P keys: $PUBKEYFILE $PRIVKEYFILE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -f $PRIVKEYSTORE ]
|
||||||
|
then
|
||||||
|
echo "Creating new SU3 $KEYTYPE keys for $SIGNER"
|
||||||
|
java -cp $I2P/lib/i2p.jar net.i2p.crypto.SU3File keygen -t $KEYTYPE $PUBKEYSTORE $PRIVKEYSTORE $SIGNER || exit 1
|
||||||
|
echo '*** Save your password in a safe place!!! ***'
|
||||||
|
rm -rf logs/
|
||||||
|
# copy to the router dir so verify will work
|
||||||
|
CDIR=$I2P/certificates/plugin
|
||||||
|
mkdir -p $CDIR || exit 1
|
||||||
|
CFILE=$CDIR/`echo $SIGNER | sed s/@/_at_/`.crt
|
||||||
|
cp $PUBKEYSTORE $CFILE
|
||||||
|
chmod 444 $PUBKEYSTORE
|
||||||
|
chmod 400 $PRIVKEYSTORE
|
||||||
|
chmod 644 $CFILE
|
||||||
|
echo "Created new SU3 keys: $PUBKEYSTORE $PRIVKEYSTORE"
|
||||||
|
echo "Copied public key to $CFILE for testing"
|
||||||
|
fi
|
||||||
|
|
||||||
|
rm -f plugin.zip
|
||||||
|
|
||||||
|
OPWD=$PWD
|
||||||
|
cd $PLUGINDIR
|
||||||
|
|
||||||
|
grep -q '^name=' $PC
|
||||||
|
if [ "$?" -ne "0" ]
|
||||||
|
then
|
||||||
|
echo "You must have a plugin name in $PC"
|
||||||
|
echo 'For example name=foo'
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
grep -q '^version=' $PC
|
||||||
|
if [ "$?" -ne "0" ]
|
||||||
|
then
|
||||||
|
echo "You must have a version in $PC"
|
||||||
|
echo 'For example version=0.1.2'
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# update the date
|
||||||
|
grep -v '^date=' $PC > $PCT
|
||||||
|
DATE=`date '+%s000'`
|
||||||
|
echo "date=$DATE" >> $PCT
|
||||||
|
mv $PCT $PC || exit 1
|
||||||
|
|
||||||
|
# add our Base64 key
|
||||||
|
grep -v '^key=' $PC > $PCT
|
||||||
|
B64KEY=`cat $B64KEYFILE`
|
||||||
|
echo "key=$B64KEY" >> $PCT || exit 1
|
||||||
|
mv $PCT $PC || exit 1
|
||||||
|
|
||||||
|
# zip it
|
||||||
|
zip -r $OPWD/plugin.zip * || exit 1
|
||||||
|
|
||||||
|
# get the version and use it for the sud header
|
||||||
|
VERSION=`grep '^version=' $PC | cut -f 2 -d '='`
|
||||||
|
# get the name and use it for the file name
|
||||||
|
NAME=`grep '^name=' $PC | cut -f 2 -d '='`
|
||||||
|
XPI2P=${NAME}.xpi2p
|
||||||
|
SU3=${NAME}.su3
|
||||||
|
cd $OPWD
|
||||||
|
|
||||||
|
# sign it
|
||||||
|
echo "Signing version $VERSION by $SIGNER"
|
||||||
|
java -cp $I2P/lib/i2p.jar net.i2p.crypto.TrustedUpdate sign plugin.zip $XPI2P $PRIVKEYFILE $VERSION || exit 1
|
||||||
|
java -cp $I2P/lib/i2p.jar net.i2p.crypto.SU3File sign -c PLUGIN -t $KEYTYPE plugin.zip $SU3 $PRIVKEYSTORE $VERSION $SIGNER || exit 1
|
||||||
|
rm -f plugin.zip
|
||||||
|
|
||||||
|
# verify
|
||||||
|
echo 'Verifying. ...'
|
||||||
|
java -cp $I2P/lib/i2p.jar net.i2p.crypto.TrustedUpdate showversion $XPI2P || exit 1
|
||||||
|
java -cp $I2P/lib/i2p.jar -Drouter.trustedUpdateKeys=$B64KEY net.i2p.crypto.TrustedUpdate verifysig $XPI2P || exit 1
|
||||||
|
java -cp $I2P/lib/i2p.jar net.i2p.crypto.SU3File showversion $SU3 || exit 1
|
||||||
|
java -cp $I2P/lib/i2p.jar net.i2p.crypto.SU3File verifysig -k $PUBKEYSTORE $SU3 || exit 1
|
||||||
|
rm -rf logs/
|
||||||
|
|
||||||
|
echo 'Plugin files created: '
|
||||||
|
wc -c $XPI2P
|
||||||
|
wc -c $SU3
|
||||||
|
|
||||||
|
exit 0
|
15
scripts/plugin.config
Normal file
15
scripts/plugin.config
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
name=sqldb
|
||||||
|
signer=zzz-plugin@mail.i2p
|
||||||
|
consoleLinkName=SQLDB
|
||||||
|
consoleLinkURL=/dns
|
||||||
|
consoleLinkTooltip=sqlite3 addressbook database
|
||||||
|
icon-code=iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAMAAACdt4HsAAABm1BMVEUAAAAZGRkZGRkaGhoZGRkZGRkZGRkZGRkYGBgZGRkYGBgZGRkYGBgZGRkZGRkXFxcYGBgZGRkZGRkZGRkZGRkAAAAZGRnziRYTExPzfhbzbhbzdxbzgxbzlRYLCwvzjhbzcxbMzMzzkBb~~~~~~Pl0dHRdXV3GxsYnJyfe3t7OycbBwcGcnJyHh4cjEgP39~f96dSurq5~f397e3tra2tlZWU7OzseHh7haRSGSAsOBwGpqKeWlpbgpnRUVFRNTU00NDTxmynPbRJwNgpXLwdEJQY4IAUVCwLy8vL83sK7u7uysrL7yqf6v5Tdr4H4t3H4rGz2pEvnjUnqnkQvLy~zii30gyjxdCLqdhXLexK9bhGQTQ1-QAtlLgn-9u~Pxr7Uvqr71KbYuJz6yZn5v4T3pVv3s1rkmVr1nzr1kzLyjiPzex~pbBXJYxLJXRK~XxG4aBCYRQ5iNQlMKgctGgT7-~vas4zhnGj2qlNERETlhRTefxTedRTVfxOsZhC0YBC4UhCpWw9wQgr4sH~kqF7sizVpSyfWXxOZVw56Yx8pAAAAFXRSTlMAjPQOr8vV7eVwaVtPNyUa27WCwoZvol0xAAAEx0lEQVRYw72XZ1PbQBCGXQEnVMNJAjtyjpPcbWxsMB2SQOg1tCT0EiA9kN578rOzd4eQZUuO8iXPjGfkmdv3dm-v7DqsaKht8XhrBKDG6~HXNjj-iTpnlVBClbPOrrXb18htJElmSNK5hs9tx9zp4saCXOgOq6qaH-qWkCQzEZf~rxKXqvnU0c6pCUKIohDKREKNckeqL1U0r~cyc6kzRpTJg8OTILBysji~nyEkpnKJ5npr-8suZp7sUHbvXTFybX6SvEhKVMJ12creSaeXUx1bB6utJqzsKx0pthZOc3sPnX4kpsw-uNozmr5xtZzVGRIboU54zOyb6PQ5kjkWxbdphNBd0YTFDFGpE03m88v9ZD8Ew04R8Fw0I7RLsrKZD05qH1EWqKePEUNz~GGPIY4FMkUVnCXrT-2nlMNWyhhirLM~66MIpZ-0FnGoJKjCZUP-XWCfJTx3txHnNvt3hoBxQ0rvKf2g4CreD83ggErmg4xRxPkUBE7ZZ1~QwALJgQveov0L9iNkpo3Rg855Bn82-Odmm5FZMgIKF7vaXQ0BxDIil7-rCWzo39eDRsRMDIKo1k6WHxxIkcV2TloTGG3~iDjP20s5VlJ6JtywglLHTIDzCHHo2mtfvYEyZjskWEfugg8cSCqrAc4NdEGf9tFTLvBgKwku-JhAFazAi93QOeOojLGQCQfUhUZ2~7EUnoicp6icL6IJ95VOcKGOb2I5NqklaBOZkN589ritlJmYDMvII4iSBW2f9iErxt63GlgkURZDAzigkmtXOHeQNaNXjLAYGhy1sASJjCZ7iiqwbnRhcgoup1pHiyCgiVktMMsI-N428G0C0UVogl1E5kWOdQQmV8xrIkhwsXgFqZu8DnG-oop8CBVzTLolOJI1gjxEVq5yxlFFjBdtgIRlocYBSciTVf0cVOTs7qOAjqLCTnCwLLZzepENbn79-JYP39IEwttBThrZ5IwNx2FNIM7z8gvZ5jMMX8NDIEAXcRgHGbYi0O~LFfwGFpGmcRnznTyGbMJv7Ft4mabRAxsJL7VSxpFtrsPwIww3QhM9zSjxir1AyD70sRpMwFZuYYdpYI~vY~uIwE5SpoepAQS64iLw-98E7rMsQvnXKEgFvAQubSLb9MHwI1yQhKrzKy37EhblJrJNLwzfmz6~0upYDJDIPmSTsQ-0aGIRsOKzkVYGg8H3yB7jX4KUOSzzCPjD0rm99hnZ4sbDNspaPAcO-PSnLTLYa-ckbmjP7FxEpk-bXt7k8c-~GffeCV1wC-fBAX~x8z7dX3HmJ-uGl3Eny5734gIjilXruAMlzOEoLzA0vDSVeBhZ8DRk5DtLYXNpkZWKdFsJiAZu4RQrssrKvGTCQsH4si7FB1iZZ1JoDuBhq9OvcxRPskLTtNRN4Zz5~aMzx~wXPBbFdhj3Ryt58GMHd-nFtpkP0SzOSWX3TxtnbRBPR1m5X6nhyEciaonEO17UDG5H8rzhqNjyyHIO44FhuViAbt6X8Uhn5ZYHqG8WmER4GuN-dWhEYq4Ull7txXG2izdd3nobbZ8sF8LJBGZE4JcY6CrYavsAt98lcA0kLb8ZCofDw8sSor4DLqfbVutbZd76Nvrc~6P51tt~v97-t1i3~38A57d5M52iLPcAAAAASUVORK5CYII=
|
||||||
|
description=BitTorrent OpenTracker
|
||||||
|
author=zzz
|
||||||
|
updateURL=http://stats.i2p/i2p/plugins/sqldb-update.xpi2p
|
||||||
|
updateURL.su3=http://stats.i2p/i2p/plugins/sqldb-update.su3
|
||||||
|
websiteURL=http://zzz.i2p/forums/16
|
||||||
|
license=Apache 2.0
|
||||||
|
min-jetty-version=9
|
||||||
|
min-i2p-version=0.9.31
|
||||||
|
update-only=true
|
49
src/build.xml
Normal file
49
src/build.xml
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project basedir="." default="all" name="i2psnark">
|
||||||
|
<property name="i2pbase" value="../../i2p.i2p"/>
|
||||||
|
<property name="i2plib" value="${i2pbase}/build"/>
|
||||||
|
<path id="cp">
|
||||||
|
<pathelement path="${java.class.path}" />
|
||||||
|
<pathelement location="${i2plib}/i2p.jar" />
|
||||||
|
<pathelement location="${ant.home}/lib/ant.jar"/>
|
||||||
|
</path>
|
||||||
|
|
||||||
|
<target name="all" depends="clean, build" />
|
||||||
|
<target name="build" depends="jar" />
|
||||||
|
<target name="builddep">
|
||||||
|
</target>
|
||||||
|
|
||||||
|
<property name="javac.compilerargs" value="" />
|
||||||
|
<property name="javac.version" value="1.8" />
|
||||||
|
|
||||||
|
<target name="compile">
|
||||||
|
<mkdir dir="./build" />
|
||||||
|
<mkdir dir="./build/obj" />
|
||||||
|
<javac
|
||||||
|
srcdir="./java"
|
||||||
|
debug="true" deprecation="on" source="${javac.version}" target="${javac.version}"
|
||||||
|
destdir="./build/obj"
|
||||||
|
includeAntRuntime="false"
|
||||||
|
classpath="${i2plib}/i2p.jar" >
|
||||||
|
<compilerarg line="${javac.compilerargs}" />
|
||||||
|
</javac>
|
||||||
|
</target>
|
||||||
|
|
||||||
|
<target name="jar" depends="builddep, compile">
|
||||||
|
<mkdir dir="build/obj/net/i2p/client/naming/sqldb/resources" />
|
||||||
|
<copy todir="build/obj/net/i2p/client/naming/sqldb/resources" >
|
||||||
|
<fileset dir="../resources" />
|
||||||
|
</copy>
|
||||||
|
<jar destfile="build/sqldb.jar" basedir="./build/obj" includes="**/*.class **/resources/*" >
|
||||||
|
</jar>
|
||||||
|
</target>
|
||||||
|
|
||||||
|
<target name="clean">
|
||||||
|
<delete dir="./build" />
|
||||||
|
</target>
|
||||||
|
|
||||||
|
<target name="cleandep" depends="clean">
|
||||||
|
</target>
|
||||||
|
<target name="distclean" depends="clean">
|
||||||
|
</target>
|
||||||
|
</project>
|
1138
src/java/net/i2p/client/naming/sqldb/DBClient.java
Normal file
1138
src/java/net/i2p/client/naming/sqldb/DBClient.java
Normal file
File diff suppressed because it is too large
Load Diff
143
src/java/net/i2p/client/naming/sqldb/DBInit.java
Normal file
143
src/java/net/i2p/client/naming/sqldb/DBInit.java
Normal file
@ -0,0 +1,143 @@
|
|||||||
|
package net.i2p.client.naming.sqldb;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.PreparedStatement;
|
||||||
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
|
||||||
|
import net.i2p.I2PAppContext;
|
||||||
|
import net.i2p.util.Log;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize the database, creating and updating to the latest version if necessary
|
||||||
|
*
|
||||||
|
* Adapted from syndie (public domain)
|
||||||
|
*/
|
||||||
|
class DBInit {
|
||||||
|
|
||||||
|
private final Connection _con;
|
||||||
|
private final Log _log;
|
||||||
|
|
||||||
|
private static final String DDL_PREFIX = "/net/i2p/client/naming/sqldb/resources/ddl_update";
|
||||||
|
private static final String DDL_SUFFIX = ".txt";
|
||||||
|
|
||||||
|
public DBInit(I2PAppContext ctx, Connection dbConn) {
|
||||||
|
_con = dbConn;
|
||||||
|
_log = ctx.logManager().getLog(DBInit.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize the DB, update to latest version if necessary
|
||||||
|
*/
|
||||||
|
public void initDB() throws SQLException {
|
||||||
|
int version = checkDBVersion();
|
||||||
|
if (_log.shouldLog(Log.DEBUG))
|
||||||
|
_log.debug("Known DB version: " + version);
|
||||||
|
if (version < 0) {
|
||||||
|
if (_log.shouldLog(Log.INFO))
|
||||||
|
_log.info("Building the database...");
|
||||||
|
}
|
||||||
|
int updates = getDBUpdateCount();
|
||||||
|
if (updates <= 0)
|
||||||
|
throw new SQLException("No DDL 0");
|
||||||
|
for (int i = version + 1; i < updates; i++) {
|
||||||
|
if (i >= version) {
|
||||||
|
if (_log.shouldLog(Log.DEBUG))
|
||||||
|
_log.debug("Updating database version " + i + " to " + (i+1));
|
||||||
|
updateDB(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private int checkDBVersion() {
|
||||||
|
PreparedStatement stmt = null;
|
||||||
|
try {
|
||||||
|
stmt = _con.prepareStatement("SELECT value FROM info WHERE key = 'version'");
|
||||||
|
ResultSet rs = stmt.executeQuery();
|
||||||
|
while (rs.next()) {
|
||||||
|
int rv = rs.getInt(1);
|
||||||
|
if (!rs.wasNull())
|
||||||
|
return rv;
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
} catch (SQLException se) {
|
||||||
|
if (_log.shouldLog(Log.WARN))
|
||||||
|
_log.warn("Unable to check the database version (does not exist?)", se);
|
||||||
|
return -1;
|
||||||
|
} finally {
|
||||||
|
if (stmt != null) try { stmt.close(); } catch (SQLException se) {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private int getDBUpdateCount() {
|
||||||
|
int updates = 0;
|
||||||
|
while (true) {
|
||||||
|
InputStream in = getClass().getResourceAsStream(DDL_PREFIX + updates + DDL_SUFFIX);
|
||||||
|
if (in != null) {
|
||||||
|
updates++;
|
||||||
|
try { in.close(); } catch (IOException ioe) {}
|
||||||
|
} else {
|
||||||
|
if (_log.shouldLog(Log.DEBUG))
|
||||||
|
_log.debug("There were " + updates + " database updates known");
|
||||||
|
return updates;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new DB with the version 1 ddl_update0.txt, or
|
||||||
|
* Update from oldVersion to oldVersion + 1 using ddl_update{oldVersion}.txt
|
||||||
|
*/
|
||||||
|
private void updateDB(int oldVersion) throws SQLException {
|
||||||
|
StringBuilder cmdBuf = new StringBuilder();
|
||||||
|
BufferedReader r = null;
|
||||||
|
try {
|
||||||
|
InputStream in = getClass().getResourceAsStream(DDL_PREFIX + oldVersion + DDL_SUFFIX);
|
||||||
|
if (in != null) {
|
||||||
|
r = new BufferedReader(new InputStreamReader(in));
|
||||||
|
String line = null;
|
||||||
|
while ( (line = r.readLine()) != null) {
|
||||||
|
line = line.trim();
|
||||||
|
if (line.startsWith("//") || line.startsWith("--"))
|
||||||
|
continue;
|
||||||
|
cmdBuf.append(' ').append(line);
|
||||||
|
if (line.endsWith(";")) {
|
||||||
|
exec(cmdBuf.toString());
|
||||||
|
cmdBuf.setLength(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
r.close();
|
||||||
|
r = null;
|
||||||
|
} else {
|
||||||
|
throw new SQLException("Cannot load update for database version " + oldVersion);
|
||||||
|
}
|
||||||
|
} catch (IOException ioe) {
|
||||||
|
if (_log.shouldLog(Log.ERROR))
|
||||||
|
_log.error("Error reading the db script", ioe);
|
||||||
|
throw new SQLException(ioe.toString());
|
||||||
|
} catch (SQLException se) {
|
||||||
|
if (_log.shouldLog(Log.ERROR))
|
||||||
|
_log.error("Error building the db, failed on statement: " + cmdBuf, se);
|
||||||
|
throw se;
|
||||||
|
} finally {
|
||||||
|
if (r != null) try { r.close(); } catch (IOException ioe) {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void exec(String cmd) throws SQLException {
|
||||||
|
if (_log.shouldLog(Log.DEBUG))
|
||||||
|
_log.debug("Exec [" + cmd + "]");
|
||||||
|
PreparedStatement stmt = null;
|
||||||
|
try {
|
||||||
|
stmt = _con.prepareStatement(cmd);
|
||||||
|
stmt.execute();
|
||||||
|
} finally {
|
||||||
|
if (stmt != null) stmt.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
1428
src/java/net/i2p/client/naming/sqldb/SQLNamingService.java
Normal file
1428
src/java/net/i2p/client/naming/sqldb/SQLNamingService.java
Normal file
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user