Main Page | Alphabetical List | Data Structures | Directories | File List | Data Fields | Globals

date.h

Go to the documentation of this file.
00001 /* ==================================================================== 
00002  * The Kannel Software License, Version 1.0 
00003  * 
00004  * Copyright (c) 2001-2008 Kannel Group  
00005  * Copyright (c) 1998-2001 WapIT Ltd.   
00006  * All rights reserved. 
00007  * 
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions 
00010  * are met: 
00011  * 
00012  * 1. Redistributions of source code must retain the above copyright 
00013  *    notice, this list of conditions and the following disclaimer. 
00014  * 
00015  * 2. Redistributions in binary form must reproduce the above copyright 
00016  *    notice, this list of conditions and the following disclaimer in 
00017  *    the documentation and/or other materials provided with the 
00018  *    distribution. 
00019  * 
00020  * 3. The end-user documentation included with the redistribution, 
00021  *    if any, must include the following acknowledgment: 
00022  *       "This product includes software developed by the 
00023  *        Kannel Group (http://www.kannel.org/)." 
00024  *    Alternately, this acknowledgment may appear in the software itself, 
00025  *    if and wherever such third-party acknowledgments normally appear. 
00026  * 
00027  * 4. The names "Kannel" and "Kannel Group" must not be used to 
00028  *    endorse or promote products derived from this software without 
00029  *    prior written permission. For written permission, please  
00030  *    contact org@kannel.org. 
00031  * 
00032  * 5. Products derived from this software may not be called "Kannel", 
00033  *    nor may "Kannel" appear in their name, without prior written 
00034  *    permission of the Kannel Group. 
00035  * 
00036  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 
00037  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 
00038  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00039  * DISCLAIMED.  IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS 
00040  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,  
00041  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT  
00042  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR  
00043  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  
00044  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE  
00045  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,  
00046  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00047  * ==================================================================== 
00048  * 
00049  * This software consists of voluntary contributions made by many 
00050  * individuals on behalf of the Kannel Group.  For more information on  
00051  * the Kannel Group, please see <http://www.kannel.org/>. 
00052  * 
00053  * Portions of this software are based upon software originally written at  
00054  * WapIT Ltd., Helsinki, Finland for the Kannel project.  
00055  */ 
00056 
00057 /*
00058  * date.h - interface to utilities for handling date and time values
00059  *
00060  * Richard Braakman
00061  */
00062 
00063 #include "gwlib.h"
00064 
00065 /* Broken-down time structure without timezone.  The values are
00066  * longs because that makes them easier to use with octstr_parse_long().
00067  */
00068 struct universaltime
00069 {
00070     long day;      /* 1-31 */
00071     long month;    /* 0-11 */
00072     long year;     /* 1970- */
00073     long hour;     /* 0-23 */
00074     long minute;   /* 0-59 */
00075     long second;   /* 0-59 */
00076 };
00077 
00078 
00079 /* Calculate the unix time value (seconds since 1970) given a broken-down
00080  * date structure in GMT. */
00081 long date_convert_universal(struct universaltime *t);
00082 
00083 
00084 /*
00085  * Convert a unix time value to a value of the form
00086  * Sun, 06 Nov 1994 08:49:37 GMT
00087  * This is the format required by the HTTP protocol (RFC 2616),
00088  * and it is defined in RFC 822 as updated by RFC 1123.
00089  */
00090 Octstr *date_format_http(unsigned long unixtime);
00091 
00092 
00093 /*
00094  * Convert a date string as defined by the HTTP protocol (RFC 2616)
00095  * to a unix time value.  Return -1 if the date string was invalid.
00096  * Three date formats are acceptable:
00097  *   Sun, 06 Nov 1994 08:49:37 GMT  ; RFC 822, updated by RFC 1123
00098  *   Sunday, 06-Nov-94 08:49:37 GMT ; RFC 850, obsoleted by RFC 1036
00099  *   Sun Nov  6 08:49:37 1994       ; ANSI C's asctime() format
00100  * White space is significant.
00101  */
00102 long date_parse_http(Octstr *date);
00103 
00104 /*
00105  * attempt to read an ISO-8601 format or similar, making no assumptions on 
00106  * seperators and number of elements, adding 0 or 1 to missing fields
00107  * For example, acceptable formats :
00108  *  2002-05-15 13:23:44
00109  *  02/05/15:13:23
00110  * support of 2 digit years is done by assuming years 70 an over are 20th century. this will
00111  * have to be revised sometime in the next 50 or so years
00112  */
00113 int date_parse_iso(struct universaltime *ut, Octstr *os);
00114 
00115 /*
00116  * create an ISO-8601 formated time stamp
00117  */
00118 Octstr* date_create_iso(time_t unixtime);
00119  
00120 /*
00121  * Return the current date and time as a unix time value.
00122  */
00123 long date_universal_now(void);
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.