Provided by: libpithub-perl_0.01041-1_all 

NAME
Pithub::GitData::Trees - Github v3 Git Data Trees API
VERSION
version 0.01041
METHODS
create
The tree creation API will take nested entries as well. If both a tree and a nested path modifying that
tree are specified, it will overwrite the contents of that tree with the new path contents and write a
new tree out.
• Create a Tree
POST /repos/:user/:repo/git/trees
Parameters:
• user: mandatory string
• repo: mandatory string
• data: mandatory hashref, having following keys:
• base_tree: optional String of the SHA1 of the tree you want to update with new data.
• tree: mandatory arrayref of hashrefs, having following keys:
• path: mandatory string of the file referenced in the tree.
• mode: mandatory string of the file mode - one of 100644 for file (blob), 100755 for
executable (blob), 040000 for subdirectory (tree), 160000 for submodule (commit) or
120000 for a blob that specifies the path of a symlink.
• type: mandatory string of "blob", "tree", "commit".
• sha: mandatory string of SHA1 checksum ID of the object in the tree.
• content: String of content you want this file to have - GitHub will write this blob out
and use that SHA for this entry. Use either this or "tree.sha".
Examples:
my $t = Pithub::GitData::Trees->new;
my $result = $t->create(
user => 'octocat',
repo => 'Hello-World',
data => {
tree => [
{
path => 'file.rb',
mode => '100644',
type => 'blob',
sha => '7c258a9869f33c1e1e1f74fbb32f07c86cb5a75b',
}
]
}
);
Response: Status: 201 Created
{
"sha": "cd8274d15fa3ae2ab983129fb037999f264ba9a7",
"url": "https://api.github.com/repo/octocat/Hello-World/trees/cd8274d15fa3ae2ab983129fb037999f264ba9a7",
"tree": [
{
"path": "file.rb",
"mode": "100644",
"type": "blob",
"size": 132,
"sha": "7c258a9869f33c1e1e1f74fbb32f07c86cb5a75b",
"url": "https://api.github.com/octocat/Hello-World/git/blobs/7c258a9869f33c1e1e1f74fbb32f07c86cb5a75b"
}
]
}
get
• Get a Tree
GET /repos/:user/:repo/git/trees/:sha
Parameters:
• user: mandatory string
• repo: mandatory string
• sha: mandatory string
• recursive: optional boolean
Examples:
my $t = Pithub::GitData::Trees->new;
my $result = $t->get(
user => 'plu',
repo => 'Pithub',
sha => 'df21b2660fb6'
);
Response: Status: 200 OK
{
"sha": "9fb037999f264ba9a7fc6274d15fa3ae2ab98312",
"url": "https://api.github.com/repo/octocat/Hello-World/trees/9fb037999f264ba9a7fc6274d15fa3ae2ab98312",
"tree": [
{
"path": "file.rb",
"mode": "100644",
"type": "blob",
"size": 30,
"sha": "44b4fc6d56897b048c772eb4087f854f46256132",
"url": "https://api.github.com/octocat/Hello-World/git/blobs/44b4fc6d56897b048c772eb4087f854f46256132"
},
{
"path": "subdir",
"mode": "040000",
"type": "tree",
"sha": "f484d249c660418515fb01c2b9662073663c242e",
"url": "https://api.github.com/octocat/Hello-World/git/blobs/f484d249c660418515fb01c2b9662073663c242e"
},
{
"path": "exec_file",
"mode": "100755",
"type": "blob",
"size": 75,
"sha": "45b983be36b73c0788dc9cbcb76cbb80fc7bb057",
"url": "https://api.github.com/octocat/Hello-World/git/blobs/45b983be36b73c0788dc9cbcb76cbb80fc7bb057"
}
]
}
• Get a Tree Recursively
GET /repos/:user/:repo/git/trees/:sha?recursive=1
Parameters:
• user: mandatory string
• repo: mandatory string
• sha: mandatory string
• recursive: optional boolean
Examples:
my $t = Pithub::GitData::Trees->new;
my $result = $t->get(
user => 'plu',
repo => 'Pithub',
sha => 'df21b2660fb6',
recursive => 1,
);
Response: Status: 200 OK
{
"sha": "fc6274d15fa3ae2ab983129fb037999f264ba9a7",
"url": "https://api.github.com/repo/octocat/Hello-World/trees/fc6274d15fa3ae2ab983129fb037999f264ba9a7",
"tree": [
{
"path": "subdir/file.txt",
"mode": "100644",
"type": "blob",
"size": 132,
"sha": "7c258a9869f33c1e1e1f74fbb32f07c86cb5a75b",
"url": "https://api.github.com/octocat/Hello-World/git/7c258a9869f33c1e1e1f74fbb32f07c86cb5a75b"
}
]
}
AUTHOR
Johannes Plunien <plu@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2011 by Johannes Plunien.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5
programming language system itself.
perl v5.36.0 2023-09-02 Pithub::GitData::Trees(3pm)