Skip to content
This repository has been archived by the owner on Jul 14, 2022. It is now read-only.

Make the script work for modern (Fall 2017) activity page #19

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

landaire
Copy link

@landaire landaire commented Nov 19, 2017

As this stands right now this should not be merged since the code can be cleaned up and made better. There's a lot of weird stuff from me figuring out Selenium and Facebook's activity page weirdness.

Basically the changes are:

  • Wait for elements to be found by Selenium instead of using timing (for the most part -- some cases didn't work for this)
  • Add indicators of what was skipped, where errors happened, and what was hidden/deleted
  • Add support for passing in --days to delete posts older than N days
  • Add support for doing a dry run
  • Slightly different logic for loading the full activity. If you only keep scrolling down, eventually Facebook will stop loading activity past a certain point. For me it ended in 2012 when I had posts going back to 2008. I changed this logic so that the script will click on each of the years that are present on the right of the page which loads that activity, then it will go through and repeatedly click the "More Activity" button to load activity
  • After loading all activity posts start to be deleted. This logic is somewhat strange right now because the way I initially did this was to do some weirdness with scrolling to the element since Selenium's WebElement.click() function will literally emulate a mouse click at that coordinate rather than just triggering the action. This resulted in some weirdness with either the element being off-screen so it couldn't be clicked, the header getting in the way, or there not being enough room to show the full menu so Facebook wouldn't pop it. I ended up changing this logic so that instead I execute JavaScript to trigger the click() event which works a lot nicer but the old scroll logic remains
  • Some of the functions do too much and change behavior based off of an additional parameter which I don't really like and could modify
  • There's an off-by-one error of sorts where the final modal dialog for deleting items isn't clicked... not sure what the deal with this is but I think it has to do with the XPath for the modal.

I wanted to make the PR for awareness though and can clean this up in a bit.


This change is Reviewable

@asonawalla asonawalla self-requested a review November 20, 2017 14:18
@asonawalla asonawalla self-assigned this Nov 20, 2017
@asonawalla
Copy link
Owner

Awesome, thanks for doing this! Will take a look in the next day or two.

@asonawalla asonawalla removed their request for review November 20, 2017 14:20
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants