Skip to content

Add UI for enterprise user Extension Marketplace in Group Settings

Issue: Add UI for Group settings enterprise_users_exte... (#477174 - closed)

MR Chain:

  1. Add field enterprise_users_extensions_marketpla... (!161728 - merged)
  2. Extend extensions gallery metadata with enterpr... (!161740 - merged)
  3. Add UI for enterprise user Extension Marketplac... (!161819 - merged)

What does this MR do and why?

Add UI for enterprise user extension marketplace availability

  • This is default to off so that groups must opt-in
  • This updates enterprise_users_extensions_marketplace_enabled? to take into account the license and feature checks
  • This helps resolve this epic

MR acceptance checklist

Please evaluate this MR against the MR acceptance checklist. It helps you analyze changes to reduce risks in quality, performance, reliability, security, and maintainability.

Screenshots or screen recordings

With FF Off With FF On Demo
Screenshot_2024-08-05_at_12.50.23_PM Screenshot_2024-08-22_at_12.22.30_AM 20240822_enterprise_user_extensions_marketplace_demo

How to set up and validate locally

First, make sure that the following feature flags are enabled either through the rails console or /rails/features:

  • vscode_web_ide
  • web_ide_oauth
  • web_ide_extensions_marketplace

Prerequisite: You must start GDK as SaaS with an Ultimate licensed group. See docs for simulating a SaaS instance.

  1. In terminal in GitLab directory, run:

    gdk stop
    
    export GITLAB_SIMULATE_SAAS=1
    
    gdk start
  2. Create a new group (or you can use an existing one). In a rails console (rails c) set it's plan to Ultimate:

    Group.last.gitlab_subscription.update(hosted_plan: Plan.find_by(name: 'ultimate'))

Prerequisite: The group used in the last step must have a verified domain:

  1. Visit top-level group's homepage on GDK.

  2. (Optional) if a project doesn't exist for the group, go ahead and create one.

  3. Go to Settings > Domain Verification.

  4. Click Add Domain.

  5. For Domain enter example.com and use whatever Project.

  6. Click Add Domain.

  7. In the rails console (rails c), make the domain verified with:

    group = Group.find(<ID_OF_GROUP>) # <------- Change this line
    domain = Group.last.all_projects_pages_domains[0]
    domain.assign_attributes(verified_at: Time.current, enabled_until: 100.days.from_now, remove_at: nil)
    domain.save!(validate: false)

Prerequisite: Create a new user with an email of the verified domain in the last step and invite to group

Open an Incognito Window of your browser and visit /users/sign_in of the GDK:

  1. Click Register now.
  2. Enter anything for the fields, except the email must have @example.com (or the verified domain you created in previous step).
  3. Click Register.
  4. Enter Username and Password and click Sign in.

In the other browser window that's signed into the group owner on the group settings page:

  1. Go to Manage > Members in the sidebar.
  2. Click Invite members.
  3. For Username, search for the new user you just registered.
  4. For Select a role, select Developer.
  5. Click Invite.
  6. The user should show up in the list of members with an Enterprise User badge

Screenshot_2024-08-05_at_11.26.08_AM

Now, we need to enable the extension marketplace in our User's preferences. In the browser window that's signed into the new Enterprise User account:

  1. Go to user preferences at /-/profile/preferences.
  2. Find the Integrations section and select Enable extension marketplace under Web IDE.
  3. Click Save changes.

Open Web IDE and verify disabled/enabled marketplace:

The Enterprise Group has not opted into the extensions marketplace, so even though it's enabled on the user's preferences, it should still be disabled.

In the browser window that is signed into the Enterprise User account:

  1. Visit any project with code.
  2. Click Edit > Web IDE.
  3. In the WebIDE sidebar, click the top hamburger menu, then View > Extensions.
  4. The extensions marketplace should not be enabled and should show a message The extension marketplace has been disabled.

To enable the marketplace:

  1. Visit the relevant enterprise group page as a group owner/maintainer.
  2. Go to Settings > General.
  3. Find the Web IDE and workspaces checkbox under Permissions and group features section.
  4. Check Enable extension marketplace.
  5. Click Save changes.

Now, in the browser window that is signed into the Enterprise User account, visit the Web IDE and you should be able to use the extension marketplace.

Related to #477174 (closed)

Edited by Paul Slaughter

Merge request reports

Loading