Запрос данных WordPressЗаписи
Записи
Это примеры queries для получения и изменения данных записей.
Получение записей
Одна запись с автором и тегами:
query {
post(by: { id: 1 }) {
title
content
url
date
author {
id
name
}
tags {
id
name
}
}
}Список из 5 записей с комментариями:
query {
posts(pagination: { limit: 5 }) {
id
title
excerpt
url
dateStr(format: "d/m/Y")
comments(pagination: { limit: 5 }) {
id
date
content
}
}
}Список заранее заданных записей:
query {
posts(filter: { ids: [1499, 1657] }) {
id
title
excerpt
url
date
}
}Фильтрация записей:
query {
posts(
filter: { search: "wordpress", dateQuery: { after: "2019-06-01" } },
sort: { order: ASC, by: TITLE }
) {
id
title
excerpt
url
status
}
}Подсчёт результатов записей:
query {
postCount(
filter: { search: "api" }
)
}Постраничный вывод записей:
query {
posts(
pagination: {
limit: 5,
offset: 5
}
) {
id
title
}
}Записи с тегами:
query {
posts(
filter: { tagSlugs: ["graphql", "wordpress", "plugin"] }
) {
id
title
}
}Записи с категориями:
query {
posts(
filter: { categoryIDs: [50, 190] }
) {
id
title
}
}Получение мета-значений:
query {
posts {
title
metaValue(
key: "_wp_page_template",
)
}
}Получение записей авторизованного пользователя
Поля post, posts и postCount возвращают только записи со статусом "publish".
Чтобы получить записи авторизованного пользователя с любым статусом ("publish", "pending", "draft" или "trash"), используйте следующие поля:
myPostmyPostsmyPostCount
query {
myPosts(filter: { status: [draft, pending] }) {
id
title
status
}
}Создание записей
Создавать записи могут только авторизованные пользователи.
mutation {
createPost(
input: {
title: "Hi there!"
contentAs: { html: "How do you like it?" }
status: draft
tags: ["demo", "plugin"]
}
) {
status
errors {
__typename
...on ErrorPayload {
message
}
...on GenericErrorPayload {
code
}
}
postID
post {
status
title
content
url
date
author {
id
name
}
tags {
id
name
}
}
}
}Обновление записей
Редактировать записи могут только пользователи с соответствующими правами.
mutation {
updatePost(
input: {
id: 1,
title: "This is my new title",
}
) {
status
errors {
__typename
...on ErrorPayload {
message
}
...on GenericErrorPayload {
code
}
}
post {
id
title
}
}
}Этот запрос использует вложенные мутации для обновления записи:
mutation {
post(by: { id: 1 }) {
originalTitle: title
update(input: {
title: "This is my new title",
contentAs: { html: "This rocks!" }
}) {
status
errors {
__typename
...on ErrorPayload {
message
}
}
post {
newTitle: title
content
}
}
}
}