Add Content-Language iff Accept-Language
Add Content-Language header in the response if and only if there is an Accept-Language header in the request.
This commit is contained in:
		 Fabrice Fontaine
					Fabrice Fontaine
				
			
				
					committed by
					
						 Marcelo Roberto Jimenez
						Marcelo Roberto Jimenez
					
				
			
			
				
	
			
			
			 Marcelo Roberto Jimenez
						Marcelo Roberto Jimenez
					
				
			
						parent
						
							2fcbe6df52
						
					
				
				
					commit
					d2238615e3
				
			| @@ -2,6 +2,13 @@ | ||||
| Version 1.6.7 | ||||
| ******************************************************************************* | ||||
|  | ||||
| 2010-09-21 Fabrice Fontaine <fabrice.fontaine(at)orange-ftgroup.com> | ||||
|  | ||||
| 	Add Content-Language iff Accept-Language | ||||
|  | ||||
| 	Add Content-Language header in the response if and only if there is an | ||||
| 	Accept-Language header in the request. | ||||
|  | ||||
| 2010-09-21 Fabrice Fontaine <fabrice.fontaine(at)orange-ftgroup.com> | ||||
|  | ||||
| 	Addition of WEB_SERVER_CONTENT_LANGUAGE parameter | ||||
|   | ||||
| @@ -1908,7 +1908,8 @@ http_SendStatusResponse( IN SOCKINFO * info, | ||||
|  *	'G':	arg = range information     // add range header | ||||
|  *	'h':	arg = off_t number          // appends off_t number | ||||
|  *	'K':	(no args)                   // add chunky header | ||||
|  *	'L':	(no args) appends HTTP Content-Language: header if | ||||
|  *	'L':	arg = language information  // add Content-Language header if | ||||
|  *			Accept-Language header is not empty and if | ||||
|  *			WEB_SERVER_CONTENT_LANGUAGE is not empty | ||||
|  *	'N':	arg1 = off_t content_length // content-length header | ||||
|  *	'q':    arg1 = http_method_t        // request start line and HOST header | ||||
| @@ -2055,8 +2056,13 @@ http_MakeMessage( INOUT membuffer * buf, | ||||
|             } | ||||
|         } else if ( c == 'L' ) { | ||||
|             // Add CONTENT-LANGUAGE header only if WEB_SERVER_CONTENT_LANGUAGE | ||||
|             // is not empty | ||||
|             if (strcmp( WEB_SERVER_CONTENT_LANGUAGE, "" ) && http_MakeMessage( | ||||
|             // is not empty and if Accept-Language header is not empty | ||||
|             struct SendInstruction *RespInstr; | ||||
|             RespInstr = (struct SendInstruction *) | ||||
|                 va_arg( argp, struct SendInstruction *); | ||||
|             assert( RespInstr ); | ||||
|             if (strcmp( RespInstr->AcceptLanguageHeader, "" ) && | ||||
|                 strcmp( WEB_SERVER_CONTENT_LANGUAGE, "" ) && http_MakeMessage( | ||||
|                 buf, http_major_version, http_minor_version, | ||||
|                 "ssc", | ||||
|                 "CONTENT-LANGUAGE: ", WEB_SERVER_CONTENT_LANGUAGE ) != 0 ) { | ||||
|   | ||||
| @@ -1124,6 +1124,12 @@ CheckOtherHTTPHeaders( IN http_message_t * Req, | ||||
|                         return RetCode; | ||||
|                     } | ||||
|                     break; | ||||
|                 case HDR_ACCEPT_LANGUAGE: | ||||
|                     { | ||||
|                         memcpy( RespInstr->AcceptLanguageHeader, TmpBuf, | ||||
|                             sizeof( RespInstr->AcceptLanguageHeader ) - 1 ); | ||||
|                         break; | ||||
|                     } | ||||
|                 default: | ||||
|                     /* | ||||
|                        TODO  | ||||
| @@ -1138,7 +1144,6 @@ CheckOtherHTTPHeaders( IN http_message_t * Req, | ||||
|                        case HDR_CONTENT_LOCATION://return 1; | ||||
|                        case HDR_ACCEPT: //return 1; | ||||
|                        case HDR_ACCEPT_CHARSET://return 1; | ||||
|                        case HDR_ACCEPT_LANGUAGE://return 1; | ||||
|                        case HDR_USER_AGENT: break;//return 1; | ||||
|                      */ | ||||
|  | ||||
| @@ -1402,6 +1407,7 @@ process_request( IN http_message_t * req, | ||||
|             HTTP_PARTIAL_CONTENT,           // status code | ||||
|             finfo.content_type,   // content type | ||||
|             RespInstr,                      // range info | ||||
|             RespInstr,                      // language info | ||||
|             "LAST-MODIFIED: ", | ||||
| 	    &finfo.last_modified, | ||||
|             X_USER_AGENT, | ||||
| @@ -1418,6 +1424,7 @@ process_request( IN http_message_t * req, | ||||
|             RespInstr->ReadSendSize,        // content length | ||||
|             finfo.content_type,       // content type | ||||
|             RespInstr,                      // range info | ||||
|             RespInstr,                      // language info | ||||
|             "LAST-MODIFIED: ", | ||||
| 	    &finfo.last_modified, | ||||
|             X_USER_AGENT, | ||||
| @@ -1433,6 +1440,7 @@ process_request( IN http_message_t * req, | ||||
|             "RK" "TLD" "s" "tcS" "Xc" "sCc", | ||||
|             HTTP_OK,                        // status code | ||||
|             finfo.content_type, // content type | ||||
|             RespInstr,                      // language info | ||||
|             "LAST-MODIFIED: ", | ||||
| 	    &finfo.last_modified, | ||||
|             X_USER_AGENT, | ||||
| @@ -1450,6 +1458,7 @@ process_request( IN http_message_t * req, | ||||
|                 HTTP_OK,                        // status code | ||||
|                 RespInstr->ReadSendSize,        // content length | ||||
|                 finfo.content_type,      // content type | ||||
|                 RespInstr,                      // language info | ||||
|                 "LAST-MODIFIED: ", | ||||
| 		&finfo.last_modified, | ||||
|                 X_USER_AGENT, | ||||
| @@ -1464,6 +1473,7 @@ process_request( IN http_message_t * req, | ||||
|                 "R" "TLD" "s" "tcS" "b" "Xc" "sCc", | ||||
|                 HTTP_OK,                        // status code | ||||
|                 finfo.content_type, // content type | ||||
|                 RespInstr,                      // language info | ||||
|                 "LAST-MODIFIED: ", | ||||
| 		&finfo.last_modified, | ||||
|                 X_USER_AGENT, | ||||
| @@ -1697,6 +1707,8 @@ web_server_callback( IN http_parser_t * parser, | ||||
|     RespInstr.IsChunkActive = 0; | ||||
|     RespInstr.IsRangeActive = 0; | ||||
|     RespInstr.IsTrailers = 0; | ||||
|     memset( RespInstr.AcceptLanguageHeader, 0, | ||||
|        sizeof( RespInstr.AcceptLanguageHeader ) ); | ||||
|     // init | ||||
|     membuffer_init( &headers ); | ||||
|     membuffer_init( &filename ); | ||||
| @@ -1751,7 +1763,7 @@ web_server_callback( IN http_parser_t * parser, | ||||
|  | ||||
|                 http_MakeMessage( | ||||
|                     &headers, 1, 1, | ||||
|                     "RLTDSXcCc", | ||||
|                     "RTLSXcCc", | ||||
|                     ret, | ||||
|                     "text/html", | ||||
|                     X_USER_AGENT ); | ||||
|   | ||||
| @@ -48,6 +48,7 @@ struct SendInstruction | ||||
|    int  IsRangeActive; | ||||
|    int  IsTrailers; | ||||
|    char RangeHeader[200]; | ||||
|    char AcceptLanguageHeader[200]; | ||||
|    off_t RangeOffset; | ||||
|    off_t ReadSendSize;  // Read from local source and send on the network. | ||||
|    long RecvWriteSize; // Recv from the network and write into local file. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user