Bugzilla::Webservice::Product - The Product API
This part of the Bugzilla API allows you to list the available Products and get information about them.
See Bugzilla::WebService for a description of how parameters are passed, and what STABLE, UNSTABLE, and EXPERIMENTAL mean.
Although the data input and output is the same for JSONRPC, XMLRPC and REST, the directions for how to access the data via REST is noted in each method where applicable.
EXPERIMENTAL
Returns a list of the ids of the products the user can search on.
GET /rest/product_selectable
the returned data format is same as below.
A hash containing one item,
ids,
that contains an array of product ids.
EXPERIMENTAL
Returns a list of the ids of the products the user can enter bugs against.
GET /rest/product_enterable
the returned data format is same as below.
A hash containing one item,
ids,
that contains an array of product ids.
UNSTABLE
Returns a list of the ids of the products the user can search or enter bugs against.
GET /rest/product_accessible
the returned data format is same as below.
A hash containing one item,
ids,
that contains an array of product ids.
EXPERIMENTAL
Returns a list of information about the products passed to it.
Note: You must at least specify one of ids or names.
To return information about a specific groups of products such as accessible,
selectable,
or enterable:
GET /rest/product?type=accessible
To return information about a specific product by id or name:
GET /rest/product/<product_id_or_name>
You can also return information about more than one specific product by using the following in your query string:
GET /rest/product?ids=1&ids=2&ids=3 or GET /product?names=ProductOne&names=Product2
the returned data format is same as below.
In addition to the parameters below, this method also accepts the standard include_fields and exclude_fields arguments.
This RPC call supports sub field restrictions.
idsAn array of product ids
namesAn array of product names
typeThe group of products to return.
Valid values are: accessible (default),
selectable,
and enterable.
type can be a single value or an array of values if more than one group is needed with duplicates removed.
A hash containing one item,
products,
that is an array of hashes.
Each hash describes a product,
and has the following items:
idint An integer id uniquely identifying the product in this installation only.
namestring The name of the product.
This is a unique identifier for the product.
descriptionstring A description of the product,
which may contain HTML.
is_activeboolean A boolean indicating if the product is active.
default_milestonestring The name of the default milestone for the product.
has_unconfirmedboolean Indicates whether the UNCONFIRMED bug status is available for this product.
classificationstring The classification name for the product.
componentsarray An array of hashes,
where each hash describes a component,
and has the following items:
idint An integer id uniquely identifying the component in this installation only.
namestring The name of the component.
This is a unique identifier for this component.
descriptionstring A description of the component,
which may contain HTML.
default_assigned_tostring The login name of the user to whom new bugs will be assigned by default.
default_qa_contactstring The login name of the user who will be set as the QA Contact for new bugs by default.
Empty string if the QA contact is not defined.
sort_keyint Components,
when displayed in a list,
are sorted first by this integer and then secondly by their name.
is_activeboolean A boolean indicating if the component is active.
Inactive components are not enabled for new bugs.
flag_typesA hash containing the two items bug and attachment that each contains an array of hashes,
where each hash describes a flagtype,
and has the following items:
idint Returns the ID of the flagtype.
namestring Returns the name of the flagtype.
descriptionstring Returns the description of the flagtype.
cc_liststring Returns the concatenated CC list for the flagtype,
as a single string.
sort_keyint Returns the sortkey of the flagtype.
is_activeboolean Returns whether the flagtype is active or disabled.
Flags being in a disabled flagtype are not deleted.
It only prevents you from adding new flags to it.
is_requestableboolean Returns whether you can request for the given flagtype (i.e.
whether the '?' flag is available or not).
is_requesteebleboolean Returns whether you can ask someone specifically or not.
is_multiplicableboolean Returns whether you can have more than one flag for the given flagtype in a given bug/attachment.
grant_groupint the group id that is allowed to grant/deny flags of this type.
If the item is not included all users are allowed to grant/deny this flagtype.
request_groupint the group id that is allowed to request the flag if the flag is of the type requestable.
If the item is not included all users are allowed request this flagtype.
versionsarray An array of hashes,
where each hash describes a version,
and has the following items: name,
sort_key and is_active.
milestonesarray An array of hashes,
where each hash describes a milestone,
and has the following items: name,
sort_key and is_active.
Note, that if the user tries to access a product that is not in the list of accessible products for the user, or a product that does not exist, that is silently ignored, and no information about that product is returned.
names was added as an input parameter.classification,
components,
versions,
milestones,
default_milestone and has_unconfirmed were added to the fields returned by get as a replacement for internals,
which has been removed.flag_types was added to the fields returned by get.EXPERIMENTAL
This allows you to create a new product in Bugzilla.
POST /rest/product
The params to include in the POST body as well as the returned data format, are the same as below.
Some params must be set, or an error will be thrown. These params are marked Required.
nameRequired string The name of this product.
Must be globally unique within Bugzilla.
descriptionRequired string A description for this product.
Allows some simple HTML.
versionRequired string The default version for this product.
has_unconfirmedboolean Allow the UNCONFIRMED status to be set on bugs in this product.
Default: true.
classificationstring The name of the Classification which contains this product.
default_milestonestring The default milestone for this product.
Default '---'.
is_openboolean True if the product is currently allowing bugs to be entered into it.
Default: true.
create_seriesboolean True if you want series for New Charts to be created for this new product.
Default: true.
A hash with one element, id. This is the id of the newly-filed product.
You must specify an existing classification name.
You must specify a non-blank name for this product.
The name specified for this product was longer than the maximum allowed length.
You specified the name of a product that already exists. (Product names must be globally unique in Bugzilla.)
You must specify a description for this product.
You must specify a version for this product.
EXPERIMENTAL
This allows you to update a product in Bugzilla.
PUT /rest/product/<product_id_or_name>
The params to include in the PUT body as well as the returned data format,
are the same as below.
The ids and names params will be overridden as it is pulled from the URL path.
Note: The following parameters specify which products you are updating. You must set one or both of these parameters.
idsarray of ints.
Numeric ids of the products that you wish to update.
namesarray or strings.
Names of the products that you wish to update.
Note: The following parameters specify the new values you want to set for the products you are updating.
namestring A new name for this product.
If you try to set this while updating more than one product,
an error will occur,
as product names must be unique.
default_milestonestring When a new bug is filed,
what milestone does it get by default if the user does not choose one?
Must represent a milestone that is valid for this product.
descriptionstring Update the long description for these products to this value.
has_unconfirmedboolean Allow the UNCONFIRMED status to be set on bugs in products.
is_openboolean True if the product is currently allowing bugs to be entered into it,
False otherwise.
A hash with a single field "products".
This points to an array of hashes with the following fields:
idint The id of the product that was updated.
changeshash The changes that were actually done on this product.
The keys are the names of the fields that were changed,
and the values are a hash with two keys:
addedstring The value that this field was changed to.
removedstring The value that was previously set in this field.
Note that booleans will be represented with the strings '1' and '0'.
Here's an example of what a return value might look like:
{
products => [
{
id => 123,
changes => {
name => {
removed => 'FooName',
added => 'BarName'
},
has_unconfirmed => {
removed => '1',
added => '0',
}
}
}
]
}
You must specify a non-blank name for this product.
The name specified for this product was longer than the maximum allowed length.
You specified the name of a product that already exists. (Product names must be globally unique in Bugzilla.)
You must specify a description for this product.
You must define a default milestone.