Exception no cadastro de Strings - Vraptor/Hibernate

estou usando Vraptor+Hibernate para fazer um cadastro simples, quando eu utilizo somente os campos da tabela ‘user’ ele funciona, mas quando eu utilizo as outras tabelas relacionadas ele me retorna um exception e não entendi como resolver por mais que pareça simples:

Segue o exception completo abaixo:

java.lang.ClassCastException: java.lang.String cannot be cast to java.lang.Integer br.com.caelum.vraptor.http.ognl.ListAccessor.setProperty(ListAccessor.java:68) ognl.OgnlRuntime.setProperty(OgnlRuntime.java:2225) ognl.ASTProperty.setValueBody(ASTProperty.java:127) ognl.SimpleNode.evaluateSetValueBody(SimpleNode.java:220) ognl.SimpleNode.setValue(SimpleNode.java:279) ognl.ASTChain.setValueBody(ASTChain.java:227) ognl.SimpleNode.evaluateSetValueBody(SimpleNode.java:220) ognl.SimpleNode.setValue(SimpleNode.java:279) ognl.Ognl.setValue(Ognl.java:737) ognl.Ognl.setValue(Ognl.java:783) br.com.caelum.vraptor.http.ognl.OgnlFacade.setValue(OgnlFacade.java:100) br.com.caelum.vraptor.http.ognl.OgnlParametersProvider.setProperty(OgnlParametersProvider.java:162) br.com.caelum.vraptor.http.ognl.OgnlParametersProvider.createParameter(OgnlParametersProvider.java:134) br.com.caelum.vraptor.http.ognl.OgnlParametersProvider.getParametersFor(OgnlParametersProvider.java:86) br.com.caelum.vraptor.interceptor.ParametersInstantiatorInterceptor.getParametersFor(ParametersInstantiatorInterceptor.java:132) br.com.caelum.vraptor.interceptor.ParametersInstantiatorInterceptor.intercept(ParametersInstantiatorInterceptor.java:86) br.com.caelum.vraptor.core.LazyInterceptorHandler.execute(LazyInterceptorHandler.java:59) br.com.caelum.vraptor.core.DefaultInterceptorStack.next(DefaultInterceptorStack.java:54) br.com.caelum.vraptor.interceptor.ResourceLookupInterceptor.intercept(ResourceLookupInterceptor.java:69) br.com.caelum.vraptor.core.ToInstantiateInterceptorHandler.execute(ToInstantiateInterceptorHandler.java:54) br.com.caelum.vraptor.core.DefaultInterceptorStack.next(DefaultInterceptorStack.java:54) br.com.caelum.vraptor.core.ToInstantiateInterceptorHandler.execute(ToInstantiateInterceptorHandler.java:56) br.com.caelum.vraptor.core.DefaultInterceptorStack.next(DefaultInterceptorStack.java:54) br.com.caelum.vraptor.core.EnhancedRequestExecution.execute(EnhancedRequestExecution.java:44) br.com.caelum.vraptor.VRaptor$1.insideRequest(VRaptor.java:91) br.com.caelum.vraptor.ioc.spring.SpringProvider.provideForRequest(SpringProvider.java:58) br.com.caelum.vraptor.VRaptor.doFilter(VRaptor.java:88)

O relacionamento das tabelas é o seguinte:
User possui uma Collection de telefones
User possui uma Formação academica
Formaçao academica possui duas Collections, Curso e Idioma

Segue algumas classes abaixo para facilitar o entendimento.

User.java

[code]package model;

import java.util.Collection;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.OneToMany;
import javax.persistence.Table;

import org.hibernate.validator.constraints.Email;

@Entity(name = “user”)
@Table(name = “user”)
public class User {

private Long id;    
private String nome;
private String numeroRg;
private String numeroCpf;
private String cidade;
private String estado;
private String email;
private Collection<Telefones> telefonesList;
private FormacaoAcademica formacaoAcademica;

@Id
@GeneratedValue
@Column(name="id", nullable=false)
public Long getId() {
    return id;
}

public void setId(Long id) {
    this.id = id;
}

@OneToMany(mappedBy="user", cascade=CascadeType.ALL, fetch=FetchType.LAZY)
public Collection<Telefones> getTelefones() {
    return telefonesList;
}

public void setTelefones(Collection<Telefones> telefonesList) {
    this.telefonesList=telefonesList;
}

@Column(name="numeroRg", nullable=false)
public String getNumeroRg() {
    return numeroRg;
}

public void setNumeroRg(String numeroRg) {
    this.numeroRg = numeroRg;
}

@Column(name="numeroCpf", nullable=false)
public String getNumeroCpf() {
    return numeroCpf;
}

public void setNumeroCpf(String numeroCpf) {
    this.numeroCpf = numeroCpf;
}

@Column(name="cidade", nullable=false)
public String getCidade() {
    return cidade;
}

public void setCidade(String cidade) {
    this.cidade = cidade;
}

@Column(name="estado", nullable=false)
public String getEstado() {
    return estado;
}

public void setEstado(String estado) {
    this.estado = estado;
}

@Column(name="email", nullable=false)
public String getEmail() {
    return email;
}

public void setEmail(String email) {
    this.email = email;
}


@Column(name="nome", nullable=false)
public String getNome() {
    return nome;
}

public void setNome(String nome) {
    this.nome = nome;
}


@ManyToOne
@JoinColumn(name="fk_formacaoAcademica", nullable=false)
public FormacaoAcademica getFormacaoAcademica() {
    return formacaoAcademica;
}

public void setFormacaoAcademica(FormacaoAcademica formacaoAcademica) {
    this.formacaoAcademica = formacaoAcademica;
}

}[/code]

