|
@@ -25,12 +25,18 @@
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
+ *
|
|
|
+ * History:
|
|
|
+ * -------
|
|
|
+ * 2003-04-14 tm_isdst in struct tm set to -1 to let mktime
|
|
|
+ * guess daylight saving (janakj)
|
|
|
*/
|
|
|
|
|
|
+#define _XOPEN_SOURCE
|
|
|
+
|
|
|
#include <string.h>
|
|
|
-#include "utils.h"
|
|
|
#include "defs.h"
|
|
|
-
|
|
|
+#include "utils.h"
|
|
|
|
|
|
/* FIXME: to be removed */
|
|
|
|
|
@@ -61,3 +67,112 @@ char* trim(char* _s)
|
|
|
|
|
|
return _s;
|
|
|
}
|
|
|
+
|
|
|
+
|
|
|
+/*
|
|
|
+ * Convert time_t structure to format accepted by MySQL database
|
|
|
+ */
|
|
|
+int time2mysql(time_t _time, char* _result, int _res_len)
|
|
|
+{
|
|
|
+ struct tm* t;
|
|
|
+
|
|
|
+ /*
|
|
|
+ if (_time == MAX_TIME_T) {
|
|
|
+ snprintf(_result, _res_len, "0000-00-00 00:00:00");
|
|
|
+ }
|
|
|
+ */
|
|
|
+
|
|
|
+ t = localtime(&_time);
|
|
|
+ return strftime(_result, _res_len, "%Y-%m-%d %H:%M:%S", t);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+/*
|
|
|
+ * Convert MySQL time representation to time_t structure
|
|
|
+ */
|
|
|
+time_t mysql2time(const char* _str)
|
|
|
+{
|
|
|
+ struct tm time;
|
|
|
+
|
|
|
+ /* It is neccessary to zero tm structure first */
|
|
|
+ memset(&time, '\0', sizeof(struct tm));
|
|
|
+ strptime(_str, "%Y-%m-%d %H:%M:%S", &time);
|
|
|
+
|
|
|
+ /* Daylight saving information got lost in the database
|
|
|
+ * so let mktime to guess it. This eliminates the bug when
|
|
|
+ * contacts reloaded from the database have different time
|
|
|
+ * of expiration by one hour when daylight saving is used
|
|
|
+ */
|
|
|
+ time.tm_isdst = -1;
|
|
|
+ return mktime(&time);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+/* FIXME */
|
|
|
+/*
|
|
|
+ * SQL URL parser
|
|
|
+ */
|
|
|
+int parse_sql_url(char* _url, char** _user, char** _pass,
|
|
|
+ char** _host, char** _port, char** _db)
|
|
|
+{
|
|
|
+ char* slash, *dcolon, *at, *db_slash;
|
|
|
+
|
|
|
+ *_user = '\0';
|
|
|
+ *_pass = '\0';
|
|
|
+ *_host = '\0';
|
|
|
+ *_port = '\0';
|
|
|
+ *_db = '\0';
|
|
|
+
|
|
|
+ /* Remove any leading and trailing spaces and tab */
|
|
|
+ _url = trim(_url);
|
|
|
+
|
|
|
+ if (strlen(_url) < 6) return -1;
|
|
|
+
|
|
|
+ if (*_url == '\0') return -2; /* Empty string */
|
|
|
+
|
|
|
+ slash = strchr(_url, '/');
|
|
|
+ if (!slash) return -3; /* Invalid string, slashes not found */
|
|
|
+
|
|
|
+ if ((*(++slash)) != '/') { /* Invalid URL, 2nd slash not found */
|
|
|
+ return -4;
|
|
|
+ }
|
|
|
+
|
|
|
+ slash++;
|
|
|
+
|
|
|
+ at = strchr(slash, '@');
|
|
|
+
|
|
|
+ db_slash = strchr(slash, '/');
|
|
|
+ if (db_slash) {
|
|
|
+ *db_slash++ = '\0';
|
|
|
+ *_db = trim(db_slash);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!at) {
|
|
|
+ dcolon = strchr(slash, ':');
|
|
|
+ if (dcolon) {
|
|
|
+ *dcolon++ = '\0';
|
|
|
+ *_port = trim(dcolon);
|
|
|
+ }
|
|
|
+ *_host = trim(slash);
|
|
|
+ } else {
|
|
|
+ dcolon = strchr(slash, ':');
|
|
|
+ *at++ = '\0';
|
|
|
+ if (dcolon) {
|
|
|
+ *dcolon++ = '\0';
|
|
|
+ if (dcolon < at) { /* user:passwd */
|
|
|
+ *_pass = trim(dcolon);
|
|
|
+ dcolon = strchr(at, ':');
|
|
|
+ if (dcolon) { /* host:port */
|
|
|
+ *dcolon++ = '\0';
|
|
|
+ *_port = trim(dcolon);
|
|
|
+ }
|
|
|
+ } else { /* host:port */
|
|
|
+ *_port = trim(dcolon);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ *_host = trim(at);
|
|
|
+ *_user = trim(slash);
|
|
|
+ }
|
|
|
+
|
|
|
+ return 0;
|
|
|
+}
|