summaryrefslogtreecommitdiff
path: root/server/server.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'server/server.cpp')
-rw-r--r--server/server.cpp371
1 files changed, 0 insertions, 371 deletions
diff --git a/server/server.cpp b/server/server.cpp
deleted file mode 100644
index 56bf442..0000000
--- a/server/server.cpp
+++ /dev/null
@@ -1,371 +0,0 @@
-/*
- * File: server.cpp
- * Author: savop
- *
- * Created on 19. April 2009, 17:42
- */
-
-#include <vdr/plugin.h>
-#include <stdlib.h>
-#include <string.h>
-#include <arpa/inet.h>
-#include <upnp/upnp.h>
-#include "server.h"
-#include "util.h"
-#include "config.h"
-#include "../common.h"
-#include "upnp/dlna.h"
-#include "object.h"
-
-/****************************************************
- *
- * The UPnP Server
- *
- * Handles incoming messages, UPnP connections
- * and so on.
- *
- ****************************************************/
-
-cConnectionManager* cUPnPServer::mConnectionManager = NULL;
-cContentDirectory* cUPnPServer::mContentDirectory = NULL;
-
-cUPnPServer::cUPnPServer() {
- this->mServerAddr = new sockaddr_in;
- // Bugfix: this was necessary because there were
- // some uninitialised bytes in the structure (Please recheck this!)
- memset(this->mServerAddr,0,sizeof(sockaddr_in));
- this->mServerAddr->sin_family = AF_INET;
- this->mServerAddr->sin_port = 0;
- this->mIsRunning = false;
- this->mIsAutoDetectionEnabled = true;
- this->mIsEnabled = false;
- this->mDeviceHandle = NULL;
- this->mMediaDatabase = NULL;
-}
-
-cUPnPServer::~cUPnPServer() {
- delete this->mServerAddr; this->mServerAddr = NULL;
- delete this->mMediaDatabase;
-}
-
-bool cUPnPServer::init(void){
-
- MESSAGE(VERBOSE_SDK, "Loading configuration...");
- cUPnPConfig* config = cUPnPConfig::get();
- this->enable(config->mEnable == 1 ? true : false);
- if(!config->mAutoSetup){
- if(config->mInterface)
- if(!this->setInterface(config->mInterface)){
- ERROR("Invalid network interface: %s", config->mInterface);
- return false;
- }
- if(config->mAddress)
- if(!this->setAddress(config->mAddress)){
- ERROR("Invalid IP address: %s", config->mAddress);
- return false;
- }
- if(!this->setServerPort((short)config->mPort)){
- ERROR("Invalid port: %d", config->mPort);
- return false;
- }
- }
- else {
- if(!this->setAutoDetection(config->mAutoSetup == 1 ? true : false)){
- ERROR("Invalid auto detection setting: %d", config->mAutoSetup);
- return false;
- }
- if(!this->autoDetectSettings()){
- ERROR("Error while auto detecting settings.");
- return false;
- }
- }
-
- MESSAGE(VERBOSE_SDK, "Initializing Intel UPnP SDK on %s:%d",inet_ntoa(this->mServerAddr->sin_addr), ntohs(this->mServerAddr->sin_port));
- int ret = 0;
- ret = UpnpInit(inet_ntoa(this->mServerAddr->sin_addr), ntohs(this->mServerAddr->sin_port));
-
- if (ret != UPNP_E_SUCCESS) {
- // test if SDK was allready initiated
- if (ret == UPNP_E_INIT) {
- WARNING("SDK was allready initiated (no problem) - Errorcode: %d", ret);
- } else {
- ERROR("Error while init Intel SDK - Errorcode: %d", ret);
- return false;
- }
- }
- else {
- if(!inet_aton(UpnpGetServerIpAddress(),&this->mServerAddr->sin_addr)){
- ERROR("Unable to set IP address");
- }
- this->mServerAddr->sin_port = htons(UpnpGetServerPort());
- MESSAGE(VERBOSE_SDK, "Initializing succesfully at %s:%d", UpnpGetServerIpAddress(), UpnpGetServerPort());
- }
-
- MESSAGE(VERBOSE_CUSTOM_OUTPUT, "Setting maximum packet size for SOAP requests");
- UpnpSetMaxContentLength(UPNP_SOAP_MAX_LEN);
-
- const char* httpdir = (cUPnPConfig::get()->mHTTPFolder) ? cUPnPConfig::get()->mHTTPFolder : cPluginUpnp::getConfigDirectory();
- //set the root directory of the webserver
- cString WebserverRootDir = cString::sprintf("%s%s", httpdir, UPNP_WEB_SERVER_ROOT_DIR);
-
- MESSAGE(VERBOSE_SDK, "Set web server root dir: %s", *WebserverRootDir );
- this->mWebServer = cUPnPWebServer::getInstance(WebserverRootDir);
- MESSAGE(VERBOSE_SDK, "Initializing web server.");
- if (!this->mWebServer->init()) {
- ERROR("Error while setting web server root dir - Errorcode: %d", ret);
- return false;
- }
-
- //register media server device to SDK
- cString URLBase = cString::sprintf("http://%s:%d", UpnpGetServerIpAddress(), UpnpGetServerPort());
-
- this->mDeviceDescription = cString(cDlna::getInstance()->getDeviceDescription(URLBase),true);
-
- MESSAGE(VERBOSE_SDK, "Register Media Server Device");
- ret = UpnpRegisterRootDevice2(UPNPREG_BUF_DESC,
- this->mDeviceDescription, sizeof(this->mDeviceDescription), 1,
- &cUPnPServer::upnpActionCallback,
- &this->mDeviceHandle,
- &this->mDeviceHandle);
- if (ret != UPNP_E_SUCCESS) {
- ERROR("Error while registering device - Errorcode: %d", ret);
- return false;
- }
-
- MESSAGE(VERBOSE_CUSTOM_OUTPUT, "Unregister server to cleanup previously started servers");
- ret = UpnpUnRegisterRootDevice(this->mDeviceHandle);
- if (ret != UPNP_E_SUCCESS) {
- WARNING("Unregistering old devices failed");
- return false;
- }
-
- MESSAGE(VERBOSE_CUSTOM_OUTPUT, "Register Media Server Device");
- ret = UpnpRegisterRootDevice2(UPNPREG_BUF_DESC,
- this->mDeviceDescription, sizeof(this->mDeviceDescription), 1,
- &cUPnPServer::upnpActionCallback,
- &this->mDeviceHandle,
- &this->mDeviceHandle);
- if (ret != UPNP_E_SUCCESS) {
- ERROR("Error while registering device - Errorcode: %d", ret);
- return false;
- }
-
- MESSAGE(VERBOSE_SDK, "Initializing media database");
- this->mMediaDatabase = new cMediaDatabase;
- if(!this->mMediaDatabase->init()){
- ERROR("Error while initializing database");
- return false;
- }
-
- MESSAGE(VERBOSE_SDK, "Initializing connection manager");
- cUPnPServer::mConnectionManager = new cConnectionManager(this->mDeviceHandle);
- MESSAGE(VERBOSE_SDK, "Initializing content directory");
- cUPnPServer::mContentDirectory = new cContentDirectory(this->mDeviceHandle, this->mMediaDatabase);
- if(!cUPnPServer::mContentDirectory->Start()){
- ERROR("Unable to start content directory thread");
- return false;
- }
-
- //send first advertisments
- MESSAGE(VERBOSE_SDK, "Send first advertisements to publish start in network");
- ret = UpnpSendAdvertisement(this->mDeviceHandle, UPNP_ANNOUNCE_MAX_AGE);
- if (ret != UPNP_E_SUCCESS) {
- ERROR("Error while sending first advertisments - Errorcode: %d", ret);
- return false;
- }
-
- return true;
-}
-
-bool cUPnPServer::uninit(void) {
- MESSAGE(VERBOSE_SDK, "Shuting down content directory");
- delete cUPnPServer::mContentDirectory; cUPnPServer::mContentDirectory = NULL;
-
- MESSAGE(VERBOSE_SDK, "Shuting down connection manager");
- delete cUPnPServer::mConnectionManager; cUPnPServer::mConnectionManager = NULL;
-
- MESSAGE(VERBOSE_SDK, "Closing metadata database");
- delete this->mMediaDatabase; this->mMediaDatabase = NULL;
-
- MESSAGE(VERBOSE_SDK, "Closing the web server");
- this->mWebServer->uninit();
- delete this->mWebServer;
-
- MESSAGE(VERBOSE_SDK, "Close Intel SDK");
- // unregiser media server device from UPnP SDK
- int ret = UpnpUnRegisterRootDevice(this->mDeviceHandle);
- if (ret != UPNP_E_SUCCESS) {
- WARNING("No device registered");
- }
- // send intel sdk message to shutdown
- ret = UpnpFinish();
-
- if (ret == UPNP_E_SUCCESS) {
- MESSAGE(VERBOSE_SDK, "Close Intel SDK Successfull");
- return true;
- } else {
- ERROR("Intel SDK unintialized or already closed - Errorcode: %d", ret);
- return false;
- }
-}
-
-int cUPnPServer::upnpActionCallback(Upnp_EventType eventtype, void *event, void *cookie) {
- // only to remove warning while compiling because cookie is unused
- cookie = NULL;
- Upnp_Subscription_Request* eventRequest = NULL;
- Upnp_Action_Request* actionRequest = NULL;
-
- //check committed event variable
- if (event == NULL) {
- ERROR("UPnP Callback - NULL request");
- return UPNP_E_BAD_REQUEST;
- }
-
- switch (eventtype) {
- case UPNP_CONTROL_ACTION_REQUEST:
- actionRequest = (Upnp_Action_Request*) event;
-
- //check that request is for this device
- if (strcmp(actionRequest->DevUDN, UPNP_DEVICE_UDN) != 0) {
- ERROR("UPnP Callback - actions request not for this device");
- return UPNP_E_BAD_REQUEST;
- }
-
- //find out which service was called
- if (strcmp(actionRequest->ServiceID, UPNP_CMS_SERVICE_ID) == 0) {
- // proceed action
- return cUPnPServer::mConnectionManager->execute(actionRequest);
-
- } else if (strcmp(actionRequest->ServiceID, UPNP_CDS_SERVICE_ID) == 0) {
- // proceed action
- return cUPnPServer::mContentDirectory->execute(actionRequest);
- } else {
- ERROR("UPnP Callback - unsupported service called for control");
- return UPNP_E_BAD_REQUEST;
- }
- case UPNP_EVENT_SUBSCRIPTION_REQUEST:
- eventRequest = (Upnp_Subscription_Request*) event;
-
- //check that request is for this device
- if (strcmp(eventRequest->UDN, UPNP_DEVICE_UDN) != 0) {
- ERROR("UPnP Callback - event request not for this device");
- return UPNP_E_BAD_REQUEST;
- }
-
- if (strcmp(eventRequest->ServiceId, UPNP_CMS_SERVICE_ID) == 0) {
- // handle event request
- return cUPnPServer::mConnectionManager->subscribe(eventRequest);
-
- } else if (strcmp(eventRequest->ServiceId, UPNP_CDS_SERVICE_ID) == 0) {
- // handle event request
- return cUPnPServer::mContentDirectory->subscribe(eventRequest);
- } else {
- ERROR("UPnP Callback - unsupported service called for eventing");
- return UPNP_E_BAD_REQUEST;
- }
-
- return UPNP_E_BAD_REQUEST;
- default:
- ERROR("UPnP Action Callback - Unsupported Event");
- return UPNP_E_BAD_REQUEST;
- }
-
- return UPNP_E_BAD_REQUEST;
-}
-
-bool cUPnPServer::autoDetectSettings(void){
- int count;
- char** Ifaces = getNetworkInterfaces(&count);
- int i=0;
- bool ret = false;
- MESSAGE(VERBOSE_CUSTOM_OUTPUT, "AUTODETECT: Found %d possible interfaces.", sizeof(Ifaces));
- while(Ifaces[i]){
- if(strcmp(Ifaces[i],"lo")!=0){
- // true || false == true
- // false || false == false
- ret = this->setInterface(strdup(Ifaces[i])) || ret;
- }
- i++;
- }
- delete [] Ifaces;
- if(!ret){
- MESSAGE(VERBOSE_CUSTOM_OUTPUT, "AUTODETECT: No suitable interface. Giving up.");
- return false;
- }
- this->setServerPort(0);
- return true;
-}
-
-bool cUPnPServer::start(void){
- if(!this->isRunning()){
- // Put all the stuff which shall be started with the server in here
- // if the startup failed due any reason return false!
- MESSAGE(VERBOSE_SDK, "Starting UPnP Server on %s:%d",inet_ntoa(this->getServerAddress()->sin_addr), ntohs(this->getServerAddress()->sin_port));
- MESSAGE(VERBOSE_SDK, "Using DLNA version: %s", DLNA_PROTOCOL_VERSION_STR);
- this->mIsRunning = true;
- // Start Media database thread
- this->mMediaDatabase->Start();
- }
- return true;
-}
-
-void cUPnPServer::stop(void){
- if(this->isRunning()){
- MESSAGE(VERBOSE_SDK, "Call upnpServer STOP");
- this->uninit();
- this->mIsRunning = false;
- }
- return;
-}
-
-bool cUPnPServer::restart(void){
- MESSAGE(VERBOSE_SDK, "Call upnpServer RESTART");
- this->stop();
- return this->start();
-}
-
-void cUPnPServer::enable(bool enabled){
- this->mIsEnabled = enabled;
-}
-
-bool cUPnPServer::setInterface(const char* Interface){
- if(Interface != NULL) this->mInterface = Interface;
-
- if(*this->mInterface!=NULL){
- MESSAGE(VERBOSE_CUSTOM_OUTPUT, "Try to retrieve address for NIC %s",Interface);
- const sockaddr_in* ipAddress = getIPFromInterface(Interface);
- if(ipAddress!=NULL){
- memcpy(&this->mServerAddr->sin_addr,&ipAddress->sin_addr,sizeof(ipAddress->sin_addr));
- MESSAGE(VERBOSE_CUSTOM_OUTPUT, "NIC %s has the following IP: %s", *this->mInterface, inet_ntoa(this->mServerAddr->sin_addr));
- this->stop();
- return true;
- }
- delete ipAddress;
- ERROR("Unable to obtain a valid IP address for NIC %s!",Interface);
- }
- this->mServerAddr = NULL;
- return false;
-}
-
-bool cUPnPServer::setServerPort(unsigned short port){
- // check if the port is in user range or 0
- if(port != 0 && port < SERVER_MIN_PORT) return false;
- this->stop();
- this->mServerAddr->sin_port = htons(port);
- return true;
-}
-
-bool cUPnPServer::setAddress(const char* Address){
- if(inet_aton(Address, &this->mServerAddr->sin_addr) == 0) return false;
- this->stop();
- return true;
-}
-
-bool cUPnPServer::setAutoDetection(bool enable){
- this->mIsAutoDetectionEnabled = enable;
- return true;
-}
-
-sockaddr_in* cUPnPServer::getServerAddress() {
- return this->mServerAddr;
-} \ No newline at end of file