Skip to content

Commit

Permalink
Adding HTML content rejection by default for text fields (#754)
Browse files Browse the repository at this point in the history
  • Loading branch information
ilgrosso committed Jun 26, 2024
1 parent fcad066 commit 0c620a9
Show file tree
Hide file tree
Showing 12 changed files with 201 additions and 25 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@
import org.apache.wicket.model.IModel;
import org.apache.wicket.model.ResourceModel;

public class AjaxPasswordFieldPanel extends FieldPanel<String> {
public class AjaxPasswordFieldPanel extends TextFieldPanel {

private static final long serialVersionUID = -5490115280336667460L;

Expand All @@ -50,6 +50,7 @@ public AjaxPasswordFieldPanel(
super(id, name, model);

field = new PasswordTextField("passwordField", model);
setHTMLInputNotAllowed();
add(field.setLabel(new ResourceModel(name, name)).setRequired(false).setOutputMarkupId(true));
Optional.ofNullable(passwordStrengthBehavior).ifPresent(field::add);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,9 +33,8 @@
import org.apache.wicket.extensions.ajax.markup.html.autocomplete.IAutoCompleteRenderer;
import org.apache.wicket.model.IModel;
import org.apache.wicket.model.ResourceModel;
import org.apache.wicket.validation.IValidator;

public class AjaxTextFieldPanel extends FieldPanel<String> implements Cloneable {
public class AjaxTextFieldPanel extends TextFieldPanel implements Cloneable {

private static final long serialVersionUID = 238940918106696068L;

Expand Down Expand Up @@ -70,7 +69,9 @@ protected Iterator<String> getChoices(final String input) {

@Override
protected AutoCompleteBehavior<String> newAutoCompleteBehavior(
final IAutoCompleteRenderer<String> renderer, final AutoCompleteSettings settings) {
final IAutoCompleteRenderer<String> renderer,
final AutoCompleteSettings settings) {

return new IndicatorAutoCompleteBehavior<>(renderer, settings) {

private static final long serialVersionUID = 1070808433195962931L;
Expand All @@ -82,6 +83,7 @@ protected Iterator<String> getChoices(final String input) {
};
}
};
setHTMLInputNotAllowed();
add(field.setLabel(new ResourceModel(name, name)).setOutputMarkupId(true));

if (enableOnChange && !isReadOnly()) {
Expand All @@ -97,10 +99,6 @@ protected void onUpdate(final AjaxRequestTarget target) {
}
}

public void addValidator(final IValidator<? super String> validator) {
this.field.add(validator);
}

public void setChoices(final List<String> choices) {
if (choices != null) {
this.choices = choices;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
import org.apache.wicket.model.IModel;
import org.apache.wicket.model.ResourceModel;

public class EncryptedFieldPanel extends FieldPanel<String> implements Cloneable {
public class EncryptedFieldPanel extends TextFieldPanel implements Cloneable {

private static final long serialVersionUID = 1882871043451691005L;

Expand All @@ -34,7 +34,11 @@ public EncryptedFieldPanel(final String id, final String name, final IModel<Stri
}

public EncryptedFieldPanel(
final String id, final String name, final IModel<String> model, final boolean enableOnChange) {
final String id,
final String name,
final IModel<String> model,
final boolean enableOnChange) {

super(id, name, model);

field = new TextField<>("encryptedField", model) {
Expand All @@ -43,9 +47,10 @@ public EncryptedFieldPanel(

@Override
protected String[] getInputTypes() {
return new String[]{"password"};
return new String[] { "password" };
}
};
setHTMLInputNotAllowed();

if (enableOnChange && !isReadOnly()) {
field.add(new IndicatorAjaxFormComponentUpdatingBehavior(Constants.ON_CHANGE) {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.syncope.client.ui.commons.markup.html.form;

import java.util.regex.Pattern;
import org.apache.wicket.model.IModel;
import org.apache.wicket.validation.IValidatable;
import org.apache.wicket.validation.IValidator;
import org.apache.wicket.validation.ValidationError;

public abstract class TextFieldPanel extends FieldPanel<String> {

private static final long serialVersionUID = 1708195999215061362L;

private static final Pattern HTML_PATTERN = Pattern.compile("<(\"[^\"]*\"|'[^']*'|[^'\">])*>");

public TextFieldPanel(final String id, final String name, final IModel<String> model) {
super(id, name, model);
}

protected TextFieldPanel setHTMLInputNotAllowed() {
field.add(new IValidator<String>() {

private static final long serialVersionUID = -8386207349500954732L;

@Override
public void validate(final IValidatable<String> validatable) {
if (HTML_PATTERN.matcher(validatable.getValue()).matches()) {
ValidationError error = new ValidationError().addKey("htmlErrorMessage");
error.setVariable("label", field.getLabel().getObject());
validatable.error(error);
}
}
});

return this;
}

public void addValidator(final IValidator<? super String> validator) {
this.field.add(validator);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
confirmMessage=This will remove the current value. Continue?
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
htmlErrorMessage=HTML input not allowed for '${label}'
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
htmlErrorMessage=HTML input not allowed for '${label}'
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
htmlErrorMessage=Input HTML non consentito per '${label}'
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
htmlErrorMessage=HTML input not allowed for '${label}'
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
htmlErrorMessage=HTML input not allowed for '${label}'
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
#
# field.DateTimeFieldPanel$DateTimeFormValidator=\u00d0\u009f\u00d0\u00be\u00d0\u00bb\u00d0\u00b5 '${label0}' \u00d0\u00b4\u00d0\u00be\u00d0\u00bb\u00d0\u00b6\u00d0\u00bd\u00d0\u00be \u00d0\u00b1\u00d1\u008b\u00d1\u0082\u00d1\u008c \u00d0\u00b7\u00d0\u00b0\u00d0\u00bf\u00d0\u00be\u00d0\u00bb\u00d0\u00bd\u00d0\u00b5\u00d0\u00bd\u00d0\u00be \u00d0\u00bf\u00d0\u00be\u00d0\u00bb\u00d0\u00bd\u00d0\u00be\u00d1\u0081\u00d1\u0082\u00d1\u008c\u00d1\u008e
htmlErrorMessage=HTML input not allowed for '${label}'
Original file line number Diff line number Diff line change
Expand Up @@ -24,16 +24,16 @@
import org.apache.syncope.client.ui.commons.ajax.form.IndicatorAjaxFormComponentUpdatingBehavior;
import org.apache.syncope.client.ui.commons.ajax.form.IndicatorAutoCompleteBehavior;
import org.apache.syncope.client.ui.commons.markup.html.form.FieldPanel;
import org.apache.syncope.client.ui.commons.markup.html.form.TextFieldPanel;
import org.apache.wicket.ajax.AjaxRequestTarget;
import org.apache.wicket.extensions.ajax.markup.html.autocomplete.AutoCompleteBehavior;
import org.apache.wicket.extensions.ajax.markup.html.autocomplete.AutoCompleteSettings;
import org.apache.wicket.extensions.ajax.markup.html.autocomplete.AutoCompleteTextField;
import org.apache.wicket.extensions.ajax.markup.html.autocomplete.IAutoCompleteRenderer;
import org.apache.wicket.model.IModel;
import org.apache.wicket.model.ResourceModel;
import org.apache.wicket.validation.IValidator;

public class AjaxSearchFieldPanel extends FieldPanel<String> implements Cloneable {
public class AjaxSearchFieldPanel extends TextFieldPanel implements Cloneable {

private static final long serialVersionUID = 6890905510177974519L;

Expand Down Expand Up @@ -75,11 +75,12 @@ protected Iterator<String> getChoices(final String input) {

@Override
protected AutoCompleteBehavior<String> newAutoCompleteBehavior(
final IAutoCompleteRenderer<String> renderer, final AutoCompleteSettings settings) {
final IAutoCompleteRenderer<String> renderer,
final AutoCompleteSettings settings) {

return new IndicatorAutoCompleteBehavior<>(
AjaxSearchFieldPanel.this.renderer != null ? AjaxSearchFieldPanel.this.renderer : renderer,
AjaxSearchFieldPanel.this.settings != null ? AjaxSearchFieldPanel.this.settings : settings) {
AjaxSearchFieldPanel.this.renderer != null ? AjaxSearchFieldPanel.this.renderer : renderer,
AjaxSearchFieldPanel.this.settings != null ? AjaxSearchFieldPanel.this.settings : settings) {

private static final long serialVersionUID = 1070808433195962931L;

Expand All @@ -90,6 +91,7 @@ protected Iterator<String> getChoices(final String input) {
};
}
};
setHTMLInputNotAllowed();
add(field.setLabel(new ResourceModel(name, name)).setOutputMarkupId(true));

if (!isReadOnly()) {
Expand All @@ -105,19 +107,10 @@ protected void onUpdate(final AjaxRequestTarget target) {
}
}

@Override
public FieldPanel<String> setRequired(final boolean required) {
return super.setRequired(required);
}

public List<String> getChoices() {
return choices;
}

public void addValidator(final IValidator<String> validator) {
this.field.add(validator);
}

public void onUpdateBehavior() {
}

Expand Down

0 comments on commit 0c620a9

Please sign in to comment.