fideloper / porter
Extendable link-parser and meta-data obtainer for various services such as Vimeo and Youtube
Installs: 1 689
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 3
Forks: 2
Open Issues: 0
Requires
- shuber/curl: dev-master
Requires (Dev)
- mockery/mockery: >=0.7.2
This package is auto-updated.
Last update: 2024-11-06 09:26:14 UTC
README
#Porter
Extendable url-parser thingy and meta-data obtainer for various services such as Youtube and Vimeo
What does it do?
Say you have a piece of content, maybe from a user on your site.
I love Sriracha sauce!!! I even put it on my Cinnamon Toast Struddle Crunch Tiger Blood Leprechaun cereal!
Here's a video review of it http://www.youtube.com/watch?v=GYamE6G1EZo,
and a spiffy ad for Sriracha Sauce!!! http://vimeo.com/41852814
You like how Twitter shows an embed and information about linked Youtube videos, so you figure
Hey, Twitter is cool! I'm gonna do exactly what Twitter does so I'm cool too!
Well you're in luck! Using this spicy library, you can grab the URLs from content and get meta information about them.
How do I use it?
$some_weirdos_comment = "I love Sriracha sauce!!! I even put it on my Cinnamon Toast Struddle Crunch Tiger Blood Leprechaun cereal! Here's a video review of it http://www.youtube.com/watch?v=GYamE6G1EZo, and a spiffy ad for Sriracha Sauce!!! http://vimeo.com/41852814"; $parser = new \Porter\Parser(); // I want YouTooooooob! $parser->addService( new \Porter\Service\Youtube() ); // I want Vimeooooooooo! $parser->addService( new \Porter\Service\Vimeo() ); $parsed_urls = $parser->parse( $parser->matchUrls($some_weirdos_comment) ); // ID's Parsed from URLs directly foreach ( $parsed_urls as $parsed ) { $item_id = $parsed->getId(); //Youtube: GYamE6G1EZo, Vimeo: 41852814 } // Now, let's get fancy with some API requests foreach ( $parsed_urls as $parsed ) { $meta = $parsed->getMetadata( new \Porter\Request\Curl() ); // stdClass of data }
Foreach service (Currently Youtube, Vimeo), you can get:
- Video ID
- Meta Data Available via public api
- ID
- Image
- Play Time
- Title
- etc
Contribute!
There's room for improvement. For instance:
- I've abstracted out a Request implementation, when the code using it pretty clearly expects a cURL request to happen (Gives it a URL to grab data from)
- Only supports Youtube/Vimeo at the moment (Flickr? Twitpic? etc etc)
- The Parser class loops through each service, and creates a new instance of each service on each iteration. Needed for multiple URLs, but I dislike the implementation.
Licence
MIT