camper 0.0.7 → 0.0.8
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +8 -1
- data/Gemfile.lock +1 -1
- data/README.md +12 -0
- data/lib/camper/api/{comment.rb → comments.rb} +3 -1
- data/lib/camper/api/{message.rb → messages.rb} +1 -1
- data/lib/camper/api/people.rb +97 -0
- data/lib/camper/api/{project.rb → projects.rb} +2 -3
- data/lib/camper/api/{todo.rb → todos.rb} +4 -5
- data/lib/camper/client.rb +5 -4
- data/lib/camper/error.rb +4 -0
- data/lib/camper/version.rb +1 -1
- metadata +8 -7
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: ac986df88ec826cc3b15bb75ba1bab382a144f6fdbf9900881907e7f82aab633
|
4
|
+
data.tar.gz: 122bba57a7e32a886390dbae0220122c86417c064a9ed9815085639fb5f4519c
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 9c7dbea42ec5e6ab228fe0fe627e61e45877f9c82803391005d0c45c262231c165bd523036f3bd38072be2c0ace8510dfc61f2ab792dc8ad27e66b3deae710c5
|
7
|
+
data.tar.gz: 1a7d91f083e430ee984bf81e1f55f5a70281721071e2fd86a947ac7b26a99fc18324bd4da88cbaa2d8ab34e989f2f6396197a904670e785ae42b002b07667b78
|
data/CHANGELOG.md
CHANGED
@@ -1,6 +1,13 @@
|
|
1
1
|
# Changelog
|
2
2
|
|
3
|
-
## [
|
3
|
+
## [Unreleased](https://github.com/renehernandez/camper/tree/HEAD)
|
4
|
+
|
5
|
+
**Implemented enhancements:**
|
6
|
+
|
7
|
+
- Add people API [\#46](https://github.com/renehernandez/camper/pull/46)
|
8
|
+
- Raise error if resource can't be commented [\#45](https://github.com/renehernandez/camper/pull/45)
|
9
|
+
|
10
|
+
## [v0.0.7](https://github.com/renehernandez/camper/tree/v0.0.7) (2020-10-04)
|
4
11
|
|
5
12
|
**Implemented enhancements:**
|
6
13
|
|
data/Gemfile.lock
CHANGED
data/README.md
CHANGED
@@ -24,6 +24,18 @@ Or install it yourself as:
|
|
24
24
|
$ gem install camper
|
25
25
|
```
|
26
26
|
|
27
|
+
## Implemented API endpoints
|
28
|
+
|
29
|
+
The up-to-date list of Basecamp API endpoints can be found at [here](https://github.com/basecamp/bc3-api#api-endpoints).
|
30
|
+
|
31
|
+
Currently, Camper supports the following endpoints:
|
32
|
+
|
33
|
+
* [Comments](https://github.com/basecamp/bc3-api/blob/master/sections/comments.md): Implementation at [comments.rb](./lib/camper/api/comments.rb) **Partial**
|
34
|
+
* [Messages](https://github.com/basecamp/bc3-api/blob/master/sections/messages.md): Implementation at [messages.rb](./lib/camper/api/messages.rb) **Partial**
|
35
|
+
* [People](https://github.com/basecamp/bc3-api/blob/master/sections/people.md): Implementation at [people.rb](./lib/camper/api/people.rb) **Complete**
|
36
|
+
* [Projects](https://github.com/basecamp/bc3-api/blob/master/sections/projects.md): Implementation at [projects.rb](./lib/camper/api/projects.rb) **Partial**
|
37
|
+
* [To-dos](https://github.com/basecamp/bc3-api/blob/master/sections/todos.md): Implementation at [todos.rb](./lib/camper/api/todos.rb) **Partial**
|
38
|
+
|
27
39
|
## Usage
|
28
40
|
|
29
41
|
### Configuration
|
@@ -1,8 +1,10 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
class Camper::Client
|
4
|
-
module
|
4
|
+
module CommentsAPI
|
5
5
|
def create_comment(resource, content)
|
6
|
+
raise Error::ResourceCannotBeCommented, resource unless resource.can_be_commented?
|
7
|
+
|
6
8
|
post(resource.comments_url, override_path: true, body: { content: content })
|
7
9
|
end
|
8
10
|
|
@@ -0,0 +1,97 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class Camper::Client
|
4
|
+
# Defines methods related to people.
|
5
|
+
# @see ttps://github.com/basecamp/bc3-api/blob/master/sections/people.md
|
6
|
+
module PeopleAPI
|
7
|
+
# Get all people visible to the current user
|
8
|
+
#
|
9
|
+
# @example
|
10
|
+
# client.people
|
11
|
+
#
|
12
|
+
# @return [Array<Resource>]
|
13
|
+
# @see https://github.com/basecamp/bc3-api/blob/master/sections/people.md#get-all-people
|
14
|
+
def people
|
15
|
+
get('/people')
|
16
|
+
end
|
17
|
+
|
18
|
+
# Get all active people on the project with the given ID
|
19
|
+
#
|
20
|
+
# @example
|
21
|
+
# client.people_in_project(10)
|
22
|
+
# @example
|
23
|
+
# client.people_in_project("20")
|
24
|
+
# @example
|
25
|
+
# client.people_in_project(my_project)
|
26
|
+
#
|
27
|
+
# @param project [Resource|Integer|String] A project resource or a project id
|
28
|
+
# @return [Array<Resource>]
|
29
|
+
# @see https://github.com/basecamp/bc3-api/blob/master/sections/people.md#get-people-on-a-project
|
30
|
+
def people_in_project(project)
|
31
|
+
id = project.respond_to?(:id) ? project.id : project
|
32
|
+
|
33
|
+
get("/projects/#{id}/people")
|
34
|
+
end
|
35
|
+
|
36
|
+
# Allows granting new and existing people access to a project, and revoking access from existing people.
|
37
|
+
#
|
38
|
+
# @example
|
39
|
+
# client.update_access_in_project(10, { grant: [102, 127] })
|
40
|
+
# @example
|
41
|
+
# client.update_access_in_project("8634", { revoke: [300, 12527] })
|
42
|
+
# @example
|
43
|
+
# client.update_access_in_project(my_project, {
|
44
|
+
# create: [{
|
45
|
+
# name: "Victor Copper",
|
46
|
+
# email_address: "victor@hanchodesign.com"
|
47
|
+
# }]
|
48
|
+
# })
|
49
|
+
#
|
50
|
+
# @param project [Resource|Integer|String] A project resource or a project id
|
51
|
+
# @param options [Hash] options to update access, either grant, revoke or create new people
|
52
|
+
# @return [Resource]
|
53
|
+
# @raise [Error::RequestIsMissingParameters] if no option is specified
|
54
|
+
# @see https://github.com/basecamp/bc3-api/blob/master/sections/people.md#update-who-can-access-a-project
|
55
|
+
def update_access_in_project(project, options = {})
|
56
|
+
raise RequestIsMissingParameters, 'options cannot be empty' if options.empty?
|
57
|
+
|
58
|
+
id = project.respond_to?(:id) ? project.id : project
|
59
|
+
|
60
|
+
put("/projects/#{id}/people/users", body: { **options })
|
61
|
+
end
|
62
|
+
|
63
|
+
# Get all people on this Basecamp account who can be pinged
|
64
|
+
#
|
65
|
+
# @example
|
66
|
+
# client.pingable_people
|
67
|
+
#
|
68
|
+
# @return [Array<Resource>]
|
69
|
+
# @see https://github.com/basecamp/bc3-api/blob/master/sections/people.md#get-pingable-people
|
70
|
+
def pingable_people
|
71
|
+
get('/circles/people')
|
72
|
+
end
|
73
|
+
|
74
|
+
# Get the profile for the user with the given ID
|
75
|
+
#
|
76
|
+
# @example
|
77
|
+
# client.person(234790)
|
78
|
+
#
|
79
|
+
# @param id [Integer|String] A user id
|
80
|
+
# @return [Resource]
|
81
|
+
# @see https://github.com/basecamp/bc3-api/blob/master/sections/people.md#get-person
|
82
|
+
def person(id)
|
83
|
+
get("/people/#{id}")
|
84
|
+
end
|
85
|
+
|
86
|
+
# Get the current user's personal info.
|
87
|
+
#
|
88
|
+
# @example
|
89
|
+
# client.profile
|
90
|
+
#
|
91
|
+
# @return [Resource]
|
92
|
+
# @see https://github.com/basecamp/bc3-api/blob/master/sections/people.md#get-my-personal-info
|
93
|
+
def profile
|
94
|
+
get('/my/profile')
|
95
|
+
end
|
96
|
+
end
|
97
|
+
end
|
@@ -1,8 +1,7 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
class Camper::Client
|
4
|
-
module
|
5
|
-
|
4
|
+
module TodosAPI
|
6
5
|
# Get the todolists associated with the todoset
|
7
6
|
#
|
8
7
|
# @example
|
@@ -14,7 +13,7 @@ class Camper::Client
|
|
14
13
|
# @param options [Hash] extra options to filter the list of todolist
|
15
14
|
# @return [Array<Resource>]
|
16
15
|
# @see https://github.com/basecamp/bc3-api/blob/master/sections/todolists.md#get-to-do-lists
|
17
|
-
def todolists(todoset, options={})
|
16
|
+
def todolists(todoset, options = {})
|
18
17
|
get(todoset.todolists_url, options.merge(override_path: true))
|
19
18
|
end
|
20
19
|
|
@@ -42,7 +41,7 @@ class Camper::Client
|
|
42
41
|
# @param options [Hash] options to filter the list of todos
|
43
42
|
# @return [Resource]
|
44
43
|
# @see https://github.com/basecamp/bc3-api/blob/master/sections/todos.md#get-to-dos
|
45
|
-
def todos(todolist, options={})
|
44
|
+
def todos(todolist, options = {})
|
46
45
|
get(todolist.todos_url, options.merge(override_path: true))
|
47
46
|
end
|
48
47
|
|
@@ -62,7 +61,7 @@ class Camper::Client
|
|
62
61
|
# @param options [Hash] extra configuration for the todo such as due_date and description
|
63
62
|
# @return [Resource]
|
64
63
|
# @see https://github.com/basecamp/bc3-api/blob/master/sections/todos.md#create-a-to-do
|
65
|
-
def create_todo(todolist, content, options={})
|
64
|
+
def create_todo(todolist, content, options = {})
|
66
65
|
post(todolist.todos_url, body: { content: content, **options }, override_path: true)
|
67
66
|
end
|
68
67
|
|
data/lib/camper/client.rb
CHANGED
@@ -12,12 +12,13 @@ module Camper
|
|
12
12
|
|
13
13
|
# Keep in alphabetical order
|
14
14
|
include Authorization
|
15
|
-
include
|
15
|
+
include CommentsAPI
|
16
16
|
include Logging
|
17
|
-
include
|
18
|
-
include
|
17
|
+
include MessagesAPI
|
18
|
+
include PeopleAPI
|
19
|
+
include ProjectsAPI
|
19
20
|
include ResourceAPI
|
20
|
-
include
|
21
|
+
include TodosAPI
|
21
22
|
|
22
23
|
# Creates a new Client instance.
|
23
24
|
# @raise [Error:MissingCredentials]
|
data/lib/camper/error.rb
CHANGED
data/lib/camper/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: camper
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.8
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- renehernandez
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2020-10-
|
11
|
+
date: 2020-10-27 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: httparty
|
@@ -114,11 +114,12 @@ files:
|
|
114
114
|
- examples/obtain_acces_token.rb
|
115
115
|
- examples/todos.rb
|
116
116
|
- lib/camper.rb
|
117
|
-
- lib/camper/api/
|
118
|
-
- lib/camper/api/
|
119
|
-
- lib/camper/api/
|
117
|
+
- lib/camper/api/comments.rb
|
118
|
+
- lib/camper/api/messages.rb
|
119
|
+
- lib/camper/api/people.rb
|
120
|
+
- lib/camper/api/projects.rb
|
120
121
|
- lib/camper/api/resource.rb
|
121
|
-
- lib/camper/api/
|
122
|
+
- lib/camper/api/todos.rb
|
122
123
|
- lib/camper/authorization.rb
|
123
124
|
- lib/camper/client.rb
|
124
125
|
- lib/camper/configuration.rb
|
@@ -152,7 +153,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
152
153
|
- !ruby/object:Gem::Version
|
153
154
|
version: '0'
|
154
155
|
requirements: []
|
155
|
-
rubygems_version: 3.1.
|
156
|
+
rubygems_version: 3.1.4
|
156
157
|
signing_key:
|
157
158
|
specification_version: 4
|
158
159
|
summary: Ruby client for Basecamp 3 API
|