Telefones.java

[code]package model;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;

@Entity(name = “user_telefones”)
@Table(name = “user_telefones”)
public class Telefones {

private Long id;
private User user;
private String tipo;
private String numero;
private String ddd;

@Id
@GeneratedValue
@Column(name="id", nullable=false)
public Long getId() {
    return id;
}
public void setId(Long id) {
    this.id = id;
}

@Column(name="tipo", nullable=false)
public String getTipo() {
    return tipo;
}
public void setTipo(String tipo) {
    this.tipo = tipo;
}
@Column(name="numeroTelefone", nullable=false)
public String getNumero() {
    return numero;
}
public void setNumero(String numero) {
    this.numero = numero;
}

@Column(name="ddd", nullable=false)
public String getDdd() {
    return ddd;
}
public void setDdd(String ddd) {
    this.ddd = ddd;
}

@ManyToOne
@JoinColumn(name="fk_user", nullable=false)
public User getUser() {
    return user;
}
public void setUser(User user) {
    this.user = user;
}

}[/code]

UserDao.java

[code]package dao;

import generic.Dao;

import java.util.List;

import model.User;

import org.hibernate.Session;
import org.hibernate.Transaction;

import br.com.caelum.vraptor.ioc.Component;

@Component
public class UserDao extends Dao{

public UserDao(Session session){
    super(session, User.class);
}

public void salvar (User user){
    Transaction transaction = this.session.beginTransaction();  
    this.session.save(user);  
    transaction.commit();  
}

public void remove(Long id){
    Transaction transaction = this.session.beginTransaction(); 
    this.session.delete((User)this.session.load(User.class, id));
    this.session.flush();
    transaction.commit();  
}

public User load(Long id){
    return(User)this.session.load(User.class, id);
}

public void update(User user){
    Transaction transaction = this.session.beginTransaction(); 
    this.session.update(user);
    this.session.flush();
    transaction.commit(); 
}

public List<User> listaTodos(){
    return session.createCriteria(User.class).list();
}

}[/code]

UserController.java

[code]package controller;

import java.util.List;

import model.User;

import org.hibernate.Session;

import br.com.caelum.vraptor.Get;
import br.com.caelum.vraptor.Path;
import br.com.caelum.vraptor.Post;
import br.com.caelum.vraptor.Put;
import br.com.caelum.vraptor.Resource;
import br.com.caelum.vraptor.Result;
import br.com.caelum.vraptor.Validator;
import br.com.caelum.vraptor.validator.ValidationMessage;
import dao.UserDao;

@Resource
public class UsersController {

private final UserDao userDao;
private final Session session;
private final Result result;
private final Validator validator;

public UsersController(UserDao userDao, Result result, Session session, Validator validator){
    this.userDao=userDao;
    this.session=session;
    this.result=result;
    this.validator=validator;
}

@Post
@Path("/users")
public void add(User user){
    userDao.salvar(user);
    result.include("mensagem", "Usuário adicionado com sucesso!");
    result.redirectTo(UsersController.class).list();
}

@Get
@Path("/users/{id}")
public User view(Long id){
    return userDao.load(id);
}

@Path("/users/delete/{id}")
public void delete(Long id){
    userDao.remove(id);
    result.include("mensagem", "Usuário excluído com sucesso!");
    result.redirectTo(UsersController.class).list();
}

@Put
@Path("/users")
public void edit(User user){
    userDao.update(user);
    result.include("mensagem", "Usuário alterado com sucesso!");
    result.redirectTo(UsersController.class).list();
}

@Path("/")
public List<User> list(){
    return userDao.listaTodos();
}

}[/code]

Quais são os parâmetros que vc tava passando na requisição?