#include "pagecontroller.h"

#include "../static.h"

#include "comic.h"
#include "comiccontroller.h"
#include "yacreader_http_session.h"

#include <QDataStream>
#include <QPointer>

#include <QsLog.h>

#include "db_helper.h"

PageController::PageController() {}

void PageController::service(HttpRequest &request, HttpResponse &response)
{
    HttpSession session = Static::sessionStore->getSession(request, response, false);
    YACReaderHttpSession *ySession = Static::yacreaderSessionStore->getYACReaderSessionHttpSession(session.getId());

    QString path = QUrl::fromPercentEncoding(request.getPath()).toUtf8();
    bool remote = path.endsWith("remote");

    //QByteArray path2=request.getPath();
    //qDebug("PageController: request to -> %s ",path2.data());

    QStringList pathElements = path.split('/');
    QString libraryName = DBHelper::getLibraryName(pathElements.at(2).toInt());
    qulonglong comicId = pathElements.at(4).toULongLong();
    unsigned int page = pathElements.at(6).toUInt();

    //qDebug("lib name : %s",pathElements.at(2).data());

    Comic *comicFile;
    qulonglong currentComicId;
    if (remote) {
        QLOG_TRACE() << "se recupera comic remoto para servir páginas";
        comicFile = ySession->getCurrentRemoteComic();
        currentComicId = ySession->getCurrentRemoteComicId();
    } else {
        QLOG_TRACE() << "se recupera comic para servir páginas";
        comicFile = ySession->getCurrentComic();
        currentComicId = ySession->getCurrentComicId();
    }

    if (currentComicId != 0 && !QPointer<Comic>(comicFile).isNull()) {
        if (comicId == currentComicId && page < comicFile->numPages()) {
            if (comicFile->pageIsLoaded(page)) {
                //qDebug("PageController: La página estaba cargada -> %s ",path.data());
                response.setHeader("Content-Type", "image/jpeg");
                response.setHeader("Transfer-Encoding", "chunked");
                QByteArray pageData = comicFile->getRawPage(page);
                QDataStream data(pageData);
                char buffer[4096];
                while (!data.atEnd()) {
                    int len = data.readRawData(buffer, 4096);
                    response.write(QByteArray(buffer, len));
                }
                //response.write(pageData,true);
                response.write(QByteArray(), true);
            } else {
                //qDebug("PageController: La página NO estaba cargada 404 -> %s ",path.data());
                response.setStatus(404, "not found"); //TODO qué mensaje enviar
                response.write("404 not found", true);
            }
        } else {
            if (comicId != currentComicId) {
                //delete comicFile;
                if (remote)
                    ySession->dismissCurrentRemoteComic();
                else
                    ySession->dismissCurrentComic();
            }
            response.setStatus(404, "not found"); //TODO qué mensaje enviar
            response.write("404 not found", true);
        }
    } else {
        response.setStatus(404, "not found");
        response.write("404 not found", true);
    }

    //response.write(t.toLatin1(),true);
}