[tor-commits] [flashproxy/master] Add instructions for building the Cumulus server.
dcf at torproject.org
dcf at torproject.org
Fri Jun 17 08:36:04 UTC 2011
commit 67d49a45b114ac93b9fe36592509bf9fd1c2804b
Author: David Fifield <david at bamsoftware.com>
Date: Fri Jun 17 01:19:34 2011 -0700
Add instructions for building the Cumulus server.
---
Cumulus-no-manage-log.patch | 39 ++++++++++++++++++++++++++++++
README | 32 +++++++++++++++++++++++++
cumulus | 55 +++++++++++++++++++++++++++++++++++++++++++
3 files changed, 126 insertions(+), 0 deletions(-)
diff --git a/Cumulus-no-manage-log.patch b/Cumulus-no-manage-log.patch
new file mode 100644
index 0000000..810b52d
--- /dev/null
+++ b/Cumulus-no-manage-log.patch
@@ -0,0 +1,39 @@
+Don't try to re-open log files. This avoids a failure after --daemon
+causes a chdir to /.
+
+diff --git a/CumulusService/sources/main.cpp b/CumulusService/sources/main.cpp
+index 891621f..39ea4eb 100644
+--- a/CumulusService/sources/main.cpp
++++ b/CumulusService/sources/main.cpp
+@@ -132,7 +132,6 @@ protected:
+ void dumpHandler(const char* data,int size) {
+ cout.write(data,size);
+ _logStream.write(data,size);
+- manageLogFile();
+ }
+
+ void logHandler(Thread::TID threadId,const std::string& threadName,Priority priority,const char *filePath,long line, const char *text) {
+@@ -140,23 +139,6 @@ protected:
+ _logStream << DateTimeFormatter::format(LocalDateTime(),"%d/%m %H:%M:%S.%c ")
+ << g_logPriorities[priority-1] << '\t' << threadName << '(' << threadId << ")\t"
+ << Path(filePath).getFileName() << '[' << line << "] " << text << std::endl;
+- manageLogFile();
+- }
+-
+- void manageLogFile() {
+- if(_logFile.getSize()>LOG_SIZE) {
+- _logStream.close();
+- int num = 10;
+- File file(LOG_FILE(10));
+- if(file.exists())
+- file.remove();
+- while(--num>=0) {
+- file = LOG_FILE_VAR(num);
+- if(file.exists())
+- file.renameTo(LOG_FILE_VAR(num+1));
+- }
+- _logStream.open(LOG_FILE(0),ios::in | ios::ate);
+- }
+ }
+
+ bool onConnection(Client& client) {
diff --git a/README b/README
index 4b6a2dc..ccde8b9 100644
--- a/README
+++ b/README
@@ -94,6 +94,38 @@ try deleting the files in ~/.tor or /var/lib/tor.
You will be able to see byte counts flowing in the browser window, and
eventually be able to build a circuit.
+== Building the Cumulus RTMFP server
+
+There is a free RTMFP rendezvous server called Cumulus. It is a
+replacement for the Adobe Cirrus service at rtmfp://p2p.rtmfp.net/.
+These are instructions to build and install it.
+
+First install the prerequisite libpoco, http://poco.sourceforge.net/.
+You only need the "Basic Edition."
+ # apt-get install libpoco-dev
+or
+ $ cd poco-VERSION
+ $ ./configure && make
+ # make install
+
+Follow these steps to install the Cumulus server. You need to open port
+1935/udp in the firewall.
+ $ git clone git://github.com/OpenRTMFP/Cumulus.git
+ $ cd Cumulus
+ $ patch -p0 < Cumulus-no-manage-log.patch
+ $ cd CumulusLib
+ $ make LIBS=./
+ # cp libCumulus.so /usr/local/lib
+ $ cd ../../CumulusService
+ $ make
+ # cp CumulusService /usr/local/bin
+ # useradd -d /dev/null -s /bin/false cumulus
+ # mkdir /var/cumulus
+ # chown -R cumulus.cumulus /var/cumulus
+ # cp flashproxy/cumulus /etc/init.d/cumulus
+ # chkconfig --add cumulus
+ # service cumulus start
+
== Rationale
The purpose of this project is to create many, generally ephemeral
diff --git a/cumulus b/cumulus
new file mode 100755
index 0000000..7fdac3e
--- /dev/null
+++ b/cumulus
@@ -0,0 +1,55 @@
+#!/bin/sh
+#
+# cumulus This shell script takes care of starting and stopping
+# the Cumulus server.
+#
+# chkconfig: 2345 90 10
+# description: Cumulus RTMFP server.
+# processname: CumulusService
+# pidfile: /var/cumulus/cumulus.pid
+
+# Source function library.
+. /etc/rc.d/init.d/functions
+
+BINDIR=/usr/local/bin
+VARDIR=/var/cumulus
+CUMULUS=$BINDIR/CumulusService
+PIDFILE=$VARDIR/cumulus.pid
+USER=cumulus
+
+# See how we were called.
+case "$1" in
+ start)
+ [ -x $CUMULUS ] || exit 1
+ echo -n $"Starting Cumulus server: "
+ cd $VARDIR && daemon --user cumulus --pidfile $PIDFILE $CUMULUS --daemon --pidfile=$PIDFILE
+ RETVAL=$?
+ echo
+ [ $RETVAL -eq 0 ] && touch /var/lock/subsys/cumulus
+ ;;
+ stop)
+ # Stop daemon.
+ echo -n $"Shutting down Cumulus server: "
+ killproc CumulusService
+ RETVAL=$?
+ echo
+ [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/cumulus
+ ;;
+ status)
+ status cumulus
+ RETVAL=$?
+ ;;
+ restart|reload)
+ $0 stop
+ $0 start
+ ;;
+ condrestart)
+ [ -f /var/lock/subsys/cumulus ] && restart || :
+ ;;
+ *)
+ echo $"Usage: $0 {start|stop|status|restart}"
+ RETVAL=3
+ ;;
+esac
+
+exit $RETVAL
More information about the tor-commits
mailing list