def post(self):
        self.verify_permissions()
        suggestion_id = int(self.request.get("suggestion_id"))
        verdict = self.request.get("verdict")
        message = self.request.get("user_message")

        admin_email_body = None
        email_body = None
        user = None
        event_key = None
        status = ''
        if verdict == "accept":
            status = 'accept'
            auth_id, user, event_key, email_body = self._process_accepted(suggestion_id, message)
            admin_email_body = """{} ({}) has accepted the request with the following message:
{}

View the key: https://www.thebluealliance.com/admin/api_auth/edit/{}

""".format(self.user_bundle.account.display_name, self.user_bundle.account.email, message, auth_id)

        elif verdict == "reject":
            suggestion = Suggestion.get_by_id(suggestion_id)
            event_key = suggestion.contents['event_key']
            user = suggestion.author.get()
            event = Event.get_by_id(event_key)
            suggestion.review_state = Suggestion.REVIEW_REJECTED
            suggestion.reviewer = self.user_bundle.account.key
            suggestion.reviewed_at = datetime.now()
            suggestion.put()

            status = 'reject'
            email_body = """Hi {},

We have reviewer your request for auth tokens for {} {} and have regretfully declined with the following message:

{}

If you have any questions, please don't hesitate to reach out to us at [email protected]

Thanks,
TBA Admins
""".format(user.display_name, event.year, event.name, message)

            admin_email_body = """{} ({}) has rejected this request with the following reason:
{}
""".format(self.user_bundle.account.display_name, self.user_bundle.account.email, message)

        # Notify the user their keys are available
        if email_body:
            mail.send_mail(sender="The Blue Alliance Contact <*****@*****.**>",
                           to=user.email,
                           subject="The Blue Alliance Auth Tokens for {}".format(event_key),
                           body=email_body)
        if admin_email_body:
            # Subject should match the one in suggest_apiwrite_controller
            subject = "Trusted API Key Request for {}".format(event_key)
            SuggestionNotifier.send_admin_alert_email(subject, admin_email_body)

        self.redirect("/suggest/apiwrite/review?success={}".format(status))
Beispiel #2
0
    def post(self):
        self._require_registration()

        event_name = self.request.get("name", None)
        status, failures = SuggestionCreator.createOffseasonEventSuggestion(
            author_account_key=self.user_bundle.account.key,
            name=event_name,
            start_date=self.request.get("start_date", None),
            end_date=self.request.get("end_date", None),
            website=self.request.get("website", None),
            venue_name=self.request.get("venue_name", None),
            address=self.request.get("venue_address", None),
            city=self.request.get("venue_city", None),
            state=self.request.get("venue_state", None),
            country=self.request.get("venue_country", None)
        )
        if status != 'success':
            # Don't completely wipe form data if validation fails
            self.template_values.update({
                'status': status,
                'failures': failures,
                'name': self.request.get('name', None),
                'start_date': self.request.get('start_date', None),
                'end_date': self.request.get('end_date', None),
                'website': self.request.get('website', None),
                'venue_address': self.request.get('venue_address', None),
            })
            self.response.out.write(
                jinja2_engine.render('suggest_offseason_event.html', self.template_values))
        else:
            subject, body = self._gen_notification_email(event_name)
            SuggestionNotifier.send_admin_alert_email(subject, body)
            self.redirect('/suggest/offseason?status=%s' % status)
