controlador de p?ginas

corregido bug relacionado con los datos de sesi?n (delete comic)
This commit is contained in:
Luis Ángel San Martín 2012-09-09 14:30:17 +02:00
parent b0cfaaf13c
commit a39cc616f6
9 changed files with 83 additions and 10 deletions

View File

@ -45,6 +45,7 @@
bool loaded(); bool loaded();
QPixmap * operator[](unsigned int index); QPixmap * operator[](unsigned int index);
QVector<QByteArray> * getRawData(){return &_pages;}; QVector<QByteArray> * getRawData(){return &_pages;};
QByteArray getRawPage(int page){return _pages[page];};
public slots: public slots:
void loadImages(); void loadImages();
void loadSizes(); void loadSizes();

View File

@ -18,12 +18,14 @@ int main( int argc, char ** argv )
app.installTranslator(&translator); app.installTranslator(&translator);
app.setApplicationName("YACReaderLibrary"); app.setApplicationName("YACReaderLibrary");
s = new Startup();
s->start();
mw = new LibraryWindow(); mw = new LibraryWindow();
mw->resize(800,480); mw->resize(800,480);
mw->showMaximized(); mw->showMaximized();
s = new Startup();
s->start();
return app.exec(); return app.exec();
} }

View File

@ -41,7 +41,7 @@ void ComicController::service(HttpRequest& request, HttpResponse& response)
} }
else else
{ {
delete comicFile; //delete comicFile;
response.setStatus(404,"not found"); response.setStatus(404,"not found");
response.write("404 not found",true); response.write("404 not found",true);
} }

View File

@ -0,0 +1,39 @@
#include "pagecontroller.h"
#include "../static.h"
#include "comic.h"
PageController::PageController() {}
void PageController::service(HttpRequest& request, HttpResponse& response)
{
HttpSession session=Static::sessionStore->getSession(request,response);
QStringList pathElements = ((QString)request.getPath()).split('/');
QString libraryName = pathElements.at(2);
qulonglong comicId = pathElements.at(4).toULongLong();
quint16 page = pathElements.at(6).toUInt();
Comic * comicFile = session.getCurrentComic();
if((comicFile != 0) && comicId == session.getCurrentComicId())
{
response.setHeader("Content-Type", "image/page");
QByteArray pageData = comicFile->getRawPage(page);
response.write(pageData);
}
else
{
delete comicFile;
response.setStatus(404,"not found");
response.write("404 not found",true);
}
//response.write(t.toLatin1(),true);
}

View File

@ -0,0 +1,20 @@
#ifndef PAGECONTROLLER_H
#define PAGECONTROLLER_H
#include "httprequest.h"
#include "httpresponse.h"
#include "httprequesthandler.h"
class PageController : public HttpRequestHandler {
Q_OBJECT
Q_DISABLE_COPY(PageController);
public:
/** Constructor */
PageController();
/** Generates the response */
void service(HttpRequest& request, HttpResponse& response);
};
#endif // PAGECONTROLLER_H

View File

@ -12,6 +12,7 @@
HttpSession::HttpSession(bool canStore) { HttpSession::HttpSession(bool canStore) {
if (canStore) { if (canStore) {
dataPtr=new HttpSessionData(); dataPtr=new HttpSessionData();
dataPtr->yacreaderSessionData.comic = 0;
dataPtr->refCount=1; dataPtr->refCount=1;
dataPtr->lastAccess=QDateTime::currentMSecsSinceEpoch(); dataPtr->lastAccess=QDateTime::currentMSecsSinceEpoch();
dataPtr->id=QUuid::createUuid().toString().toAscii(); dataPtr->id=QUuid::createUuid().toString().toAscii();

View File

@ -17,6 +17,7 @@
#include "controllers/covercontroller.h" #include "controllers/covercontroller.h"
#include "controllers/comiccontroller.h" #include "controllers/comiccontroller.h"
#include "controllers/folderinfocontroller.h" #include "controllers/folderinfocontroller.h"
#include "controllers/pagecontroller.h"
RequestMapper::RequestMapper(QObject* parent) RequestMapper::RequestMapper(QObject* parent)
:HttpRequestHandler(parent) {} :HttpRequestHandler(parent) {}
@ -50,7 +51,7 @@ void RequestMapper::service(HttpRequest& request, HttpResponse& response) {
} }
else if(path.contains("page")) else if(path.contains("page"))
{ {
PageController().service(request,response);
} }
else else
{ {

View File

@ -53,7 +53,8 @@ QString Static::getConfigDir() {
foreach (QString dir, searchList) { foreach (QString dir, searchList) {
qWarning("%s/%s not found",qPrintable(dir),qPrintable(configFileName)); qWarning("%s/%s not found",qPrintable(dir),qPrintable(configFileName));
} }
qFatal("Cannot find config file %s",qPrintable(configFileName)); qWarning("Cannot find config file %s",qPrintable(configFileName)); //TODO establecer los valores por defecto
return 0; return 0;
} }

View File

@ -21,8 +21,8 @@ ServerConfigDialog::ServerConfigDialog(QWidget * parent)
mainLayout->addWidget(accept,0,0); mainLayout->addWidget(accept,0,0);
mainLayout->addWidget(qrCode,0,1); mainLayout->addWidget(qrCode,0,1);
this->setLayout(mainLayout); this->setLayout(mainLayout);
generateQR();
} }
void ServerConfigDialog::generateQR() void ServerConfigDialog::generateQR()
@ -42,11 +42,19 @@ void ServerConfigDialog::generateQR()
QList<QHostAddress> list = QHostInfo::fromName( QHostInfo::localHostName() ).addresses(); QList<QHostAddress> list = QHostInfo::fromName( QHostInfo::localHostName() ).addresses();
foreach(QHostAddress add, list) foreach(QHostAddress add, list)
{ {
dir = add.toString(); QString tmp = add.toString();
if(dir.contains(".")) if(tmp.contains(".") && tmp != "127.0.0.1")
{
dir = tmp;
break; break;
}
}
if(!dir.isEmpty())
generateQR(dir+":"+s->getPort());
else
{
} }
generateQR(dir+":"+s->getPort());
//qrCode->setText(dir+":8080"); //qrCode->setText(dir+":8080");
} }
@ -58,7 +66,7 @@ void ServerConfigDialog::generateQR(const QString & serverAddress)
attributes << "-o" << QCoreApplication::applicationDirPath()+"/utils/tmp.png" << "-s" << "8" << "-l" << "H" << serverAddress; attributes << "-o" << QCoreApplication::applicationDirPath()+"/utils/tmp.png" << "-s" << "8" << "-l" << "H" << serverAddress;
connect(qrGenerator,SIGNAL(finished(int,QProcess::ExitStatus)),this,SLOT(updateImage(void))); connect(qrGenerator,SIGNAL(finished(int,QProcess::ExitStatus)),this,SLOT(updateImage(void)));
connect(qrGenerator,SIGNAL(error(QProcess::ProcessError)),this,SLOT(openingError(QProcess::ProcessError))); connect(qrGenerator,SIGNAL(error(QProcess::ProcessError)),this,SLOT(openingError(QProcess::ProcessError)));
qrGenerator->start(QCoreApplication::applicationDirPath()+"/utils/qrcode",attributes); qrGenerator->start(QCoreApplication::applicationDirPath()+"/utils/qrencode",attributes);
} }
void ServerConfigDialog::updateImage() void ServerConfigDialog::updateImage()