<h: form> dentro de <ui: repeat> não totalmente funcional, somente o último <h: form> é processado

Eu gostaria de editar uma lista de itens na mesma página. Cada item deve ser editado usando um formulário separado. Estou criando um h: form dentro de ui: repeat. Somente quando o último formulário é enviado, a entrada do usuário é aplicada ao bean gerenciado. Para todos os outros formulários, a entrada do usuário não é aplicada ao modelo.

@ManagedBean
public class Controller {
    Logger logger = Logger.getLogger("TestWeb");
    private List<Customer> customerList;

    public List<Customer> getCustomerList() {
        if (customerList == null) {
            customerList = new ArrayList<Customer>();
            customerList.add(new Customer("Daffy Duck", "[email protected]"));                          
            customerList.add(new Customer("Bugs Bunny", "[email protected]"));       
            customerList.add(new Customer("Samity Sam", "[email protected]"));
        }
        return customerList;
    }
    public String updateCustomer(Customer c) {
        logger.info("Updating: " + c.getName());
        return null;
    }
}

Na visão, eu tenho

<ui:repeat var="c" value="#{controller.customerList}">
<h:form>
  <h3>Edit Customer</h3>
  Name: <h:inputText value="#{c.name}"/><br/>
  E-mail: <h:inputText value="#{c.email}"/><br/>
  <h:commandButton value="Update"
    action="#{controller.updateCustomer(c)}"/>
</h:form>
</ui:repeat>

Eu procuro por horas sem qualquer solução. Qual será a maneira correta de fazer isso? Eu posso hackeá-lo usando uma única forma e usando um ui: repita dentro dele. Mas há muitos problemas com isso e prefiro não seguir esse caminho. Obrigado.

questionAnswers(1)

yourAnswerToTheQuestion