Research
Security News
Malicious npm Package Targets Solana Developers and Hijacks Funds
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
Ok! Lets say there is a awesome ruby gem you want to use in your project and it haven't been updated for a long time. This is a ruby 2.3.1 and rails 5 updated version of youtube_it.
tubeclip is the most complete Ruby client for the YouTube GData API. It provides an easy way to access the latest and most complete access to YouTube's video API. In comparison with the earlier Youtube interfaces, this new API and library offers much-improved flexibility around executing complex search queries to obtain well-targeted video search results. In addition, standard video management including but not limited to uploading, deleting, updating, like, dislike, ratings and comments.
Add this line to your application's Gemfile:
gem 'tubeclip'
And then execute:
$ bundle
Or install it yourself as:
$ gem install tubeclip
Note: Do forget to create a youtube account, create a developer key here http://code.google.com/apis/youtube/dashboard and tubeclip supports ClientLogin(YouTube account), OAuth or AuthSub authentication methods.
You can checkout this SitePoint Youtube on rails tutorial . Please use tubeclip gem or just use youtube_it gem and rails 3/4
Important: The Account Authentication API for OAuth 1.0, AuthSub and Client Login has been officially deprecated as of April 20, 2012. It will continue to work as per our deprecation policy(https://developers.google.com/accounts/terms), but we encourage you to migrate to OAuth 2.0 authentication as soon as possible. If you are building a new application, you should use OAuth 2.0 authentication.
Creating a client:
$ require 'tubeclip'
$ client = Tubeclip::Client.new
Client with developer key:
$ client = Tubeclip::Client.new(:dev_key => "developer_key")
Client with youtube account and developer key:
$ client = Tubeclip::Client.new(:username => "youtube_username", :password => "youtube_passwd", :dev_key => "developer_key")
Client with AuthSub:
$ client = Tubeclip::AuthSubClient.new(:token => "token" , :dev_key => "developer_key")
Client with OAuth:
$ client = Tubeclip::OAuthClient.new("consumer_key", "consumer_secret", "youtube_username", "developer_key")
$ client.authorize_from_access("access_token", "access_secret")
Client with OAuth2:
$ client = Tubeclip::OAuth2Client.new(client_access_token: "access_token", client_refresh_token: "refresh_token", client_id: "client_id", client_secret: "client_secret", dev_key: "dev_key", expires_at: "expiration time")
If your access token is still valid (be careful, access tokens may only be valid for about 1 hour), you can use the client directly. If you want to refresh the access token using the refresh token just do:
$ client.refresh_access_token!
you can use multiple profiles in the same account like that
$ profiles = client.profiles(['username1','username2'])
$ profiles['username1'].username, "username1"
Note: Each type of client enables searching capabilities.
Basic Queries:
$ client.videos_by(:query => "penguin")
$ client.videos_by(:query => "penguin", :page => 2, :per_page => 15)
$ client.videos_by(:query => "penguin", :restriction => "DE")
$ client.videos_by(:query => "penguin", :author => "liz")
$ client.videos_by(:tags => ['tiger', 'leopard'])
$ client.videos_by(:categories => [:news, :sports])
$ client.videos_by(:categories => [:news, :sports], :tags => ['soccer', 'football'])
$ client.videos_by(:user => 'liz')
$ client.videos_by(:favorites, :user => 'liz')
$ client.video_by("FQK1URcxmb4")
$ client.video_by("https://www.youtube.com/watch?v=QsbmrCtiEUU")
$ client.video_by_user("chebyte","FQK1URcxmb4")
Standard Queries:
$ client.videos_by(:most_viewed)
$ client.videos_by(:most_linked, :page => 3)
$ client.videos_by(:top_rated, :time => :today)
$ client.get_all_videos(:top_rated, :time => :today)
$ client.videos_by(:top_rated, :region => "RU", :category => "News")
Advanced Queries (with boolean operators OR (either), AND (include), NOT (exclude)): $ client.videos_by(:categories => { :either => [:news, :sports], :exclude => [:comedy] }, :tags => { :include => ['football'], :exclude => ['soccer'] })
Custom Query Params You can use custom query params like that:
$ client.videos_by(:query => "penguin", :safe_search => "strict")
$ client.videos_by(:query => "penguin", :duration => "long")
$ client.videos_by(:query => "penguin", :hd => "true")
$ client.videos_by(:query => "penguin", :region => "AR")
you can see more options here https://developers.google.com/youtube/2.0/reference#yt_format
Fields Parameter(experimental features): Return videos more than 1000 views
$ client.videos_by(:fields => {:view_count => "1000"})
Filter by date
$ client.videos_by(:fields => {:published => (Date.today)})
$ client.videos_by(:fields => {:recorded => (Date.today)})
Filter by date with range
$ client.videos_by(:fields => {:published => ((Date.today - 30)..(Date.today))})
$ client.videos_by(:fields => {:recorded => ((Date.today - 30)..(Date.today))})
Note: These queries do not find private videos! Use these methods instead:
$ client.my_video("FQK1URcxmb4")
$ client.my_videos(:query => "penguin")
Note: YouTube account, OAuth or AuthSub enables video management.
Upload Video:
$ client.video_upload(File.open("test.mov"), :title => "test",:description => 'some description', :category => 'People',:keywords => %w[cool blah test])
Upload Remote Video:
$ client.video_upload("http://url/myvideo.mp4", :title => "test",:description => 'some description', :category => 'People',:keywords => %w[cool blah test])
Upload Video With A Developer Tag (Note the tags are not immediately available):
$ client.video_upload(File.open("test.mov"), :title => "test",:description => 'some description', :category => 'People',:keywords => %w[cool blah test], :dev_tag => 'tagdev')
Upload Video from url:
$ client.video_upload("http://media.railscasts.com/assets/episodes/videos/412-fast-rails-commands.mp4", :title => "test",:description => 'some description', :category => 'People',:keywords => %w[cool blah test])
Upload Private Video:
$ client.video_upload(File.open("test.mov"), :title => "test",:description => 'some description', :category => 'People',:keywords => %w[cool blah test], :private => true)
Update Video:
$ client.video_update("FQK1URcxmb4", :title => "new test",:description => 'new description', :category => 'People',:keywords => %w[cool blah test])
Delete Video:
$ client.video_delete("FQK1URcxmb4")
My Videos:
$ client.my_videos
My Video:
$ client.my_video(video_id)
Profile Details:
$ client.profile(user) #default: current user
List Comments:
$ client.comments(video_id)
Add A Comment:
$ client.add_comment(video_id, "test comment!")
Add A Reply Comment:
$ client.add_comment(video_id, "test reply!", :reply_to => another_comment)
Delete A Comment:
$ client.delete_comment(video_id, comment_id)
List Favorites:
$ client.favorites(user) # default: current user
Add Favorite:
$ client.add_favorite(video_id)
Delete Favorite:
$ client.delete_favorite(favorite_entry_id)
Like A Video:
$ client.like_video(video_id)
Dislike A Video:
$ client.dislike_video(video_id)
List Subscriptions:
$ client.subscriptions(user) # default: current user
Subscribe To A Channel:
$ client.subscribe_channel(channel_name)
Unsubscribe To A Channel:
$ client.unsubscribe_channel(subscription_id)
List New Subscription Videos:
$ client.new_subscription_videos(user) # default: current user
List Playlists:
$ client.playlists(user, order_by) # default: current user, position
for example you can get the videos of your playlist ordered by title
$ client.playlists(user, "title")
you can see more about options for order_by here: https://developers.google.com/youtube/2.0/reference#orderbysp
Select Playlist:
$ client.playlist(playlist_id)
Select All Videos From A Playlist:
$ playlist = client.playlist(playlist_id)
$ playlist.videos
Create Playlist:
$ playlist = client.add_playlist(:title => "new playlist", :description => "playlist description")
Delete Playlist:
$ client.delete_playlist(playlist_id)
Add Video To Playlist:
$ client.add_video_to_playlist(playlist_id, video_id, position)
Remove Video From Playlist:
$ client.delete_video_from_playlist(playlist_id, playlist_entry_id)
Update Position Video From Playlist:
$ client.update_position_video_from_playlist(playlist_id, playlist_entry_id, position)
Select All Videos From your Watch Later Playlist:
$ watcher_later = client.watcherlater(user) #default: current user
$ watcher_later.videos
Add Video To Watcher Later Playlist:
$ client.add_video_to_watchlater(video_id)
Remove Video From Watch Later Playlist:
$ client.delete_video_from_watchlater(watchlater_entry_id)
List Related Videos
$ video = client.video_by("https://www.youtube.com/watch?v=QsbmrCtiEUU&feature=player_embedded")
$ video.related.videos
Add Response Video
$ video.add_response(original_video_id, response_video_id)
Delete Response Video
$ video.delete_response(original_video_id, response_video_id)
List Response Videos
$ video = client.video_by("https://www.youtube.com/watch?v=QsbmrCtiEUU&feature=player_embedded")
$ video.responses.videos
you can list many videos at the same time
$ client.videos(['video_id_1', 'video_id_2',...])
You can give permissions in your videos, for example denied comments, rate, etc... you can read more there http://code.google.com/apis/youtube/2.0/reference.html#youtube_data_api_tag_yt:accessControl you have available the followings options:
:rate, :comment, :commentVote, :videoRespond, :list, :embed, :syndicate
with just two values:
allowed or denied
Example
client = Tubeclip::Client.new(:username => "youtube_username", :password => "youtube_passwd", :dev_key => "developer_key")
upload video with denied comments
client.video_upload(File.open("test.mov"), :title => "test",:description => 'some description', :category => 'People',:keywords => %w[cool blah test], :comment => "denied")
You can send a single PATCH request to add, replace and/or delete specific fields for a particular resource.
client.video_partial_update(video.unique_id, :list => 'denied', :embed => 'allowed')
You can get user activity with the followings params:
$ client.activity(user) #default current user
When uploading a video from your browser you need make a form upload with the followings params: $ upload_token(params, nexturl) params => params like :title => "title", :description => "description", :category => "People", :keywords => ["test"] nexturl => redirect to this url after upload
Controller def upload @upload_info = Tubeclip::Client.new.upload_token(params, videos_url) end
View (upload.html.erb) <% form_tag @upload_info[:url], :multipart => true do %> <%= hidden_field_tag :token, @upload_info[:token] %> <%= label_tag :file %> <%= file_field_tag :file %> <%= submit_tag "Upload video" %> <% end %>
If the videos has support for widescreen: $ video.embed_html_with_width(1280)
Note: you can specify width or just use the default of 1280.
Now you can embed videos without use flash using html5, usefull for mobiles that not support flash but has html5 browser
You can specify these options $ video.embed_html5({:class => 'video-player', :id => 'my-video', :width => '425', :height => '350', :frameborder => '1', :url_params => {:option_one => "value", :option_two => "value"}, fullscreen: true, :sandbox => "value"})
or just use with default options $ video.embed_html5 #default: width: 425, height: 350, frameborder: 0
Tubeclip passes all logs through the logger variable on the class itself. In Rails context, assign the Rails logger to that variable to collect the messages (don't forget to set the level to debug): $ Tubeclip.logger = RAILS_DEFAULT_LOGGER $ RAILS_DEFAULT_LOGGER.level = Logger::DEBUG
The gem is available as open source under the terms of the MIT License
Bug reports and pull requests are welcome on GitHub at https://github.com/zPhumzani/tubeclip. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.
FAQs
Unknown package
We found that tubeclip demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
Security News
Research
Socket researchers have discovered malicious npm packages targeting crypto developers, stealing credentials and wallet data using spyware delivered through typosquats of popular cryptographic libraries.
Security News
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.