2012-12-13 03:59:48 +00:00
< ? php
class HiwaterController extends DataController
{
private $limit = 20 ;
function preDispatch ()
{
parent :: preDispatch ();
2013-04-16 09:19:06 +00:00
//$this->_helper->layout->setLayout('hiwater');
2012-12-13 03:59:48 +00:00
$this -> debug = 1 ;
2013-04-16 09:19:06 +00:00
$acName = $this -> _request -> getActionName ();
2013-09-26 10:28:55 +00:00
if ( in_array ( $acName , array ( " aviation " , " radiometer " , " lidar " , " ccdlidar " , " widas " , 'ccdwidas' , " nearvis " , " thermal " )))
2013-04-16 09:19:06 +00:00
{
$this -> view -> pageIn = " collapse1 " ;
}
2013-09-26 10:28:55 +00:00
else if ( in_array ( $acName , array ( " airborne " , " demdsm " , " reflectance " , " vegtypeair " , " vegparam " , " temperature " , " soilmoisture " )))
2013-04-16 09:19:06 +00:00
{
$this -> view -> pageIn = " collapse2 " ;
}
2014-09-13 02:18:32 +00:00
else if ( in_array ( $acName , array ( " hmon " , 'hmon2012' , 'hmon2013' , 'hmon2012up' , 'hmon2012middle' , 'hmon2012down' , 'hmon2013up' , 'hmon2013middle' , 'hmon2013down' , 'super' , 'normal' , 'prec' )))
2013-04-16 09:19:06 +00:00
{
$this -> view -> pageIn = " collapse3 " ;
}
2013-05-25 02:19:17 +00:00
else if ( in_array ( $acName , array ( " cgs " , " calibration " , " ground " , 'sync' )))
2013-04-16 09:19:06 +00:00
{
$this -> view -> pageIn = " collapse4 " ;
}
2013-05-25 02:19:17 +00:00
else if ( in_array ( $acName , array ( " wsn " , " waternet " , " soilnet " , " bnunet " , 'bnulai' )))
2013-04-16 09:19:06 +00:00
{
$this -> view -> pageIn = " collapse5 " ;
2013-09-26 10:28:55 +00:00
}
2013-06-13 13:09:10 +00:00
else if ( in_array ( $acName , array ( " mso " , " autometeo " , " ec " , 'las' , " cosmos " , " tdp " , " isotope " )))
2013-06-07 02:30:26 +00:00
{
$this -> view -> pageIn = " collapse6 " ;
2013-09-26 10:28:55 +00:00
}
2013-06-13 13:09:10 +00:00
else if ( in_array ( $acName , array ( " rsproduct " , " dem " , " precipitation " , 'sm' , " snow " , " vegtype " , " vegcov " , 'phenology' , 'npp' )))
{
$this -> view -> pageIn = " collapse7 " ;
2013-09-26 10:28:55 +00:00
}
2013-05-28 04:20:36 +00:00
else if ( in_array ( $acName , array ( " browse " , " thumb " , " fund " , " tag " , " timeline " , " timemap " , 'author' , 'organization' )))
2013-05-26 11:23:36 +00:00
{
$this -> view -> pageIn = " collapse10 " ;
2013-04-16 09:19:06 +00:00
}
2013-05-25 02:19:17 +00:00
else if ( in_array ( $acName , array ( " other " )))
2013-04-16 09:19:06 +00:00
{
2013-06-07 02:30:26 +00:00
$this -> view -> pageIn = " collapse9 " ;
2013-04-16 09:19:06 +00:00
}
2013-09-26 10:28:55 +00:00
$this -> view -> pageID = " hiwater- " . $acName ;
2013-06-18 03:05:05 +00:00
$this -> _helper -> layout -> setLayout ( 'heihe' );
2012-12-13 03:59:48 +00:00
}
function indexAction ()
{
$sql = " select m.uuid,m.title,m.id,m.description from normalmetadata m left join thumbnail t on m.id=t.id where m.uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and length(t.data)>2 order by random() limit 3 " ;
$this -> view -> meatdata = $this -> db -> fetchAll ( $sql );
$archive = new Archive ( $this -> db );
2012-12-13 06:07:06 +00:00
$this -> view -> info = $archive -> getOneArchive ( 'HiWATER: 黑河流域生态-水文过程综合遥感观测联合试验' , 'about' );
2012-12-13 03:59:48 +00:00
}
/*
* 数据浏览
*/
function browseAction ()
{
$page = ( int ) $this -> _request -> getParam ( 'page' );
if ( empty ( $page )) $page = 1 ;
$offset = $this -> limit * ( $page - 1 );
$state = $this -> db -> query ( " select count(*) from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') " );
$row = $state -> fetchAll ();
$sum = $row [ 0 ][ 'count' ];
$select = $this -> db -> select ();
$select -> from ( 'normalmetadata' , '*' ) -> where ( " uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') " ) -> order ( 'title desc' ) -> limitPage ( $page , $this -> limit );
$this -> view -> metadata = $this -> db -> fetchAll ( $select );
$this -> view -> page = new Pagination ( $sum , $page , $this -> limit );
$this -> view -> offset = $offset + 1 ;
}
function thumbAction ()
{
$page = ( int ) $this -> _request -> getParam ( 'page' );
if ( empty ( $page )) $page = 1 ;
$offset = $this -> limit * ( $page - 1 );
$state = $this -> db -> query ( " select count(*) from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') " );
$row = $state -> fetchAll ();
$sum = $row [ 0 ][ 'count' ];
$select = $this -> db -> select ();
$select -> from ( 'normalmetadata as m' , 'm.*' )
-> where ( " uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') " )
-> order ( 'm.title desc' ) -> limitPage ( $page , $this -> limit );
$this -> view -> metadata = $this -> db -> fetchAll ( $select );
$this -> view -> page = new Pagination ( $sum , $page , $this -> limit );
}
function documentAction ()
{
$page = ( int ) $this -> _request -> getParam ( 'page' );
if ( empty ( $page )) $page = 1 ;
$offset = $this -> limit * ( $page - 1 );
$row = $this -> db -> fetchAll ( " select count(*) from reference where id in (select refid from mdref where uuid in (select uuid from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') )) " );
$sum = $row [ 0 ][ 'count' ];
$sql = " select * from reference where id in (select refid from mdref where uuid in (select uuid from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') )) order by reference limit ? offset ? " ;
$this -> view -> refs = $this -> db -> fetchAll ( $sql , array ( $this -> limit , $offset ));
$this -> view -> page = new Pagination ( $sum , $page , $this -> limit , " 文献 " );
$this -> view -> offset = $offset + 1 ;
}
2013-05-24 16:24:31 +00:00
function aviationAction ()
{
2013-06-07 02:30:26 +00:00
$this -> getmdlimited ( array ( 'WiDAS' , 'PLMR' , 'Lidar' , 'CASI' , '热红外高光谱数据' ), '航空遥感' );
2013-05-24 16:24:31 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
function radiometerAction ()
{
2013-06-07 02:30:26 +00:00
$this -> getmdlimited ( 'PLMR' , '航空遥感' );
2013-05-24 16:24:31 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
function lidarAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( '激光雷达' , '航空遥感' , array ( 'CCD' ));
2013-05-24 16:24:31 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
2013-09-26 10:28:55 +00:00
function ccdlidarAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdrestricted ( array ( 'CCD' , '航空遥感' , " 激光雷达 " ));
2013-09-26 10:28:55 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
2013-05-24 16:24:31 +00:00
function widasAction ()
2013-09-26 10:28:55 +00:00
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( 'WIDAS' , '航空遥感' , array ( 'CCD' ));
2013-05-24 16:24:31 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
2013-09-26 10:28:55 +00:00
function ccdwidasAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdrestricted ( array ( 'CCD' , '航空遥感' , 'WIDAS' ));
2013-06-18 12:23:33 +00:00
$this -> _helper -> viewRenderer ( 'base' );
2013-09-26 10:28:55 +00:00
}
2013-05-24 16:24:31 +00:00
function nearvisAction ()
2013-09-26 10:28:55 +00:00
{
2013-06-07 02:30:26 +00:00
$this -> getmdlimited ( 'CASI' , '航空遥感' );
2013-05-24 16:24:31 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
function thermalAction ()
2013-09-26 10:28:55 +00:00
{
2013-06-07 02:30:26 +00:00
$this -> getmdlimited ( '热红外高光谱数据' , '航空遥感' );
2013-05-24 16:24:31 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
2013-05-25 02:19:17 +00:00
function airborneAction ()
2012-12-13 03:59:48 +00:00
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( 'DEM' , 'DSM' , 'DOM' , '地表反照率' , '地表反射率' , '植被类型' , '植被结构参数' , '土壤水分' , '地表温度' ), '航空遥感产品' );
2013-05-25 02:19:17 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
2013-09-26 10:28:55 +00:00
function demdsmAction ()
2013-05-25 02:19:17 +00:00
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( 'DEM' , 'DSM' , 'DOM' ), " 航空遥感产品 " );
2013-09-26 10:28:55 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
function reflectanceAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( '地表反照率' , '地表反射率' ), " 航空遥感产品 " );
2013-09-26 10:28:55 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
function vegtypeairAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( '植被类型' ), '航空遥感产品' );
2013-05-25 02:19:17 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
function vegparamAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( " " , '植被结构参数' ), " 航空遥感产品 " );
2013-05-25 02:19:17 +00:00
$this -> _helper -> viewRenderer ( 'base' );
2013-09-26 10:28:55 +00:00
}
function soilmoistureAction ()
2013-05-25 02:19:17 +00:00
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( '' , '土壤水分' ), " 航空遥感产品 " );
2013-05-25 02:19:17 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
function temperatureAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( '' , '地表温度' ), " 航空遥感产品 " );
2013-05-25 02:19:17 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
2013-06-13 13:09:10 +00:00
function hmonAction ()
2013-05-25 02:19:17 +00:00
{
2014-09-13 02:18:32 +00:00
$this -> getmd ( array ( '水文气象观测网' ));
$archive = new Archive ( $this -> db );
$this -> view -> info = $archive -> getOneArchive ( 'HiWATER: 流域水文气象观测网' , 'about' );
2013-06-13 13:09:10 +00:00
$this -> _helper -> viewRenderer ( 'base' );
2013-09-26 10:28:55 +00:00
}
2013-06-13 13:09:10 +00:00
function superAction ()
{
$this -> getmdlimited ( array ( '阿柔超级站' , '大满超级站' , '四道桥超级站' ), '水文气象' );
2013-05-25 02:19:17 +00:00
$this -> _helper -> viewRenderer ( 'base' );
2012-12-13 03:59:48 +00:00
}
2013-06-13 13:09:10 +00:00
function normalAction ()
2012-12-13 03:59:48 +00:00
{
2013-11-11 04:17:15 +00:00
$this -> getmdlimited ( array ( '景阳岭站' , '峨堡站' , '黄草沟站' , '阿柔阴坡站' , '阿柔阳坡站' , '黄藏寺站' , '大沙龙站' , '寺大隆站' , '排露沟林前气象站' , '水源涵养林研究院观测站' , '巴吉滩戈壁站' , '神沙窝沙漠站' , '张掖湿地站' ,
'花寒子荒漠站' , '五里墩气象站' , '四道桥混合林站' , '四道桥胡杨林站' , '四道桥裸地站' , '四道桥农田站' , '黑河上游生态-水文试验研究站' , '临泽内陆河流域研究站' , '阿拉善荒漠生态-水文实验研究站' ), '水文气象' );
2013-05-25 02:19:17 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
2013-06-13 13:09:10 +00:00
2013-05-25 02:19:17 +00:00
function autometeoAction ()
{
$this -> getmd ( array ( '' , '自动气象站' ));
$this -> _helper -> viewRenderer ( 'base' );
2013-09-26 10:28:55 +00:00
$archive = new Archive ( $this -> db );
$this -> view -> info = $archive -> getOneArchive ( 'HiWATER-通量观测矩阵' , 'about' );
2013-05-25 02:19:17 +00:00
}
function ecAction ()
{
$this -> getmd ( array ( '' , '涡动相关仪' ));
$this -> _helper -> viewRenderer ( 'base' );
2013-09-26 10:28:55 +00:00
$archive = new Archive ( $this -> db );
$this -> view -> info = $archive -> getOneArchive ( 'HiWATER-通量观测矩阵' , 'about' );
2013-05-25 02:19:17 +00:00
}
function lasAction ()
{
$this -> getmd ( array ( '' , '大孔径闪烁仪' ));
2013-09-26 10:28:55 +00:00
$this -> _helper -> viewRenderer ( 'base' );
$archive = new Archive ( $this -> db );
$this -> view -> info = $archive -> getOneArchive ( 'HiWATER-通量观测矩阵' , 'about' );
2013-06-25 01:01:35 +00:00
2013-05-25 02:19:17 +00:00
}
function precAction ()
{
$this -> getmd ( array ( '' , '河川径流观测' ));
$this -> _helper -> viewRenderer ( 'base' );
2012-12-13 03:59:48 +00:00
}
2013-05-25 02:19:17 +00:00
function cgsAction ()
2012-12-13 03:59:48 +00:00
{
2013-05-25 02:19:17 +00:00
$this -> getmd ( array ( '定标观测' , '地基遥感观测' , '地面同步观测' ));
$this -> _helper -> viewRenderer ( 'base' );
2012-12-13 03:59:48 +00:00
}
2013-05-25 02:19:17 +00:00
function calibrationAction ()
2012-12-13 03:59:48 +00:00
{
2013-05-25 02:19:17 +00:00
$this -> getmd ( array ( '' , '定标观测' ));
$this -> _helper -> viewRenderer ( 'base' );
2012-12-13 03:59:48 +00:00
}
2013-05-25 02:19:17 +00:00
function groundAction ()
2012-12-13 03:59:48 +00:00
{
2013-05-25 02:19:17 +00:00
$this -> getmd ( array ( '' , '地基遥感观测' ));
$this -> _helper -> viewRenderer ( 'base' );
2012-12-13 03:59:48 +00:00
}
2013-05-25 02:19:17 +00:00
function syncAction ()
2012-12-13 03:59:48 +00:00
{
2013-05-25 02:19:17 +00:00
$this -> getmd ( array ( '' , '地面同步观测' ));
$this -> _helper -> viewRenderer ( 'base' );
2012-12-13 03:59:48 +00:00
}
2013-05-25 02:19:17 +00:00
function wsnAction ()
2012-12-13 03:59:48 +00:00
{
2013-05-25 02:19:17 +00:00
$this -> getmd ( array ( 'WATERNET' , 'SoilNET' , 'BNUNET' , 'BNULAI' ));
$this -> _helper -> viewRenderer ( 'base' );
2012-12-13 03:59:48 +00:00
}
2013-05-25 02:19:17 +00:00
function waternetAction ()
2012-12-13 03:59:48 +00:00
{
2013-05-25 02:19:17 +00:00
$this -> getmd ( array ( '' , 'WATERNET' ));
$this -> _helper -> viewRenderer ( 'base' );
}
function soilnetAction ()
{
$this -> getmd ( array ( '' , 'SoilNET' ));
$this -> _helper -> viewRenderer ( 'base' );
}
function bnunetAction ()
{
$this -> getmd ( array ( '' , 'BNUNET' ));
$this -> _helper -> viewRenderer ( 'base' );
}
function bnulaiAction ()
{
2013-06-08 09:56:15 +00:00
$this -> getmdlimited ( 'LAI' , '生态水文无线传感器网络' );
2013-05-25 02:19:17 +00:00
$this -> _helper -> viewRenderer ( 'base' );
2012-12-13 03:59:48 +00:00
}
2013-05-25 02:19:17 +00:00
function satelliteAction ()
2012-12-13 03:59:48 +00:00
{
2013-05-25 02:19:17 +00:00
$this -> getmd ( array ( '' , '卫星遥感' ));
$this -> _helper -> viewRenderer ( 'base' );
2012-12-13 03:59:48 +00:00
}
function soilAction ()
{
2013-05-25 02:19:17 +00:00
$this -> getmd ( array ( '' , '卫星遥感' ));
$this -> _helper -> viewRenderer ( 'base' );
2012-12-13 03:59:48 +00:00
}
function meteoAction ()
{
$this -> getmd ( '气象' , 'theme' );
}
function hydroAction ()
{
$this -> getmd ( '水文观测' , 'theme' );
}
function irragationAction ()
{
$this -> getmd ( '灌溉' , 'theme' );
}
function obsAction ()
{
$this -> getmd ( '试验' , 'theme' );
}
2013-09-26 10:28:55 +00:00
2013-06-07 02:30:26 +00:00
function msoAction ()
{
2013-06-13 13:09:10 +00:00
$this -> getmd ( array ( '自动气象站' , '涡动相关仪' , '大孔径闪烁仪' , '稳定同位素观测系统' , '热扩散液流计( TDP) ' , '宇宙射线土壤水分' ));
2013-09-26 10:28:55 +00:00
$this -> _helper -> viewRenderer ( 'base' );
$archive = new Archive ( $this -> db );
2013-06-25 01:01:35 +00:00
$this -> view -> info = $archive -> getOneArchive ( 'HiWATER-通量观测矩阵' , 'about' );
2013-06-07 02:30:26 +00:00
}
2012-12-13 03:59:48 +00:00
2013-06-07 02:30:26 +00:00
function isotopeAction ()
{
$this -> getmd ( array ( '' , '稳定同位素观测系统' ));
$this -> _helper -> viewRenderer ( 'base' );
}
2013-09-26 10:28:55 +00:00
2013-06-07 02:30:26 +00:00
function tdpAction ()
{
$this -> getmd ( array ( '' , '热扩散液流计( TDP) ' ));
$this -> _helper -> viewRenderer ( 'base' );
}
2013-09-26 10:28:55 +00:00
2013-06-07 02:30:26 +00:00
function cosmosAction ()
{
$this -> getmd ( array ( '' , '宇宙射线土壤水分' ));
$this -> _helper -> viewRenderer ( 'base' );
2013-09-26 10:28:55 +00:00
}
2013-06-13 13:09:10 +00:00
function rsproductAction ()
{
2015-01-14 06:19:53 +00:00
$this -> getmd ( array ( '卫星遥感产品' ));
2013-06-13 13:09:10 +00:00
$this -> _helper -> viewRenderer ( 'base' );
2013-06-07 02:30:26 +00:00
}
2013-06-13 13:09:10 +00:00
function demAction ()
{
$this -> getmdlimited ( array ( 'DEM' , 'DOM' ), '数据产品' );
$this -> _helper -> viewRenderer ( 'base' );
}
function precipitationAction ()
{
$this -> getmdlimited ( array ( '降水' , '' ), '数据产品' );
$this -> _helper -> viewRenderer ( 'base' );
}
function smAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( '土壤水分' , " " ), '卫星遥感产品' );
2013-06-13 13:09:10 +00:00
$this -> _helper -> viewRenderer ( 'base' );
}
function snowAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( '积雪' , " " ), '卫星遥感产品' );
2013-06-13 13:09:10 +00:00
$this -> _helper -> viewRenderer ( 'base' );
2013-09-26 10:28:55 +00:00
}
2013-06-13 13:09:10 +00:00
function vegtypeAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( '植被类型' , '' ), '卫星遥感产品' );
2013-06-13 13:09:10 +00:00
$this -> _helper -> viewRenderer ( 'base' );
2013-09-26 10:28:55 +00:00
}
2013-06-13 13:09:10 +00:00
function vegcovAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( '植被覆盖度' , '' ), '卫星遥感产品' );
2013-06-13 13:09:10 +00:00
$this -> _helper -> viewRenderer ( 'base' );
2013-09-26 10:28:55 +00:00
}
2013-06-13 13:09:10 +00:00
function phenologyAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( '物候期' , '' ), '卫星遥感产品' );
2013-06-13 13:09:10 +00:00
$this -> _helper -> viewRenderer ( 'base' );
2013-09-26 10:28:55 +00:00
}
2013-06-13 13:09:10 +00:00
function nppAction ()
{
2014-06-06 01:02:29 +00:00
$this -> getmdlimited ( array ( 'NPP' , '' ), '卫星遥感产品' );
2013-06-13 13:09:10 +00:00
$this -> _helper -> viewRenderer ( 'base' );
2013-09-26 10:28:55 +00:00
}
2014-09-13 02:18:32 +00:00
function hmon2012Action ()
{
$this -> getmdrestricted ( array ( '2012' , '水文气象观测网' ));
$archive = new Archive ( $this -> db );
$this -> view -> info = $archive -> getOneArchive ( 'HiWATER: 流域水文气象观测网' , 'about' );
$this -> _helper -> viewRenderer ( 'base' );
}
function hmon2013Action ()
{
$this -> getmdrestricted ( array ( '2013' , '水文气象观测网' ));
$archive = new Archive ( $this -> db );
$this -> view -> info = $archive -> getOneArchive ( 'HiWATER: 流域水文气象观测网' , 'about' );
$this -> _helper -> viewRenderer ( 'base' );
}
function hmon2012upAction ()
{
$this -> getmdrestricted ( array ( '2012' , '上游寒区水文试验区' , '水文气象观测网' ));
$this -> _helper -> viewRenderer ( 'base' );
}
function hmon2012middleAction ()
{
$this -> getmdrestricted ( array ( '2012' , '中游人工绿洲试验区' , '水文气象观测网' ));
$this -> _helper -> viewRenderer ( 'base' );
}
function hmon2012downAction ()
{
$this -> getmdrestricted ( array ( '2012' , '下游天然绿洲试验区' , '水文气象观测网' ));
$this -> _helper -> viewRenderer ( 'base' );
}
function hmon2013upAction ()
{
$this -> getmdrestricted ( array ( '2013' , '上游寒区水文试验区' , '水文气象观测网' ));
$this -> _helper -> viewRenderer ( 'base' );
}
function hmon2013middleAction ()
{
$this -> getmdrestricted ( array ( '2013' , '中游人工绿洲试验区' , '水文气象观测网' ));
$this -> _helper -> viewRenderer ( 'base' );
}
function hmon2013downAction ()
{
$this -> getmdrestricted ( array ( '2013' , '下游天然绿洲试验区' , '水文气象观测网' ));
$this -> _helper -> viewRenderer ( 'base' );
}
2012-12-13 03:59:48 +00:00
function listAction ()
{
$sql = " select uuid,title from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') order by timebegin,title " ;
$this -> view -> metadata = $this -> db -> fetchAll ( $sql );
}
function tagAction ()
{
$key = $this -> _request -> getParam ( 'key' );
2013-05-25 03:46:38 +00:00
$keytype = $this -> _request -> getParam ( 'keytype' );
2012-12-13 03:59:48 +00:00
$page = ( int ) $this -> _request -> getParam ( 'page' );
if ( empty ( $page )) $page = 1 ;
$offset = $this -> limit * ( $page - 1 );
if ( ! empty ( $key )) {
$this -> view -> codename = $key ;
2013-05-25 03:46:38 +00:00
$sql = $this -> db -> quoteInto ( " select count(k.id) from keyword k left join normalmetadata m on k.id=m.id where m.uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and k.keyword=? " , $key );
2012-12-13 03:59:48 +00:00
$state = $this -> db -> query ( $sql );
$row = $state -> fetchAll ();
$sum = $row [ 0 ][ 'count' ];
$sql = " select uuid,title,id,description from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and id in (select id from keyword where keyword=' " . $key . " ') order by timebegin,title limit ? offset ? " ;
$this -> view -> metadata = $this -> db -> fetchAll ( $sql , array ( $this -> limit , $offset ));
$this -> view -> page = new Pagination ( $sum , $page , $this -> limit );
} else {
2013-05-25 03:46:38 +00:00
$sql = " select k.keyword,count(*),k.keytype from keyword k left join normalmetadata m on k.id=m.id where m.uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') " ;
if ( ! empty ( $keytype ) && ( $keytype == 'place' || $keytype == 'theme' || $keytype == 'discipline' || $keytype == 'temporal' )) $sql .= " and k.keytype=' " . $keytype . " ' " ;
$sql .= ' group by k.keyword,k.keytype order by k.keytype,k.keyword,count desc' ;
$state = $this -> db -> query ( $sql );
$this -> view -> keytype = $keytype ;
$this -> view -> keywords = $state -> fetchAll ();
2012-12-13 03:59:48 +00:00
}
}
function searchAction ()
{
$this -> view -> addHelperPath ( 'helper' , 'Zend_View_Helper_' );
$form = new SearchForm ();
$this -> view -> form = $form ;
//$form->submit->setLabel('快速搜索');
$key = $this -> _request -> getParam ( 'q' );
if ( ! empty ( $key )) {
2013-05-25 02:19:17 +00:00
$search = new SimpleSearch ( $key );
2012-12-13 03:59:48 +00:00
$where = $search -> sql_expr ( array ( " title " , " description " ));
$page =@ ( int ) $this -> _request -> getParam ( 'page' );
if ( empty ( $page )) $page = 1 ;
$offset = $this -> limit * ( $page - 1 );
$row = $this -> db -> fetchAll ( " select count(*) from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and " . $where );
$sum = $row [ 0 ][ 'count' ];
$sql = " select uuid,title,id,description from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and " . $where . " order by timebegin,title limit ? offset ? " ;
$this -> view -> metadata = $this -> db -> fetchAll ( $sql , array ( $this -> limit , $offset ));
$this -> view -> page = new Pagination ( $sum , $page , $this -> limit );
$this -> view -> key = $key ;
$this -> view -> offset = $offset + 1 ;
}
}
function timemapAction ()
{
$sql = " select id,uuid,west,south,north,east,title,timebegin,timeend from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and timebegin is not null " ;
$this -> view -> rows = $this -> db -> fetchAll ( $sql );
}
function timelineAction ()
{
2013-05-25 03:46:38 +00:00
$fn = " hiwatertime.xml " ;
2012-12-13 03:59:48 +00:00
$rows = $this -> db -> fetchAll ( " select ts_created from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') order by ts_created desc limit 1 " );
$last_update = strtotime ( $rows [ 0 ][ 'ts_created' ]);
if ( ! file_exists ( $fn ) || ( filemtime ( $fn ) < $last_update ))
{
$dateformat = " M j Y " ;
$rows = $this -> db -> fetchAll ( " select id,uuid,description,title,timebegin,timeend from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and timebegin is not null order by timebegin,title " );
$timexml = '<data>' ;
foreach ( $rows as $row ) {
$timexml .= '<event start="' . date ( $dateformat , strtotime ( $row [ 'timebegin' ])) . ' GMT+0800" ' ;
if ( $row [ 'timeend' ] != '' && $row [ 'timeend' ] != $row [ 'timebegin' ]) $timexml .= ' end="' . date ( $dateformat , strtotime ( $row [ 'timeend' ])) . '" isDuration="true"' ;
$timexml .= ' title="' . htmlspecialchars ( $row [ 'title' ]) . '" image="/images/westdc_40w.gif" link="/hiwater/view/uuid/' . $row [ 'uuid' ] . '">' ;
$desc_length = mb_strlen ( $row [ 'description' ], " UTF-8 " );
$desc = mb_substr ( $row [ 'description' ], 0 ,( $desc_length > 300 ) ? 300 : $desc_length , " UTF-8 " );
if ( $desc_length > 300 ) $desc .= " ... " ;
$timexml .= htmlspecialchars ( $desc );
$timexml .= " </event> \n " ;
}
$timexml .= '</data>' ;
$fp = fopen ( $fn , 'w' );
fwrite ( $fp , $timexml );
fclose ( $fp );
}
}
function categoryAction ()
{
$code = ( int ) $this -> _request -> getParam ( 'code' );
$page = ( int ) $this -> _request -> getParam ( 'page' );
if ( empty ( $page )) $page = 1 ;
$offset = $this -> limit * ( $page - 1 );
$this -> view -> category = $this -> db -> fetchAll ( " select c.code,name,name_zh,count(*) from category c left join normalmetadata m on c.id=m.id,categorycode cc where c.code=cc.code and m.uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') group by c.code,cc.name,cc.name_zh " );
if ( $code > 0 && $code < 20 ) {
$row = $this -> db -> fetchAll ( " select count(*) from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and id in (select id from category where code= " . $code . " ) " );
$sum = $row [ 0 ][ 'count' ];
$sql = " select uuid,title,description,id from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and id in (select distinct id from category where code= " . $code . " ) order by timebegin,title limit ? offset ? " ;
$this -> view -> metadata = $this -> db -> fetchAll ( $sql , array ( $this -> limit , $offset ));
$this -> view -> page = new Pagination ( $sum , $page , $this -> limit );
$this -> view -> offset = $offset + 1 ;
$row = $this -> db -> fetchRow ( " select name,name_zh from categorycode where code=? " , $code );
$this -> view -> codename = ( empty ( $row [ 'name_zh' ]) ? $row [ 'name' ] : $row [ 'name_zh' ]);
} else {
//提供全部分类列表
}
}
2013-05-25 03:46:38 +00:00
function viewAction ()
{
parent :: viewAction ();
$this -> _helper -> viewRenderer ( 'hiwater/view' );
}
2012-12-13 03:59:48 +00:00
private function getmd ( $keyword , $type = 'theme' )
{
$page = ( int ) $this -> _request -> getParam ( 'page' );
if ( empty ( $page )) $page = 1 ;
$offset = $this -> limit * ( $page - 1 );
2013-05-24 16:24:31 +00:00
if ( ! is_array ( $keyword ))
{
$keyword = array ( $keyword );
}
$key = " ( " ;
foreach ( $keyword as $k )
{
$key .= " ' " . $k . " ', " ;
}
$key = substr ( $key , 0 , - 1 );
$key .= " ) " ;
$keyword = $key ;
$state = $this -> db -> query ( " select count(m.*) from normalmetadata m left join datasource d on m.uuid=d.uuid left join source s on d.sourceid=s.id where s.code='hiwater' and m.id in (select id from keyword where keytype=' " . $type . " ' and keyword in " . $keyword . " ) " );
2012-12-13 03:59:48 +00:00
$row = $state -> fetchAll ();
$sum = $row [ 0 ][ 'count' ];
//@todo: add order with title
2013-07-01 15:11:03 +00:00
$sql = " select uuid,title from normalmetadata where uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and id in (select id from keyword where keytype=' " . $type . " ' and keyword in " . $keyword . " ) order by title limit ? offset ? " ;
2012-12-13 03:59:48 +00:00
$this -> view -> metadata = $this -> db -> fetchAll ( $sql , array ( $this -> limit , $offset ));
2013-06-07 02:30:26 +00:00
$this -> view -> page = new Pagination ( $sum , $page , $this -> limit );
$this -> view -> offset = $offset + 1 ;
2013-09-26 10:28:55 +00:00
}
//获取多项条件并列关系的数据并必须满足limited条件
//$keyword:字符串或字符串数组
//$limited:限制字符串
2014-06-06 01:02:29 +00:00
//$without:明确不包含的字符串数组
private function getmdlimited ( $keyword , $limited , $without = '' )
2013-06-07 02:30:26 +00:00
{
$page = ( int ) $this -> _request -> getParam ( 'page' );
if ( empty ( $page )) $page = 1 ;
$offset = $this -> limit * ( $page - 1 );
if ( ! is_array ( $keyword ))
{
$keyword = array ( $keyword );
}
$key = " ( " ;
foreach ( $keyword as $k )
{
$key .= " ' " . $k . " ', " ;
}
$key = substr ( $key , 0 , - 1 );
$key .= " ) " ;
$keyword = $key ;
2014-06-06 01:02:29 +00:00
if ( ! empty ( $without ))
{
if ( ! is_array ( $without ))
{
$without = array ( $without );
}
$withoutkey = " ( " ;
foreach ( $without as $wo )
{
$withoutkey .= " ' " . $wo . " ', " ;
}
$withoutkey = substr ( $withoutkey , 0 , - 1 );
$withoutkey .= " ) " ;
}
$sql = " select count(m.*) from normalmetadata m left join datasource d on m.uuid=d.uuid left join source s on d.sourceid=s.id
where s . code = 'hiwater' and m . id in ( select id from keyword where keyword = '".$limited."' )
and m . id in ( select id from keyword where keyword in " . $keyword . " ) " ;
if ( ! empty ( $without )) $sql .= " and m.id not in (select id from keyword where keyword in $withoutkey ) " ;
$state = $this -> db -> query ( $sql );
$row = $state -> fetchAll ();
$sum = $row [ 0 ][ 'count' ];
//@todo: add order with title
$sql = " select uuid,title from normalmetadata where
uuid in ( select d . uuid from datasource d left join source s on d . sourceid = s . id where s . code = 'hiwater' )
and id in ( select id from keyword where keyword = '".$limited."' )
and id in ( select id from keyword where keyword in " . $keyword . " ) " ;
if ( ! empty ( $without )) $sql .= " and id not in (select id from keyword where keyword in $withoutkey ) " ;
$sql .= " order by title limit ? offset ? " ;
$this -> view -> metadata = $this -> db -> fetchAll ( $sql , array ( $this -> limit , $offset ));
$this -> view -> page = new Pagination ( $sum , $page , $this -> limit );
$this -> view -> offset = $offset + 1 ;
}
//获取多项必须满足的条件
//$keyword:字符串或字符串数组
private function getmdrestricted ( $keyword )
{
$page = ( int ) $this -> _request -> getParam ( 'page' );
if ( empty ( $page )) $page = 1 ;
$offset = $this -> limit * ( $page - 1 );
if ( ! is_array ( $keyword ))
{
$keyword = array ( $keyword );
}
$key = " ( " ;
foreach ( $keyword as $k )
{
$key .= " m.id in (select id from keyword where keyword=' " . $k . " ') and " ;
}
$key = substr ( $key , 0 , - 4 );
$key .= " ) " ;
$keyword = $key ;
$state = $this -> db -> query ( " select count(m.*) from normalmetadata m left join datasource d on m.uuid=d.uuid left join source s on d.sourceid=s.id where s.code='hiwater' and $keyword " );
2013-06-07 02:30:26 +00:00
$row = $state -> fetchAll ();
$sum = $row [ 0 ][ 'count' ];
//@todo: add order with title
2014-06-06 01:02:29 +00:00
$sql = " select uuid,title from normalmetadata m where m.uuid in
( select d . uuid from datasource d left join source s on d . sourceid = s . id where s . code = 'hiwater' )
and $keyword
order by title limit ? offset ? " ;
2013-06-07 02:30:26 +00:00
$this -> view -> metadata = $this -> db -> fetchAll ( $sql , array ( $this -> limit , $offset ));
2012-12-13 03:59:48 +00:00
$this -> view -> page = new Pagination ( $sum , $page , $this -> limit );
$this -> view -> offset = $offset + 1 ;
}
2013-05-26 11:23:36 +00:00
//基于数据作者的浏览(包括认证后的数据作者以及未认证的数据作者)
function authorAction ()
{
$ac = $this -> _request -> getParam ( 'ac' );
$id = ( int ) $this -> _request -> getParam ( 'id' );
if ( $ac == 'verified' ) {
//已经认证过的数据作者
$this -> view -> tabID = 'author-verified' ;
$this -> view -> ac = 'verified' ;
if ( $id ) {
//列出作者的数据
$sql = " select username,realname from users where id=? " ;
$this -> view -> author = $this -> db -> fetchRow ( $sql , array ( $id ));
$sql = " select m.* from normalmetadata m left join mdauthor a on a.uuid=m.uuid where m.uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and a.userid=? " ;
$sth = $this -> db -> prepare ( $sql );
$sth -> execute ( array ( $id ));
$rows = $sth -> fetchAll ();
$paginator = Zend_Paginator :: factory ( $rows );
$paginator -> setCurrentPageNumber ( $this -> _getParam ( 'page' ));
$paginator -> setItemCountPerPage ( 10 );
$paginator -> setView ( $this -> view );
Zend_View_Helper_PaginationControl :: setDefaultViewPartial ( 'pagination_param.phtml' );
$this -> view -> paginator = $paginator ;
} else {
//已经认证过的数据作者
$sql = " select u.username,u.realname,u.id,count(u.id) as count from mdauthor a left join users u on a.userid=u.id where a.uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and a.status=1 and a.uuid in (select uuid from normalmetadata) group by u.id,u.username,u.realname " ;
$sth = $this -> db -> prepare ( $sql );
$sth -> execute ();
$rows = $sth -> fetchAll ();
$paginator = Zend_Paginator :: factory ( $rows );
$paginator -> setCurrentPageNumber ( $this -> _getParam ( 'page' ));
$paginator -> setItemCountPerPage ( 50 );
$paginator -> setView ( $this -> view );
Zend_View_Helper_PaginationControl :: setDefaultViewPartial ( 'pagination_param.phtml' );
$this -> view -> paginator = $paginator ;
}
} else if ( $ac == 'unverified' || empty ( $ac )) {
//未认证的数据作者
$this -> view -> tabID = 'author-unverified' ;
$this -> view -> ac = 'unverified' ;
if ( $id ) {
//列出数据
$sql = " select individual as username from responsible where id=? " ;
$this -> view -> author = $this -> db -> fetchRow ( $sql , array ( $id ));
$sql = " select distinct m.* from normalmetadata m left join role r on m.uuid=r.uuid left join responsible s on r.resid=s.id where r.uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and r.role in ('pointOfContact','resourceProvider','owner') and s.id=? " ;
$sth = $this -> db -> prepare ( $sql );
$sth -> execute ( array ( $id ));
$rows = $sth -> fetchAll ();
$paginator = Zend_Paginator :: factory ( $rows );
$paginator -> setCurrentPageNumber ( $this -> _getParam ( 'page' ));
$paginator -> setItemCountPerPage ( 10 );
$paginator -> setView ( $this -> view );
Zend_View_Helper_PaginationControl :: setDefaultViewPartial ( 'pagination_param.phtml' );
$this -> view -> paginator = $paginator ;
} else {
//列出所有作者
$sql = " select distinct responsible.individual as username,responsible.id from responsible left join role on role.resid=responsible.id where role.uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and role.role in ('pointOfContact','resourceProvider','owner') " ;
$sth = $this -> db -> prepare ( $sql );
$sth -> execute ();
$rows = $sth -> fetchAll ();
$paginator = Zend_Paginator :: factory ( $rows );
$paginator -> setCurrentPageNumber ( $this -> _getParam ( 'page' ));
$paginator -> setItemCountPerPage ( 50 );
$paginator -> setView ( $this -> view );
Zend_View_Helper_PaginationControl :: setDefaultViewPartial ( 'pagination_param.phtml' );
$this -> view -> paginator = $paginator ;
}
}
2013-09-26 10:28:55 +00:00
}
2013-05-26 11:23:36 +00:00
function fundAction ()
{
$id = ( int ) $this -> _request -> getParam ( 'id' );
if ( ! empty ( $id )) {
$sql = " select * from fund where id=? " ;
$this -> view -> fund = $this -> db -> fetchRow ( $sql , array ( $id ));
if ( $this -> view -> fund ) {
$sql = " select distinct m.* from normalmetadata m left join mdfund mf on m.uuid=mf.uuid where m.uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and mf.fid=? " ;
$sth = $this -> db -> prepare ( $sql );
$sth -> execute ( array ( $id ));
$rows = $sth -> fetchAll ();
$paginator = Zend_Paginator :: factory ( $rows );
$paginator -> setCurrentPageNumber ( $this -> _getParam ( 'page' ));
$paginator -> setItemCountPerPage ( 10 );
$paginator -> setView ( $this -> view );
Zend_View_Helper_PaginationControl :: setDefaultViewPartial ( 'pagination_param.phtml' );
$this -> view -> paginator = $paginator ;
}
} else {
//提供全部分类列表
$sql = " select f.id,f.title,f.fund_id,f.fund_type,f.ts_created,count(m.id) as datacount,sum(md.filesize) as filesize from fund f left join mdfund m on f.id=m.fid left join metadata md on m.uuid=md.uuid where m.uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') group by f.id,f.title,f.fund_id,f.fund_type,f.ts_created order by f.ts_created desc " ;
$sth = $this -> db -> prepare ( $sql );
$sth -> execute ();
$rows = $sth -> fetchAll ();
$paginator = Zend_Paginator :: factory ( $rows );
$paginator -> setCurrentPageNumber ( $this -> _getParam ( 'page' ));
$paginator -> setItemCountPerPage ( 10 );
$paginator -> setView ( $this -> view );
Zend_View_Helper_PaginationControl :: setDefaultViewPartial ( 'pagination_param.phtml' );
$this -> view -> paginator = $paginator ;
$this -> _helper -> viewRenderer ( 'fund-list' );
}
2013-09-26 10:28:55 +00:00
}
2013-05-26 11:23:36 +00:00
function organizationAction ()
{
$page = $this -> _request -> getParam ( 'page' );
$name = $this -> _request -> getParam ( 'name' );
$state = $this -> db -> query ( " select distinct responsible.organisation from responsible left join role on role.resid=responsible.id where role.uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and role.role in ('pointOfContact','resourceProvider','owner') " );
$this -> view -> organisation = $state -> fetchAll ();
if ( ! empty ( $name )) {
$this -> view -> codename = $name ;
$sql = " select distinct m.* from normalmetadata m left join role r on m.uuid=r.uuid left join responsible s on r.resid=s.id where m.uuid in (select d.uuid from datasource d left join source s on d.sourceid=s.id where s.code='hiwater') and r.role in ('pointOfContact','resourceProvider','owner') and s.organisation=? " ;
$sth = $this -> db -> prepare ( $sql );
$sth -> execute ( array ( $name ));
$rows = $sth -> fetchAll ();
$paginator = Zend_Paginator :: factory ( $rows );
$paginator -> setCurrentPageNumber ( $this -> _getParam ( 'page' ));
$paginator -> setItemCountPerPage ( 10 );
$paginator -> setView ( $this -> view );
Zend_View_Helper_PaginationControl :: setDefaultViewPartial ( 'pagination_param.phtml' );
$this -> view -> paginator = $paginator ;
} else {
//提供全部分类列表
}
}
2012-12-13 03:59:48 +00:00
}