¿Cómo hago relaciones reflexivas de autounión en ActiveRecord?
-
06-07-2019 - |
Pregunta
Estoy tratando de implementar un modelo de amistad de estilo de red social y no tuve mucha suerte tratando de descubrir los complementos disponibles. Creo que aprenderé Rails mejor si lo hago yo mismo. Entonces, esto es lo que tengo:
class User < ActiveRecord::Base
has_many :invitee_friendships ,
:foreign_key => :friend_id,
:class_name => 'Friendship'
has_many :inviter_friends,
:through => :invitee_friendships
has_many :inviter_friendships ,
:foreign_key => :user_id,
:class_name => 'Friendship'
has_many :invited_friends,
:through => :inviter_friendships
end
class Friendship < ActiveRecord::Base
belongs_to :user
//I think something needs to come here, i dont know what
end
En irb
cuando intento esto:
friend1 = Friend.create(:name => 'Jack')
friend2 = Friend.create(:name => 'John')
bff = Friendship.create(:user_id =>1, :friend_id => 2)
f1.invited_friends
Me sale un error:
ActiveRecord::HasManyThroughSourceAssociationNotFoundError:
Could not find the source
association(s) :invited_friend or
:invited_friends in model Friendship.
Try 'has_many :invited_friends,
:through => :invited_friendships,
:source => <name>'. Is it one of
:user?
Expansión del sistema de amistad:
- Un usuario puede invitar a otros usuarios a hacerse amigos.
- Los usuarios que invitó a hacerse amigos están representados por
invite_friends
. - Los usuarios que lo invitaron a hacerse amigo están representados por
inviter_friends
. - Tu lista total de amigos está representada por
invite_friends
+inviter_friends
.
Schema
table Friendship
t.integer :user_id
t.integer :friend_id
t.boolean :invite_accepted
t.timestamps
table User
t.string :name
t.string :description
Solución
Estoy sorprendido de que nadie haya señalado el reciente sobre el tema :)
¡Espero que esto ayude!
Extracto de Ryan '... requiere una asociación autorreferencial en el modelo de usuario para definir amigos / seguidores'
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow