Skip to content

Commit

Permalink
Merge pull request #8 from duckduckgo/ema/fix-platforms-breakages
Browse files Browse the repository at this point in the history
Fix breakages introduced on other platforms
  • Loading branch information
GioSensation authored Jul 5, 2021
2 parents 3f8b4d6 + 2849241 commit 2d6e7a3
Show file tree
Hide file tree
Showing 6 changed files with 48 additions and 41 deletions.
1 change: 1 addition & 0 deletions dist/autofill.css
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,7 @@
width: 36px;
height: 36px;
margin: auto 6px auto 0;
/* TODO: use dynamically from src/UI/img/ddgPasswordIcon.js */
background-image: url('');
background-size: cover;
}
Expand Down
51 changes: 28 additions & 23 deletions dist/autofill.js
Original file line number Diff line number Diff line change
Expand Up @@ -169,6 +169,8 @@ class ExtensionInterface extends InterfacePrototype {
constructor() {
super();

this.isDeviceSignedIn = () => this.hasLocalAddresses;

this.setupAutofill = ({
shouldLog
} = {
Expand Down Expand Up @@ -260,28 +262,24 @@ class AndroidInterface extends InterfacePrototype {
alias
}) => alias);

this.isDeviceSignedIn = () => new Promise(resolve => {
resolve(window.EmailInterface.isSignedIn() === 'true');
});
this.isDeviceSignedIn = () => window.EmailInterface.isSignedIn() === 'true';

this.setupAutofill = ({
shouldLog
} = {
shouldLog: false
}) => {
this.isDeviceSignedIn().then(signedIn => {
if (signedIn) {
notifyWebApp({
deviceSignedIn: {
value: true,
shouldLog
}
});
scanForInputs(this);
} else {
this.trySigningIn();
}
});
if (this.isDeviceSignedIn()) {
notifyWebApp({
deviceSignedIn: {
value: true,
shouldLog
}
});
scanForInputs(this);
} else {
this.trySigningIn();
}
};

this.storeUserData = ({
Expand Down Expand Up @@ -314,10 +312,13 @@ class AppleDeviceInterface extends InterfacePrototype {
await this.getAccounts();
}

const signedIn = await this.isDeviceSignedIn();
const signedIn = await this._checkDeviceSignedIn();

if (signedIn) {
await this.getAddresses();
if (isApp) {
await this.getAddresses();
}

notifyWebApp({
deviceSignedIn: {
value: true,
Expand Down Expand Up @@ -353,10 +354,13 @@ class AppleDeviceInterface extends InterfacePrototype {

this.refreshAlias = () => wkSend('emailHandlerRefreshAlias');

this.isDeviceSignedIn = async () => {
this._checkDeviceSignedIn = async () => {
const {
isAppSignedIn
} = await wkSendAndWait('emailHandlerCheckAppSignedInStatus');

this.isDeviceSignedIn = () => !!isAppSignedIn;

return !!isAppSignedIn;
};

Expand Down Expand Up @@ -662,7 +666,7 @@ class Form {
if (this.isLogin) {
if (this.Device.hasLocalCredentials) this.decorateInput(input);
} else {
if (this.Device.hasLocalAddresses && !input.matches(PASSWORD_SELECTOR)) {
if (this.Device.isDeviceSignedIn() && !input.matches(PASSWORD_SELECTOR)) {
this.decorateInput(input);
}
}
Expand Down Expand Up @@ -763,9 +767,7 @@ class FormAnalyzer {
constructor(form, input) {
this.form = form;
this.autofillSignal = 0;
this.signals = []; // Avoid autofill on our signup page

if (window.location.href.match(/^https:\/\/.+\.duckduckgo\.com\/email\/signup/i)) return this;
this.signals = [];
this.evaluateElAttributes(input, 3, true);
form ? this.evaluateForm() : this.evaluatePage();
return this;
Expand Down Expand Up @@ -1713,6 +1715,9 @@ const {
const forms = new Map(); // Accepts the DeviceInterface as an explicit dependency

const scanForInputs = DeviceInterface => {
// Avoid autofill on our signup page
if (window.location.href.match(/^https:\/\/.+\.duckduckgo\.com\/email\/choose-address/i)) return;

const getParentForm = input => {
if (input.form) return input.form;
let element = input; // traverse the DOM to search for related inputs
Expand Down
29 changes: 15 additions & 14 deletions src/DeviceInterface.js
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,8 @@ class ExtensionInterface extends InterfacePrototype {
constructor () {
super()

this.isDeviceSignedIn = () => this.hasLocalAddresses

this.setupAutofill = ({shouldLog} = {shouldLog: false}) => {
this.getAddresses().then(addresses => {
if (this.hasLocalAddresses) {
Expand Down Expand Up @@ -194,19 +196,15 @@ class AndroidInterface extends InterfacePrototype {
window.EmailInterface.showTooltip(), 'getAliasResponse')
.then(({alias}) => alias)

this.isDeviceSignedIn = () => new Promise(resolve => {
resolve(window.EmailInterface.isSignedIn() === 'true')
})
this.isDeviceSignedIn = () => window.EmailInterface.isSignedIn() === 'true'

this.setupAutofill = ({shouldLog} = {shouldLog: false}) => {
this.isDeviceSignedIn().then((signedIn) => {
if (signedIn) {
notifyWebApp({ deviceSignedIn: {value: true, shouldLog} })
scanForInputs(this)
} else {
this.trySigningIn()
}
})
if (this.isDeviceSignedIn()) {
notifyWebApp({ deviceSignedIn: {value: true, shouldLog} })
scanForInputs(this)
} else {
this.trySigningIn()
}
}

this.storeUserData = ({addUserData: {token, userName}}) =>
Expand All @@ -227,9 +225,11 @@ class AppleDeviceInterface extends InterfacePrototype {
await this.getAccounts()
}

const signedIn = await this.isDeviceSignedIn()
const signedIn = await this._checkDeviceSignedIn()
if (signedIn) {
await this.getAddresses()
if (isApp) {
await this.getAddresses()
}
notifyWebApp({ deviceSignedIn: {value: true, shouldLog} })
forms.forEach(form => form.redecorateAllInputs())
} else {
Expand Down Expand Up @@ -260,8 +260,9 @@ class AppleDeviceInterface extends InterfacePrototype {

this.refreshAlias = () => wkSend('emailHandlerRefreshAlias')

this.isDeviceSignedIn = async () => {
this._checkDeviceSignedIn = async () => {
const {isAppSignedIn} = await wkSendAndWait('emailHandlerCheckAppSignedInStatus')
this.isDeviceSignedIn = () => !!isAppSignedIn
return !!isAppSignedIn
}

Expand Down
2 changes: 1 addition & 1 deletion src/Form/Form.js
Original file line number Diff line number Diff line change
Expand Up @@ -181,7 +181,7 @@ class Form {
if (this.isLogin) {
if (this.Device.hasLocalCredentials) this.decorateInput(input)
} else {
if (this.Device.hasLocalAddresses && !input.matches(PASSWORD_SELECTOR)) {
if (this.Device.isDeviceSignedIn() && !input.matches(PASSWORD_SELECTOR)) {
this.decorateInput(input)
}
}
Expand Down
3 changes: 0 additions & 3 deletions src/Form/FormAnalyzer.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,6 @@ class FormAnalyzer {
this.autofillSignal = 0
this.signals = []

// Avoid autofill on our signup page
if (window.location.href.match(/^https:\/\/.+\.duckduckgo\.com\/email\/signup/i)) return this

this.evaluateElAttributes(input, 3, true)
form ? this.evaluateForm() : this.evaluatePage()
return this
Expand Down
3 changes: 3 additions & 0 deletions src/scanForInputs.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@ const forms = new Map()

// Accepts the DeviceInterface as an explicit dependency
const scanForInputs = (DeviceInterface) => {
// Avoid autofill on our signup page
if (window.location.href.match(/^https:\/\/.+\.duckduckgo\.com\/email\/choose-address/i)) return

const getParentForm = (input) => {
if (input.form) return input.form

Expand Down

0 comments on commit 2d6e7a3

Please sign in to comment.