pushing requested changes - adding timeout refusal

This commit is contained in:
Wayne Chen 2018-09-11 18:32:17 -07:00
parent 490cdc901e
commit a7321f950a
5 changed files with 21 additions and 8 deletions

View file

@ -230,8 +230,6 @@ public:
bool getPreferAvatarFingerOverStylus() { return false; }
void setPreferAvatarFingerOverStylus(bool value);
float getDomainLoadingProgress() { return _octreeProcessor.domainLoadingProgress(); }
float getSettingConstrainToolbarPosition() { return _constrainToolbarPosition.get(); }
void setSettingConstrainToolbarPosition(bool setting);

View file

@ -23,7 +23,6 @@
// should be longer to allow the application to initialize.
static const int ON_INITIAL_LOAD_REDIRECT_AFTER_DISCONNECTED_FOR_X_MS = 10000;
static const int REDIRECT_AFTER_DISCONNECTED_FOR_X_MS = 5000;
static const QString ERROR_DOMAIN_URL = "file:///~/serverless/redirect.json";
void ConnectionMonitor::init() {
// Connect to domain disconnected message
@ -33,15 +32,17 @@ void ConnectionMonitor::init() {
connect(&domainHandler, &DomainHandler::disconnectedFromDomain, this, &ConnectionMonitor::startTimer);
connect(&domainHandler, &DomainHandler::connectedToDomain, this, &ConnectionMonitor::stopTimer);
connect(&domainHandler, &DomainHandler::domainConnectionRefused, this, &ConnectionMonitor::stopTimer);
connect(&domainHandler, &DomainHandler::redirectToErrorDomainURL, this, &ConnectionMonitor::stopTimer);
_timer.setSingleShot(true);
if (!domainHandler.isConnected()) {
_timer.start(ON_INITIAL_LOAD_REDIRECT_AFTER_DISCONNECTED_FOR_X_MS);
}
connect(&_timer, &QTimer::timeout, this, []() {
connect(&_timer, &QTimer::timeout, this, [domainHandler]() {
qDebug() << "ConnectionMonitor: Redirecting to 404 error domain";
qApp->goToErrorDomainURL(REDIRECT_HIFI_ADDRESS);
// set in a timeout error
domainHandler.setErrorRedirectState(REDIRECT_HIFI_ADDRESS, 5);
});
}

View file

@ -594,5 +594,5 @@ void WindowScriptingInterface::onMessageBoxSelected(int button) {
float WindowScriptingInterface::domainLoadingProgress() {
return qApp->getDomainLoadingProgress();
return qApp->getOctreePacketProcessor().domainLoadingProgress();
}

View file

@ -335,6 +335,12 @@ void DomainHandler::loadedErrorDomain(std::map<QString, QString> namedPaths) {
DependencyManager::get<AddressManager>()->goToViewpointForPath(viewpoint, QString());
}
void DomainHandler::setRedirectErrorState(QUrl errorUrl, int reasonCode) {
_errorDomainURL = errorUrl;
_lastDomainConnectionError = reasonCode;
emit redirectToErrorDomainURL(_errorDomainURL);
}
void DomainHandler::requestDomainSettings() {
qCDebug(networking) << "Requesting settings from domain server";

View file

@ -87,6 +87,8 @@ public:
void connectedToServerless(std::map<QString, QString> namedPaths);
void loadedErrorDomain(std::map<QString, QString> namedPaths);
// sets domain handler in error state.
void setRedirectErrorState(QUrl errorUrl, int reasonCode);
QString getViewPointFromNamedPath(QString namedPath);
@ -142,6 +144,11 @@ public:
* <td><code>4</code></td>
* <td>The domain already has its maximum number of users.</td>
* </tr>
* <tr>
* <td><strong>TimedOut</strong></td>
* <td><code>5</code></td>
* <td>Connecting to the domain timed out.</td>
* </tr>
* </tbody>
* </table>
* @typedef {number} Window.ConnectionRefusedReason
@ -151,7 +158,8 @@ public:
ProtocolMismatch,
LoginError,
NotAuthorized,
TooManyUsers
TooManyUsers,
TimedOut
};
public slots:
@ -188,7 +196,7 @@ signals:
void settingsReceiveFail();
void domainConnectionRefused(QString reasonMessage, int reason, const QString& extraInfo);
void redirectToErrorDomainURL(QUrl errorDomaunURL);
void redirectToErrorDomainURL(QUrl errorDomainURL);
void limitOfSilentDomainCheckInsReached();