Tutorial do schema
Tutorial do schemaLição 8: Migrações de site

Lição 8: Migrações de site

Podemos executar um lote de queries GraphQL para adaptar o conteúdo do site ao migrá-lo para um novo domínio, mover páginas para uma URL diferente, entre outros.

Para que esta query GraphQL funcione, a Configuração de Schema aplicada ao endpoint precisa ter as Mutações Aninhadas habilitadas

Adaptando o conteúdo ao novo domínio

Esta query GraphQL primeiro filtra todos os posts que contêm "https://my-old-domain.com" no seu conteúdo, e substitui essa string por "https://my-new-domain.com":

mutation ReplaceOldWithNewDomainInPosts {
  posts(
    filter: {
      search: "https://my-old-domain.com"
    }
  ) {
    id
    rawContent
    adaptedRawContent: _strReplace(
      search: "https://my-old-domain.com"
      replaceWith: "https://my-new-domain.com"
      in: $__rawContent
    )
    update(input: {
      contentAs: { html: $__adaptedRawContent }
    }) {
      status
      errors {
        __typename
        ...on ErrorPayload {
          message
        }
      }
      post {
        id
        rawContent
      }
    }
  }
}

Adaptando o conteúdo a uma nova URL de post ou página

Após alterar o slug de um post ou página, podemos converter todo o conteúdo para apontar para a nova URL.

Esta query GraphQL primeiro recupera o domínio a partir da configuração WordPress "siteurl" para recriar as URLs antigas e novas da página:

query ExportData(
  $oldPageSlug: String!
  $newPageSlug: String!
) {
  siteURL: optionValue(name: "siteurl")
 
  oldPageURL: _strAppend(
    after: $__siteURL,
    append: $oldPageSlug
  ) @export(as: "oldPageURL")
 
  newPageURL: _strAppend(
    after: $__siteURL,
    append: $newPageSlug
  ) @export(as: "newPageURL")
}
 
mutation ReplaceOldWithNewURLInPosts
  @depends(on: "ExportData")
{
  posts(
    filter: {
      search: $oldPageURL
    },
    sort: { by: ID, order: ASC }
  ) {
    id
    rawContent
    adaptedRawContent: _strReplace(
      search: $oldPageURL
      replaceWith: $newPageURL
      in: $__rawContent
    )
    update(input: {
      contentAs: { html: $__adaptedRawContent }
    }) {
      status
      errors {
        __typename
        ...on ErrorPayload {
          message
        }
      }
      post {
        id
        rawContent
      }
    }
  }
}

Em seguida, fornecemos os slugs antigo e novo da página por meio do dicionário variables:

{
  "oldPageSlug": "/privacy/",
  "newPageSlug": "/user-privacy/"
}