OSDN Git Service

* Writing is changed.
[modchxj/mod_chxj.git] / src / chxj_specified_device.c
1 /*
2  * Copyright (C) 2005 QSDN,Inc. All rights reserved.
3  * Copyright (C) 2005 Atsushi Konno All rights reserved.
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  *     http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  */
17 #include "mod_chxj.h"
18
19 static device_table_t  UNKNOWN_DEVICE      = {
20     NULL, "","UNKNOWN", CHXJ_SPEC_UNKNOWN,  0,  0,0,0,0,0,0,0,0,0,0,0,0, ""};
21
22 /**
23  * The device is specified from UserAgent. 
24  * @param r Request_rec is appointed.
25  * @param userAgent UserAgent is appointed here,
26  * @return The style which corresponds is returned.
27  */
28 device_table_t*
29 chxj_specified_device(request_rec* r, const char* user_agent) 
30 {
31   ap_regex_t*          regexp;
32   ap_regmatch_t        match[10];
33   device_table_t*      returnType = &UNKNOWN_DEVICE;
34   device_table_list_t* dtl;
35   device_table_t* dt;
36   mod_chxj_config* conf; 
37   int rtn;
38   char* device_id;
39
40   if (! user_agent) 
41     return returnType;
42             
43
44   DBG(r, "start chxj_specified_device()");
45   conf = ap_get_module_config(r->per_dir_config, &chxj_module);
46   for (dtl = conf->devices; dtl; dtl = dtl->next) {
47     if (! dtl->pattern) {
48       DBG(r, "pattern is null");
49       continue;
50     }
51
52     DBG1(r, "pattern is [%s]", dtl->pattern);
53     if (! dtl->regexp) {
54       DBG(r,"compile failed.");
55       return returnType;
56     }
57
58     rtn = ap_regexec(regexp, user_agent, regexp->re_nsub + 1, match, 0);
59     ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "pattern is [%s]", dtl->pattern);
60     if (rtn == 0) {
61       device_id = ap_pregsub(r->pool, "$1", user_agent, regexp->re_nsub + 1, match);
62       ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "device_id:[%s]", device_id);
63       for (dt = dtl->table; dt; dt = dt->next) {
64         if (strcasecmp(device_id, dt->device_id) == 0) {
65           ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "device_name:[%s]", dt->device_name);
66           returnType = dt;
67           break;
68         }
69       }
70       if (dt == NULL) {
71         for (dt = dtl->table; dt; dt = dt->next) {
72           if (dt->next == NULL) {
73             break;
74           }
75         }
76         if (dt != NULL) {
77           returnType = dt;
78         }
79       }
80     }
81     ap_pregfree(r->pool, regexp);
82     if (returnType != &UNKNOWN_DEVICE) {
83       ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "end chxj_specified_device()");
84       return returnType;
85     }
86   }
87   ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "end chxj_specified_device()");
88
89   return returnType;
90 }
91
92 /*
93  * vim:ts=2 et
94  */
95