Skip to content

Team ManagementΒΆ

MCP Gateway organizes users into teams so you can scope access and group operational responsibilities. While first-class UI for team administration is evolving, teams are already referenced across SSO guides and configuration for mapping identities to gateway-scoped groups.


ConceptsΒΆ

  • Teams: Logical groups used to organize users for access and ownership boundaries.
  • Mapping: Associate external identity attributes (e.g., Okta groups, Google Groups, GitHub orgs) to gateway team IDs.
  • Usage: Team IDs are used by administrative flows and planned RBAC policies.

Team Mapping ExamplesΒΆ

Use provider-specific environment variables to auto-assign users to teams on SSO login.

GitHub Organization β†’ TeamΒΆ

# Map a GitHub organization to a gateway team
GITHUB_ORG_TEAM_MAPPING={"your-github-org": "dev-team-uuid"}

Google Groups β†’ TeamΒΆ

# Map Google Groups to gateway team IDs
GOOGLE_GROUPS_MAPPING={"group1@yourcompany.com": "team-uuid-1", "admins@yourcompany.com": "admin-team-uuid"}

Okta Groups β†’ TeamΒΆ

# Map Okta groups to gateway team IDs
OKTA_GROUP_MAPPING={"MCP Gateway Admins": "admin-team-uuid", "MCP Gateway Users": "user-team-uuid"}

IBM Security Verify (Groups) β†’ TeamΒΆ

# Map ISV groups to gateway team IDs
IBM_VERIFY_GROUP_MAPPING={"CN=Developers,OU=Groups": "dev-team-uuid", "CN=Administrators,OU=Groups": "admin-team-uuid"}

Team Name ValidationΒΆ

Team names are validated against a strict character pattern to prevent XSS attacks and ensure consistent display across the UI.

Allowed CharactersΒΆ

Team names may only contain:

  • Letters (a-z, A-Z)
  • Numbers (0-9)
  • Spaces
  • Underscores (_)
  • Periods (.)
  • Dashes (-)

Pattern: ^[a-zA-Z0-9_.\-\s]+$

Rejected CharactersΒΆ

The following characters are not allowed in team names:

  • Ampersand (&)
  • Apostrophe (')
  • Forward slash (/)
  • Angle brackets (<, >)
  • Quotation marks (")
  • Any HTML or script content

ExamplesΒΆ

Team Name Valid? Reason
Engineering Team βœ… Letters and space
Dev_Team-2024.v1 βœ… Allowed special chars
R&D Team ❌ Ampersand not allowed
O'Connor's Team ❌ Apostrophe not allowed
Team <Alpha> ❌ Angle brackets not allowed

Migrating Existing TeamsΒΆ

If you have existing teams with names containing restricted characters, you'll need to update them before they can be modified via the API or Admin UI.

Find affected teams:

-- SQLite
SELECT id, name FROM email_teams
WHERE name GLOB '*[^a-zA-Z0-9_. -]*';

-- PostgreSQL
SELECT id, name FROM email_teams
WHERE name !~ '^[a-zA-Z0-9_.\- ]+$';

Update team names manually or via script:

-- Example: Replace & with 'and'
UPDATE email_teams SET name = REPLACE(name, '&', 'and')
WHERE name LIKE '%&%';

Option 2: Python Migration ScriptΒΆ

import re
from mcpgateway.db import get_db, EmailTeam

VALID_PATTERN = re.compile(r'^[a-zA-Z0-9_.\-\s]+$')

def sanitize_name(name: str) -> str:
    """Replace invalid characters."""
    name = name.replace('&', 'and')
    return re.sub(r'[^a-zA-Z0-9_.\-\s]', '-', name)

def migrate_team_names():
    db = next(get_db())
    teams = db.query(EmailTeam).all()
    for team in teams:
        if not VALID_PATTERN.match(team.name):
            old_name = team.name
            team.name = sanitize_name(team.name)
            print(f"Migrated: '{old_name}' -> '{team.name}'")
    db.commit()

if __name__ == "__main__":
    migrate_team_names()

Operational TipsΒΆ

  • Generate deterministic team UUIDs and manage them via export/import or admin APIs so they're stable across environments.
  • Use a small set of core teams (e.g., developers, admins, observers) to keep mappings simple.
  • Test SSO login with a pilot user per provider to verify expected team assignment.