Ping provides a simple and easy Messaging or Chat or Conversation system to your Laravel Framework. It is easy to integrate and use.
- One to One Conversation.
- Send a message without checking for conversation.
- Check if user has access to a conversation.
- Conversation's unread messages count (total & by user).
- Retriving messages with auto marking as seen.
- Marking all unread messages as seen (total & by user).
- Deleting messages from the participant side.
- Hard deletion (delete permanently) of messages and conversation.
- Message Encryption (Coming soon!).
- Group Conversation (Coming soon!).
To get started with Ping, use Composer to add the package to your project:
composer require harshaaliaschinna/ping
After installing the Ping package, register the Harshaaliaschinna\Ping\PingServiceProvider
in your config/app.php
configuration file:
'providers' => [
// Other service providers...
Harshaaliaschinna\Ping\PingServiceProvider::class,
],
You don't need to add the Ping to alias array. We already done that for you 💙.
Run below command in your terminal to publish required migration files for this package.
php artisan vendor:publish --provider="Harshaaliaschinna\Ping\PingServiceProvider"
Finally run below command to execute migrations.
php artisan migrate
Example 1:
// Ping::setId(from_id)->send(to_id, message);
Ping::setId(1)->send(2, "Hello, How are you?");
Example 2:
Ping::setId(1);
Ping::send(2, "Hello, How are you?");
Example 3:
namespace App\Controllers;
..
use Ping;
class Demo extends Controller {
public function __construct() {
// Ping once initialized it can be used anywhere without setting From Id.
Ping::setId(Auth::Id());
}
public function sendMessage($toId, $message) {
..
..
Ping::send($toId, $message);
..
}
public function retriveMessage($Id) {
..
$markAsSeen = true; // Bool
$message = Ping::recieve($Id, $markAsSeen);
..
}
..
..
..
}
Method | V0.1 |
---|---|
setId() | ✔️ |
send() | ✔️ |
new() | ✔️ |
exists() | ✔️ |
receive() | ✔️ |
receiveAll() | ✔️ |
totalConnections() | ✔️ |
unreadCount() | ✔️ |
markAsSeen() | ✔️ |
markUnreadAsSeen() | ✔️ |
hasAccess() | ✔️ |
delete() | ✔️ |
hardDelete() | ✔️ |
hardDeleteAll() | ✔️ |
hardDeleteConnection() | ✔️ |
hardDeleteConnectionByUserId() | ✔️ |
*Note: Please note that connection and conversation both are same. As the package name itself refers to a Networking scenario, these words were used just for fun! 😛 .
This method sets the base Id known as base_user. From which the requests can be made.
object setId( int $id )
Parameters:
Id: Unique Id from which further requests can be performed.
Return Values:
Returns Ping object. FALSE on errors.
Sends the message to other user. This method creates automatically a new connection if there is no connection between users. If there exists a connection already it will use it to send message.
object send( int $to_id, string $message)
Parameters:
to_id: Unique Id to which the message to be sent.
message: The message field.
Return Values:
Returns object on Success. FALSE on errors.
object returned containes newly sent message id ->id
. It also containes connection id ->connection_id
and few others.
Creates new connection between users.
object new( int $user_one[, int $user_two = null])
Parameters:
user_one: Unique Id.
user_two: If this field is not set, Ping will create a connection between base_user(user set through setId()
method) and user_one. Else it will create a connection between user_one and user_two.
Return Values:
Returns object on Success. FALSE on errors.
returned object containes Connection id ->id
Checks whether a connection exists between base_user and provided user.
bool exists( int $user_two)
Parameters:
user_two: Unique Id. This method is dependent on setId()
Return Values:
Returns object on Success. FALSE on errors.
Retrives a message using message_id.
object receive( int $message_id[, $seen = false])
Parameters:
message_id: Message id should be passed to retrive message.
seen: Mark this message as seen.
Return Values:
Returns object on Success. FALSE on errors or not found.
Retrives all messages that are present in a connection or conversation using connection_id
object receiveAll( int $connection_id[[[[, bool $seen = false], string $order = 'ASC'], int $skip=null], int $take=null])
Parameters:
connection_id: Connection id.
seen: Mark unread messages as seen by base_user
. Default it will be as false
.
Value | Result |
---|---|
true | Mark as seen |
false | Ignore |
order: Order by ascending order or descending order using messages timestamp.
Value | Result |
---|---|
ASC | Ascending order |
DESC | Descending order |
skip: number of messages to skip.
take: number of messages to retrive.
Return Values:
Returns object on Success. FALSE on errors or not found.
Retrives all connections that are linked to base_user
or provided user.
object totalConnections([int $user_id=null])
Parameters:
user_id: If user_id
is passed, Ping will retrive all connections based on provided user_id
. Else it will use base_user
as user_id
and retrives all connections.
Return Values:
Returns object on Success. FALSE on errors or not found.
Retrives unread messages count based on connection_id
.
int unreadCount( int $connection_id[, int $user_id=null])
Parameters:
connection_id: If user_id
is passed, Ping will retrive all unread messages count based on provided user_id
. Else it will use base_user
as user_id
and retrives the count.
user_id: If user_id
is passed, Ping will set it as base_user
and retrives unread message count. Else it will use base_user
as user_id
and retrives it.
Return Values:
Returns integer on Success. FALSE on errors or not found.
Mark a message as seen.
bool markAsSeen( int $message_id)
Parameters:
message_id: Message Id should be passed.
Return Values:
Returns true
on Success. FALSE on errors or not found.
Mark all unread messages as seen using connection_id
. If user_id
is passed it will mark that user specific received messages as seen. Else it will mark all messages as seen in that particular connection.
bool markUnreadAsSeen( int $conection_id[, int $user_id = null])
Parameters:
connection_id: Specific connection_id
should be passed.
user_id: If user_id
is passed it will mark that users received messages as seen.
Return Values:
Returns true
on Success. FALSE on errors or not found.
Checks whether a user has access to specific connection or not.
bool hasAccess( int $connection_id[, int $user_id = null])
Parameters:
connection_id: Specific connection_id
should be passed.
user_id: If user_id
is passed, Ping will check whether the given user_id
has access to connection or not. Else it will use base_user
as user_id
and checks for access.
Return Values:
Returns true
if user has access. FALSE if they don't have access.
To delete a message from one user side.
bool delete( int $message_id[, int $user_id=null])
Parameters:
message_id: Specific message_id
should be passed.
user_id: If user_id
is passed, Ping will remove message from that user side. Else it will use base_user
as user_id
and removes from that user side.
Return Values:
Returns true
on Success. FALSE on errors or not found.
Message will be deleted permanently from database. Any user present in that connection cannot retrive this message again.
bool hardDelete( int $message_id)
Parameters:
message_id: Specific message_id
should be passed.
Return Values:
Returns true
on Success. FALSE on errors or not found.
This will delete all the messages permanently in a connection. In other words it will reset that connection.
bool hardDeleteAll( int $connection_id)
Parameters:
connection_id: Specific connection_id
should be passed.
Return Values:
Returns true
on Success. FALSE on errors or not found.
This will delete a connection & messages present in it permanently.
bool hardDeleteConnection( int $connection_id)
Parameters:
connection_id: Specific connection_id
should be passed.
Return Values:
Returns true
on Success. FALSE on errors or not found.
This is same as hardDeleteConnection()
but this method will accept user_id
as parameter. Connection & messages that exists between base_user
and provider user_id
will be deleted permanently.
bool hardDeleteConnectionByUserId( int $user_id)
Parameters:
user_id: Specific user_id
should be passed.
Return Values:
Returns true
on Success. FALSE on errors or not found.