MOBILE-3715 login: Show error if SSO login with external app

main
Dani Palou 2022-01-18 12:51:28 +01:00
parent 396d221961
commit fbf9d6c7fa
3 changed files with 14 additions and 3 deletions

View File

@ -1658,6 +1658,7 @@
"core.errorsync": "local_moodlemobileapp", "core.errorsync": "local_moodlemobileapp",
"core.errorsyncblocked": "local_moodlemobileapp", "core.errorsyncblocked": "local_moodlemobileapp",
"core.errorurlschemeinvalidscheme": "local_moodlemobileapp", "core.errorurlschemeinvalidscheme": "local_moodlemobileapp",
"core.errorurlschemeinvalidschemessologin": "local_moodlemobileapp",
"core.errorurlschemeinvalidsite": "local_moodlemobileapp", "core.errorurlschemeinvalidsite": "local_moodlemobileapp",
"core.expand": "moodle", "core.expand": "moodle",
"core.explanationdigitalminor": "moodle", "core.explanationdigitalminor": "moodle",

View File

@ -19,7 +19,7 @@ import { BackButtonEvent } from '@ionic/core';
import { CoreLang } from '@services/lang'; import { CoreLang } from '@services/lang';
import { CoreLoginHelper } from '@features/login/services/login-helper'; import { CoreLoginHelper } from '@features/login/services/login-helper';
import { CoreEvents } from '@singletons/events'; import { CoreEvents } from '@singletons/events';
import { Network, NgZone, Platform, SplashScreen } from '@singletons'; import { Network, NgZone, Platform, SplashScreen, Translate } from '@singletons';
import { CoreApp, CoreAppProvider } from '@services/app'; import { CoreApp, CoreAppProvider } from '@services/app';
import { CoreSites } from '@services/sites'; import { CoreSites } from '@services/sites';
import { CoreNavigator } from '@services/navigator'; import { CoreNavigator } from '@services/navigator';
@ -30,6 +30,7 @@ import { CoreUtils } from '@services/utils/utils';
import { CoreUrlUtils } from '@services/utils/url'; import { CoreUrlUtils } from '@services/utils/url';
import { CoreConstants } from '@/core/constants'; import { CoreConstants } from '@/core/constants';
import { CoreSitePlugins } from '@features/siteplugins/services/siteplugins'; import { CoreSitePlugins } from '@features/siteplugins/services/siteplugins';
import { CoreDomUtils } from '@services/utils/dom';
const MOODLE_VERSION_PREFIX = 'version-'; const MOODLE_VERSION_PREFIX = 'version-';
const MOODLEAPP_VERSION_PREFIX = 'moodleapp-'; const MOODLEAPP_VERSION_PREFIX = 'moodleapp-';
@ -111,6 +112,8 @@ export class AppComponent implements OnInit, AfterViewInit {
// URLs with a custom scheme can be prefixed with "http://" or "https://", we need to remove this. // URLs with a custom scheme can be prefixed with "http://" or "https://", we need to remove this.
const protocol = CoreUrlUtils.getUrlProtocol(event.url); const protocol = CoreUrlUtils.getUrlProtocol(event.url);
const url = event.url.replace(/^https?:\/\//, ''); const url = event.url.replace(/^https?:\/\//, '');
const urlScheme = CoreUrlUtils.getUrlProtocol(url);
const isExternalApp = urlScheme && urlScheme !== 'file' && urlScheme !== 'cdvfile';
if (CoreCustomURLSchemes.isCustomURL(url)) { if (CoreCustomURLSchemes.isCustomURL(url)) {
// Close the browser if it's a valid SSO URL. // Close the browser if it's a valid SSO URL.
@ -119,10 +122,16 @@ export class AppComponent implements OnInit, AfterViewInit {
}); });
CoreUtils.closeInAppBrowser(); CoreUtils.closeInAppBrowser();
} else if (isExternalApp && url.includes('://token=')) {
// It's an SSO token for another app. Close the IAB and show an error.
CoreUtils.closeInAppBrowser();
CoreDomUtils.showErrorModal(Translate.instant('core.errorurlschemeinvalidschemessologin', {
$a: urlScheme,
}));
} else if (CoreApp.isAndroid()) { } else if (CoreApp.isAndroid()) {
// Check if the URL has a custom URL scheme. In Android they need to be opened manually. // Check if the URL has a custom URL scheme. In Android they need to be opened manually.
const urlScheme = CoreUrlUtils.getUrlProtocol(url); if (isExternalApp) {
if (urlScheme && urlScheme !== 'file' && urlScheme !== 'cdvfile') {
// Open in browser should launch the right app if found and do nothing if not found. // Open in browser should launch the right app if found and do nothing if not found.
CoreUtils.openInBrowser(url, { showBrowserWarning: false }); CoreUtils.openInBrowser(url, { showBrowserWarning: false });

View File

@ -113,6 +113,7 @@
"errorsync": "An error occurred while synchronising. Please try again.", "errorsync": "An error occurred while synchronising. Please try again.",
"errorsyncblocked": "This {{$a}} cannot be synchronised right now because of an ongoing process. Please try again later. If the problem persists, try restarting the app.", "errorsyncblocked": "This {{$a}} cannot be synchronised right now because of an ongoing process. Please try again later. If the problem persists, try restarting the app.",
"errorurlschemeinvalidscheme": "This URL is meant to be used in another app: {{$a}}.", "errorurlschemeinvalidscheme": "This URL is meant to be used in another app: {{$a}}.",
"errorurlschemeinvalidschemessologin": "This site is configured to be used in another app: {{$a}}.",
"errorurlschemeinvalidsite": "This site URL cannot be opened in this app.", "errorurlschemeinvalidsite": "This site URL cannot be opened in this app.",
"expand": "Expand", "expand": "Expand",
"explanationdigitalminor": "This information is required to determine if your age is over the digital age of consent. This is the age when an individual can consent to terms and conditions and their data being legally stored and processed.", "explanationdigitalminor": "This information is required to determine if your age is over the digital age of consent. This is the age when an individual can consent to terms and conditions and their data being legally stored and processed.",