Retweet Function

Hello, good day!

This is a rather intricate question coming from a not so experienced ruby on
rails user. Let's get to it:

I am developing an app that has users, authors, microposts and tags. I want
to implement something like a retweet button for the microposts:

The task is simple:
Get the params of a micropost(original user, original author, original tags)
"Retweet" it to my own wall, using these params, but also with my own
user_id embedded in it.

So far I managed to "retweet" it, but there is one problem. As it is now, I
am copying all the params and creating a new micropost with these params.
As this creates exact duplicate, I would like to know what would be the best
approach to implement this function without creating replicas all over my
app.

Think about the objects and relationships. You want a user to have
many retweets (which are microposts) and a micropost must not only
have its original owner but also users who have retweeted it.

You have not told us the relationships at the moment but I assume that
it is something like user has_many microposts and micropost belongs_to
user. This does not quite match what you have as you have author_id
but presumably you can sort that bit out.

I would suggest using a join table possibly called retweetings where
user has_many retweetings and user has_many retweets through
retweetings. Also micropost has_many retweetings and has_many
retweeters through retweetings.

Then for retweetings you just need retweeter_id and retweet_id and
have retweetings belongs_to :retweeter, :class_name => "user" and
belongs_to :retweet, :class_name => "micropost"

You probably need the class_name spec on the has_many through relationships too.

Looking back at the post you seem to have authors and users in
different tables. Are you sure that is right, what is the difference
between an author and a user?

Colin

I meant to say have a look at the Rails Guide on ActiveRecord
Associations for some background data on this if you do not understand
what I mean.

Colin

Hello Colin, good day!

Thank you for your prompt response.

I am sorry if I failed to provide some basic information.

Ur assumptions were right:

USER has_many MICROPOSTS

MICROPOST belongs_to USER

The relations are exactly the same for author. My app has Users and Authors and they do live in two different tables.

It is a Quotation app, so Authors are famous people and Users are normal people.

Even though the tables are pretty much the same, they have security differences.

Any given user could create an Author Profile which has attributes that are accessible to any other user to change. And of course, this does not happen in the user’s table.

I understand the Join table approach. Will dig deeper through this way and will get back to you with more updates.

Thanks again!

Hey Collin! Good day!

I managed to implement the functionality I was seeking through a join model.

Thanks for your inputs!

Hello Tariq, and whoever it may concern.

I’ve implemented this using a join model, which we can call Reposts, that has its id, an author_id and a post_id.

In my app:

  • Author has many Posts.
  • Post belongs to Author and has many Reposts.
  • Repost belongs to Post and belongs to Author

Then, we can create the Reposts, straight from the Post view, with a form calling for the create method in the Reposts Controller.

def create

@post = Post.find_by(id: params[:post_id])

current_user.recite!(@post)

respond_with(@repost)

end

Here, I’m calling the recite! method from the Author model.

def recite!(post)

reposts.create!(post_id: post.id)

end

And that’s it.
Please note this code is still undercooked and under test.

Cheers!