twttr 0.0.1 → 0.0.5

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 0e5bcf2caf8b35685648f7ea2f2e3ded03f29a2d645c3fefd0dd201c40a29063
4
- data.tar.gz: e4abe1c561235477fa18e53a99712f6c81dff499a084597f05c076a7db47bdc1
3
+ metadata.gz: f243e0ac613090cfeabaeb49b72f9fa3cca1b210bf8578313d23ce264f7fb76e
4
+ data.tar.gz: 320ed5bcce042083e80be627237eab12459d3694a86b3033b576b03f65f6eca2
5
5
  SHA512:
6
- metadata.gz: ba330361302ab0f8cb28ab17235baae529674fd02b766a6e55c5e48b10fd960d682b4efcb05d594216cf40288606fb87f77b50fbe8f2ef66cfde75d2a075165a
7
- data.tar.gz: '04890ed05e20b2e710d3a3f7697b21823542da9e8e88e35e9361a73251d89b1a18a12a0dddd3dbf031cf390a3d344894b775cb80daf1b37978993c8e2d3ad6f5'
6
+ metadata.gz: 36181b93842dd22bdf49759f92e970a63b59121e3a025d229820fe75e0ce101d6eeafdb87459c063d3826b86d23e5908601d2ffb1f0e2a7e83da4261c4182cce
7
+ data.tar.gz: 8e44f6b807d3abe417b78a563bb341ba3297a193701846a06885ef6cf8f590bb16720d84647c9b723b51bb91d7c7ac2c519054bd042b59a8789ed6e1293eabbd
@@ -13,31 +13,33 @@ module Twttr
13
13
  # GET /2/users/:id/following
14
14
  # https://developer.twitter.com/en/docs/twitter-api/users/follows/api-reference/get-users-id-following
15
15
  #
16
+ # Returns paginated list of users followed by user_id.
17
+ #
16
18
  # @param user_id [String] The user ID whose following you would like to retrieve.
17
19
  # @param max_results [Integer] Max number of results per peage.
18
20
  # @param pagination_token [String] Initial page pagination token.
19
21
  # @yield [Array<Twttr::Model::User>] Users followed by page.
22
+ # @yield [String,NilClass] Pagination token.
20
23
  # @return [Array<Twttr::Model::User>] Users followed.
21
- # @return [String,NilClass] Pagination token.
22
- def following(user_id, max_results: nil, pagination_token: nil) # rubocop:disable Metrics/MethodLength
23
- loop do
24
- response = get(FOLLOWING_PATH, params: { user_id: user_id },
25
- query_params: {
26
- 'user.fields': config.user_fields,
27
- max_results: max_results,
28
- pagination_token: pagination_token
29
- }.compact)
24
+ def following(user_id, max_results: nil, pagination_token: nil, &block) # rubocop:disable Metrics/MethodLength, Metrics/AbcSize
25
+ response = get(FOLLOWING_PATH, params: { user_id: user_id },
26
+ query_params: {
27
+ 'user.fields': config.user_fields,
28
+ max_results: max_results,
29
+ pagination_token: pagination_token
30
+ }.compact)
31
+
32
+ return [] if response['meta']['result_count'].zero?
30
33
 
31
- users = response['data'].map { |v| Model::User.new(v, self) }
34
+ users = response['data'].map { |v| Model::User.new(v, self) }
32
35
 
33
- pagination_token = response['meta']['pagination_token']
36
+ pagination_token = response['meta']['pagination_token']
34
37
 
35
- return users, pagination_token unless block_given?
38
+ yield users, pagination_token if block_given?
36
39
 
37
- yield users, pagination_token
40
+ return users if pagination_token.nil?
38
41
 
39
- break if pagination_token.nil?
40
- end
42
+ users + following(user_id, pagination_token: pagination_token, &block)
41
43
  end
42
44
  end
43
45
  end
@@ -12,23 +12,62 @@ module Twttr
12
12
  USER_BY_USERNAME_PATH = "#{V2::V2_PATH}/users/by/username/%<username>s"
13
13
  USER_PATH = "#{V2::V2_PATH}/users/%<user_id>s"
14
14
 
15
+ # GET /2/users/:id/following
16
+ # https://developer.twitter.com/en/docs/twitter-api/users/follows/api-reference/get-users-id-following
17
+ #
18
+ # Returns paginated list of users followed by user_id.
19
+ #
20
+ # @param user_id [String] The user ID whose following you would like to retrieve.
21
+ # @param max_results [Integer] Max number of results per peage.
22
+ # @param pagination_token [String] Initial page pagination token.
23
+ # @yield [Array<Twttr::Model::User>] Users followed by page.
24
+ # @yield [String,NilClass] Pagination token.
25
+ # @return [Array<Twttr::Model::User>] Users followed.
26
+
27
+ # GET /2/users/me
28
+ # https://developer.twitter.com/en/docs/twitter-api/users/lookup/api-reference/get-users-me
29
+ #
30
+ # Returns current authenticated user
31
+ #
32
+ # @return [Twttr::Model::User] Current user.
15
33
  def me
16
34
  response = get(ME_PATH, query_params: { 'user.fields': config.user_fields })
17
35
  Model::User.new(response['data'], self)
18
36
  end
19
37
 
38
+ # GET /2/users/:id
39
+ # https://developer.twitter.com/en/docs/twitter-api/users/lookup/api-reference/get-users-id
40
+ #
41
+ # Returns target user by id
42
+ #
43
+ # @param user_id [String] Traget user id.
44
+ # @return [Twttr::Model::User] Target user.
20
45
  def user(user_id)
21
46
  response = get(USER_PATH, params: { user_id: user_id },
22
47
  query_params: { 'user.fields': config.user_fields })
23
48
  Model::User.new(response['data'], self)
24
49
  end
25
50
 
51
+ # GET /2/users/by/username/:username
52
+ # https://developer.twitter.com/en/docs/twitter-api/users/lookup/api-reference/get-users-by-username-username
53
+ #
54
+ # Returns target user by username
55
+ #
56
+ # @param username [String] Traget username.
57
+ # @return [Twttr::Model::User] Target user.
26
58
  def user_by_username(username)
27
59
  response = get(USER_BY_USERNAME_PATH, params: { username: username },
28
60
  query_params: { 'user.fields': config.user_fields })
29
61
  Model::User.new(response['data'], self)
30
62
  end
31
63
 
64
+ # GET /2/users
65
+ # https://developer.twitter.com/en/docs/twitter-api/users/lookup/api-reference/get-users
66
+ #
67
+ # Returns target users by id
68
+ #
69
+ # @param user_ids [Array<String>] Traget user ids.
70
+ # @return [Array<Twttr::Model::User>] Target users.
32
71
  def users(user_ids)
33
72
  response = get(USERS_PATH,
34
73
  query_params: { ids: user_ids.join(','), 'user.fields': config.user_fields })
@@ -15,8 +15,20 @@ module Twttr
15
15
  @client = client
16
16
  end
17
17
 
18
- def following(pagination_token: nil, &block)
19
- client.following(id, pagination_token: pagination_token, &block)
18
+ # Forwards to Follows#following setting user_id to current user's id.
19
+ #
20
+ # GET /2/users/:id/following
21
+ # https://developer.twitter.com/en/docs/twitter-api/users/follows/api-reference/get-users-id-following
22
+ #
23
+ # Returns paginated list of users followed by user_id.
24
+ #
25
+ # @param max_results [Integer] Max number of results per peage.
26
+ # @param pagination_token [String] Initial page pagination token.
27
+ # @yield [Array<Twttr::Model::User>] Users followed by page.
28
+ # @yield [String,NilClass] Pagination token.
29
+ # @return [Array<Twttr::Model::User>] Users followed.
30
+ def following(max_results: nil, pagination_token: nil, &block)
31
+ client.following(id, max_results: max_results, pagination_token: pagination_token, &block)
20
32
  end
21
33
 
22
34
  private
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: twttr
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.1
4
+ version: 0.0.5
5
5
  platform: ruby
6
6
  authors:
7
7
  - Roberto Decurnex
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-12-29 00:00:00.000000000 Z
11
+ date: 2022-01-17 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: oauth