You are here: Re: internal messaging « All PHP « IT news, forums, messages
Re: internal messaging

Posted by Rik on 10/11/22 11:52

Mike wrote:
> Hi,
>
> I'm working on an internal messaging within a website.
>
> Basically, it will be like email but internal so a user logs in to the
> site and can send a message to another user who has access to the
> site. When a user logs into the site and visits their profile page,
> they can see if they have any messages and choose to read, reply or
> delete. All the messages are to be stored in a db.
>
> I've thought of a way to do it by creating 1 table with the following
> fields..
>
> Unique id - increments on every new message
> sender_id - taken from the id of the logged in person
> receiver_id - taken from the id of the person he is sending to
> subject - message subject
> message - message body
> read - flag to show if receiver has read the message or not
> date_added - date the message is sent
> reply_id - the unique_id of the message this message is a reply too,
> if at all
>
> So if a new message is created, all the above will be filled in apart
> from the reply_id.
>
> If the receiver replys then the reply_id will reference the message it
> is responding to.
>
> Then by various searches, all messages can be shown, including any
> previous relating messages.
>
> Although I have only planned it on paper, the logic seems to work
> except I can't think of a way for a user to delete a message.
>
> As replys are read by the sender and the receiver, if the sender
> deletes a message the reciever will then not see that particular
> message.
>
> I did think that rather than having a reply_id, the reply message
> simply takes the pervious message and adds it to the string but I
> though this would duplicate data in the database.
>
> Is there another way to set up this type of system?

Based on your plan I'd say use different tables:
messages (message_id, bodey etc.)
user_messages (message_id, user_id, sent/received)

When deleting a message, sent or received, it's only deleted from the table
user_messages. After that, a check can be done wether there is still a
reference to it from other tables, if not, delete the message all together,
if there is, leave te message itself be. Bonus in this scenario is messages
can be sent to multiple users without doubling them in the main table.

Offcourse, it might be usefull to keep a message history even though the
users don't think so. A simple additional flag wether to display it for the
particular user might be sufficient. Then you can apply your own logic to
wether a thread of messages has been inactive long enough to delete them.

Grtz,
--
Rik Wasmus

 

Navigation:

[Reply to this message]


Удаленная работа для программистов  •  Как заработать на Google AdSense  •  England, UK  •  статьи на английском  •  PHP MySQL CMS Apache Oscommerce  •  Online Business Knowledge Base  •  DVD MP3 AVI MP4 players codecs conversion help
Home  •  Search  •  Site Map  •  Set as Homepage  •  Add to Favourites

Copyright © 2005-2006 Powered by Custom PHP Programming

Сайт изготовлен в Студии Валентина Петручека
изготовление и поддержка веб-сайтов, разработка программного обеспечения, поисковая оптимизация