Re: Похоже на багу в date_local в ssi
Maxim Dounin
mdounin на mdounin.ru
Пт Фев 19 16:02:34 MSK 2010
Hello!
On Fri, Feb 19, 2010 at 03:13:24PM +0300, Oleg Motienko wrote:
> Привет всем.
>
> В ssi вот такая конструкция выдаёт время на 180 секунд вперед.
> <!--# config timefmt="%s" --><!--# echo var="date_local" -->
>
> А такая - верное.
> <!--# config timefmt="%s" --><!--# echo var="date_gmt" -->
>
> Почему-то возникает предположение, что 180 - это моя таймзона (GMT +3)* 60.
> Только, почему-то 180 секунд, а не минут.
Патч.
Maxim Dounin
-------------- next part --------------
# HG changeset patch
# User Maxim Dounin <mdounin at mdounin.ru>
# Date 1266584382 -10800
# Node ID 843f000d1b37757c0753853d671c94192dcb8dcc
# Parent 9009f1982e02d6f0614d4ddeae0672042442775a
SSI: time format "%s" means seconds since the Epoch in UTC
Adding local timezone offset is wrong here at all.
diff --git a/src/http/modules/ngx_http_ssi_filter_module.c b/src/http/modules/ngx_http_ssi_filter_module.c
--- a/src/http/modules/ngx_http_ssi_filter_module.c
+++ b/src/http/modules/ngx_http_ssi_filter_module.c
@@ -2615,8 +2615,7 @@ ngx_http_ssi_date_gmt_local_variable(ngx
return NGX_ERROR;
}
- v->len = ngx_sprintf(v->data, "%T", tp->sec + (gmt ? 0 : tp->gmtoff))
- - v->data;
+ v->len = ngx_sprintf(v->data, "%T", tp->sec) - v->data;
return NGX_OK;
}
Подробная информация о списке рассылки nginx-ru