/* GoToSocial Copyright (C) GoToSocial Authors admin@gotosocial.org SPDX-License-Identifier: AGPL-3.0-or-later This program 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. This program 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 this program. If not, see . */ import React from "react"; import { usePostHeaderAllowMutation, usePostHeaderBlockMutation } from "../../../lib/query/admin/http-header-permissions"; import { useTextInput } from "../../../lib/form"; import useFormSubmit from "../../../lib/form/submit"; import { TextInput } from "../../../components/form/inputs"; import MutationButton from "../../../components/form/mutation-button"; import type { PermType } from "../../../lib/types/perm"; import { RE2JS } from "re2js"; export default function HeaderPermCreateForm({ permType }: { permType: PermType }) { const form = { header: useTextInput("header", { validator: (val: string) => { // Technically invalid but avoid // showing red outline when user // hasn't entered anything yet. if (val.length === 0) { return ""; } // Only requirement is that header // must be less than 1024 chars. if (val.length > 1024) { return "header must be less than 1024 characters"; } return ""; }, }), regex: useTextInput("regex", { validator: (val: string) => { // Technically invalid but avoid // showing red outline when user // hasn't entered anything yet. if (val.length === 0) { return ""; } // Ensure regex compiles. try { RE2JS.compile(val); } catch (e) { return e; } return ""; }, }), }; // Use appropriate mutation for given permType. const [ postAllowTrigger, postAllowResult ] = usePostHeaderAllowMutation(); const [ postBlockTrigger, postBlockResult ] = usePostHeaderBlockMutation(); let mutationTrigger; let mutationResult; if (permType === "block") { mutationTrigger = postBlockTrigger; mutationResult = postBlockResult; } else { mutationTrigger = postAllowTrigger; mutationResult = postAllowResult; } const [formSubmit, result] = useFormSubmit( form, [mutationTrigger, mutationResult], { changedOnly: false, onFinish: ({ _data }) => { form.header.reset(); form.regex.reset(); }, }); return (

Create new HTTP header {permType}

Header Name  Learn more about HTTP request headers (opens in a new tab) } placeholder={"User-Agent"} autoCapitalize="none" spellCheck="false" {...{className: "monospace"}} /> Value Regex  Learn more about RE2 regular expressions (opens in a new tab) } placeholder={"^.*Some-User-Agent.*$"} autoCapitalize="none" spellCheck="false" {...{className: "monospace"}} /> ); }