1 | <?php |
||
2 | /** |
||
3 | * @category Library |
||
4 | * @license MIT http://opensource.org/licenses/MIT |
||
5 | * @link https://github.com/emlynwest/changelog |
||
6 | */ |
||
7 | |||
8 | namespace ChangeLog\IO; |
||
9 | |||
10 | use stdClass; |
||
11 | |||
12 | /** |
||
13 | * Allows change log files to be read from GitHub and committed back. |
||
14 | * |
||
15 | * This class has the following config options |
||
16 | * - repo: "<user>/<repo>" The full username and repo name to use. |
||
17 | * - file: Path to the file from the root of the repo |
||
18 | * - token: GitHub API token, can be generated under account -> applications |
||
19 | * - commit_message: Optional commit message, used when setContent() is called. |
||
20 | * |
||
21 | * The token must have the "repo" or "public_repo" permission depending on the visibility of the repo. |
||
22 | */ |
||
23 | class GitHub extends AbstractGitHubIO |
||
24 | { |
||
25 | |||
26 | protected $configDefaults = [ |
||
27 | 'commit_message' => 'Updates change log.', |
||
28 | 'line_separator' => "\n", |
||
29 | ]; |
||
30 | |||
31 | /** |
||
32 | * {@inheritdoc} |
||
33 | */ |
||
34 | 2 | public function getContent() |
|
35 | { |
||
36 | 2 | $content = $this->requestFile(); |
|
37 | |||
38 | 1 | return explode( |
|
39 | 1 | $this->getConfig('line_separator'), |
|
0 ignored issues
–
show
Bug
introduced
by
![]() |
|||
40 | 1 | base64_decode($content->content) |
|
41 | 1 | ); |
|
42 | } |
||
43 | |||
44 | /** |
||
45 | * {@inheritdoc} |
||
46 | */ |
||
47 | 1 | public function setContent($content) |
|
48 | { |
||
49 | // Request the file so we can get its sha |
||
50 | 1 | $fileInfo = $this->requestFile(); |
|
51 | |||
52 | 1 | $encodedContent = base64_encode($content); |
|
53 | 1 | $data = [ |
|
54 | 1 | 'message' => $this->getConfig('commit_message'), |
|
55 | 1 | 'content' => $encodedContent, |
|
56 | 1 | 'sha' => $fileInfo->sha, |
|
57 | 1 | ]; |
|
58 | |||
59 | 1 | $api = $this->getApi(); |
|
60 | 1 | $response = $api->put($this->getApiUrl(), $data); |
|
61 | // Parse the response so an exception is thrown if anything goes funky |
||
62 | 1 | $api->decode($response); |
|
63 | } |
||
64 | |||
65 | /** |
||
66 | * Gets a URL for the GitHub api for our file. |
||
67 | * |
||
68 | * @return string |
||
69 | */ |
||
70 | 2 | protected function getApiUrl() |
|
71 | { |
||
72 | 2 | $repo = $this->getConfig('repo'); |
|
73 | 2 | $file = $this->getConfig('file'); |
|
74 | |||
75 | 2 | $url = "/repos/$repo/contents/$file"; |
|
76 | 2 | return $url; |
|
77 | } |
||
78 | |||
79 | /** |
||
80 | * @return stdClass |
||
81 | */ |
||
82 | 3 | protected function requestFile() |
|
83 | { |
||
84 | 3 | $api = $this->getApi(); |
|
85 | 2 | $response = $api->get($this->getApiUrl()); |
|
86 | 2 | $content = $api->decode($response); |
|
87 | 2 | return $content; |
|
88 | } |
||
89 | |||
90 | } |
||
91 |