diff options
author | Francesco Colista <fcolista@alpinelinux.org> | 2016-05-04 13:13:39 +0000 |
---|---|---|
committer | Francesco Colista <fcolista@alpinelinux.org> | 2016-05-04 13:13:43 +0000 |
commit | ed7b203f73102e2e15ee629c12aad42b682d4a9c (patch) | |
tree | 5a40e144cd70bf70277639c38d62ff5dbbfbcaf9 /testing/kiwiirc | |
parent | 600ae0872414197129bfe26f27e6264e339f6d07 (diff) | |
download | aports-ed7b203f73102e2e15ee629c12aad42b682d4a9c.tar.bz2 aports-ed7b203f73102e2e15ee629c12aad42b682d4a9c.tar.xz |
testing/kiwiirc: new aport
Diffstat (limited to 'testing/kiwiirc')
-rw-r--r-- | testing/kiwiirc/APKBUILD | 73 | ||||
-rw-r--r-- | testing/kiwiirc/kiwiirc.confd | 5 | ||||
-rw-r--r-- | testing/kiwiirc/kiwiirc.initd | 32 | ||||
-rw-r--r-- | testing/kiwiirc/kiwiirc.pre-install | 4 | ||||
-rw-r--r-- | testing/kiwiirc/kiwilauncher.patch | 24 | ||||
-rw-r--r-- | testing/kiwiirc/kiwipath.patch | 156 |
6 files changed, 294 insertions, 0 deletions
diff --git a/testing/kiwiirc/APKBUILD b/testing/kiwiirc/APKBUILD new file mode 100644 index 0000000000..ae0694159a --- /dev/null +++ b/testing/kiwiirc/APKBUILD @@ -0,0 +1,73 @@ +# Contributor: Francesco Colista <fcolista@alpinelinux.org> +# Maintainer: Francesco Colista <fcolista@alpinelinux.org> +pkgname=kiwiirc +_pkgname=KiwiIRC +pkgver=0.9.4 +pkgrel=0 +pkgdesc="A hand-crafted webirc client" +url="https://www.kiwiirc.com/" +arch="noarch" +license="AGPL3" +depends="nodejs>=0.10.0" +depends_dev="" +makedepends="$depends_dev nodejs" +install="$pkgname.pre-install" +subpackages="$pkgname-doc" +pkgusers="kiwiirc" +pkggroups="kiwiirc" +source="$pkgname-$pkgver.tar.gz::https://github.com/prawnsalad/$_pkgname/archive/v$pkgver.tar.gz + kiwilauncher.patch + kiwipath.patch + $pkgname.initd + $pkgname.confd" + +builddir="$srcdir"/$_pkgname-$pkgver +build() { + cd "$builddir" + npm -q install + npm -q dedupe +} + +package() { + cd "$builddir" + install -D -m644 config.example.js $pkgdir/etc/kiwiirc/config.js + install -D -m755 kiwi $pkgdir/usr/bin/kiwi + install -D -m644 package.json $pkgdir/usr/share/webapps/kiwiirc/package.json + install -d -m755 $pkgdir/usr/lib/kiwiirc/server_modules + install -d -m755 $pkgdir/var/lib/kiwiirc + install -d -m775 $pkgdir/var/run/kiwiirc + install -d -m644 $pkgdir/var/log/kiwiirc + install -d -m755 $pkgdir/usr/share/webapps/kiwiirc/server + install -d -m755 $pkgdir/usr/share/webapps/kiwiirc/node_modules + + cp -a client/* $pkgdir/var/lib/kiwiirc + cp -a node_modules $pkgdir/usr/share/webapps/kiwiirc/ + cp -a server $pkgdir/usr/share/webapps/kiwiirc + cp -a server_modules $pkgdir/usr/lib/kiwiirc + + chown -R $pkgusers:$pkggroups "$pkgdir"/etc/kiwiirc + chown -R $pkgusers:$pkggroups "$pkgdir"/usr/lib/kiwiirc + chown -R $pkgusers:$pkggroups "$pkgdir"/usr/share/webapps/kiwiirc + chown -R $pkgusers:$pkggroups "$pkgdir"/var/lib/kiwiirc + chown $pkgusers:$pkggroups "$pkgdir"/var/run/kiwiirc + + install -D -m755 $srcdir/$pkgname.initd $pkgdir/etc/init.d/$pkgname + install -D -m644 $srcdir/$pkgname.confd $pkgdir/etc/conf.d/$pkgname + install -D -m644 LICENSE.txt "$pkgdir"/usr/share/doc/$pkgname/LICENSE.txt +} + +md5sums="1a06e33088ca6ed89f857f7687470761 kiwiirc-0.9.4.tar.gz +c92dbf55621e1ed5d130c58405b14919 kiwilauncher.patch +c93b69c4bca4bce7e3e7520b6e9f4588 kiwipath.patch +96b27bb7baf6d8cca689b123527da265 kiwiirc.initd +372c26f6b491c2a69f4d8fbaff6a598b kiwiirc.confd" +sha256sums="72d63c3e88b0e510de761b4fd5ee889e77a3df14a8f2aa425bf291f7dafb23dc kiwiirc-0.9.4.tar.gz +8099343315fadf5fdc84095eba4a2ec53066b36e2f4f51cd871fe95a8fcc1489 kiwilauncher.patch +5803c819cc35aeeab5b9f69d91afa36f752f9749946cfbbed97fa06d0a444ecd kiwipath.patch +15827222103f8dd03ae1c579c12927f761da9174612fab0a43927b5275ccff5b kiwiirc.initd +73a1ec4ce7b379bd3e121100258ce03c45818ecee331c690d42d7fc991692466 kiwiirc.confd" +sha512sums="81034d4b1d6af93bd2fbacd302c0780996b87bbf0b936b61abb1ca04fb97939d956bf4704ada63766a4da04feb56957abf141ed74fff02fd7db237b6272a6ac4 kiwiirc-0.9.4.tar.gz +2b2b61d579fe73ba59c05b3bf9a8ac1bc43225ad414ab34474746731a443c56431ddc9156005a7d3890c65e2344c882d8731c1c36b7a07af0c7014fd4d37e811 kiwilauncher.patch +1bc8829398d1311384f8411bd65f6231831d2f24728d779f97a99b5e7e46758771c36b5daba215fe6508c728162bfbb22fdaa3be2b44988d59c53804e7005c40 kiwipath.patch +c902defbce14646fef798fdba81e8900d7ae50317a2b5f304cf5af803d8c0661bdc2806fa868c8f990f36021d91f6f3b189390fb990ce217f086d66960632025 kiwiirc.initd +416b807dee290b0d55020fd980dbf232615f173899d13fe859834cdb61af96a30c5edbeafa35e290cb9d9ed9695ae53abfc876fb4b73687dabfcb3467046a304 kiwiirc.confd" diff --git a/testing/kiwiirc/kiwiirc.confd b/testing/kiwiirc/kiwiirc.confd new file mode 100644 index 0000000000..ebf89cafdd --- /dev/null +++ b/testing/kiwiirc/kiwiirc.confd @@ -0,0 +1,5 @@ +# Kiwi IRC facultative paramters +# -v = verbose +# -c = config file path + +#args="-v" diff --git a/testing/kiwiirc/kiwiirc.initd b/testing/kiwiirc/kiwiirc.initd new file mode 100644 index 0000000000..fee5998a4f --- /dev/null +++ b/testing/kiwiirc/kiwiirc.initd @@ -0,0 +1,32 @@ +#!/sbin/openrc-run +# +# Open-RC init.d file for Kiwi IRC +# Copyright (c) 2016 - Francesco Colista (fcolista@alpinelinux.org) + +description="Kiwi IRC Daemon" +command="/usr/bin/kiwi" +pidfile="/var/run/kiwiirc/kiwiirc.pid" + +depend() { + use net + after firewall +} + +start() { + if ! [ -f /var/lib/kiwiirc/index.html ]; then + $command build + fi + $command start + eend $? +} + +stop() { + $command stop + eend $? +} + +status() { + $command status + eend $? +} + diff --git a/testing/kiwiirc/kiwiirc.pre-install b/testing/kiwiirc/kiwiirc.pre-install new file mode 100644 index 0000000000..53a5edb7dc --- /dev/null +++ b/testing/kiwiirc/kiwiirc.pre-install @@ -0,0 +1,4 @@ +#!/bin/sh +addgroup kiwiirc 2>/dev/null +adduser -S -H -h /var/lib/kiwiirc -s /sbin/nologin -G kiwiirc kiwiirc 2>/dev/null +exit 0 diff --git a/testing/kiwiirc/kiwilauncher.patch b/testing/kiwiirc/kiwilauncher.patch new file mode 100644 index 0000000000..cdc8545963 --- /dev/null +++ b/testing/kiwiirc/kiwilauncher.patch @@ -0,0 +1,24 @@ +index a1f1208..47770b6 100644 +--- a/server/helpers/launcher.js ++++ b/server/helpers/launcher.js +@@ -1,5 +1,5 @@ + var kiwi_app = '../kiwi.js'; +-var pidfile = '../../kiwiirc.pid'; ++var pidfile = '/run/kiwiirc/kiwiirc.pid'; + var pidfile_arg; + + // Check if a pidfile has been set as an argument +@@ -16,6 +16,13 @@ if (process.argv.indexOf('-p') > -1) { + } + } + ++try { ++ process.setgid('kiwiirc'); ++ process.setuid('kiwiirc'); ++} catch (e) { ++ console.error('Cannot switch to user kiwiirc. Try running as root.') ++ process.exit(); ++} + + var daemon = require('daemonize2').setup({ + main: kiwi_app, diff --git a/testing/kiwiirc/kiwipath.patch b/testing/kiwiirc/kiwipath.patch new file mode 100644 index 0000000000..41d645b4b9 --- /dev/null +++ b/testing/kiwiirc/kiwipath.patch @@ -0,0 +1,156 @@ +diff --git a/config.example.js b/config.example.js +index f432409..1049700 100644 +--- a/config.example.js ++++ b/config.example.js +@@ -6,7 +6,7 @@ conf.group = ""; + + + // Log file location +-conf.log = "kiwi.log"; ++conf.log = "/var/log/kiwi/kiwiirc.log"; + + + +@@ -53,7 +53,7 @@ conf.identd = { + + + // Where the client files are +-conf.public_http = "client/"; ++conf.public_http = "/var/lib/kiwiirc/"; + + // Transports available to the client. + // Behind an Apache reverse proxy? Uncomment the below - Apache does not support websockets! +@@ -122,7 +122,7 @@ conf.client_plugins = [ + + + // Directory to find the server modules +-conf.module_dir = "../server_modules/"; ++conf.module_dir = "/usr/lib/kiwiirc/server_modules/"; + + // Which modules to load + conf.modules = [ +diff --git a/kiwi b/kiwi +index ddcdfdf..dca2dcc 100755 +--- a/kiwi ++++ b/kiwi +@@ -1,11 +1,6 @@ + #!/bin/sh +-basedir=`dirname "$0"` + +-case `uname` in +- *CYGWIN*) basedir=`cygpath -w "$basedir"`;; +-esac +- +-$(command -v nodejs || command -v node) $basedir/server/helpers/launcher.js "$@" ++node /usr/share/webapps/kiwiirc/server/helpers/launcher.js "$@" + ret=$? + + exit $ret +diff --git a/server_modules/client_file_watcher.js b/server_modules/client_file_watcher.js +index 2c3a017..47ad093 100644 +--- a/server_modules/client_file_watcher.js ++++ b/server_modules/client_file_watcher.js +@@ -6,12 +6,12 @@ + + var fs = require('fs'); + var path = require('path'); +-var kiwiModules = require('../server/modules'); ++var kiwiModules = require('/usr/share/webapps/kiwiirc/server/modules'); + + var module = new kiwiModules.Module('client_file_watcher'); + + // Watch the common stylesheets +-fs.watch('client/assets/css', alertClients); ++fs.watch('/var/lib/kiwiirc/assets/css', alertClients); + + + // Watch the theme stylesheets +diff --git a/server_modules/control.js b/server_modules/control.js +index d1c9cbf..1e187ec 100644 +--- a/server_modules/control.js ++++ b/server_modules/control.js +@@ -5,8 +5,8 @@ + */ + + var net = require('net'), +- kiwiModules = require('../server/modules'), +- ControlInterface = require('../server/controlinterface.js'), ++ kiwiModules = require('/usr/share/webapps/kiwiirc/server/modules'), ++ ControlInterface = require('/usr/share/webapps/kiwiirc/server/controlinterface.js'), + _ = require('lodash'), + winston = require('winston'); + +diff --git a/server_modules/dnsbl.js b/server_modules/dnsbl.js +index 1a2c718..54a4300 100644 +--- a/server_modules/dnsbl.js ++++ b/server_modules/dnsbl.js +@@ -5,7 +5,7 @@ + */ + + var dns = require('dns'), +- kiwiModules = require('../server/modules'); ++ kiwiModules = require('/usr/share/webapps/kiwiirc/server/modules'); + + + // The available DNS zones to check against +diff --git a/server_modules/example.js b/server_modules/example.js +index d880c19..575dc5f 100644 +--- a/server_modules/example.js ++++ b/server_modules/example.js +@@ -1,4 +1,4 @@ +-var kiwiModules = require('../server/modules'); ++var kiwiModules = require('/usr/share/webapps/kiwiirc/server/modules'); + + var module = new kiwiModules.Module('Example Module'); + +diff --git a/server_modules/force_https.js b/server_modules/force_https.js +index 9ca8362..512ffed 100644 +--- a/server_modules/force_https.js ++++ b/server_modules/force_https.js +@@ -4,7 +4,7 @@ + * Keep users secure by redirecting them to HTTPS if not already + */ + +-var kiwiModules = require('../server/modules'); ++var kiwiModules = require('/usr/share/webapps/kiwiirc/server/modules'); + + var module = new kiwiModules.Module('force_https'); + +diff --git a/server_modules/proxychecker.js b/server_modules/proxychecker.js +index 660defc..7fb96e6 100644 +--- a/server_modules/proxychecker.js ++++ b/server_modules/proxychecker.js +@@ -5,7 +5,7 @@ + */ + + var util = require('util'), +- kiwiModules = require('../server/modules'); ++ kiwiModules = require('/usr/share/webapps/kiwiirc/server/modules'); + + + var module = new kiwiModules.Module('proxychecker'); +diff --git a/server_modules/stats.js b/server_modules/stats.js +index 736ba17..a9de440 100644 +--- a/server_modules/stats.js ++++ b/server_modules/stats.js +@@ -4,7 +4,7 @@ + * Retreive stats for internal kiwi events. Handy for graphing + */ + +-var kiwiModules = require('../server/modules'), ++var kiwiModules = require('/usr/share/webapps/kiwiirc/server/modules'), + fs = require('fs'); + + +diff --git a/server_modules/web_agent_debugger.js b/server_modules/web_agent_debugger.js +index 2358508..ef85e9f 100644 +--- a/server_modules/web_agent_debugger.js ++++ b/server_modules/web_agent_debugger.js +@@ -6,7 +6,7 @@ + */ + + +-var kiwiModules = require('../server/modules'), ++var kiwiModules = require('/usr/share/webapps/kiwiirc/server/modules'), + agent = require('webkit-devtools-agent'); + |