From c5783960ca160b61f750253b08383cbe666a4a30 Mon Sep 17 00:00:00 2001 From: GioSensation <1828326+GioSensation@users.noreply.github.com> Date: Thu, 14 Mar 2024 08:19:39 +0000 Subject: [PATCH] Update autofill to 10.2.0 --- .../autofill/dist/autofill-debug.js | 464 ++++++++---------- .../@duckduckgo/autofill/dist/autofill.css | 3 +- .../@duckduckgo/autofill/dist/autofill.js | 464 ++++++++---------- .../autofill/dist/shared-credentials.json | 16 + package-lock.json | 7 +- package.json | 2 +- 6 files changed, 458 insertions(+), 498 deletions(-) diff --git a/node_modules/@duckduckgo/autofill/dist/autofill-debug.js b/node_modules/@duckduckgo/autofill/dist/autofill-debug.js index 3627f1372b9d..de63872a0617 100644 --- a/node_modules/@duckduckgo/autofill/dist/autofill-debug.js +++ b/node_modules/@duckduckgo/autofill/dist/autofill-debug.js @@ -6618,6 +6618,9 @@ module.exports={ "clien.net": { "password-rules": "minlength: 5; required: lower, upper; required: digit;" }, + "cogmembers.org": { + "password-rules": "minlength: 8; maxlength: 14; required: upper; required: digit, allowed: lower;" + }, "collectivehealth.com": { "password-rules": "minlength: 8; required: lower; required: upper; required: digit;" }, @@ -6708,6 +6711,9 @@ module.exports={ "eddservices.edd.ca.gov": { "password-rules": "minlength: 8; maxlength: 12; required: lower; required: upper; required: digit; required: [!@#$%^&*()];" }, + "edistrict.kerala.gov.in": { + "password-rules": "minlength: 5; maxlength: 15; required: lower; required: upper; required: digit; required: [!@#$];" + }, "empower-retirement.com": { "password-rules": "minlength: 8; maxlength: 16;" }, @@ -6762,6 +6768,9 @@ module.exports={ "gamestop.com": { "password-rules": "minlength: 8; maxlength: 225; required: lower; required: upper; required: digit; required: [!@#$%];" }, + "garmin.com": { + "password-rules": "minlength: 8; required: lower; required: upper; required: digit;" + }, "getflywheel.com": { "password-rules": "minlength: 7; maxlength: 72;" }, @@ -7308,6 +7317,9 @@ module.exports={ "target.com": { "password-rules": "minlength: 8; maxlength: 20; required: lower, upper; required: digit, [-!\"#$%&'()*+,./:;=?@[\\^_`{|}~];" }, + "tdscpc.gov.in": { + "password-rules": "minlength: 8; maxlength: 15; required: lower; required: upper; required: digit; required: [ &',;\"];" + }, "telekom-dienste.de": { "password-rules": "minlength: 8; maxlength: 16; required: lower; required: upper; required: digit; required: [#$%&()*+,./<=>?@_{|}~];" }, @@ -7485,7 +7497,7 @@ function createDevice() { return new _ExtensionInterface.ExtensionInterface(globalConfig, deviceApi, settings); } -},{"../packages/device-api/index.js":12,"./DeviceInterface/AndroidInterface.js":23,"./DeviceInterface/AppleDeviceInterface.js":24,"./DeviceInterface/AppleOverlayDeviceInterface.js":25,"./DeviceInterface/ExtensionInterface.js":26,"./DeviceInterface/WindowsInterface.js":28,"./DeviceInterface/WindowsOverlayDeviceInterface.js":29,"./Settings.js":50,"./config.js":63,"./deviceApiCalls/transports/transports.js":71}],23:[function(require,module,exports){ +},{"../packages/device-api/index.js":12,"./DeviceInterface/AndroidInterface.js":23,"./DeviceInterface/AppleDeviceInterface.js":24,"./DeviceInterface/AppleOverlayDeviceInterface.js":25,"./DeviceInterface/ExtensionInterface.js":26,"./DeviceInterface/WindowsInterface.js":28,"./DeviceInterface/WindowsOverlayDeviceInterface.js":29,"./Settings.js":50,"./config.js":64,"./deviceApiCalls/transports/transports.js":72}],23:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -7495,15 +7507,11 @@ exports.AndroidInterface = void 0; var _InterfacePrototype = _interopRequireDefault(require("./InterfacePrototype.js")); var _autofillUtils = require("../autofill-utils.js"); var _NativeUIController = require("../UI/controllers/NativeUIController.js"); -var _appleUtils = require("@duckduckgo/content-scope-scripts/src/apple-utils"); var _InContextSignup = require("../InContextSignup.js"); var _deviceApiCalls = require("../deviceApiCalls/__generated__/deviceApiCalls.js"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } class AndroidInterface extends _InterfacePrototype.default { inContextSignup = new _InContextSignup.InContextSignup(this); - async isEnabled() { - return (0, _autofillUtils.autofillEnabled)(this.globalConfig, _appleUtils.processConfig); - } /** * @returns {Promise} @@ -7637,7 +7645,7 @@ class AndroidInterface extends _InterfacePrototype.default { } exports.AndroidInterface = AndroidInterface; -},{"../InContextSignup.js":44,"../UI/controllers/NativeUIController.js":56,"../autofill-utils.js":61,"../deviceApiCalls/__generated__/deviceApiCalls.js":65,"./InterfacePrototype.js":27,"@duckduckgo/content-scope-scripts/src/apple-utils":1}],24:[function(require,module,exports){ +},{"../InContextSignup.js":44,"../UI/controllers/NativeUIController.js":57,"../autofill-utils.js":62,"../deviceApiCalls/__generated__/deviceApiCalls.js":66,"./InterfacePrototype.js":27}],24:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -7646,7 +7654,6 @@ Object.defineProperty(exports, "__esModule", { exports.AppleDeviceInterface = void 0; var _InterfacePrototype = _interopRequireDefault(require("./InterfacePrototype.js")); var _autofillUtils = require("../autofill-utils.js"); -var _appleUtils = require("@duckduckgo/content-scope-scripts/src/apple-utils"); var _HTMLTooltip = require("../UI/HTMLTooltip.js"); var _HTMLTooltipUIController = require("../UI/controllers/HTMLTooltipUIController.js"); var _OverlayUIController = require("../UI/controllers/OverlayUIController.js"); @@ -7656,6 +7663,7 @@ var _NativeUIController = require("../UI/controllers/NativeUIController.js"); var _deviceApiCalls = require("../deviceApiCalls/__generated__/deviceApiCalls.js"); var _matching = require("../Form/matching.js"); var _InContextSignup = require("../InContextSignup.js"); +var _ThirdPartyProvider = require("../ThirdPartyProvider.js"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /** * @typedef {import('../deviceApiCalls/__generated__/validators-ts').GetAutofillDataRequest} GetAutofillDataRequest @@ -7666,9 +7674,7 @@ class AppleDeviceInterface extends _InterfacePrototype.default { /** @override */ initialSetupDelayMs = 300; - async isEnabled() { - return (0, _autofillUtils.autofillEnabled)(this.globalConfig, _appleUtils.processConfig); - } + thirdPartyProvider = new _ThirdPartyProvider.ThirdPartyProvider(this); /** * The default functionality of this class is to operate as an 'overlay controller' - @@ -7871,20 +7877,6 @@ class AppleDeviceInterface extends _InterfacePrototype.default { return this.deviceApi.notify((0, _index.createNotification)('pmHandlerOpenManagePasswords')); } - /** - * Opens the native UI for managing identities - */ - openManageIdentities() { - return this.deviceApi.notify((0, _index.createNotification)('pmHandlerOpenManageIdentities')); - } - - /** - * Opens the native UI for managing credit cards - */ - openManageCreditCards() { - return this.deviceApi.notify((0, _index.createNotification)('pmHandlerOpenManageCreditCards')); - } - /** * Gets a single identity obj once the user requests it * @param {IdentityObject['id']} id @@ -7940,36 +7932,7 @@ class AppleDeviceInterface extends _InterfacePrototype.default { }); } async addDeviceListeners() { - if (this.settings.featureToggles.third_party_credentials_provider) { - if (this.globalConfig.hasModernWebkitAPI) { - Object.defineProperty(window, 'providerStatusUpdated', { - enumerable: false, - configurable: false, - writable: false, - value: data => { - this.providerStatusUpdated(data); - } - }); - } else { - // On Catalina we poll the native layer - setTimeout(() => this._pollForUpdatesToCredentialsProvider(), 2000); - } - } - } - - // Only used on Catalina - async _pollForUpdatesToCredentialsProvider() { - try { - const response = await this.deviceApi.request(new _deviceApiCalls.CheckCredentialsProviderStatusCall(null)); - if (response.availableInputTypes.credentialsProviderStatus !== this.settings.availableInputTypes.credentialsProviderStatus) { - this.providerStatusUpdated(response); - } - setTimeout(() => this._pollForUpdatesToCredentialsProvider(), 2000); - } catch (e) { - if (this.globalConfig.isDDGTestMode) { - console.log('isDDGTestMode: _pollForUpdatesToCredentialsProvider: ❌', e); - } - } + this.thirdPartyProvider.init(); } /** @type {any} */ @@ -8023,7 +7986,7 @@ class AppleDeviceInterface extends _InterfacePrototype.default { } exports.AppleDeviceInterface = AppleDeviceInterface; -},{"../../packages/device-api/index.js":12,"../Form/matching.js":43,"../InContextSignup.js":44,"../UI/HTMLTooltip.js":54,"../UI/controllers/HTMLTooltipUIController.js":55,"../UI/controllers/NativeUIController.js":56,"../UI/controllers/OverlayUIController.js":57,"../autofill-utils.js":61,"../deviceApiCalls/__generated__/deviceApiCalls.js":65,"../deviceApiCalls/additionalDeviceApiCalls.js":67,"./InterfacePrototype.js":27,"@duckduckgo/content-scope-scripts/src/apple-utils":1}],25:[function(require,module,exports){ +},{"../../packages/device-api/index.js":12,"../Form/matching.js":43,"../InContextSignup.js":44,"../ThirdPartyProvider.js":51,"../UI/HTMLTooltip.js":55,"../UI/controllers/HTMLTooltipUIController.js":56,"../UI/controllers/NativeUIController.js":57,"../UI/controllers/OverlayUIController.js":58,"../autofill-utils.js":62,"../deviceApiCalls/__generated__/deviceApiCalls.js":66,"../deviceApiCalls/additionalDeviceApiCalls.js":68,"./InterfacePrototype.js":27}],25:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -8034,8 +7997,6 @@ var _AppleDeviceInterface = require("./AppleDeviceInterface.js"); var _HTMLTooltipUIController = require("../UI/controllers/HTMLTooltipUIController.js"); var _overlayApi = require("./overlayApi.js"); var _index = require("../../packages/device-api/index.js"); -var _deviceApiCalls = require("../deviceApiCalls/__generated__/deviceApiCalls.js"); -var _validatorsZod = require("../deviceApiCalls/__generated__/validators.zod.js"); /** * This subclass is designed to separate code that *only* runs inside the * Overlay into a single place. @@ -8137,27 +8098,10 @@ class AppleOverlayDeviceInterface extends _AppleDeviceInterface.AppleDeviceInter async selectedDetail(data, type) { return this.overlay.selectedDetail(data, type); } - async askToUnlockProvider() { - const response = await this.deviceApi.request(new _deviceApiCalls.AskToUnlockProviderCall(null)); - this.providerStatusUpdated(response); - } - providerStatusUpdated(data) { - const { - credentials, - availableInputTypes - } = (0, _index.validate)(data, _validatorsZod.providerStatusUpdatedSchema); - - // Update local settings and data - this.settings.setAvailableInputTypes(availableInputTypes); - this.storeLocalCredentials(credentials); - - // rerender the tooltip - this.uiController?.updateItems(credentials); - } } exports.AppleOverlayDeviceInterface = AppleOverlayDeviceInterface; -},{"../../packages/device-api/index.js":12,"../UI/controllers/HTMLTooltipUIController.js":55,"../deviceApiCalls/__generated__/deviceApiCalls.js":65,"../deviceApiCalls/__generated__/validators.zod.js":66,"./AppleDeviceInterface.js":24,"./overlayApi.js":31}],26:[function(require,module,exports){ +},{"../../packages/device-api/index.js":12,"../UI/controllers/HTMLTooltipUIController.js":56,"./AppleDeviceInterface.js":24,"./overlayApi.js":31}],26:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -8219,18 +8163,6 @@ class ExtensionInterface extends _InterfacePrototype.default { this.uiController = this.createUIController(); await this.postInit(); } - async isEnabled() { - return new Promise(resolve => { - chrome?.runtime?.sendMessage({ - registeredTempAutofillContentScript: true, - documentUrl: window.location.href - }, response => { - if (response && 'site' in response) { - resolve((0, _autofillUtils.isAutofillEnabledFromProcessedConfig)(response)); - } - }); - }); - } isDeviceSignedIn() { return this.hasLocalAddresses; } @@ -8388,7 +8320,7 @@ class ExtensionInterface extends _InterfacePrototype.default { } exports.ExtensionInterface = ExtensionInterface; -},{"../Form/matching.js":43,"../InContextSignup.js":44,"../UI/HTMLTooltip.js":54,"../UI/controllers/HTMLTooltipUIController.js":55,"../autofill-utils.js":61,"./InterfacePrototype.js":27}],27:[function(require,module,exports){ +},{"../Form/matching.js":43,"../InContextSignup.js":44,"../UI/HTMLTooltip.js":55,"../UI/controllers/HTMLTooltipUIController.js":56,"../autofill-utils.js":62,"./InterfacePrototype.js":27}],27:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -8408,7 +8340,6 @@ var _Settings = require("../Settings.js"); var _index = require("../../packages/device-api/index.js"); var _deviceApiCalls = require("../deviceApiCalls/__generated__/deviceApiCalls.js"); var _initFormSubmissionsApi = require("./initFormSubmissionsApi.js"); -var _validatorsZod = require("../deviceApiCalls/__generated__/validators.zod.js"); var _EmailProtection = require("../EmailProtection.js"); /** * @typedef {import('../deviceApiCalls/__generated__/validators-ts').StoreFormData} StoreFormData @@ -8434,6 +8365,8 @@ class InterfacePrototype { /** @type {import("../InContextSignup.js").InContextSignup | null} */ inContextSignup = null; + /** @type {import("../ThirdPartyProvider.js").ThirdPartyProvider | null} */ + thirdPartyProvider = null; /** @type {{privateAddress: string, personalAddress: string}} */ #addresses = { @@ -8646,14 +8579,14 @@ class InterfacePrototype { async startInit() { if (this.isInitializationStarted) return; this.alreadyInitialized = true; - await this.refreshSettings(); + await this.settings.refresh(); this.addDeviceListeners(); await this.setupAutofill(); this.uiController = this.createUIController(); // this is the temporary measure to support windows whilst we still have 'setupAutofill' // eventually all interfaces will use this - if (!this.isEnabledViaSettings()) { + if (!this.settings.enabled) { return; } await this.setupSettingsPage(); @@ -8662,39 +8595,10 @@ class InterfacePrototype { (0, _initFormSubmissionsApi.initFormSubmissionsApi)(this.scanner.forms, this.scanner.matching); } } - - /** - * This is to aid the migration to all platforms using Settings.enabled. - * - * For now, Windows is the only platform that can be 'enabled' or 'disabled' via - * the new Settings - which is why in that interface it has `return this.settings.enabled` - * - * Whilst we wait for other platforms to catch up, we offer this default implementation - * of just returning true. - * - * @returns {boolean} - */ - isEnabledViaSettings() { - return true; - } - - /** - * This is a fall-back situation for macOS since it was the only - * platform to support anything none-email based in the past. - * - * Once macOS fully supports 'getAvailableInputTypes' this can be removed - * - * @returns {Promise} - */ - async refreshSettings() { - await this.settings.refresh(); - } - async isEnabled() { - return (0, _autofillUtils.autofillEnabled)(this.globalConfig); - } async init() { - const isEnabled = await this.isEnabled(); - if (!isEnabled) return; + // bail very early if we can + const settings = await this.settings.refresh(); + if (!settings.enabled) return; const handler = async () => { if (document.readyState === 'complete') { window.removeEventListener('load', handler); @@ -8896,7 +8800,7 @@ class InterfacePrototype { const mainType = (0, _matching.getMainTypeFromType)(inputType); const subtype = (0, _matching.getSubtypeFromType)(inputType); if (id === _Credentials.PROVIDER_LOCKED) { - return this.askToUnlockProvider(); + return this.thirdPartyProvider?.askToUnlockProvider(); } const matchingData = items.find(item => String(item.id) === id); if (!matchingData) throw new Error('unreachable (fatal)'); @@ -8967,10 +8871,6 @@ class InterfacePrototype { return this.removeTooltip(); }); } - async askToUnlockProvider() { - const response = await this.deviceApi.request(new _deviceApiCalls.AskToUnlockProviderCall(null)); - this.providerStatusUpdated(response); - } isTooltipActive() { return this.uiController?.isActive?.() ?? false; } @@ -9073,7 +8973,7 @@ class InterfacePrototype { // This call doesn't send a response, so we can't know if it succeeded this.storeUserData(data); await this.setupAutofill(); - await this.refreshSettings(); + await this.settings.refresh(); await this.setupSettingsPage({ shouldLog: true }); @@ -9086,37 +8986,6 @@ class InterfacePrototype { storeUserData(_data) {} addDeviceListeners() {} - /** - * Called by the native layer on all tabs when the provider status is updated - * @param {import("../deviceApiCalls/__generated__/validators-ts").ProviderStatusUpdated} data - */ - providerStatusUpdated(data) { - try { - const { - credentials, - availableInputTypes - } = (0, _index.validate)(data, _validatorsZod.providerStatusUpdatedSchema); - - // Update local settings and data - this.settings.setAvailableInputTypes(availableInputTypes); - this.storeLocalCredentials(credentials); - - // rerender the tooltip - this.uiController?.updateItems(credentials); - // If the tooltip is open on an autofill type that's not available, close it - const currentInputSubtype = (0, _matching.getSubtypeFromType)(this.getCurrentInputType()); - if (!availableInputTypes.credentials?.[currentInputSubtype]) { - this.removeTooltip(); - } - // Redecorate fields according to the new types - this.scanner.forms.forEach(form => form.recategorizeAllInputs()); - } catch (e) { - if (this.globalConfig.isDDGTestMode) { - console.log('isDDGTestMode: providerStatusUpdated error: ❌', e); - } - } - } - /** @param {() => void} _fn */ addLogoutListener(_fn) {} isDeviceSignedIn() { @@ -9270,7 +9139,7 @@ class InterfacePrototype { } var _default = exports.default = InterfacePrototype; -},{"../../packages/device-api/index.js":12,"../EmailProtection.js":32,"../Form/formatters.js":36,"../Form/matching.js":43,"../InputTypes/Credentials.js":45,"../PasswordGenerator.js":48,"../Scanner.js":49,"../Settings.js":50,"../UI/controllers/NativeUIController.js":56,"../autofill-utils.js":61,"../config.js":63,"../deviceApiCalls/__generated__/deviceApiCalls.js":65,"../deviceApiCalls/__generated__/validators.zod.js":66,"../deviceApiCalls/transports/transports.js":71,"./initFormSubmissionsApi.js":30}],28:[function(require,module,exports){ +},{"../../packages/device-api/index.js":12,"../EmailProtection.js":32,"../Form/formatters.js":36,"../Form/matching.js":43,"../InputTypes/Credentials.js":45,"../PasswordGenerator.js":48,"../Scanner.js":49,"../Settings.js":50,"../UI/controllers/NativeUIController.js":57,"../autofill-utils.js":62,"../config.js":64,"../deviceApiCalls/__generated__/deviceApiCalls.js":66,"../deviceApiCalls/transports/transports.js":72,"./initFormSubmissionsApi.js":30}],28:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -9290,22 +9159,12 @@ class WindowsInterface extends _InterfacePrototype.default { ready = false; /** @type {AbortController|null} */ _abortController = null; - /** - * @deprecated This runs too early, and will be removed eventually. - * @returns {Promise} - */ - async isEnabled() { - return true; - } async setupAutofill() { const loggedIn = await this._getIsLoggedIn(); if (loggedIn) { await this.getAddresses(); } } - isEnabledViaSettings() { - return Boolean(this.settings.enabled); - } postInit() { super.postInit(); this.ready = true; @@ -9442,7 +9301,7 @@ class WindowsInterface extends _InterfacePrototype.default { } exports.WindowsInterface = WindowsInterface; -},{"../UI/controllers/OverlayUIController.js":57,"../deviceApiCalls/__generated__/deviceApiCalls.js":65,"./InterfacePrototype.js":27}],29:[function(require,module,exports){ +},{"../UI/controllers/OverlayUIController.js":58,"../deviceApiCalls/__generated__/deviceApiCalls.js":66,"./InterfacePrototype.js":27}],29:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -9621,7 +9480,7 @@ class WindowsOverlayDeviceInterface extends _InterfacePrototype.default { } exports.WindowsOverlayDeviceInterface = WindowsOverlayDeviceInterface; -},{"../UI/controllers/HTMLTooltipUIController.js":55,"../deviceApiCalls/__generated__/deviceApiCalls.js":65,"./InterfacePrototype.js":27,"./overlayApi.js":31}],30:[function(require,module,exports){ +},{"../UI/controllers/HTMLTooltipUIController.js":56,"../deviceApiCalls/__generated__/deviceApiCalls.js":66,"./InterfacePrototype.js":27,"./overlayApi.js":31}],30:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -9720,7 +9579,7 @@ function initFormSubmissionsApi(forms, matching) { }); } -},{"../Form/label-util.js":39,"../autofill-utils.js":61}],31:[function(require,module,exports){ +},{"../Form/label-util.js":39,"../autofill-utils.js":62}],31:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -9778,7 +9637,7 @@ function overlayApi(device) { }; } -},{"../deviceApiCalls/__generated__/deviceApiCalls.js":65}],32:[function(require,module,exports){ +},{"../deviceApiCalls/__generated__/deviceApiCalls.js":66}],32:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -10475,6 +10334,7 @@ class Form { if ((0, _autofillUtils.isEventWithinDax)(e, input)) return true; if (this.device.globalConfig.isWindows) return true; const subtype = (0, _matching.getInputSubtype)(input); + const variant = (0, _matching.getInputVariant)(input); const isIncontextSignupAvailable = this.device.inContextSignup?.isAvailable(subtype); if (this.device.globalConfig.isApp) { const mainType = (0, _matching.getInputMainType)(input); @@ -10483,7 +10343,8 @@ class Form { // just showing in-context signup, or with other autofill items. const hasSavedDetails = this.device.settings.canAutofillType({ mainType, - subtype + subtype, + variant }, null); // Don't open the tooltip on input focus whenever it'll only show in-context signup @@ -10608,13 +10469,15 @@ class Form { if (!input) return; const mainType = (0, _matching.getInputMainType)(input); const subtype = (0, _matching.getInputSubtype)(input); + const variant = (0, _matching.getInputVariant)(input); await this.device.settings.populateDataIfNeeded({ mainType, subtype }); if (this.device.settings.canAutofillType({ mainType, - subtype + subtype, + variant }, this.device.inContextSignup)) { // The timeout is needed in case the page shows a cookie prompt with a slight delay setTimeout(() => { @@ -10653,7 +10516,7 @@ class Form { } exports.Form = Form; -},{"../InputTypes/Credentials.js":45,"../autofill-utils.js":61,"../constants.js":64,"./FormAnalyzer.js":34,"./formatters.js":36,"./inputStyles.js":37,"./inputTypeConfig.js":38,"./matching.js":43}],34:[function(require,module,exports){ +},{"../InputTypes/Credentials.js":45,"../autofill-utils.js":62,"../constants.js":65,"./FormAnalyzer.js":34,"./formatters.js":36,"./inputStyles.js":37,"./inputTypeConfig.js":38,"./matching.js":43}],34:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -10694,8 +10557,16 @@ class FormAnalyzer { * @type {string[]} */ this.signals = []; + + // Analyse the input that was passed. This is pretty arbitrary, but historically it's been working nicely. this.evaluateElAttributes(input, 1, true); - form ? this.evaluateForm() : this.evaluatePage(); + + // If we have a meaningful container (a form), check that, otherwise check the whole page + if (form !== input) { + this.evaluateForm(); + } else { + this.evaluatePage(); + } return this; } @@ -10846,6 +10717,7 @@ class FormAnalyzer { }); } evaluatePage() { + this.evaluateUrl(); this.evaluatePageTitle(); this.evaluatePageHeadings(); // Check for submit buttons @@ -10938,13 +10810,17 @@ class FormAnalyzer { this.evaluateElAttributes(this.form); // Check form contents (noisy elements are skipped with the safeUniversalSelector) - this.form.querySelectorAll(this.matching.cssSelector('safeUniversalSelector')).forEach(el => { + const formElements = this.form.querySelectorAll(this.matching.cssSelector('safeUniversalSelector')); + for (let i = 0; i < formElements.length; i++) { + // Safety cutoff to avoid huge DOMs freezing the browser + if (i >= 200) break; + const element = formElements[i]; // Check if element is not hidden. Note that we can't use offsetHeight // nor intersectionObserver, because the element could be outside the // viewport or its parent hidden - const displayValue = window.getComputedStyle(el, null).getPropertyValue('display'); - if (displayValue !== 'none') this.evaluateElement(el); - }); + const displayValue = window.getComputedStyle(element, null).getPropertyValue('display'); + if (displayValue !== 'none') this.evaluateElement(element); + } // A form with many fields is unlikely to be a login form const relevantFields = this.form.querySelectorAll(this.matching.cssSelector('genericTextField')); @@ -11005,7 +10881,7 @@ class FormAnalyzer { } var _default = exports.default = FormAnalyzer; -},{"../autofill-utils.js":61,"../constants.js":64,"./matching-config/__generated__/compiled-matching-config.js":41,"./matching.js":43}],35:[function(require,module,exports){ +},{"../autofill-utils.js":62,"../constants.js":65,"./matching-config/__generated__/compiled-matching-config.js":41,"./matching.js":43}],35:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -12064,16 +11940,18 @@ const canBeInteractedWith = input => !input.readOnly && !input.disabled; */ exports.canBeInteractedWith = canBeInteractedWith; const canBeAutofilled = async (input, device) => { - if (!canBeInteractedWith(input)) return false; const mainType = (0, _matching.getInputMainType)(input); + if (mainType === 'unknown') return false; const subtype = (0, _matching.getInputSubtype)(input); + const variant = (0, _matching.getInputVariant)(input); await device.settings.populateDataIfNeeded({ mainType, subtype }); const canAutofill = device.settings.canAutofillType({ mainType, - subtype + subtype, + variant }, device.inContextSignup); return Boolean(canAutofill); }; @@ -12125,16 +12003,11 @@ const inputTypeConfig = { } = _ref5; const subtype = (0, _matching.getInputSubtype)(input); const variant = (0, _matching.getInputVariant)(input); - - // Check first for password generation and the password.new scoring - if (device.settings.featureToggles.password_generation) { - if (subtype === 'password' && variant === 'new') { - return canBeInteractedWith(input); - } - } - - // if we are on a 'login' page, check if we have data to autofill the field - if (isLogin || isHybrid || variant === 'current') { + if (subtype === 'password' && variant === 'new' || + // New passord field + isLogin || isHybrid || variant === 'current' // Current password field + ) { + // Check feature flags and available input types return canBeAutofilled(input, device); } return false; @@ -12221,7 +12094,7 @@ const isFieldDecorated = input => { }; exports.isFieldDecorated = isFieldDecorated; -},{"../InputTypes/Credentials.js":45,"../InputTypes/CreditCard.js":46,"../InputTypes/Identity.js":47,"../UI/img/ddgPasswordIcon.js":59,"../constants.js":64,"./logo-svg.js":40,"./matching.js":43}],39:[function(require,module,exports){ +},{"../InputTypes/Credentials.js":45,"../InputTypes/CreditCard.js":46,"../InputTypes/Identity.js":47,"../UI/img/ddgPasswordIcon.js":60,"../constants.js":65,"./logo-svg.js":40,"./matching.js":43}],39:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -12514,6 +12387,7 @@ const matchingConfiguration = exports.matchingConfiguration = { selectors: { genericTextField: 'input:not([type=button]):not([type=checkbox]):not([type=color]):not([type=file]):not([type=hidden]):not([type=radio]):not([type=range]):not([type=reset]):not([type=image]):not([type=search]):not([type=submit]):not([type=time]):not([type=url]):not([type=week]):not([name^=fake i]):not([data-description^=dummy i]):not([name*=otp]):not([autocomplete="fake"]):not([placeholder^=search i]):not([type=date]):not([type=datetime-local]):not([type=datetime]):not([type=month])', submitButtonSelector: 'input[type=submit], input[type=button], input[type=image], button:not([role=switch]):not([role=link]), [role=button], a[href="#"][id*=button i], a[href="#"][id*=btn i]', + formInputsSelectorWithoutSelect: 'input:not([type=button]):not([type=checkbox]):not([type=color]):not([type=file]):not([type=hidden]):not([type=radio]):not([type=range]):not([type=reset]):not([type=image]):not([type=search]):not([type=submit]):not([type=time]):not([type=url]):not([type=week]):not([name^=fake i]):not([data-description^=dummy i]):not([name*=otp]):not([autocomplete="fake"]):not([placeholder^=search i]):not([type=date]):not([type=datetime-local]):not([type=datetime]):not([type=month]),[autocomplete=username]', formInputsSelector: 'input:not([type=button]):not([type=checkbox]):not([type=color]):not([type=file]):not([type=hidden]):not([type=radio]):not([type=range]):not([type=reset]):not([type=image]):not([type=search]):not([type=submit]):not([type=time]):not([type=url]):not([type=week]):not([name^=fake i]):not([data-description^=dummy i]):not([name*=otp]):not([autocomplete="fake"]):not([placeholder^=search i]):not([type=date]):not([type=datetime-local]):not([type=datetime]):not([type=month]),[autocomplete=username],select', safeUniversalSelector: '*:not(select):not(option):not(script):not(noscript):not(style):not(br)', emailAddress: 'input:not([type])[name*=email i]:not([placeholder*=search i]):not([placeholder*=filter i]):not([placeholder*=subject i]):not([name*=code i]), input[type=""][name*=email i]:not([placeholder*=search i]):not([placeholder*=filter i]):not([placeholder*=subject i]):not([type=tel]), input[type=text][name*=email i]:not([placeholder*=search i]):not([placeholder*=filter i]):not([placeholder*=subject i]):not([name*=title i]):not([name*=tab i]):not([name*=code i]), input:not([type])[placeholder*=email i]:not([placeholder*=search i]):not([placeholder*=filter i]):not([placeholder*=subject i]):not([name*=code i]), input[type=text][placeholder*=email i]:not([placeholder*=search i]):not([placeholder*=filter i]):not([placeholder*=subject i]), input[type=""][placeholder*=email i]:not([placeholder*=search i]):not([placeholder*=filter i]):not([placeholder*=subject i]), input[type=email], input[type=text][aria-label*=email i]:not([aria-label*=search i]), input:not([type])[aria-label*=email i]:not([aria-label*=search i]), input[name=username][type=email], input[autocomplete=username][type=email], input[autocomplete=username][placeholder*=email i], input[autocomplete=email],input[name="mail_tel" i],input[value=email i]', @@ -12536,9 +12410,9 @@ const matchingConfiguration = exports.matchingConfiguration = { addressProvince: '[name=province i], [name=state i], [autocomplete=address-level1 i]', addressPostalCode: '[name=zip i], [name=zip2 i], [name=postal i], [autocomplete=postal-code i], [autocomplete=zip-code i], [name*=postalCode i], [name*=zipcode i]', addressCountryCode: '[name=country i], [autocomplete=country i], [name*=countryCode i], [name*=country-code i], [name*=countryName i], [name*=country-name i],select.idms-address-country', - birthdayDay: '[name=bday-day i], [name*=birthday_day i], [name*=birthday-day i], [name=date_of_birth_day i], [name=date-of-birth-day i], [name^=birthdate_d i], [name^=birthdate-d i], [aria-label="birthday" i][placeholder="day" i]', - birthdayMonth: '[name=bday-month i], [name*=birthday_month i], [name*=birthday-month i], [name=date_of_birth_month i], [name=date-of-birth-month i], [name^=birthdate_m i], [name^=birthdate-m i], select[name="mm" i]', - birthdayYear: '[name=bday-year i], [name*=birthday_year i], [name*=birthday-year i], [name=date_of_birth_year i], [name=date-of-birth-year i], [name^=birthdate_y i], [name^=birthdate-y i], [aria-label="birthday" i][placeholder="year" i]' + birthdayDay: '[autocomplete=bday-day i], [name=bday-day i], [name*=birthday_day i], [name*=birthday-day i], [name=date_of_birth_day i], [name=date-of-birth-day i], [name^=birthdate_d i], [name^=birthdate-d i], [aria-label="birthday" i][placeholder="day" i]', + birthdayMonth: '[autocomplete=bday-month i], [name=bday-month i], [name*=birthday_month i], [name*=birthday-month i], [name=date_of_birth_month i], [name=date-of-birth-month i], [name^=birthdate_m i], [name^=birthdate-m i], select[name="mm" i]', + birthdayYear: '[autocomplete=bday-year i], [name=bday-year i], [name*=birthday_year i], [name*=birthday-year i], [name=date_of_birth_year i], [name=date-of-birth-year i], [name^=birthdate_y i], [name^=birthdate-y i], [aria-label="birthday" i][placeholder="year" i]' } }, ddgMatcher: { @@ -12652,7 +12526,7 @@ const matchingConfiguration = exports.matchingConfiguration = { match: /sign(ing)?.?[io]n(?!g)|log.?[io]n|log.?out|unsubscri|(forgot(ten)?|reset) (your )?password|password (forgotten|lost)|mfa-submit-form|unlock|logged in as|entra|accedi|accesso|resetta password|password dimenticata|dimenticato la password|recuper[ao] password|(ein|aus)loggen|anmeld(eformular|ung|efeld)|abmelden|passwort (vergessen|verloren)|zugang| zugangsformular|einwahl|inloggen|se (dé)?connecter|(dé)?connexion|récupérer ((mon|ton|votre|le) )?mot de passe|mot de passe (oublié|perdu)|clave(?! su)|olvidó su (clave|contraseña)|.*sesión|conect(arse|ado)|conéctate|acce(de|so)|entrar|logga (in|ut)|avprenumerera|avregistrera|glömt lösenord|återställ lösenord/iu }, signupRegex: { - match: /sign(ing)?.?up|join|\bregist(er|ration)|newsletter|\bsubscri(be|ption)|contact|create|start|enroll|settings|preferences|profile|update|checkout|purchase|buy|order|schedule|estimate|request|new.?customer|(confirm|re.?(type|enter)|repeat) password|password confirm|iscri(viti|zione)|registra(ti|zione)|(?:nuovo|crea(?:zione)?) account|contatt(?:ac)i|sottoscriv|sottoscrizione|compra|acquist(a|o)|ordin[aeio]|richie(?:di|sta)|(?:conferma|ripeti) password|inizia|nuovo cliente|impostazioni|preferenze|profilo|aggiorna|paga|registrier(ung|en)|profil (anlegen|erstellen)| nachrichten|verteiler|neukunde|neuer (kunde|benutzer|nutzer)|passwort wiederholen|anmeldeseite|nieuwsbrief|aanmaken|profiel|s.inscrire|inscription|s.abonner|créer|préférences|profil|mise à jour|payer|ach(eter|at)| nouvel utilisateur|(confirmer|réessayer) ((mon|ton|votre|le) )?mot de passe|regis(trarse|tro)|regístrate|inscr(ibirse|ipción|íbete)|solicitar|crea(r cuenta)?|nueva cuenta|nuevo (cliente|usuario)|preferencias|perfil|lista de correo|registrer(a|ing)|(nytt|öppna) konto|nyhetsbrev|prenumer(era|ation)|kontakt|skapa|starta|inställningar|min (sida|kundvagn)|uppdatera|till kassan|gäst|köp|beställ|schemalägg|ny kund|(repetera|bekräfta) lösenord/iu + match: /sign(ing)?.?up|join|\bregist(er|ration)|newsletter|\bsubscri(be|ption)|contact|create|start|enroll|settings|preferences|profile|update|checkout|purchase|buy|^order|schedule|estimate|request|new.?customer|(confirm|re.?(type|enter)|repeat) password|password confirm|iscri(viti|zione)|registra(ti|zione)|(?:nuovo|crea(?:zione)?) account|contatt(?:ac)i|sottoscriv|sottoscrizione|compra|acquist(a|o)|ordin[aeio]|richie(?:di|sta)|(?:conferma|ripeti) password|inizia|nuovo cliente|impostazioni|preferenze|profilo|aggiorna|paga|registrier(ung|en)|profil (anlegen|erstellen)| nachrichten|verteiler|neukunde|neuer (kunde|benutzer|nutzer)|passwort wiederholen|anmeldeseite|nieuwsbrief|aanmaken|profiel|s.inscrire|inscription|s.abonner|créer|préférences|profil|mise à jour|payer|ach(eter|at)| nouvel utilisateur|(confirmer|réessayer) ((mon|ton|votre|le) )?mot de passe|regis(trarse|tro)|regístrate|inscr(ibirse|ipción|íbete)|solicitar|crea(r cuenta)?|nueva cuenta|nuevo (cliente|usuario)|preferencias|perfil|lista de correo|registrer(a|ing)|(nytt|öppna) konto|nyhetsbrev|prenumer(era|ation)|kontakt|skapa|starta|inställningar|min (sida|kundvagn)|uppdatera|till kassan|gäst|köp|beställ|schemalägg|ny kund|(repetera|bekräfta) lösenord/iu }, conservativeSignupRegex: { match: /sign.?up|join|register|enroll|(create|new).+account|newsletter|subscri(be|ption)|settings|preferences|profile|update|iscri(viti|zione)|registra(ti|zione)|(?:nuovo|crea(?:zione)?) account|contatt(?:ac)?i|sottoscriv|sottoscrizione|impostazioni|preferenze|aggiorna|anmeld(en|ung)|registrier(en|ung)|neukunde|neuer (kunde|benutzer|nutzer)|registreren|eigenschappen|profiel|bijwerken|s.inscrire|inscription|s.abonner|abonnement|préférences|profil|créer un compte|regis(trarse|tro)|regístrate|inscr(ibirse|ipción|íbete)|crea(r cuenta)?|nueva cuenta|nuevo (cliente|usuario)|preferencias|perfil|lista de correo|registrer(a|ing)|(nytt|öppna) konto|nyhetsbrev|prenumer(era|ation)|kontakt|skapa|starta|inställningar|min (sida|kundvagn)|uppdatera/iu @@ -12829,7 +12703,7 @@ function logUnmatched(el, allStrings) { console.groupEnd(); } -},{"../autofill-utils.js":61,"./matching.js":43}],43:[function(require,module,exports){ +},{"../autofill-utils.js":62,"./matching.js":43}],43:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13814,7 +13688,7 @@ function createMatching() { return new Matching(_compiledMatchingConfig.matchingConfiguration); } -},{"../autofill-utils.js":61,"../constants.js":64,"./label-util.js":39,"./matching-config/__generated__/compiled-matching-config.js":41,"./matching-utils.js":42}],44:[function(require,module,exports){ +},{"../autofill-utils.js":62,"../constants.js":65,"./label-util.js":39,"./matching-config/__generated__/compiled-matching-config.js":41,"./matching-utils.js":42}],44:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13946,7 +13820,7 @@ class InContextSignup { } exports.InContextSignup = InContextSignup; -},{"./autofill-utils.js":61,"./deviceApiCalls/__generated__/deviceApiCalls.js":65}],45:[function(require,module,exports){ +},{"./autofill-utils.js":62,"./deviceApiCalls/__generated__/deviceApiCalls.js":66}],45:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -14093,7 +13967,7 @@ function createCredentialsTooltipItem(data) { return new CredentialsTooltipItem(data); } -},{"../autofill-utils.js":61}],46:[function(require,module,exports){ +},{"../autofill-utils.js":62}],46:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -14358,10 +14232,10 @@ class DefaultScanner { if (this.device.globalConfig.isDDGDomain) { return this; } - if ('matches' in context && context.matches?.(this.matching.cssSelector('formInputsSelector'))) { + if ('matches' in context && context.matches?.(this.matching.cssSelector('formInputsSelectorWithoutSelect'))) { this.addInput(context); } else { - const inputs = context.querySelectorAll(this.matching.cssSelector('formInputsSelector')); + const inputs = context.querySelectorAll(this.matching.cssSelector('formInputsSelectorWithoutSelect')); if (inputs.length > this.options.maxInputsPerPage) { this.stopScanner(`Too many input fields in the given context (${inputs.length}), stop scanning`, context); return this; @@ -14613,7 +14487,7 @@ function createScanner(device, scannerOptions) { }); } -},{"./Form/Form.js":33,"./Form/matching.js":43,"./autofill-utils.js":61,"./constants.js":64,"./deviceApiCalls/__generated__/deviceApiCalls.js":65}],50:[function(require,module,exports){ +},{"./Form/Form.js":33,"./Form/matching.js":43,"./autofill-utils.js":62,"./constants.js":65,"./deviceApiCalls/__generated__/deviceApiCalls.js":66}],50:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -14624,7 +14498,6 @@ var _index = require("../packages/device-api/index.js"); var _deviceApiCalls = require("./deviceApiCalls/__generated__/deviceApiCalls.js"); var _validatorsZod = require("./deviceApiCalls/__generated__/validators.zod.js"); var _autofillUtils = require("./autofill-utils.js"); -var _appleUtils = require("@duckduckgo/content-scope-scripts/src/apple-utils"); /** * Some Type helpers to prevent duplication * @typedef {import("./deviceApiCalls/__generated__/validators-ts").AutofillFeatureToggles} AutofillFeatureToggles @@ -14701,7 +14574,7 @@ class Settings { async getEnabled() { try { const runtimeConfig = await this._getRuntimeConfiguration(); - const enabled = (0, _autofillUtils.autofillEnabled)(runtimeConfig, _appleUtils.processConfig); + const enabled = (0, _autofillUtils.autofillEnabled)(runtimeConfig); return enabled; } catch (e) { // these are the fallbacks for when a platform hasn't implemented the calls above. (like on android) @@ -14840,6 +14713,7 @@ class Settings { * @param {{ * mainType: SupportedMainTypes * subtype: import('./Form/matching.js').SupportedSubTypes | "unknown" + * variant: import('./Form/matching.js').SupportedVariants | "" * }} types * @param {import("./InContextSignup.js").InContextSignup?} inContextSignup * @returns {boolean} @@ -14847,7 +14721,8 @@ class Settings { canAutofillType(_ref3, inContextSignup) { let { mainType, - subtype + subtype, + variant } = _ref3; if (this.isTypeUnavailable({ mainType, @@ -14862,6 +14737,11 @@ class Settings { if (inContextSignup?.isAvailable(subtype)) { return true; } + + // Check for password generation and the password.new scoring + if (subtype === 'password' && variant === 'new' && this.featureToggles.password_generation) { + return true; + } if (subtype === 'fullName') { return Boolean(this.availableInputTypes.identities?.firstName || this.availableInputTypes.identities?.lastName); } @@ -14962,7 +14842,97 @@ class Settings { } exports.Settings = Settings; -},{"../packages/device-api/index.js":12,"./autofill-utils.js":61,"./deviceApiCalls/__generated__/deviceApiCalls.js":65,"./deviceApiCalls/__generated__/validators.zod.js":66,"@duckduckgo/content-scope-scripts/src/apple-utils":1}],51:[function(require,module,exports){ +},{"../packages/device-api/index.js":12,"./autofill-utils.js":62,"./deviceApiCalls/__generated__/deviceApiCalls.js":66,"./deviceApiCalls/__generated__/validators.zod.js":67}],51:[function(require,module,exports){ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ThirdPartyProvider = void 0; +var _deviceApiCalls = require("./deviceApiCalls/__generated__/deviceApiCalls.js"); +var _validatorsZod = require("./deviceApiCalls/__generated__/validators.zod.js"); +var _matching = require("./Form/matching.js"); +var _index = require("../packages/device-api/index.js"); +class ThirdPartyProvider { + /** + * @param {import("./DeviceInterface/InterfacePrototype").default} device + */ + constructor(device) { + this.device = device; + } + init() { + if (this.device.settings.featureToggles.third_party_credentials_provider) { + if (this.device.globalConfig.hasModernWebkitAPI) { + Object.defineProperty(window, 'providerStatusUpdated', { + enumerable: false, + configurable: false, + writable: false, + value: data => { + this.providerStatusUpdated(data); + } + }); + } else { + // On Catalina we poll the native layer + setTimeout(() => this._pollForUpdatesToCredentialsProvider(), 2000); + } + } + } + async askToUnlockProvider() { + const response = await this.device.deviceApi.request(new _deviceApiCalls.AskToUnlockProviderCall(null)); + this.providerStatusUpdated(response); + } + + /** + * Called by the native layer on all tabs when the provider status is updated + * @param {import("./deviceApiCalls/__generated__/validators-ts").ProviderStatusUpdated} data + */ + providerStatusUpdated(data) { + try { + const { + credentials, + availableInputTypes + } = (0, _index.validate)(data, _validatorsZod.providerStatusUpdatedSchema); + + // Update local settings and data + this.device.settings.setAvailableInputTypes(availableInputTypes); + this.device.storeLocalCredentials(credentials); + + // rerender the tooltip + this.device.uiController?.updateItems(credentials); + if (!this.device.globalConfig.isTopFrame) { + // If the tooltip is open on an autofill type that's not available, close it + const currentInputSubtype = (0, _matching.getSubtypeFromType)(this.device.getCurrentInputType()); + if (!availableInputTypes.credentials?.[currentInputSubtype]) { + this.device.removeTooltip(); + } + // Redecorate fields according to the new types + this.device.scanner.forms.forEach(form => form.recategorizeAllInputs()); + } + } catch (e) { + if (this.device.globalConfig.isDDGTestMode) { + console.log('isDDGTestMode: providerStatusUpdated error: ❌', e); + } + } + } + + // Only used on Catalina + async _pollForUpdatesToCredentialsProvider() { + try { + const response = await this.device.deviceApi.request(new _deviceApiCalls.CheckCredentialsProviderStatusCall(null)); + if (response.availableInputTypes.credentialsProviderStatus !== this.device.settings.availableInputTypes.credentialsProviderStatus) { + this.providerStatusUpdated(response); + } + setTimeout(() => this._pollForUpdatesToCredentialsProvider(), 2000); + } catch (e) { + if (this.device.globalConfig.isDDGTestMode) { + console.log('isDDGTestMode: _pollForUpdatesToCredentialsProvider: ❌', e); + } + } + } +} +exports.ThirdPartyProvider = ThirdPartyProvider; + +},{"../packages/device-api/index.js":12,"./Form/matching.js":43,"./deviceApiCalls/__generated__/deviceApiCalls.js":66,"./deviceApiCalls/__generated__/validators.zod.js":67}],52:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -15090,7 +15060,7 @@ ${css} } var _default = exports.default = DataHTMLTooltip; -},{"../InputTypes/Credentials.js":45,"../autofill-utils.js":61,"./HTMLTooltip.js":54}],52:[function(require,module,exports){ +},{"../InputTypes/Credentials.js":45,"../autofill-utils.js":62,"./HTMLTooltip.js":55}],53:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -15168,7 +15138,7 @@ ${this.options.css} } var _default = exports.default = EmailHTMLTooltip; -},{"../autofill-utils.js":61,"./HTMLTooltip.js":54}],53:[function(require,module,exports){ +},{"../autofill-utils.js":62,"./HTMLTooltip.js":55}],54:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -15224,7 +15194,7 @@ ${this.options.css} } var _default = exports.default = EmailSignupHTMLTooltip; -},{"./HTMLTooltip.js":54}],54:[function(require,module,exports){ +},{"./HTMLTooltip.js":55}],55:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -15612,7 +15582,7 @@ class HTMLTooltip { exports.HTMLTooltip = HTMLTooltip; var _default = exports.default = HTMLTooltip; -},{"../Form/matching.js":43,"../autofill-utils.js":61,"./styles/styles.js":60}],55:[function(require,module,exports){ +},{"../Form/matching.js":43,"../autofill-utils.js":62,"./styles/styles.js":61}],56:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -15969,7 +15939,7 @@ class HTMLTooltipUIController extends _UIController.UIController { } exports.HTMLTooltipUIController = HTMLTooltipUIController; -},{"../../Form/inputTypeConfig.js":38,"../../Form/matching.js":43,"../../autofill-utils.js":61,"../DataHTMLTooltip.js":51,"../EmailHTMLTooltip.js":52,"../EmailSignupHTMLTooltip.js":53,"../HTMLTooltip.js":54,"./UIController.js":58}],56:[function(require,module,exports){ +},{"../../Form/inputTypeConfig.js":38,"../../Form/matching.js":43,"../../autofill-utils.js":62,"../DataHTMLTooltip.js":52,"../EmailHTMLTooltip.js":53,"../EmailSignupHTMLTooltip.js":54,"../HTMLTooltip.js":55,"./UIController.js":59}],57:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -16131,7 +16101,7 @@ class NativeUIController extends _UIController.UIController { } exports.NativeUIController = NativeUIController; -},{"../../Form/matching.js":43,"../../InputTypes/Credentials.js":45,"../../deviceApiCalls/__generated__/deviceApiCalls.js":65,"./UIController.js":58}],57:[function(require,module,exports){ +},{"../../Form/matching.js":43,"../../InputTypes/Credentials.js":45,"../../deviceApiCalls/__generated__/deviceApiCalls.js":66,"./UIController.js":59}],58:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -16368,7 +16338,7 @@ class OverlayUIController extends _UIController.UIController { } exports.OverlayUIController = OverlayUIController; -},{"../../Form/matching.js":43,"./UIController.js":58}],58:[function(require,module,exports){ +},{"../../Form/matching.js":43,"./UIController.js":59}],59:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -16452,7 +16422,7 @@ class UIController { } exports.UIController = UIController; -},{}],59:[function(require,module,exports){ +},{}],60:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -16469,16 +16439,16 @@ const ddgCcIconBase = exports.ddgCcIconBase = ' const ddgCcIconFilled = exports.ddgCcIconFilled = ''; const ddgIdentityIconBase = exports.ddgIdentityIconBase = ``; -},{}],60:[function(require,module,exports){ +},{}],61:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.CSS_STYLES = void 0; -const CSS_STYLES = exports.CSS_STYLES = ":root {\n color-scheme: light dark;\n}\n\n.wrapper *, .wrapper *::before, .wrapper *::after {\n box-sizing: border-box;\n}\n.wrapper {\n position: fixed;\n top: 0;\n left: 0;\n padding: 0;\n font-family: 'DDG_ProximaNova', 'Proxima Nova', system-ui, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu',\n 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;\n -webkit-font-smoothing: antialiased;\n z-index: 2147483647;\n}\n.wrapper--data {\n font-family: 'SF Pro Text', system-ui, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu',\n 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;\n}\n:not(.top-autofill) .tooltip {\n position: absolute;\n width: 300px;\n max-width: calc(100vw - 25px);\n transform: translate(-1000px, -1000px);\n z-index: 2147483647;\n}\n.tooltip--data, #topAutofill {\n background-color: rgba(242, 240, 240, 1);\n -webkit-backdrop-filter: blur(40px);\n backdrop-filter: blur(40px);\n}\n@media (prefers-color-scheme: dark) {\n .tooltip--data, #topAutofill {\n background: rgb(100, 98, 102, .9);\n }\n}\n.tooltip--data {\n padding: 6px;\n font-size: 13px;\n line-height: 14px;\n width: 315px;\n max-height: 290px;\n overflow-y: auto;\n}\n.top-autofill .tooltip--data {\n min-height: 100vh;\n}\n.tooltip--data.tooltip--incontext-signup {\n width: 360px;\n}\n:not(.top-autofill) .tooltip--data {\n top: 100%;\n left: 100%;\n border: 0.5px solid rgba(255, 255, 255, 0.2);\n border-radius: 6px;\n box-shadow: 0 10px 20px rgba(0, 0, 0, 0.32);\n}\n@media (prefers-color-scheme: dark) {\n :not(.top-autofill) .tooltip--data {\n border: 1px solid rgba(255, 255, 255, 0.2);\n }\n}\n:not(.top-autofill) .tooltip--email {\n top: calc(100% + 6px);\n right: calc(100% - 48px);\n padding: 8px;\n border: 1px solid #D0D0D0;\n border-radius: 10px;\n background-color: #FFFFFF;\n font-size: 14px;\n line-height: 1.3;\n color: #333333;\n box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);\n}\n.tooltip--email__caret {\n position: absolute;\n transform: translate(-1000px, -1000px);\n z-index: 2147483647;\n}\n.tooltip--email__caret::before,\n.tooltip--email__caret::after {\n content: \"\";\n width: 0;\n height: 0;\n border-left: 10px solid transparent;\n border-right: 10px solid transparent;\n display: block;\n border-bottom: 8px solid #D0D0D0;\n position: absolute;\n right: -28px;\n}\n.tooltip--email__caret::before {\n border-bottom-color: #D0D0D0;\n top: -1px;\n}\n.tooltip--email__caret::after {\n border-bottom-color: #FFFFFF;\n top: 0px;\n}\n\n/* Buttons */\n.tooltip__button {\n display: flex;\n width: 100%;\n padding: 8px 8px 8px 0px;\n font-family: inherit;\n color: inherit;\n background: transparent;\n border: none;\n border-radius: 6px;\n}\n.tooltip__button.currentFocus,\n.wrapper:not(.top-autofill) .tooltip__button:hover {\n background-color: #3969EF;\n color: #FFFFFF;\n}\n\n/* Data autofill tooltip specific */\n.tooltip__button--data {\n position: relative;\n min-height: 48px;\n flex-direction: row;\n justify-content: flex-start;\n font-size: inherit;\n font-weight: 500;\n line-height: 16px;\n text-align: left;\n border-radius: 3px;\n}\n.tooltip--data__item-container {\n max-height: 220px;\n overflow: auto;\n}\n.tooltip__button--data:first-child {\n margin-top: 0;\n}\n.tooltip__button--data:last-child {\n margin-bottom: 0;\n}\n.tooltip__button--data::before {\n content: '';\n flex-shrink: 0;\n display: block;\n width: 32px;\n height: 32px;\n margin: 0 8px;\n background-size: 20px 20px;\n background-repeat: no-repeat;\n background-position: center center;\n}\n#provider_locked::after {\n position: absolute;\n content: '';\n flex-shrink: 0;\n display: block;\n width: 32px;\n height: 32px;\n margin: 0 8px;\n background-size: 11px 13px;\n background-repeat: no-repeat;\n background-position: right bottom;\n}\n.tooltip__button--data.currentFocus:not(.tooltip__button--data--bitwarden)::before,\n.wrapper:not(.top-autofill) .tooltip__button--data:not(.tooltip__button--data--bitwarden):hover::before {\n filter: invert(100%);\n}\n@media (prefers-color-scheme: dark) {\n .tooltip__button--data:not(.tooltip__button--data--bitwarden)::before,\n .tooltip__button--data:not(.tooltip__button--data--bitwarden)::before {\n filter: invert(100%);\n opacity: .9;\n }\n}\n.tooltip__button__text-container {\n margin: auto 0;\n}\n.label {\n display: block;\n font-weight: 400;\n letter-spacing: -0.25px;\n color: rgba(0,0,0,.8);\n font-size: 13px;\n line-height: 1;\n}\n.label + .label {\n margin-top: 2px;\n}\n.label.label--medium {\n font-weight: 500;\n letter-spacing: -0.25px;\n color: rgba(0,0,0,.9);\n}\n.label.label--small {\n font-size: 11px;\n font-weight: 400;\n letter-spacing: 0.06px;\n color: rgba(0,0,0,0.6);\n}\n@media (prefers-color-scheme: dark) {\n .tooltip--data .label {\n color: #ffffff;\n }\n .tooltip--data .label--medium {\n color: #ffffff;\n }\n .tooltip--data .label--small {\n color: #cdcdcd;\n }\n}\n.tooltip__button.currentFocus .label,\n.wrapper:not(.top-autofill) .tooltip__button:hover .label {\n color: #FFFFFF;\n}\n\n.tooltip__button--manage {\n font-size: 13px;\n padding: 5px 9px;\n border-radius: 3px;\n margin: 0;\n}\n\n/* Icons */\n.tooltip__button--data--credentials::before,\n.tooltip__button--data--credentials__current::before {\n background-size: 28px 28px;\n background-image: url('');\n}\n.tooltip__button--data--credentials__new::before {\n background-size: 28px 28px;\n background-image: url('');\n}\n.tooltip__button--data--creditCards::before {\n background-image: url('');\n}\n.tooltip__button--data--identities::before {\n background-image: url('');\n}\n.tooltip__button--data--credentials.tooltip__button--data--bitwarden::before {\n background-image: url('');\n}\n#provider_locked:after {\n background-image: url('');\n}\n\nhr {\n display: block;\n margin: 5px 9px;\n border: none; /* reset the border */\n border-top: 1px solid rgba(0,0,0,.1);\n}\n\nhr:first-child {\n display: none;\n}\n\n@media (prefers-color-scheme: dark) {\n hr {\n border-top: 1px solid rgba(255,255,255,.2);\n }\n}\n\n#privateAddress {\n align-items: flex-start;\n}\n#personalAddress::before,\n#privateAddress::before,\n#incontextSignup::before,\n#personalAddress.currentFocus::before,\n#personalAddress:hover::before,\n#privateAddress.currentFocus::before,\n#privateAddress:hover::before {\n filter: none;\n /* This is the same icon as `daxBase64` in `src/Form/logo-svg.js` */\n background-image: url('');\n}\n\n/* Email tooltip specific */\n.tooltip__button--email {\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n font-size: 14px;\n padding: 4px 8px;\n}\n.tooltip__button--email__primary-text {\n font-weight: bold;\n}\n.tooltip__button--email__secondary-text {\n font-size: 12px;\n}\n\n/* Email Protection signup notice */\n:not(.top-autofill) .tooltip--email-signup {\n text-align: left;\n color: #222222;\n padding: 16px 20px;\n width: 380px;\n}\n\n.tooltip--email-signup h1 {\n font-weight: 700;\n font-size: 16px;\n line-height: 1.5;\n margin: 0;\n}\n\n.tooltip--email-signup p {\n font-weight: 400;\n font-size: 14px;\n line-height: 1.4;\n}\n\n.notice-controls {\n display: flex;\n}\n\n.tooltip--email-signup .notice-controls > * {\n border-radius: 8px;\n border: 0;\n cursor: pointer;\n display: inline-block;\n font-family: inherit;\n font-style: normal;\n font-weight: bold;\n padding: 8px 12px;\n text-decoration: none;\n}\n\n.notice-controls .ghost {\n margin-left: 1rem;\n}\n\n.tooltip--email-signup a.primary {\n background: #3969EF;\n color: #fff;\n}\n\n.tooltip--email-signup a.primary:hover,\n.tooltip--email-signup a.primary:focus {\n background: #2b55ca;\n}\n\n.tooltip--email-signup a.primary:active {\n background: #1e42a4;\n}\n\n.tooltip--email-signup button.ghost {\n background: transparent;\n color: #3969EF;\n}\n\n.tooltip--email-signup button.ghost:hover,\n.tooltip--email-signup button.ghost:focus {\n background-color: rgba(0, 0, 0, 0.06);\n color: #2b55ca;\n}\n\n.tooltip--email-signup button.ghost:active {\n background-color: rgba(0, 0, 0, 0.12);\n color: #1e42a4;\n}\n\n.tooltip--email-signup button.close-tooltip {\n background-color: transparent;\n background-image: url();\n background-position: center center;\n background-repeat: no-repeat;\n border: 0;\n cursor: pointer;\n padding: 16px;\n position: absolute;\n right: 12px;\n top: 12px;\n}\n"; +const CSS_STYLES = exports.CSS_STYLES = ":root {\n color-scheme: light dark;\n}\n\n.wrapper *, .wrapper *::before, .wrapper *::after {\n box-sizing: border-box;\n}\n.wrapper {\n position: fixed;\n top: 0;\n left: 0;\n padding: 0;\n font-family: 'DDG_ProximaNova', 'Proxima Nova', system-ui, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu',\n 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;\n -webkit-font-smoothing: antialiased;\n z-index: 2147483647;\n}\n.wrapper--data {\n font-family: 'SF Pro Text', system-ui, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu',\n 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;\n}\n:not(.top-autofill) .tooltip {\n position: absolute;\n width: 300px;\n max-width: calc(100vw - 25px);\n transform: translate(-1000px, -1000px);\n z-index: 2147483647;\n}\n.tooltip--data, #topAutofill {\n background-color: rgba(242, 240, 240, 1);\n -webkit-backdrop-filter: blur(40px);\n backdrop-filter: blur(40px);\n}\n@media (prefers-color-scheme: dark) {\n .tooltip--data, #topAutofill {\n background: rgb(100, 98, 102, .9);\n }\n}\n.tooltip--data {\n padding: 6px;\n font-size: 13px;\n line-height: 14px;\n width: 315px;\n max-height: 290px;\n overflow-y: auto;\n}\n.top-autofill .tooltip--data {\n min-height: 100vh;\n}\n.tooltip--data.tooltip--incontext-signup {\n width: 360px;\n}\n:not(.top-autofill) .tooltip--data {\n top: 100%;\n left: 100%;\n border: 0.5px solid rgba(255, 255, 255, 0.2);\n border-radius: 6px;\n box-shadow: 0 10px 20px rgba(0, 0, 0, 0.32);\n}\n@media (prefers-color-scheme: dark) {\n :not(.top-autofill) .tooltip--data {\n border: 1px solid rgba(255, 255, 255, 0.2);\n }\n}\n:not(.top-autofill) .tooltip--email {\n top: calc(100% + 6px);\n right: calc(100% - 48px);\n padding: 8px;\n border: 1px solid #D0D0D0;\n border-radius: 10px;\n background-color: #FFFFFF;\n font-size: 14px;\n line-height: 1.3;\n color: #333333;\n box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);\n}\n.tooltip--email__caret {\n position: absolute;\n transform: translate(-1000px, -1000px);\n z-index: 2147483647;\n}\n.tooltip--email__caret::before,\n.tooltip--email__caret::after {\n content: \"\";\n width: 0;\n height: 0;\n border-left: 10px solid transparent;\n border-right: 10px solid transparent;\n display: block;\n border-bottom: 8px solid #D0D0D0;\n position: absolute;\n right: -28px;\n}\n.tooltip--email__caret::before {\n border-bottom-color: #D0D0D0;\n top: -1px;\n}\n.tooltip--email__caret::after {\n border-bottom-color: #FFFFFF;\n top: 0px;\n}\n\n/* Buttons */\n.tooltip__button {\n display: flex;\n width: 100%;\n padding: 8px 8px 8px 0px;\n font-family: inherit;\n color: inherit;\n background: transparent;\n border: none;\n border-radius: 6px;\n}\n.tooltip__button.currentFocus,\n.wrapper:not(.top-autofill) .tooltip__button:hover {\n background-color: #3969EF;\n color: #FFFFFF;\n}\n\n/* Data autofill tooltip specific */\n.tooltip__button--data {\n position: relative;\n min-height: 48px;\n flex-direction: row;\n justify-content: flex-start;\n font-size: inherit;\n font-weight: 500;\n line-height: 16px;\n text-align: left;\n border-radius: 3px;\n}\n.tooltip--data__item-container {\n max-height: 220px;\n overflow: auto;\n}\n.tooltip__button--data:first-child {\n margin-top: 0;\n}\n.tooltip__button--data:last-child {\n margin-bottom: 0;\n}\n.tooltip__button--data::before {\n content: '';\n flex-shrink: 0;\n display: block;\n width: 32px;\n height: 32px;\n margin: 0 8px;\n background-size: 20px 20px;\n background-repeat: no-repeat;\n background-position: center center;\n}\n#provider_locked::after {\n position: absolute;\n content: '';\n flex-shrink: 0;\n display: block;\n width: 32px;\n height: 32px;\n margin: 0 8px;\n background-size: 11px 13px;\n background-repeat: no-repeat;\n background-position: right bottom;\n}\n.tooltip__button--data.currentFocus:not(.tooltip__button--data--bitwarden)::before,\n.wrapper:not(.top-autofill) .tooltip__button--data:not(.tooltip__button--data--bitwarden):hover::before {\n filter: invert(100%);\n}\n@media (prefers-color-scheme: dark) {\n .tooltip__button--data:not(.tooltip__button--data--bitwarden)::before,\n .tooltip__button--data:not(.tooltip__button--data--bitwarden)::before {\n filter: invert(100%);\n opacity: .9;\n }\n}\n.tooltip__button__text-container {\n margin: auto 0;\n}\n.label {\n display: block;\n font-weight: 400;\n letter-spacing: -0.25px;\n color: rgba(0,0,0,.8);\n font-size: 13px;\n line-height: 1;\n}\n.label + .label {\n margin-top: 2px;\n}\n.label.label--medium {\n font-weight: 500;\n letter-spacing: -0.25px;\n color: rgba(0,0,0,.9);\n}\n.label.label--small {\n font-size: 11px;\n font-weight: 400;\n letter-spacing: 0.06px;\n color: rgba(0,0,0,0.6);\n}\n@media (prefers-color-scheme: dark) {\n .tooltip--data .label {\n color: #ffffff;\n }\n .tooltip--data .label--medium {\n color: #ffffff;\n }\n .tooltip--data .label--small {\n color: #cdcdcd;\n }\n}\n.tooltip__button.currentFocus .label,\n.wrapper:not(.top-autofill) .tooltip__button:hover .label {\n color: #FFFFFF;\n}\n\n.tooltip__button--manage {\n font-size: 13px;\n padding: 5px 9px;\n border-radius: 3px;\n margin: 0;\n}\n\n/* Icons */\n.tooltip__button--data--credentials::before,\n.tooltip__button--data--credentials__current::before {\n background-size: 28px 28px;\n background-image: url('');\n}\n.tooltip__button--data--credentials__new::before {\n background-size: 28px 28px;\n background-image: url('');\n}\n.tooltip__button--data--creditCards::before {\n background-image: url('');\n}\n.tooltip__button--data--identities::before {\n background-image: url('');\n}\n.tooltip__button--data--credentials.tooltip__button--data--bitwarden::before,\n.tooltip__button--data--credentials__current.tooltip__button--data--bitwarden::before {\n background-image: url('');\n}\n#provider_locked:after {\n background-image: url('');\n}\n\nhr {\n display: block;\n margin: 5px 9px;\n border: none; /* reset the border */\n border-top: 1px solid rgba(0,0,0,.1);\n}\n\nhr:first-child {\n display: none;\n}\n\n@media (prefers-color-scheme: dark) {\n hr {\n border-top: 1px solid rgba(255,255,255,.2);\n }\n}\n\n#privateAddress {\n align-items: flex-start;\n}\n#personalAddress::before,\n#privateAddress::before,\n#incontextSignup::before,\n#personalAddress.currentFocus::before,\n#personalAddress:hover::before,\n#privateAddress.currentFocus::before,\n#privateAddress:hover::before {\n filter: none;\n /* This is the same icon as `daxBase64` in `src/Form/logo-svg.js` */\n background-image: url('');\n}\n\n/* Email tooltip specific */\n.tooltip__button--email {\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n font-size: 14px;\n padding: 4px 8px;\n}\n.tooltip__button--email__primary-text {\n font-weight: bold;\n}\n.tooltip__button--email__secondary-text {\n font-size: 12px;\n}\n\n/* Email Protection signup notice */\n:not(.top-autofill) .tooltip--email-signup {\n text-align: left;\n color: #222222;\n padding: 16px 20px;\n width: 380px;\n}\n\n.tooltip--email-signup h1 {\n font-weight: 700;\n font-size: 16px;\n line-height: 1.5;\n margin: 0;\n}\n\n.tooltip--email-signup p {\n font-weight: 400;\n font-size: 14px;\n line-height: 1.4;\n}\n\n.notice-controls {\n display: flex;\n}\n\n.tooltip--email-signup .notice-controls > * {\n border-radius: 8px;\n border: 0;\n cursor: pointer;\n display: inline-block;\n font-family: inherit;\n font-style: normal;\n font-weight: bold;\n padding: 8px 12px;\n text-decoration: none;\n}\n\n.notice-controls .ghost {\n margin-left: 1rem;\n}\n\n.tooltip--email-signup a.primary {\n background: #3969EF;\n color: #fff;\n}\n\n.tooltip--email-signup a.primary:hover,\n.tooltip--email-signup a.primary:focus {\n background: #2b55ca;\n}\n\n.tooltip--email-signup a.primary:active {\n background: #1e42a4;\n}\n\n.tooltip--email-signup button.ghost {\n background: transparent;\n color: #3969EF;\n}\n\n.tooltip--email-signup button.ghost:hover,\n.tooltip--email-signup button.ghost:focus {\n background-color: rgba(0, 0, 0, 0.06);\n color: #2b55ca;\n}\n\n.tooltip--email-signup button.ghost:active {\n background-color: rgba(0, 0, 0, 0.12);\n color: #1e42a4;\n}\n\n.tooltip--email-signup button.close-tooltip {\n background-color: transparent;\n background-image: url();\n background-position: center center;\n background-repeat: no-repeat;\n border: 0;\n cursor: pointer;\n padding: 16px;\n position: absolute;\n right: 12px;\n top: 12px;\n}\n"; -},{}],61:[function(require,module,exports){ +},{}],62:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -16507,6 +16477,7 @@ exports.wasAutofilledByChrome = void 0; exports.whenIdle = whenIdle; var _matching = require("./Form/matching.js"); var _constants = require("./constants.js"); +var _appleUtils = require("@duckduckgo/content-scope-scripts/src/apple-utils"); const SIGN_IN_MSG = exports.SIGN_IN_MSG = { signMeIn: true }; @@ -16541,15 +16512,19 @@ const sendAndWaitForAnswer = (msgOrFn, expectedResponse) => { /** * @param {Pick} globalConfig - * @param [processConfig] * @return {boolean} */ exports.sendAndWaitForAnswer = sendAndWaitForAnswer; -const autofillEnabled = (globalConfig, processConfig) => { +const autofillEnabled = globalConfig => { if (!globalConfig.contentScope) { // Return enabled for platforms that haven't implemented the config yet return true; } + // already processed? this handles an edgecase in the extension where the config is already processed + if ('site' in globalConfig.contentScope) { + const enabled = isAutofillEnabledFromProcessedConfig(globalConfig.contentScope); + return enabled; + } const { contentScope, userUnprotectedDomains, @@ -16557,7 +16532,7 @@ const autofillEnabled = (globalConfig, processConfig) => { } = globalConfig; // Check config on Apple platforms - const processedConfig = processConfig(contentScope, userUnprotectedDomains, userPreferences); + const processedConfig = (0, _appleUtils.processConfig)(contentScope, userUnprotectedDomains, userPreferences); return isAutofillEnabledFromProcessedConfig(processedConfig); }; exports.autofillEnabled = autofillEnabled; @@ -17092,7 +17067,7 @@ function getActiveElement() { return innerActiveElement; } -},{"./Form/matching.js":43,"./constants.js":64}],62:[function(require,module,exports){ +},{"./Form/matching.js":43,"./constants.js":65,"@duckduckgo/content-scope-scripts/src/apple-utils":1}],63:[function(require,module,exports){ "use strict"; require("./requestIdleCallback.js"); @@ -17123,7 +17098,7 @@ var _autofillUtils = require("./autofill-utils.js"); } })(); -},{"./DeviceInterface.js":22,"./autofill-utils.js":61,"./requestIdleCallback.js":73}],63:[function(require,module,exports){ +},{"./DeviceInterface.js":22,"./autofill-utils.js":62,"./requestIdleCallback.js":74}],64:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -17176,15 +17151,12 @@ function createGlobalConfig(overrides) { // The native layer will inject a randomised secret here and use it to verify the origin let secret = 'PLACEHOLDER_SECRET'; - /** - * The user agent check will not be needed here once `android` supports `userPreferences?.platform.name` - */ // @ts-ignore - const isAndroid = userPreferences?.platform.name === 'android' || /Android.*DuckDuckGo\/\d/i.test(window.navigator.userAgent); + const isAndroid = userPreferences?.platform.name === 'android'; // @ts-ignore - const isDDGApp = ['ios', 'android', 'macos', 'windows'].includes(userPreferences?.platform.name) || isAndroid || isWindows; + const isDDGApp = ['ios', 'android', 'macos', 'windows'].includes(userPreferences?.platform.name) || isWindows; // @ts-ignore - const isMobileApp = ['ios', 'android'].includes(userPreferences?.platform.name) || isAndroid; + const isMobileApp = ['ios', 'android'].includes(userPreferences?.platform.name); const isFirefox = navigator.userAgent.includes('Firefox'); const isDDGDomain = Boolean(window.location.href.match(DDG_DOMAIN_REGEX)); const isExtension = false; @@ -17212,7 +17184,7 @@ function createGlobalConfig(overrides) { return config; } -},{}],64:[function(require,module,exports){ +},{}],65:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -17229,7 +17201,7 @@ const constants = exports.constants = { MAX_FORM_RESCANS: 50 }; -},{}],65:[function(require,module,exports){ +},{}],66:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -17475,7 +17447,7 @@ class ShowInContextEmailProtectionSignupPromptCall extends _deviceApi.DeviceApiC } exports.ShowInContextEmailProtectionSignupPromptCall = ShowInContextEmailProtectionSignupPromptCall; -},{"../../../packages/device-api":12,"./validators.zod.js":66}],66:[function(require,module,exports){ +},{"../../../packages/device-api":12,"./validators.zod.js":67}],67:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -17876,7 +17848,7 @@ const apiSchema = exports.apiSchema = _zod.z.object({ })).optional() }); -},{"zod":9}],67:[function(require,module,exports){ +},{"zod":9}],68:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -17902,7 +17874,7 @@ class GetAlias extends _index.DeviceApiCall { } exports.GetAlias = GetAlias; -},{"../../packages/device-api/index.js":12,"./__generated__/validators.zod.js":66}],68:[function(require,module,exports){ +},{"../../packages/device-api/index.js":12,"./__generated__/validators.zod.js":67}],69:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -18045,7 +18017,7 @@ function androidSpecificAvailableInputTypes(globalConfig) { }; } -},{"../../../packages/device-api/index.js":12,"../__generated__/deviceApiCalls.js":65}],69:[function(require,module,exports){ +},{"../../../packages/device-api/index.js":12,"../__generated__/deviceApiCalls.js":66}],70:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -18088,7 +18060,7 @@ class AppleTransport extends _index.DeviceApiTransport { } exports.AppleTransport = AppleTransport; -},{"../../../packages/device-api/index.js":12,"../../../packages/messaging/messaging.js":15}],70:[function(require,module,exports){ +},{"../../../packages/device-api/index.js":12,"../../../packages/messaging/messaging.js":15}],71:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -18162,7 +18134,7 @@ async function extensionSpecificRuntimeConfiguration(deviceApi) { } }, // @ts-ignore - userUnprotectedDomains: deviceApi.config?.userUnprotectedDomains + userUnprotectedDomains: deviceApi.config?.userUnprotectedDomains || [] } }; } @@ -18240,7 +18212,7 @@ async function extensionSpecificSetIncontextSignupPermanentlyDismissedAtCall(par }); } -},{"../../../packages/device-api/index.js":12,"../../Settings.js":50,"../../autofill-utils.js":61,"../__generated__/deviceApiCalls.js":65}],71:[function(require,module,exports){ +},{"../../../packages/device-api/index.js":12,"../../Settings.js":50,"../../autofill-utils.js":62,"../__generated__/deviceApiCalls.js":66}],72:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -18284,7 +18256,7 @@ function createTransport(globalConfig) { return new _extensionTransport.ExtensionTransport(globalConfig); } -},{"./android.transport.js":68,"./apple.transport.js":69,"./extension.transport.js":70,"./windows.transport.js":72}],72:[function(require,module,exports){ +},{"./android.transport.js":69,"./apple.transport.js":70,"./extension.transport.js":71,"./windows.transport.js":73}],73:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -18369,7 +18341,7 @@ function waitForWindowsResponse(responseId, options) { }); } -},{"../../../packages/device-api/index.js":12}],73:[function(require,module,exports){ +},{"../../../packages/device-api/index.js":12}],74:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -18412,4 +18384,4 @@ window.cancelIdleCallback = window.cancelIdleCallback || function (id) { }; var _default = exports.default = {}; -},{}]},{},[62]); +},{}]},{},[63]); diff --git a/node_modules/@duckduckgo/autofill/dist/autofill.css b/node_modules/@duckduckgo/autofill/dist/autofill.css index dadd223be473..e712368f55c7 100644 --- a/node_modules/@duckduckgo/autofill/dist/autofill.css +++ b/node_modules/@duckduckgo/autofill/dist/autofill.css @@ -237,7 +237,8 @@ .tooltip__button--data--identities::before { background-image: url(''); } -.tooltip__button--data--credentials.tooltip__button--data--bitwarden::before { +.tooltip__button--data--credentials.tooltip__button--data--bitwarden::before, +.tooltip__button--data--credentials__current.tooltip__button--data--bitwarden::before { background-image: url(''); } #provider_locked:after { diff --git a/node_modules/@duckduckgo/autofill/dist/autofill.js b/node_modules/@duckduckgo/autofill/dist/autofill.js index 51f2466a87d3..637b93e6949d 100644 --- a/node_modules/@duckduckgo/autofill/dist/autofill.js +++ b/node_modules/@duckduckgo/autofill/dist/autofill.js @@ -2452,6 +2452,9 @@ module.exports={ "clien.net": { "password-rules": "minlength: 5; required: lower, upper; required: digit;" }, + "cogmembers.org": { + "password-rules": "minlength: 8; maxlength: 14; required: upper; required: digit, allowed: lower;" + }, "collectivehealth.com": { "password-rules": "minlength: 8; required: lower; required: upper; required: digit;" }, @@ -2542,6 +2545,9 @@ module.exports={ "eddservices.edd.ca.gov": { "password-rules": "minlength: 8; maxlength: 12; required: lower; required: upper; required: digit; required: [!@#$%^&*()];" }, + "edistrict.kerala.gov.in": { + "password-rules": "minlength: 5; maxlength: 15; required: lower; required: upper; required: digit; required: [!@#$];" + }, "empower-retirement.com": { "password-rules": "minlength: 8; maxlength: 16;" }, @@ -2596,6 +2602,9 @@ module.exports={ "gamestop.com": { "password-rules": "minlength: 8; maxlength: 225; required: lower; required: upper; required: digit; required: [!@#$%];" }, + "garmin.com": { + "password-rules": "minlength: 8; required: lower; required: upper; required: digit;" + }, "getflywheel.com": { "password-rules": "minlength: 7; maxlength: 72;" }, @@ -3142,6 +3151,9 @@ module.exports={ "target.com": { "password-rules": "minlength: 8; maxlength: 20; required: lower, upper; required: digit, [-!\"#$%&'()*+,./:;=?@[\\^_`{|}~];" }, + "tdscpc.gov.in": { + "password-rules": "minlength: 8; maxlength: 15; required: lower; required: upper; required: digit; required: [ &',;\"];" + }, "telekom-dienste.de": { "password-rules": "minlength: 8; maxlength: 16; required: lower; required: upper; required: digit; required: [#$%&()*+,./<=>?@_{|}~];" }, @@ -3319,7 +3331,7 @@ function createDevice() { return new _ExtensionInterface.ExtensionInterface(globalConfig, deviceApi, settings); } -},{"../packages/device-api/index.js":2,"./DeviceInterface/AndroidInterface.js":13,"./DeviceInterface/AppleDeviceInterface.js":14,"./DeviceInterface/AppleOverlayDeviceInterface.js":15,"./DeviceInterface/ExtensionInterface.js":16,"./DeviceInterface/WindowsInterface.js":18,"./DeviceInterface/WindowsOverlayDeviceInterface.js":19,"./Settings.js":40,"./config.js":53,"./deviceApiCalls/transports/transports.js":61}],13:[function(require,module,exports){ +},{"../packages/device-api/index.js":2,"./DeviceInterface/AndroidInterface.js":13,"./DeviceInterface/AppleDeviceInterface.js":14,"./DeviceInterface/AppleOverlayDeviceInterface.js":15,"./DeviceInterface/ExtensionInterface.js":16,"./DeviceInterface/WindowsInterface.js":18,"./DeviceInterface/WindowsOverlayDeviceInterface.js":19,"./Settings.js":40,"./config.js":54,"./deviceApiCalls/transports/transports.js":62}],13:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -3329,15 +3341,11 @@ exports.AndroidInterface = void 0; var _InterfacePrototype = _interopRequireDefault(require("./InterfacePrototype.js")); var _autofillUtils = require("../autofill-utils.js"); var _NativeUIController = require("../UI/controllers/NativeUIController.js"); -var _appleUtils = require("@duckduckgo/content-scope-scripts/src/apple-utils"); var _InContextSignup = require("../InContextSignup.js"); var _deviceApiCalls = require("../deviceApiCalls/__generated__/deviceApiCalls.js"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } class AndroidInterface extends _InterfacePrototype.default { inContextSignup = new _InContextSignup.InContextSignup(this); - async isEnabled() { - return (0, _autofillUtils.autofillEnabled)(this.globalConfig, _appleUtils.processConfig); - } /** * @returns {Promise} @@ -3471,7 +3479,7 @@ class AndroidInterface extends _InterfacePrototype.default { } exports.AndroidInterface = AndroidInterface; -},{"../InContextSignup.js":34,"../UI/controllers/NativeUIController.js":46,"../autofill-utils.js":51,"../deviceApiCalls/__generated__/deviceApiCalls.js":55,"./InterfacePrototype.js":17,"@duckduckgo/content-scope-scripts/src/apple-utils":1}],14:[function(require,module,exports){ +},{"../InContextSignup.js":34,"../UI/controllers/NativeUIController.js":47,"../autofill-utils.js":52,"../deviceApiCalls/__generated__/deviceApiCalls.js":56,"./InterfacePrototype.js":17}],14:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -3480,7 +3488,6 @@ Object.defineProperty(exports, "__esModule", { exports.AppleDeviceInterface = void 0; var _InterfacePrototype = _interopRequireDefault(require("./InterfacePrototype.js")); var _autofillUtils = require("../autofill-utils.js"); -var _appleUtils = require("@duckduckgo/content-scope-scripts/src/apple-utils"); var _HTMLTooltip = require("../UI/HTMLTooltip.js"); var _HTMLTooltipUIController = require("../UI/controllers/HTMLTooltipUIController.js"); var _OverlayUIController = require("../UI/controllers/OverlayUIController.js"); @@ -3490,6 +3497,7 @@ var _NativeUIController = require("../UI/controllers/NativeUIController.js"); var _deviceApiCalls = require("../deviceApiCalls/__generated__/deviceApiCalls.js"); var _matching = require("../Form/matching.js"); var _InContextSignup = require("../InContextSignup.js"); +var _ThirdPartyProvider = require("../ThirdPartyProvider.js"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /** * @typedef {import('../deviceApiCalls/__generated__/validators-ts').GetAutofillDataRequest} GetAutofillDataRequest @@ -3500,9 +3508,7 @@ class AppleDeviceInterface extends _InterfacePrototype.default { /** @override */ initialSetupDelayMs = 300; - async isEnabled() { - return (0, _autofillUtils.autofillEnabled)(this.globalConfig, _appleUtils.processConfig); - } + thirdPartyProvider = new _ThirdPartyProvider.ThirdPartyProvider(this); /** * The default functionality of this class is to operate as an 'overlay controller' - @@ -3705,20 +3711,6 @@ class AppleDeviceInterface extends _InterfacePrototype.default { return this.deviceApi.notify((0, _index.createNotification)('pmHandlerOpenManagePasswords')); } - /** - * Opens the native UI for managing identities - */ - openManageIdentities() { - return this.deviceApi.notify((0, _index.createNotification)('pmHandlerOpenManageIdentities')); - } - - /** - * Opens the native UI for managing credit cards - */ - openManageCreditCards() { - return this.deviceApi.notify((0, _index.createNotification)('pmHandlerOpenManageCreditCards')); - } - /** * Gets a single identity obj once the user requests it * @param {IdentityObject['id']} id @@ -3774,36 +3766,7 @@ class AppleDeviceInterface extends _InterfacePrototype.default { }); } async addDeviceListeners() { - if (this.settings.featureToggles.third_party_credentials_provider) { - if (this.globalConfig.hasModernWebkitAPI) { - Object.defineProperty(window, 'providerStatusUpdated', { - enumerable: false, - configurable: false, - writable: false, - value: data => { - this.providerStatusUpdated(data); - } - }); - } else { - // On Catalina we poll the native layer - setTimeout(() => this._pollForUpdatesToCredentialsProvider(), 2000); - } - } - } - - // Only used on Catalina - async _pollForUpdatesToCredentialsProvider() { - try { - const response = await this.deviceApi.request(new _deviceApiCalls.CheckCredentialsProviderStatusCall(null)); - if (response.availableInputTypes.credentialsProviderStatus !== this.settings.availableInputTypes.credentialsProviderStatus) { - this.providerStatusUpdated(response); - } - setTimeout(() => this._pollForUpdatesToCredentialsProvider(), 2000); - } catch (e) { - if (this.globalConfig.isDDGTestMode) { - console.log('isDDGTestMode: _pollForUpdatesToCredentialsProvider: ❌', e); - } - } + this.thirdPartyProvider.init(); } /** @type {any} */ @@ -3857,7 +3820,7 @@ class AppleDeviceInterface extends _InterfacePrototype.default { } exports.AppleDeviceInterface = AppleDeviceInterface; -},{"../../packages/device-api/index.js":2,"../Form/matching.js":33,"../InContextSignup.js":34,"../UI/HTMLTooltip.js":44,"../UI/controllers/HTMLTooltipUIController.js":45,"../UI/controllers/NativeUIController.js":46,"../UI/controllers/OverlayUIController.js":47,"../autofill-utils.js":51,"../deviceApiCalls/__generated__/deviceApiCalls.js":55,"../deviceApiCalls/additionalDeviceApiCalls.js":57,"./InterfacePrototype.js":17,"@duckduckgo/content-scope-scripts/src/apple-utils":1}],15:[function(require,module,exports){ +},{"../../packages/device-api/index.js":2,"../Form/matching.js":33,"../InContextSignup.js":34,"../ThirdPartyProvider.js":41,"../UI/HTMLTooltip.js":45,"../UI/controllers/HTMLTooltipUIController.js":46,"../UI/controllers/NativeUIController.js":47,"../UI/controllers/OverlayUIController.js":48,"../autofill-utils.js":52,"../deviceApiCalls/__generated__/deviceApiCalls.js":56,"../deviceApiCalls/additionalDeviceApiCalls.js":58,"./InterfacePrototype.js":17}],15:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -3868,8 +3831,6 @@ var _AppleDeviceInterface = require("./AppleDeviceInterface.js"); var _HTMLTooltipUIController = require("../UI/controllers/HTMLTooltipUIController.js"); var _overlayApi = require("./overlayApi.js"); var _index = require("../../packages/device-api/index.js"); -var _deviceApiCalls = require("../deviceApiCalls/__generated__/deviceApiCalls.js"); -var _validatorsZod = require("../deviceApiCalls/__generated__/validators.zod.js"); /** * This subclass is designed to separate code that *only* runs inside the * Overlay into a single place. @@ -3971,27 +3932,10 @@ class AppleOverlayDeviceInterface extends _AppleDeviceInterface.AppleDeviceInter async selectedDetail(data, type) { return this.overlay.selectedDetail(data, type); } - async askToUnlockProvider() { - const response = await this.deviceApi.request(new _deviceApiCalls.AskToUnlockProviderCall(null)); - this.providerStatusUpdated(response); - } - providerStatusUpdated(data) { - const { - credentials, - availableInputTypes - } = (0, _index.validate)(data, _validatorsZod.providerStatusUpdatedSchema); - - // Update local settings and data - this.settings.setAvailableInputTypes(availableInputTypes); - this.storeLocalCredentials(credentials); - - // rerender the tooltip - this.uiController?.updateItems(credentials); - } } exports.AppleOverlayDeviceInterface = AppleOverlayDeviceInterface; -},{"../../packages/device-api/index.js":2,"../UI/controllers/HTMLTooltipUIController.js":45,"../deviceApiCalls/__generated__/deviceApiCalls.js":55,"../deviceApiCalls/__generated__/validators.zod.js":56,"./AppleDeviceInterface.js":14,"./overlayApi.js":21}],16:[function(require,module,exports){ +},{"../../packages/device-api/index.js":2,"../UI/controllers/HTMLTooltipUIController.js":46,"./AppleDeviceInterface.js":14,"./overlayApi.js":21}],16:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -4053,18 +3997,6 @@ class ExtensionInterface extends _InterfacePrototype.default { this.uiController = this.createUIController(); await this.postInit(); } - async isEnabled() { - return new Promise(resolve => { - chrome?.runtime?.sendMessage({ - registeredTempAutofillContentScript: true, - documentUrl: window.location.href - }, response => { - if (response && 'site' in response) { - resolve((0, _autofillUtils.isAutofillEnabledFromProcessedConfig)(response)); - } - }); - }); - } isDeviceSignedIn() { return this.hasLocalAddresses; } @@ -4222,7 +4154,7 @@ class ExtensionInterface extends _InterfacePrototype.default { } exports.ExtensionInterface = ExtensionInterface; -},{"../Form/matching.js":33,"../InContextSignup.js":34,"../UI/HTMLTooltip.js":44,"../UI/controllers/HTMLTooltipUIController.js":45,"../autofill-utils.js":51,"./InterfacePrototype.js":17}],17:[function(require,module,exports){ +},{"../Form/matching.js":33,"../InContextSignup.js":34,"../UI/HTMLTooltip.js":45,"../UI/controllers/HTMLTooltipUIController.js":46,"../autofill-utils.js":52,"./InterfacePrototype.js":17}],17:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -4242,7 +4174,6 @@ var _Settings = require("../Settings.js"); var _index = require("../../packages/device-api/index.js"); var _deviceApiCalls = require("../deviceApiCalls/__generated__/deviceApiCalls.js"); var _initFormSubmissionsApi = require("./initFormSubmissionsApi.js"); -var _validatorsZod = require("../deviceApiCalls/__generated__/validators.zod.js"); var _EmailProtection = require("../EmailProtection.js"); /** * @typedef {import('../deviceApiCalls/__generated__/validators-ts').StoreFormData} StoreFormData @@ -4268,6 +4199,8 @@ class InterfacePrototype { /** @type {import("../InContextSignup.js").InContextSignup | null} */ inContextSignup = null; + /** @type {import("../ThirdPartyProvider.js").ThirdPartyProvider | null} */ + thirdPartyProvider = null; /** @type {{privateAddress: string, personalAddress: string}} */ #addresses = { @@ -4480,14 +4413,14 @@ class InterfacePrototype { async startInit() { if (this.isInitializationStarted) return; this.alreadyInitialized = true; - await this.refreshSettings(); + await this.settings.refresh(); this.addDeviceListeners(); await this.setupAutofill(); this.uiController = this.createUIController(); // this is the temporary measure to support windows whilst we still have 'setupAutofill' // eventually all interfaces will use this - if (!this.isEnabledViaSettings()) { + if (!this.settings.enabled) { return; } await this.setupSettingsPage(); @@ -4496,39 +4429,10 @@ class InterfacePrototype { (0, _initFormSubmissionsApi.initFormSubmissionsApi)(this.scanner.forms, this.scanner.matching); } } - - /** - * This is to aid the migration to all platforms using Settings.enabled. - * - * For now, Windows is the only platform that can be 'enabled' or 'disabled' via - * the new Settings - which is why in that interface it has `return this.settings.enabled` - * - * Whilst we wait for other platforms to catch up, we offer this default implementation - * of just returning true. - * - * @returns {boolean} - */ - isEnabledViaSettings() { - return true; - } - - /** - * This is a fall-back situation for macOS since it was the only - * platform to support anything none-email based in the past. - * - * Once macOS fully supports 'getAvailableInputTypes' this can be removed - * - * @returns {Promise} - */ - async refreshSettings() { - await this.settings.refresh(); - } - async isEnabled() { - return (0, _autofillUtils.autofillEnabled)(this.globalConfig); - } async init() { - const isEnabled = await this.isEnabled(); - if (!isEnabled) return; + // bail very early if we can + const settings = await this.settings.refresh(); + if (!settings.enabled) return; const handler = async () => { if (document.readyState === 'complete') { window.removeEventListener('load', handler); @@ -4730,7 +4634,7 @@ class InterfacePrototype { const mainType = (0, _matching.getMainTypeFromType)(inputType); const subtype = (0, _matching.getSubtypeFromType)(inputType); if (id === _Credentials.PROVIDER_LOCKED) { - return this.askToUnlockProvider(); + return this.thirdPartyProvider?.askToUnlockProvider(); } const matchingData = items.find(item => String(item.id) === id); if (!matchingData) throw new Error('unreachable (fatal)'); @@ -4801,10 +4705,6 @@ class InterfacePrototype { return this.removeTooltip(); }); } - async askToUnlockProvider() { - const response = await this.deviceApi.request(new _deviceApiCalls.AskToUnlockProviderCall(null)); - this.providerStatusUpdated(response); - } isTooltipActive() { return this.uiController?.isActive?.() ?? false; } @@ -4907,7 +4807,7 @@ class InterfacePrototype { // This call doesn't send a response, so we can't know if it succeeded this.storeUserData(data); await this.setupAutofill(); - await this.refreshSettings(); + await this.settings.refresh(); await this.setupSettingsPage({ shouldLog: true }); @@ -4920,37 +4820,6 @@ class InterfacePrototype { storeUserData(_data) {} addDeviceListeners() {} - /** - * Called by the native layer on all tabs when the provider status is updated - * @param {import("../deviceApiCalls/__generated__/validators-ts").ProviderStatusUpdated} data - */ - providerStatusUpdated(data) { - try { - const { - credentials, - availableInputTypes - } = (0, _index.validate)(data, _validatorsZod.providerStatusUpdatedSchema); - - // Update local settings and data - this.settings.setAvailableInputTypes(availableInputTypes); - this.storeLocalCredentials(credentials); - - // rerender the tooltip - this.uiController?.updateItems(credentials); - // If the tooltip is open on an autofill type that's not available, close it - const currentInputSubtype = (0, _matching.getSubtypeFromType)(this.getCurrentInputType()); - if (!availableInputTypes.credentials?.[currentInputSubtype]) { - this.removeTooltip(); - } - // Redecorate fields according to the new types - this.scanner.forms.forEach(form => form.recategorizeAllInputs()); - } catch (e) { - if (this.globalConfig.isDDGTestMode) { - console.log('isDDGTestMode: providerStatusUpdated error: ❌', e); - } - } - } - /** @param {() => void} _fn */ addLogoutListener(_fn) {} isDeviceSignedIn() { @@ -5104,7 +4973,7 @@ class InterfacePrototype { } var _default = exports.default = InterfacePrototype; -},{"../../packages/device-api/index.js":2,"../EmailProtection.js":22,"../Form/formatters.js":26,"../Form/matching.js":33,"../InputTypes/Credentials.js":35,"../PasswordGenerator.js":38,"../Scanner.js":39,"../Settings.js":40,"../UI/controllers/NativeUIController.js":46,"../autofill-utils.js":51,"../config.js":53,"../deviceApiCalls/__generated__/deviceApiCalls.js":55,"../deviceApiCalls/__generated__/validators.zod.js":56,"../deviceApiCalls/transports/transports.js":61,"./initFormSubmissionsApi.js":20}],18:[function(require,module,exports){ +},{"../../packages/device-api/index.js":2,"../EmailProtection.js":22,"../Form/formatters.js":26,"../Form/matching.js":33,"../InputTypes/Credentials.js":35,"../PasswordGenerator.js":38,"../Scanner.js":39,"../Settings.js":40,"../UI/controllers/NativeUIController.js":47,"../autofill-utils.js":52,"../config.js":54,"../deviceApiCalls/__generated__/deviceApiCalls.js":56,"../deviceApiCalls/transports/transports.js":62,"./initFormSubmissionsApi.js":20}],18:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -5124,22 +4993,12 @@ class WindowsInterface extends _InterfacePrototype.default { ready = false; /** @type {AbortController|null} */ _abortController = null; - /** - * @deprecated This runs too early, and will be removed eventually. - * @returns {Promise} - */ - async isEnabled() { - return true; - } async setupAutofill() { const loggedIn = await this._getIsLoggedIn(); if (loggedIn) { await this.getAddresses(); } } - isEnabledViaSettings() { - return Boolean(this.settings.enabled); - } postInit() { super.postInit(); this.ready = true; @@ -5276,7 +5135,7 @@ class WindowsInterface extends _InterfacePrototype.default { } exports.WindowsInterface = WindowsInterface; -},{"../UI/controllers/OverlayUIController.js":47,"../deviceApiCalls/__generated__/deviceApiCalls.js":55,"./InterfacePrototype.js":17}],19:[function(require,module,exports){ +},{"../UI/controllers/OverlayUIController.js":48,"../deviceApiCalls/__generated__/deviceApiCalls.js":56,"./InterfacePrototype.js":17}],19:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -5455,7 +5314,7 @@ class WindowsOverlayDeviceInterface extends _InterfacePrototype.default { } exports.WindowsOverlayDeviceInterface = WindowsOverlayDeviceInterface; -},{"../UI/controllers/HTMLTooltipUIController.js":45,"../deviceApiCalls/__generated__/deviceApiCalls.js":55,"./InterfacePrototype.js":17,"./overlayApi.js":21}],20:[function(require,module,exports){ +},{"../UI/controllers/HTMLTooltipUIController.js":46,"../deviceApiCalls/__generated__/deviceApiCalls.js":56,"./InterfacePrototype.js":17,"./overlayApi.js":21}],20:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -5554,7 +5413,7 @@ function initFormSubmissionsApi(forms, matching) { }); } -},{"../Form/label-util.js":29,"../autofill-utils.js":51}],21:[function(require,module,exports){ +},{"../Form/label-util.js":29,"../autofill-utils.js":52}],21:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -5612,7 +5471,7 @@ function overlayApi(device) { }; } -},{"../deviceApiCalls/__generated__/deviceApiCalls.js":55}],22:[function(require,module,exports){ +},{"../deviceApiCalls/__generated__/deviceApiCalls.js":56}],22:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -6309,6 +6168,7 @@ class Form { if ((0, _autofillUtils.isEventWithinDax)(e, input)) return true; if (this.device.globalConfig.isWindows) return true; const subtype = (0, _matching.getInputSubtype)(input); + const variant = (0, _matching.getInputVariant)(input); const isIncontextSignupAvailable = this.device.inContextSignup?.isAvailable(subtype); if (this.device.globalConfig.isApp) { const mainType = (0, _matching.getInputMainType)(input); @@ -6317,7 +6177,8 @@ class Form { // just showing in-context signup, or with other autofill items. const hasSavedDetails = this.device.settings.canAutofillType({ mainType, - subtype + subtype, + variant }, null); // Don't open the tooltip on input focus whenever it'll only show in-context signup @@ -6442,13 +6303,15 @@ class Form { if (!input) return; const mainType = (0, _matching.getInputMainType)(input); const subtype = (0, _matching.getInputSubtype)(input); + const variant = (0, _matching.getInputVariant)(input); await this.device.settings.populateDataIfNeeded({ mainType, subtype }); if (this.device.settings.canAutofillType({ mainType, - subtype + subtype, + variant }, this.device.inContextSignup)) { // The timeout is needed in case the page shows a cookie prompt with a slight delay setTimeout(() => { @@ -6487,7 +6350,7 @@ class Form { } exports.Form = Form; -},{"../InputTypes/Credentials.js":35,"../autofill-utils.js":51,"../constants.js":54,"./FormAnalyzer.js":24,"./formatters.js":26,"./inputStyles.js":27,"./inputTypeConfig.js":28,"./matching.js":33}],24:[function(require,module,exports){ +},{"../InputTypes/Credentials.js":35,"../autofill-utils.js":52,"../constants.js":55,"./FormAnalyzer.js":24,"./formatters.js":26,"./inputStyles.js":27,"./inputTypeConfig.js":28,"./matching.js":33}],24:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -6528,8 +6391,16 @@ class FormAnalyzer { * @type {string[]} */ this.signals = []; + + // Analyse the input that was passed. This is pretty arbitrary, but historically it's been working nicely. this.evaluateElAttributes(input, 1, true); - form ? this.evaluateForm() : this.evaluatePage(); + + // If we have a meaningful container (a form), check that, otherwise check the whole page + if (form !== input) { + this.evaluateForm(); + } else { + this.evaluatePage(); + } return this; } @@ -6680,6 +6551,7 @@ class FormAnalyzer { }); } evaluatePage() { + this.evaluateUrl(); this.evaluatePageTitle(); this.evaluatePageHeadings(); // Check for submit buttons @@ -6772,13 +6644,17 @@ class FormAnalyzer { this.evaluateElAttributes(this.form); // Check form contents (noisy elements are skipped with the safeUniversalSelector) - this.form.querySelectorAll(this.matching.cssSelector('safeUniversalSelector')).forEach(el => { + const formElements = this.form.querySelectorAll(this.matching.cssSelector('safeUniversalSelector')); + for (let i = 0; i < formElements.length; i++) { + // Safety cutoff to avoid huge DOMs freezing the browser + if (i >= 200) break; + const element = formElements[i]; // Check if element is not hidden. Note that we can't use offsetHeight // nor intersectionObserver, because the element could be outside the // viewport or its parent hidden - const displayValue = window.getComputedStyle(el, null).getPropertyValue('display'); - if (displayValue !== 'none') this.evaluateElement(el); - }); + const displayValue = window.getComputedStyle(element, null).getPropertyValue('display'); + if (displayValue !== 'none') this.evaluateElement(element); + } // A form with many fields is unlikely to be a login form const relevantFields = this.form.querySelectorAll(this.matching.cssSelector('genericTextField')); @@ -6839,7 +6715,7 @@ class FormAnalyzer { } var _default = exports.default = FormAnalyzer; -},{"../autofill-utils.js":51,"../constants.js":54,"./matching-config/__generated__/compiled-matching-config.js":31,"./matching.js":33}],25:[function(require,module,exports){ +},{"../autofill-utils.js":52,"../constants.js":55,"./matching-config/__generated__/compiled-matching-config.js":31,"./matching.js":33}],25:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -7898,16 +7774,18 @@ const canBeInteractedWith = input => !input.readOnly && !input.disabled; */ exports.canBeInteractedWith = canBeInteractedWith; const canBeAutofilled = async (input, device) => { - if (!canBeInteractedWith(input)) return false; const mainType = (0, _matching.getInputMainType)(input); + if (mainType === 'unknown') return false; const subtype = (0, _matching.getInputSubtype)(input); + const variant = (0, _matching.getInputVariant)(input); await device.settings.populateDataIfNeeded({ mainType, subtype }); const canAutofill = device.settings.canAutofillType({ mainType, - subtype + subtype, + variant }, device.inContextSignup); return Boolean(canAutofill); }; @@ -7959,16 +7837,11 @@ const inputTypeConfig = { } = _ref5; const subtype = (0, _matching.getInputSubtype)(input); const variant = (0, _matching.getInputVariant)(input); - - // Check first for password generation and the password.new scoring - if (device.settings.featureToggles.password_generation) { - if (subtype === 'password' && variant === 'new') { - return canBeInteractedWith(input); - } - } - - // if we are on a 'login' page, check if we have data to autofill the field - if (isLogin || isHybrid || variant === 'current') { + if (subtype === 'password' && variant === 'new' || + // New passord field + isLogin || isHybrid || variant === 'current' // Current password field + ) { + // Check feature flags and available input types return canBeAutofilled(input, device); } return false; @@ -8055,7 +7928,7 @@ const isFieldDecorated = input => { }; exports.isFieldDecorated = isFieldDecorated; -},{"../InputTypes/Credentials.js":35,"../InputTypes/CreditCard.js":36,"../InputTypes/Identity.js":37,"../UI/img/ddgPasswordIcon.js":49,"../constants.js":54,"./logo-svg.js":30,"./matching.js":33}],29:[function(require,module,exports){ +},{"../InputTypes/Credentials.js":35,"../InputTypes/CreditCard.js":36,"../InputTypes/Identity.js":37,"../UI/img/ddgPasswordIcon.js":50,"../constants.js":55,"./logo-svg.js":30,"./matching.js":33}],29:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -8348,6 +8221,7 @@ const matchingConfiguration = exports.matchingConfiguration = { selectors: { genericTextField: 'input:not([type=button]):not([type=checkbox]):not([type=color]):not([type=file]):not([type=hidden]):not([type=radio]):not([type=range]):not([type=reset]):not([type=image]):not([type=search]):not([type=submit]):not([type=time]):not([type=url]):not([type=week]):not([name^=fake i]):not([data-description^=dummy i]):not([name*=otp]):not([autocomplete="fake"]):not([placeholder^=search i]):not([type=date]):not([type=datetime-local]):not([type=datetime]):not([type=month])', submitButtonSelector: 'input[type=submit], input[type=button], input[type=image], button:not([role=switch]):not([role=link]), [role=button], a[href="#"][id*=button i], a[href="#"][id*=btn i]', + formInputsSelectorWithoutSelect: 'input:not([type=button]):not([type=checkbox]):not([type=color]):not([type=file]):not([type=hidden]):not([type=radio]):not([type=range]):not([type=reset]):not([type=image]):not([type=search]):not([type=submit]):not([type=time]):not([type=url]):not([type=week]):not([name^=fake i]):not([data-description^=dummy i]):not([name*=otp]):not([autocomplete="fake"]):not([placeholder^=search i]):not([type=date]):not([type=datetime-local]):not([type=datetime]):not([type=month]),[autocomplete=username]', formInputsSelector: 'input:not([type=button]):not([type=checkbox]):not([type=color]):not([type=file]):not([type=hidden]):not([type=radio]):not([type=range]):not([type=reset]):not([type=image]):not([type=search]):not([type=submit]):not([type=time]):not([type=url]):not([type=week]):not([name^=fake i]):not([data-description^=dummy i]):not([name*=otp]):not([autocomplete="fake"]):not([placeholder^=search i]):not([type=date]):not([type=datetime-local]):not([type=datetime]):not([type=month]),[autocomplete=username],select', safeUniversalSelector: '*:not(select):not(option):not(script):not(noscript):not(style):not(br)', emailAddress: 'input:not([type])[name*=email i]:not([placeholder*=search i]):not([placeholder*=filter i]):not([placeholder*=subject i]):not([name*=code i]), input[type=""][name*=email i]:not([placeholder*=search i]):not([placeholder*=filter i]):not([placeholder*=subject i]):not([type=tel]), input[type=text][name*=email i]:not([placeholder*=search i]):not([placeholder*=filter i]):not([placeholder*=subject i]):not([name*=title i]):not([name*=tab i]):not([name*=code i]), input:not([type])[placeholder*=email i]:not([placeholder*=search i]):not([placeholder*=filter i]):not([placeholder*=subject i]):not([name*=code i]), input[type=text][placeholder*=email i]:not([placeholder*=search i]):not([placeholder*=filter i]):not([placeholder*=subject i]), input[type=""][placeholder*=email i]:not([placeholder*=search i]):not([placeholder*=filter i]):not([placeholder*=subject i]), input[type=email], input[type=text][aria-label*=email i]:not([aria-label*=search i]), input:not([type])[aria-label*=email i]:not([aria-label*=search i]), input[name=username][type=email], input[autocomplete=username][type=email], input[autocomplete=username][placeholder*=email i], input[autocomplete=email],input[name="mail_tel" i],input[value=email i]', @@ -8370,9 +8244,9 @@ const matchingConfiguration = exports.matchingConfiguration = { addressProvince: '[name=province i], [name=state i], [autocomplete=address-level1 i]', addressPostalCode: '[name=zip i], [name=zip2 i], [name=postal i], [autocomplete=postal-code i], [autocomplete=zip-code i], [name*=postalCode i], [name*=zipcode i]', addressCountryCode: '[name=country i], [autocomplete=country i], [name*=countryCode i], [name*=country-code i], [name*=countryName i], [name*=country-name i],select.idms-address-country', - birthdayDay: '[name=bday-day i], [name*=birthday_day i], [name*=birthday-day i], [name=date_of_birth_day i], [name=date-of-birth-day i], [name^=birthdate_d i], [name^=birthdate-d i], [aria-label="birthday" i][placeholder="day" i]', - birthdayMonth: '[name=bday-month i], [name*=birthday_month i], [name*=birthday-month i], [name=date_of_birth_month i], [name=date-of-birth-month i], [name^=birthdate_m i], [name^=birthdate-m i], select[name="mm" i]', - birthdayYear: '[name=bday-year i], [name*=birthday_year i], [name*=birthday-year i], [name=date_of_birth_year i], [name=date-of-birth-year i], [name^=birthdate_y i], [name^=birthdate-y i], [aria-label="birthday" i][placeholder="year" i]' + birthdayDay: '[autocomplete=bday-day i], [name=bday-day i], [name*=birthday_day i], [name*=birthday-day i], [name=date_of_birth_day i], [name=date-of-birth-day i], [name^=birthdate_d i], [name^=birthdate-d i], [aria-label="birthday" i][placeholder="day" i]', + birthdayMonth: '[autocomplete=bday-month i], [name=bday-month i], [name*=birthday_month i], [name*=birthday-month i], [name=date_of_birth_month i], [name=date-of-birth-month i], [name^=birthdate_m i], [name^=birthdate-m i], select[name="mm" i]', + birthdayYear: '[autocomplete=bday-year i], [name=bday-year i], [name*=birthday_year i], [name*=birthday-year i], [name=date_of_birth_year i], [name=date-of-birth-year i], [name^=birthdate_y i], [name^=birthdate-y i], [aria-label="birthday" i][placeholder="year" i]' } }, ddgMatcher: { @@ -8486,7 +8360,7 @@ const matchingConfiguration = exports.matchingConfiguration = { match: /sign(ing)?.?[io]n(?!g)|log.?[io]n|log.?out|unsubscri|(forgot(ten)?|reset) (your )?password|password (forgotten|lost)|mfa-submit-form|unlock|logged in as|entra|accedi|accesso|resetta password|password dimenticata|dimenticato la password|recuper[ao] password|(ein|aus)loggen|anmeld(eformular|ung|efeld)|abmelden|passwort (vergessen|verloren)|zugang| zugangsformular|einwahl|inloggen|se (dé)?connecter|(dé)?connexion|récupérer ((mon|ton|votre|le) )?mot de passe|mot de passe (oublié|perdu)|clave(?! su)|olvidó su (clave|contraseña)|.*sesión|conect(arse|ado)|conéctate|acce(de|so)|entrar|logga (in|ut)|avprenumerera|avregistrera|glömt lösenord|återställ lösenord/iu }, signupRegex: { - match: /sign(ing)?.?up|join|\bregist(er|ration)|newsletter|\bsubscri(be|ption)|contact|create|start|enroll|settings|preferences|profile|update|checkout|purchase|buy|order|schedule|estimate|request|new.?customer|(confirm|re.?(type|enter)|repeat) password|password confirm|iscri(viti|zione)|registra(ti|zione)|(?:nuovo|crea(?:zione)?) account|contatt(?:ac)i|sottoscriv|sottoscrizione|compra|acquist(a|o)|ordin[aeio]|richie(?:di|sta)|(?:conferma|ripeti) password|inizia|nuovo cliente|impostazioni|preferenze|profilo|aggiorna|paga|registrier(ung|en)|profil (anlegen|erstellen)| nachrichten|verteiler|neukunde|neuer (kunde|benutzer|nutzer)|passwort wiederholen|anmeldeseite|nieuwsbrief|aanmaken|profiel|s.inscrire|inscription|s.abonner|créer|préférences|profil|mise à jour|payer|ach(eter|at)| nouvel utilisateur|(confirmer|réessayer) ((mon|ton|votre|le) )?mot de passe|regis(trarse|tro)|regístrate|inscr(ibirse|ipción|íbete)|solicitar|crea(r cuenta)?|nueva cuenta|nuevo (cliente|usuario)|preferencias|perfil|lista de correo|registrer(a|ing)|(nytt|öppna) konto|nyhetsbrev|prenumer(era|ation)|kontakt|skapa|starta|inställningar|min (sida|kundvagn)|uppdatera|till kassan|gäst|köp|beställ|schemalägg|ny kund|(repetera|bekräfta) lösenord/iu + match: /sign(ing)?.?up|join|\bregist(er|ration)|newsletter|\bsubscri(be|ption)|contact|create|start|enroll|settings|preferences|profile|update|checkout|purchase|buy|^order|schedule|estimate|request|new.?customer|(confirm|re.?(type|enter)|repeat) password|password confirm|iscri(viti|zione)|registra(ti|zione)|(?:nuovo|crea(?:zione)?) account|contatt(?:ac)i|sottoscriv|sottoscrizione|compra|acquist(a|o)|ordin[aeio]|richie(?:di|sta)|(?:conferma|ripeti) password|inizia|nuovo cliente|impostazioni|preferenze|profilo|aggiorna|paga|registrier(ung|en)|profil (anlegen|erstellen)| nachrichten|verteiler|neukunde|neuer (kunde|benutzer|nutzer)|passwort wiederholen|anmeldeseite|nieuwsbrief|aanmaken|profiel|s.inscrire|inscription|s.abonner|créer|préférences|profil|mise à jour|payer|ach(eter|at)| nouvel utilisateur|(confirmer|réessayer) ((mon|ton|votre|le) )?mot de passe|regis(trarse|tro)|regístrate|inscr(ibirse|ipción|íbete)|solicitar|crea(r cuenta)?|nueva cuenta|nuevo (cliente|usuario)|preferencias|perfil|lista de correo|registrer(a|ing)|(nytt|öppna) konto|nyhetsbrev|prenumer(era|ation)|kontakt|skapa|starta|inställningar|min (sida|kundvagn)|uppdatera|till kassan|gäst|köp|beställ|schemalägg|ny kund|(repetera|bekräfta) lösenord/iu }, conservativeSignupRegex: { match: /sign.?up|join|register|enroll|(create|new).+account|newsletter|subscri(be|ption)|settings|preferences|profile|update|iscri(viti|zione)|registra(ti|zione)|(?:nuovo|crea(?:zione)?) account|contatt(?:ac)?i|sottoscriv|sottoscrizione|impostazioni|preferenze|aggiorna|anmeld(en|ung)|registrier(en|ung)|neukunde|neuer (kunde|benutzer|nutzer)|registreren|eigenschappen|profiel|bijwerken|s.inscrire|inscription|s.abonner|abonnement|préférences|profil|créer un compte|regis(trarse|tro)|regístrate|inscr(ibirse|ipción|íbete)|crea(r cuenta)?|nueva cuenta|nuevo (cliente|usuario)|preferencias|perfil|lista de correo|registrer(a|ing)|(nytt|öppna) konto|nyhetsbrev|prenumer(era|ation)|kontakt|skapa|starta|inställningar|min (sida|kundvagn)|uppdatera/iu @@ -8663,7 +8537,7 @@ function logUnmatched(el, allStrings) { console.groupEnd(); } -},{"../autofill-utils.js":51,"./matching.js":33}],33:[function(require,module,exports){ +},{"../autofill-utils.js":52,"./matching.js":33}],33:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -9648,7 +9522,7 @@ function createMatching() { return new Matching(_compiledMatchingConfig.matchingConfiguration); } -},{"../autofill-utils.js":51,"../constants.js":54,"./label-util.js":29,"./matching-config/__generated__/compiled-matching-config.js":31,"./matching-utils.js":32}],34:[function(require,module,exports){ +},{"../autofill-utils.js":52,"../constants.js":55,"./label-util.js":29,"./matching-config/__generated__/compiled-matching-config.js":31,"./matching-utils.js":32}],34:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -9780,7 +9654,7 @@ class InContextSignup { } exports.InContextSignup = InContextSignup; -},{"./autofill-utils.js":51,"./deviceApiCalls/__generated__/deviceApiCalls.js":55}],35:[function(require,module,exports){ +},{"./autofill-utils.js":52,"./deviceApiCalls/__generated__/deviceApiCalls.js":56}],35:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -9927,7 +9801,7 @@ function createCredentialsTooltipItem(data) { return new CredentialsTooltipItem(data); } -},{"../autofill-utils.js":51}],36:[function(require,module,exports){ +},{"../autofill-utils.js":52}],36:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -10192,10 +10066,10 @@ class DefaultScanner { if (this.device.globalConfig.isDDGDomain) { return this; } - if ('matches' in context && context.matches?.(this.matching.cssSelector('formInputsSelector'))) { + if ('matches' in context && context.matches?.(this.matching.cssSelector('formInputsSelectorWithoutSelect'))) { this.addInput(context); } else { - const inputs = context.querySelectorAll(this.matching.cssSelector('formInputsSelector')); + const inputs = context.querySelectorAll(this.matching.cssSelector('formInputsSelectorWithoutSelect')); if (inputs.length > this.options.maxInputsPerPage) { this.stopScanner(`Too many input fields in the given context (${inputs.length}), stop scanning`, context); return this; @@ -10447,7 +10321,7 @@ function createScanner(device, scannerOptions) { }); } -},{"./Form/Form.js":23,"./Form/matching.js":33,"./autofill-utils.js":51,"./constants.js":54,"./deviceApiCalls/__generated__/deviceApiCalls.js":55}],40:[function(require,module,exports){ +},{"./Form/Form.js":23,"./Form/matching.js":33,"./autofill-utils.js":52,"./constants.js":55,"./deviceApiCalls/__generated__/deviceApiCalls.js":56}],40:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -10458,7 +10332,6 @@ var _index = require("../packages/device-api/index.js"); var _deviceApiCalls = require("./deviceApiCalls/__generated__/deviceApiCalls.js"); var _validatorsZod = require("./deviceApiCalls/__generated__/validators.zod.js"); var _autofillUtils = require("./autofill-utils.js"); -var _appleUtils = require("@duckduckgo/content-scope-scripts/src/apple-utils"); /** * Some Type helpers to prevent duplication * @typedef {import("./deviceApiCalls/__generated__/validators-ts").AutofillFeatureToggles} AutofillFeatureToggles @@ -10535,7 +10408,7 @@ class Settings { async getEnabled() { try { const runtimeConfig = await this._getRuntimeConfiguration(); - const enabled = (0, _autofillUtils.autofillEnabled)(runtimeConfig, _appleUtils.processConfig); + const enabled = (0, _autofillUtils.autofillEnabled)(runtimeConfig); return enabled; } catch (e) { // these are the fallbacks for when a platform hasn't implemented the calls above. (like on android) @@ -10674,6 +10547,7 @@ class Settings { * @param {{ * mainType: SupportedMainTypes * subtype: import('./Form/matching.js').SupportedSubTypes | "unknown" + * variant: import('./Form/matching.js').SupportedVariants | "" * }} types * @param {import("./InContextSignup.js").InContextSignup?} inContextSignup * @returns {boolean} @@ -10681,7 +10555,8 @@ class Settings { canAutofillType(_ref3, inContextSignup) { let { mainType, - subtype + subtype, + variant } = _ref3; if (this.isTypeUnavailable({ mainType, @@ -10696,6 +10571,11 @@ class Settings { if (inContextSignup?.isAvailable(subtype)) { return true; } + + // Check for password generation and the password.new scoring + if (subtype === 'password' && variant === 'new' && this.featureToggles.password_generation) { + return true; + } if (subtype === 'fullName') { return Boolean(this.availableInputTypes.identities?.firstName || this.availableInputTypes.identities?.lastName); } @@ -10796,7 +10676,97 @@ class Settings { } exports.Settings = Settings; -},{"../packages/device-api/index.js":2,"./autofill-utils.js":51,"./deviceApiCalls/__generated__/deviceApiCalls.js":55,"./deviceApiCalls/__generated__/validators.zod.js":56,"@duckduckgo/content-scope-scripts/src/apple-utils":1}],41:[function(require,module,exports){ +},{"../packages/device-api/index.js":2,"./autofill-utils.js":52,"./deviceApiCalls/__generated__/deviceApiCalls.js":56,"./deviceApiCalls/__generated__/validators.zod.js":57}],41:[function(require,module,exports){ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ThirdPartyProvider = void 0; +var _deviceApiCalls = require("./deviceApiCalls/__generated__/deviceApiCalls.js"); +var _validatorsZod = require("./deviceApiCalls/__generated__/validators.zod.js"); +var _matching = require("./Form/matching.js"); +var _index = require("../packages/device-api/index.js"); +class ThirdPartyProvider { + /** + * @param {import("./DeviceInterface/InterfacePrototype").default} device + */ + constructor(device) { + this.device = device; + } + init() { + if (this.device.settings.featureToggles.third_party_credentials_provider) { + if (this.device.globalConfig.hasModernWebkitAPI) { + Object.defineProperty(window, 'providerStatusUpdated', { + enumerable: false, + configurable: false, + writable: false, + value: data => { + this.providerStatusUpdated(data); + } + }); + } else { + // On Catalina we poll the native layer + setTimeout(() => this._pollForUpdatesToCredentialsProvider(), 2000); + } + } + } + async askToUnlockProvider() { + const response = await this.device.deviceApi.request(new _deviceApiCalls.AskToUnlockProviderCall(null)); + this.providerStatusUpdated(response); + } + + /** + * Called by the native layer on all tabs when the provider status is updated + * @param {import("./deviceApiCalls/__generated__/validators-ts").ProviderStatusUpdated} data + */ + providerStatusUpdated(data) { + try { + const { + credentials, + availableInputTypes + } = (0, _index.validate)(data, _validatorsZod.providerStatusUpdatedSchema); + + // Update local settings and data + this.device.settings.setAvailableInputTypes(availableInputTypes); + this.device.storeLocalCredentials(credentials); + + // rerender the tooltip + this.device.uiController?.updateItems(credentials); + if (!this.device.globalConfig.isTopFrame) { + // If the tooltip is open on an autofill type that's not available, close it + const currentInputSubtype = (0, _matching.getSubtypeFromType)(this.device.getCurrentInputType()); + if (!availableInputTypes.credentials?.[currentInputSubtype]) { + this.device.removeTooltip(); + } + // Redecorate fields according to the new types + this.device.scanner.forms.forEach(form => form.recategorizeAllInputs()); + } + } catch (e) { + if (this.device.globalConfig.isDDGTestMode) { + console.log('isDDGTestMode: providerStatusUpdated error: ❌', e); + } + } + } + + // Only used on Catalina + async _pollForUpdatesToCredentialsProvider() { + try { + const response = await this.device.deviceApi.request(new _deviceApiCalls.CheckCredentialsProviderStatusCall(null)); + if (response.availableInputTypes.credentialsProviderStatus !== this.device.settings.availableInputTypes.credentialsProviderStatus) { + this.providerStatusUpdated(response); + } + setTimeout(() => this._pollForUpdatesToCredentialsProvider(), 2000); + } catch (e) { + if (this.device.globalConfig.isDDGTestMode) { + console.log('isDDGTestMode: _pollForUpdatesToCredentialsProvider: ❌', e); + } + } + } +} +exports.ThirdPartyProvider = ThirdPartyProvider; + +},{"../packages/device-api/index.js":2,"./Form/matching.js":33,"./deviceApiCalls/__generated__/deviceApiCalls.js":56,"./deviceApiCalls/__generated__/validators.zod.js":57}],42:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -10924,7 +10894,7 @@ ${css} } var _default = exports.default = DataHTMLTooltip; -},{"../InputTypes/Credentials.js":35,"../autofill-utils.js":51,"./HTMLTooltip.js":44}],42:[function(require,module,exports){ +},{"../InputTypes/Credentials.js":35,"../autofill-utils.js":52,"./HTMLTooltip.js":45}],43:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -11002,7 +10972,7 @@ ${this.options.css} } var _default = exports.default = EmailHTMLTooltip; -},{"../autofill-utils.js":51,"./HTMLTooltip.js":44}],43:[function(require,module,exports){ +},{"../autofill-utils.js":52,"./HTMLTooltip.js":45}],44:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -11058,7 +11028,7 @@ ${this.options.css} } var _default = exports.default = EmailSignupHTMLTooltip; -},{"./HTMLTooltip.js":44}],44:[function(require,module,exports){ +},{"./HTMLTooltip.js":45}],45:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -11446,7 +11416,7 @@ class HTMLTooltip { exports.HTMLTooltip = HTMLTooltip; var _default = exports.default = HTMLTooltip; -},{"../Form/matching.js":33,"../autofill-utils.js":51,"./styles/styles.js":50}],45:[function(require,module,exports){ +},{"../Form/matching.js":33,"../autofill-utils.js":52,"./styles/styles.js":51}],46:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -11803,7 +11773,7 @@ class HTMLTooltipUIController extends _UIController.UIController { } exports.HTMLTooltipUIController = HTMLTooltipUIController; -},{"../../Form/inputTypeConfig.js":28,"../../Form/matching.js":33,"../../autofill-utils.js":51,"../DataHTMLTooltip.js":41,"../EmailHTMLTooltip.js":42,"../EmailSignupHTMLTooltip.js":43,"../HTMLTooltip.js":44,"./UIController.js":48}],46:[function(require,module,exports){ +},{"../../Form/inputTypeConfig.js":28,"../../Form/matching.js":33,"../../autofill-utils.js":52,"../DataHTMLTooltip.js":42,"../EmailHTMLTooltip.js":43,"../EmailSignupHTMLTooltip.js":44,"../HTMLTooltip.js":45,"./UIController.js":49}],47:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -11965,7 +11935,7 @@ class NativeUIController extends _UIController.UIController { } exports.NativeUIController = NativeUIController; -},{"../../Form/matching.js":33,"../../InputTypes/Credentials.js":35,"../../deviceApiCalls/__generated__/deviceApiCalls.js":55,"./UIController.js":48}],47:[function(require,module,exports){ +},{"../../Form/matching.js":33,"../../InputTypes/Credentials.js":35,"../../deviceApiCalls/__generated__/deviceApiCalls.js":56,"./UIController.js":49}],48:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -12202,7 +12172,7 @@ class OverlayUIController extends _UIController.UIController { } exports.OverlayUIController = OverlayUIController; -},{"../../Form/matching.js":33,"./UIController.js":48}],48:[function(require,module,exports){ +},{"../../Form/matching.js":33,"./UIController.js":49}],49:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -12286,7 +12256,7 @@ class UIController { } exports.UIController = UIController; -},{}],49:[function(require,module,exports){ +},{}],50:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -12303,16 +12273,16 @@ const ddgCcIconBase = exports.ddgCcIconBase = ' const ddgCcIconFilled = exports.ddgCcIconFilled = ''; const ddgIdentityIconBase = exports.ddgIdentityIconBase = ``; -},{}],50:[function(require,module,exports){ +},{}],51:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.CSS_STYLES = void 0; -const CSS_STYLES = exports.CSS_STYLES = ":root {\n color-scheme: light dark;\n}\n\n.wrapper *, .wrapper *::before, .wrapper *::after {\n box-sizing: border-box;\n}\n.wrapper {\n position: fixed;\n top: 0;\n left: 0;\n padding: 0;\n font-family: 'DDG_ProximaNova', 'Proxima Nova', system-ui, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu',\n 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;\n -webkit-font-smoothing: antialiased;\n z-index: 2147483647;\n}\n.wrapper--data {\n font-family: 'SF Pro Text', system-ui, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu',\n 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;\n}\n:not(.top-autofill) .tooltip {\n position: absolute;\n width: 300px;\n max-width: calc(100vw - 25px);\n transform: translate(-1000px, -1000px);\n z-index: 2147483647;\n}\n.tooltip--data, #topAutofill {\n background-color: rgba(242, 240, 240, 1);\n -webkit-backdrop-filter: blur(40px);\n backdrop-filter: blur(40px);\n}\n@media (prefers-color-scheme: dark) {\n .tooltip--data, #topAutofill {\n background: rgb(100, 98, 102, .9);\n }\n}\n.tooltip--data {\n padding: 6px;\n font-size: 13px;\n line-height: 14px;\n width: 315px;\n max-height: 290px;\n overflow-y: auto;\n}\n.top-autofill .tooltip--data {\n min-height: 100vh;\n}\n.tooltip--data.tooltip--incontext-signup {\n width: 360px;\n}\n:not(.top-autofill) .tooltip--data {\n top: 100%;\n left: 100%;\n border: 0.5px solid rgba(255, 255, 255, 0.2);\n border-radius: 6px;\n box-shadow: 0 10px 20px rgba(0, 0, 0, 0.32);\n}\n@media (prefers-color-scheme: dark) {\n :not(.top-autofill) .tooltip--data {\n border: 1px solid rgba(255, 255, 255, 0.2);\n }\n}\n:not(.top-autofill) .tooltip--email {\n top: calc(100% + 6px);\n right: calc(100% - 48px);\n padding: 8px;\n border: 1px solid #D0D0D0;\n border-radius: 10px;\n background-color: #FFFFFF;\n font-size: 14px;\n line-height: 1.3;\n color: #333333;\n box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);\n}\n.tooltip--email__caret {\n position: absolute;\n transform: translate(-1000px, -1000px);\n z-index: 2147483647;\n}\n.tooltip--email__caret::before,\n.tooltip--email__caret::after {\n content: \"\";\n width: 0;\n height: 0;\n border-left: 10px solid transparent;\n border-right: 10px solid transparent;\n display: block;\n border-bottom: 8px solid #D0D0D0;\n position: absolute;\n right: -28px;\n}\n.tooltip--email__caret::before {\n border-bottom-color: #D0D0D0;\n top: -1px;\n}\n.tooltip--email__caret::after {\n border-bottom-color: #FFFFFF;\n top: 0px;\n}\n\n/* Buttons */\n.tooltip__button {\n display: flex;\n width: 100%;\n padding: 8px 8px 8px 0px;\n font-family: inherit;\n color: inherit;\n background: transparent;\n border: none;\n border-radius: 6px;\n}\n.tooltip__button.currentFocus,\n.wrapper:not(.top-autofill) .tooltip__button:hover {\n background-color: #3969EF;\n color: #FFFFFF;\n}\n\n/* Data autofill tooltip specific */\n.tooltip__button--data {\n position: relative;\n min-height: 48px;\n flex-direction: row;\n justify-content: flex-start;\n font-size: inherit;\n font-weight: 500;\n line-height: 16px;\n text-align: left;\n border-radius: 3px;\n}\n.tooltip--data__item-container {\n max-height: 220px;\n overflow: auto;\n}\n.tooltip__button--data:first-child {\n margin-top: 0;\n}\n.tooltip__button--data:last-child {\n margin-bottom: 0;\n}\n.tooltip__button--data::before {\n content: '';\n flex-shrink: 0;\n display: block;\n width: 32px;\n height: 32px;\n margin: 0 8px;\n background-size: 20px 20px;\n background-repeat: no-repeat;\n background-position: center center;\n}\n#provider_locked::after {\n position: absolute;\n content: '';\n flex-shrink: 0;\n display: block;\n width: 32px;\n height: 32px;\n margin: 0 8px;\n background-size: 11px 13px;\n background-repeat: no-repeat;\n background-position: right bottom;\n}\n.tooltip__button--data.currentFocus:not(.tooltip__button--data--bitwarden)::before,\n.wrapper:not(.top-autofill) .tooltip__button--data:not(.tooltip__button--data--bitwarden):hover::before {\n filter: invert(100%);\n}\n@media (prefers-color-scheme: dark) {\n .tooltip__button--data:not(.tooltip__button--data--bitwarden)::before,\n .tooltip__button--data:not(.tooltip__button--data--bitwarden)::before {\n filter: invert(100%);\n opacity: .9;\n }\n}\n.tooltip__button__text-container {\n margin: auto 0;\n}\n.label {\n display: block;\n font-weight: 400;\n letter-spacing: -0.25px;\n color: rgba(0,0,0,.8);\n font-size: 13px;\n line-height: 1;\n}\n.label + .label {\n margin-top: 2px;\n}\n.label.label--medium {\n font-weight: 500;\n letter-spacing: -0.25px;\n color: rgba(0,0,0,.9);\n}\n.label.label--small {\n font-size: 11px;\n font-weight: 400;\n letter-spacing: 0.06px;\n color: rgba(0,0,0,0.6);\n}\n@media (prefers-color-scheme: dark) {\n .tooltip--data .label {\n color: #ffffff;\n }\n .tooltip--data .label--medium {\n color: #ffffff;\n }\n .tooltip--data .label--small {\n color: #cdcdcd;\n }\n}\n.tooltip__button.currentFocus .label,\n.wrapper:not(.top-autofill) .tooltip__button:hover .label {\n color: #FFFFFF;\n}\n\n.tooltip__button--manage {\n font-size: 13px;\n padding: 5px 9px;\n border-radius: 3px;\n margin: 0;\n}\n\n/* Icons */\n.tooltip__button--data--credentials::before,\n.tooltip__button--data--credentials__current::before {\n background-size: 28px 28px;\n background-image: url('');\n}\n.tooltip__button--data--credentials__new::before {\n background-size: 28px 28px;\n background-image: url('');\n}\n.tooltip__button--data--creditCards::before {\n background-image: url('');\n}\n.tooltip__button--data--identities::before {\n background-image: url('');\n}\n.tooltip__button--data--credentials.tooltip__button--data--bitwarden::before {\n background-image: url('');\n}\n#provider_locked:after {\n background-image: url('');\n}\n\nhr {\n display: block;\n margin: 5px 9px;\n border: none; /* reset the border */\n border-top: 1px solid rgba(0,0,0,.1);\n}\n\nhr:first-child {\n display: none;\n}\n\n@media (prefers-color-scheme: dark) {\n hr {\n border-top: 1px solid rgba(255,255,255,.2);\n }\n}\n\n#privateAddress {\n align-items: flex-start;\n}\n#personalAddress::before,\n#privateAddress::before,\n#incontextSignup::before,\n#personalAddress.currentFocus::before,\n#personalAddress:hover::before,\n#privateAddress.currentFocus::before,\n#privateAddress:hover::before {\n filter: none;\n /* This is the same icon as `daxBase64` in `src/Form/logo-svg.js` */\n background-image: url('');\n}\n\n/* Email tooltip specific */\n.tooltip__button--email {\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n font-size: 14px;\n padding: 4px 8px;\n}\n.tooltip__button--email__primary-text {\n font-weight: bold;\n}\n.tooltip__button--email__secondary-text {\n font-size: 12px;\n}\n\n/* Email Protection signup notice */\n:not(.top-autofill) .tooltip--email-signup {\n text-align: left;\n color: #222222;\n padding: 16px 20px;\n width: 380px;\n}\n\n.tooltip--email-signup h1 {\n font-weight: 700;\n font-size: 16px;\n line-height: 1.5;\n margin: 0;\n}\n\n.tooltip--email-signup p {\n font-weight: 400;\n font-size: 14px;\n line-height: 1.4;\n}\n\n.notice-controls {\n display: flex;\n}\n\n.tooltip--email-signup .notice-controls > * {\n border-radius: 8px;\n border: 0;\n cursor: pointer;\n display: inline-block;\n font-family: inherit;\n font-style: normal;\n font-weight: bold;\n padding: 8px 12px;\n text-decoration: none;\n}\n\n.notice-controls .ghost {\n margin-left: 1rem;\n}\n\n.tooltip--email-signup a.primary {\n background: #3969EF;\n color: #fff;\n}\n\n.tooltip--email-signup a.primary:hover,\n.tooltip--email-signup a.primary:focus {\n background: #2b55ca;\n}\n\n.tooltip--email-signup a.primary:active {\n background: #1e42a4;\n}\n\n.tooltip--email-signup button.ghost {\n background: transparent;\n color: #3969EF;\n}\n\n.tooltip--email-signup button.ghost:hover,\n.tooltip--email-signup button.ghost:focus {\n background-color: rgba(0, 0, 0, 0.06);\n color: #2b55ca;\n}\n\n.tooltip--email-signup button.ghost:active {\n background-color: rgba(0, 0, 0, 0.12);\n color: #1e42a4;\n}\n\n.tooltip--email-signup button.close-tooltip {\n background-color: transparent;\n background-image: url();\n background-position: center center;\n background-repeat: no-repeat;\n border: 0;\n cursor: pointer;\n padding: 16px;\n position: absolute;\n right: 12px;\n top: 12px;\n}\n"; +const CSS_STYLES = exports.CSS_STYLES = ":root {\n color-scheme: light dark;\n}\n\n.wrapper *, .wrapper *::before, .wrapper *::after {\n box-sizing: border-box;\n}\n.wrapper {\n position: fixed;\n top: 0;\n left: 0;\n padding: 0;\n font-family: 'DDG_ProximaNova', 'Proxima Nova', system-ui, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu',\n 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;\n -webkit-font-smoothing: antialiased;\n z-index: 2147483647;\n}\n.wrapper--data {\n font-family: 'SF Pro Text', system-ui, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu',\n 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;\n}\n:not(.top-autofill) .tooltip {\n position: absolute;\n width: 300px;\n max-width: calc(100vw - 25px);\n transform: translate(-1000px, -1000px);\n z-index: 2147483647;\n}\n.tooltip--data, #topAutofill {\n background-color: rgba(242, 240, 240, 1);\n -webkit-backdrop-filter: blur(40px);\n backdrop-filter: blur(40px);\n}\n@media (prefers-color-scheme: dark) {\n .tooltip--data, #topAutofill {\n background: rgb(100, 98, 102, .9);\n }\n}\n.tooltip--data {\n padding: 6px;\n font-size: 13px;\n line-height: 14px;\n width: 315px;\n max-height: 290px;\n overflow-y: auto;\n}\n.top-autofill .tooltip--data {\n min-height: 100vh;\n}\n.tooltip--data.tooltip--incontext-signup {\n width: 360px;\n}\n:not(.top-autofill) .tooltip--data {\n top: 100%;\n left: 100%;\n border: 0.5px solid rgba(255, 255, 255, 0.2);\n border-radius: 6px;\n box-shadow: 0 10px 20px rgba(0, 0, 0, 0.32);\n}\n@media (prefers-color-scheme: dark) {\n :not(.top-autofill) .tooltip--data {\n border: 1px solid rgba(255, 255, 255, 0.2);\n }\n}\n:not(.top-autofill) .tooltip--email {\n top: calc(100% + 6px);\n right: calc(100% - 48px);\n padding: 8px;\n border: 1px solid #D0D0D0;\n border-radius: 10px;\n background-color: #FFFFFF;\n font-size: 14px;\n line-height: 1.3;\n color: #333333;\n box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);\n}\n.tooltip--email__caret {\n position: absolute;\n transform: translate(-1000px, -1000px);\n z-index: 2147483647;\n}\n.tooltip--email__caret::before,\n.tooltip--email__caret::after {\n content: \"\";\n width: 0;\n height: 0;\n border-left: 10px solid transparent;\n border-right: 10px solid transparent;\n display: block;\n border-bottom: 8px solid #D0D0D0;\n position: absolute;\n right: -28px;\n}\n.tooltip--email__caret::before {\n border-bottom-color: #D0D0D0;\n top: -1px;\n}\n.tooltip--email__caret::after {\n border-bottom-color: #FFFFFF;\n top: 0px;\n}\n\n/* Buttons */\n.tooltip__button {\n display: flex;\n width: 100%;\n padding: 8px 8px 8px 0px;\n font-family: inherit;\n color: inherit;\n background: transparent;\n border: none;\n border-radius: 6px;\n}\n.tooltip__button.currentFocus,\n.wrapper:not(.top-autofill) .tooltip__button:hover {\n background-color: #3969EF;\n color: #FFFFFF;\n}\n\n/* Data autofill tooltip specific */\n.tooltip__button--data {\n position: relative;\n min-height: 48px;\n flex-direction: row;\n justify-content: flex-start;\n font-size: inherit;\n font-weight: 500;\n line-height: 16px;\n text-align: left;\n border-radius: 3px;\n}\n.tooltip--data__item-container {\n max-height: 220px;\n overflow: auto;\n}\n.tooltip__button--data:first-child {\n margin-top: 0;\n}\n.tooltip__button--data:last-child {\n margin-bottom: 0;\n}\n.tooltip__button--data::before {\n content: '';\n flex-shrink: 0;\n display: block;\n width: 32px;\n height: 32px;\n margin: 0 8px;\n background-size: 20px 20px;\n background-repeat: no-repeat;\n background-position: center center;\n}\n#provider_locked::after {\n position: absolute;\n content: '';\n flex-shrink: 0;\n display: block;\n width: 32px;\n height: 32px;\n margin: 0 8px;\n background-size: 11px 13px;\n background-repeat: no-repeat;\n background-position: right bottom;\n}\n.tooltip__button--data.currentFocus:not(.tooltip__button--data--bitwarden)::before,\n.wrapper:not(.top-autofill) .tooltip__button--data:not(.tooltip__button--data--bitwarden):hover::before {\n filter: invert(100%);\n}\n@media (prefers-color-scheme: dark) {\n .tooltip__button--data:not(.tooltip__button--data--bitwarden)::before,\n .tooltip__button--data:not(.tooltip__button--data--bitwarden)::before {\n filter: invert(100%);\n opacity: .9;\n }\n}\n.tooltip__button__text-container {\n margin: auto 0;\n}\n.label {\n display: block;\n font-weight: 400;\n letter-spacing: -0.25px;\n color: rgba(0,0,0,.8);\n font-size: 13px;\n line-height: 1;\n}\n.label + .label {\n margin-top: 2px;\n}\n.label.label--medium {\n font-weight: 500;\n letter-spacing: -0.25px;\n color: rgba(0,0,0,.9);\n}\n.label.label--small {\n font-size: 11px;\n font-weight: 400;\n letter-spacing: 0.06px;\n color: rgba(0,0,0,0.6);\n}\n@media (prefers-color-scheme: dark) {\n .tooltip--data .label {\n color: #ffffff;\n }\n .tooltip--data .label--medium {\n color: #ffffff;\n }\n .tooltip--data .label--small {\n color: #cdcdcd;\n }\n}\n.tooltip__button.currentFocus .label,\n.wrapper:not(.top-autofill) .tooltip__button:hover .label {\n color: #FFFFFF;\n}\n\n.tooltip__button--manage {\n font-size: 13px;\n padding: 5px 9px;\n border-radius: 3px;\n margin: 0;\n}\n\n/* Icons */\n.tooltip__button--data--credentials::before,\n.tooltip__button--data--credentials__current::before {\n background-size: 28px 28px;\n background-image: url('');\n}\n.tooltip__button--data--credentials__new::before {\n background-size: 28px 28px;\n background-image: url('');\n}\n.tooltip__button--data--creditCards::before {\n background-image: url('');\n}\n.tooltip__button--data--identities::before {\n background-image: url('');\n}\n.tooltip__button--data--credentials.tooltip__button--data--bitwarden::before,\n.tooltip__button--data--credentials__current.tooltip__button--data--bitwarden::before {\n background-image: url('');\n}\n#provider_locked:after {\n background-image: url('');\n}\n\nhr {\n display: block;\n margin: 5px 9px;\n border: none; /* reset the border */\n border-top: 1px solid rgba(0,0,0,.1);\n}\n\nhr:first-child {\n display: none;\n}\n\n@media (prefers-color-scheme: dark) {\n hr {\n border-top: 1px solid rgba(255,255,255,.2);\n }\n}\n\n#privateAddress {\n align-items: flex-start;\n}\n#personalAddress::before,\n#privateAddress::before,\n#incontextSignup::before,\n#personalAddress.currentFocus::before,\n#personalAddress:hover::before,\n#privateAddress.currentFocus::before,\n#privateAddress:hover::before {\n filter: none;\n /* This is the same icon as `daxBase64` in `src/Form/logo-svg.js` */\n background-image: url('');\n}\n\n/* Email tooltip specific */\n.tooltip__button--email {\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n font-size: 14px;\n padding: 4px 8px;\n}\n.tooltip__button--email__primary-text {\n font-weight: bold;\n}\n.tooltip__button--email__secondary-text {\n font-size: 12px;\n}\n\n/* Email Protection signup notice */\n:not(.top-autofill) .tooltip--email-signup {\n text-align: left;\n color: #222222;\n padding: 16px 20px;\n width: 380px;\n}\n\n.tooltip--email-signup h1 {\n font-weight: 700;\n font-size: 16px;\n line-height: 1.5;\n margin: 0;\n}\n\n.tooltip--email-signup p {\n font-weight: 400;\n font-size: 14px;\n line-height: 1.4;\n}\n\n.notice-controls {\n display: flex;\n}\n\n.tooltip--email-signup .notice-controls > * {\n border-radius: 8px;\n border: 0;\n cursor: pointer;\n display: inline-block;\n font-family: inherit;\n font-style: normal;\n font-weight: bold;\n padding: 8px 12px;\n text-decoration: none;\n}\n\n.notice-controls .ghost {\n margin-left: 1rem;\n}\n\n.tooltip--email-signup a.primary {\n background: #3969EF;\n color: #fff;\n}\n\n.tooltip--email-signup a.primary:hover,\n.tooltip--email-signup a.primary:focus {\n background: #2b55ca;\n}\n\n.tooltip--email-signup a.primary:active {\n background: #1e42a4;\n}\n\n.tooltip--email-signup button.ghost {\n background: transparent;\n color: #3969EF;\n}\n\n.tooltip--email-signup button.ghost:hover,\n.tooltip--email-signup button.ghost:focus {\n background-color: rgba(0, 0, 0, 0.06);\n color: #2b55ca;\n}\n\n.tooltip--email-signup button.ghost:active {\n background-color: rgba(0, 0, 0, 0.12);\n color: #1e42a4;\n}\n\n.tooltip--email-signup button.close-tooltip {\n background-color: transparent;\n background-image: url();\n background-position: center center;\n background-repeat: no-repeat;\n border: 0;\n cursor: pointer;\n padding: 16px;\n position: absolute;\n right: 12px;\n top: 12px;\n}\n"; -},{}],51:[function(require,module,exports){ +},{}],52:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -12341,6 +12311,7 @@ exports.wasAutofilledByChrome = void 0; exports.whenIdle = whenIdle; var _matching = require("./Form/matching.js"); var _constants = require("./constants.js"); +var _appleUtils = require("@duckduckgo/content-scope-scripts/src/apple-utils"); const SIGN_IN_MSG = exports.SIGN_IN_MSG = { signMeIn: true }; @@ -12375,15 +12346,19 @@ const sendAndWaitForAnswer = (msgOrFn, expectedResponse) => { /** * @param {Pick} globalConfig - * @param [processConfig] * @return {boolean} */ exports.sendAndWaitForAnswer = sendAndWaitForAnswer; -const autofillEnabled = (globalConfig, processConfig) => { +const autofillEnabled = globalConfig => { if (!globalConfig.contentScope) { // Return enabled for platforms that haven't implemented the config yet return true; } + // already processed? this handles an edgecase in the extension where the config is already processed + if ('site' in globalConfig.contentScope) { + const enabled = isAutofillEnabledFromProcessedConfig(globalConfig.contentScope); + return enabled; + } const { contentScope, userUnprotectedDomains, @@ -12391,7 +12366,7 @@ const autofillEnabled = (globalConfig, processConfig) => { } = globalConfig; // Check config on Apple platforms - const processedConfig = processConfig(contentScope, userUnprotectedDomains, userPreferences); + const processedConfig = (0, _appleUtils.processConfig)(contentScope, userUnprotectedDomains, userPreferences); return isAutofillEnabledFromProcessedConfig(processedConfig); }; exports.autofillEnabled = autofillEnabled; @@ -12926,7 +12901,7 @@ function getActiveElement() { return innerActiveElement; } -},{"./Form/matching.js":33,"./constants.js":54}],52:[function(require,module,exports){ +},{"./Form/matching.js":33,"./constants.js":55,"@duckduckgo/content-scope-scripts/src/apple-utils":1}],53:[function(require,module,exports){ "use strict"; require("./requestIdleCallback.js"); @@ -12957,7 +12932,7 @@ var _autofillUtils = require("./autofill-utils.js"); } })(); -},{"./DeviceInterface.js":12,"./autofill-utils.js":51,"./requestIdleCallback.js":63}],53:[function(require,module,exports){ +},{"./DeviceInterface.js":12,"./autofill-utils.js":52,"./requestIdleCallback.js":64}],54:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13010,15 +12985,12 @@ function createGlobalConfig(overrides) { // The native layer will inject a randomised secret here and use it to verify the origin let secret = 'PLACEHOLDER_SECRET'; - /** - * The user agent check will not be needed here once `android` supports `userPreferences?.platform.name` - */ // @ts-ignore - const isAndroid = userPreferences?.platform.name === 'android' || /Android.*DuckDuckGo\/\d/i.test(window.navigator.userAgent); + const isAndroid = userPreferences?.platform.name === 'android'; // @ts-ignore - const isDDGApp = ['ios', 'android', 'macos', 'windows'].includes(userPreferences?.platform.name) || isAndroid || isWindows; + const isDDGApp = ['ios', 'android', 'macos', 'windows'].includes(userPreferences?.platform.name) || isWindows; // @ts-ignore - const isMobileApp = ['ios', 'android'].includes(userPreferences?.platform.name) || isAndroid; + const isMobileApp = ['ios', 'android'].includes(userPreferences?.platform.name); const isFirefox = navigator.userAgent.includes('Firefox'); const isDDGDomain = Boolean(window.location.href.match(DDG_DOMAIN_REGEX)); const isExtension = false; @@ -13046,7 +13018,7 @@ function createGlobalConfig(overrides) { return config; } -},{}],54:[function(require,module,exports){ +},{}],55:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13063,7 +13035,7 @@ const constants = exports.constants = { MAX_FORM_RESCANS: 50 }; -},{}],55:[function(require,module,exports){ +},{}],56:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13309,7 +13281,7 @@ class ShowInContextEmailProtectionSignupPromptCall extends _deviceApi.DeviceApiC } exports.ShowInContextEmailProtectionSignupPromptCall = ShowInContextEmailProtectionSignupPromptCall; -},{"../../../packages/device-api":2,"./validators.zod.js":56}],56:[function(require,module,exports){ +},{"../../../packages/device-api":2,"./validators.zod.js":57}],57:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13356,7 +13328,7 @@ const askToUnlockProviderResultSchema = exports.askToUnlockProviderResultSchema const checkCredentialsProviderStatusResultSchema = exports.checkCredentialsProviderStatusResultSchema = null; const apiSchema = exports.apiSchema = null; -},{}],57:[function(require,module,exports){ +},{}],58:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13382,7 +13354,7 @@ class GetAlias extends _index.DeviceApiCall { } exports.GetAlias = GetAlias; -},{"../../packages/device-api/index.js":2,"./__generated__/validators.zod.js":56}],58:[function(require,module,exports){ +},{"../../packages/device-api/index.js":2,"./__generated__/validators.zod.js":57}],59:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13525,7 +13497,7 @@ function androidSpecificAvailableInputTypes(globalConfig) { }; } -},{"../../../packages/device-api/index.js":2,"../__generated__/deviceApiCalls.js":55}],59:[function(require,module,exports){ +},{"../../../packages/device-api/index.js":2,"../__generated__/deviceApiCalls.js":56}],60:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13568,7 +13540,7 @@ class AppleTransport extends _index.DeviceApiTransport { } exports.AppleTransport = AppleTransport; -},{"../../../packages/device-api/index.js":2,"../../../packages/messaging/messaging.js":5}],60:[function(require,module,exports){ +},{"../../../packages/device-api/index.js":2,"../../../packages/messaging/messaging.js":5}],61:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13642,7 +13614,7 @@ async function extensionSpecificRuntimeConfiguration(deviceApi) { } }, // @ts-ignore - userUnprotectedDomains: deviceApi.config?.userUnprotectedDomains + userUnprotectedDomains: deviceApi.config?.userUnprotectedDomains || [] } }; } @@ -13720,7 +13692,7 @@ async function extensionSpecificSetIncontextSignupPermanentlyDismissedAtCall(par }); } -},{"../../../packages/device-api/index.js":2,"../../Settings.js":40,"../../autofill-utils.js":51,"../__generated__/deviceApiCalls.js":55}],61:[function(require,module,exports){ +},{"../../../packages/device-api/index.js":2,"../../Settings.js":40,"../../autofill-utils.js":52,"../__generated__/deviceApiCalls.js":56}],62:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13764,7 +13736,7 @@ function createTransport(globalConfig) { return new _extensionTransport.ExtensionTransport(globalConfig); } -},{"./android.transport.js":58,"./apple.transport.js":59,"./extension.transport.js":60,"./windows.transport.js":62}],62:[function(require,module,exports){ +},{"./android.transport.js":59,"./apple.transport.js":60,"./extension.transport.js":61,"./windows.transport.js":63}],63:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13849,7 +13821,7 @@ function waitForWindowsResponse(responseId, options) { }); } -},{"../../../packages/device-api/index.js":2}],63:[function(require,module,exports){ +},{"../../../packages/device-api/index.js":2}],64:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { @@ -13892,4 +13864,4 @@ window.cancelIdleCallback = window.cancelIdleCallback || function (id) { }; var _default = exports.default = {}; -},{}]},{},[52]); +},{}]},{},[53]); diff --git a/node_modules/@duckduckgo/autofill/dist/shared-credentials.json b/node_modules/@duckduckgo/autofill/dist/shared-credentials.json index 0715247d99c7..f00f48ac322f 100644 --- a/node_modules/@duckduckgo/autofill/dist/shared-credentials.json +++ b/node_modules/@duckduckgo/autofill/dist/shared-credentials.json @@ -371,6 +371,22 @@ "profile.callofduty.com" ] }, + { + "from": [ + "scottscheapflights.com" + ], + "to": [ + "going.com" + ], + "fromDomainsAreObsoleted": true + }, + { + "shared": [ + "taxhawk.com", + "freetaxusa.com", + "express1040.com" + ] + }, { "from": [ "transferwise.com" diff --git a/package-lock.json b/package-lock.json index d00ae7402b3c..154be54a6bfe 100644 --- a/package-lock.json +++ b/package-lock.json @@ -9,7 +9,7 @@ "version": "1.0.0", "dependencies": { "@duckduckgo/autoconsent": "^10.3.0", - "@duckduckgo/autofill": "github:duckduckgo/duckduckgo-autofill#10.1.0", + "@duckduckgo/autofill": "github:duckduckgo/duckduckgo-autofill#10.2.0", "@duckduckgo/content-scope-scripts": "github:duckduckgo/content-scope-scripts#5.5.0", "@duckduckgo/privacy-dashboard": "github:duckduckgo/privacy-dashboard#3.0.0", "@duckduckgo/privacy-reference-tests": "github:duckduckgo/privacy-reference-tests#1708702034" @@ -64,9 +64,8 @@ "integrity": "sha512-dUf37qkaYDuXEytU9mNNLGw28S1t1M1dFnvMHZDV9BpINVJeAl1ye7CmlABuGlDs6URrp2ZLZ5IxcKQhQglYcw==" }, "node_modules/@duckduckgo/autofill": { - "resolved": "git+ssh://git@github.com/duckduckgo/duckduckgo-autofill.git#03d3e3a959dd75afbe8c59b5a203ea676d37555d", - "hasInstallScript": true, - "license": "Apache-2.0" + "resolved": "git+ssh://git@github.com/duckduckgo/duckduckgo-autofill.git#6493e296934bf09277c03df45f11f4619711cb24", + "hasInstallScript": true }, "node_modules/@duckduckgo/content-scope-scripts": { "resolved": "git+ssh://git@github.com/duckduckgo/content-scope-scripts.git#a9a0aeb0d259930406a0337ccc719c9afa8b575f", diff --git a/package.json b/package.json index 8d97c86859e8..698c6a74cb06 100644 --- a/package.json +++ b/package.json @@ -15,7 +15,7 @@ }, "dependencies": { "@duckduckgo/autoconsent": "^10.3.0", - "@duckduckgo/autofill": "github:duckduckgo/duckduckgo-autofill#10.1.0", + "@duckduckgo/autofill": "github:duckduckgo/duckduckgo-autofill#10.2.0", "@duckduckgo/content-scope-scripts": "github:duckduckgo/content-scope-scripts#5.5.0", "@duckduckgo/privacy-dashboard": "github:duckduckgo/privacy-dashboard#3.0.0", "@duckduckgo/privacy-reference-tests": "github:duckduckgo/privacy-reference-tests#1708702034"