-
Notifications
You must be signed in to change notification settings - Fork 40
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
(PC-33346)[API] feat: add route to create and delete headline offer
- Loading branch information
1 parent
4e33ce5
commit ebcd1a0
Showing
15 changed files
with
513 additions
and
30 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
import logging | ||
|
||
from flask_login import current_user | ||
from flask_login import login_required | ||
|
||
from pcapi.core.offers import exceptions | ||
import pcapi.core.offers.api as offers_api | ||
import pcapi.core.offers.repository as offers_repository | ||
from pcapi.models import api_errors | ||
from pcapi.repository import atomic | ||
from pcapi.routes.apis import private_api | ||
from pcapi.routes.serialization import headline_offer_serialize | ||
from pcapi.serialization.decorator import spectree_serialize | ||
from pcapi.utils import rest | ||
|
||
from . import blueprint | ||
|
||
|
||
logger = logging.getLogger(__name__) | ||
|
||
|
||
@private_api.route("/offers/headline", methods=["POST"]) | ||
@login_required | ||
@spectree_serialize( | ||
on_success_status=204, | ||
api=blueprint.pro_private_schema, | ||
) | ||
@atomic() | ||
def make_offer_headline_from_offers(body: headline_offer_serialize.HeadlineOfferCreationBodyModel) -> None: | ||
|
||
offer = offers_repository.get_offer_by_id(body.offer_id, load_options=["headline_offer"]) | ||
|
||
if not offer: | ||
raise api_errors.ResourceNotFoundError | ||
offerer_id = offer.venue.managingOffererId | ||
|
||
rest.check_user_has_access_to_offerer(current_user, offerer_id) | ||
try: | ||
offers_api.make_offer_headline(offer) | ||
except exceptions.OffererCanNotHaveHeadlineOffer: | ||
raise api_errors.ApiErrors( | ||
errors={ | ||
"global": [ | ||
"Vous ne pouvez pas créer d'offre à la une sur une entité juridique possédant plusieurs structures" | ||
] | ||
}, | ||
) | ||
except exceptions.VirtualOfferCanNotBeHeadline: | ||
raise api_errors.ApiErrors( | ||
errors={"global": ["Une offre virtuelle ne peut pas être mise à la une"]}, | ||
) | ||
except exceptions.OfferHasAlreadyAnActiveHeadlineOffer: | ||
raise api_errors.ApiErrors( | ||
errors={"global": ["Cette offre est déjà mise à la une"]}, | ||
) | ||
except exceptions.VenueHasAlreadyAnActiveHeadlineOffer: | ||
raise api_errors.ApiErrors( | ||
errors={"global": ["Cette structure possède déjà une offre à la une"]}, | ||
) | ||
except exceptions.InactiveOfferCanNotBeHeadline: | ||
raise api_errors.ApiErrors( | ||
errors={"global": ["Cette offre est inactive et ne peut pas être mise à la une"]}, | ||
) | ||
|
||
|
||
@private_api.route("/offers/delete_headline", methods=["POST"]) | ||
@login_required | ||
@spectree_serialize( | ||
on_success_status=204, | ||
api=blueprint.pro_private_schema, | ||
) | ||
@atomic() | ||
def delete_headline_offer(body: headline_offer_serialize.HeadlineOfferDeleteBodyModel) -> None: | ||
rest.check_user_has_access_to_offerer(current_user, body.offerer_id) | ||
if active_headline_offer := offers_repository.get_offerers_active_headline_offer(body.offerer_id): | ||
offers_api.remove_headline_offer(active_headline_offer) |
18 changes: 18 additions & 0 deletions
18
api/src/pcapi/routes/serialization/headline_offer_serialize.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
from pcapi.routes.serialization import BaseModel | ||
from pcapi.serialization.utils import to_camel | ||
|
||
|
||
class HeadlineOfferCreationBodyModel(BaseModel): | ||
offer_id: int | ||
|
||
class Config: | ||
alias_generator = to_camel | ||
extra = "forbid" | ||
|
||
|
||
class HeadlineOfferDeleteBodyModel(BaseModel): | ||
offerer_id: int | ||
|
||
class Config: | ||
alias_generator = to_camel | ||
extra = "forbid" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.