Мое приложение логически разделено на серверы, которые содержат мои объекты домена Grails и контроллеры; и клиент, где у меня есть классы Ext GWT, которые создают все страницы пользовательского интерфейса.
Для запросов пользовательского интерфейса я использую AJAX-вызов метода контроллера, который возвращает, например, список объектов домена в виде структуры JSON.
Следуя принципу DRY, я не хотел бы «сериализовать» данные домена в строку JSON на сервере, а затем десериализовать их на клиенте в другую структуру - я бы хотел воспользоваться уже имеющимся у меня объектом «Домен». , мне не нужно менять несколько мест при добавлении, изменении или удалении нового поля.
Вопрос: это хороший способ пойти?
Если да, то как лучше всего сделать объекты домена .groovy доступными в "клиентских" классах Ext GWT Java?
Если нет, то почему это плохо и что бы вы посоветовали взамен?





Хорошего способа нет - вам нужен Java-объект, сериализуемый GWT. Единственное реальное решение, которое я вижу, - это написать плагин (или добавить к плагину GWT) способ автогенерации объекта передачи данных, возможно, используя аннотации в объекте домена grails.
Аналогичный метод используется для автоматической генерации интерфейсов RPCAsync в подключаемом модуле gwt - см. GwtGrailsPlugin.groovy в каталоге подключаемого модуля gwt, строка 133 или около того является началом.
Вы можете подключиться к нему (или просто изменить этот файл напрямую, возможно, проще) и вставить некоторый код для генерации файлов передачи данных. Дополнительным преимуществом может быть то, что вы можете детализировать объект передачи данных, чтобы личные данные (например, пароли!) Не передавались.
Если вы пытаетесь это сделать, могу ли я предложить вам опубликовать изменения, чтобы их увидели другие? это может быть полезно. Я действительно подумываю сделать это в одном из моих проектов - я просто еще не дошел до этого! Когда я это сделаю, я опубликую его где-нибудь - возможно, в jira плагина grails gwt.
В качестве альтернативы вы можете отправить свои данные на клиентскую сторону как json или xml. вы можете создать REST api для своей серверной части.
Я проголосовал за ваш вопрос, потому что хочу сделать то же самое.