From Code to Community: Sponsoring The Perl and Raku Conference 2025 Learn more

NAME

CPAN::Mini::Inject::REST::Controller::API::Version1_0

DESCRIPTION

Catalyst Controller.

METHODS

repository

/api/1.0/repository/File-Name-1.00.tar.gz

GET

Downloads a file from the repository. Returns status 404 if the file could not be found.

POST

Adds a file to the repository and injects it into the mirror. If the file can be added, status 201 (Created) is returned with details of which modules the file provides.

{
"provides": [
{
"version": "0.04",
"module": "hello"
}
],
"file": "hello-0.04.tar.gz"
}

If the file cannot be added to the repository, status 400 is returned with an appropriate error message:

{
"error": "File hello-0.03.tar.gz is already in the repository"
}

Note that if a file already exists in the repository, it cannot be added again.

mirror

/api/1.0/mirror/File-Name-1.0.tar.gz

GET

Returns a list of modules provided by the file, and the CPAN-style path to download the file from the mirror (e.g. L/LO/LOCAL/File-Name-1.0.tar.gz).

{
"provides": {
"CPAN::Mini::Inject::Config": {
"version":"0.28"
},
"CPAN::Mini::Inject": {
"version":"0.28"
}
},
"file": "CPAN-Mini-Inject-0.28.tar.gz",
"path": "L/LO/LOCAL/CPAN-Mini-Inject-0.28.tar.gz"
}

If the file has not been added to the mirror, status 404 is returned with an appropriate error message:

{
"error": "File My-Module-1.04.tar.gz does not exist"
}

all_files

GET

Returns a list of all files that have been added to the mirror.

{
"files": [
"CPAN-Mini-Inject-0.28.tar.gz",
"My-Private-Module-0.02.tar.gz"
]
}

If no files have been added, status 204 (No Content) is returned.

dist

/api/1.0/dist/Distribution-Name

GET

Returns a list of files, from both the repository and the mirror, which match the specified distibution name.

{
"repository": [
"hello-0.01.tar.gz",
"hello-0.02.tar.gz",
"hello-0.03.tar.gz"
],
"mirror": [
"hello-0.02.tar.gz"
]
}

If the distribution cannot be found, status 404 is returned with an appropriate error message:

{
"error": "Cannot find dist My-Private-Module"
}

all_dists

/api/1.0/all_dists

GET

Returns a list of all distributions that have been added to the mirror.

{
"dists": [
"CPAN-Mini-Inject",
"My-Private-Module"
]
}

If no distributions have been added, status 204 (No Content) is returned.

AUTHOR

Jon Allen (JJ) <jj@jonallen.info>

LICENSE

This library is free software. You can redistribute it and/or modify it under the same terms as Perl itself.