Required validation works on client side, so I have not tested it on server.
I can say, that when my custom validation causes error (password and
password verification don't match), then I have 2 error messages on
registration page (if email is also not valid) - email error and password
verification error.

Anton

2010/10/25 Mark <mark-li...@xeric.net>

> Do all the other validations perform as expected other than email? Does the
> "required" validation on email work correctly and give you an error when
> you
> try to submit. Also do you have any types of constraints on the email field
> in the database? Is it possible that what you are entering in the email
> fields is passing the email validation, but getting rejected by the
> database?
>
> I don't remember what Tapestry uses to determine whether or not something
> is
> a valid email address, but I do know that the actual spec for email
> addresses is a lot more permissive than you'd think.
>
> Mark
>
> On Mon, Oct 25, 2010 at 6:35 AM, Anton Mezerny <anton.meze...@gmail.com
> >wrote:
>
> > So, I removed initializeNewUser() from Registration.java and added
> @Inject
> > annotation to User.java and Customer.java (I also made user and customer
> > separate, not nested one into another and I nest user into customer just
> > before saving to DB). Now page renders well, but when I try to save user
> > and
> > customer (and email is invalid) - email validation does not occurs - I
> just
> > have email = null in my customer.email field (even if i set some
> incorrect
> > value, for exapmle 'test_email'). There is no redirect to the
> registration
> > page with error message - program continues execution and tries to save
> > data
> > to DB.
> >
> > 2010/10/23 Mark W. Shead <mwsh...@gmail.com>
> >
> > > I don't think you want to use flash persistence for this.  Try just
> > > using @Persist. It looks like you are creating a new user every time
> > > the page renders.
> > >
> > > Mark
> > >
> > > On Sat, Oct 23, 2010 at 3:08 PM, Jim O'Callaghan <
> jc1000...@yahoo.co.uk>
> > > wrote:
> > > > I'm not sure if this is relevant to your current problem, but to tell
> > > > Tapestry which constructor to use for the bean editor, you should
> > > annotate
> > > > the default (no args) constructor with @Inject - this will allow the
> > BEF
> > > to
> > > > create the relevant entity if none if present.  Hope this helps.
> > > >
> > > > Regards,
> > > > Jim.
> > > >
> > > > -----Original Message-----
> > > > From: Anton Mezerny [mailto:anton.meze...@gmail.com]
> > > > Sent: 23 October 2010 17:02
> > > > To: Tapestry users
> > > > Subject: Objects session persistance and validation
> > > >
> > > > Hi all,
> > > > I'm trying to write simple registration form using beaneditor
> > component.
> > > > If I fullfill all reqired fields in the form and submit it -
> everything
> > > > works fine, but if server validation occurs (for example passwords
> > don't
> > > > match), then all data is lost and Registration page renders with
> > > validation
> > > > errors, but without user data (input values).
> > > > I think the reason for this behaviour is the initializeNewUser()
> > method,
> > > > wich rewrites all data if user field is null. But if I delete this
> > method
> > > > from code, tapestry throws exception - User can't be instantiated
> > > (tapestry
> > > > tries to use constructor with most parameters, which has custom
> > objects,
> > > not
> > > > only String, Integer, etc). So how can resolve this problem?
> > > > Thanks in advance.
> > > >
> > > >  My code (some code is token from Tapestry5 Hotel Booking example):
> > > >
> > >
> >
> -----------------Registration.java:-----------------------------------------
> > > > ---
> > > >
> > > > public class Registration {
> > > >
> > > >    @Property
> > > >    @Persist(PersistenceConstants.FLASH)
> > > >    private User user;
> > > >
> > > >    @OnEvent(value = EventConstants.PREPARE, component =
> "registerForm")
> > > >    private void initializeNewUser() {
> > > >        if (this.user == null) {
> > > >            this.user = new User();
> > > >            this.user.setCustomer(new Customer());
> > > >        } else {
> > > >            if (this.user.getCustomer() == null) {
> > > >                this.user.setCustomer(new Customer());
> > > >            }
> > > >        }
> > > >    }
> > > >
> > > >
> > > >    @Property
> > > >    private String verifyPassword;
> > > >
> > > >    @Inject
> > > >    private UserService userService;
> > > >
> > > >    @Component
> > > >    private Form registerForm;
> > > >
> > > >    @Inject
> > > >    private Messages messages;
> > > >
> > > >    public Object onSubmitFromRegisterForm() {
> > > >
> > > >        if (!verifyPassword.equals(user.getPassword())) {
> > > >
> > >  registerForm.recordError(messages.get("error.verify.password"));
> > > >
> > > >            return null;
> > > >        }
> > > >
> > > >        if (userService.getUserByLogin(user.getLogin()) != null) {
> > > >
> > > > registerForm.recordError(messages.get("error.user.already.exists"));
> > > >
> > > >            return null;
> > > >        }
> > > >
> > > >        userService.save(user);
> > > >
> > > >        return Index.class;
> > > >
> > > >    }
> > > > }
> > > >
> > > >
> > > > --------------Registration.tml------------------------------------
> > > >
> > > >
> > > > <html t:type="layout" title="Customer registration"
> > > >      t:sidebarTitle="Current Time"
> > > >      t:pageTitle="Register"
> > > >      xmlns:t="http://tapestry.apache.org/schema/tapestry_5_1_0.xsd";
> > > >      xmlns:p="tapestry:parameter">
> > > >
> > > > <fieldset id="register">
> > > >    <form class="full-form" t:id="registerForm">
> > > >        <t:errors/>
> > > >
> > > >                <fieldset>
> > > >                    <legend>Customer registration(company or private
> > > > person)</legend>
> > > >
> > > >                    <t:beaneditor object="user.customer"
> > > > exclude="literal:id,users">
> > > >                        <p:businessName>
> > > >                            <t:label for="businessName"/>
> > > >                            <t:textfield t:id="businessName"
> > > > value="user.customer.businessName" validate="required"/>
> > > >                        </p:businessName>
> > > >                        <p:contactPhone>
> > > >                            <t:label for="customer_contactPhone"/>
> > > >                            <t:textfield t:id="customer_contactPhone"
> > > > value="user.customer.contactPhone" validate="required"/>
> > > >                        </p:contactPhone>
> > > >                        <p:contactPerson>
> > > >                            <t:label for="contactPerson"/>
> > > >                            <t:textfield t:id="contactPerson"
> > > > value="user.customer.contactPerson" validate="required"/>
> > > >                        </p:contactPerson>
> > > >                        <p:businessAddress>
> > > >                            <t:label for="businessAddress"/>
> > > >                            <t:textfield t:id="businessAddress"
> > > > value="user.customer.businessAddress" validate="required"/>
> > > >                        </p:businessAddress>
> > > >                        <p:email>
> > > >                            <t:label for="customer_email"/>
> > > >                            <t:textfield t:id="customer_email"
> > > > value="user.customer.email" validate="required,email"/>
> > > >                        </p:email>
> > > >                    </t:beaneditor>
> > > >                </fieldset>
> > > >
> > > >        <fieldset>
> > > >                <legend>Personal registration</legend>
> > > >        <t:beaneditor object="user" exclude="literal:id,roles"
> > > > add="verifyPassword">
> > > >
> > > >
> > > >                <p:firstName>
> > > >                    <t:label for="firstName"/>
> > > >                    <t:textfield t:id="firstName"
> value="user.firstName"
> > > > validate="required"/>
> > > >                </p:firstName>
> > > >
> > > >
> > > >                <p:middleName>
> > > >                    <t:label for="middleName"/>
> > > >                    <t:textfield t:id="middleName"
> > value="user.middleName"
> > > > validate="required"/>
> > > >                </p:middleName>
> > > >
> > > >
> > > >                <p:lastName>
> > > >                    <t:label for="lastName"/>
> > > >                    <t:textfield t:id="lastName" value="user.lastName"
> > > > validate="required"/>
> > > >                </p:lastName>
> > > >
> > > >
> > > >                <p:contactPhone>
> > > >                    <t:label for="contactPhone"/>
> > > >                    <t:textfield t:id="contactPhone"
> > > > value="user.contactPhone" validate="required"/>
> > > >                </p:contactPhone>
> > > >
> > > >
> > > >                <p:mobilePhone>
> > > >                    <t:label for="mobilePhone"/>
> > > >                    <t:textfield t:id="mobilePhone"
> > > value="user.mobilePhone"
> > > > validate="required"/>
> > > >                </p:mobilePhone>
> > > >
> > > >
> > > >                <p:address>
> > > >                    <t:label for="address"/>
> > > >                    <t:textfield t:id="address" value="user.address"
> > > > validate="required"/>
> > > >                </p:address>
> > > >
> > > >
> > > >                <p:email>
> > > >                    <t:label for="email"/>
> > > >                    <t:textfield t:id="email" value="user.email"
> > > > validate="required"/>
> > > >                </p:email>
> > > >
> > > >
> > > >                <p:nickname>
> > > >                    <t:label for="nickname"/>
> > > >                    <t:textfield t:id="nickname" value="user.nickname"
> > > > validate="required"/>
> > > >                </p:nickname>
> > > >
> > > >
> > > >                <p:login>
> > > >                    <t:label for="login"/>
> > > >                    <t:textfield t:id="login" value="user.login"
> > > > validate="required"/>
> > > >                </p:login>
> > > >
> > > >
> > > >                <p:password>
> > > >                    <t:label for="password"/>
> > > >                    <t:passwordfield t:id="password"
> > value="user.password"
> > > > validate="required"/>
> > > >                </p:password>
> > > >
> > > >                <p:verifyPassword>
> > > >                    <t:label for="verifyPassword"/>
> > > >                    <t:passwordfield t:id="verifyPassword"
> > > > value="verifyPassword" validate="required"/>
> > > >                </p:verifyPassword>
> > > >
> > > >        </t:beaneditor>
> > > >
> > > >        </fieldset>
> > > >
> > > >        <div class="form-submit">
> > > >            <input type="submit" value="Register"/>
> > > >        </div>
> > > >        <div class="member">Already member?
> > > >            <t:pagelink page="Login">Login now!</t:pagelink>
> > > >        </div>
> > > >    </form>
> > > > </fieldset>
> > > > </html>
> > > >
> > > >
> > > > ---------------------------------------------------------------------
> > > > To unsubscribe, e-mail: users-unsubscr...@tapestry.apache.org
> > > > For additional commands, e-mail: users-h...@tapestry.apache.org
> > > >
> > > >
> > >
> > > ---------------------------------------------------------------------
> > > To unsubscribe, e-mail: users-unsubscr...@tapestry.apache.org
> > > For additional commands, e-mail: users-h...@tapestry.apache.org
> > >
> > >
> >
>

Reply via email to