diff options
Diffstat (limited to 'service/pixelated/config/app_factory.py')
-rw-r--r-- | service/pixelated/config/app_factory.py | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/service/pixelated/config/app_factory.py b/service/pixelated/config/app_factory.py new file mode 100644 index 00000000..f4aa06d7 --- /dev/null +++ b/service/pixelated/config/app_factory.py @@ -0,0 +1,86 @@ +# +# Copyright (c) 2014 ThoughtWorks, Inc. +# +# Pixelated is free software: you can redistribute it and/or modify +# it under the terms of the GNU Affero General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Pixelated is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Affero General Public License for more details. +# +# You should have received a copy of the GNU Affero General Public License +# along with Pixelated. If not, see <http://www.gnu.org/licenses/>. + +from pixelated.adapter.mail_service import MailService +from pixelated.adapter.mail import InputMail +from pixelated.adapter.soledad_querier import SoledadQuerier +from pixelated.adapter.search import SearchEngine +from pixelated.adapter.draft_service import DraftService +from pixelated.adapter.listener import MailboxListener +import pixelated.bitmask_libraries.session as LeapSession +from pixelated.controllers import * +from pixelated.adapter.tag_service import TagService +import os + + +def _setup_routes(app, home_controller, mails_controller, tags_controller, features_controller): + # home + app.add_url_rule('/', methods=['GET'], view_func=home_controller.home) + # mails + app.add_url_rule('/mails', methods=['GET'], view_func=mails_controller.mails) + app.add_url_rule('/mail/<mail_id>/read', methods=['POST'], view_func=mails_controller.mark_mail_as_read) + app.add_url_rule('/mail/<mail_id>/unread', methods=['POST'], view_func=mails_controller.mark_mail_as_unread) + app.add_url_rule('/mails/unread', methods=['POST'], view_func=mails_controller.mark_many_mail_unread) + app.add_url_rule('/mail/<mail_id>', methods=['GET'], view_func=mails_controller.mail) + app.add_url_rule('/mail/<mail_id>', methods=['DELETE'], view_func=mails_controller.delete_mail) + app.add_url_rule('/mails', methods=['DELETE'], view_func=mails_controller.delete_mails) + app.add_url_rule('/mails', methods=['POST'], view_func=mails_controller.send_mail) + app.add_url_rule('/mail/<mail_id>/tags', methods=['POST'], view_func=mails_controller.mail_tags) + app.add_url_rule('/mails', methods=['PUT'], view_func=mails_controller.update_draft) + # tags + app.add_url_rule('/tags', methods=['GET'], view_func=tags_controller.tags) + # features + app.add_url_rule('/features', methods=['GET'], view_func=features_controller.features) + + +def create_app(debug_enabled, app): + + with app.app_context(): + leap_session = LeapSession.open(app.config['LEAP_USERNAME'], app.config['LEAP_PASSWORD'], + app.config['LEAP_SERVER_NAME']) + tag_service = TagService() + soledad_querier = SoledadQuerier(soledad=leap_session.account._soledad) + pixelated_mailboxes = PixelatedMailBoxes(leap_session.account, soledad_querier) + pixelated_mail_sender = PixelatedMailSender(leap_session.account_email()) + mail_service = MailService(pixelated_mailboxes, pixelated_mail_sender, tag_service, soledad_querier) + search_engine = SearchEngine() + search_engine.index_mails(mail_service.all_mails()) + draft_service = DraftService(pixelated_mailboxes) + + MailboxListener.SEARCH_ENGINE = search_engine + InputMail.FROM_EMAIL_ADDRESS = leap_session.account_email() + + home_controller = HomeController() + features_controller = FeaturesController() + mails_controller = MailsController(mail_service=mail_service, + draft_service=draft_service, + search_engine=search_engine) + tags_controller = TagsController(search_engine=search_engine) + + _setup_routes(app, home_controller, mails_controller, tags_controller, features_controller) + + app.run(host=app.config['HOST'], debug=debug_enabled, + port=app.config['PORT'], use_reloader=False) + + +def get_static_folder(): + static_folder = os.path.abspath(os.path.join(os.path.abspath(__file__), "..", "..", "..", "web-ui", "app")) + # this is a workaround for packaging + if not os.path.exists(static_folder): + static_folder = os.path.abspath(os.path.join(os.path.abspath(__file__), "..", "..", "..", "..", "web-ui", "app")) + if not os.path.exists(static_folder): + static_folder = os.path.join('/', 'usr', 'share', 'pixelated-user-agent') + return static_folder |