1Net::GitHub::V3::Repos(U3s)er Contributed Perl DocumentatNieotn::GitHub::V3::Repos(3)
2
3
4

NAME

6       Net::GitHub::V3::Repos - GitHub Repos API
7

SYNOPSIS

9           use Net::GitHub::V3;
10
11           my $gh = Net::GitHub::V3->new; # read L<Net::GitHub::V3> to set right authentication info
12           my $repos = $gh->repos;
13
14           # set :user/:repo for simple calls
15           $repos->set_default_user_repo('fayland', 'perl-net-github');
16           my @contributors = $repos->contributors; # don't need pass user and repos
17

DESCRIPTION

19   METHODS
20       Repos
21
22       <http://developer.github.com/v3/repos/>
23
24       list
25       list_all
26               # All public repositories on Github
27               my @rp = $repos->list_all;
28               # starting at id 500
29               my @rp = $repos->list_all(500);
30
31       list_user
32       list_org
33               my @rp = $repos->list; # or my $rp = $repos->list;
34               my @rp = $repos->list({
35                   type => 'private'
36                   sort => 'updated'
37               });
38               my @rp = $repos->list_user('c9s');
39               my @rp = $repos->list_user('c9s', {
40                   type => 'member'
41               });
42               my @rp = $repos->list_org('perlchina');
43               my @rp = $repos->list_org('perlchina', 'public');
44
45       next_repo, next_all_repo, next_user_repo, next_org_repo
46               # Iterate over your repositories
47               while (my $repo = $repos->next_repo) { ...; }
48               # Iterate over all public repositories
49               while (my $repo = $repos->next_all_repo(500)) { ...; }
50               # Iterate over repositories of another user
51               while (my $repo = $repos->next_user_repo('c9s')) { ...; }
52               # Iterate over repositories of an organisation
53               while (my $repo = $repos->next_org_repo('perlchina','public')) { ...; }
54
55       create
56               # create for yourself
57               my $rp = $repos->create( {
58                   "name" => "Hello-World",
59                   "description" => "This is your first repo",
60                   "homepage" => "https://github.com"
61               } );
62               # create for organization
63               my $rp = $repos->create( {
64                   "org"  => "perlchina", ## the organization
65                   "name" => "Hello-World",
66                   "description" => "This is your first repo",
67                   "homepage" => "https://github.com"
68               } );
69
70       get
71               my $rp = $repos->get('fayland', 'perl-net-github');
72
73       To ease the keyboard, we provied two ways to call any method which
74       starts with :user/:repo
75
76       1. SET user/repos before call methods below
77
78           $gh->set_default_user_repo('fayland', 'perl-net-github'); # take effects for all $gh->
79           $repos->set_default_user_repo('fayland', 'perl-net-github'); # only take effect to $gh->repos
80           my @contributors = $repos->contributors;
81
82       2. If it is just for once, we can pass :user, :repo before any
83       arguments
84
85           my @contributors = $repos->contributors($user, $repo);
86
87       update
88               $repos->update({ homepage => 'https://metacpan.org/module/Net::GitHub' });
89
90       delete
91               $repos->delete();
92
93       contributors
94       languages
95       teams
96       tags
97       contributors
98               my @contributors = $repos->contributors;
99               my @languages = $repos->languages;
100               my @teams = $repos->teams;
101               my @tags = $repos->tags;
102               my @branches = $repos->branches;
103               my $branch = $repos->branch('master');
104               while (my $contributor = $repos->next_contributor) { ...; }
105               while (my $team = $repos->next_team) { ... ; }
106               while (my $tags = $repos->next_tag) { ... ; }
107
108       Repo Collaborators API
109
110       <http://developer.github.com/v3/repos/collaborators/>
111
112       collaborators
113       is_collaborator
114       add_collaborator
115       delete_collaborator
116               my @collaborators = $repos->collaborators;
117               while (my $collaborator = $repos->next_collaborator) { ...; }
118               my $is = $repos->is_collaborator('fayland');
119               $repos->add_collaborator('fayland');
120               $repos->delete_collaborator('fayland');
121
122       Commits API
123
124       <http://developer.github.com/v3/repos/commits/>
125
126       commits
127       commit
128               my @commits = $repos->commits;
129               my @commits = $repos->commits({
130                   author => 'fayland'
131               });
132               my $commit  = $repos->commit($sha);
133               while (my $commit = $repos->next_commit({...})) { ...; }
134
135       comments
136       commit_comments
137       create_comment
138       comment
139       update_comment
140       delete_comment
141               my @comments = $repos->comments;
142               while (my $comment = $repos->next_comment) { ...; }
143               my @comments = $repos->commit_comments($sha);
144               while (my $comment = $repos->next_commit_comment($sha)) { ...; }
145               my $comment  = $repos->create_comment($sha, {
146                   "body" => "Nice change",
147                   "commit_id" => "6dcb09b5b57875f334f61aebed695e2e4193db5e",
148                   "line" => 1,
149                   "path" => "file1.txt",
150                   "position" => 4
151               });
152               my $comment = $repos->comment($comment_id);
153               my $comment = $repos->update_comment($comment_id, {
154                   "body" => "Nice change"
155               });
156               my $st = $repos->delete_comment($comment_id);
157
158       compare_commits
159               my $diffs = $repos->compare_commits($base, $head);
160
161       Forks API
162
163       <http://developer.github.com/v3/repos/forks/>
164
165       forks
166       create_fork
167               my @forks = $repos->forks;
168               while (my $fork = $repos->next_fork) { ...; }
169               my $fork = $repos->create_fork;
170               my $fork = $repos->create_fork($org);
171
172       Repos Deploy Keys API
173
174       <http://developer.github.com/v3/repos/keys/>
175
176       keys
177       key
178       create_key
179       update_key
180       delete_key
181               my @keys = $repos->keys;
182               while (my $key = $repos->next_key) { ...; }
183               my $key  = $repos->key($key_id); # get key
184               $repos->create_key( {
185                   title => 'title',
186                   key   => $key
187               } );
188               $repos->update_key($key_id, {
189                   title => $title,
190                   key   => $key
191               });
192               $repos->delete_key($key_id);
193
194       Repo Watching API
195
196       <http://developer.github.com/v3/repos/watching/>
197
198       watchers
199               my @watchers = $repos->watchers;
200               while (my $watcher = $repos->next_watcher) { ...; }
201
202       watched
203               my @repos = $repos->watched; # what I watched
204               my @repos = $repos->watched('c9s');
205
206       is_watching
207               my $is_watching = $repos->is_watching;
208               my $is_watching = $repos->is_watching('fayland', 'perl-net-github');
209
210       watch
211       unwatch
212               my $st = $repos->watch();
213               my $st = $repos->watch('fayland', 'perl-net-github');
214               my $st = $repos->unwatch();
215               my $st = $repos->unwatch('fayland', 'perl-net-github');
216
217       Subscriptions
218
219       Github changed the ideas of Watchers (stars) and Subscriptions (new
220       watchers).
221
222           https://github.com/blog/1204-notifications-stars
223
224       The Watchers code in this module predates the terminology change, so
225       the new Watcher methods use the GitHub 'subscription' terminology.
226
227       subscribers
228           Returns a list of subscriber data hashes.
229
230       next_subscriber
231           Returns the next subscriber in the list, or undef if there are no
232           more subscribers.
233
234       is_subscribed
235           Returns true or false if you are subscribed
236
237               $repos->is_subscribed();
238               $repos->is_subscribed('fayland','perl-net-github');
239
240       subscription
241           Returns more information about your subscription to a repo.
242           is_subscribed is a shortcut to calling this and checking for
243           subscribed => 1.
244
245       subscribe
246           Required argument telling github if you want to subscribe or if you
247           want to ignore mentions. If you want to change from subscribed to
248           ignores you need to unsubscribe first.
249
250               $repos->subscribe('fayland','perl-net-github', { subscribed => 1 })
251               $repos->subscribe('fayland','perl-net-github', { ignored => 1 })
252
253       unsubscribe
254               $repos->unsubscribe('fayland','perl-net-github');
255
256       Hooks API
257
258       <http://developer.github.com/v3/repos/hooks/>
259
260       hooks
261       next_hook
262       hook
263       create_hook
264       update_hook
265       test_hook
266       delete_hook
267               my @hooks = $repos->hooks;
268               while (my $hook = $repos->next_hook) { ...; }
269               my $hook  = $repos->hook($hook_id);
270               my $hook  = $repos->create_hook($hook_hash);
271               my $hook  = $repos->update_hook($hook_id, $new_hook_hash);
272               my $st    = $repos->test_hook($hook_id);
273               my $st    = $repos->delete_hook($hook_id);
274
275       Repo Merging API
276
277       <http://developer.github.com/v3/repos/merging/>
278
279       merges
280               my $status = $repos->merges( {
281                   "base" => "master",
282                   "head" => "cool_feature",
283                   "commit_message" => "Shipped cool_feature!"
284               } );
285
286       Repo Statuses API
287
288       <http://developer.github.com/v3/repos/statuses/>
289
290       list_statuses
291               $gh->set_default_user_repo('fayland', 'perl-net-github');
292               my @statuses = $repos->lists_statuses($sha);
293
294           Or:
295
296               my @statuses = $repos->list_statuses('fayland', 'perl-net-github', $sha);
297
298       next_status
299               while (my $status = $repos->next_status($sha)) { ...; }
300
301       create_status
302               $gh->set_default_user_repo('fayland', 'perl-net-github');
303               my %payload = {
304                   "state"       => "success",
305                   "target_url"  => "https://example.com/build/status",
306                   "description" => "The build succeeded!",
307                   "context"     => "build/status"
308               };
309               my $status = $repos->create_status($sha, %payload);
310
311           Or:
312
313               my %payload = {
314                   "state"       => "success",
315                   "target_url"  => "https://example.com/build/status",
316                   "description" => "The build succeeded!",
317                   "context"     => "build/status"
318               };
319               my $status = $repos->create_status(
320                   'fayland', 'perl-net-github', $sha, %payload
321               );
322
323       Repo Releases API
324
325       <http://developer.github.com/v3/repos/releases/>
326
327       releases
328               my @releases = $repos->releases();
329               while (my $release = $repos->next_release) { ...; }
330
331       release
332               my $release = $repos->release($release_id);
333
334       create_release
335               my $release = $repos->create_release({
336                 "tag_name" => "v1.0.0",
337                 "target_commitish" => "master",
338                 "name" => "v1.0.0",
339                 "body" => "Description of the release",
340                 "draft" => \1,
341               });
342
343       update_release
344               my $release = $repos->update_release($release_id, {
345                 "tag_name" => "v1.0.0",
346                 "target_commitish" => "master",
347                 "name" => "v1.0.0",
348                 "body" => "Description of the release",
349               });
350
351       delete_release
352               $repos->delete_release($release_id);
353
354       release_assets
355               my @release_assets = $repos->release_assets($release_id);
356               while (my $asset = $repos->next_release_asset($release_id)) { ...; }
357
358       upload_asset
359               my $asset = $repos->upload_asset($release_id, $name, $content_type, $file_content);
360
361           Check examples/upload_asset.pl for a working example.
362
363       release_asset
364               my $release_asset = $repos->release_asset($release_id, $asset_id);
365
366       update_release_asset
367               my $release_asset = $repos->update_release_asset($release_id, $asset_id, {
368                   name" => "foo-1.0.0-osx.zip",
369                   "label" => "Mac binary"
370               });
371
372       delete_release_asset
373               my $ok = $repos->delete_release_asset($release_id, $asset_id);
374
375       Contents API
376
377       <https://developer.github.com/v3/repos/contents/>
378
379       get_content
380           Gets the contents of a file or directory in a repository.  Specify
381           the file path or directory in $path.  If you omit $path, you will
382           receive the contents of all files in the repository.
383
384               my $response = $repos->get_content( $owner, $repo, $path )
385                   or
386                   $repos->get_content(
387                       { owner => $owner,  repo => $repo, path => $path },
388                    )
389                   or
390                   $repos->get_content(
391                       { owner => $owner,  repo => $repo, path => $path },
392                       { ref => 'feature-branch' }
393                    )
394
395       Repo Deployment API
396
397       <http://developer.github.com/v3/repos/deployments/>
398
399       list_deployments
400               my $response = $repos->list_deployments( $owner, $repo, {
401                   'ref' => 'feature-branch',
402               });
403
404       next_deployment
405               while (my $deployment = $repos->next_deployment( $owner, $repo, {
406                   'ref' => 'feature-branch',
407               }) { ...; }
408
409       create_deployment
410               my $response = $repos->create_deployment( $owner, $repo, {
411                 "ref" => 'feature-branch',
412                 "description" => "deploying my new feature",
413               });
414
415       list_deployment_statuses
416               my $response = $repos->list_deployment_statuses( $owner, $repo, $deployment_id );
417
418       next_deployment_status
419               while (my $status = next_deployment_status($o,$r,$id)) { ...; }
420
421       create_deployment_status
422               my $response = $repos->create_deployment_status( $owner, $repo, $deployment_id, {
423                   "state": "success",
424                   "target_url": "https://example.com/deployment/42/output",
425                   "description": "Deployment finished successfully."
426               });
427
428       Repo Statistics API
429
430       <http://developer.github.com/v3/repos/statistics/>
431
432       contributor stats
433       commit activity
434       code frequency
435       participation
436       punch card
437               my $contributor_stats   = $repos->contributor_stats($owner, $repo);
438               my $commit_activity     = $repos->commit_activity($owner, $repo);
439               my $code_freq           = $repos->code_frequency($owner, $repo);
440               my $participation       = $repos->participation($owner, $repo);
441               my $punch_card          = $repos->punch_card($owner, $repo);
442
443       Branch Protection API
444
445       <https://docs.github.com/en/rest/branches/branch-protection>
446
447       branch_protection
448               my $protection = $repos->branch_protection('fayland', 'perl-net-github', 'master');
449
450       delete_branch_protection
451               $repos->delete_branch_protection('fayland', 'perl-net-github', 'master');
452
453       update_branch_protection
454               $repos->update_branch_protection('fayland', 'perl-net-github', 'master', {
455                   allow_deletions => \0,
456                   allow_force_pushes => \0,
457                   block_creations => \1,
458                   enforce_admins => \1,
459                   required_conversation_resolution => \1,
460                   required_linear_history => \0,
461                   required_pull_request_reviews => {
462                       dismiss_stale_reviews => \1,
463                       require_code_owner_reviews => \1,
464                       required_approving_review_count => 2,
465                   },
466                   required_status_checks => {
467                       strict => \1,
468                       contexts => []
469                   },
470                   restrictions => undef,
471               });
472
474       Refer Net::GitHub
475
476
477
478perl v5.36.0                      2022-10-04         Net::GitHub::V3::Repos(3)
Impressum