| | |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import com.fasterxml.jackson.core.JsonParser; |
| | | import com.ruoyi.common.core.domain.AjaxResult; |
| | | import com.ruoyi.common.core.domain.entity.EsModel; |
| | | import com.ruoyi.common.core.domain.entity.SysUser; |
| | | import com.ruoyi.common.utils.MapUtils; |
| | | import com.ruoyi.common.utils.SecurityUtils; |
| | |
| | | import com.ruoyi.domain.ZfCollection; |
| | | import com.ruoyi.domain.ZfCollection; |
| | | import com.ruoyi.mapper.ZfCollectionMapper; |
| | | import com.ruoyi.service.ZAuthorityService; |
| | | import com.ruoyi.service.ZInfoUserService; |
| | | import com.ruoyi.service.ZfCollectionService; |
| | | import com.ruoyi.service.ZfLogService; |
| | | import com.ruoyi.service.*; |
| | | import com.ruoyi.util.ArraysUtil; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.elasticsearch.action.delete.DeleteRequest; |
| | | import org.elasticsearch.action.update.UpdateRequest; |
| | | import org.elasticsearch.client.RequestOptions; |
| | | import org.elasticsearch.client.RestHighLevelClient; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | import org.springframework.web.multipart.MultipartFile; |
| | | |
| | | import javax.annotation.Resource; |
| | | import java.io.IOException; |
| | | import java.time.LocalDateTime; |
| | | import java.util.*; |
| | | import java.util.stream.Collectors; |
| | |
| | | |
| | | @Resource |
| | | ZfLogService zfLogService; |
| | | |
| | | @Resource |
| | | EsService esService; |
| | | |
| | | @Resource |
| | | RestHighLevelClient restHighLevelClient; |
| | | |
| | | private LambdaQueryWrapper<ZfCollection> buildCondition(ZfCollection zfCollection,List<Long> familyIdList) { |
| | | LambdaQueryWrapper<ZfCollection> lqw = new LambdaQueryWrapper<>(); |
| | |
| | | } |
| | | |
| | | if (save(zfCollection)) { |
| | | |
| | | EsModel esModel = new EsModel(); |
| | | Integer inte = zfCollection.getId().intValue(); |
| | | String uuid = UUID.randomUUID().toString().replace("-",""); |
| | | esModel.setId(uuid); |
| | | esModel.setCtId(Long.valueOf(inte)); |
| | | esModel.setCtTableName("收藏和荣誉"); |
| | | esModel.setBy1(zfCollection.getType()); |
| | | esModel.setBy2(zfCollection.getName()); |
| | | esModel.setBy3(zfCollection.getSource()); |
| | | esModel.setBy4(zfCollection.getOwner()); |
| | | esModel.setBy5("/family/zfCollection"); |
| | | esModel.setBy6(zfCollection.getLocation()); |
| | | esModel.setRemark(zfCollection.getRemark()); |
| | | //这里存储查询详情的路径 |
| | | esService.insertTable(esModel); |
| | | |
| | | return AjaxResult.success(); |
| | | } else { |
| | | return AjaxResult.error(); |
| | |
| | | |
| | | if(updateById(zfCollection)){ |
| | | |
| | | //到数据库中查询对应的数据 |
| | | ZfCollection dataById = getById(zfCollection.getId()); |
| | | |
| | | //先到es中查询到对应那条数据在es的id |
| | | EsModel esResult = esService.findByCtId(dataById.getId().intValue(), "收藏和荣誉"); |
| | | |
| | | //操作es修改数据 |
| | | EsModel newModel = new EsModel(); |
| | | if(zfCollection.getType()!=null){ |
| | | newModel.setBy1(zfCollection.getType()); |
| | | }else { |
| | | newModel.setBy1(dataById.getType()); |
| | | } |
| | | |
| | | if(zfCollection.getName()!=null){ |
| | | newModel.setBy2(zfCollection.getName()); |
| | | }else { |
| | | newModel.setBy2(dataById.getName()); |
| | | } |
| | | |
| | | if(zfCollection.getSource()!=null){ |
| | | newModel.setBy3(zfCollection.getSource()); |
| | | }else { |
| | | newModel.setBy3(dataById.getSource()); |
| | | } |
| | | |
| | | if(zfCollection.getOwner()!=null){ |
| | | newModel.setBy4(zfCollection.getOwner()); |
| | | }else { |
| | | newModel.setBy4(dataById.getOwner()); |
| | | } |
| | | |
| | | if(zfCollection.getLocation()!=null){ |
| | | newModel.setBy6(zfCollection.getLocation()); |
| | | }else { |
| | | newModel.setBy6(dataById.getLocation()); |
| | | } |
| | | |
| | | if(zfCollection.getRemark()!=null){ |
| | | newModel.setRemark(zfCollection.getRemark()); |
| | | }else { |
| | | newModel.setRemark(dataById.getRemark()); |
| | | } |
| | | |
| | | |
| | | UpdateRequest updateRequest = new UpdateRequest("allsearchdata", esResult.getId()); |
| | | updateRequest.doc( |
| | | "by1",newModel.getBy1(), |
| | | "by2",newModel.getBy2(), |
| | | "by3",newModel.getBy3(), |
| | | "by4",newModel.getBy4(), |
| | | "by6",newModel.getBy6(), |
| | | "remark",newModel.getRemark() |
| | | ); |
| | | |
| | | try { |
| | | restHighLevelClient.update(updateRequest, RequestOptions.DEFAULT); |
| | | } catch (IOException e) { |
| | | throw new RuntimeException(e); |
| | | } |
| | | |
| | | return AjaxResult.success(); |
| | | }else { |
| | | return AjaxResult.error(); |
| | |
| | | } |
| | | } |
| | | |
| | | List<ZfCollection> zfCollections = listByIds(Arrays.asList(ids)); |
| | | |
| | | if (zfCollectionService.removeByIds(Arrays.asList(ids))) { |
| | | |
| | | //删除es中的数据 |
| | | zfCollections.stream().forEach(zfCollection -> { |
| | | EsModel esModel = esService.findByCtId(zfCollection.getId().intValue(), "收藏和荣誉"); |
| | | DeleteRequest deleteRequest = new DeleteRequest("allsearchdata", esModel.getId()); |
| | | try { |
| | | restHighLevelClient.delete(deleteRequest,RequestOptions.DEFAULT); |
| | | } catch (IOException e) { |
| | | throw new RuntimeException(e); |
| | | } |
| | | }); |
| | | return AjaxResult.success(); |
| | | }else { |
| | | return AjaxResult.error(); |