Modx restfull api

Доброго времени дня!
Начал изучать vue.js и встал вопрос как сдружить vue с modx?
Есть ли готовое решение для реализации рест апи?
Руслан Сафин
01 июня 2018, 14:43
modx.pro
4
3 348
+1

Комментарии: 19

Михаил
02 июня 2018, 07:44
0
Делал я эту связку. Можете про рест тут почитать
    Sergey Leleko
    03 июня 2018, 19:50
    0
    У меня вот точно такая же проблема. Но этой доки что вы дали ссылку, даже близко не хватает для решения конкретных задач. Так общего плана я бы сказал информация. И вот что странно ни где я например так и не нашел более развернутой информации. Такое ощущение что придется лепить какой-то велосипед с помощью стороннего решения. (
      shtyrman
      04 июня 2018, 11:39
      +1
      Столкнулся в подобным, информации нет.
      Легче modx оставить как админку, а остальное развернуть на express, sequelize, nuxt.js — чем думать об api modx…
        Руслан Сафин
        04 июня 2018, 11:46
        0
        Для меня интересна связка Nuxt.js + Modx. Но у Modx нет rest api, как их связывать между собой? pdoTools может отдавать json, но этого мало
          Sergey Leleko
          04 июня 2018, 11:50
          0
          Да есть у него rest просто как я выше писал документации «скорее нет чем есть»… В этом вся проблема.
          В телеграм канале скидывали решение с помощью подключения slim фреймворка. Но ой как не хочется городить костыли.
            shtyrman
            04 июня 2018, 12:00
            +2
            Руслан это адовый ад получится (сугубо личное мнение). Вопросов, в процессе разработки, будет появляется значительно больше, нежели чем вариантов решения.
            Я пришел к выводу, что легче modx использовать как админку, а с помощью sequelize подключаться к базе и передавать нужные запросы и выводить все с помощью nuxt.js
            т.е. по сути вы придете к отказу от modx и допилите себе админку и переделаете бд)

            но я оговорюсь, что modx мне нравится (с него все началось).
              Руслан Сафин
              04 июня 2018, 12:11
              0
              Спасибо за наводку!
              Как раз пошарил на гитхабе, заготовку нашел под связку nuxt + sequelize
              github.com/yogesum/vue-express-sequelize-base
                shtyrman
                04 июня 2018, 12:20
                +2
                Не стоит себя ограничивать чем-то одним. Sequalize — это просто ORM, которая помогает вам интерпретировать запросы sql в js. Для начала вам, если нету опыта, лучше начать с связки node + express.
                  Sergey Leleko
                  04 июня 2018, 12:33
                  0
                  Плюс к каждому вашему ответу от меня )
                    Руслан Сафин
                    04 июня 2018, 12:43
                    0
                    shtyrman, предложил использовать связку sequelize (для работы с базой данный, это ORM как я понял, пока не читал документацию) docs.sequelizejs.com/

                    А дальше vuejs (nuxtjs) работает с базой через sequelize.

                    А админка modx используется для администрирования и по сути никакой контент не генерирует
                      shtyrman
                      04 июня 2018, 12:59
                      0
                      Все верно. И в итоге — привет мир js!
                Sergey Leleko
                04 июня 2018, 12:11
                0
                Не могли бы посоветовать чтото почитать по вашему решению?
                  shtyrman
                  04 июня 2018, 13:07
                  2
                  +2
                  Сергей, тут все упирается в знание js и мониторинг информации за бугром. Если на modx информации порой вообще нет, то на какие то решения в js и подавно хрен что найдешь.
                  Если вас интересует как стартануть в full stack, то у меня был такой процесс:
                  — изучаем js. 3-е издание \ Этан Браун
                  — секреты JavaScript ниндзя. Второе издание
                  — js подробное руководство. 6-е издание
                  — веб-разработка с применение node и express \ Итан Браун
                  — React и Redux. Функциональная веб-разработка
                  Этого будет достаточно что бы понять как все устроенно и плавать дальше самому, используя документации.
              Андрей Степаненко
              12 февраля 2019, 08:11
              0
              Все есть Nuxt.js + Modx часть кода от туда.
        Никита
        11 февраля 2019, 15:25
        0
        Есть ли готовое решение для реализации рест апи?
        Как может существовать готовое решение к методологии общения клиент-сервер?
        Для интеграции vue в modx вовсе необязательно следовать REST.
          Руслан Сафин
          11 февраля 2019, 22:00
          0
          Я подразумевал не совсем готовое)))
          В ларавеле допустим апи достаточно просто делается. В модиксе даже схему работы не представляю, отдать данные мы можем в json (хоть через обычные ресурсы — снепеттом). А вот как реализовать обновление и создание? Возможно тоже просто, но глубоко я не копал
            Никита
            11 февраля 2019, 22:32
            1
            0
            Фронт компилишь двумя путями, с двумя конфигами для запросов
            1) dev сервер. Среда разработки веб-приложения на vue.js собираемая вебпаком. В алиас конфигов дева и прода кидаем два разных пути. dev и prod. Запросы по api осуществляются через import config from 'config'.
            axios.get(config.index.get)…

            2) пишем в этот конфиг все url для ajax-запросов.
            3) создаём папку на сервере со скриптами, в роли обработчиков запросов. Указываем в modx о том что это статичные сниппеты и возвращаем данные в json. На место чанка писать в json никто не запрещает
              Андрей Степаненко
              12 февраля 2019, 07:17
              2
              0
              Схема работы с RESTfull для modx реализована по документации

              Что нужно сделать, пошагово:
              Создаем index файл для обработки запросов
              rest/index.php
              https://gist.github.com/webnitros/b8e56c0482a797c926e69ff507a72aa9
              Создаем контроллер: пример файла контроллера для получения способов оплаты из minishop
              rest/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
            Авторизуйтесь или зарегистрируйтесь, чтобы оставлять комментарии.
            19