From c8df217a529951a4dbf6a98d9e12d3ce8ee9c1c3 Mon Sep 17 00:00:00 2001 From: Francesco Colista Date: Wed, 18 Jun 2014 14:49:38 +0000 Subject: testing/darwin-streaming-server: new aport --- testing/darwin-streaming-server/APKBUILD | 84 +++++ .../darwin-streaming-server.post-install | 4 + testing/darwin-streaming-server/dss-6.0.3.patch | 381 +++++++++++++++++++++ .../dss-hh-20080728-1.patch | 302 ++++++++++++++++ testing/darwin-streaming-server/dss.initd | 98 ++++++ 5 files changed, 869 insertions(+) create mode 100644 testing/darwin-streaming-server/APKBUILD create mode 100644 testing/darwin-streaming-server/darwin-streaming-server.post-install create mode 100644 testing/darwin-streaming-server/dss-6.0.3.patch create mode 100644 testing/darwin-streaming-server/dss-hh-20080728-1.patch create mode 100644 testing/darwin-streaming-server/dss.initd (limited to 'testing/darwin-streaming-server') diff --git a/testing/darwin-streaming-server/APKBUILD b/testing/darwin-streaming-server/APKBUILD new file mode 100644 index 0000000000..fd17e6d816 --- /dev/null +++ b/testing/darwin-streaming-server/APKBUILD @@ -0,0 +1,84 @@ +# Contributor: Francesco Colista +# Maintainer: Francesco Colista +pkgname=darwin-streaming-server +_pkgname=DarwinStreamingSrvr +pkgver=6.0.3 +pkgrel=0 +pkgdesc="Open source version of Apple's QuickTime Streaming Server technology" +url="http://dss.macosforge.org/" +arch="all" +license="Custom" +depends="perl" +depends_dev="perl" +makedepends="$depends_dev" +install="$pkgname.post-install" +subpackages="$pkgname-doc" +pkgfroups="qtss" +source="http://dss.macosforge.org/downloads/DarwinStreamingSrvr6.0.3-Source.tar + dss-hh-20080728-1.patch + dss-6.0.3.patch + dss.initd" +_builddir="$srcdir"/"$_pkgname$pkgver-Source" + +prepare() { + local i + cd "$_builddir" + for i in $source; do + case $i in + *.patch) msg $i; patch -p1 -i "$srcdir"/$i || return 1;; + esac + done +} + +build() { + cd "$_builddir" + ./Buildit || return 1 +} + +package() { + cd "$_builddir" + mkdir -p "$pkgdir"/usr/bin + mkdir -p "$pkgdir"/usr/sbin + mkdir -p "$pkgdir"/var/run/darwinstreaming + mkdir -p "$pkgdir"/var/darwinstreaming + mkdir -p -m 775 "$pkgdir/var/darwinstreaming/movies" + mkdir -p -m 770 "$pkgdir/var/darwinstreaming/playlists" + mkdir -p "$pkgdir/usr/sbin/StreamingServerModules" + install -D -m0755 "$srcdir"/dss.initd "$pkgdir/etc/init.d/dss" + install -D -m 644 APPLE_LICENSE "$pkgdir/usr/share/licenses/$pkgname/APPLE_LICENSE" + install ./StreamingLoadTool/StreamingLoadTool "$pkgdir/usr/bin/StreamingLoadTool" + install ./WebAdmin/src/streamingadminserver.pl "$pkgdir/usr/sbin/streamingadminserver.pl" + install -D -m 600 relayconfig.xml-Sample "$pkgdir/etc/darwinstreaming/relayconfig.xml-Sample" + echo "realm Streaming Server" > "$pkgdir/etc/darwinstreaming/qtusers" + chmod 600 "$pkgdir/etc/darwinstreaming/qtusers" + echo "admin: " > "$pkgdir/etc/darwinstreaming/qtgroups" + chmod 600 "$pkgdir/etc/darwinstreaming/qtgroups" + install -m 644 -D ./Documentation/readme.txt "$pkgdir/var/darwinstreaming/readme.txt" + install -m 644 ./Documentation/3rdPartyAcknowledgements.rtf "$pkgdir/var/darwinstreaming/3rdPartyAcknowledgements.rtf" + install -m 644 sample_100kbit.mov "$pkgdir/var/darwinstreaming/movies/sample_100kbit.mov" + install -m 644 sample_300kbit.mov "$pkgdir/var/darwinstreaming/movies/sample_300kbit.mov" + install -m 644 sample_100kbit.mp4 "$pkgdir/var/darwinstreaming/movies/sample_100kbit.mp4" + install -m 644 sample_300kbit.mp4 "$pkgdir/var/darwinstreaming/movies/sample_300kbit.mp4" + install -m 644 sample.mp3 "$pkgdir/var/darwinstreaming/movies/sample.mp3" + install -m 644 sample_50kbit.3gp "$pkgdir/var/darwinstreaming/movies/sample_50kbit.3gp" + install -m 644 sample_h264_100kbit.mp4 "$pkgdir/var/darwinstreaming/movies/sample_h264_100kbit.mp4" + install -m 644 sample_h264_300kbit.mp4 "$pkgdir/var/darwinstreaming/movies/sample_h264_300kbit.mp4" + install -m 644 sample_h264_1mbit.mp4 "$pkgdir/var/darwinstreaming/movies/sample_h264_1mbit.mp4" + install -m 644 StreamingLoadTool/streamingloadtool.conf "$pkgdir/etc/darwinstreaming/loadtool.conf" + cp -f -r ./WebAdmin/WebAdminHtml "$pkgdir/var/darwinstreaming" + mv "$pkgdir/var/darwinstreaming/WebAdminHtml" "$pkgdir/var/darwinstreaming/AdminHtml" + install -m 644 ./WebAdmin/streamingadminserver_Darwin.conf "$pkgdir/etc/darwinstreaming/adminserver.conf" +} + +md5sums="ca676691db8417d05121699c0ca3d549 DarwinStreamingSrvr6.0.3-Source.tar +4a55c16f291f60056f38ee687680c769 dss-hh-20080728-1.patch +ee10f86fd27ef2da68782414e30cd226 dss-6.0.3.patch +aeb9cff914e598fa1a96c9e34d9ad535 dss.initd" +sha256sums="7bf75ced3f603f55c6f7601bfecd9f26393ea98be821d24169f2091843706522 DarwinStreamingSrvr6.0.3-Source.tar +ed2c25242c862bade182c1329c84b6003c6d5ed31ef6a00fc7364d224bad137a dss-hh-20080728-1.patch +13741e14f704d3b0db00100c9213ff0bec104403622905e92f370d846bf8f2ea dss-6.0.3.patch +f1e84078fe122a9e0debb3508e959b4f8bd7655bdb0cce25b32b7a477c0d61f0 dss.initd" +sha512sums="f507c8e01ca6f81e1d00a85fb137486d026817015178593c2a5de1dde34f809bc48b1348ea661a94ee0913811d23d0c204d28c29af0c1c9d69bd31eeefd9af85 DarwinStreamingSrvr6.0.3-Source.tar +2706e75e8ffca0096f2cd53b5c0d3a8b5577766fac9bbfa9c03a894c18ea13f01117adca52e6f539233971ccc283c2751d02e8a8cd44427c07b2569e9369bfd0 dss-hh-20080728-1.patch +299e330fd39a263ffebb573b9c5c8b264b203ba9cab108d074f34234491f25d84a929c3bfee045655abdb2564ea8201c0abebbdc36d5ee70399b3684a8c23f50 dss-6.0.3.patch +16755dcd3625f21ac6ab138e1a5b5c8589b9dc46add974065786db764dbd02f734f945aeb6f05e7b3d4cc80c804d2c1c8ac21e6e41264b3b9445687bad9b418c dss.initd" diff --git a/testing/darwin-streaming-server/darwin-streaming-server.post-install b/testing/darwin-streaming-server/darwin-streaming-server.post-install new file mode 100644 index 0000000000..bfd9a90c75 --- /dev/null +++ b/testing/darwin-streaming-server/darwin-streaming-server.post-install @@ -0,0 +1,4 @@ +#!/bin/sh +addgroup -S qtss &>/dev/null +adduser -s /bin/false -G qtss -h /var/darwinstreaming -S -D qtss &>/dev/null +exit 0 diff --git a/testing/darwin-streaming-server/dss-6.0.3.patch b/testing/darwin-streaming-server/dss-6.0.3.patch new file mode 100644 index 0000000000..87dac4cc1b --- /dev/null +++ b/testing/darwin-streaming-server/dss-6.0.3.patch @@ -0,0 +1,381 @@ +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/APICommonCode/QTAccessFile.cpp DarwinStreamingSrvr6.0.3-Source/APICommonCode/QTAccessFile.cpp +--- DarwinStreamingSrvr6.0.3-Source.orig/APICommonCode/QTAccessFile.cpp 2008-05-06 01:28:57.000000000 +0200 ++++ DarwinStreamingSrvr6.0.3-Source/APICommonCode/QTAccessFile.cpp 2008-05-24 03:23:13.000000000 +0200 +@@ -46,7 +46,9 @@ + + + #include ++#ifdef __MacOSX__ + #include ++#endif + #include + #include + #include +@@ -613,6 +615,7 @@ + + bool DSAccessFile::CheckGroupMembership(const char* inUsername, const char* inGroupName) + { ++#ifdef __MacOSX__ + // In Tiger, group membership is painfully simple: we ask memberd for it! + struct passwd *user = NULL; + struct group *group = NULL; +@@ -641,6 +644,9 @@ + if ( mbr_check_membership(userID, groupID, &isMember) ) + return false; + return (bool)isMember; ++#else ++ return true; ++#endif + } + + Bool16 DSAccessFile::ValidUser( char*userName, void* extraDataPtr) +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/CommonUtilitiesLib/OSHeaders.h DarwinStreamingSrvr6.0.3-Source/CommonUtilitiesLib/OSHeaders.h +--- DarwinStreamingSrvr6.0.3-Source.orig/CommonUtilitiesLib/OSHeaders.h 2008-05-06 01:28:59.000000000 +0200 ++++ DarwinStreamingSrvr6.0.3-Source/CommonUtilitiesLib/OSHeaders.h 2008-05-24 02:05:15.000000000 +0200 +@@ -120,7 +120,6 @@ + + + #elif __linux__ || __linuxppc__ || __FreeBSD__ +- + /* Defines */ + #define _64BITARG_ "q" + #define _S64BITARG_ "lld" +@@ -128,9 +127,13 @@ + #if __LP64__ + #define _S32BITARG_ "d" + #define _U32BITARG_ "u" ++ #define _SPOINTERSIZEARG_ _S64BITARG_ ++ #define _UPOINTERSIZEARG_ _U64BITARG_ + #else +- #define _S32BITARG_ "ld" +- #define _U32BITARG_ "lu" ++ #define _S32BITARG_ "d" ++ #define _U32BITARG_ "u" ++ #define _SPOINTERSIZEARG_ _S32BITARG_ ++ #define _UPOINTERSIZEARG_ _U32BITARG_ + #endif + + /* paths */ +@@ -141,6 +144,7 @@ + + /* Includes */ + #include ++ #include + + /* Constants */ + #define QT_TIME_TO_LOCAL_TIME (-2082844800) +@@ -149,14 +153,14 @@ + /* Typedefs */ + typedef signed long PointerSizedInt; + typedef unsigned long PointerSizedUInt; +- typedef unsigned char UInt8; +- typedef signed char SInt8; +- typedef unsigned short UInt16; +- typedef signed short SInt16; +- typedef unsigned int UInt32; +- typedef signed int SInt32; +- typedef signed int int SInt64; +- typedef unsigned int int UInt64; ++ typedef uint8_t UInt8; ++ typedef int8_t SInt8; ++ typedef uint16_t UInt16; ++ typedef int16_t SInt16; ++ typedef uint32_t UInt32; ++ typedef int32_t SInt32; ++ typedef int64_t SInt64; ++ typedef uint64_t UInt64; + typedef float Float32; + typedef double Float64; + typedef UInt16 Bool16; +@@ -177,11 +181,14 @@ + + #define TW0_CHARS_TO_INT( c1, c2 ) ( c1 << 8 | c2 ) + ++ #define kSInt16_Max USHRT_MAX ++ #define kUInt16_Max USHRT_MAX + ++ #define kSInt32_Max LONG_MAX ++ #define kUInt32_Max ULONG_MAX + +- +- +- ++ #define kSInt64_Max LONG_LONG_MAX ++ #define kUInt64_Max ULONG_LONG_MAX + + #elif __Win32__ + +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/CommonUtilitiesLib/OSRef.h DarwinStreamingSrvr6.0.3-Source/CommonUtilitiesLib/OSRef.h +--- DarwinStreamingSrvr6.0.3-Source.orig/CommonUtilitiesLib/OSRef.h 2008-05-06 01:28:59.000000000 +0200 ++++ DarwinStreamingSrvr6.0.3-Source/CommonUtilitiesLib/OSRef.h 2008-05-23 22:28:51.000000000 +0200 +@@ -45,6 +45,7 @@ + #include "StrPtrLen.h" + #include "OSHashTable.h" + #include "OSCond.h" ++#include "OSHeaders.h" + + class OSRefKey; + +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/Makefile.POSIX DarwinStreamingSrvr6.0.3-Source/Makefile.POSIX +--- DarwinStreamingSrvr6.0.3-Source.orig/Makefile.POSIX 2007-11-16 06:17:59.000000000 +0100 ++++ DarwinStreamingSrvr6.0.3-Source/Makefile.POSIX 2008-05-24 07:19:34.000000000 +0200 +@@ -42,7 +42,6 @@ + CCFLAGS += -IRTPMetaInfoLib + CCFLAGS += -IPrefsSourceLib + CCFLAGS += -IServer.tproj +- + # EACH DIRECTORY WITH A STATIC LIBRARY MUST BE APPENDED IN THIS MANNER TO THE LINKOPTS + + LINKOPTS = -LCommonUtilitiesLib +@@ -52,38 +51,42 @@ + + CFILES = CommonUtilitiesLib/daemon.c + +-CPPFILES = Server.tproj/QTSSExpirationDate.cpp\ ++CPPFILES = Server.tproj/GenerateXMLPrefs.cpp \ ++ Server.tproj/main.cpp \ + Server.tproj/QTSSCallbacks.cpp \ +- Server.tproj/QTSSDictionary.cpp\ + Server.tproj/QTSSDataConverter.cpp \ ++ Server.tproj/QTSSDictionary.cpp \ + Server.tproj/QTSSErrorLogModule.cpp \ +- Server.tproj/QTSSMessages.cpp\ ++ Server.tproj/QTSServer.cpp \ ++ Server.tproj/QTSServerInterface.cpp \ ++ Server.tproj/QTSServerPrefs.cpp \ ++ Server.tproj/QTSSExpirationDate.cpp \ ++ Server.tproj/QTSSFile.cpp \ ++ Server.tproj/QTSSMessages.cpp \ + Server.tproj/QTSSModule.cpp \ +- Server.tproj/QTSServerPrefs.cpp\ +- Server.tproj/QTSSSocket.cpp\ +- Server.tproj/QTSSFile.cpp\ + Server.tproj/QTSSPrefs.cpp \ +- Server.tproj/QTSServer.cpp\ +- Server.tproj/QTSServerInterface.cpp \ +- Server.tproj/RTCPTask.cpp\ +- Server.tproj/RTPSession.cpp \ +- Server.tproj/RTPPacketResender.cpp \ ++ Server.tproj/QTSSSocket.cpp \ ++ Server.tproj/QTSSUserProfile.cpp \ ++ Server.tproj/RTCPTask.cpp \ + Server.tproj/RTPBandwidthTracker.cpp \ + Server.tproj/RTPOverbufferWindow.cpp \ +- Server.tproj/RTPSessionInterface.cpp\ ++ Server.tproj/RTPPacketResender.cpp \ ++ Server.tproj/RTPSession3GPP.cpp \ ++ Server.tproj/RTPSession.cpp \ ++ Server.tproj/RTPSessionInterface.cpp \ ++ Server.tproj/RTPStream3gpp.cpp \ + Server.tproj/RTPStream.cpp \ +- Server.tproj/RTSPProtocol.cpp\ ++ Server.tproj/RTSPProtocol.cpp \ ++ Server.tproj/RTSPRequest3GPP.cpp \ + Server.tproj/RTSPRequest.cpp \ +- Server.tproj/RTSPRequestInterface.cpp\ ++ Server.tproj/RTSPRequestInterface.cpp \ + Server.tproj/RTSPRequestStream.cpp \ +- Server.tproj/RTSPResponseStream.cpp\ ++ Server.tproj/RTSPResponseStream.cpp \ ++ Server.tproj/RTSPSession3GPP.cpp \ + Server.tproj/RTSPSession.cpp \ +- Server.tproj/RTSPSessionInterface.cpp\ +- Server.tproj/main.cpp \ ++ Server.tproj/RTSPSessionInterface.cpp \ + Server.tproj/RunServer.cpp \ +- Server.tproj/GenerateXMLPrefs.cpp \ +- Server.tproj/QTSSUserProfile.cpp\ +- PrefsSourceLib/FilePrefsSource.cpp\ ++ PrefsSourceLib/FilePrefsSource.cpp \ + PrefsSourceLib/XMLPrefsParser.cpp \ + PrefsSourceLib/XMLParser.cpp \ + OSMemoryLib/OSMemory.cpp \ +@@ -91,17 +94,20 @@ + RTSPClientLib/ClientSocket.cpp \ + HTTPUtilitiesLib/HTTPProtocol.cpp \ + HTTPUtilitiesLib/HTTPRequest.cpp \ +- RTCPUtilitiesLib/RTCPAPPPacket.cpp\ ++ RTCPUtilitiesLib/RTCPAckPacket.cpp \ ++ RTCPUtilitiesLib/RTCPAPPNADUPacket.cpp \ ++ RTCPUtilitiesLib/RTCPAPPPacket.cpp \ ++ RTCPUtilitiesLib/RTCPAPPQTSSPacket.cpp \ + RTCPUtilitiesLib/RTCPPacket.cpp \ +- RTCPUtilitiesLib/RTCPSRPacket.cpp\ +- RTCPUtilitiesLib/RTCPAckPacket.cpp\ +- RTPMetaInfoLib/RTPMetaInfoPacket.cpp\ ++ RTCPUtilitiesLib/RTCPSRPacket.cpp \ ++ RTPMetaInfoLib/RTPMetaInfoPacket.cpp \ + APIStubLib/QTSS_Private.cpp \ + APICommonCode/QTSSModuleUtils.cpp\ + APICommonCode/QTSSRollingLog.cpp \ + APICommonCode/SDPSourceInfo.cpp \ + APICommonCode/SourceInfo.cpp \ + APICommonCode/QTAccessFile.cpp \ ++ APICommonCode/QTSS3GPPModuleUtils.cpp \ + SafeStdLib/InternalStdLib.cpp \ + APIModules/QTSSAccessLogModule/QTSSAccessLogModule.cpp \ + APIModules/QTSSFileModule/QTSSFileModule.cpp \ +@@ -129,7 +135,7 @@ + APIModules/QTSSAccessModule/QTSSAccessModule.cpp \ + APIModules/QTSSHttpFileModule/QTSSHttpFileModule.cpp \ + APIModules/QTSSAccessModule/AccessChecker.cpp +- ++ + # CCFLAGS += $(foreach dir,$(HDRS),-I$(dir)) + + LIBFILES = QTFileLib/libQTFileLib.a \ +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/RTSPClientLib/PlayerSimulator.h DarwinStreamingSrvr6.0.3-Source/RTSPClientLib/PlayerSimulator.h +--- DarwinStreamingSrvr6.0.3-Source.orig/RTSPClientLib/PlayerSimulator.h 2008-05-06 01:29:00.000000000 +0200 ++++ DarwinStreamingSrvr6.0.3-Source/RTSPClientLib/PlayerSimulator.h 2008-05-24 02:08:45.000000000 +0200 +@@ -31,7 +31,7 @@ + #ifndef _PLAYERSIMULATOR_H_ + #define _PLAYERSIMULATOR_H_ + +-#include "SafeStdLib.h"" ++#include "SafeStdLib.h" + #include "OSHeaders.h" + #include "OS.h" + #include "SVector.h" +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/QTSSErrorLogModule.cpp DarwinStreamingSrvr6.0.3-Source/Server.tproj/QTSSErrorLogModule.cpp +--- DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/QTSSErrorLogModule.cpp 2008-05-06 01:28:59.000000000 +0200 ++++ DarwinStreamingSrvr6.0.3-Source/Server.tproj/QTSSErrorLogModule.cpp 2008-05-24 02:58:48.000000000 +0200 +@@ -265,7 +265,11 @@ + + sDupErrorStringCount = 0; + } +- ::strlcpy(sLastErrorString, inParamBlock->errorParams.inBuffer, sizeof(sLastErrorString)); ++#if __MacOSX__ ++ strlcpy(sLastErrorString, inParamBlock->errorParams.inBuffer, sizeof(sLastErrorString)); ++#else ++ strncpy(sLastErrorString, inParamBlock->errorParams.inBuffer, sizeof(sLastErrorString) -1); ++#endif + + } + +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/QTSServer.cpp DarwinStreamingSrvr6.0.3-Source/Server.tproj/QTSServer.cpp +--- DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/QTSServer.cpp 2008-05-06 01:28:59.000000000 +0200 ++++ DarwinStreamingSrvr6.0.3-Source/Server.tproj/QTSServer.cpp 2008-05-24 07:24:39.000000000 +0200 +@@ -70,7 +70,9 @@ + #include "QTSSAdminModule.h" + #include "QTSSAccessModule.h" + #include "QTSSMP3StreamingModule.h" ++#if __MacOSX__ + #include "QTSSDSAuthModule.h" ++#endif + #if MEMORY_DEBUGGING + #include "QTSSWebDebugModule.h" + #endif +@@ -85,7 +87,7 @@ + #include "RTCPTask.h" + #include "QTSSFile.h" + +-#include "RTPStream3GPP.h" ++#include "RTPStream3gpp.h" + #include "RTSPRequest3GPP.h" + + // CLASS DEFINITIONS +@@ -680,9 +682,11 @@ + (void)AddModule(theWebDebug); + #endif + ++#if __MacOSX__ + QTSSModule* theQTSSDSAuthModule = new QTSSModule("QTSSDSAuthModule"); + (void)theQTSSDSAuthModule->SetupModule(&sCallbacks, &QTSSDSAuthModule_Main); + (void)AddModule(theQTSSDSAuthModule); ++#endif + + QTSSModule* theQTACCESSmodule = new QTSSModule("QTSSAccessModule"); + (void)theQTACCESSmodule->SetupModule(&sCallbacks, &QTSSAccessModule_Main); +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/RTPSession.cpp DarwinStreamingSrvr6.0.3-Source/Server.tproj/RTPSession.cpp +--- DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/RTPSession.cpp 2008-05-06 01:28:59.000000000 +0200 ++++ DarwinStreamingSrvr6.0.3-Source/Server.tproj/RTPSession.cpp 2008-05-24 02:39:34.000000000 +0200 +@@ -38,7 +38,7 @@ + #include "RTSPProtocol.h" + #include "QTSServerInterface.h" + #include "QTSS.h" +-#include "RTSPRequest3gpp.h" ++#include "RTSPRequest3GPP.h" + + #include "OS.h" + #include "OSMemory.h" +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/RTPStream3gpp.cpp DarwinStreamingSrvr6.0.3-Source/Server.tproj/RTPStream3gpp.cpp +--- DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/RTPStream3gpp.cpp 2008-05-06 01:28:59.000000000 +0200 ++++ DarwinStreamingSrvr6.0.3-Source/Server.tproj/RTPStream3gpp.cpp 2008-05-24 02:48:52.000000000 +0200 +@@ -34,7 +34,7 @@ + #include "RTPStream.h" + #include "RTPStream3gpp.h" + #include "RTPSessionInterface.h" +-#include "RTSPRequest3gpp.h" ++#include "RTSPRequest3GPP.h" + #include "RTCPAPPNADUPacket.h" + + #if DEBUG +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/RTPStream.h DarwinStreamingSrvr6.0.3-Source/Server.tproj/RTPStream.h +--- DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/RTPStream.h 2008-05-06 01:28:59.000000000 +0200 ++++ DarwinStreamingSrvr6.0.3-Source/Server.tproj/RTPStream.h 2008-05-24 02:36:24.000000000 +0200 +@@ -57,7 +57,7 @@ + + #include "RTCPPacket.h" + +-#include "RTSPRequest3gpp.h" ++#include "RTSPRequest3GPP.h" + + #ifndef MIN + #define MIN(a,b) (((a)<(b))?(a):(b)) +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/RTSPRequest3GPP.cpp DarwinStreamingSrvr6.0.3-Source/Server.tproj/RTSPRequest3GPP.cpp +--- DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/RTSPRequest3GPP.cpp 2008-05-06 01:28:59.000000000 +0200 ++++ DarwinStreamingSrvr6.0.3-Source/Server.tproj/RTSPRequest3GPP.cpp 2008-05-24 02:49:26.000000000 +0200 +@@ -32,7 +32,7 @@ + */ + + +-#include "RTSPRequest3gpp.h" ++#include "RTSPRequest3GPP.h" + #include "RTSPProtocol.h" + #include "QTSServerInterface.h" + +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/StreamingLoadTool/Makefile.POSIX DarwinStreamingSrvr6.0.3-Source/StreamingLoadTool/Makefile.POSIX +--- DarwinStreamingSrvr6.0.3-Source.orig/StreamingLoadTool/Makefile.POSIX 2007-11-16 06:17:36.000000000 +0100 ++++ DarwinStreamingSrvr6.0.3-Source/StreamingLoadTool/Makefile.POSIX 2008-05-24 02:32:03.000000000 +0200 +@@ -17,6 +17,7 @@ + CCFLAGS += -I.. + CCFLAGS += -I../OSMemoryLib + CCFLAGS += -I../RTSPClientLib ++CCFLAGS += -I../RTCPUtilitiesLib + CCFLAGS += -I../APICommonCode + CCFLAGS += -I../CommonUtilitiesLib + CCFLAGS += -I../PrefsSourceLib +@@ -36,6 +37,12 @@ + ../RTSPClientLib/ClientSocket.cpp \ + ../RTSPClientLib/RTSPClient.cpp \ + ../RTSPClientLib/ClientSession.cpp \ ++ ../RTCPUtilitiesLib/RTCPAckPacket.cpp \ ++ ../RTCPUtilitiesLib/RTCPAPPNADUPacket.cpp \ ++ ../RTCPUtilitiesLib/RTCPAPPPacket.cpp \ ++ ../RTCPUtilitiesLib/RTCPAPPQTSSPacket.cpp \ ++ ../RTCPUtilitiesLib/RTCPPacket.cpp \ ++ ../RTCPUtilitiesLib/RTCPSRPacket.cpp \ + ../PrefsSourceLib/FilePrefsSource.cpp \ + ../APICommonCode/SDPSourceInfo.cpp \ + ../APICommonCode/SourceInfo.cpp \ +diff -ur --exclude='*~' DarwinStreamingSrvr6.0.3-Source.orig/StreamingLoadTool/StreamingLoadTool.cpp DarwinStreamingSrvr6.0.3-Source/StreamingLoadTool/StreamingLoadTool.cpp +--- DarwinStreamingSrvr6.0.3-Source.orig/StreamingLoadTool/StreamingLoadTool.cpp 2008-05-06 01:28:57.000000000 +0200 ++++ DarwinStreamingSrvr6.0.3-Source/StreamingLoadTool/StreamingLoadTool.cpp 2008-05-24 02:22:13.000000000 +0200 +@@ -743,7 +743,7 @@ + + bitsReceived += .5; + +- printf("%5lu %6lu %8lu %6lu %6lu %6lu %9.0fk\n", ++ printf("%5"_U32BITARG_" %6"_U32BITARG_" %8"_U32BITARG_" %6"_U32BITARG_" %6"_U32BITARG_" %6"_U32BITARG_" %9.0fk\n", + ClientSession:: GetActiveConnections (), + ClientSession:: GetPlayingConnections (), + ClientSession:: GetConnectionAttempts (), +@@ -811,7 +811,7 @@ + if (sLog != NULL) + ::fclose(sLog); + +- printf("%5lu %6lu %8lu %6lu %6lu %6lu %9.0fk\n", ++ printf("%5"_U32BITARG_" %6"_U32BITARG_" %8"_U32BITARG_" %6"_U32BITARG_" %6"_U32BITARG_" %6"_U32BITARG_" %9.0fk\n", + ClientSession:: GetActiveConnections (), + ClientSession:: GetPlayingConnections (), + ClientSession:: GetConnectionAttempts (), diff --git a/testing/darwin-streaming-server/dss-hh-20080728-1.patch b/testing/darwin-streaming-server/dss-hh-20080728-1.patch new file mode 100644 index 0000000000..d8475f686c --- /dev/null +++ b/testing/darwin-streaming-server/dss-hh-20080728-1.patch @@ -0,0 +1,302 @@ +--- DarwinStreamingSrvr6.0.3-Source.orig/Buildit 2008-03-26 08:42:48.000000000 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/Buildit 2008-07-10 18:56:05.000000000 +0800 +@@ -86,14 +86,19 @@ case $PLAT in + ;; + + Linux.i586 | \ +- Linux.i686) ++ Linux.i686 | \ ++ Linux.x86_64 ) + echo "Configuring for the "$OSNAME" "$HARDWARENAME" platform" + CPLUS=gcc + CCOMP=gcc + LINKER='gcc' + MAKE=make + +- COMPILER_FLAGS="-D_REENTRANT -D__USE_POSIX -D__linux__ -pipe" ++ if [ "$PLAT" = "Linux.x86_64" ]; then ++ COMPILER_FLAGS="-D_REENTRANT -D__USE_POSIX -D__linux__ -pipe -fPIC" ++ else ++ COMPILER_FLAGS="-D_REENTRANT -D__USE_POSIX -D__linux__ -pipe" ++ fi + INCLUDE_FLAG="-include" + + CORE_LINK_LIBS="-lpthread -ldl -lstdc++ -lm -lcrypt" +--- DarwinStreamingSrvr6.0.3-Source.orig/MP3Broadcaster/BroadcasterMain.cpp_orig 2008-07-03 20:51:14.000000000 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/MP3Broadcaster/BroadcasterMain.cpp 2008-07-03 20:51:47.000000000 +0800 +@@ -216,7 +216,7 @@ static void RegisterEventHandlers() + + struct sigaction act; + +-#if defined(sun) || defined(i386) || defined(__MacOSX__) || defined(__sgi__) || defined(__osf__) || defined(__hpux__) || defined(__linuxppc__) ++#if defined(sun) || defined(i386) || defined(__MacOSX__) || defined(__sgi__) || defined(__osf__) || defined(__hpux__) || defined(__linuxppc__) || defined(__linux__) + sigemptyset(&act.sa_mask); + act.sa_flags = 0; + act.sa_handler = (void(*)(int))&SignalEventHandler; +--- DarwinStreamingSrvr6.0.3-Source.orig/PlaylistBroadcaster.tproj/PlaylistBroadcaster.cpp_orig 2008-07-03 20:42:56.000000000 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/PlaylistBroadcaster.tproj/PlaylistBroadcaster.cpp 2008-07-03 20:43:13.000000000 +0800 +@@ -2082,7 +2082,7 @@ static void RegisterEventHandlers() + + struct sigaction act; + +-#if defined(sun) || defined(i386) || defined(__MacOSX__) || defined(__powerpc__) || defined (__sgi_cc__) || defined(__osf__) || defined(__hpux__) ++#if defined(sun) || defined(i386) || defined(__MacOSX__) || defined(__powerpc__) || defined (__sgi_cc__) || defined(__osf__) || defined(__hpux__) || defined(__linux__) + sigemptyset(&act.sa_mask); + act.sa_flags = 0; + act.sa_handler = (void(*)(int))&SignalEventHandler; +--- DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/main.cpp_orig 2008-07-03 20:38:56.000000000 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/Server.tproj/main.cpp 2008-07-03 20:39:30.000000000 +0800 +@@ -216,7 +216,7 @@ int main(int argc, char * argv[]) + //(void) ::signal(SIGPIPE, SIG_IGN); + struct sigaction act; + +-#if defined(sun) || defined(i386) || defined (__MacOSX__) || defined(__powerpc__) || defined (__osf__) || defined (__sgi_cc__) || defined (__hpux__) ++#if defined(sun) || defined(i386) || defined (__MacOSX__) || defined(__powerpc__) || defined (__osf__) || defined (__sgi_cc__) || defined (__hpux__) || defined (__linux__) + sigemptyset(&act.sa_mask); + act.sa_flags = 0; + act.sa_handler = (void(*)(int))&sigcatcher; +--- DarwinStreamingSrvr6.0.3-Source.orig/StreamingLoadTool/StreamingLoadTool.cpp_orig 2008-07-04 13:37:58.000000000 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/StreamingLoadTool/StreamingLoadTool.cpp 2008-07-04 13:38:16.000000000 +0800 +@@ -135,7 +135,7 @@ int main(int argc, char *argv[]) + #ifndef __Win32__ + struct sigaction act; + +-#if defined(sun) || defined(i386) || defined (__MacOSX__) || defined(__powerpc__) || defined (__osf__) || defined (__sgi_cc__) || defined (__hpux__) ++#if defined(sun) || defined(i386) || defined (__MacOSX__) || defined(__powerpc__) || defined (__osf__) || defined (__sgi_cc__) || defined (__hpux__) || defined (__linux__) + sigemptyset(&act.sa_mask); + act.sa_flags = 0; + act.sa_handler = (void(*)(int))&sigcatcher; +--- DarwinStreamingSrvr6.0.3-Source_orig/CommonUtilitiesLib/SocketUtils.cpp_orig 2008-07-22 13:27:28.026924464 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/CommonUtilitiesLib/SocketUtils.cpp 2008-07-22 13:33:57.944935981 +0800 +@@ -549,9 +549,6 @@ Bool16 SocketUtils::IncrementIfReqIter(c + //if the length of the addr is 0, use the family to determine + //what the addr size is + if (ifr->ifr_addr.sa_len == 0) +-#else +- *inIfReqIter += sizeof(ifr->ifr_name) + 0; +-#endif + { + switch (ifr->ifr_addr.sa_family) + { +@@ -565,6 +562,9 @@ Bool16 SocketUtils::IncrementIfReqIter(c + // return false; + } + } ++#else ++ *inIfReqIter += sizeof(*ifr); ++#endif + return true; + } + #endif +--- DarwinStreamingSrvr6.0.3-Source_orig/CommonUtilitiesLib/Task.h_orig 2008-07-25 17:12:53.000000000 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/CommonUtilitiesLib/Task.h 2008-07-25 17:14:05.000000000 +0800 +@@ -213,7 +213,7 @@ private: + static UInt32 sNumShortTaskThreads; + static UInt32 sNumBlockingTaskThreads; + +- static OSMutexRW sMutexRW; ++ static OSMutexRW sMutexRW __attribute__((visibility("hidden"))); + + friend class Task; + friend class TaskThread; +--- DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/QTSServer.cpp_orig 2008-07-24 10:00:06.000000000 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/Server.tproj/QTSServer.cpp 2008-07-24 20:59:40.000000000 +0800 +@@ -135,13 +135,13 @@ QTSServer::~QTSServer() + // + // Grab the server mutex. This is to make sure all gets & set values on this + // object complete before we start deleting stuff +- OSMutexLocker serverlocker(this->GetServerObjectMutex()); ++ OSMutexLocker* serverlocker = new OSMutexLocker(this->GetServerObjectMutex()); + + // + // Grab the prefs mutex. This is to make sure we can't reread prefs + // WHILE shutting down, which would cause some weirdness for QTSS API + // (some modules could get QTSS_RereadPrefs_Role after QTSS_Shutdown, which would be bad) +- OSMutexLocker locker(this->GetPrefs()->GetMutex()); ++ OSMutexLocker* locker = new OSMutexLocker(this->GetPrefs()->GetMutex()); + + QTSS_ModuleState theModuleState; + theModuleState.curRole = QTSS_Shutdown_Role; +@@ -152,6 +152,13 @@ QTSServer::~QTSServer() + (void)QTSServerInterface::GetModule(QTSSModule::kShutdownRole, x)->CallDispatch(QTSS_Shutdown_Role, NULL); + + OSThread::SetMainThreadData(NULL); ++ ++ delete fRTPMap; ++ delete fSocketPool; ++ delete fSrvrMessages; ++ delete locker; ++ delete serverlocker; ++ delete fSrvrPrefs; + } + + Bool16 QTSServer::Initialize(XMLPrefsParser* inPrefsSource, PrefsSource* inMessagesSource, UInt16 inPortOverride, Bool16 createListeners) +--- DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/QTSSMessages.cpp_orig 2008-07-24 14:26:35.000000000 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/Server.tproj/QTSSMessages.cpp 2008-07-24 19:28:31.000000000 +0800 +@@ -212,15 +212,17 @@ void QTSSMessages::Initialize() + } + + QTSSMessages::QTSSMessages(PrefsSource* inMessages) +-: QTSSDictionary(QTSSDictionaryMap::GetMap(QTSSDictionaryMap::kTextMessagesDictIndex)) ++: QTSSDictionary(QTSSDictionaryMap::GetMap(QTSSDictionaryMap::kTextMessagesDictIndex)), ++ numAttrs(GetDictionaryMap()->GetNumAttrs()) + { + static const UInt32 kMaxMessageSize = 2048; + char theMessage[kMaxMessageSize]; + + // Use the names of the attributes in the attribute map as the key values for + // finding preferences in the config file. +- +- for (UInt32 x = 0; x < this->GetDictionaryMap()->GetNumAttrs(); x++) ++ attrBuffer = NEW char* [numAttrs]; ++ ::memset(attrBuffer, 0, sizeof(char*) * numAttrs); ++ for (UInt32 x = 0; x < numAttrs; x++) + { + theMessage[0] = '\0'; + (void)inMessages->GetValue(this->GetDictionaryMap()->GetAttrName(x), &theMessage[0]); +@@ -248,9 +250,10 @@ QTSSMessages::QTSSMessages(PrefsSource* + // the new attribute, and copy the data into the newly allocated buffer + if (theMessage[0] != '\0') + { +- char* attrBuffer = NEW char[::strlen(theMessage) + 2]; +- ::strcpy(attrBuffer, theMessage); +- this->SetVal(this->GetDictionaryMap()->GetAttrID(x), attrBuffer, ::strlen(attrBuffer)); ++ attrBuffer[x] = NEW char[::strlen(theMessage) + 2]; ++ ::strcpy(attrBuffer[x], theMessage); ++ this->SetVal(this->GetDictionaryMap()->GetAttrID(x), ++ attrBuffer[x], ::strlen(attrBuffer[x])); + } + } + } +--- DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/QTSSDictionary.h_orig 2008-07-24 15:52:36.000000000 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/Server.tproj/QTSSDictionary.h 2008-07-24 15:52:36.000000000 +0800 +@@ -215,7 +215,8 @@ class QTSSDictionary : public QTSSStream + Bool16 fMyMutex; + Bool16 fLocked; + +- void DeleteAttributeData(DictValueElement* inDictValues, UInt32 inNumValues); ++ void DeleteAttributeData(DictValueElement* inDictValues, ++ UInt32 inNumValues, QTSSDictionaryMap* theMap); + }; + + +@@ -271,7 +272,11 @@ class QTSSDictionaryMap + // CONSTRUCTOR / DESTRUCTOR + + QTSSDictionaryMap(UInt32 inNumReservedAttrs, UInt32 inFlags = kNoFlags); +- ~QTSSDictionaryMap(){ delete fAttrArray; } ++ ~QTSSDictionaryMap() { ++ for (UInt32 i = 0; i < fAttrArraySize; i++) ++ delete fAttrArray[i]; ++ delete [] fAttrArray; ++ } + + // + // QTSS API CALLS +--- DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/QTSSMessages.h_orig 2008-07-24 14:26:35.000000000 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/Server.tproj/QTSSMessages.h 2008-07-24 20:20:45.000000000 +0800 +@@ -53,13 +53,20 @@ class QTSSMessages : public QTSSDictiona + static void Initialize(); + + QTSSMessages(PrefsSource* inMessages); +- virtual ~QTSSMessages() {} ++ virtual ~QTSSMessages() { ++ for (UInt32 x = 0; x < numAttrs; x++) ++ if (attrBuffer[x] != NULL) ++ delete [] attrBuffer[x]; ++ delete [] attrBuffer; ++ } + + + //Use the standard GetAttribute method in QTSSDictionary to retrieve messages + + private: +- ++ char** attrBuffer; ++ UInt32 numAttrs; ++ + enum + { + kNumMessages = 74 // 0 based count so it is one more than last message index number +--- DarwinStreamingSrvr6.0.3-Source.orig/Server.tproj/QTSSDictionary.cpp_orig 2008-07-23 12:27:56.000000000 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/Server.tproj/QTSSDictionary.cpp 2008-07-24 16:54:46.000000000 +0800 +@@ -60,12 +60,12 @@ QTSSDictionary::QTSSDictionary(QTSSDicti + QTSSDictionary::~QTSSDictionary() + { + if (fMap != NULL) +- this->DeleteAttributeData(fAttributes, fMap->GetNumAttrs()); ++ this->DeleteAttributeData(fAttributes, fMap->GetNumAttrs(), fMap); + if (fAttributes != NULL) + delete [] fAttributes; +- delete fInstanceMap; +- this->DeleteAttributeData(fInstanceAttrs, fInstanceArraySize); ++ this->DeleteAttributeData(fInstanceAttrs, fInstanceArraySize, fInstanceMap); + delete [] fInstanceAttrs; ++ delete fInstanceMap; + if (fMyMutex) + delete fMutexP; + } +@@ -340,7 +340,8 @@ QTSS_Error QTSSDictionary::SetValue(QTSS + theAttrs[theMapIndex].fAttributeData.Len = sizeof(char*); + // store off original string as first value in array + *(char**)theAttrs[theMapIndex].fAttributeData.Ptr = temp; +- // question: why isn't theAttrs[theMapIndex].fAllocatedInternally set to true? ++ // question: why isn't theAttrs[theMapIndex].fAllocatedInternally set to true? ++ theAttrs[theMapIndex].fAllocatedInternally = true; + } + } + else +@@ -407,7 +408,7 @@ QTSS_Error QTSSDictionary::SetValue(QTSS + // The offset should be (attrLen * inIndex) and not (inLen * inIndex) + char** valuePtr = (char**)(theAttrs[theMapIndex].fAttributeData.Ptr + (attrLen * inIndex)); + if (inIndex < numValues) // we're replacing an existing string +- delete *valuePtr; ++ delete [] *valuePtr; + *valuePtr = (char*)attributeBufferPtr; + } + +@@ -522,7 +523,7 @@ QTSS_Error QTSSDictionary::RemoveValue(Q + { + // we need to delete the string + char* str = *(char**)(theAttrs[theMapIndex].fAttributeData.Ptr + (theValueLen * inIndex)); +- delete str; ++ delete [] str; + } + + // +@@ -797,12 +798,22 @@ QTSS_Error QTSSDictionary::GetAttrInfoBy + return theErr; + } + +-void QTSSDictionary::DeleteAttributeData(DictValueElement* inDictValues, UInt32 inNumValues) ++void QTSSDictionary::DeleteAttributeData(DictValueElement* inDictValues, ++ UInt32 inNumValues, ++ QTSSDictionaryMap* theMap) + { + for (UInt32 x = 0; x < inNumValues; x++) + { +- if (inDictValues[x].fAllocatedInternally) ++ if (inDictValues[x].fAllocatedInternally) { ++ if ((theMap->GetAttrType(x) == qtssAttrDataTypeCharArray) && ++ (inDictValues[x].fNumAttributes > 1)) { ++ UInt32 z = 0; ++ for (char **y = (char **) (inDictValues[x].fAttributeData.Ptr); ++ z < inDictValues[x].fNumAttributes; z++) ++ delete [] y[z]; ++ } + delete [] inDictValues[x].fAttributeData.Ptr; ++ } + } + } + +--- DarwinStreamingSrvr6.0.3-Source.orig/CommonUtilitiesLib/OS.cpp_orig 2008-07-24 09:38:53.000000000 +0800 ++++ DarwinStreamingSrvr6.0.3-Source/CommonUtilitiesLib/OS.cpp 2008-07-24 09:39:31.000000000 +0800 +@@ -220,7 +220,7 @@ SInt32 OS::GetGMTOffset() + return ((tzInfo.Bias / 60) * -1); + #else + +- time_t clock; ++ time_t clock = 0; //Make 'clock' initialized for valgrind + struct tm *tmptr= localtime(&clock); + if (tmptr == NULL) + return 0; diff --git a/testing/darwin-streaming-server/dss.initd b/testing/darwin-streaming-server/dss.initd new file mode 100644 index 0000000000..15dd6f9ced --- /dev/null +++ b/testing/darwin-streaming-server/dss.initd @@ -0,0 +1,98 @@ +#!/sbin/runscript + +opts="statusdss statusadmin restart" + +depend() { + need net + use dns +} + +start() { + ebegin "Starting DSS (per Streaming Admin Server)" + /usr/sbin/streamingadminserver.pl + eend $? +} + +stop(){ + + PIDFILE="/var/run/darwinstreaming/adminserver.pid" + + if [ -f "$PIDFILE" ]; then + + PID=`cat "$PIDFILE"` + ps axo pid | grep $PID &>/dev/null + + if [ $? -eq 0 ]; then + ebegin "Stopping Streaming Admin Server" + kill $PID + eend $? + else + einfo "Streaming Admin Server not running." + ebegin "Dropping stale PID file" + rm "$PIDFILE" + eend $? + fi + + else + einfo "Streaming Admin Server not running obviously." + fi + + + # DSS isn't writing PID file actually + # --> use ps to check for running instance + + PID=`ps axo user,pid,cmd | grep -E '^qtss ' | grep Streaming | awk '{print $2}'` + + if [ $? -eq 0 ]; then + ebegin "Stopping DSS" + kill $PID + eend $? + else + einfo "DSS not running." + fi + +} + +statusdss() { + PIDFILE="/var/run/darwinstreaming/DarwinStreamingServer.pid" + if [ -f "$PIDFILE" ]; then + + PID=`cat "$PIDFILE"` + ps axo pid | grep PID &>/dev/null + + if [ $? -eq 0 ]; then + einfo "DSS is running" + return 0 + else + ewarning "found stale PID file" + fi + fi + + einfo "DSS is not running" + return 1 +} + +statusadmin() { + PIDFILE="/var/run/darwinstreaming/adminserver.pid" + if [ -f "$PIDFILE" ]; then + + PID=`cat "$PIDFILE"` + ps axo pid | grep PID &>/dev/null + + if [ $? -eq 0 ]; then + einfo "Streaming Admin Server is running" + return 0 + else + ewarning "found stale PID file" + fi + fi + + einfo "Streaming Admin Server is not running" + return 1 +} + +restart() { + stop + start +} + -- cgit v1.2.3