mirror of https://github.com/nymea/nymea.git
183 lines
6.2 KiB
C++
183 lines
6.2 KiB
C++
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
* *
|
|
* Copyright (C) 2016 Simon Stürz <simon.stuerz@guh.io> *
|
|
* *
|
|
* This file is part of nymea. *
|
|
* *
|
|
* This library is free software; you can redistribute it and/or *
|
|
* modify it under the terms of the GNU Lesser General Public *
|
|
* License as published by the Free Software Foundation; either *
|
|
* version 2.1 of the License, or (at your option) any later version. *
|
|
* *
|
|
* This library is distributed in the hope that it will be useful, *
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
|
|
* Lesser General Public License for more details. *
|
|
* *
|
|
* You should have received a copy of the GNU Lesser General Public *
|
|
* License along with this library; If not, see *
|
|
* <http://www.gnu.org/licenses/>. *
|
|
* *
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
/*!
|
|
\class AvahiServiceEntry
|
|
\brief Holds information about an avahi service entry.
|
|
|
|
\ingroup types
|
|
\inmodule libnymea
|
|
|
|
You can find an example \l{QtAvahiServiceBrowser}{here}.
|
|
|
|
*/
|
|
|
|
#include "avahiserviceentry.h"
|
|
|
|
/*! Constructs an empty invalid \l{AvahiServiceEntry}*/
|
|
AvahiServiceEntry::AvahiServiceEntry() :
|
|
m_port(0),
|
|
m_protocol(QAbstractSocket::UnknownNetworkLayerProtocol)
|
|
{
|
|
|
|
}
|
|
|
|
|
|
/*! Constructs a new \l{AvahiServiceEntry} with the given \a name, \a serviceType, \a hostAddress, \a domain, \a hostName, \a port, \a protocol, \a txt and \a flags.*/
|
|
AvahiServiceEntry::AvahiServiceEntry(QString name, QString serviceType, QHostAddress hostAddress, QString domain, QString hostName, quint16 port, QAbstractSocket::NetworkLayerProtocol protocol, QStringList txt, AvahiLookupResultFlags flags) :
|
|
m_name(name),
|
|
m_serviceType(serviceType),
|
|
m_hostAddress(hostAddress),
|
|
m_domain(domain),
|
|
m_hostName(hostName),
|
|
m_port(port),
|
|
m_protocol(protocol),
|
|
m_txt(txt),
|
|
m_flags(flags)
|
|
{
|
|
|
|
}
|
|
|
|
/*! Returns the name of this \l{AvahiServiceEntry}.*/
|
|
QString AvahiServiceEntry::name() const
|
|
{
|
|
return m_name;
|
|
}
|
|
|
|
/*! Returns the service type of this \l{AvahiServiceEntry}.*/
|
|
QString AvahiServiceEntry::serviceType() const
|
|
{
|
|
return m_serviceType;
|
|
}
|
|
|
|
/*! Returns the host address of this \l{AvahiServiceEntry}.*/
|
|
QHostAddress AvahiServiceEntry::hostAddress() const
|
|
{
|
|
return m_hostAddress;
|
|
}
|
|
|
|
/*! Returns the domain of this \l{AvahiServiceEntry}.*/
|
|
QString AvahiServiceEntry::domain() const
|
|
{
|
|
return m_domain;
|
|
}
|
|
|
|
/*! Returns the host name of this \l{AvahiServiceEntry}.*/
|
|
QString AvahiServiceEntry::hostName() const
|
|
{
|
|
return m_hostName;
|
|
}
|
|
|
|
/*! Returns the port of this \l{AvahiServiceEntry}.*/
|
|
quint16 AvahiServiceEntry::port() const
|
|
{
|
|
return m_port;
|
|
}
|
|
|
|
/*! Returns the network protocol of this \l{AvahiServiceEntry}.*/
|
|
QAbstractSocket::NetworkLayerProtocol AvahiServiceEntry::protocol() const
|
|
{
|
|
return m_protocol;
|
|
}
|
|
|
|
/*! Returns the avahi flags of this \l{AvahiServiceEntry}.*/
|
|
AvahiLookupResultFlags AvahiServiceEntry::flags() const
|
|
{
|
|
return m_flags;
|
|
}
|
|
|
|
/*! Returns the txt string list of this \l{AvahiServiceEntry}.*/
|
|
QStringList AvahiServiceEntry::txt() const
|
|
{
|
|
return m_txt;
|
|
}
|
|
|
|
/*! Returns true if this \l{AvahiServiceEntry} is valid.*/
|
|
bool AvahiServiceEntry::isValid() const
|
|
{
|
|
return !m_hostAddress.isNull() && !m_hostName.isEmpty() && m_port != 0 && m_protocol != QAbstractSocket::UnknownNetworkLayerProtocol;
|
|
}
|
|
|
|
/*! Returns true if this \l{AvahiServiceEntry} is cached.*/
|
|
bool AvahiServiceEntry::isChached() const
|
|
{
|
|
return m_flags & AVAHI_LOOKUP_RESULT_CACHED;
|
|
}
|
|
|
|
/*! Returns true if this \l{AvahiServiceEntry} was found in the wide area.*/
|
|
bool AvahiServiceEntry::isWideArea() const
|
|
{
|
|
return m_flags & AVAHI_LOOKUP_RESULT_WIDE_AREA;
|
|
}
|
|
|
|
/*! Returns true if this \l{AvahiServiceEntry} is a multicast service.*/
|
|
bool AvahiServiceEntry::isMulticast() const
|
|
{
|
|
return m_flags & AVAHI_LOOKUP_RESULT_MULTICAST;
|
|
}
|
|
|
|
/*! Returns true if this \l{AvahiServiceEntry} was found local.*/
|
|
bool AvahiServiceEntry::isLocal() const
|
|
{
|
|
return m_flags & AVAHI_LOOKUP_RESULT_LOCAL;
|
|
}
|
|
|
|
/*! Returns true if this \l{AvahiServiceEntry} is our own service.*/
|
|
bool AvahiServiceEntry::isOurOwn() const
|
|
{
|
|
return m_flags & AVAHI_LOOKUP_RESULT_OUR_OWN;
|
|
}
|
|
|
|
/*! Returns true if this \l{AvahiServiceEntry} is equal to \a other; otherwise returns false.*/
|
|
bool AvahiServiceEntry::operator ==(const AvahiServiceEntry &other) const
|
|
{
|
|
return other.name() == m_name &&
|
|
other.serviceType() == m_serviceType &&
|
|
other.hostAddress() == m_hostAddress &&
|
|
other.domain() == m_domain &&
|
|
other.hostName() == m_hostName &&
|
|
other.port() == m_port &&
|
|
other.protocol() == m_protocol &&
|
|
other.flags() == m_flags &&
|
|
other.txt() == m_txt;
|
|
}
|
|
|
|
/*! Returns true if this \l{AvahiServiceEntry} is not equal to \a other; otherwise returns false.*/
|
|
bool AvahiServiceEntry::operator !=(const AvahiServiceEntry &other) const
|
|
{
|
|
return !operator==(other);
|
|
}
|
|
|
|
/*! Writes the given \a entry to the specified \a dbg.*/
|
|
QDebug operator <<(QDebug dbg, const AvahiServiceEntry &entry)
|
|
{
|
|
dbg.nospace() << "AvahiServiceEntry(";
|
|
dbg << entry.name() << ")" << endl;
|
|
dbg << " location: " << entry.hostAddress().toString() << ":" << entry.port() << endl;
|
|
dbg << " hostname: " << entry.hostName() << endl;
|
|
dbg << " domain: " << entry.domain() << endl;
|
|
dbg << "service type: " << entry.serviceType() << endl;
|
|
dbg << " protocol: " << entry.protocol() << endl;
|
|
dbg << " txt: " << entry.txt() << endl;
|
|
return dbg;
|
|
}
|