Modx restfull api
Доброго времени дня!
Начал изучать vue.js и встал вопрос как сдружить vue с modx?
Есть ли готовое решение для реализации рест апи?
Начал изучать vue.js и встал вопрос как сдружить vue с modx?
Есть ли готовое решение для реализации рест апи?
Комментарии: 19
Делал я эту связку. Можете про рест тут почитать
У меня вот точно такая же проблема. Но этой доки что вы дали ссылку, даже близко не хватает для решения конкретных задач. Так общего плана я бы сказал информация. И вот что странно ни где я например так и не нашел более развернутой информации. Такое ощущение что придется лепить какой-то велосипед с помощью стороннего решения. (
Столкнулся в подобным, информации нет.
Легче modx оставить как админку, а остальное развернуть на express, sequelize, nuxt.js — чем думать об api modx…
Легче modx оставить как админку, а остальное развернуть на express, sequelize, nuxt.js — чем думать об api modx…
Для меня интересна связка Nuxt.js + Modx. Но у Modx нет rest api, как их связывать между собой? pdoTools может отдавать json, но этого мало
Да есть у него rest просто как я выше писал документации «скорее нет чем есть»… В этом вся проблема.
В телеграм канале скидывали решение с помощью подключения slim фреймворка. Но ой как не хочется городить костыли.
В телеграм канале скидывали решение с помощью подключения slim фреймворка. Но ой как не хочется городить костыли.
Руслан это адовый ад получится (сугубо личное мнение). Вопросов, в процессе разработки, будет появляется значительно больше, нежели чем вариантов решения.
Я пришел к выводу, что легче modx использовать как админку, а с помощью sequelize подключаться к базе и передавать нужные запросы и выводить все с помощью nuxt.js
т.е. по сути вы придете к отказу от modx и допилите себе админку и переделаете бд)
но я оговорюсь, что modx мне нравится (с него все началось).
Я пришел к выводу, что легче modx использовать как админку, а с помощью sequelize подключаться к базе и передавать нужные запросы и выводить все с помощью nuxt.js
т.е. по сути вы придете к отказу от modx и допилите себе админку и переделаете бд)
но я оговорюсь, что modx мне нравится (с него все началось).
Спасибо за наводку!
Как раз пошарил на гитхабе, заготовку нашел под связку nuxt + sequelize
github.com/yogesum/vue-express-sequelize-base
Как раз пошарил на гитхабе, заготовку нашел под связку nuxt + sequelize
github.com/yogesum/vue-express-sequelize-base
Не стоит себя ограничивать чем-то одним. Sequalize — это просто ORM, которая помогает вам интерпретировать запросы sql в js. Для начала вам, если нету опыта, лучше начать с связки node + express.
Плюс к каждому вашему ответу от меня )
shtyrman, предложил использовать связку sequelize (для работы с базой данный, это ORM как я понял, пока не читал документацию) docs.sequelizejs.com/
А дальше vuejs (nuxtjs) работает с базой через sequelize.
А админка modx используется для администрирования и по сути никакой контент не генерирует
А дальше vuejs (nuxtjs) работает с базой через sequelize.
А админка modx используется для администрирования и по сути никакой контент не генерирует
Все верно. И в итоге — привет мир js!
Не могли бы посоветовать чтото почитать по вашему решению?
Сергей, тут все упирается в знание js и мониторинг информации за бугром. Если на modx информации порой вообще нет, то на какие то решения в js и подавно хрен что найдешь.
Если вас интересует как стартануть в full stack, то у меня был такой процесс:
— изучаем js. 3-е издание \ Этан Браун
— секреты JavaScript ниндзя. Второе издание
— js подробное руководство. 6-е издание
— веб-разработка с применение node и express \ Итан Браун
— React и Redux. Функциональная веб-разработка
Этого будет достаточно что бы понять как все устроенно и плавать дальше самому, используя документации.
Если вас интересует как стартануть в full stack, то у меня был такой процесс:
— изучаем js. 3-е издание \ Этан Браун
— секреты JavaScript ниндзя. Второе издание
— js подробное руководство. 6-е издание
— веб-разработка с применение node и express \ Итан Браун
— React и Redux. Функциональная веб-разработка
Этого будет достаточно что бы понять как все устроенно и плавать дальше самому, используя документации.
Спасибо!
Все есть Nuxt.js + Modx часть кода от туда.
Есть ли готовое решение для реализации рест апи?Как может существовать готовое решение к методологии общения клиент-сервер?
Для интеграции vue в modx вовсе необязательно следовать REST.
Я подразумевал не совсем готовое)))
В ларавеле допустим апи достаточно просто делается. В модиксе даже схему работы не представляю, отдать данные мы можем в json (хоть через обычные ресурсы — снепеттом). А вот как реализовать обновление и создание? Возможно тоже просто, но глубоко я не копал
В ларавеле допустим апи достаточно просто делается. В модиксе даже схему работы не представляю, отдать данные мы можем в json (хоть через обычные ресурсы — снепеттом). А вот как реализовать обновление и создание? Возможно тоже просто, но глубоко я не копал
Фронт компилишь двумя путями, с двумя конфигами для запросов
1) dev сервер. Среда разработки веб-приложения на vue.js собираемая вебпаком. В алиас конфигов дева и прода кидаем два разных пути. dev и prod. Запросы по api осуществляются через import config from 'config'.
axios.get(config.index.get)…
2) пишем в этот конфиг все url для ajax-запросов.
3) создаём папку на сервере со скриптами, в роли обработчиков запросов. Указываем в modx о том что это статичные сниппеты и возвращаем данные в json. На место чанка писать в json никто не запрещает
1) dev сервер. Среда разработки веб-приложения на vue.js собираемая вебпаком. В алиас конфигов дева и прода кидаем два разных пути. dev и prod. Запросы по api осуществляются через import config from 'config'.
axios.get(config.index.get)…
2) пишем в этот конфиг все url для ajax-запросов.
3) создаём папку на сервере со скриптами, в роли обработчиков запросов. Указываем в modx о том что это статичные сниппеты и возвращаем данные в json. На место чанка писать в json никто не запрещает
Схема работы с RESTfull для modx реализована по документации
Что нужно сделать, пошагово:
Создаем index файл для обработки запросов
Код выше выдернуть из рабочего проект, кое где кое что убрал, так что с первого раза может не запустить.
Дальше уже включаем фантазию и разбираемся с классом rest.modRestService
И тут вот чтобы не ошибатся
yadi.sk/i/MyAlG1dNdIEOWQ
MyController — это название основного префикса? и прописывается он в rest/index.php
То есть если у вас контроллер называется вот так resource то класс для него будет
Что нужно сделать, пошагово:
Создаем index файл для обработки запросов
rest/index.php
https://gist.github.com/webnitros/b8e56c0482a797c926e69ff507a72aa9
Создаем контроллер: пример файла контроллера для получения способов оплаты из minishoprest/Controllers/payment.php
https://gist.github.com/webnitros/bc2cf0417df58a945202a55683519d1e
В конфиге nginx прописываем вот так:location /rest/ {
try_files $uri @modx_rest;
}
location @modx_rest {
rewrite ^/rest/(.*)$ /rest/index.php?_rest=$1&$args last;
}
Обащение происходитhttps://mysite.ru/rest/payment
Вернет массив данных в json форматеКод выше выдернуть из рабочего проект, кое где кое что убрал, так что с первого раза может не запустить.
Дальше уже включаем фантазию и разбираемся с классом rest.modRestService
И тут вот чтобы не ошибатся
yadi.sk/i/MyAlG1dNdIEOWQ
MyController — это название основного префикса? и прописывается он в rest/index.php
То есть если у вас контроллер называется вот так resource то класс для него будет
MyControllerResource
rest/Controllers/resource.php
Кстати контроллер работает имено в связке vue с modx
Авторизуйтесь или зарегистрируйтесь, чтобы оставлять комментарии.