All notable changes to this project will be documented in this file.
For more information about changelogs, check Keep a Changelog and Vandamme.
- [BUGFIX] Fetch like count for more Facebook videos.
- [BUGFIX] Allow funky to scrape view count for more videos
- [BUGFIX] Fetch comment count, share count, like count for Facebook videos with different HTML.
- [ENHANCEMENT] Use 2.10 of Facebook Graph API (upgrade from 2.8).
- There will be deprecations in v2.8 of the Facebook Graph API soon. Check out the changelog.
- Funky API is not changed. (The same test is still passing)
- [BUGFIX] Fetch the comment count, with more Facebook videos.
- [FEATURE] Add ActiveSupport::Notification based instrumentation.
- [FEATURE] Raise Funky::CountersNotFound error when a video does not have its view count.
- [BUGFIX] Revert the change of version 0.2.29 and do not use request to get app access token.
- [ENHANCEMENT] Allow funky to scrape view count for more videos, by changing the way how to scrape.
- [BUGFIX] Test should pass when call Page#videos. Partly revert the change of version 0.2.28
- [ENHANCEMENT] Use request to get app access token. Do not use
app_id|app_secret
string.
- [FEATURE] Add
since
option when it calls Page#videos and Page#posts to reduce amount of requests when it gets only recent items.
- [BUGFIX] Fetch the correct view count even for non-English pages
- [ENHANCEMENT] Raise ContentNotFound if Page#find is called with an invalid URI
- [FEATURE] Retry up to 5 times if Facebook responds with error
- [BUGFIX] Raise Funky::ContentNotFound error when a page does not return
its name. This change will filter out cases a full url of website entered
as page_id argument of
Funky::Page#find
, instead of username.
- [FEATURE] Print out logs for each pagination
- [BUGFIX] Use cursor-based pagination for
Funky::Page#posts
to resolve infinite loop issue when the page has life events with old backdated time.
- [FEATURE] Add
Funky::Page#posts
. - [FEATURE] Add
Funky::Page#has_featured_video?
.
- [FEATURE] Add
Funky::Page#fan_count
.
- [BUGFIX] Fix
Funky::Page#videos
by adding condition for an edge case.
- [IMPROVEMENT] Retry 3 times after a server error or a socket error, to fetch data even with any temporary issue from Facebook.
- [ENHANCEMENT]
Funky::Page#videos
now fetches more videos by time-based pagination.
- [FEATURE] Add
Funky::Page.find
class method to find a page by its page ID. - [FEATURE] Add
Funky::Page#videos
instance method to list all videos under a page fetched by API call.
- [ENHANCEMENT] Video.where(id: [..ids..]) now works even with more than 50 ids.
- [BUGFIX] Return a string for the description field of a Funky::Video object even when the Facebook video has no description
- [ENHANCEMENT] Add the Funky::Page API to fetch name, username, location, city, state, zip, street, country, longitude, and latitude fields from the Facebook Graph API given a page ID.
- [BUGFIX] Correctly fetch data for videos that belong to a Facebook page with a username that contains URL-unsafe characters. For instance "https://www.facebook.com/KinoToPrzygoda /" (with a space) is a valid Facebook page URL.
- [ENHANCEMENT] Use 2.8 of Facebook Graph API (upgrade from 2.6).
- There were deprecations in v2.8 of the Facebook Graph API as well as additions documented in the changelog.
- The current API of Funky is not affected.
- [ENHANCEMENT] Parse new format of share & comment count in Facebook HTML
- [BUGFIX] Fix regular expression for likecount
- [ENHANCEMENT] Follow redirects when Facebook responds with 302
- [ENHANCEMENT] Parse new format of view count in Facebook HTML
- [ENHANCEMENT] Add a facebook page ID as a part of the Funky::Video API
- [ENHANCEMENT] Add a facebook page URL as a part of the Funky::Video API
- [BUGFIX] Allow a video ID to be parsed out of facebook video URLs with trailing slashes.
- [BUGFIX] Change the way that "like counts" are parsed now that Facebook has changed the structure of the HTML and can include multiple "likecounts" elements in the same page.
- [ENHANCEMENT] When Funky makes a request to an HTML page, Funky would now raise
Funky::ConnectionError
should the following errors occur: OpenSSL::SSL::SSLError, Errno::ETIMEDOUT, Errno::EHOSTUNREACH, Errno::ENETUNREACH, Errno::ECONNRESET, Net::OpenTimeout, SocketError
- [BUGFIX] Force scraping to use English-US version of Facebook by appending
locale=en_US
to the query string. This prevents cases where Funky's requests originate from non English speaking countries and receiving different HTML templates.
- [ENHANCEMENT] Allow Funky to also scrape view count that uses dot delimiters. Previously, it only scraped view count with comma delimiters.
- [ENHANCEMENT] Change the way views are scraped from a Facebook page, by not depending the regex on the word "Views". This has the added benefit of being able to scrape the Facebook pages that are not just in English, but also in Hebrew. Potentially, it could scrape from other languages too, but that is speculation for now.
- [FEATURE] Add
page_name
of a video found by API call (which isFunky::Video.where
)
- [BUGFIX] Single video id passed to the
Funky::Video.where
clause will not error even if the response is not 200. It would return an empty array.
- [FEATURE] Add method to find video by url,
Funky::Video.find_by_url!(url)
. The following URL formats are currently supported:
https://www.facebook.com/{page_name}/videos/vb.{alt_page_id}/{video_id}/
https://www.facebook.com/{page_name}/videos/{video_id}/
https://www.facebook.com/{page_id}/videos/{video_id}/
https://www.facebook.com/video.php?v={video_id}
How to upgrade
If your code never calls Funky::Video#view_count
, then you are good to go.
If it does, then be aware that Facebook has started displaying two types of
view counts in the video page: 'views from this post' and 'cumulative views'.
For coherence with the videos without this new type of page, view_count
will
always return the "views from this post" (whereas it was returning cumulative
views in 0.1.1)
- [ENHANCEMENT] Always return 'views from this post' in
Funky::Video#view_count
.
- [BUGFIX] Added support for scraping view count from the new cumulative views that Facebook recently started rolling out.
- [FEATURE] Added support for Facebook video data. Currently we can get the video id, length, description, created_time, picture, view_count, share_count, comment_count, and like_count.