X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;f=src%2Fsituareservice%2Fsituareservice.cpp;h=87847c4adf9fdc434415ed1c886d1ad72f0f7371;hb=58e9620f35a4317bae95cb4e363b1442bdc4c5e2;hp=12b56ebaa9deaf832cdaae883a6a845139d10b2a;hpb=533f6b3aac8291f23a5032f181541780a1d724db;p=situare diff --git a/src/situareservice/situareservice.cpp b/src/situareservice/situareservice.cpp index 12b56eb..87847c4 100644 --- a/src/situareservice/situareservice.cpp +++ b/src/situareservice/situareservice.cpp @@ -19,13 +19,13 @@ USA. */ -#include "parser.h" +#include -#include #include #include #include #include +#include #include #include "error.h" @@ -67,46 +67,96 @@ SituareService::~SituareService() m_friendsList.clear(); } -void SituareService::fetchLocations() +void SituareService::addProfileImages(const QList &imageUrlList) { qDebug() << __PRETTY_FUNCTION__; - QString cookie = formCookie(API_KEY, m_credentials.expires(), m_credentials.userID(), - m_credentials.sessionKey(), m_credentials.sessionSecret(), - m_credentials.sig(), EN_LOCALE); + foreach(QUrl url, imageUrlList) { + emit fetchImage(url); + } +} + +void SituareService::appendAccessToken(QString &requestUrl) +{ + qWarning() << __PRETTY_FUNCTION__; + +// requestUrl.append("access_token="); + requestUrl.append(m_session); - QUrl url = formUrl(SITUARE_URL, GET_LOCATIONS); - sendRequest(url, COOKIE, cookie); +// qWarning() << __PRETTY_FUNCTION__ << "request url with parameters and access token:" << requestUrl; } -void SituareService::reverseGeo(const GeoCoordinate &coordinates) +void SituareService::buildRequest(const QString &script, const QHash ¶meters) { - qDebug() << __PRETTY_FUNCTION__; + qWarning() << __PRETTY_FUNCTION__; + + const QString PARAMETER_KEY_API = "api"; + const QString PARAMETER_VALUE_API = "2.0"; + + QString url = SITUARE_URL; + url.append(script); + url.append("?"); + + // append default api version parameter if not yet specified + if (!parameters.contains(PARAMETER_KEY_API)) + url.append(PARAMETER_KEY_API + "=" + PARAMETER_VALUE_API + "&"); + + // append parameters + if (!parameters.isEmpty()) { + QHash::const_iterator i = parameters.constBegin(); + while (i != parameters.constEnd()) { + url.append(i.key()); + url.append("="); + url.append(i.value()); + url.append("&"); + i++; + } + } + +// qWarning() << __PRETTY_FUNCTION__ << "request url with parameters:" << url; - QString cookie = formCookie(API_KEY, m_credentials.expires(),m_credentials.userID(), - m_credentials.sessionKey(), m_credentials.sessionSecret(), - m_credentials.sig(), EN_LOCALE); + if (!m_session.isEmpty()) { + appendAccessToken(url); + sendRequest(url); + } else { + m_requestsWaitingAccessToken.append(url); + ///< @todo emit login request + } +} + +void SituareService::clearUserData() +{ + qDebug() << __PRETTY_FUNCTION__; - QString urlParameters = formUrlParameters(coordinates); - urlParameters.append(JSON_FORMAT); - QUrl url = formUrl(SITUARE_URL, REVERSE_GEO, urlParameters); + qDeleteAll(m_friendsList.begin(), m_friendsList.end()); + m_friendsList.clear(); - sendRequest(url, COOKIE, cookie); + if(m_user) { + delete m_user; + m_user = 0; + } + emit userDataChanged(m_user, m_friendsList); } -void SituareService::updateLocation(const GeoCoordinate &coordinates, const QString &status, - const bool &publish) +QString SituareService::degreesToString(double degrees) { qDebug() << __PRETTY_FUNCTION__; - QString urlParameters = formUrlParameters(coordinates, status, publish); - QUrl url = formUrl(SITUARE_URL, UPDATE_LOCATION, urlParameters); + // one scene pixel is about 5.4e-6 degrees, the integer part is max three digits and one + // additional digit is added for maximum precision + const int PRECISION = 10; + + return QString::number(degrees, 'f', PRECISION); +} - QString cookie = formCookie(API_KEY, m_credentials.expires(), m_credentials.userID(), - m_credentials.sessionKey(), m_credentials.sessionSecret(), - m_credentials.sig(), EN_LOCALE); +void SituareService::fetchLocations() +{ + qDebug() << __PRETTY_FUNCTION__; - sendRequest(url, COOKIE, cookie); + QHash parameters; + parameters.insert("extra_user_data", NORMAL_SIZE_PROFILE_IMAGE); + + buildRequest(GET_LOCATIONS, parameters); } QString SituareService::formCookie(const QString &apiKeyValue, QString expiresValue, @@ -222,76 +272,44 @@ QString SituareService::formUrlParameters(const GeoCoordinate &coordinates, QStr return parameters; } -void SituareService::sendRequest(const QUrl &url, const QString &cookieType, const QString &cookie) -{ - qDebug() << __PRETTY_FUNCTION__; - - QNetworkRequest request; - - request.setUrl(url); - request.setAttribute(QNetworkRequest::CacheSaveControlAttribute, false); - request.setRawHeader(cookieType.toAscii(), cookie.toUtf8()); - - QNetworkReply *reply = m_networkManager->get(request, true); - - m_currentRequests.append(reply); -} - -void SituareService::requestFinished(QNetworkReply *reply) +void SituareService::imageReceived(const QUrl &url, const QPixmap &image) { qDebug() << __PRETTY_FUNCTION__; + qDebug() << "Image URL: " << url << " size :" << image.size(); - //Reply from situare - if (m_currentRequests.contains(reply)) { - - qDebug() << "BytesAvailable: " << reply->bytesAvailable(); - - if (reply->error()) { - emit error(ErrorContext::NETWORK, reply->error()); - } else { - QByteArray replyArray = reply->readAll(); - qDebug() << "Reply from: " << reply->url() << "reply " << replyArray; - - if(replyArray == ERROR_LAT.toAscii()) { - qDebug() << "Error: " << ERROR_LAT; - emit error(ErrorContext::SITUARE, SituareError::UPDATE_FAILED); - } else if(replyArray == ERROR_LON.toAscii()) { - qDebug() << "Error: " << ERROR_LON; - emit error(ErrorContext::SITUARE, SituareError::UPDATE_FAILED); - } else if(replyArray.contains(ERROR_SESSION.toAscii())) { - qDebug() << "Error: " << ERROR_SESSION; - emit error(ErrorContext::SITUARE, SituareError::SESSION_EXPIRED); - } else if(replyArray.startsWith(OPENING_BRACE_MARK.toAscii())) { - qDebug() << "JSON string"; - parseUserData(replyArray); - } else if(replyArray.isEmpty()) { - if(reply->url().toString().contains(UPDATE_LOCATION.toAscii())) { - emit updateWasSuccessful(); - } else { - // session credentials are invalid - emit error(ErrorContext::SITUARE, SituareError::SESSION_EXPIRED); - } - } else { - // unknown reply - emit error(ErrorContext::SITUARE, SituareError::ERROR_GENERAL); + // assign facebook silhouette image to all who doesn't have a profile image + if(url == QUrl(SILHOUETTE_URL)) { + if(m_user->profileImageUrl().isEmpty()) { + m_user->setProfileImage(AvatarImage::create(image, AvatarImage::Large)); + emit imageReady(m_user); + } + foreach(User *friendItem, m_friendsList) { + if(friendItem->profileImageUrl().isEmpty()) { + friendItem->setProfileImage(AvatarImage::create(image, AvatarImage::Small)); + emit imageReady(friendItem); } } - m_currentRequests.removeAll(reply); - reply->deleteLater(); } -} -void SituareService::credentialsReady(const FacebookCredentials &credentials) -{ - qDebug() << __PRETTY_FUNCTION__; + if (m_user->profileImageUrl() == url) { + m_user->setProfileImage(AvatarImage::create(image, AvatarImage::Large)); + emit imageReady(m_user); + } - m_credentials = credentials; + foreach(User *friendItem, m_friendsList) { + if(friendItem->profileImageUrl() == url) { + friendItem->setProfileImage(AvatarImage::create(image, AvatarImage::Small)); + emit imageReady(friendItem); + } + } } void SituareService::parseUserData(const QByteArray &jsonReply) { qDebug() << __PRETTY_FUNCTION__; + qWarning() << __PRETTY_FUNCTION__ << "Server reply:" << jsonReply; + m_defaultImage = false; QJson::Parser parser; @@ -448,57 +466,113 @@ void SituareService::parseUserData(const QByteArray &jsonReply) } } -void SituareService::imageReceived(const QUrl &url, const QPixmap &image) +void SituareService::requestFinished(QNetworkReply *reply) { qDebug() << __PRETTY_FUNCTION__; - qDebug() << "Image URL: " << url << " size :" << image.size(); - // assign facebook silhouette image to all who doesn't have a profile image - if(url == QUrl(SILHOUETTE_URL)) { - if(m_user->profileImageUrl().isEmpty()) { - m_user->setProfileImage(AvatarImage::create(image, AvatarImage::Large)); - emit imageReady(m_user); - } - foreach(User *friendItem, m_friendsList) { - if(friendItem->profileImageUrl().isEmpty()) { - friendItem->setProfileImage(AvatarImage::create(image, AvatarImage::Small)); - emit imageReady(friendItem); + //Reply from situare + if (m_currentRequests.contains(reply)) { + + qDebug() << "BytesAvailable: " << reply->bytesAvailable(); + + if (reply->error()) { + emit error(ErrorContext::NETWORK, reply->error()); + } else { + QByteArray replyArray = reply->readAll(); + qDebug() << "Reply from: " << reply->url() << "reply " << replyArray; + + if(replyArray == ERROR_LAT.toAscii()) { + qDebug() << "Error: " << ERROR_LAT; + emit error(ErrorContext::SITUARE, SituareError::UPDATE_FAILED); + } else if(replyArray == ERROR_LON.toAscii()) { + qDebug() << "Error: " << ERROR_LON; + emit error(ErrorContext::SITUARE, SituareError::UPDATE_FAILED); + } else if(replyArray.contains(ERROR_SESSION.toAscii())) { + qDebug() << "Error: " << ERROR_SESSION; + emit error(ErrorContext::SITUARE, SituareError::SESSION_EXPIRED); + } else if(replyArray.startsWith(OPENING_BRACE_MARK.toAscii())) { + qDebug() << "JSON string"; + parseUserData(replyArray); + } else if(replyArray.isEmpty()) { + if(reply->url().toString().contains(UPDATE_LOCATION.toAscii())) { + emit updateWasSuccessful(); + } else { + // session credentials are invalid + emit error(ErrorContext::SITUARE, SituareError::SESSION_EXPIRED); + } + } else { + // unknown reply + emit error(ErrorContext::SITUARE, SituareError::ERROR_GENERAL); } } + m_currentRequests.removeAll(reply); + reply->deleteLater(); } +} - if (m_user->profileImageUrl() == url) { - m_user->setProfileImage(AvatarImage::create(image, AvatarImage::Large)); - emit imageReady(m_user); - } +void SituareService::reverseGeo(const GeoCoordinate &coordinates) +{ + qDebug() << __PRETTY_FUNCTION__; - foreach(User *friendItem, m_friendsList) { - if(friendItem->profileImageUrl() == url) { - friendItem->setProfileImage(AvatarImage::create(image, AvatarImage::Small)); - emit imageReady(friendItem); - } - } + QHash parameters; + parameters.insert("lat", degreesToString(coordinates.latitude())); + parameters.insert("lon", degreesToString(coordinates.longitude())); + parameters.insert("format", "json"); + + buildRequest(REVERSE_GEO, parameters); } -void SituareService::addProfileImages(const QList &imageUrlList) +void SituareService::sendRequest(const QUrl &url, const QString &cookieType, const QString &cookie) { qDebug() << __PRETTY_FUNCTION__; - foreach(QUrl url, imageUrlList) { - emit fetchImage(url); + QNetworkRequest request; + + request.setUrl(url); + request.setAttribute(QNetworkRequest::CacheSaveControlAttribute, false); + request.setRawHeader(cookieType.toAscii(), cookie.toUtf8()); + + QNetworkReply *reply = m_networkManager->get(request, true); + + m_currentRequests.append(reply); +} + +void SituareService::sendRequest(const QString &requestUrl) +{ + qWarning() << __PRETTY_FUNCTION__ << "requestUrl" << requestUrl; + + // make and send the request + QNetworkRequest request; + request.setUrl(QUrl(requestUrl)); + request.setAttribute(QNetworkRequest::CacheSaveControlAttribute, false); + QNetworkReply *reply = m_networkManager->get(request, true); + m_currentRequests.append(reply); +} + +void SituareService::updateSession(const QString &session) +{ + qWarning() << __PRETTY_FUNCTION__; + + m_session = session; + + foreach (QString request, m_requestsWaitingAccessToken) { + appendAccessToken(request); + sendRequest(request); } + + m_requestsWaitingAccessToken.clear(); } -void SituareService::clearUserData() +void SituareService::updateLocation(const GeoCoordinate &coordinates, const QString &status, + const bool &publish) { qDebug() << __PRETTY_FUNCTION__; - qDeleteAll(m_friendsList.begin(), m_friendsList.end()); - m_friendsList.clear(); + QHash parameters; + parameters.insert("lat", degreesToString(coordinates.latitude())); + parameters.insert("lon", degreesToString(coordinates.longitude())); + parameters.insert("publish", publish ? "true" : "false"); + parameters.insert("data", status); ///< @todo if !empty ??? - if(m_user) { - delete m_user; - m_user = 0; - } - emit userDataChanged(m_user, m_friendsList); + buildRequest(UPDATE_LOCATION, parameters); }