Solved

Using PHP's IMAP module with Gmail, how do I keep a script alive checking for emails every 5 seconds

Posted on 2014-12-01
8
134 Views
Last Modified: 2014-12-02
The code I've been using (snippet):

while(true) {

	imap_check($connection);
	$emails = imap_search($connection,'ALL');
	

	if($emails) {

		rsort($emails);
		foreach($emails as $email_number) {
			$overview = imap_fetch_overview($connection, "{$email_number}:{$email_number}");
			$headers = imap_header($connection, $email_number);
			$replyto = $headers->reply_toaddress;
			$subject = $headers->Subject;

                       #........ code to delete email and a bunch more lines

		}
		
	}
	
	else echo "No New Emails\n";
	
	imap_gc($connection, IMAP_GC_ELT); # Clear Cache

	sleep(5);

}

Open in new window


The code works when left on for a few hours however I left it on this weekend and when I came back, it wasn't obtaining new emails (it just kept outputting "No New Emails"). When I restarted the script, it started working property...

Please advise, thanks
0
Comment
Question by:Mark
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 5
  • 3
8 Comments
 
LVL 62

Expert Comment

by:gheist
ID: 40475275
You never check if connection is alive.
0
 

Author Comment

by:Mark
ID: 40475296
Could you supply the correct code then that checks as you mention and reconnects if necessary
0
 
LVL 62

Expert Comment

by:gheist
ID: 40475443
Add imap_open/imap_close in the loop
They are outside code presented, so I hold no chance to fix it.
0
Salesforce Made Easy to Use

On-screen guidance at the moment of need enables you & your employees to focus on the core, you can now boost your adoption rates swiftly and simply with one easy tool.

 

Author Comment

by:Mark
ID: 40475792
I already have imap_open but at the beginning of the script before the infinite loop begins. I don't have an imap_close tag anywhere because I want to connection to remain alive.

I don't want the script to have to reconnect to gmail's servers every 5 seconds as it will slow its performance down. The way I have it now, it works well however after a few hours it stops working (I was even going to add a while ($loopCount<x) but that doesn't seem like the right way togo.

I assumed when building the script that imap_search would throw an error of it's no longer connected to a the server but that doesn't seem to be the case (or gmail has some sort of limits)
0
 
LVL 62

Expert Comment

by:gheist
ID: 40475832
if imap_check()
 ... do your loop
else imap_close/imap_open
0
 

Author Comment

by:Mark
ID: 40475873
I, what about imap_ping .. Any use with that in this instance
0
 
LVL 62

Accepted Solution

by:
gheist earned 500 total points
ID: 40476761
imap_check has same return semantics and updates mailbox status at the same time.
0
 
LVL 62

Expert Comment

by:gheist
ID: 40477532
if !(imap_check()) then
 reconnect
fi
doyour loop
0

Featured Post

Secure Your WordPress Site: 5 Essential Approaches

WordPress is the web's most popular CMS, but its dominance also makes it a target for attackers. Our eBook will show you how to:

Prevent costly exploits of core and plugin vulnerabilities
Repel automated attacks
Lock down your dashboard, secure your code, and protect your users

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Nothing in an HTTP request can be trusted, including HTTP headers and form data.  A form token is a tool that can be used to guard against request forgeries (CSRF).  This article shows an improved approach to form tokens, making it more difficult to…
This article discusses how to implement server side field validation and display customized error messages to the client.
This Micro Tutorial will introduce a Google tool, which is a great way to learn more about dimensions in metrics in Google Analytics, even if you use the interface or the API.
This Micro Tutorial demonstrates in Google Sheets how to use the HYPERLINK function to create live links inside your spreadsheet.

696 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question