mirror of
				https://github.com/datahub-project/datahub.git
				synced 2025-10-31 02:37:05 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /**
 | |
|  * Copyright 2015 LinkedIn Corp. All rights reserved.
 | |
|  *
 | |
|  * Licensed under the Apache License, Version 2.0 (the "License");
 | |
|  * you may not use this file except in compliance with the License.
 | |
|  * You may obtain a copy of the License at
 | |
|  *
 | |
|  * http://www.apache.org/licenses/LICENSE-2.0
 | |
|  *
 | |
|  * Unless required by applicable law or agreed to in writing, software
 | |
|  * distributed under the License is distributed on an "AS IS" BASIS,
 | |
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
|  */
 | |
| package models.daos;
 | |
| 
 | |
| import java.util.ArrayList;
 | |
| import java.util.HashMap;
 | |
| import java.util.List;
 | |
| import java.util.Map;
 | |
| 
 | |
| import com.fasterxml.jackson.databind.node.ObjectNode;
 | |
| import org.apache.commons.lang3.StringUtils;
 | |
| 
 | |
| import play.libs.Json;
 | |
| import utils.JdbcUtil;
 | |
| 
 | |
| /**
 | |
|  * Created by nvemuri on 6/29/16.
 | |
|  * Modified by nvemuri on 6/29/16.
 | |
|  */
 | |
| public class UserDao {
 | |
| 
 | |
|   private final static String GET_USERS_WATCHED_DATASET =
 | |
|       "SELECT u.username AS username FROM users u JOIN watch w ON " +
 | |
|           "u.id = w.user_id JOIN dict_dataset d ON w.item_id = d.id " +
 | |
|           "WHERE d.name = :name AND w.item_type = 'dataset' ";
 | |
| 
 | |
|   public static ObjectNode getWatchers(String datasetName) {
 | |
|     List<String> watchUsers = new ArrayList<String>();
 | |
|     if (StringUtils.isNotBlank(datasetName)) {
 | |
|       Map<String, Object> params = new HashMap<>();
 | |
|       params.put("name", datasetName);
 | |
|       List<Map<String, Object>> rows = null;
 | |
|       rows = JdbcUtil.wherehowsNamedJdbcTemplate.queryForList(GET_USERS_WATCHED_DATASET, params);
 | |
|       for (Map row : rows) {
 | |
|         String userName = (String) row.get("username");
 | |
|         watchUsers.add(userName);
 | |
|       }
 | |
|     }
 | |
|     ObjectNode result = Json.newObject();
 | |
|     result.put("count", watchUsers.size());
 | |
|     result.set("users", Json.toJson(watchUsers));
 | |
|     return result;
 | |
|   }
 | |
| }
 | 
