From 2b3d913e3de82b51d711d03f5faa299e041b1bd6 Mon Sep 17 00:00:00 2001 From: Shishir <75600200+shishir-intelli@users.noreply.github.com> Date: Tue, 5 Dec 2023 12:29:54 +0530 Subject: [PATCH] Resolved the validation for monitized enabled org for enabling teams for ApigeeX and edge for 2x (#1000) --- .../apigee_edge_teams.install | 27 +++-- .../apigee_edge_teams.services.yml | 6 + .../ValidateApigeeXTeamEnabledSubscriber.php | 114 ++++++++++++++++++ 3 files changed, 135 insertions(+), 12 deletions(-) create mode 100644 modules/apigee_edge_teams/src/EventSubscriber/ValidateApigeeXTeamEnabledSubscriber.php diff --git a/modules/apigee_edge_teams/apigee_edge_teams.install b/modules/apigee_edge_teams/apigee_edge_teams.install index a3191e3b..d0a83c20 100644 --- a/modules/apigee_edge_teams/apigee_edge_teams.install +++ b/modules/apigee_edge_teams/apigee_edge_teams.install @@ -41,18 +41,21 @@ function apigee_edge_teams_requirements($phase) { $org_controller = \Drupal::service('apigee_edge.controller.organization'); /* @var \Apigee\Edge\Api\Management\Entity\Organization $organization */ $organization = $org_controller->load($sdk_connector->getOrganization()); - if ($organization && !OrganizationFeatures::isCompaniesFeatureAvailable($organization) && OrganizationFeatures::isMonetizationEnabled($organization)) { - $url = [ - ':url' => 'https://cloud.google.com/apigee/docs/api-platform/get-started/compare-apigee-products#unsupported-apis', - ]; - $message = ($phase == 'runtime') ? - t("The Teams module functionality is not available for monetization enabled org on Apigee X / Hybrid and should be uninstalled, because AppGroup APIs are not supported in Apigee X / Hybrid orgs with monetization enabled.", $url) : - t("The Teams module functionality is not available for monetization enabled org on Apigee X / Hybrid because AppGroup APIs are not supported in Apigee X / Hybrid orgs with monetization enabled.", $url); - $requirements['apigee_edge_teams_not_supported'] = [ - 'title' => t('Apigee Edge Teams'), - 'description' => $message, - 'severity' => REQUIREMENT_ERROR, - ]; + if ($organization && $org_controller->isOrganizationApigeeX()) { + // AppGroup APIs are not supported in Apigee X / Hybrid orgs with monetization enabled. + if ($organization->getAddonsConfig() && $organization->getAddonsConfig()->getMonetizationConfig() && TRUE === $organization->getAddonsConfig()->getMonetizationConfig()->getEnabled()) { + $url = [ + ':url' => 'https://cloud.google.com/apigee/docs/api-platform/publish/organizing-client-app-ownership?hl=en#appgroups-limitations-and-known-issues', + ]; + $message = ($phase == 'runtime') ? + t("The Teams module functionality is not available for monetization enabled org on Apigee X / Hybrid and should be uninstalled, because AppGroup APIs are not supported in Apigee X / Hybrid orgs with monetization enabled.", $url) : + t("The Teams module functionality is not available for monetization enabled org on Apigee X / Hybrid because AppGroup APIs are not supported in Apigee X / Hybrid orgs with monetization enabled.", $url); + $requirements['apigee_edge_teams_not_supported'] = [ + 'title' => t('Apigee Edge Teams'), + 'description' => $message, + 'severity' => REQUIREMENT_ERROR, + ]; + } } } catch (\Exception $exception) { diff --git a/modules/apigee_edge_teams/apigee_edge_teams.services.yml b/modules/apigee_edge_teams/apigee_edge_teams.services.yml index 0db1d3f9..6e772912 100644 --- a/modules/apigee_edge_teams/apigee_edge_teams.services.yml +++ b/modules/apigee_edge_teams/apigee_edge_teams.services.yml @@ -121,6 +121,12 @@ services: tags: - { name: event_subscriber } + apigee_edge_teams.validate_apigeexteam_enabled: + class: Drupal\apigee_edge_teams\EventSubscriber\ValidateApigeeXTeamEnabledSubscriber + arguments: ['@current_user', '@apigee_edge.sdk_connector', '@apigee_edge.controller.organization', '@messenger'] + tags: + - {name: event_subscriber} + route.subscriber.apigee_edge_teams.team_app_by_name: class: Drupal\apigee_edge_teams\Routing\TeamAppByNameRouteAlterSubscriber tags: diff --git a/modules/apigee_edge_teams/src/EventSubscriber/ValidateApigeeXTeamEnabledSubscriber.php b/modules/apigee_edge_teams/src/EventSubscriber/ValidateApigeeXTeamEnabledSubscriber.php new file mode 100644 index 00000000..2b2129f9 --- /dev/null +++ b/modules/apigee_edge_teams/src/EventSubscriber/ValidateApigeeXTeamEnabledSubscriber.php @@ -0,0 +1,114 @@ +currentUser = $current_user; + $this->connector = $sdk_connector; + $this->orgController = $org_controller; + $this->messenger = $messenger; + } + + /** + * If monetization enabled in Apigee X org alert the user. + * + * @param \Symfony\Component\HttpKernel\Event\RequestEvent $event + * The event. + */ + public function validateApigeexTeamEnabled(RequestEvent $event): void { + // Check only for html request and admin users. + if ($this->currentUser->hasPermission('administer modules') && $event->getRequest()->getRequestFormat() === 'html') { + /** @var \Symfony\Component\Routing\Route $current_route */ + if (($current_route = $event->getRequest()->get('_route')) && (strpos($current_route, 'entity.team') !== FALSE || strpos($current_route, 'settings.team') !== FALSE)) { + $organization = $this->orgController->load($this->connector->getOrganization()); + if ($organization && $this->orgController->isOrganizationApigeeX()) { + if ($organization->getAddonsConfig() && $organization->getAddonsConfig()->getMonetizationConfig() && TRUE === $organization->getAddonsConfig()->getMonetizationConfig()->getEnabled()) { + $this->messenger->addError($this->t('The Teams module functionality is not available for monetization enabled org on Apigee X / Hybrid and should be uninstalled.')); + } + } + } + } + } + + /** + * {@inheritdoc} + */ + public static function getSubscribedEvents(): array { + $events[KernelEvents::REQUEST][] = ['validateApigeexTeamEnabled']; + return $events; + } + +}