Beispiel #3
0
    def post(self):
        self.verify_permissions()
        suggestion_id = int(self.request.get("suggestion_id"))
        verdict = self.request.get("verdict")
        message = self.request.get("user_message")

        admin_email_body = None
        email_body = None
        user = None
        event_key = None
        status = ''
        if verdict == "accept":
            status = 'accept'
            auth_id, user, event_key, email_body = self._process_accepted(suggestion_id)
            admin_email_body = """{} ({}) has accepted the request with the following message:
{}

View the key: https://www.thebluealliance.com/admin/api_auth/edit/{}

""".format(self.user_bundle.account.display_name, self.user_bundle.account.email, message, auth_id)

        elif verdict == "reject":
            suggestion = Suggestion.get_by_id(suggestion_id)
            event_key = suggestion.contents['event_key']
            user = suggestion.author.get()
            event = Event.get_by_id(event_key)
            self._process_rejected(suggestion.key.id())

            status = 'reject'
            email_body = """Hi {},

We have reviewer your request for auth tokens for {} {} and have regretfully declined with the following message:

{}

If you have any questions, please don't hesitate to reach out to us at [email protected]

Thanks,
TBA Admins
""".format(user.display_name, event.year, event.name, message)

            admin_email_body = """{} ({}) has rejected this request with the following reason:
{}
""".format(self.user_bundle.account.display_name, self.user_bundle.account.email, message)

        # Notify the user their keys are available
        if email_body:
            mail.send_mail(sender="The Blue Alliance Contact <*****@*****.**>",
                           to=user.email,
                           subject="The Blue Alliance Auth Tokens for {}".format(event_key),
                           body=email_body)
        if admin_email_body:
            # Subject should match the one in suggest_apiwrite_controller
            subject = "Trusted API Key Request for {}".format(event_key)
            SuggestionNotifier.send_admin_alert_email(subject, admin_email_body)

        self.redirect("/suggest/apiwrite/review?success={}".format(status))
Beispiel #4
0
    def post(self):
        self._require_login()

        auth_types = self.request.get_all("auth_types", [])
        clean_auth_types = filter(lambda a: int(a) in AuthType.type_names.keys(), auth_types)
        event_key = self.request.get("event_key", None)
        status = SuggestionCreator.createApiWriteSuggestion(
            author_account_key=self.user_bundle.account.key,
            event_key=event_key,
            affiliation=self.request.get("role", None),
            auth_types=clean_auth_types,
        )
        if status == 'success':
            subject, body = self._gen_notification_email(event_key, self.user_bundle)
            SuggestionNotifier.send_admin_alert_email(subject, body)
        self.redirect('/request/apiwrite?status={}'.format(status), abort=True)
Beispiel #5
0
    def post(self):
        self._require_login()

        auth_types = self.request.get_all("auth_types", [])
        clean_auth_types = filter(
            lambda a: int(a) in AuthType.type_names.keys(), auth_types)
        event_key = self.request.get("event_key", None)
        status = SuggestionCreator.createApiWriteSuggestion(
            author_account_key=self.user_bundle.account.key,
            event_key=event_key,
            affiliation=self.request.get("role", None),
            auth_types=clean_auth_types,
        )
        if status == 'success':
            subject, body = self._gen_notification_email(
                event_key, self.user_bundle)
            SuggestionNotifier.send_admin_alert_email(subject, body)
        self.redirect('/request/apiwrite?status={}'.format(status), abort=True)
    def post(self):
        self._require_login()

        auth_types = self.request.get_all("auth_types", [])
        clean_auth_types = filter(lambda a: int(a) in AuthType.type_names.keys(), auth_types)
        event_key = self.request.get("event_key", None)
        status = SuggestionCreator.createApiWriteSuggestion(
            author_account_key=self.user_bundle.account.key,
            event_key=event_key,
            affiliation=self.request.get("role", None),
            auth_types=clean_auth_types,
        )
        if status == 'success':
            subject, body = self._gen_notification_email(event_key, self.user_bundle)
            SuggestionNotifier.send_admin_alert_email(subject, body)
        self.template_values.update({
            'status': status,
            "auth_types": AuthType.type_names,
        })
        self.response.out.write(
            jinja2_engine.render('suggest_apiwrite.html', self.template_values))
    def post(self):
        self._require_login()

        auth_types = self.request.get_all("auth_types", [])
        clean_auth_types = filter(
            lambda a: int(a) in AuthType.type_names.keys(), auth_types)
        event_key = self.request.get("event_key", None)
        status = SuggestionCreator.createApiWriteSuggestion(
            author_account_key=self.user_bundle.account.key,
            event_key=event_key,
            affiliation=self.request.get("role", None),
            auth_types=clean_auth_types,
        )
        if status == 'success':
            subject, body = self._gen_notification_email(
                event_key, self.user_bundle)
            SuggestionNotifier.send_admin_alert_email(subject, body)
        self.template_values.update({
            'status': status,
            "auth_types": AuthType.type_names,
        })
        self.response.out.write(
            jinja2_engine.render('suggest_apiwrite.html',
                                 self.template_values))