mirror of
https://github.com/IT4Change/gradido.git
synced 2025-12-13 07:45:54 +00:00
268 lines
12 KiB
C++
268 lines
12 KiB
C++
#include "SaveKeysPage.h"
|
|
#include "Poco/Net/HTTPServerRequest.h"
|
|
#include "Poco/Net/HTTPServerResponse.h"
|
|
#include "Poco/Net/HTMLForm.h"
|
|
#include "Poco/DeflatingStream.h"
|
|
|
|
|
|
#line 7 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\saveKeys.cpsp"
|
|
|
|
#include "Poco/Net/HTTPServerParams.h"
|
|
|
|
enum PageState
|
|
{
|
|
PAGE_ASK,
|
|
PAGE_SHOW_PUBKEY,
|
|
PAGE_ERROR
|
|
};
|
|
|
|
#line 1 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\header.cpsp"
|
|
|
|
#include "../ServerConfig.h"
|
|
|
|
|
|
SaveKeysPage::SaveKeysPage(Session* arg):
|
|
SessionHTTPRequestHandler(arg)
|
|
{
|
|
}
|
|
|
|
|
|
void SaveKeysPage::handleRequest(Poco::Net::HTTPServerRequest& request, Poco::Net::HTTPServerResponse& response)
|
|
{
|
|
response.setChunkedTransferEncoding(true);
|
|
response.setContentType("text/html");
|
|
bool _compressResponse(request.hasToken("Accept-Encoding", "gzip"));
|
|
if (_compressResponse) response.set("Content-Encoding", "gzip");
|
|
|
|
Poco::Net::HTMLForm form(request, request.stream());
|
|
#line 18 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\saveKeys.cpsp"
|
|
|
|
const char* pageName = "Daten auf Server speichern?";
|
|
bool hasErrors = mSession->errorCount() > 0;
|
|
// crypto key only in memory, if user has tipped in his passwort in this session
|
|
bool hasPassword = mSession->getUser()->hasCryptoKey();
|
|
PageState state = PAGE_ASK;
|
|
auto uri_start = ServerConfig::g_php_serverPath;//request.serverParams().getServerName();
|
|
|
|
// skip asking user if he like to save keys and passphrase on server
|
|
state = PAGE_SHOW_PUBKEY;
|
|
if(!mSession->generateKeys(true, true)) {
|
|
getErrors(mSession);
|
|
}
|
|
|
|
if(!form.empty()) {
|
|
// privkey
|
|
auto savePrivkeyChoice = form.get("save-privkey");
|
|
bool savePrivkey = false;
|
|
if(savePrivkeyChoice == "yes") {
|
|
if(!hasPassword) {
|
|
// check pwd
|
|
auto pwd = form.get("save-privkey-password", "");
|
|
|
|
if(!mSession->isPwdValid(pwd)) {
|
|
addError(new Error("Passwort", "Das Passwort stimmt nicht. Bitte verwende dein Passwort von der Registrierung"));
|
|
hasErrors = true;
|
|
} else {
|
|
savePrivkey = true;
|
|
}
|
|
} else {
|
|
savePrivkey = true;
|
|
}
|
|
}
|
|
if(!hasErrors) {
|
|
auto savePassphraseChoice = form.get("save-passphrase");
|
|
bool savePassphrase = false;
|
|
if(savePassphraseChoice == "yes") {
|
|
savePassphrase = true;
|
|
}
|
|
if(!mSession->generateKeys(savePrivkey, savePassphrase)) {
|
|
hasErrors = true;
|
|
} else if(mSession->getSessionState() >= SESSION_STATE_KEY_PAIR_GENERATED) {
|
|
state = PAGE_SHOW_PUBKEY;
|
|
|
|
//printf("uri_start: %s\n", uri_start.data());
|
|
//response.redirect(uri_start + "/");
|
|
} else {
|
|
state = PAGE_ERROR;
|
|
}
|
|
}
|
|
//printf("SaveKeysPage: hasErrors: %d, session state: %d, target state: %d\n",
|
|
//hasErrors, mSession->getSessionState(), SESSION_STATE_KEY_PAIR_GENERATED);
|
|
}
|
|
getErrors(mSession);
|
|
std::ostream& _responseStream = response.send();
|
|
Poco::DeflatingOutputStream _gzipStream(_responseStream, Poco::DeflatingStreamBuf::STREAM_GZIP, 1);
|
|
std::ostream& responseStream = _compressResponse ? _gzipStream : _responseStream;
|
|
responseStream << "\n";
|
|
// begin include header.cpsp
|
|
responseStream << "\n";
|
|
responseStream << "<!DOCTYPE html>\n";
|
|
responseStream << "<html>\n";
|
|
responseStream << "<head>\n";
|
|
responseStream << "<meta charset=\"UTF-8\">\n";
|
|
responseStream << "<meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n";
|
|
responseStream << "<title>Gradido Login Server: ";
|
|
#line 9 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\header.cpsp"
|
|
responseStream << ( pageName );
|
|
responseStream << "</title>\n";
|
|
responseStream << "<!--<link rel=\"stylesheet\" type=\"text/css\" href=\"css/styles.min.css\">-->\n";
|
|
responseStream << "<link rel=\"stylesheet\" type=\"text/css\" href=\"";
|
|
#line 11 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\header.cpsp"
|
|
responseStream << ( ServerConfig::g_php_serverPath );
|
|
responseStream << "/css/styles.css\">\n";
|
|
responseStream << "<style type=\"text/css\" >\n";
|
|
responseStream << ".grd_container\n";
|
|
responseStream << "{\n";
|
|
responseStream << " max-width:820px;\n";
|
|
responseStream << " margin-left:auto;\n";
|
|
responseStream << " margin-right:auto;\n";
|
|
responseStream << "}\n";
|
|
responseStream << "\n";
|
|
responseStream << "input:not([type='radio']) {\n";
|
|
responseStream << "\twidth:200px;\n";
|
|
responseStream << "}\n";
|
|
responseStream << "label:not(.grd_radio_label) {\n";
|
|
responseStream << "\twidth:80px;\n";
|
|
responseStream << "\tdisplay:inline-block;\n";
|
|
responseStream << "}\n";
|
|
responseStream << ".grd_container_small\n";
|
|
responseStream << "{\n";
|
|
responseStream << " max-width:500px;\n";
|
|
responseStream << "}\n";
|
|
responseStream << ".grd_text {\n";
|
|
responseStream << " max-width:550px;\n";
|
|
responseStream << " margin-bottom: 5px;\n";
|
|
responseStream << "}\n";
|
|
responseStream << ".dev-info {\n";
|
|
responseStream << "\tposition: fixed;\n";
|
|
responseStream << "\tcolor:grey;\n";
|
|
responseStream << "\tfont-size: smaller;\n";
|
|
responseStream << "\tleft:8px;\n";
|
|
responseStream << "}\n";
|
|
responseStream << ".grd-time-used { \n";
|
|
responseStream << " bottom:0;\n";
|
|
responseStream << "} \n";
|
|
responseStream << "\n";
|
|
responseStream << ".versionstring {\n";
|
|
responseStream << "\ttop:0;\n";
|
|
responseStream << "}\n";
|
|
responseStream << "</style>\n";
|
|
responseStream << "</head>\n";
|
|
responseStream << "<body>\n";
|
|
responseStream << "<div class=\"versionstring dev-info\">\n";
|
|
responseStream << "\t<p class=\"grd_small\">Login Server in Entwicklung</p>\n";
|
|
responseStream << "\t<p class=\"grd_small\">Alpha 0.4.5</p>\n";
|
|
responseStream << "</div>\n";
|
|
responseStream << "<!--<nav class=\"grd-left-bar expanded\" data-topbar role=\"navigation\">\n";
|
|
responseStream << "\t<div class=\"grd-left-bar-section\">\n";
|
|
responseStream << "\t\t<ul class=\"grd-no-style\">\n";
|
|
responseStream << "\t\t <li><a href=\"";
|
|
#line 58 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\header.cpsp"
|
|
responseStream << ( ServerConfig::g_php_serverPath );
|
|
responseStream << "\" class=\"grd-nav-bn\">Startseite</a>\n";
|
|
responseStream << "\t\t <li><a href=\"./account/logout\" class=\"grd-nav-bn\">Logout</a></li>\n";
|
|
responseStream << "\t\t</ul>\n";
|
|
responseStream << "\t</div>\n";
|
|
responseStream << "</nav>-->";
|
|
// end include header.cpsp
|
|
responseStream << "\n";
|
|
responseStream << "<div class=\"grd_container\">\n";
|
|
responseStream << "\t<h1>Daten speichern</h1>\n";
|
|
responseStream << "\t";
|
|
#line 75 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\saveKeys.cpsp"
|
|
responseStream << ( getErrorsHtml() );
|
|
responseStream << "\n";
|
|
responseStream << "\t";
|
|
#line 76 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\saveKeys.cpsp"
|
|
if(state == PAGE_ASK) { responseStream << "\n";
|
|
responseStream << "\t<form method=\"POST\">\n";
|
|
responseStream << "\t\t<fieldset>\n";
|
|
responseStream << "\t\t\t<legend>Gradido Private Key speichern</legend>\n";
|
|
responseStream << "\t\t\t<div class=\"grd_text\">\n";
|
|
responseStream << "\t\t\t\t<p>Möchtest du deinen Gradido Private Key auf dem Server mit deinem Passwort verschlüsselt speichern?</p>\n";
|
|
responseStream << "\t\t\t\t<p>Wenn du ihn speicherst brauchst du dich in Zukunft nur mit deiner E-Mail und deinem Passwort einzuloggen.</p>\n";
|
|
responseStream << "\t\t\t\t<p>Wenn du ihn nicht speicherst, müsstest du jedes mal wenn du eine Transaktion machen willst, deine Passphrase hier reinkopieren.</p>\n";
|
|
responseStream << "\t\t\t</div>\n";
|
|
responseStream << "\t\t\t<p class=\"grd_small\">\n";
|
|
responseStream << "\t\t\t\t<input id=\"save-privkey-yes\" type=\"radio\" name=\"save-privkey\" value=\"yes\" checked/>\n";
|
|
responseStream << "\t\t\t\t<label class=\"grd_radio_label\" for=\"save-privkey-yes\">Ja, bitte speichern!</label>\n";
|
|
responseStream << "\t\t\t</p>\n";
|
|
responseStream << "\t\t\t";
|
|
#line 89 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\saveKeys.cpsp"
|
|
if(!hasPassword) { responseStream << "\n";
|
|
responseStream << "\t\t\t\t<p>Ich brauche nochmal dein Passwort wenn du dich für ja entscheidest.</p>\n";
|
|
responseStream << "\t\t\t\t<p class=\"grd_small\">\n";
|
|
responseStream << "\t\t\t\t\t<label for=\"save-privkey-password\">Passwort</label>\n";
|
|
responseStream << "\t\t\t\t\t<input id=\"save-privkey-password\" type=\"password\" name=\"save-privkey-password\"/>\n";
|
|
responseStream << "\t\t\t\t</p>\n";
|
|
responseStream << "\t\t\t";
|
|
#line 95 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\saveKeys.cpsp"
|
|
} responseStream << "\n";
|
|
responseStream << "\t\t\t<p class=\"grd_small\">\n";
|
|
responseStream << "\t\t\t\t<input id=\"save-privkey-no\" type=\"radio\" name=\"save-privkey\" value=\"no\"/>\n";
|
|
responseStream << "\t\t\t\t<label class=\"grd_radio_label\" for=\"save-privkey-no\">Nein, ich kümmere mich selbst darum!</label>\n";
|
|
responseStream << "\t\t\t</p>\n";
|
|
responseStream << "\t\t</fieldset>\n";
|
|
responseStream << "\t\t<fieldset>\n";
|
|
responseStream << "\t\t\t<legend>Passphrase speichern</legend>\n";
|
|
responseStream << "\t\t\t<div class=\"grd_text\">\n";
|
|
responseStream << "\t\t\t\t<p>Möchtest du deine Passphrase mit dem Server-Admin-Key verschlüsselt auf dem Server gespeichert haben?</p>\n";
|
|
responseStream << "\t\t\t\t<p>Dann kann dir der Server-Admin deine Passphrase zuschicken wenn du sie verlegt hast. </p>\n";
|
|
responseStream << "\t\t\t</div>\n";
|
|
responseStream << "\t\t\t<p class=\"grd_small\">\n";
|
|
responseStream << "\t\t\t\t<input id=\"save-passphrase-yes\" type=\"radio\" name=\"save-passphrase\" value=\"yes\" checked/>\n";
|
|
responseStream << "\t\t\t\t<label class=\"grd_radio_label\" for=\"save-passphrase-yes\">Ja, bitte speichern!</label>\n";
|
|
responseStream << "\t\t\t</p>\n";
|
|
responseStream << "\t\t\t<p class=\"grd_small\">\n";
|
|
responseStream << "\t\t\t\t<input id=\"save-passphrase-no\" type=\"radio\" name=\"save-passphrase\" value=\"no\"/>\n";
|
|
responseStream << "\t\t\t\t<label class=\"grd_radio_label\" for=\"save-passphrase-no\">Nein, ich vertraue nur mir selbst!</label>\n";
|
|
responseStream << "\t\t\t</p>\n";
|
|
responseStream << "\t\t</fieldset>\n";
|
|
responseStream << "\t\t<input class=\"grd-form-bn grd-form-bn-succeed\" type=\"submit\" value=\"Speichern\">\n";
|
|
responseStream << "\t</form>\n";
|
|
responseStream << "\t";
|
|
#line 118 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\saveKeys.cpsp"
|
|
} else if(state == PAGE_SHOW_PUBKEY) { responseStream << "\n";
|
|
responseStream << "\t\t<div class=\"grd_text\">\n";
|
|
responseStream << "\t\t\t<!--<p>Je nach Auswahl werden deine Daten nun verschlüsselt und gespeichert. </p>-->\n";
|
|
responseStream << "\t\t\t<p>Deine Daten werden nun verschlüsselt und gespeichert.</p>\n";
|
|
responseStream << "\t\t\t<!--<p>Deine Gradido Adresse (Hex): </p>\n";
|
|
responseStream << "\t\t\t<p class=\"grd_textarea\">\n";
|
|
responseStream << "\t\t\t\t";
|
|
#line 124 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\saveKeys.cpsp"
|
|
responseStream << ( mSession->getUser()->getPublicKeyHex() );
|
|
responseStream << "\n";
|
|
responseStream << "\t\t\t</p>-->\n";
|
|
responseStream << "\t\t\t<a class=\"grd-form-bn\" href=\"";
|
|
#line 126 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\saveKeys.cpsp"
|
|
responseStream << ( uri_start );
|
|
responseStream << "\">Zurück zur Startseite</a>\n";
|
|
responseStream << "\t\t</div>\n";
|
|
responseStream << "\t";
|
|
#line 128 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\saveKeys.cpsp"
|
|
} else if(state == PAGE_ERROR) { responseStream << "\n";
|
|
responseStream << "\t\t<div class=\"grd_text\">\n";
|
|
responseStream << "\t\t\t<p>Ein Fehler trat auf, bitte versuche es erneut oder wende dich an den Server-Admin</p>\n";
|
|
responseStream << "\t\t\t";
|
|
#line 131 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\saveKeys.cpsp"
|
|
responseStream << ( mSession->getSessionStateString() );
|
|
responseStream << "\n";
|
|
responseStream << "\t\t</div>\n";
|
|
responseStream << "\t";
|
|
#line 133 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\saveKeys.cpsp"
|
|
} responseStream << "\n";
|
|
responseStream << "</div>\n";
|
|
// begin include footer.cpsp
|
|
responseStream << "\t<div class=\"grd-time-used dev-info\">\n";
|
|
responseStream << "\t\t\t";
|
|
#line 2 "I:\\Code\\C++\\Eigene_Projekte\\Gradido_LoginServer\\src\\cpsp\\footer.cpsp"
|
|
responseStream << ( mTimeProfiler.string() );
|
|
responseStream << "\n";
|
|
responseStream << "\t</div>\n";
|
|
responseStream << "</body>\n";
|
|
responseStream << "</html>";
|
|
// end include footer.cpsp
|
|
responseStream << "\n";
|
|
if (_compressResponse) _gzipStream.close();
|
|
}
|