#include "form_validator.h" #include "../http/web_server_request.h" //FormFieldEntry PoolStringArray FormFieldEntry::validate(Ref request, const Ref &field, const String &data) { return call("_validate", request, field, data); } PoolStringArray FormFieldEntry::_validate(Ref request, const Ref &field, const String &data) { return PoolStringArray(); } FormFieldEntry::FormFieldEntry() { } FormFieldEntry::~FormFieldEntry() { } //FormExistsFieldEntry PoolStringArray FormExistsFieldEntry::_validate(Ref request, const Ref &field, const String &data) { PoolStringArray errors; if (data == "") { errors.push_back(field->get_human_name() + not_exists_error); } return errors; } FormExistsFieldEntry::FormExistsFieldEntry() { not_exists_error = " field need to exists!"; } FormExistsFieldEntry::~FormExistsFieldEntry() { } //FormIntFieldEntry PoolStringArray FormIntFieldEntry::_validate(Ref request, const Ref &field, const String &data) { PoolStringArray errors; if (data.empty()) { return errors; } if (!data.is_valid_integer()) { errors.push_back(field->get_human_name() + not_int_error); } return errors; } FormIntFieldEntry::FormIntFieldEntry() { not_int_error = " needs to be an integer."; } FormIntFieldEntry::~FormIntFieldEntry() { } //FormFloatFieldEntry PoolStringArray FormFloatFieldEntry::_validate(Ref request, const Ref &field, const String &data) { PoolStringArray errors; if (data.empty()) { return errors; } if (!data.is_valid_float()) { errors.push_back(field->get_human_name() + not_float_error); } return errors; } FormFloatFieldEntry::FormFloatFieldEntry() { not_float_error = " needs to be an floating point number."; } FormFloatFieldEntry::~FormFloatFieldEntry() { } //FormAlphaFieldEntry PoolStringArray FormAlphaFieldEntry::_validate(Ref request, const Ref &field, const String &data) { PoolStringArray errors; for (int i = 0; i < data.size(); ++i) { if (!isalpha(data[i])) { errors.push_back(field->get_human_name() + not_alpha_error); return errors; } } return errors; } FormAlphaFieldEntry::FormAlphaFieldEntry() { not_alpha_error = " needs to only contain caharcters."; } FormAlphaFieldEntry::~FormAlphaFieldEntry() { } //FormAlphaNumericFieldEntry PoolStringArray FormAlphaNumericFieldEntry::_validate(Ref request, const Ref &field, const String &data) { PoolStringArray errors; for (int i = 0; i < data.size(); ++i) { if (!isalnum(data[i])) { errors.push_back(field->get_human_name() + not_alpha_numeric_error); return errors; } } return errors; } FormAlphaNumericFieldEntry::FormAlphaNumericFieldEntry() { not_alpha_numeric_error = " needs to only contain caharcters of numbers."; } FormAlphaNumericFieldEntry::~FormAlphaNumericFieldEntry() { } //FormNeedsLowercaseCharacterFieldEntry PoolStringArray FormNeedsLowercaseCharacterFieldEntry::_validate(Ref request, const Ref &field, const String &data) { PoolStringArray errors; for (int i = 0; i < data.size(); ++i) { if (islower(data[i])) { return errors; } } errors.push_back(field->get_human_name() + does_not_have_lowercase_error); return errors; } FormNeedsLowercaseCharacterFieldEntry::FormNeedsLowercaseCharacterFieldEntry() { does_not_have_lowercase_error = " needs at least one lowercase character!"; } FormNeedsLowercaseCharacterFieldEntry::~FormNeedsLowercaseCharacterFieldEntry() { } //FormNeedsUppercaseCharacterFieldEntry PoolStringArray FormNeedsUppercaseCharacterFieldEntry::_validate(Ref request, const Ref &field, const String &data) { PoolStringArray errors; for (int i = 0; i < data.size(); ++i) { if (isupper(data[i])) { return errors; } } errors.push_back(field->get_human_name() + does_not_have_uppercase_error); return errors; } FormNeedsUppercaseCharacterFieldEntry::FormNeedsUppercaseCharacterFieldEntry() { does_not_have_uppercase_error = " needs at least one uppercase character!"; } FormNeedsUppercaseCharacterFieldEntry::~FormNeedsUppercaseCharacterFieldEntry() { } //FormNeedsOtherCharacterFieldEntry PoolStringArray FormNeedsOtherCharacterFieldEntry::_validate(Ref request, const Ref &field, const String &data) { PoolStringArray errors; for (int i = 0; i < data.size(); ++i) { if (!isalnum(data[i])) { return errors; } } errors.push_back(field->get_human_name() + does_not_have_other_error); return errors; } FormNeedsOtherCharacterFieldEntry::FormNeedsOtherCharacterFieldEntry() { does_not_have_other_error = " needs at least one other character!"; } FormNeedsOtherCharacterFieldEntry::~FormNeedsOtherCharacterFieldEntry() { } //FormMinimumLengthFieldEntry PoolStringArray FormMinimumLengthFieldEntry::_validate(Ref request, const Ref &field, const String &data) { PoolStringArray errors; if (data.size() < min_length) { errors.push_back(field->get_human_name() + does_not_have_min_length_errorf + itos(min_length) + does_not_have_min_length_errors); } return errors; } FormMinimumLengthFieldEntry::FormMinimumLengthFieldEntry() { does_not_have_min_length_errorf = " needs at least "; does_not_have_min_length_errors = " characters!"; min_length = 5; } FormMinimumLengthFieldEntry::~FormMinimumLengthFieldEntry() { } //FormMaximumLengthFieldEntry PoolStringArray FormMaximumLengthFieldEntry::_validate(Ref request, const Ref &field, const String &data) { PoolStringArray errors; if (data.size() > max_length) { errors.push_back(field->get_human_name() + does_not_have_max_length_errorf + itos(max_length) + does_not_have_max_length_errors); } return errors; } FormMaximumLengthFieldEntry::FormMaximumLengthFieldEntry() { does_not_have_max_length_errorf = " needs at most "; does_not_have_max_length_errors = " characters!"; max_length = 10; } FormMaximumLengthFieldEntry::~FormMaximumLengthFieldEntry() { } //FormEmailFieldEntry PoolStringArray FormEmailFieldEntry::_validate(Ref request, const Ref &field, const String &data) { PoolStringArray errors; if (data.size() == 0) { errors.push_back(field->get_human_name() + email_format_error); return errors; } if (!isalpha(data[0])) { errors.push_back(field->get_human_name() + email_format_error); return errors; } int dot_pos = -1; int at_pos = -1; for (int i = 0; i < data.size(); ++i) { if (data[i] == '.') { if (dot_pos != -1) { errors.push_back(field->get_human_name() + email_format_error); return errors; } dot_pos = i; return errors; } } if (dot_pos == -1) { errors.push_back(field->get_human_name() + email_format_error); return errors; } for (int i = 0; i < data.size(); ++i) { if (data[i] == '@') { if (at_pos != -1) { errors.push_back(field->get_human_name() + email_format_error); return errors; } at_pos = i; return errors; } } if (at_pos == -1) { errors.push_back(field->get_human_name() + email_format_error); return errors; } for (int i = 0; i < data.size(); ++i) { if (i == at_pos || i == dot_pos) { continue; } if (!isalnum(data[i])) { errors.push_back(field->get_human_name() + email_format_error); return errors; } } return errors; } FormEmailFieldEntry::FormEmailFieldEntry() { email_format_error = " is invalid!"; } FormEmailFieldEntry::~FormEmailFieldEntry() { } //FormNeedToMatchOtherFieldEntry PoolStringArray FormNeedToMatchOtherFieldEntry::_validate(Ref request, const Ref &field, const String &data) { PoolStringArray errors; if (data != request->get_parameter(other_field)) { errors.push_back(field->get_human_name() + does_not_match_error + field->get_field_name() + "."); } return errors; } FormNeedToMatchOtherFieldEntry::FormNeedToMatchOtherFieldEntry() { does_not_match_error = " does not match "; } FormNeedToMatchOtherFieldEntry::~FormNeedToMatchOtherFieldEntry() { } //FormField String FormField::get_field_name() const { return _field_name; } void FormField::set_field_name(const String &val) { _field_name = val; } String FormField::get_human_name() const { return _human_name; } void FormField::set_human_name(const String &val) { _human_name = val; } bool FormField::get_ignore_if_not_exists() const { return _ignore_if_not_exists; } void FormField::set_ignore_if_not_exists(const bool &val) { _ignore_if_not_exists = val; } bool FormField::get_ignore_if_other_field_not_exists() const { return _ignore_if_other_field_not_exists; } void FormField::set_ignore_if_other_field_not_exists(const bool &val) { _ignore_if_other_field_not_exists = val; } String FormField::get_ignore_if_other_field_not_exist_field() const { return _ignore_if_other_field_not_exist_field; } void FormField::set_ignore_if_other_field_not_exist_field(const String &val) { _ignore_if_other_field_not_exist_field = val; } void FormField::add_entry(const Ref &field) { _entries.push_back(field); } Ref FormField::get_entry(const int index) { ERR_FAIL_INDEX_V(index, _entries.size(), Ref()); return _entries[index]; } void FormField::remove_entry(const int index) { ERR_FAIL_INDEX(index, _entries.size()); _entries.remove(index); } void FormField::clear_entries() { _entries.clear(); } int FormField::get_entry_count() const { return _entries.size(); } Vector FormField::get_entries() { Vector r; for (int i = 0; i < _entries.size(); i++) { r.push_back(_entries[i].get_ref_ptr()); } return r; } void FormField::set_entries(const Vector &p_arrays) { _entries.clear(); for (int i = 0; i < p_arrays.size(); ++i) { Ref f = Ref(p_arrays[i]); _entries.push_back(f); } } Ref FormField::need_to_exist() { Ref f; f.instance(); add_entry(f); return Ref(this); } Ref FormField::need_to_be_int() { Ref f; f.instance(); add_entry(f); return Ref(this); } Ref FormField::need_to_be_float() { Ref f; f.instance(); add_entry(f); return Ref(this); } Ref FormField::need_to_be_alpha() { Ref f; f.instance(); add_entry(f); return Ref(this); } Ref FormField::need_to_be_alpha_numeric() { Ref f; f.instance(); add_entry(f); return Ref(this); } Ref FormField::need_to_have_lowercase_character() { Ref f; f.instance(); add_entry(f); return Ref(this); } Ref FormField::need_to_have_uppercase_character() { Ref f; f.instance(); add_entry(f); return Ref(this); } Ref FormField::need_to_have_other_character() { Ref f; f.instance(); add_entry(f); return Ref(this); } Ref FormField::need_minimum_length(const int min_length) { Ref f; f.instance(); f->min_length = min_length; add_entry(f); return Ref(this); } Ref FormField::need_maximum_length(const int max_length) { Ref f; f.instance(); f->max_length = max_length; add_entry(f); return Ref(this); } Ref FormField::need_to_be_email() { Ref f; f.instance(); add_entry(f); return Ref(this); } Ref FormField::need_to_match(const String &other) { Ref f; f.instance(); f->other_field = other; add_entry(f); return Ref(this); } Ref FormField::ignore_if_not_exists() { _ignore_if_not_exists = true; return Ref(this); } Ref FormField::ignore_if_other_field_not_exists(const String &other) { _ignore_if_other_field_not_exists = true; _ignore_if_other_field_not_exist_field = other; return Ref(this); } PoolStringArray FormField::validate(const Ref &request) { return call("_validate", request); } PoolStringArray FormField::_validate(Ref request) { String param = request->get_parameter(get_field_name()); if (_ignore_if_not_exists && param == "") { return PoolStringArray(); } if (_ignore_if_other_field_not_exists) { String op = request->get_parameter(_ignore_if_other_field_not_exist_field); if (op == "") { return PoolStringArray(); } } PoolStringArray arr; for (int i = 0; i < _entries.size(); ++i) { Ref f = _entries[i]; if (f.is_valid()) { arr.append_array(f->validate(request, Ref(this), param)); } } return arr; } FormField::FormField() { _ignore_if_not_exists = false; _ignore_if_other_field_not_exists = false; } FormField::~FormField() { _entries.clear(); } //FormValidator void FormValidator::add_field(const Ref &field) { _fields.push_back(field); } Ref FormValidator::get_field(const int index) { ERR_FAIL_INDEX_V(index, _fields.size(), Ref()); return _fields[index]; } void FormValidator::remove_field(const int index) { ERR_FAIL_INDEX(index, _fields.size()); _fields.remove(index); } void FormValidator::clear_fields() { _fields.clear(); } Ref FormValidator::new_field(const String &name, const String &human_name) { Ref f; f.instance(); f->set_field_name(name); f->set_human_name(human_name); _fields.push_back(f); return f; } int FormValidator::get_field_count() const { return _fields.size(); } Vector FormValidator::get_fields() { Vector r; for (int i = 0; i < _fields.size(); i++) { r.push_back(_fields[i].get_ref_ptr()); } return r; } void FormValidator::set_fields(const Vector &p_arrays) { _fields.clear(); for (int i = 0; i < p_arrays.size(); ++i) { Ref f = Ref(p_arrays[i]); _fields.push_back(f); } } PoolStringArray FormValidator::validate(const Ref &request) { return call("_validate", request); } PoolStringArray FormValidator::_validate(Ref request) { PoolStringArray arr; for (int i = 0; i < _fields.size(); ++i) { Ref f = _fields[i]; if (f.is_valid()) { arr.append_array(f->validate(request)); } } return arr; } FormValidator::FormValidator() { } FormValidator::~FormValidator() { _fields.clear(); }