GitLab · JSON Structure

Gitlab Project Structure

A GitLab project containing a Git repository, issues, merge requests, CI/CD pipelines, and other DevOps resources.

Type: object Properties: 33 Required: 4
CodePlatformSoftware DevelopmentSource Control

GitLab Project is a JSON Structure definition published by GitLab, describing 33 properties, of which 4 are required. It conforms to the https://json-structure.org/meta/core/v0/# meta-schema.

Properties

id name description path path_with_namespace name_with_namespace visibility web_url http_url_to_repo ssh_url_to_repo readme_url default_branch topics archived empty_repo namespace owner creator_id star_count forks_count open_issues_count ci_config_path issues_access_level merge_requests_access_level builds_access_level wiki_access_level container_registry_access_level pages_access_level permissions statistics created_at updated_at last_activity_at

Meta-schema: https://json-structure.org/meta/core/v0/#

JSON Structure

Raw ↑
{
  "$schema": "https://json-structure.org/meta/core/v0/#",
  "$id": "https://gitlab.com/schemas/gitlab/project.json",
  "name": "GitLab Project",
  "description": "A GitLab project containing a Git repository, issues, merge requests, CI/CD pipelines, and other DevOps resources.",
  "type": "object",
  "required": [
    "id",
    "name",
    "path",
    "path_with_namespace"
  ],
  "properties": {
    "id": {
      "type": "int32",
      "description": "The unique identifier of the project."
    },
    "name": {
      "type": "string",
      "description": "The display name of the project."
    },
    "description": {
      "type": "string",
      "description": "A short description of the project.",
      "maxLength": 2000
    },
    "path": {
      "type": "string",
      "description": "The URL-friendly path component of the project name.",
      "pattern": "^[a-zA-Z0-9_.-]+$"
    },
    "path_with_namespace": {
      "type": "string",
      "description": "The full path of the project including the namespace, such as group/project-name."
    },
    "name_with_namespace": {
      "type": "string",
      "description": "The full name of the project including the namespace."
    },
    "visibility": {
      "type": "string",
      "enum": [
        "private",
        "internal",
        "public"
      ],
      "description": "The visibility level of the project."
    },
    "web_url": {
      "type": "uri",
      "description": "The URL to access the project in a browser."
    },
    "http_url_to_repo": {
      "type": "uri",
      "description": "The HTTP URL for cloning the repository."
    },
    "ssh_url_to_repo": {
      "type": "string",
      "description": "The SSH URL for cloning the repository."
    },
    "readme_url": {
      "type": "string",
      "format": "uri",
      "description": "The URL to the README file of the default branch."
    },
    "default_branch": {
      "type": "string",
      "description": "The default branch of the repository."
    },
    "topics": {
      "type": "array",
      "description": "List of topic tags associated with the project.",
      "items": {
        "type": "string"
      }
    },
    "archived": {
      "type": "boolean",
      "description": "Whether the project is archived and read-only."
    },
    "empty_repo": {
      "type": "boolean",
      "description": "Whether the repository has been initialized with commits."
    },
    "namespace": {
      "$ref": "#/$defs/Namespace"
    },
    "owner": {
      "$ref": "#/$defs/UserSummary"
    },
    "creator_id": {
      "type": "int32",
      "description": "The ID of the user who created the project."
    },
    "star_count": {
      "type": "int32",
      "minimum": 0,
      "description": "The number of stars the project has received."
    },
    "forks_count": {
      "type": "int32",
      "minimum": 0,
      "description": "The number of forks of the project."
    },
    "open_issues_count": {
      "type": "int32",
      "minimum": 0,
      "description": "The number of open issues in the project."
    },
    "ci_config_path": {
      "type": "string",
      "description": "The path to the CI/CD configuration file relative to the repository root.",
      "default": ".gitlab-ci.yml"
    },
    "issues_access_level": {
      "type": "string",
      "enum": [
        "disabled",
        "private",
        "enabled",
        "public"
      ],
      "description": "The access level for the issues feature."
    },
    "merge_requests_access_level": {
      "type": "string",
      "enum": [
        "disabled",
        "private",
        "enabled",
        "public"
      ],
      "description": "The access level for the merge requests feature."
    },
    "builds_access_level": {
      "type": "string",
      "enum": [
        "disabled",
        "private",
        "enabled",
        "public"
      ],
      "description": "The access level for CI/CD pipelines and builds."
    },
    "wiki_access_level": {
      "type": "string",
      "enum": [
        "disabled",
        "private",
        "enabled",
        "public"
      ],
      "description": "The access level for the project wiki."
    },
    "container_registry_access_level": {
      "type": "string",
      "enum": [
        "disabled",
        "private",
        "enabled",
        "public"
      ],
      "description": "The access level for the container registry."
    },
    "pages_access_level": {
      "type": "string",
      "enum": [
        "disabled",
        "private",
        "enabled",
        "public"
      ],
      "description": "The access level for GitLab Pages."
    },
    "permissions": {
      "$ref": "#/$defs/Permissions"
    },
    "statistics": {
      "$ref": "#/$defs/Statistics"
    },
    "created_at": {
      "type": "datetime",
      "description": "The date and time the project was created."
    },
    "updated_at": {
      "type": "datetime",
      "description": "The date and time the project was last updated."
    },
    "last_activity_at": {
      "type": "datetime",
      "description": "The date and time of the last activity in the project."
    }
  },
  "$defs": {
    "Namespace": {
      "type": "object",
      "description": "The namespace (user or group) that owns the project.",
      "properties": {
        "id": {
          "type": "integer",
          "description": "The unique identifier of the namespace."
        },
        "name": {
          "type": "string",
          "description": "The display name of the namespace."
        },
        "path": {
          "type": "string",
          "description": "The URL path of the namespace."
        },
        "kind": {
          "type": "string",
          "enum": [
            "user",
            "group"
          ],
          "description": "Whether the namespace belongs to a user or a group."
        },
        "full_path": {
          "type": "string",
          "description": "The full path of the namespace."
        },
        "parent_id": {
          "type": [
            "integer",
            "null"
          ],
          "description": "The ID of the parent namespace for subgroups."
        },
        "avatar_url": {
          "type": [
            "string",
            "null"
          ],
          "format": "uri",
          "description": "URL to the namespace avatar image."
        },
        "web_url": {
          "type": "string",
          "format": "uri",
          "description": "URL to the namespace page on GitLab."
        }
      }
    },
    "UserSummary": {
      "type": "object",
      "description": "A simplified representation of a GitLab user.",
      "required": [
        "id",
        "username"
      ],
      "properties": {
        "id": {
          "type": "integer",
          "description": "The unique identifier of the user."
        },
        "username": {
          "type": "string",
          "description": "The username of the user."
        },
        "name": {
          "type": "string",
          "description": "The display name of the user."
        },
        "state": {
          "type": "string",
          "enum": [
            "active",
            "blocked",
            "deactivated"
          ],
          "description": "The current state of the user account."
        },
        "avatar_url": {
          "type": [
            "string",
            "null"
          ],
          "format": "uri",
          "description": "URL to the user's avatar image."
        },
        "web_url": {
          "type": "string",
          "format": "uri",
          "description": "URL to the user's profile on GitLab."
        }
      }
    },
    "Permissions": {
      "type": "object",
      "description": "The access permissions the current user has on the project.",
      "properties": {
        "project_access": {
          "type": [
            "object",
            "null"
          ],
          "description": "Direct project access level for the user.",
          "properties": {
            "access_level": {
              "type": "integer",
              "description": "Access level value (10=Guest, 20=Reporter, 30=Developer, 40=Maintainer, 50=Owner)."
            }
          }
        },
        "group_access": {
          "type": [
            "object",
            "null"
          ],
          "description": "Group-inherited access level for the user.",
          "properties": {
            "access_level": {
              "type": "integer",
              "description": "Access level value inherited from group membership."
            }
          }
        }
      }
    },
    "Statistics": {
      "type": "object",
      "description": "Storage and activity statistics for the project.",
      "properties": {
        "commit_count": {
          "type": "integer",
          "minimum": 0,
          "description": "The total number of commits in the default branch."
        },
        "storage_size": {
          "type": "integer",
          "minimum": 0,
          "description": "Total storage size in bytes."
        },
        "repository_size": {
          "type": "integer",
          "minimum": 0,
          "description": "Git repository size in bytes."
        },
        "wiki_size": {
          "type": "integer",
          "minimum": 0,
          "description": "Wiki repository size in bytes."
        },
        "lfs_objects_size": {
          "type": "integer",
          "minimum": 0,
          "description": "LFS objects size in bytes."
        },
        "job_artifacts_size": {
          "type": "integer",
          "minimum": 0,
          "description": "CI/CD job artifacts size in bytes."
        },
        "packages_size": {
          "type": "integer",
          "minimum": 0,
          "description": "Packages registry size in bytes."
        },
        "snippets_size": {
          "type": "integer",
          "minimum": 0,
          "description": "Snippets size in bytes."
        }
      }
    }
  }
}