|  |  |  | 
|---|
|  |  |  | package com.genersoft.iot.vmp.storager.dao; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.ParentPlatform; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.dao.dto.ChannelSourceInfo; | 
|---|
|  |  |  | import org.apache.ibatis.annotations.*; | 
|---|
|  |  |  | import org.springframework.stereotype.Repository; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | @Repository | 
|---|
|  |  |  | public interface ParentPlatformMapper { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Insert("INSERT INTO parent_platform (enable, name, serverGBId, serverGBDomain, serverIP, serverPort, deviceGBId, deviceIp,  " + | 
|---|
|  |  |  | "            devicePort, username, password, expires, keepTimeout, transport, characterSet, PTZEnable, rtcp, " + | 
|---|
|  |  |  | "            status) " + | 
|---|
|  |  |  | "            VALUES (${enable}, '${name}', '${serverGBId}', '${serverGBDomain}', '${serverIP}', ${serverPort}, '${deviceGBId}', '${deviceIp}', " + | 
|---|
|  |  |  | "            '${devicePort}', '${username}', '${password}', '${expires}', '${keepTimeout}', '${transport}', '${characterSet}', ${PTZEnable}, ${rtcp}, " + | 
|---|
|  |  |  | "            ${status})") | 
|---|
|  |  |  | @Insert("INSERT INTO wvp_platform (enable, name, server_gb_id, server_gb_domain, server_ip, server_port,device_gb_id,device_ip,"+ | 
|---|
|  |  |  | "device_port,username,password,expires,keep_timeout,transport,character_set,ptz,rtcp,as_message_channel,"+ | 
|---|
|  |  |  | "status,start_offline_push,catalog_id,administrative_division,catalog_group,create_time,update_time,tree_type) " + | 
|---|
|  |  |  | "            VALUES (#{enable}, #{name}, #{serverGBId}, #{serverGBDomain}, #{serverIP}, #{serverPort}, #{deviceGBId}, #{deviceIp}, " + | 
|---|
|  |  |  | "            #{devicePort}, #{username}, #{password}, #{expires}, #{keepTimeout}, #{transport}, #{characterSet}, #{ptz}, #{rtcp}, #{asMessageChannel}, " + | 
|---|
|  |  |  | "            #{status},  #{startOfflinePush}, #{catalogId}, #{administrativeDivision}, #{catalogGroup}, #{createTime}, #{updateTime}, #{treeType})") | 
|---|
|  |  |  | int addParentPlatform(ParentPlatform parentPlatform); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Update("UPDATE parent_platform " + | 
|---|
|  |  |  | @Update("UPDATE wvp_platform " + | 
|---|
|  |  |  | "SET enable=#{enable}, " + | 
|---|
|  |  |  | "name=#{name}," + | 
|---|
|  |  |  | "serverGBId=#{serverGBId}," + | 
|---|
|  |  |  | "serverGBDomain=#{serverGBDomain}, " + | 
|---|
|  |  |  | "serverIP=#{serverIP}," + | 
|---|
|  |  |  | "serverPort=#{serverPort}, " + | 
|---|
|  |  |  | "deviceIp=#{deviceIp}, " + | 
|---|
|  |  |  | "devicePort=#{devicePort}, " + | 
|---|
|  |  |  | "device_gb_id=#{deviceGBId}," + | 
|---|
|  |  |  | "server_gb_id=#{serverGBId}, " + | 
|---|
|  |  |  | "server_gb_domain=#{serverGBDomain}, " + | 
|---|
|  |  |  | "server_ip=#{serverIP}," + | 
|---|
|  |  |  | "server_port=#{serverPort}, " + | 
|---|
|  |  |  | "device_ip=#{deviceIp}, " + | 
|---|
|  |  |  | "device_port=#{devicePort}, " + | 
|---|
|  |  |  | "username=#{username}, " + | 
|---|
|  |  |  | "password=#{password}, " + | 
|---|
|  |  |  | "expires=#{expires}, " + | 
|---|
|  |  |  | "keepTimeout=#{keepTimeout}, " + | 
|---|
|  |  |  | "keep_timeout=#{keepTimeout}, " + | 
|---|
|  |  |  | "transport=#{transport}, " + | 
|---|
|  |  |  | "characterSet=#{characterSet}, " + | 
|---|
|  |  |  | "PTZEnable=#{PTZEnable}, " + | 
|---|
|  |  |  | "character_set=#{characterSet}, " + | 
|---|
|  |  |  | "ptz=#{ptz}, " + | 
|---|
|  |  |  | "rtcp=#{rtcp}, " + | 
|---|
|  |  |  | "status=#{status} " + | 
|---|
|  |  |  | "WHERE deviceGBId=#{deviceGBId}") | 
|---|
|  |  |  | "as_message_channel=#{asMessageChannel}, " + | 
|---|
|  |  |  | "status=#{status}, " + | 
|---|
|  |  |  | "start_offline_push=#{startOfflinePush}, " + | 
|---|
|  |  |  | "catalog_group=#{catalogGroup}, " + | 
|---|
|  |  |  | "administrative_division=#{administrativeDivision}, " + | 
|---|
|  |  |  | "create_time=#{createTime}, " + | 
|---|
|  |  |  | "update_time=#{updateTime}, " + | 
|---|
|  |  |  | "tree_type=#{treeType}, " + | 
|---|
|  |  |  | "catalog_id=#{catalogId} " + | 
|---|
|  |  |  | "WHERE id=#{id}") | 
|---|
|  |  |  | int updateParentPlatform(ParentPlatform parentPlatform); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Delete("DELETE FROM parent_platform WHERE deviceGBId=#{deviceGBId}") | 
|---|
|  |  |  | @Delete("DELETE FROM wvp_platform WHERE server_gb_id=#{serverGBId}") | 
|---|
|  |  |  | int delParentPlatform(ParentPlatform parentPlatform); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Select("SELECT * FROM parent_platform") | 
|---|
|  |  |  | @Select("SELECT *, ((SELECT count(0)\n" + | 
|---|
|  |  |  | "              FROM wvp_platform_gb_channel pc\n" + | 
|---|
|  |  |  | "              WHERE pc.platform_id = pp.server_gb_id)\n" + | 
|---|
|  |  |  | "              +\n" + | 
|---|
|  |  |  | "              (SELECT count(0)\n" + | 
|---|
|  |  |  | "              FROM wvp_platform_gb_stream pgs\n" + | 
|---|
|  |  |  | "              WHERE pgs.platform_id = pp.server_gb_id)\n" + | 
|---|
|  |  |  | "              +\n" + | 
|---|
|  |  |  | "              (SELECT count(0)\n" + | 
|---|
|  |  |  | "              FROM wvp_platform_catalog pgc\n" + | 
|---|
|  |  |  | "              WHERE pgc.platform_id = pp.server_gb_id)) as channel_count\n" + | 
|---|
|  |  |  | "FROM wvp_platform pp ") | 
|---|
|  |  |  | List<ParentPlatform> getParentPlatformList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Select("SELECT * FROM parent_platform WHERE deviceGBId=#{platformGbId}") | 
|---|
|  |  |  | ParentPlatform getParentPlatById(String platformGbId); | 
|---|
|  |  |  | @Select("SELECT * FROM wvp_platform WHERE enable=#{enable} ") | 
|---|
|  |  |  | List<ParentPlatform> getEnableParentPlatformList(boolean enable); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Select("SELECT * FROM wvp_platform WHERE enable=true and as_message_channel=true") | 
|---|
|  |  |  | List<ParentPlatform> queryEnablePlatformListWithAsMessageChannel(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Select("SELECT * FROM wvp_platform WHERE server_gb_id=#{platformGbId}") | 
|---|
|  |  |  | ParentPlatform getParentPlatByServerGBId(String platformGbId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Select("SELECT * FROM wvp_platform WHERE id=#{id}") | 
|---|
|  |  |  | ParentPlatform getParentPlatById(int id); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Update("UPDATE wvp_platform SET status=false" ) | 
|---|
|  |  |  | int outlineForAllParentPlatform(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Update("UPDATE wvp_platform SET status=#{online} WHERE server_gb_id=#{platformGbID}" ) | 
|---|
|  |  |  | int updateParentPlatformStatus(String platformGbID, boolean online); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Update(value = {" <script>" + | 
|---|
|  |  |  | "UPDATE wvp_platform " + | 
|---|
|  |  |  | "SET catalog_id=#{catalogId}, update_time=#{updateTime}" + | 
|---|
|  |  |  | "WHERE server_gb_id=#{platformId}"+ | 
|---|
|  |  |  | "</script>"}) | 
|---|
|  |  |  | int setDefaultCatalog(String platformId, String catalogId, String updateTime); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Select("select 'channel' as name, count(pgc.platform_id) count from wvp_platform_gb_channel pgc left join wvp_device_channel dc on dc.id = pgc.device_channel_id where  pgc.platform_id=#{platform_id} and dc.channel_id =#{gbId} " + | 
|---|
|  |  |  | "union " + | 
|---|
|  |  |  | "select 'stream' as name, count(pgs.platform_id) count from wvp_platform_gb_stream pgs left join wvp_gb_stream gs on pgs.gb_stream_id = gs.gb_stream_id where  pgs.platform_id=#{platform_id} and gs.gb_id #{gbId}") | 
|---|
|  |  |  | List<ChannelSourceInfo> getChannelSource(String platform_id, String gbId); | 
|---|
|  |  |  | } | 
|---|