За довольно короткое время написал свой велосипед stiker.me. Использовать удобно и легко.
Под катом, описание функционала и техническая информация.
Немного о функционале
Вариантов использования два — анонимно или залогинившись.
Для анонимного использования вы можете разместить несколько стикеров и кликнуть на кнопку Save. Доска сохрянится под постоянной ссылкой.
Второй вариант, зарегистрироваться или войти под своими OAuth профилем. В этом случае вы можете создавать сколько угодно досок, все они будут отображаться в верхнем комбо-боксе.
Каждая доска имеет имя и категорию для сортировки, тут возможны варианты — работа, дом, бизнес, спорт, вообщем все что угодно. Так же можно добавить других пользователей для совместного доступа, указав email-ы через пробел в поле Grant.
Каждый стикер можно двигать, расширять, менять цвет и вставлять HTML код.
Кстати, почему анти-стартап? Потому, что нет тут никакой монетизации и не планируется. Конкурировать с другими монстрами, не будем. Это просто стикеры… тока в электронном виде.
Разработка
Так как проект не был рассчитан на большую аудиторию, то решил я его делать с пользой для себя и изучить ещё один язык Scala, а заодно и Play framework. Идея по-моему хорошая, но как оказалось ошибочная. У меня получилось быстро поднять все тестовые приложения по гайдам, изучить синтаксис Scala и чуть чуть понять как все устроено в Play. После этого, я потратил кучу времени, а именно 2 недели, чтоб собрать хоть какой-то прототипа Stiker.me. Прототип был готов, но без всякой авторизации и пользователей. Следующую неделю я потратил на то, чтоб найти и настроить модуль авторизации для Scala Play framework-а, причем там была только регистрация по логин / паролю. А как же OpenID и OAuth? Ещё через неделю бросил это дело и написал все на Java, Spring, Hibernate, Freemarker буквально за 3 дня.
Я не говорю, что Play плохой фреймворк, по-моему это лучший в своем роде, но если у тебя уже есть рабочий инструмент под рукой, то должны быть веские причины, чтобы поменять его.
Выводы или Best Practices
- Используйте то, чем владеете лучше всего
- Не стоит пытаться написать проект для продакшена и вместе с тем изучить новый язык программирования
- Не рекомендую писать тесты или использовать TDD (это обязательно нужно делать только после раскрутки)
- Используйте костыли там где можно будет быстро их убрать (например во view или контроллере, но никак не в архитектуре или DAO)
- Выносите маленькие под-проекты, только если уверен в том, что их действительно можно будет легко переиспользовать (в противном случае потратите больше времени на заточку и костыли)
- Вместо маленьких под-проектов, лучше храните какую-то заготовку, шаблон проекта с разными модулями
- Старайтесь выстраивать понятную иерархию:
Тут не много подробнее. Я например для всех java веб проектов использую следующую структуру package-ей:
- data — Entity и DAO
- service — интерфейсы сервисов (API) принимающие Model (из контроллеров) и возвращающие DTO (данные из DAO) + имплементация (Impl)
- web — контроллеры, валидаторы и т.д.
ссылка на оригинал статьи http://habrahabr.ru/post/162987/
Добавить комментарий