--- title: Managing enterprise accounts intro: You can manage your enterprise account and the organizations it owns with the GraphQL API. redirect_from: - /v4/guides/managing-enterprise-accounts versions: ghec: '*' ghes: '*' topics: - API shortTitle: Manage enterprise accounts --- ## About managing enterprise accounts with GraphQL To help you monitor and make changes in your organizations and maintain compliance, you can use the Enterprise Accounts API and the Audit Log API, which are only available as GraphQL APIs. The enterprise account endpoints work for both GitHub Enterprise Cloud and for GitHub Enterprise Server. GraphQL allows you to request and return just the data you specify. For example, you can create a GraphQL query, or request for information, to see all the new organization members added to your organization. Or you can make a mutation, or change, to invite an administrator to your enterprise account. With the Audit Log API, you can monitor when someone: * Accesses your organization or repository settings. * Changes permissions. * Adds or removes users in an organization, repository, or team. * Promotes users to admin. * Changes permissions of a GitHub App. The Audit Log API enables you to keep copies of your audit log data. For queries made with the Audit Log API, the GraphQL response can include data for up to 90 to 120 days. For a list of the fields available with the Audit Log API, see the [AUTOTITLE](/graphql/reference/interfaces#auditentry/). With the Enterprise Accounts API, you can: * List and review all of the organizations and repositories that belong to your enterprise account. * Change Enterprise account settings. * Configure policies for settings on your enterprise account and its organizations. * Invite administrators to your enterprise account. * Create new organizations in your enterprise account. For a list of the fields available with the Enterprise Accounts API, see [AUTOTITLE](/graphql/guides/managing-enterprise-accounts#graphql-fields-and-types-for-the-enterprise-accounts-api). ## Getting started using GraphQL for enterprise accounts See [AUTOTITLE](/graphql/guides/using-graphql-clients) to get started using GraphQL to manage your enterprise accounts. For some example queries, see [An example query using the Enterprise Accounts API](#an-example-query-using-the-enterprise-accounts-api). ### 1. Authenticate with your {% data variables.product.pat_generic %} 1. To authenticate with GraphQL, you need to generate a {% data variables.product.pat_generic %} from developer settings. For more information, see [AUTOTITLE](/authentication/keeping-your-account-and-data-secure/creating-a-personal-access-token). 1. Grant admin and full control permissions to your {% data variables.product.pat_generic %} for areas of your enterprise you'd like to access. For full permission to private repositories, organizations, teams, user data, and access to enterprise billing and profile data, we recommend you select these scopes for your {% data variables.product.pat_generic %}: * `repo` * `admin:org` * `user` * `admin:enterprise` The enterprise account specific scopes are: * `admin:enterprise`: Gives full control of enterprises (includes `manage_runners:enterprise`, `manage_billing:enterprise` and `read:enterprise`) * `manage_billing:enterprise`: Read and write enterprise billing data.{% ifversion ghes %} * `manage_runners:enterprise`: Access to manage GitHub Actions enterprise runners and runner-groups.{% endif %} * `read:enterprise`: Read enterprise profile data. 1. Copy your {% data variables.product.pat_generic %} and keep it in a secure place until you add it to your GraphQL client. ### 2. Choose a GraphQL client We recommend you use GraphiQL or another standalone GraphQL client that lets you configure the base URL. You may also consider using these GraphQL clients: * [Insomnia](https://support.insomnia.rest/article/176-graphql-queries) * [GraphiQL](https://www.gatsbyjs.org/docs/running-queries-with-graphiql/) * [Postman](https://learning.getpostman.com/docs/postman/sending_api_requests/graphql/) The next steps will use Insomnia. ### 3. Setting up Insomnia to use the GitHub GraphQL API with enterprise accounts 1. Add the base url and `POST` method to your GraphQL client. When using GraphQL to request information (queries), change information (mutations), or transfer data using the GitHub API, the default HTTP method is `POST` and the base url follows this syntax: * For your enterprise instance: `https:///api/graphql` * For GitHub Enterprise Cloud: `https://api.github.com/graphql` * For GitHub Enterprise Cloud with Data Residency: `https://api.SUBDOMAIN.ghe.com/graphql` 1. Select the "Auth" menu and click **Bearer Token**. If you've previously selected a different authentication method, the menu will be labeled with that method, such as "Basic Auth", instead. ![Screenshot of the expanded "Auth" menu in Insomnia. The menu label, "Auth", and the "Bearer Token" option are outlined in dark orange.](/assets/images/developer/graphql/insomnia-bearer-token-option.png) 1. In the "TOKEN" field, enter your {% data variables.product.pat_generic %} from an earlier step. ![Screenshot of the "Bearer" authentication settings in Insomnia. The "TOKEN" field is outlined in dark orange.](/assets/images/developer/graphql/insomnia-base-url-and-pat.png) 1. Click **Headers**. ![Screenshot of the settings tabs in Insomnia. The "Headers" tab is outlined in dark orange.](/assets/images/developer/graphql/json-content-type-header.png) 1. Under the **Headers** tab, click **Add**. 1. In the "header" field, enter `Content-Type`. 1. In the "value" field, enter `application/json`. Now you are ready to start making queries. ## An example query using the Enterprise Accounts API This GraphQL query requests the total number of `public` repositories in each of your appliance's organizations using the Enterprise Accounts API. To customize this query, replace `` with the handle for your enterprise account. For example, if your enterprise account is located at `https://github.com/enterprises/octo-enterprise`, replace `` with `octo-enterprise`. ```graphql query publicRepositoriesByOrganization($slug: String!) { enterprise(slug: $slug) { ...enterpriseFragment } } fragment enterpriseFragment on Enterprise { ... on Enterprise{ name organizations(first: 100){ nodes{ name ... on Organization{ name repositories(privacy: PUBLIC){ totalCount } } } } } } # Passing our Enterprise Account as a variable variables { "slug": "" } ``` The next GraphQL query example shows how challenging it is to retrieve the number of `public` repositories in each organization without using the Enterprise Account API. Notice that the GraphQL Enterprise Accounts API has made this task simpler for enterprises since you only need to customize a single variable. To customize this query, replace `` and ``, etc. with the organization names on your instance. ```graphql # Each organization is queried separately { organizationOneAlias: organization(login: "nameOfOrganizationOne") { # How to use a fragment ...repositories } organizationTwoAlias: organization(login: "nameOfOrganizationTwo") { ...repositories } # organizationThreeAlias ... and so on up-to lets say 100 } ## How to define a fragment fragment repositories on Organization { name repositories(privacy: PUBLIC){ totalCount } } ``` ## Query each organization separately ```graphql query publicRepositoriesByOrganization { organizationOneAlias: organization(login: "") { # How to use a fragment ...repositories } organizationTwoAlias: organization(login: "") { ...repositories } # organizationThreeAlias ... and so on up-to lets say 100 } # How to define a fragment fragment repositories on Organization { name repositories(privacy: PUBLIC){ totalCount } } ``` This GraphQL query requests the last 5 log entries for an enterprise organization. To customize this query, replace `` and ``. ```graphql { organization(login: "") { auditLog(last: 5, query: "actor:") { edges { node { ... on AuditEntry { # Get Audit Log Entry by 'Action' action actorLogin createdAt # User 'Action' was performed on user{ name email } } } } } } } ``` For more information about getting started with GraphQL, see [AUTOTITLE](/graphql/guides/introduction-to-graphql) and [AUTOTITLE](/graphql/guides/forming-calls-with-graphql). ## GraphQL fields and types for the Enterprise Accounts API For more details about the new queries, mutations, and schema defined types available for use with the Enterprise Accounts API, see the sidebar with detailed GraphQL definitions from any [GraphQL reference page](/graphql). You can access the reference docs from within the GraphQL clients. For more information, see [AUTOTITLE](/graphql/guides/using-graphql-clients). For other information, such as authentication and rate limit details, check out the [guides](/graphql/guides).