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   ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, 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 == NULL) {
48       ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "pattern is null");
49       continue;
50     }
51
52     ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "pattern is [%s]", dtl->pattern);
53     regexp = ap_pregcomp(r->pool, (const char*)dtl->pattern, AP_REG_EXTENDED|AP_REG_ICASE);
54     if (regexp == NULL) {
55       ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "compile failed.");
56       return returnType;
57     }
58
59     rtn = ap_regexec(regexp, user_agent, regexp->re_nsub + 1, match, 0);
60     ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "pattern is [%s]", dtl->pattern);
61     if (rtn == 0) {
62       device_id = ap_pregsub(r->pool, "$1", user_agent, regexp->re_nsub + 1, match);
63       ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "device_id:[%s]", device_id);
64       for (dt = dtl->table; dt; dt = dt->next) {
65         if (strcasecmp(device_id, dt->device_id) == 0) {
66           ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "device_name:[%s]", dt->device_name);
67           returnType = dt;
68           break;
69         }
70       }
71       if (dt == NULL) {
72         for (dt = dtl->table; dt; dt = dt->next) {
73           if (dt->next == NULL) {
74             break;
75           }
76         }
77         if (dt != NULL) {
78           returnType = dt;
79         }
80       }
81     }
82     ap_pregfree(r->pool, regexp);
83     if (returnType != &UNKNOWN_DEVICE) {
84       ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "end chxj_specified_device()");
85       return returnType;
86     }
87   }
88   ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r, "end chxj_specified_device()");
89
90   return returnType;
91 }
92
93 /*
94  * vim:ts=2 et
95  */
96