2020-10-27 02:14:56 +01:00
|
|
|
import re
|
|
|
|
|
|
|
|
from django.core.exceptions import ValidationError
|
|
|
|
from django.http import HttpRequest, HttpResponse
|
2021-04-16 00:57:30 +02:00
|
|
|
from django.utils.translation import gettext as _
|
2020-10-27 02:14:56 +01:00
|
|
|
|
2022-04-14 23:32:18 +02:00
|
|
|
from zerver.actions.realm_playgrounds import do_add_realm_playground, do_remove_realm_playground
|
2020-10-27 02:14:56 +01:00
|
|
|
from zerver.decorator import require_realm_admin
|
2021-07-16 22:11:10 +02:00
|
|
|
from zerver.lib.exceptions import JsonableError, ValidationFailureError
|
|
|
|
from zerver.lib.request import REQ, has_request_variables
|
2021-07-04 10:00:10 +02:00
|
|
|
from zerver.lib.response import json_success
|
2020-10-27 02:14:56 +01:00
|
|
|
from zerver.lib.validator import check_capped_string, check_url
|
2020-10-27 02:21:22 +01:00
|
|
|
from zerver.models import Realm, RealmPlayground, UserProfile
|
2020-10-27 02:14:56 +01:00
|
|
|
|
|
|
|
|
|
|
|
def check_pygments_language(var_name: str, val: object) -> str:
|
|
|
|
s = check_capped_string(RealmPlayground.MAX_PYGMENTS_LANGUAGE_LENGTH)(var_name, val)
|
|
|
|
# We don't want to restrict the language here to be only from the list of valid
|
|
|
|
# Pygments languages. Keeping it open would allow us to hook up a "playground"
|
|
|
|
# for custom "languages" that aren't known to Pygments. We use a similar strategy
|
2021-04-25 23:11:21 +02:00
|
|
|
# even in our fenced_code Markdown processor.
|
2020-10-27 02:14:56 +01:00
|
|
|
valid_pygments_language = re.compile(r"^[ a-zA-Z0-9_+-./#]*$")
|
|
|
|
matched_results = valid_pygments_language.match(s)
|
|
|
|
if not matched_results:
|
|
|
|
raise JsonableError(_("Invalid characters in pygments language"))
|
|
|
|
return s
|
|
|
|
|
|
|
|
|
2020-10-27 02:21:22 +01:00
|
|
|
def access_playground_by_id(realm: Realm, playground_id: int) -> RealmPlayground:
|
|
|
|
try:
|
|
|
|
realm_playground = RealmPlayground.objects.get(id=playground_id, realm=realm)
|
|
|
|
except RealmPlayground.DoesNotExist:
|
|
|
|
raise JsonableError(_("Invalid playground"))
|
|
|
|
return realm_playground
|
|
|
|
|
|
|
|
|
2020-10-27 02:14:56 +01:00
|
|
|
@require_realm_admin
|
|
|
|
@has_request_variables
|
|
|
|
def add_realm_playground(
|
|
|
|
request: HttpRequest,
|
|
|
|
user_profile: UserProfile,
|
|
|
|
name: str = REQ(),
|
2021-04-17 08:26:57 +02:00
|
|
|
url_prefix: str = REQ(str_validator=check_url),
|
|
|
|
pygments_language: str = REQ(str_validator=check_pygments_language),
|
2020-10-27 02:14:56 +01:00
|
|
|
) -> HttpResponse:
|
|
|
|
try:
|
|
|
|
playground_id = do_add_realm_playground(
|
|
|
|
realm=user_profile.realm,
|
2022-03-11 15:16:04 +01:00
|
|
|
acting_user=user_profile,
|
2020-10-27 02:14:56 +01:00
|
|
|
name=name.strip(),
|
|
|
|
pygments_language=pygments_language.strip(),
|
|
|
|
url_prefix=url_prefix.strip(),
|
|
|
|
)
|
|
|
|
except ValidationError as e:
|
2021-07-04 10:00:10 +02:00
|
|
|
raise ValidationFailureError(e)
|
2022-01-31 13:44:02 +01:00
|
|
|
return json_success(request, data={"id": playground_id})
|
2020-10-27 02:21:22 +01:00
|
|
|
|
|
|
|
|
|
|
|
@require_realm_admin
|
|
|
|
@has_request_variables
|
|
|
|
def delete_realm_playground(
|
|
|
|
request: HttpRequest, user_profile: UserProfile, playground_id: int
|
|
|
|
) -> HttpResponse:
|
|
|
|
realm_playground = access_playground_by_id(user_profile.realm, playground_id)
|
2022-03-11 15:40:42 +01:00
|
|
|
do_remove_realm_playground(user_profile.realm, realm_playground, acting_user=user_profile)
|
2022-01-31 13:44:02 +01:00
|
|
|
return json_success(request)
|