Source code for bodhi.messages.schemas.buildroot_override
# Copyright (C) 2018-2019 Red Hat, Inc.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along
# with this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
"""
Message schema for Buildroot Overrides.
Each message is defined as a Python class. For details, see `fedora-messaging
<https://fedora-messaging.readthedocs.io/en/stable/>`_ documentation on
messages.
"""
import typing
from .base import BodhiMessage, BuildV1, SCHEMA_URL, UserV1
[docs]class BuildrootOverrideMessage(BodhiMessage):
"""Base class for the buildroot_override messages."""
@property
def build(self) -> BuildV1:
"""Return the build that was overridden."""
return BuildV1(self.body['override']['nvr'])
@property
def submitter(self) -> UserV1:
"""Return the name of the submitter for the override."""
return UserV1(self.body['override']['submitter']['name'])
@property
def summary(self) -> str:
"""
Return a short, human-readable representation of this message.
This should provide a short summary of the message, much like the subject line
of an email.
"""
return self._summary_tmpl.format(submitter=self.submitter.name, build=self.build.nvr)
@property
def url(self) -> str:
"""
Return a URL to the action that caused this message to be emitted.
Returns:
A relevant URL.
"""
return f"https://bodhi.fedoraproject.org/overrides/{self.build.nvr}"
@property
def packages(self) -> typing.Iterable[str]:
"""List of packages affected by the action that generated this message.
Returns:
A list of affected package names.
"""
return [self.build.package]
@property
def agent(self) -> str:
"""Return the agent's username for this message.
Returns:
The agent's username.
"""
return self.submitter.name
@property
def usernames(self) -> typing.List[str]:
"""
List of users affected by the action that generated this message.
Returns:
A list of affected usernames.
"""
return [self.agent]
[docs]class BuildrootOverrideTagV1(BuildrootOverrideMessage):
"""Sent when a buildroot override is added and tagged into the build root."""
body_schema = {
'id': f'{SCHEMA_URL}/v1/bodhi.buildroot_override.tag#',
'$schema': 'http://json-schema.org/draft-04/schema#',
'description': 'Schema for message sent when buildroot overrides are tagged',
'type': 'object',
'properties': {
'override': {
'type': 'object',
'properties': {
'nvr': {
'type': 'string',
'description': 'The NVR of the build that was overridden'
},
'submitter': UserV1.schema(),
},
'required': ['nvr', 'submitter']
}
},
'required': ['override'],
}
topic = "bodhi.buildroot_override.tag"
_summary_tmpl = "{submitter} submitted a buildroot override for {build}"
[docs]class BuildrootOverrideUntagV1(BuildrootOverrideMessage):
"""Sent when a buildroot override is untagged from the build root."""
body_schema = {
'id': f'{SCHEMA_URL}/v1/bodhi.buildroot_override.untag#',
'$schema': 'http://json-schema.org/draft-04/schema#',
'description': 'Schema for message sent when buildroot overrides are untagged',
'type': 'object',
'properties': {
'override': {
'type': 'object',
'properties': {
'nvr': {
'type': 'string',
'description': 'The NVR of the build that had been overridden'
},
'submitter': UserV1.schema(),
},
'required': ['nvr', 'submitter']
}
},
'required': ['override'],
}
topic = "bodhi.buildroot_override.untag"
_summary_tmpl = "{submitter} expired a buildroot override for {build}"