diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/Application.java b/backend/bang-ggood/src/main/java/com/bang_ggood/Application.java index 537bca4d..d7d9cf6c 100644 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/Application.java +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/Application.java @@ -4,9 +4,11 @@ import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.context.annotation.EnableAspectJAutoProxy; import org.springframework.data.jpa.repository.config.EnableJpaAuditing; +import org.springframework.scheduling.annotation.EnableScheduling; @EnableJpaAuditing @EnableAspectJAutoProxy +@EnableScheduling @SpringBootApplication public class Application { diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/article/controller/ArticleController.java b/backend/bang-ggood/src/main/java/com/bang_ggood/article/controller/ArticleController.java index 171a5e4f..57bc89ce 100644 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/article/controller/ArticleController.java +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/article/controller/ArticleController.java @@ -1,52 +1,58 @@ package com.bang_ggood.article.controller; import com.bang_ggood.article.dto.request.ArticleCreateRequest; +import com.bang_ggood.article.dto.request.ArticleUpdateRequest; import com.bang_ggood.article.dto.response.ArticleResponse; import com.bang_ggood.article.dto.response.ArticlesResponses; -import com.bang_ggood.article.service.ArticleService; +import com.bang_ggood.article.service.ArticleManageService; import com.bang_ggood.auth.config.AdminPrincipal; -import com.bang_ggood.auth.config.AuthRequiredPrincipal; import com.bang_ggood.user.domain.User; import jakarta.validation.Valid; +import lombok.RequiredArgsConstructor; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.DeleteMapping; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.PutMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RestController; import java.net.URI; +@RequiredArgsConstructor @RestController public class ArticleController { - private final ArticleService articleService; - - public ArticleController(ArticleService articleService) { - this.articleService = articleService; - } + private final ArticleManageService articleManageService; @PostMapping("/articles") public ResponseEntity createArticle(@AdminPrincipal User user, @Valid @RequestBody ArticleCreateRequest request) { - Long id = articleService.createArticle(request); + Long id = articleManageService.createArticle(request); return ResponseEntity.created(URI.create("/article/" + id)).build(); } @GetMapping("/articles/{id}") public ResponseEntity readArticle(@PathVariable("id") Long id) { - return ResponseEntity.ok(articleService.readArticle(id)); + return ResponseEntity.ok(articleManageService.readArticle(id)); } @GetMapping("/articles") public ResponseEntity readArticles() { - return ResponseEntity.ok(articleService.readArticles()); + return ResponseEntity.ok(articleManageService.readArticles()); + } + + @PutMapping("/articles/{id}") + public ResponseEntity updateArticle(@AdminPrincipal User user, + @PathVariable("id") Long id, @Valid @RequestBody ArticleUpdateRequest request) { + articleManageService.updateArticle(id, request); + return ResponseEntity.noContent().build(); } @DeleteMapping("/articles/{id}") public ResponseEntity deleteArticle(@AdminPrincipal User user, @PathVariable("id") Long id) { - articleService.deleteArticle(id); + articleManageService.deleteArticle(id); return ResponseEntity.noContent().build(); } } diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/article/domain/Article.java b/backend/bang-ggood/src/main/java/com/bang_ggood/article/domain/Article.java index 988238da..1b00299c 100644 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/article/domain/Article.java +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/article/domain/Article.java @@ -30,12 +30,27 @@ public class Article extends BaseEntity { private String thumbnail; + private Long viewCount; + public Article(String title, String content, String keyword, String summary, String thumbnail) { this.title = title; this.content = content; this.keyword = keyword; this.summary = summary; this.thumbnail = thumbnail; + this.viewCount = 0L; + } + + public void increaseViewCount() { + viewCount++; + } + + public void change(Article article) { + this.title = article.title; + this.content = article.content; + this.keyword = article.keyword; + this.summary = article.summary; + this.thumbnail = article.thumbnail; } @Override diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/article/dto/request/ArticleUpdateRequest.java b/backend/bang-ggood/src/main/java/com/bang_ggood/article/dto/request/ArticleUpdateRequest.java new file mode 100644 index 00000000..ab9fd42a --- /dev/null +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/article/dto/request/ArticleUpdateRequest.java @@ -0,0 +1,12 @@ +package com.bang_ggood.article.dto.request; + +import com.bang_ggood.article.domain.Article; +import jakarta.validation.constraints.NotBlank; + +public record ArticleUpdateRequest(@NotBlank(message = "제목을 입력해야 합니다.") String title, String content, String keyword, + String summary, String thumbnail) { + + public Article toEntity() { + return new Article(title, content, keyword, summary, thumbnail); + } +} diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/article/dto/response/ArticleResponse.java b/backend/bang-ggood/src/main/java/com/bang_ggood/article/dto/response/ArticleResponse.java index 3aded2c3..f04f6f18 100644 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/article/dto/response/ArticleResponse.java +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/article/dto/response/ArticleResponse.java @@ -4,7 +4,7 @@ import java.time.LocalDateTime; public record ArticleResponse(Long articleId, String title, String content, String keyword, String summary, - String thumbnail, LocalDateTime createdAt) { + String thumbnail, LocalDateTime createdAt, Long viewCount) { public static ArticleResponse from(Article article) { return new ArticleResponse( @@ -14,7 +14,8 @@ public static ArticleResponse from(Article article) { article.getKeyword(), article.getSummary(), article.getThumbnail(), - article.getCreatedAt() + article.getCreatedAt(), + article.getViewCount() ); } } diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/article/repository/ArticleRepository.java b/backend/bang-ggood/src/main/java/com/bang_ggood/article/repository/ArticleRepository.java index eee97d7a..291b6ff9 100644 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/article/repository/ArticleRepository.java +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/article/repository/ArticleRepository.java @@ -7,6 +7,7 @@ import org.springframework.data.jpa.repository.Modifying; import org.springframework.data.jpa.repository.Query; import org.springframework.data.repository.query.Param; +import org.springframework.transaction.annotation.Transactional; import java.util.List; import java.util.Optional; @@ -31,4 +32,11 @@ default Article getById(Long id) { "SET a.deleted = true " + "WHERE a.id = :id") void deleteById(@Param("id") Long id); + + @Transactional + @Modifying(clearAutomatically = true, flushAutomatically = true) + @Query("UPDATE Article a " + + "SET a.viewCount = :viewCount " + + "WHERE a.id = :id") + void updateViewCount(@Param("id") long id, @Param("viewCount") Long viewCount); } diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/article/service/ArticleManageService.java b/backend/bang-ggood/src/main/java/com/bang_ggood/article/service/ArticleManageService.java new file mode 100644 index 00000000..22b083da --- /dev/null +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/article/service/ArticleManageService.java @@ -0,0 +1,53 @@ +package com.bang_ggood.article.service; + +import com.bang_ggood.article.domain.Article; +import com.bang_ggood.article.dto.request.ArticleCreateRequest; +import com.bang_ggood.article.dto.request.ArticleUpdateRequest; +import com.bang_ggood.article.dto.response.ArticleResponse; +import com.bang_ggood.article.dto.response.ArticlesResponse; +import com.bang_ggood.article.dto.response.ArticlesResponses; +import lombok.RequiredArgsConstructor; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; +import java.util.List; + +@RequiredArgsConstructor +@Service +public class ArticleManageService { + + private final ArticleService articleService; + private final ArticleViewService articleViewService; + + @Transactional + public Long createArticle(ArticleCreateRequest request) { + Article article = request.toEntity(); + return articleService.createArticle(article); + } + + @Transactional(readOnly = true) + public ArticleResponse readArticle(Long id) { + Article article = articleService.readArticle(id); + articleViewService.increaseViewCount(id); + return ArticleResponse.from(article); + } + + @Transactional(readOnly = true) + public ArticlesResponses readArticles() { + List articles = articleService.readArticles().stream() + .map(ArticlesResponse::from) + .toList(); + return new ArticlesResponses(articles); + } + + @Transactional + public void updateArticle(Long id, ArticleUpdateRequest request) { + articleViewService.syncViewCounts(); + articleService.updateArticle(id, request.toEntity()); + } + + @Transactional + public void deleteArticle(Long id) { + articleViewService.syncViewCounts(); + articleService.deleteArticle(id); + } +} diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/article/service/ArticleService.java b/backend/bang-ggood/src/main/java/com/bang_ggood/article/service/ArticleService.java index b9761998..ceff0185 100644 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/article/service/ArticleService.java +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/article/service/ArticleService.java @@ -1,13 +1,10 @@ package com.bang_ggood.article.service; import com.bang_ggood.article.domain.Article; -import com.bang_ggood.article.dto.request.ArticleCreateRequest; -import com.bang_ggood.article.dto.response.ArticleResponse; -import com.bang_ggood.article.dto.response.ArticlesResponse; -import com.bang_ggood.article.dto.response.ArticlesResponses; import com.bang_ggood.article.repository.ArticleRepository; import lombok.RequiredArgsConstructor; import org.springframework.cache.annotation.CacheEvict; +import org.springframework.cache.annotation.CachePut; import org.springframework.cache.annotation.Cacheable; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -22,25 +19,27 @@ public class ArticleService { private final ArticleRepository articleRepository; @Transactional - public long createArticle(ArticleCreateRequest request) { - Article article = request.toEntity(); + public long createArticle(Article article) { articleRepository.save(article); return article.getId(); } @Cacheable(cacheNames = ARTICLE, key = "#id") @Transactional(readOnly = true) - public ArticleResponse readArticle(Long id) { - Article article = articleRepository.getById(id); - return ArticleResponse.from(article); + public Article readArticle(Long id) { + return articleRepository.getById(id); } @Transactional(readOnly = true) - public ArticlesResponses readArticles() { - List articles = articleRepository.findLatestArticles().stream() - .map(ArticlesResponse::from) - .toList(); - return new ArticlesResponses(articles); + public List
readArticles() { + return articleRepository.findLatestArticles(); + } + + @CachePut(cacheNames = ARTICLE, key = "#id") + @Transactional + public void updateArticle(Long id, Article updateArticle) { + Article article = articleRepository.getById(id); + article.change(updateArticle); } @CacheEvict(cacheNames = ARTICLE, key = "#id") diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/article/service/ArticleViewService.java b/backend/bang-ggood/src/main/java/com/bang_ggood/article/service/ArticleViewService.java new file mode 100644 index 00000000..1c4a620c --- /dev/null +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/article/service/ArticleViewService.java @@ -0,0 +1,56 @@ +package com.bang_ggood.article.service; + +import com.bang_ggood.article.domain.Article; +import com.bang_ggood.article.repository.ArticleRepository; +import lombok.RequiredArgsConstructor; +import org.springframework.cache.Cache; +import org.springframework.cache.CacheManager; +import org.springframework.scheduling.annotation.Scheduled; +import org.springframework.stereotype.Service; +import java.util.HashSet; +import java.util.Objects; +import java.util.Set; + +import static com.bang_ggood.global.config.cache.CacheName.ARTICLE; + +@RequiredArgsConstructor +@Service +public class ArticleViewService { + + private final CacheManager cacheManager; + private final ArticleRepository articleRepository; + private final Set cacheArticleIds = new HashSet<>(); + + public void increaseViewCount(long id) { + Cache cache = cacheManager.getCache(ARTICLE); + if (cache != null) { + handleViewCount(id, cache); + } + } + + private void handleViewCount(long id, Cache cache) { + Article article = cache.get(id, Article.class); + if (article != null) { + article.increaseViewCount(); + cache.put(id, article); + cacheArticleIds.add(id); + } + } + + @Scheduled(cron = "0 0 0 * * ?") + public void syncViewCounts() { + Cache cache = cacheManager.getCache(ARTICLE); + if (cache != null) { + syncAllArticleViewCounts(cache); + cache.clear(); + cacheArticleIds.clear(); + } + } + + private void syncAllArticleViewCounts(Cache cache) { + cacheArticleIds.stream() + .map(id -> cache.get(id, Article.class)) + .filter(Objects::nonNull) + .forEach(article -> articleRepository.updateViewCount(article.getId(), article.getViewCount())); + } +} diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/controller/ChecklistController.java b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/controller/ChecklistController.java index b826f1e2..6d2ee5c3 100644 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/controller/ChecklistController.java +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/controller/ChecklistController.java @@ -3,12 +3,9 @@ import com.bang_ggood.auth.config.AuthRequiredPrincipal; import com.bang_ggood.auth.config.UserPrincipal; import com.bang_ggood.checklist.dto.request.ChecklistRequest; -import com.bang_ggood.checklist.dto.request.ChecklistRequestV1; -import com.bang_ggood.checklist.dto.response.ChecklistCompareResponsesV1; +import com.bang_ggood.checklist.dto.response.ChecklistCompareResponses; import com.bang_ggood.checklist.dto.response.ChecklistsPreviewResponse; -import com.bang_ggood.checklist.dto.response.ChecklistsPreviewResponseV1; import com.bang_ggood.checklist.dto.response.SelectedChecklistResponse; -import com.bang_ggood.checklist.dto.response.SelectedChecklistResponseV1; import com.bang_ggood.checklist.service.ChecklistManageService; import com.bang_ggood.user.domain.User; import jakarta.validation.Valid; @@ -31,73 +28,41 @@ public class ChecklistController { private final ChecklistManageService checklistManageService; - @PostMapping("/checklists") - public ResponseEntity createChecklist(@AuthRequiredPrincipal User user, - @Valid @RequestBody ChecklistRequest checklistRequest) { - long checklistId = checklistManageService.createChecklist(user, checklistRequest); - return ResponseEntity.created(URI.create("/checklist/" + checklistId)).build(); - } - @PostMapping("/v1/checklists") public ResponseEntity createChecklistV1(@AuthRequiredPrincipal User user, - @Valid @RequestBody ChecklistRequestV1 checklistRequestV1) { - long checklistId = checklistManageService.createChecklistV1(user, checklistRequestV1); + @Valid @RequestBody ChecklistRequest checklistRequest) { + long checklistId = checklistManageService.createChecklist(user, checklistRequest); return ResponseEntity.created(URI.create("/checklist/" + checklistId)).build(); } - @GetMapping("/checklists/{id}") - public ResponseEntity readChecklistById(@UserPrincipal User user, - @PathVariable("id") Long checklistId) { - return ResponseEntity.ok(checklistManageService.readChecklist(user, checklistId)); - } - @GetMapping("v1/checklists/{id}") - public ResponseEntity readChecklistByIdV1(@UserPrincipal User user, - @PathVariable("id") Long checklistId) { - return ResponseEntity.ok(checklistManageService.readChecklistV1(user, checklistId)); - } - - @GetMapping("/checklists") - public ResponseEntity readChecklistsPreview(@UserPrincipal User user) { - return ResponseEntity.ok(checklistManageService.readAllChecklistsPreview(user)); + public ResponseEntity readChecklistByIdV1(@UserPrincipal User user, + @PathVariable("id") Long checklistId) { + return ResponseEntity.ok(checklistManageService.readChecklist(user, checklistId)); } @GetMapping("/v1/checklists") - public ResponseEntity readChecklistsPreviewV1(@UserPrincipal User user) { - return ResponseEntity.ok(checklistManageService.readAllChecklistsPreviewV1(user)); - } - - @GetMapping("/checklists/like") - public ResponseEntity readLikedChecklistsPreview(@AuthRequiredPrincipal User user) { - return ResponseEntity.ok(checklistManageService.readLikedChecklistsPreview(user)); + public ResponseEntity readChecklistsPreviewV1(@UserPrincipal User user) { + return ResponseEntity.ok(checklistManageService.readAllChecklistsPreview(user)); } @GetMapping("/v1/checklists/like") - public ResponseEntity readLikedChecklistsPreviewV1(@AuthRequiredPrincipal User user) { - return ResponseEntity.ok(checklistManageService.readLikedChecklistsPreviewV1(user)); + public ResponseEntity readLikedChecklistsPreviewV1(@AuthRequiredPrincipal User user) { + return ResponseEntity.ok(checklistManageService.readLikedChecklistsPreview(user)); } @GetMapping("/v1/checklists/comparison") - public ResponseEntity readChecklistsCompare(@AuthRequiredPrincipal User user, - @RequestParam("id") List checklistIds) { + public ResponseEntity readChecklistsCompare(@AuthRequiredPrincipal User user, + @RequestParam("id") List checklistIds) { return ResponseEntity.ok(checklistManageService.compareChecklists(user, checklistIds)); } - @PutMapping("/checklists/{id}") - public ResponseEntity updateChecklistById( - @AuthRequiredPrincipal User user, - @PathVariable("id") long id, - @Valid @RequestBody ChecklistRequest checklistRequest) { - checklistManageService.updateChecklistById(user, id, checklistRequest); - return ResponseEntity.noContent().build(); - } - @PutMapping("/v1/checklists/{id}") public ResponseEntity updateChecklistByIdV1( @AuthRequiredPrincipal User user, @PathVariable("id") long id, - @Valid @RequestBody ChecklistRequestV1 checklistRequestV1) { - checklistManageService.updateChecklistByIdV1(user, id, checklistRequestV1); + @Valid @RequestBody ChecklistRequest checklistRequest) { + checklistManageService.updateChecklistById(user, id, checklistRequest); return ResponseEntity.noContent().build(); } diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/request/ChecklistRequestV1.java b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/request/ChecklistRequestV1.java deleted file mode 100644 index 9f243fdb..00000000 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/request/ChecklistRequestV1.java +++ /dev/null @@ -1,14 +0,0 @@ -package com.bang_ggood.checklist.dto.request; - -import com.bang_ggood.question.dto.request.QuestionRequest; -import com.bang_ggood.room.dto.request.RoomRequest; -import jakarta.validation.Valid; -import java.util.List; - -public record ChecklistRequestV1(@Valid RoomRequest room, List options, - @Valid List questions) { - - public ChecklistRequest toChecklistRequest() { - return new ChecklistRequest(room, options, questions); - } -} diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistCompareResponseV1.java b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistCompareResponse.java similarity index 84% rename from backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistCompareResponseV1.java rename to backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistCompareResponse.java index 126f8c53..9ac0d830 100644 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistCompareResponseV1.java +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistCompareResponse.java @@ -3,14 +3,14 @@ import com.bang_ggood.checklist.domain.Checklist; import com.bang_ggood.maintenance.domain.ChecklistMaintenance; import com.bang_ggood.option.domain.ChecklistOption; -import com.bang_ggood.question.dto.response.CategoryScoreResponsesV1; +import com.bang_ggood.question.dto.response.CategoryScoreResponses; import com.bang_ggood.station.domain.ChecklistStation; import com.bang_ggood.station.dto.response.SubwayStationResponse; import com.bang_ggood.station.dto.response.SubwayStationResponses; import java.time.LocalDateTime; import java.util.List; -public record ChecklistCompareResponseV1( +public record ChecklistCompareResponse( Long checklistId, String roomName, String address, String buildingName, Double latitude, Double longitude, List options, String structure, Double size, @@ -20,13 +20,13 @@ public record ChecklistCompareResponseV1( Integer maintenanceFee, List includedMaintenances, Integer contractTerm, Integer occupancyMonth, String occupancyPeriod, String realEstate, LocalDateTime createdAt, - CategoryScoreResponsesV1 categories + CategoryScoreResponses categories ) { - public static ChecklistCompareResponseV1 of(Checklist checklist, List options, - List stations, - List maintenances, - CategoryScoreResponsesV1 categories) { - return new ChecklistCompareResponseV1( + public static ChecklistCompareResponse of(Checklist checklist, List options, + List stations, + List maintenances, + CategoryScoreResponses categories) { + return new ChecklistCompareResponse( checklist.getId(), checklist.getRoomName(), checklist.getRoomAddress(), checklist.getRoomBuildingName(), checklist.getRoomLatitude(), checklist.getRoomLongitude(), convertToOptionIds(options), checklist.getRoomStructure().getName(), checklist.getRoomSize(), diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistCompareResponses.java b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistCompareResponses.java new file mode 100644 index 00000000..b520b09e --- /dev/null +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistCompareResponses.java @@ -0,0 +1,6 @@ +package com.bang_ggood.checklist.dto.response; + +import java.util.List; + +public record ChecklistCompareResponses(List checklists) { +} diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistCompareResponsesV1.java b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistCompareResponsesV1.java deleted file mode 100644 index cc69f5c5..00000000 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistCompareResponsesV1.java +++ /dev/null @@ -1,6 +0,0 @@ -package com.bang_ggood.checklist.dto.response; - -import java.util.List; - -public record ChecklistCompareResponsesV1(List checklists) { -} diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistPreviewResponse.java b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistPreviewResponse.java index c7e71d9f..bf684876 100644 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistPreviewResponse.java +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistPreviewResponse.java @@ -1,21 +1,22 @@ package com.bang_ggood.checklist.dto.response; import com.bang_ggood.checklist.domain.Checklist; +import com.bang_ggood.station.dto.response.SubwayStationResponse; import java.time.LocalDateTime; public record ChecklistPreviewResponse( Long checklistId, String roomName, String address, String buildingName, - String station, Integer walkingTime, + SubwayStationResponse station, Integer walkingTime, Integer deposit, Integer rent, LocalDateTime createdAt, String summary, boolean isLiked) { - public static ChecklistPreviewResponse of(Checklist checklist, boolean isLiked) { + public static ChecklistPreviewResponse of(Checklist checklist, SubwayStationResponse station, boolean isLiked) { return new ChecklistPreviewResponse( checklist.getId(), checklist.getRoomName(), checklist.getRoomAddress(), checklist.getRoomBuildingName(), - checklist.getRoomStation(), + station, checklist.getRoomWalkingTime(), checklist.getDeposit(), checklist.getRent(), diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistPreviewResponseV1.java b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistPreviewResponseV1.java deleted file mode 100644 index 1803003d..00000000 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistPreviewResponseV1.java +++ /dev/null @@ -1,27 +0,0 @@ -package com.bang_ggood.checklist.dto.response; - -import com.bang_ggood.checklist.domain.Checklist; -import com.bang_ggood.station.dto.response.SubwayStationResponse; -import java.time.LocalDateTime; - -public record ChecklistPreviewResponseV1( - Long checklistId, String roomName, String address, String buildingName, - SubwayStationResponse station, Integer walkingTime, - Integer deposit, Integer rent, LocalDateTime createdAt, - String summary, boolean isLiked) { - - public static ChecklistPreviewResponseV1 of(Checklist checklist, SubwayStationResponse station, boolean isLiked) { - return new ChecklistPreviewResponseV1( - checklist.getId(), - checklist.getRoomName(), - checklist.getRoomAddress(), - checklist.getRoomBuildingName(), - station, - checklist.getRoomWalkingTime(), - checklist.getDeposit(), - checklist.getRent(), - checklist.getCreatedAt(), - checklist.getSummary(), - isLiked); - } -} diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistsPreviewResponseV1.java b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistsPreviewResponseV1.java deleted file mode 100644 index d736420c..00000000 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/ChecklistsPreviewResponseV1.java +++ /dev/null @@ -1,10 +0,0 @@ -package com.bang_ggood.checklist.dto.response; - -import java.util.List; - -public record ChecklistsPreviewResponseV1(List checklists) { - - public static ChecklistsPreviewResponseV1 from(List checklists) { - return new ChecklistsPreviewResponseV1(checklists); - } -} diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/SelectedChecklistResponse.java b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/SelectedChecklistResponse.java index bc26a058..8f6b48ee 100644 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/SelectedChecklistResponse.java +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/SelectedChecklistResponse.java @@ -3,14 +3,21 @@ import com.bang_ggood.option.dto.response.SelectedOptionResponse; import com.bang_ggood.question.dto.response.SelectedCategoryQuestionsResponse; import com.bang_ggood.room.dto.response.SelectedRoomResponse; +import com.bang_ggood.room.dto.response.SelectedRoomResponseV1; +import com.bang_ggood.station.dto.response.SubwayStationResponse; +import com.bang_ggood.station.dto.response.SubwayStationResponses; import java.util.List; -public record SelectedChecklistResponse(SelectedRoomResponse room, +public record SelectedChecklistResponse(SelectedRoomResponseV1 room, List options, List categories, - boolean isLiked) { + boolean isLiked, + List stations) { + public static SelectedChecklistResponse of(SelectedRoomResponse room, List options, - List categories, boolean isLiked) { - return new SelectedChecklistResponse(room, options, categories, isLiked); + List categories, boolean isLiked, + SubwayStationResponses stations) { + return new SelectedChecklistResponse(SelectedRoomResponseV1.from(room), options, categories, isLiked, + stations.getStations()); } } diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/SelectedChecklistResponseV1.java b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/SelectedChecklistResponseV1.java deleted file mode 100644 index 4f2ba0a4..00000000 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/dto/response/SelectedChecklistResponseV1.java +++ /dev/null @@ -1,23 +0,0 @@ -package com.bang_ggood.checklist.dto.response; - -import com.bang_ggood.option.dto.response.SelectedOptionResponse; -import com.bang_ggood.question.dto.response.SelectedCategoryQuestionsResponse; -import com.bang_ggood.room.dto.response.SelectedRoomResponse; -import com.bang_ggood.room.dto.response.SelectedRoomResponseV1; -import com.bang_ggood.station.dto.response.SubwayStationResponse; -import com.bang_ggood.station.dto.response.SubwayStationResponses; -import java.util.List; - -public record SelectedChecklistResponseV1(SelectedRoomResponseV1 room, - List options, - List categories, - boolean isLiked, - List stations) { - - public static SelectedChecklistResponseV1 of(SelectedRoomResponse room, List options, - List categories, boolean isLiked, - SubwayStationResponses stations) { - return new SelectedChecklistResponseV1(SelectedRoomResponseV1.from(room), options, categories, isLiked, - stations.getStations()); - } -} diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/service/ChecklistManageService.java b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/service/ChecklistManageService.java index 42005e47..dd632f36 100644 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/service/ChecklistManageService.java +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/checklist/service/ChecklistManageService.java @@ -2,15 +2,11 @@ import com.bang_ggood.checklist.domain.Checklist; import com.bang_ggood.checklist.dto.request.ChecklistRequest; -import com.bang_ggood.checklist.dto.request.ChecklistRequestV1; -import com.bang_ggood.checklist.dto.response.ChecklistCompareResponseV1; -import com.bang_ggood.checklist.dto.response.ChecklistCompareResponsesV1; +import com.bang_ggood.checklist.dto.response.ChecklistCompareResponse; +import com.bang_ggood.checklist.dto.response.ChecklistCompareResponses; import com.bang_ggood.checklist.dto.response.ChecklistPreviewResponse; -import com.bang_ggood.checklist.dto.response.ChecklistPreviewResponseV1; import com.bang_ggood.checklist.dto.response.ChecklistsPreviewResponse; -import com.bang_ggood.checklist.dto.response.ChecklistsPreviewResponseV1; import com.bang_ggood.checklist.dto.response.SelectedChecklistResponse; -import com.bang_ggood.checklist.dto.response.SelectedChecklistResponseV1; import com.bang_ggood.global.exception.BangggoodException; import com.bang_ggood.global.exception.ExceptionCode; import com.bang_ggood.like.service.ChecklistLikeService; @@ -23,8 +19,8 @@ import com.bang_ggood.question.domain.Answer; import com.bang_ggood.question.domain.Category; import com.bang_ggood.question.domain.ChecklistQuestion; -import com.bang_ggood.question.dto.response.CategoryScoreResponseV1; -import com.bang_ggood.question.dto.response.CategoryScoreResponsesV1; +import com.bang_ggood.question.dto.response.CategoryScoreResponse; +import com.bang_ggood.question.dto.response.CategoryScoreResponses; import com.bang_ggood.question.dto.response.SelectedCategoryQuestionsResponse; import com.bang_ggood.question.dto.response.SelectedQuestionResponse; import com.bang_ggood.question.service.ChecklistQuestionService; @@ -66,19 +62,7 @@ public Long createChecklist(User user, ChecklistRequest checklistRequest) { createChecklistOptions(checklistRequest, checklist); createChecklistQuestions(checklistRequest, checklist); createChecklistMaintenances(checklistRequest, checklist); - return checklist.getId(); - } - - @Transactional - public Long createChecklistV1(User user, ChecklistRequestV1 checklistRequestV1) { - ChecklistRequest checklistRequest = checklistRequestV1.toChecklistRequest(); - - Room room = roomService.createRoom(checklistRequest.toRoomEntity()); - Checklist checklist = checklistService.createChecklist(checklistRequest.toChecklistEntity(room, user)); - createChecklistOptions(checklistRequest, checklist); - createChecklistQuestions(checklistRequest, checklist); - createChecklistMaintenances(checklistRequest, checklist); - createChecklistStation(checklistRequestV1.room(), checklist); + createChecklistStation(checklistRequest.room(), checklist); return checklist.getId(); } @@ -116,19 +100,6 @@ private void createChecklistStation(RoomRequest roomRequest, Checklist checklist public SelectedChecklistResponse readChecklist(User user, Long checklistId) { Checklist checklist = checklistService.readChecklist(user, checklistId); - List maintenances = readChecklistMaintenances(checklist); - List options = readChecklistOptions(checklist); - List questions = readChecklistQuestions(checklist); - SelectedRoomResponse room = SelectedRoomResponse.of(checklist, maintenances); - boolean isLiked = checklistLikeService.isLikedChecklist(checklist); - - return SelectedChecklistResponse.of(room, options, questions, isLiked); - } - - @Transactional(readOnly = true) - public SelectedChecklistResponseV1 readChecklistV1(User user, Long checklistId) { - Checklist checklist = checklistService.readChecklist(user, checklistId); - List maintenances = readChecklistMaintenances(checklist); List options = readChecklistOptions(checklist); List questions = readChecklistQuestions(checklist); @@ -136,7 +107,7 @@ public SelectedChecklistResponseV1 readChecklistV1(User user, Long checklistId) boolean isLiked = checklistLikeService.isLikedChecklist(checklist); SubwayStationResponses stations = readChecklistStations(checklist); - return SelectedChecklistResponseV1.of(room, options, questions, isLiked, stations); + return SelectedChecklistResponse.of(room, options, questions, isLiked, stations); } private List readChecklistMaintenances(Checklist checklist) { @@ -186,33 +157,19 @@ private SubwayStationResponses readChecklistStations(Checklist checklist) { @Transactional(readOnly = true) public ChecklistsPreviewResponse readLikedChecklistsPreview(User user) { List likedChecklists = checklistService.readLikedChecklistsPreview(user); - List responses = mapToChecklistPreviewResponses( - likedChecklists); - return ChecklistsPreviewResponse.from(responses); - } - - private List mapToChecklistPreviewResponses(List likedChecklists) { - return likedChecklists.stream() - .map(checklist -> ChecklistPreviewResponse.of(checklist, true)) - .toList(); - } - - @Transactional(readOnly = true) - public ChecklistsPreviewResponseV1 readLikedChecklistsPreviewV1(User user) { - List likedChecklists = checklistService.readLikedChecklistsPreview(user); - List responses = likedChecklists.stream() - .map(this::mapToChecklistPreviewV1) + List responses = likedChecklists.stream() + .map(this::mapToChecklistPreview) .toList(); - return ChecklistsPreviewResponseV1.from(responses); + return ChecklistsPreviewResponse.from(responses); } @Transactional(readOnly = true) - public ChecklistCompareResponsesV1 compareChecklists(User user, List checklistIds) { + public ChecklistCompareResponses compareChecklists(User user, List checklistIds) { validateChecklistCompareCount(checklistIds); - List checklistCompareResponses = checklistIds.stream() + List checklistCompareResponses = checklistIds.stream() .map(checklistId -> compareChecklist(user, checklistId)) .toList(); - return new ChecklistCompareResponsesV1(checklistCompareResponses); + return new ChecklistCompareResponses(checklistCompareResponses); } private void validateChecklistCompareCount(List checklistIds) { @@ -221,24 +178,24 @@ private void validateChecklistCompareCount(List checklistIds) { } } - private ChecklistCompareResponseV1 compareChecklist(User user, Long checklistId) { + private ChecklistCompareResponse compareChecklist(User user, Long checklistId) { Checklist checklist = checklistService.readChecklist(user, checklistId); List options = checklistOptionService.readChecklistOptions(checklist); List checklistStations = checklistStationService.readChecklistStationsByChecklist(checklist); List maintenances = checklistMaintenanceService.readChecklistMaintenances(checklist); - CategoryScoreResponsesV1 categoryScoreResponses = compareCategories(user, checklistId); - return ChecklistCompareResponseV1.of(checklist, options, checklistStations, maintenances, + CategoryScoreResponses categoryScoreResponses = compareCategories(user, checklistId); + return ChecklistCompareResponse.of(checklist, options, checklistStations, maintenances, categoryScoreResponses); } - private CategoryScoreResponsesV1 compareCategories(User user, Long checklistId) { - List categoryScoreResponses = new ArrayList<>(); + private CategoryScoreResponses compareCategories(User user, Long checklistId) { + List categoryScoreResponses = new ArrayList<>(); List categories = checklistQuestionService.findCategories(user, checklistId); for (Category category : categories) { Integer score = checklistQuestionService.calculateCategoryScore(checklistId, category.getId()); - categoryScoreResponses.add(new CategoryScoreResponseV1(category.getId(), category.getName(), score)); + categoryScoreResponses.add(new CategoryScoreResponse(category.getId(), category.getName(), score)); } - return new CategoryScoreResponsesV1(categoryScoreResponses); + return new CategoryScoreResponses(categoryScoreResponses); } @Transactional @@ -256,32 +213,17 @@ public void deleteChecklistById(User user, Long id) { @Transactional(readOnly = true) public ChecklistsPreviewResponse readAllChecklistsPreview(User user) { List checklists = checklistService.readAllChecklistsOrderByLatest(user); - List responses = checklists.stream() .map(this::mapToChecklistPreview) .toList(); + return ChecklistsPreviewResponse.from(responses); } private ChecklistPreviewResponse mapToChecklistPreview(Checklist checklist) { - boolean isLiked = checklistLikeService.isLikedChecklist(checklist); - return ChecklistPreviewResponse.of(checklist, isLiked); - } - - @Transactional(readOnly = true) - public ChecklistsPreviewResponseV1 readAllChecklistsPreviewV1(User user) { - List checklists = checklistService.readAllChecklistsOrderByLatest(user); - List responses = checklists.stream() - .map(this::mapToChecklistPreviewV1) - .toList(); - - return ChecklistsPreviewResponseV1.from(responses); - } - - private ChecklistPreviewResponseV1 mapToChecklistPreviewV1(Checklist checklist) { boolean isLiked = checklistLikeService.isLikedChecklist(checklist); SubwayStationResponse stationResponse = readNearestStation(checklist); - return ChecklistPreviewResponseV1.of(checklist, stationResponse, isLiked); + return ChecklistPreviewResponse.of(checklist, stationResponse, isLiked); } private SubwayStationResponse readNearestStation(Checklist checklist) { @@ -304,20 +246,7 @@ public void updateChecklistById(User user, Long checklistId, ChecklistRequest ch updateChecklistOptions(checklistRequest, checklist); updateChecklistQuestions(checklistRequest, checklist); updateChecklistMaintenances(checklistRequest, checklist); - } - - @Transactional - public void updateChecklistByIdV1(User user, Long checklistId, ChecklistRequestV1 checklistRequestV1) { - Checklist checklist = checklistService.readChecklist(user, checklistId); - - ChecklistRequest checklistRequest = checklistRequestV1.toChecklistRequest(); - roomService.updateRoom(checklist.getRoom(), checklistRequest.toRoomEntity()); - checklistService.updateChecklist(checklist, checklistRequest.toChecklistEntity(checklist.getRoom(), user)); - - updateChecklistOptions(checklistRequest, checklist); - updateChecklistQuestions(checklistRequest, checklist); - updateChecklistMaintenances(checklistRequest, checklist); - updateChecklistStations(checklistRequestV1.room(), checklist); + updateChecklistStations(checklistRequest.room(), checklist); } private void updateChecklistOptions(ChecklistRequest checklistRequest, Checklist checklist) { diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/question/dto/response/CategoryScoreResponse.java b/backend/bang-ggood/src/main/java/com/bang_ggood/question/dto/response/CategoryScoreResponse.java new file mode 100644 index 00000000..ef7c3d09 --- /dev/null +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/question/dto/response/CategoryScoreResponse.java @@ -0,0 +1,4 @@ +package com.bang_ggood.question.dto.response; + +public record CategoryScoreResponse(Integer categoryId, String categoryName, Integer score) { +} diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/question/dto/response/CategoryScoreResponseV1.java b/backend/bang-ggood/src/main/java/com/bang_ggood/question/dto/response/CategoryScoreResponseV1.java deleted file mode 100644 index 7f3328e6..00000000 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/question/dto/response/CategoryScoreResponseV1.java +++ /dev/null @@ -1,4 +0,0 @@ -package com.bang_ggood.question.dto.response; - -public record CategoryScoreResponseV1(Integer categoryId, String categoryName, Integer score) { -} diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/question/dto/response/CategoryScoreResponses.java b/backend/bang-ggood/src/main/java/com/bang_ggood/question/dto/response/CategoryScoreResponses.java new file mode 100644 index 00000000..70f46dd0 --- /dev/null +++ b/backend/bang-ggood/src/main/java/com/bang_ggood/question/dto/response/CategoryScoreResponses.java @@ -0,0 +1,6 @@ +package com.bang_ggood.question.dto.response; + +import java.util.List; + +public record CategoryScoreResponses(List categories) { +} diff --git a/backend/bang-ggood/src/main/java/com/bang_ggood/question/dto/response/CategoryScoreResponsesV1.java b/backend/bang-ggood/src/main/java/com/bang_ggood/question/dto/response/CategoryScoreResponsesV1.java deleted file mode 100644 index a23664ec..00000000 --- a/backend/bang-ggood/src/main/java/com/bang_ggood/question/dto/response/CategoryScoreResponsesV1.java +++ /dev/null @@ -1,6 +0,0 @@ -package com.bang_ggood.question.dto.response; - -import java.util.List; - -public record CategoryScoreResponsesV1(List categories) { -} diff --git a/backend/bang-ggood/src/main/resources/schema.sql b/backend/bang-ggood/src/main/resources/schema.sql index e752ffc1..5b8cde5f 100644 --- a/backend/bang-ggood/src/main/resources/schema.sql +++ b/backend/bang-ggood/src/main/resources/schema.sql @@ -159,6 +159,7 @@ CREATE TABLE article keyword VARCHAR(255), summary VARCHAR(255), thumbnail VARCHAR(2500), + view_count BIGINT default 0, created_at TIMESTAMP(6), modified_at TIMESTAMP(6), deleted BOOLEAN diff --git a/backend/bang-ggood/src/main/resources/seoul_stations_241218.csv b/backend/bang-ggood/src/main/resources/seoul_stations_241218.csv new file mode 100644 index 00000000..2e76bf81 --- /dev/null +++ b/backend/bang-ggood/src/main/resources/seoul_stations_241218.csv @@ -0,0 +1,767 @@ +_ID,,ȣ,,浵 +4703,4.19ֹ,̽ż,37.649502,127.013684 +1907,,1ȣ,37.748577,127.044213 +340,,3ȣ,37.492245,127.117757 +2818,,8ȣ,37.492888,127.118398 +2748,д,7ȣ,37.480338,126.882656 +1702,д,1ȣ,37.481581,126.882581 +4107,,9ȣ,37.561391,126.854456 +4704,,̽ż,37.641537,127.016789 +3216,,õ2ȣ,37.484192,126.683673 +3211,(Ƽ),õ2ȣ,37.524649,126.675539 +3212,߾ӽ,õ2ȣ,37.517054,126.676672 +1265,,߾Ӽ,37.568491,126.915487 +1851,õ,κд缱,37.448605,127.126697 +1323,,ἱ,37.814536,127.510739 +1816,,1ȣ,37.464737,126.694181 +3123,Ÿ,õ1ȣ,37.467048,126.707938 +1312,,ἱ,37.634118,127.114757 +3117,,õ1ȣ,37.517268,126.721514 +222,,2ȣ,37.49799,127.027912 +4307,,źд缱,37.496837,127.028104 +2732,û,7ȣ,37.517179,127.041255 +1849,û,κд缱,37.517469,127.041151 +4502,,ο,37.270161,127.126033 +2549,,5ȣ,37.535804,127.132481 +2813,û,8ȣ,37.530341,127.120508 +1269,,߾Ӽ,37.612314,126.843223 +214,(͹̳),2ȣ,37.535095,127.094681 +9995,,5ȣ,37.55749,127.17593 +1326,,ἱ,37.805723,127.634146 +2559,,5ȣ,37.498079,127.13482 +1801,,1ȣ,37.494594,126.85968 +1027,,κд缱,37.489116,127.06614 +4101,ȭ,9ȣ,37.578608,126.798153 +2512,ȭ,5ȣ,37.572399,126.806171 +2560,ſ,5ȣ,37.493105,127.14415 +212,ǴԱ,2ȣ,37.540373,127.069191 +2729,ǴԱ,7ȣ,37.540786,127.071011 +4925,Ϻ,,37.63165,126.705975 +3203,˴ܻŸ,õ2ȣ,37.60185,126.657108 +3201,˴ܿ(˴ܻ),õ2ȣ,37.594877,126.627178 +3208,˹,õ2ȣ,37.561405,126.677566 +4209,˾,ö,37.569098,126.674007 +3207,˾,õ2ȣ,37.56866,126.675687 +1504,Ɽ,氭,37.399907,127.25263 +4610,⵵ûϺû,ΰö,37.75059,127.071495 +1451,渶,4ȣ,37.443885,127.007888 +317,溹(μû),3ȣ,37.575762,126.97353 +3115,αԱ,õ1ȣ,37.538157,126.722597 +4604,ö,ΰö,37.737202,127.043257 +341,,3ȣ,37.495918,127.12454 +3114,,õ1ȣ,37.543238,126.728128 +4208,,ö,37.571662,126.7363 +3110,,õ1ȣ,37.571449,126.73578 +2553,,5ȣ,37.555004,127.154151 +2641,(),6ȣ,37.590508,127.036296 +1873,,κд缱,37.24963,126.980248 +329,͹̳,3ȣ,37.504891,127.004916 +2736,͹̳,7ȣ,37.503367,127.005068 +4123,͹̳,9ȣ,37.50598,127.004403 +1757,,4ȣ,37.316784,126.823144 +4513,,ο,37.24484,127.214251 +4928,,,37.601243,126.770345 +1272,,߾Ӽ,37.645676,126.801762 +4612,,ΰö,37.750471,127.083715 +1506,,氭,37.351315,127.34674 +2530,,5ȣ,37.544431,126.951372 +2627,,6ȣ,37.543555,126.951678 +1292,,߾Ӽ,37.542596,126.952099 +4202,,ö,37.54253,126.952024 +2718,(б),7ȣ,37.625742,127.072896 +4103,׽,9ȣ,37.563726,126.810678 +4212,ȭû,ö,37.459041,126.477516 +1453,õ,4ȣ,37.433021,126.996568 +1705,,1ȣ,37.419232,126.908706 +4411,ǻ(),Ÿ,37.4691018,126.9450639 +4319,(),źд缱,37.30211,127.044483 +4318,߾(ִ),źд缱,37.288617,127.051478 +2547,(Ŵ),5ȣ,37.545303,127.10357 +1750,,1ȣ,37.416182,126.884466 +2750,Ÿ,7ȣ,37.479252,126.854876 +1019,,1ȣ,37.623632,127.061835 +2534,ȭ(ȭȸ),5ȣ,37.571525,126.97717 +2625,â(),6ȣ,37.547456,126.931993 +223,(.û),2ȣ,37.493961,127.014667 +330,(.û),3ȣ,37.493025,127.013786 +4921,,,37.645384,126.628633 +1701,,1ȣ,37.503039,126.881966 +232,εд,2ȣ,37.485266,126.901401 +1026,,κд缱,37.486839,127.058856 +1205,,߾Ӽ,37.603392,127.143869 +4121,,9ȣ,37.501364,126.987332 +2616,,6ȣ,37.611377,126.91727 +1863,,κд缱,37.298969,127.105664 +9009,,GTX-A,37.29913,127.10389 +213,(û),2ȣ,37.537077,127.085916 +1813,,1ȣ,37.496756,126.870793 +310,Ĺ,3ȣ,37.636763,126.918821 +1214,,߾Ӽ,37.516169,127.399367 +3138,,õ1ȣ,37.399907,126.630347 +4114,ȸǻ,9ȣ,37.528105,126.917874 +2545,(ɵ),5ȣ,37.557088,127.079577 +2727,(ɵ),7ȣ,37.556897,127.079338 +1709,,1ȣ,37.35356,126.948462 +1324,,ἱ,37.832067,127.557695 +2760,õ,7ȣ,37.506997,126.73128 +2551,ٸ(ȸ),5ȣ,37.545477,127.142853 +3111,,õ1ȣ,37.566379,126.742654 +1316,ݰ,ἱ,37.637382,127.207853 +1279,ݸ,߾Ӽ,37.751322,126.765347 +1708,,1ȣ,37.372221,126.943429 +1458,,4ȣ,37.372209,126.943417 +1703,õû,1ȣ,37.455626,126.89398 +1280,,߾Ӽ,37.766217,126.774644 +324,ȣ,3ȣ,37.548034,127.015872 +1865,,κд缱,37.275061,127.11591 +4501,,ο,37.275449,127.116665 +2550,浿,5ȣ,37.537801,127.140004 +417,,4ȣ,37.603407,127.025053 +4511,跮,ο,37.237247,127.198781 +1327,,ἱ,37.818466,127.71434 +2513,,5ȣ,37.562384,126.801292 +4102,,9ȣ,37.561916,126.802152 +4207,,ö,37.561842,126.801904 +4929,,,37.56236,126.801868 +1980,,ؼ,37.5617,126.8041 +2519,ġ,5ȣ,37.531768,126.846683 +2753,ġ,7ȣ,37.506207,126.810939 +227,,2ȣ,37.47693,126.963693 +2747,,7ȣ,37.486056,126.887249 +3225,û,õ2ȣ,37.448161,126.736939 +1883,δũ,κд缱,37.407722,126.695216 +331,͹̳(),3ȣ,37.485013,127.016189 +2739,,7ȣ,37.484596,126.971251 +1002,,1ȣ,37.541021,126.9713 +2828,,8ȣ,37.4624,127.13977 +1328,õ,ἱ,37.864007,127.723792 +434,·,4ȣ,37.463873,126.989134 +2823,ѻ꼺Ա(.û),8ȣ,37.451535,127.159816 +2737,,7ȣ,37.487618,126.993513 +4118,,9ȣ,37.512887,126.953222 +4117,뷮,9ȣ,37.513534,126.941005 +1004,뷮,1ȣ,37.514149,126.94271 +411,,4ȣ,37.65627,127.063276 +2715,,7ȣ,37.654836,127.060462 +313,,3ȣ,37.600927,126.935756 +2630,(걸û),6ȣ,37.534675,126.986695 +1908,,1ȣ,37.75938,127.042292 +1021,õ,1ȣ,37.644799,127.051269 +2734,,7ȣ,37.511093,127.021415 +4305,,źд缱,37.511093,127.021415 +1271,ɰ,߾Ӽ,37.618808,126.820783 +2824,ܴŸ,8ȣ,37.44521,127.156866 +4811,޹,ؼ,37.348847,126.809409 +1878,޿,κд缱,37.379681,126.745177 +2543,ʸ,5ȣ,37.566747,127.052704 +409,,4ȣ,37.670272,127.079066 +4407,,Ÿ,37.4902998,126.9275133 +237,,2ȣ,37.534946,126.902767 +4113,,9ȣ,37.533406,126.902809 +1729,,1ȣ,37.344285,126.948345 +9002,,GTX-A,37.63191,126.81113 +1953,,3ȣ,37.631626,126.811024 +1452,,4ȣ,37.435675,127.006523 +233,븲(αû),2ȣ,37.493243,126.894932 +2746,븲(αû),7ȣ,37.493013,126.897075 +1028,Ա,κд缱,37.491373,127.07272 +1005,,1ȣ,37.513342,126.926382 +4402,,Ÿ,37.5133059,126.9257265 +1320,뼺,ἱ,37.684071,127.379319 +1752,߹,4ȣ,37.328467,126.917332 +337,û,3ȣ,37.493514,127.079532 +335,ġ,3ȣ,37.494612,127.063642 +1958,ȭ,3ȣ,37.676087,126.747569 +2626,(),6ȣ,37.547771,126.942069 +1910,,1ȣ,37.818486,127.056486 +1208,,߾Ӽ,37.586781,127.208832 +1911,,1ȣ,37.843188,127.061277 +334,,3ȣ,37.490922,127.055452 +1025,,κд缱,37.491224,127.055186 +1206,,߾Ӽ,37.608806,127.161153 +247,õ,2ȣ,37.514287,126.882768 +1902,,1ȣ,37.679563,127.045595 +2712,,7ȣ,37.689241,127.046509 +1903,,1ȣ,37.689534,127.046049 +1209,,߾Ӽ,37.579622,127.222672 +1817,,1ȣ,37.468446,126.642706 +1823,ȭ,1ȣ,37.46607,126.668672 +316,,3ȣ,37.574571,126.957748 +2614,,6ȣ,37.618456,126.933031 +1714,,1ȣ,37.466613,126.889249 +3206,,õ2ȣ,37.585212,126.675844 +2644,,6ȣ,37.610537,127.056431 +155,빮,1ȣ,37.571687,127.01093 +421,빮,4ȣ,37.57093,127.009287 +205,빮繮ȭ,2ȣ,37.565613,127.009054 +422,빮繮ȭ,4ȣ,37.565133,127.007885 +2537,빮繮ȭ,5ȣ,37.564665,127.005353 +322,Ա,3ȣ,37.559052,127.005602 +1915,õ,1ȣ,37.927878,127.05479 +1913,õ߾,1ȣ,37.901885,127.056482 +3132,,õ1ȣ,37.397878,126.674005 +159,,1ȣ,37.573197,127.01648 +2637,,6ȣ,37.572279,127.015653 +4505,,ο,37.269043,127.152716 +3121,,õ1ȣ,37.485312,126.718247 +1808,,1ȣ,37.471408,126.702896 +4608,,ΰö,37.745271,127.056947 +1811,õ,1ȣ,37.475276,126.632802 +431,(),4ȣ,37.502852,126.980347 +4120,(),9ȣ,37.502878,126.978153 +4314,õ,źд缱,37.337928,127.102976 +3131,,õ1ȣ,37.404737,126.681015 +9010,ź,GTX-A,37.20034,127.09569 +1727,,1ȣ,36.833705,127.14896 +4515,,ο,37.267051,127.21364 +2555,̵,5ȣ,37.527788,127.136248 +4137,̿,9ȣ,37.519683,127.137989 +4109,,9ȣ,37.550632,126.865689 +2619,й̵Ƽ,6ȣ,37.576108,126.901391 +1294,й̵Ƽ,߾Ӽ,37.577475,126.900453 +4204,й̵Ƽ,ö,37.576958,126.898609 +210,Ҽ,2ȣ,37.547184,127.047367 +2730,Ҽ,7ȣ,37.53154,127.066704 +2515,,5ȣ,37.560183,126.825448 +4105,,9ȣ,37.566778,126.82731 +4206,,ö,37.565543,126.827378 +1955,,3ȣ,37.652206,126.77762 +2714,,7ȣ,37.66494,127.057675 +4922,,,37.640732,126.644344 +1319,,ἱ,37.652782,127.311767 +2542,,5ȣ,37.5661,127.042973 +3204,,õ2ȣ,37.597566,126.666998 +2561,õ,5ȣ,37.49499,127.152781 +2529,,5ȣ,37.539574,126.945932 +2621,û,6ȣ,37.563515,126.903343 +3224,,õ2ȣ,37.454911,126.732094 +1203,,߾Ӽ,37.59955,127.091909 +2622,,6ȣ,37.556094,126.910052 +1904,,1ȣ,37.709914,127.047455 +1869,,κд缱,37.245795,127.057353 +1872,ű,κд缱,37.265481,127.015678 +333,ź,3ȣ,37.486947,127.046769 +1870,źǼ,κд缱,37.252759,127.040566 +2720,԰,7ȣ,37.610637,127.077725 +2723,,7ȣ,37.588579,127.087503 +424,,4ȣ,37.560989,126.986325 +2552,,5ȣ,37.55137,127.143999 +4510,,ο,37.237964,127.190294 +1707,,1ȣ,37.384653,126.935433 +2827,,8ȣ,37.433824,127.129837 +1853,,κд缱,37.432052,127.129104 +3223,𷡳,õ2ȣ,37.45583,126.719298 +2521,,5ȣ,37.526065,126.864931 +2814,伺(ȭǹ),8ȣ,37.517409,127.112359 +315,,3ȣ,37.582299,126.950291 +235,,2ȣ,37.517933,126.89476 +1284,,߾Ӽ,37.854619,126.788047 +2819,,8ȣ,37.485855,127.1225 +3127,а,õ1ȣ,37.434935,126.698579 +1858,̱,κд缱,37.350077,127.10891 +4313,̱,źд缱,37.349982,127.108918 +9996,̻,5ȣ,37.560927,127.193877 +415,̾(̹),4ȣ,37.62667,127.025983 +416,̾ƻŸ,4ȣ,37.613292,127.030053 +3112,,õ1ȣ,37.553703,126.745077 +1753,ݿ,4ȣ,37.312212,126.903524 +2735,,7ȣ,37.508178,127.011727 +4601,߰,ΰö,37.727048,127.052803 +2516,߻,5ȣ,37.558598,126.837668 +225,,2ȣ,37.481426,126.997596 +2557,,5ȣ,37.508857,127.126133 +1901,,1ȣ,37.667503,127.044273 +2511,ȭ,5ȣ,37.577446,126.812741 +1405,,1ȣ,36.777629,127.052991 +1273,鸶,߾Ӽ,37.658239,126.794461 +1954,鼮,3ȣ,37.643114,126.78787 +1325,縮,ἱ,37.830779,127.58933 +1807,,1ȣ,37.483664,126.707704 +2633,Ƽ,6ȣ,37.548013,127.007055 +1457,,4ȣ,37.389793,126.950806 +4603,,ΰö,37.728755,127.04353 +1313,,ἱ,37.64202,127.12684 +408,,4ȣ,37.66778,127.11581 +1716,,1ȣ,37.207503,127.032731 +2744,,7ȣ,37.499872,126.920428 +4404,,Ÿ,37.5002739,126.9204355 +4405,Ű,Ÿ,37.4955691,126.9180827 +4406,ź,Ÿ,37.4929598,126.9234964 +2639,,6ȣ,37.585274,127.019351 +4712,,̽ż,37.585286,127.019381 +1914,,1ȣ,37.913702,127.057277 +1861,,κд缱,37.312752,127.108196 +4514,,ο,37.258965,127.218457 +2821,,8ȣ,37.471052,127.126732 +1031,,κд缱,37.470345,127.126658 +1401,,1ȣ,36.801215,127.135763 +4129,,9ȣ,37.514219,127.060245 +229,õ,2ȣ,37.482362,126.941892 +2648,ȭ(Ƿ),6ȣ,37.617283,127.091401 +1815,ΰ,1ȣ,37.488418,126.74109 +1509,ι,氭,37.260192,127.490277 +1804,õ,1ȣ,37.48405,126.782686 +2757,õû,7ȣ,37.504631,126.763538 +2754,õտ,7ȣ,37.50538,126.797337 +1982,õտ,ؼ,37.505457,126.797289 +1806,,1ȣ,37.489445,126.724506 +3120,,õ1ȣ,37.490535,126.723453 +2761,û,7ȣ,37.507394,126.721599 +3118,û,õ1ȣ,37.508407,126.720555 +3122,Ÿ,õ1ȣ,37.477679,126.710208 +3119,,õ1ȣ,37.498383,126.722244 +4709,ѻ꺸,̽ż,37.612072,127.008251 +4701,ѻ,̽ż,37.662909,127.012706 +312,ұ,3ȣ,37.610553,126.92982 +2613,ұ,6ȣ,37.610873,126.92939 +2724,簡,7ȣ,37.580894,127.088478 +226,,2ȣ,37.476538,126.981544 +433,,4ȣ,37.476955,126.981651 +1315,縪,ἱ,37.65108,127.176933 +1877,縮,κд缱,37.28998,126.85685 +4926,(û),,37.620249,126.719731 +4124,,9ȣ,37.504206,127.015259 +3762,,7ȣ,37.5086,126.7035277 +1751,꺻,4ȣ,37.358101,126.933274 +2822,꼺,8ȣ,37.457122,127.149908 +4508,ﰡ,ο,37.242115,127.168075 +428,ﰢ,4ȣ,37.534075,126.9726 +2629,ﰢ,6ȣ,37.535534,126.974032 +1503,ﵿ,氭,37.409522,127.20336 +2759,ü,7ȣ,37.506411,126.742153 +9006,Z,GTX-A,37.50887,127.06324 +219,Z(),2ȣ,37.508844,127.06316 +4128,Z߾,9ȣ,37.513011,127.053282 +1950,,3ȣ,37.653083,126.895558 +4706,,̽ż,37.626914,127.018106 +4707,Ÿ,̽ż,37.621337,127.020473 +4131,,9ȣ,37.504738,127.088025 +1866,,κд缱,37.26181,127.108847 +410,,4ȣ,37.660878,127.073572 +2741,,7ȣ,37.502834,126.94791 +3758,,7ȣ,37.505814,126.753163 +1754,ϼ,4ȣ,37.302795,126.866489 +2722,(ÿܹ͹̳),7ȣ,37.595577,127.085716 +1202,(ÿܹ͹̳),߾Ӽ,37.596678,127.08504 +2624,,6ȣ,37.547716,126.922852 +207,սʸ,2ȣ,37.564354,127.029354 +2643,(ѱб),6ȣ,37.606377,127.048491 +2554,ϵ,5ȣ,37.556712,127.166417 +1322,õ,ἱ,37.770246,127.454821 +4317,,źд缱,37.297664,127.069342 +4609,,ΰö,37.748885,127.06362 +2617,(Ż),6ȣ,37.591148,126.913629 +4116,,9ȣ,37.517274,126.928422 +4401,,Ÿ,37.5170969,126.929399 +1263,,߾Ӽ,37.551881,126.935711 +3210,û,õ2ȣ,37.543742,126.676787 +2533,빮,5ȣ,37.565773,126.966641 +1749,ź,1ȣ,37.195504,127.051672 +3214,οȸ,õ2ȣ,37.500168,126.675795 +1009,,߾Ӽ,37.519594,126.988537 +9005,,GTX-A,37.55569,126.97296 +4410,뺥óŸ,Ÿ,37.4720019,126.9339351 +228,Ա(DZû),2ȣ,37.481247,126.952739 +1847,」,κд缱,37.543617,127.044707 +426,↑,4ȣ,37.55281,126.972556 +1001,↑,1ȣ,37.554337,126.971134 +1291,↑,߾Ӽ,37.557231,126.97103 +4201,↑,ö,37.553247,126.969769 +4403,溴û,Ÿ,37.5060464,126.9227083 +4409,,Ÿ,37.4782341,126.9330365 +1722,,1ȣ,37.056496,127.052819 +224,,2ȣ,37.491897,127.007917 +1855,,κд缱,37.385126,127.123592 +2645,,6ȣ,37.614872,127.065595 +1018,,1ȣ,37.614532,127.065934 +3763,(źϽ),7ȣ,37.5062285,126.6762813 +3213,(źϽ),õ2ȣ,37.506193,126.676203 +3220,,õ2ȣ,37.457611,126.692575 +1704,,1ȣ,37.435047,126.902295 +3222,õŸ,õ2ȣ,37.456805,126.709986 +2816,,8ȣ,37.505557,127.106832 +4133,,9ȣ,37.505208,127.10704 +4132,̰,9ȣ,37.502558,127.097033 +220,,2ȣ,37.504286,127.048203 +1023,,κд缱,37.504856,127.048807 +1450,,4ȣ,37.451673,127.002303 +4812,,ؼ,37.334353,126.809904 +4112,,9ȣ,37.53802,126.893525 +4127,,9ȣ,37.510297,127.043999 +1850,,κд缱,37.510735,127.043677 +3128,,õ1ȣ,37.426684,126.698863 +1711,հ,1ȣ,37.300349,126.97075 +1512,,氭,37.39468,127.11945 +9008,,GTX-A,37.39467,127.12058 +4316,,źд缱,37.313335,127.0801 +211,,2ȣ,37.544581,127.055961 +418,ſԱ(),4ȣ,37.592612,127.016441 +4711,ſԱ(),̽ż,37.592467,127.016516 +1725,ȯ,1ȣ,36.916076,127.126964 +1715,,1ȣ,37.245025,127.013222 +1717,,1ȣ,37.187533,127.04318 +1510,ո,氭,37.295309,127.570938 +3137,Ʈũ,õ1ȣ,37.393054,126.634729 +1880,ҷ,κд缱,37.40095,126.733522 +1814,һ,1ȣ,37.482753,126.79544 +4804,һ,ؼ,37.483279,126.795023 +4805,һ,ؼ,37.468467,126.797252 +1916,ҿ,1ȣ,37.9481,127.061034 +4702,ֹ,̽ż,37.65603,127.013273 +4708,ֻ,̽ż,37.620238,127.013626 +1805,۳,1ȣ,37.4876,126.753664 +1886,۵,κд缱,37.428514,126.657772 +3139,۵޺,õ1ȣ,37.407143,126.62597 +4614,ۻ,ΰö,37.737279,127.087159 +2514,,5ȣ,37.561184,126.811973 +1721,ź,1ȣ,37.075696,127.054301 +2817,,8ȣ,37.499703,127.112183 +4134,ij,9ȣ,37.510372,127.112216 +1856,,κд缱,37.378455,127.114322 +2713,,7ȣ,37.67785,127.055315 +1763,,4ȣ,37.349801,126.925365 +1267,,߾Ӽ,37.580842,126.895611 +339,,3ȣ,37.487378,127.101907 +1030,,κд缱,37.487472,127.101422 +9007,,GTX-A,37.48637,127.10161 +1713,,1ȣ,37.266348,126.999561 +1846,,κд缱,37.265917,126.999422 +1871,û,κд缱,37.261911,127.030736 +414,(ϱû),4ȣ,37.638052,127.025732 +4315,û,źд缱,37.322702,127.095026 +2826,,8ȣ,37.437428,127.140722 +427,Ա(),4ȣ,37.54456,126.972106 +2740,ǴԱ(),7ȣ,37.496029,126.953822 +1889,,κд缱,37.460789,126.638297 +3219,ùΰ(ȭâ),õ2ȣ,37.458335,126.681192 +151,û,1ȣ,37.565715,126.977088 +201,û,2ȣ,37.563588,126.975411 +4509,û.δ,ο,37.239151,127.178406 +4810,ɰ,ؼ,37.369864,126.808573 +4806,,ؼ,37.450145,126.793041 +4809,û,ؼ,37.382223,126.805625 +1864,Ű,κд缱,37.286102,127.111313 +2539,űȣ,5ȣ,37.554548,127.020331 +2526,ű,5ȣ,37.517623,126.914839 +1032,ű,1ȣ,37.516862,126.917865 +1760,űõ,4ȣ,37.338212,126.765844 +2649,ų,6ȣ,37.613174,127.102231 +1311,ų,ἱ,37.612887,127.103218 +4125,ų,9ȣ,37.504598,127.02506 +4306,ų,źд缱,37.504598,127.02506 +245,Ŵ,2ȣ,37.57004,127.046481 +206,Ŵ,2ȣ,37.56564,127.019614 +2636,Ŵ,6ȣ,37.566154,127.016146 +231,Ŵ,2ȣ,37.487462,126.913149 +2743,ŴŸ,7ȣ,37.499701,126.928276 +234,ŵ,2ȣ,37.508961,126.891084 +1007,ŵ,1ȣ,37.508787,126.891144 +1507,ŵе,氭,37.317185,127.40476 +230,Ÿ,2ȣ,37.484201,126.929715 +4408,Ÿ,Ÿ,37.4849266,126.9296159 +4111,Ÿ,9ȣ,37.544277,126.88308 +4122,Ź,9ȣ,37.503415,126.995925 +4104,Źȭ,9ȣ,37.567532,126.816601 +327,Ż,3ȣ,37.516334,127.020114 +4304,Ż,źд缱,37.516334,127.020114 +156,ż,1ȣ,37.576048,127.024634 +246,ż,2ȣ,37.574747,127.024932 +4713,ż,̽ż,37.576095,127.023242 +3129,ſ,õ1ȣ,37.41804,126.693863 +429,ſ,4ȣ,37.52917,126.967894 +1213,ſ,߾Ӽ,37.525545,127.372921 +1017,̹,1ȣ,37.601854,127.067325 +2520,(),5ȣ,37.524997,126.856191 +249,װŸ,2ȣ,37.520074,126.852912 +3756,ߵ,7ȣ,37.50282,126.77566 +1408,â(õ),1ȣ,36.769502,126.951108 +4807,õ,ؼ,37.439066,126.786788 +240,,2ȣ,37.555131,126.936926 +1252,,߾Ӽ,37.559733,126.942597 +1890,,κд缱,37.46874,126.623853 +2745,dz,7ȣ,37.50008,126.90993 +4808,,ؼ,37.409008,126.788017 +2825,,8ȣ,37.440918,127.147564 +413,ֹ,4ȣ,37.648627,127.034709 +1402,ֿ(緿),1ȣ,36.793759,127.1214 +1403,ƻ,1ȣ,36.792053,127.104361 +3209,ƽþƵ(̻Ÿ),õ2ȣ,37.5517,126.677122 +1215,ƽ,߾Ӽ,37.51382,127.443173 +2546,(̴Ĺ),5ȣ,37.551691,127.089761 +242,,2ȣ,37.557345,126.956141 +318,ȱ,3ȣ,37.576477,126.985443 +1759,Ȼ,4ȣ,37.327082,126.788532 +2640,Ⱦ(뺴),6ȣ,37.586272,127.029005 +1706,Ⱦ,1ȣ,37.401592,126.922874 +2811,ϻ,8ȣ,37.55021,127.127562 +326,б,3ȣ,37.527072,127.028461 +1848,бε,κд缱,37.527381,127.040534 +2531,ֿ,5ȣ,37.553736,126.95682 +1277,ߴ,߾Ӽ,37.712327,126.761356 +1876,߸,κд缱,37.264179,126.879483 +1854,ž,κд缱,37.411185,127.128715 +323,,3ȣ,37.554867,127.010541 +2634,,6ȣ,37.554263,127.010358 +1212,,߾Ӽ,37.545981,127.329098 +1204,,߾Ӽ,37.606596,127.107906 +332,(ʱû),3ȣ,37.484477,127.033902 +4308,(ʱû),źд缱,37.483809,127.034653 +4309,ùǽ(),źд缱,37.470023,127.03842 +1207,,߾Ӽ,37.60533,127.19364 +1909,,1ȣ,37.774381,127.044708 +248,õû,2ȣ,37.512398,126.865819 +4106,õⱳ,9ȣ,37.568381,126.841333 +4920,,,37.642379,126.614309 +2523,,5ȣ,37.525569,126.886129 +1217,,߾Ӽ,37.492773,127.491837 +4613,,ΰö,37.742802,127.085035 +2728,̴(),7ȣ,37.548014,127.074658 +4504,,ο,37.274917,127.143714 +1875,õ,κд缱,37.250102,126.90879 +4126,,9ȣ,37.507287,127.033868 +2528,dz,5ȣ,37.527098,126.932901 +2527,ǵ,5ȣ,37.521747,126.924357 +4115,ǵ,9ȣ,37.52176,126.92403 +1511,,氭,37.282308,127.628816 +1803,,1ȣ,37.485178,126.811502 +221,,2ȣ,37.500622,127.036456 +2612,,6ȣ,37.606021,126.922744 +1885,,κд缱,37.417804,126.67894 +311,ų,3ȣ,37.619229,126.921038 +2615,ų,6ȣ,37.618636,126.920625 +9004,ų,GTX-A,37.61878,126.9213 +1919,õ,1ȣ,38.10073,127.07372 +4110,â,9ȣ,37.546936,126.874916 +1006,,1ȣ,37.515504,126.907628 +236,û,2ȣ,37.525706,126.89661 +2524,û,5ȣ,37.5242,126.89503 +2525,,5ȣ,37.522669,126.905139 +4217,,ö,37.51202,126.524254 +1868,,κд缱,37.251568,127.071394 +3125,ȸ,õ1ȣ,37.449396,126.701012 +342,,3ȣ,37.502129,127.128319 +2558,,5ȣ,37.502057,127.127938 +406,,4ȣ,37.705,127.19281 +1802,,1ȣ,37.494526,126.845365 +1859,,κд缱,37.339824,127.108942 +2522,(񵿿),5ȣ,37.524496,126.875181 +1874,õ,κд缱,37.24304,126.963676 +1216,,߾Ӽ,37.506062,127.473868 +1719,,1ȣ,37.145885,127.06672 +1718,,1ȣ,37.168953,127.063197 +1762,̵,4ȣ,37.362357,126.738714 +325,,3ȣ,37.541684,127.017269 +1011,,߾Ӽ,37.540446,127.018672 +2752,¼(ȸԱ),7ȣ,37.492092,126.823023 +1821,¼(ȸԱ),1ȣ,37.492433,126.824086 +1407,¾õ,1ȣ,36.780483,127.003249 +2556,øȰ(ѱü),5ȣ,37.516201,127.130923 +4136,øȰ(ѱü),9ȣ,37.516269,127.130288 +3205,,õ2ȣ,37.592928,126.673203 +3202,ձ,õ2ȣ,37.59518,126.642696 +208,սʸ(û),2ȣ,37.561238,127.036954 +2541,սʸ(û),5ȣ,37.56184,127.037059 +1013,սʸ(û),߾Ӽ,37.561827,127.038352 +1016,ܴ,1ȣ,37.596073,127.063549 +244,,2ȣ,37.561904,127.050899 +250,(빮û),2ȣ,37.574028,127.038091 +2725,븶,7ȣ,37.573647,127.086727 +1219,빮,߾Ӽ,37.48223,127.594647 +1003,,1ȣ,37.529849,126.964561 +2517,,5ȣ,37.548768,126.836318 +1211,,߾Ӽ,37.554669,127.310115 +4512,.۴,ο,37.237845,127.209198 +4211,,ö,37.492904,126.49379 +4924,,,37.653867,126.68393 +3227,(â),õ2ȣ,37.440127,126.75997 +1278,,߾Ӽ,37.725826,126.767257 +9000,,GTX-A,37.71614,126.72841 +1286,õ,߾Ӽ,37.879942,126.769999 +4814,,ؼ,37.31321,126.796261 +1951,,3ȣ,37.653324,126.843041 +1218,,߾Ӽ,37.468672,127.547076 +4815,,ؼ,37.302371,126.786691 +1884,,κд缱,37.413049,126.686648 +3130,,õ1ȣ,37.412333,126.687869 +1981,,ؼ,37.5239,126.8049 +1948,,3ȣ,37.650658,126.872642 +1020,,1ȣ,37.633212,127.058831 +2642,(),6ȣ,37.601948,127.041518 +1879,,κд缱,37.391769,126.742699 +2620,Ű(),6ȣ,37.569532,126.899298 +1282,,߾Ӽ,37.796188,126.792587 +203,3,2ȣ,37.566306,126.991696 +320,3,3ȣ,37.566672,126.992548 +204,4,2ȣ,37.566595,126.997817 +2536,4,5ȣ,37.567352,126.998032 +202,Ա,2ȣ,37.566014,126.982618 +1012,,߾Ӽ,37.549946,127.034538 +2611,,6ȣ,37.598605,126.915577 +1710,ǿ,1ȣ,37.320852,126.948217 +1906,,1ȣ,37.738415,127.045958 +4605,νû,ΰö,37.739256,127.034781 +4607,߾,ΰö,37.743676,127.049565 +241,̴,2ȣ,37.556733,126.946013 +1502,̸,氭,37.394655,127.127819 +1860,̸,κд缱,37.395371,127.128248 +2738,̼,7ȣ,37.485196,126.981605 +1508,õ,氭,37.265579,127.44226 +430,(߾ӹڹ),4ȣ,37.522295,126.974733 +1008,(߾ӹڹ),߾Ӽ,37.522427,126.973406 +2631,¿,6ȣ,37.534488,126.994302 +1455,δ,4ȣ,37.401553,126.976715 +1812,õ,1ȣ,37.476079,126.616801 +1891,õ,κд缱,37.476403,126.617326 +3215,õ,õ2ȣ,37.4897,126.675208 +4213,õ1͹̳,ö,37.447464,126.452508 +4215,õ2͹̳,ö,37.460699,126.441442 +1881,õ,κд缱,37.400614,126.722478 +3226,õ,õ2ȣ,37.448769,126.752618 +3136,õԱ,õ1ȣ,37.386007,126.639484 +3124,õû,õ1ȣ,37.457263,126.702143 +3221,õû,õ2ȣ,37.456833,126.701306 +3126,õ͹̳,õ1ȣ,37.442383,126.699706 +1888,ϴ,κд缱,37.448493,126.649619 +1275,ϻ,߾Ӽ,37.682077,126.769846 +338,Ͽ,3ȣ,37.483681,127.08439 +1285,,߾Ӽ,37.888421,126.746765 +3113,,õ1ȣ,37.545059,126.738665 +3116,,õ1ȣ,37.530415,126.722527 +216,(ıû),2ȣ,37.513262,127.100159 +2815,(ıû),8ȣ,37.514692,127.104338 +215,dz,2ȣ,37.520733,127.10379 +217,ǻ,2ȣ,37.511687,127.086162 +328,,3ȣ,37.512759,127.01122 +4923,,,37.643986,126.669017 +2742,¹,7ȣ,37.504898,126.93915 +2711,,7ȣ,37.700109,127.053196 +2820,,8ȣ,37.478703,127.126191 +2544,,5ȣ,37.56144,127.064623 +1918,,1ȣ,38.02458,127.0718 +4517,.,ο,37.285342,127.219561 +4710,,̽ż,37.603133,127.013396 +1956,߻,3ȣ,37.659477,126.773359 +1454,ΰõû,4ȣ,37.426513,126.98978 +1761,,4ȣ,37.351735,126.742989 +1857,,κд缱,37.365994,127.10807 +4312,,źд缱,37.367098,127.108403 +157,⵿,1ȣ,37.578103,127.034893 +1810,,1ȣ,37.466769,126.656666 +152,,1ȣ,37.570161,126.982923 +153,3,1ȣ,37.570406,126.991847 +319,3,3ȣ,37.571605,126.991791 +2535,3,5ȣ,37.57254,126.990305 +154,5,1ȣ,37.570926,127.001849 +218,տ,2ȣ,37.511022,127.073704 +4130,տ,9ȣ,37.511426,127.076275 +1809,־,1ȣ,37.465047,126.679742 +3218,־,õ2ȣ,37.464992,126.679098 +3217,־ȱ,õ2ȣ,37.473703,126.68113 +1957,ֿ,3ȣ,37.670072,126.761334 +1862,,κд缱,37.324753,127.107395 +2716,߰,7ȣ,37.644583,127.064303 +2726,߰,7ȣ,37.565923,127.08432 +1822,ߵ,1ȣ,37.486562,126.764843 +1201,߶,߾Ӽ,37.594917,127.076116 +1756,߾,4ȣ,37.315941,126.838573 +4138,߾Ӻƺ,9ȣ,37.529191,127.148739 +2721,ȭ,7ȣ,37.602545,127.079264 +4108,,9ȣ,37.557402,126.861939 +2618,(),6ȣ,37.583876,126.909645 +4503,,ο,37.269606,127.136515 +3135,,õ1ȣ,37.378384,126.645168 +1723,,1ȣ,37.0188,127.070444 +309,,3ȣ,37.648033,126.913917 +1220,,߾Ӽ,37.476393,127.629874 +1912,,1ȣ,37.892334,127.055716 +1726,,1ȣ,36.870593,127.143904 +1720,,1ȣ,37.109447,127.062278 +405,,4ȣ,37.7205,127.2034 +412,â,4ȣ,37.653088,127.047274 +1022,â,߾Ӽ,37.653007,127.047806 +2638,â,6ȣ,37.579661,127.015241 +1318,õ,ἱ,37.658978,127.285379 +1728,õ,1ȣ,36.810005,127.146826 +2751,õ,7ȣ,37.486637,126.838713 +2548,õȣ(dz伺),5ȣ,37.53864,127.123308 +2812,õȣ(dz伺),8ȣ,37.538113,127.123254 +2749,ö,7ȣ,37.47605,126.867911 +4310,ûԱ,źд缱,37.447211,127.055664 +2538,û,5ȣ,37.560276,127.013639 +2635,û,6ȣ,37.560608,127.013986 +2731,û,7ȣ,37.519365,127.05335 +4210,û,ö,37.556409,126.624648 +158,û(øԱ),1ȣ,37.579956,127.044585 +1014,û(øԱ),߾Ӽ,37.580759,127.0483 +1867,û,κд缱,37.259489,127.078934 +1321,û,ἱ,37.735488,127.42661 +4506,ʴ,ο,37.260752,127.159443 +1917,ʼ,1ȣ,37.98172,127.06912 +1505,ʿ,氭,37.374419,127.299 +4813,,ؼ,37.319619,126.808147 +1758,,4ȣ,37.320646,126.805913 +432,ѽŴԱ(̼),4ȣ,37.486263,126.981989 +3755,,7ȣ,37.50365,126.78828 +1329,õ,ἱ,37.885054,127.717023 +321,湫,3ȣ,37.56143,126.994072 +423,湫,4ȣ,37.561207,126.99408 +243,(Ա),2ȣ,37.559704,126.964378 +2532,(Ա),5ȣ,37.560236,126.9629 +3133,ķ۽Ÿ,õ1ȣ,37.387855,126.661673 +9001,Ųؽ,GTX-A,37.66532,126.74843 +1276,ź,߾Ӽ,37.694023,126.761086 +4615,ž,ΰö,37.733579,127.088704 +1404,,1ȣ,36.78866,127.08485 +2646,¸Ա,6ȣ,37.617338,127.074735 +2719,¸Ա,7ȣ,37.618294,127.075397 +1852,,κд缱,37.440019,127.127709 +3134,ũũ,õ1ȣ,37.382268,126.656365 +1314,,ἱ,37.648311,127.143952 +1283,,߾Ӽ,37.815298,126.792783 +1501,DZ,氭,37.394761,127.111217 +4311,DZ,źд缱,37.394761,127.112217 +1210,ȴ,߾Ӽ,37.547371,127.243939 +1317,ȣ,ἱ,37.653225,127.244493 +1456,,4ȣ,37.394287,126.963883 +1724,,1ȣ,36.990726,127.085159 +4927,dz,,37.612488,126.732387 +1274,dz,߾Ӽ,37.672346,126.786243 +2717,ϰ,7ȣ,37.636352,127.06799 +2565,ϳ˴ܻ,5ȣ,37.53972,127.22345 +2566,ϳû(dz-),5ȣ,37.54205,127.20612 +2564,ϳdz,5ȣ,37.552034,127.203864 +2733,е,7ȣ,37.514229,127.031656 +336,п,3ȣ,37.496663,127.070594 +2632,Ѱ,6ȣ,37.539631,127.001725 +1010,ѳ,߾Ӽ,37.52943,127.009169 +1755,Ѵ,4ȣ,37.309689,126.85344 +419,ѼԱ(Q),4ȣ,37.588458,127.006221 +4135,Ѽ,9ȣ,37.516404,127.116503 +209,Ѿ,2ȣ,37.555273,127.043655 +1024,Ƽ,κд缱,37.496237,127.052873 +238,,2ȣ,37.549457,126.913808 +2623,,6ȣ,37.549209,126.913366 +2540,,5ȣ,37.557322,127.029476 +1270,,߾Ӽ,37.612102,126.834146 +420,ȭ,4ȣ,37.582336,127.001844 +1882,ȣ,κд缱,37.401637,126.708627 +239,ȫԱ,2ȣ,37.55679,126.923708 +1293,ȫԱ,߾Ӽ,37.557641,126.926683 +1264,ȫԱ,߾Ӽ,37.557641,126.926683 +4203,ȫԱ,ö,37.557438,126.926715 +314,ȫ,3ȣ,37.589066,126.943736 +4705,ȭ,̽ż,37.634133,127.017511 +2518,ȭ,5ȣ,37.541513,126.840461 +2647,ȭ(←Ա),6ȣ,37.620064,127.084689 +1712,ȭ,1ȣ,37.283862,126.989627 +1268,ȭ,߾Ӽ,37.602888,126.868387 +1952,ȭ,3ȣ,37.634592,126.83265 +1015,ȸ,߾Ӽ,37.58946,127.057583 +1905,ȸ,1ȣ,37.724416,127.04736 +4602,ȸ,ΰö,37.725006,127.047073 +425,ȸ(빮),4ȣ,37.558514,126.978246 +4611,ȿ,ΰö,37.754025,127.076902 +2628,ȿâ,6ȣ,37.539233,126.961384 +1261,ȿâ,߾Ӽ,37.538579,126.96221 +4119,漮(߾ӴԱ),9ȣ,37.50877,126.963708 +4606,Q,ΰö,37.743302,127.037023 \ No newline at end of file diff --git a/backend/bang-ggood/src/test/java/com/bang_ggood/article/ArticleFixture.java b/backend/bang-ggood/src/test/java/com/bang_ggood/article/ArticleFixture.java index 76204829..46b3197c 100644 --- a/backend/bang-ggood/src/test/java/com/bang_ggood/article/ArticleFixture.java +++ b/backend/bang-ggood/src/test/java/com/bang_ggood/article/ArticleFixture.java @@ -2,6 +2,7 @@ import com.bang_ggood.article.domain.Article; import com.bang_ggood.article.dto.request.ArticleCreateRequest; +import com.bang_ggood.article.dto.request.ArticleUpdateRequest; public class ArticleFixture { @@ -28,4 +29,8 @@ public static Article ARTICLE_4() { public static ArticleCreateRequest ARTICLE_CREATE_REQUEST() { return new ArticleCreateRequest("제목", "내용", "키워드", "요약", "썸네일"); } + + public static ArticleUpdateRequest ARTICLE_UPDATE_REQUEST() { + return new ArticleUpdateRequest("제목", "내용", "키워드", "요약", "썸네일"); + } } diff --git a/backend/bang-ggood/src/test/java/com/bang_ggood/article/controller/ArticleE2ETest.java b/backend/bang-ggood/src/test/java/com/bang_ggood/article/controller/ArticleE2ETest.java index be3db422..1147266f 100644 --- a/backend/bang-ggood/src/test/java/com/bang_ggood/article/controller/ArticleE2ETest.java +++ b/backend/bang-ggood/src/test/java/com/bang_ggood/article/controller/ArticleE2ETest.java @@ -98,6 +98,20 @@ void readArticlesListView() { .statusCode(200); } + @DisplayName("아티클 수정 성공") + @Test + void updateArticle() { + Article article = articleRepository.save(ArticleFixture.ARTICLE()); + + RestAssured.given().log().all() + .contentType(ContentType.JSON) + .headers(this.adminHeaders) + .body(ArticleFixture.ARTICLE_UPDATE_REQUEST()) + .when().put("/articles/" + article.getId()) + .then().log().all() + .statusCode(204); + } + @DisplayName("아티클 삭제 성공") @Test void deleteArticle() { diff --git a/backend/bang-ggood/src/test/java/com/bang_ggood/article/repository/ArticleRepositoryTest.java b/backend/bang-ggood/src/test/java/com/bang_ggood/article/repository/ArticleRepositoryTest.java index 7328d511..f9d92540 100644 --- a/backend/bang-ggood/src/test/java/com/bang_ggood/article/repository/ArticleRepositoryTest.java +++ b/backend/bang-ggood/src/test/java/com/bang_ggood/article/repository/ArticleRepositoryTest.java @@ -69,9 +69,24 @@ void findLatestArticles_exceptDeletedArticle() { Article article1 = articleRepository.save(ArticleFixture.ARTICLE_1()); Article article2 = articleRepository.save(ArticleFixture.ARTICLE_2()); Article article3 = articleRepository.save(ArticleFixture.ARTICLE_3()); - articleRepository.deleteById(ArticleFixture.ARTICLE_1().getId()); + articleRepository.deleteById(article1.getId()); // when & then - assertThat(articleRepository.findLatestArticles()).containsExactly(article3, article2, article1); + assertThat(articleRepository.findLatestArticles()).containsExactly(article3, article2); + } + + @DisplayName("아티클 조회수 업데이트 성공") + @Test + void updateViewCount() { + // given + Article article = articleRepository.save(ArticleFixture.ARTICLE()); + Long newViewCount = 100L; + + // when + articleRepository.updateViewCount(article.getId(), newViewCount); + + // then + Article updatedArticle = articleRepository.getById(article.getId()); + assertThat(updatedArticle.getViewCount()).isEqualTo(newViewCount); } } diff --git a/backend/bang-ggood/src/test/java/com/bang_ggood/article/service/ArticleServiceTest.java b/backend/bang-ggood/src/test/java/com/bang_ggood/article/service/ArticleManageServiceTest.java similarity index 57% rename from backend/bang-ggood/src/test/java/com/bang_ggood/article/service/ArticleServiceTest.java rename to backend/bang-ggood/src/test/java/com/bang_ggood/article/service/ArticleManageServiceTest.java index af645d2f..e57f9ffc 100644 --- a/backend/bang-ggood/src/test/java/com/bang_ggood/article/service/ArticleServiceTest.java +++ b/backend/bang-ggood/src/test/java/com/bang_ggood/article/service/ArticleManageServiceTest.java @@ -4,6 +4,8 @@ import com.bang_ggood.article.ArticleFixture; import com.bang_ggood.article.domain.Article; import com.bang_ggood.article.dto.request.ArticleCreateRequest; +import com.bang_ggood.article.dto.request.ArticleUpdateRequest; +import com.bang_ggood.article.dto.response.ArticleResponse; import com.bang_ggood.article.dto.response.ArticlesResponse; import com.bang_ggood.article.repository.ArticleRepository; import com.bang_ggood.global.exception.BangggoodException; @@ -16,11 +18,13 @@ import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatCode; import static org.assertj.core.api.Assertions.assertThatThrownBy; +import static org.junit.jupiter.api.Assertions.assertAll; -public class ArticleServiceTest extends IntegrationTestSupport { +public class ArticleManageServiceTest extends IntegrationTestSupport { @Autowired - ArticleService articleService; + ArticleManageService articleManageService; + @Autowired ArticleRepository articleRepository; @@ -31,7 +35,7 @@ void createArticle() { ArticleCreateRequest request = ArticleFixture.ARTICLE_CREATE_REQUEST(); // when - Long articleId = articleService.createArticle(request); + Long articleId = articleManageService.createArticle(request); // then assertThat(articleRepository.getById(articleId).getTitle()) @@ -45,7 +49,7 @@ void readArticle() { Article article = articleRepository.save(ArticleFixture.ARTICLE()); // when & then - assertThatCode(() -> articleService.readArticle(article.getId())) + assertThatCode(() -> articleManageService.readArticle(article.getId())) .doesNotThrowAnyException(); } @@ -56,7 +60,7 @@ void readArticle_invalidId_exception() { long articleId = Long.MAX_VALUE; // when & then - assertThatThrownBy(() -> articleService.readArticle(articleId)) + assertThatThrownBy(() -> articleManageService.readArticle(articleId)) .isInstanceOf(BangggoodException.class) .hasMessage(ExceptionCode.ARTICLE_NOT_FOUND.getMessage()); } @@ -71,7 +75,7 @@ void readArticles() { Article article4 = articleRepository.save(ArticleFixture.ARTICLE_4()); // when - List articleTitles = articleService.readArticles().articles().stream() + List articleTitles = articleManageService.readArticles().articles().stream() .map(ArticlesResponse::title) .toList(); @@ -80,6 +84,28 @@ void readArticles() { article1.getTitle()); } + @DisplayName("아티클 업데이트 성공") + @Test + void updateArticle() { + // given + Article article = articleRepository.save(ArticleFixture.ARTICLE_1()); + ArticleUpdateRequest updateArticle = ArticleFixture.ARTICLE_UPDATE_REQUEST(); + Long articleId = article.getId(); + + // when + articleManageService.updateArticle(articleId, updateArticle); + + // then + Article updatedArticle = articleRepository.getById(articleId); + assertAll( + () -> assertThat(updatedArticle.getTitle()).isEqualTo(updateArticle.title()), + () -> assertThat(updatedArticle.getContent()).isEqualTo(updateArticle.content()), + () -> assertThat(updatedArticle.getKeyword()).isEqualTo(updateArticle.keyword()), + () -> assertThat(updatedArticle.getSummary()).isEqualTo(updateArticle.summary()), + () -> assertThat(updatedArticle.getThumbnail()).isEqualTo(updateArticle.thumbnail()) + ); + } + @DisplayName("아티클 삭제 성공") @Test void deleteArticle() { @@ -87,11 +113,24 @@ void deleteArticle() { Article article = articleRepository.save(ArticleFixture.ARTICLE()); // when - articleService.deleteArticle(article.getId()); + articleManageService.deleteArticle(article.getId()); //then - assertThatThrownBy(() -> articleService.readArticle(article.getId())) + assertThatThrownBy(() -> articleManageService.readArticle(article.getId())) .isInstanceOf(BangggoodException.class) .hasMessage(ExceptionCode.ARTICLE_NOT_FOUND.getMessage()); } + + @DisplayName("아티클 조회 시 조회수 증가 성공") + @Test + void increaseViewCount() { + // given + Long articleId = articleRepository.save(ArticleFixture.ARTICLE()).getId(); + + // when + ArticleResponse article = articleManageService.readArticle(articleId); + + // then + assertThat(article.viewCount()).isEqualTo(1); + } } diff --git a/backend/bang-ggood/src/test/java/com/bang_ggood/article/service/ArticleViewServiceTest.java b/backend/bang-ggood/src/test/java/com/bang_ggood/article/service/ArticleViewServiceTest.java new file mode 100644 index 00000000..aaaa1dcd --- /dev/null +++ b/backend/bang-ggood/src/test/java/com/bang_ggood/article/service/ArticleViewServiceTest.java @@ -0,0 +1,81 @@ +package com.bang_ggood.article.service; + +import com.bang_ggood.IntegrationTestSupport; +import com.bang_ggood.article.ArticleFixture; +import com.bang_ggood.article.domain.Article; +import com.bang_ggood.article.dto.response.ArticleResponse; +import com.bang_ggood.article.repository.ArticleRepository; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.scheduling.TaskScheduler; +import org.springframework.scheduling.annotation.EnableScheduling; +import java.time.Instant; +import java.util.concurrent.ExecutionException; +import java.util.concurrent.ScheduledFuture; +import java.util.concurrent.TimeUnit; +import java.util.concurrent.TimeoutException; + +import static org.assertj.core.api.Assertions.assertThat; + +@EnableScheduling +class ArticleViewServiceTest extends IntegrationTestSupport { + + @Autowired + private ArticleManageService articleManageService; + + @Autowired + private ArticleViewService articleViewService; + + @Autowired + private ArticleRepository articleRepository; + + @Autowired + private TaskScheduler taskScheduler; + + @DisplayName("아티클 조회 시 조회수 증가 성공 : DB에서 조회하는 경우") + @Test + void increaseViewCount_Db() { + // given + Long articleId = articleRepository.save(ArticleFixture.ARTICLE()).getId(); + + // when + ArticleResponse article = articleManageService.readArticle(articleId); + + // then + assertThat(article.viewCount()).isEqualTo(1); + } + + @DisplayName("아티클 조회 시 조회수 증가 성공 : 캐시에서 조회하는 경우") + @Test + void increaseViewCount_Cache() { + // given + Long articleId = articleRepository.save(ArticleFixture.ARTICLE()).getId(); + + // when + articleManageService.readArticle(articleId); + ArticleResponse article = articleManageService.readArticle(articleId); + + // then + assertThat(article.viewCount()).isEqualTo(2); + } + + @DisplayName("캐시된 조회수를 DB에 동기화 성공") + @Test + void syncViewCounts() throws ExecutionException, InterruptedException { + // given + Long articleId = articleRepository.save(ArticleFixture.ARTICLE()).getId(); + articleManageService.readArticle(articleId); + articleManageService.readArticle(articleId); + + // when + taskScheduler.schedule( + () -> articleViewService.syncViewCounts(), + Instant.parse("2025-01-01T00:00:00Z") + ).get(); + + // then + Article article = articleRepository.getById(articleId); + assertThat(article.getViewCount()).isEqualTo(2); + } +} diff --git a/backend/bang-ggood/src/test/java/com/bang_ggood/auth/controller/AuthE2ETest.java b/backend/bang-ggood/src/test/java/com/bang_ggood/auth/controller/AuthE2ETest.java index 62d041a5..d4ca25ad 100644 --- a/backend/bang-ggood/src/test/java/com/bang_ggood/auth/controller/AuthE2ETest.java +++ b/backend/bang-ggood/src/test/java/com/bang_ggood/auth/controller/AuthE2ETest.java @@ -87,7 +87,7 @@ void authentication_no_cookie_exception() { RestAssured.given().log().all() .contentType(ContentType.JSON) .header(new Header(HttpHeaders.COOKIE, null)) - .when().post("/checklists") + .when().post("/v1/checklists") .then().log().all() .statusCode(401) .body("message", containsString(ExceptionCode.AUTHENTICATION_TOKEN_EMPTY.getMessage())); @@ -102,7 +102,7 @@ void authentication_invalid_cookie_exception() { RestAssured.given().log().all() .contentType(ContentType.JSON) .header(new Header(HttpHeaders.COOKIE, expectedCookie)) - .when().post("/checklists") + .when().post("/v1/checklists") .then().log().all() .statusCode(401) .body("message", containsString(ExceptionCode.AUTHENTICATION_TOKEN_EMPTY.getMessage())); diff --git a/backend/bang-ggood/src/test/java/com/bang_ggood/checklist/ChecklistFixture.java b/backend/bang-ggood/src/test/java/com/bang_ggood/checklist/ChecklistFixture.java index 9397ae98..67b66642 100644 --- a/backend/bang-ggood/src/test/java/com/bang_ggood/checklist/ChecklistFixture.java +++ b/backend/bang-ggood/src/test/java/com/bang_ggood/checklist/ChecklistFixture.java @@ -2,7 +2,6 @@ import com.bang_ggood.checklist.domain.Checklist; import com.bang_ggood.checklist.dto.request.ChecklistRequest; -import com.bang_ggood.checklist.dto.request.ChecklistRequestV1; import com.bang_ggood.contract.domain.OccupancyMonth; import com.bang_ggood.contract.domain.OccupancyPeriod; import com.bang_ggood.like.domain.ChecklistLike; @@ -117,18 +116,8 @@ public static ChecklistRequest CHECKLIST_CREATE_REQUEST() { ); } - public static ChecklistRequestV1 CHECKLIST_CREATE_REQUEST_V1() { - return new ChecklistRequestV1( - RoomFixture.ROOM_CREATE_REQUEST(), - List.of(Option.REFRIGERATOR.getId(), Option.SINK.getId(), Option.INDUCTION.getId(), - Option.SHOE_RACK.getId()), - List.of(QUESTION_1_CREATE_REQUEST(), QUESTION_2_CREATE_REQUEST(), - QUESTION_3_CREATE_REQUEST(), QUESTION_5_CREATE_REQUEST()) - ); - } - - public static ChecklistRequestV1 CHECKLIST_CREATE_REQUEST_V1_EMPTY_LOCATION() { - return new ChecklistRequestV1( + public static ChecklistRequest CHECKLIST_CREATE_REQUEST_EMPTY_LOCATION() { + return new ChecklistRequest( RoomFixture.ROOM_CREATE_REQUEST_EMPTY_LOCATION(), List.of(Option.REFRIGERATOR.getId(), Option.SINK.getId(), Option.INDUCTION.getId(), Option.SHOE_RACK.getId()), @@ -159,14 +148,6 @@ public static ChecklistRequest CHECKLIST_CREATE_REQUEST_NO_ROOM_NAME() { public static ChecklistRequest CHECKLIST_UPDATE_REQUEST() { return new ChecklistRequest( - RoomFixture.ROOM_UPDATE_REQUEST(), List.of(1, 2, 3, 4), - List.of(QUESTION_1_CREATE_REQUEST(), QUESTION_2_CREATE_REQUEST(), - QUESTION_3_CREATE_REQUEST(), QUESTION_5_UPDATE_REQUEST()) - ); - } - - public static ChecklistRequestV1 CHECKLIST_UPDATE_REQUEST_V1() { - return new ChecklistRequestV1( RoomFixture.ROOM_UPDATE_REQUEST(), List.of(Option.REFRIGERATOR.getId(), Option.INDUCTION.getId(), Option.BED.getId(), Option.WASHING_MACHINE.getId()), List.of(QUESTION_1_CREATE_REQUEST(), QUESTION_2_CREATE_REQUEST(), diff --git a/backend/bang-ggood/src/test/java/com/bang_ggood/checklist/controller/ChecklistE2ETest.java b/backend/bang-ggood/src/test/java/com/bang_ggood/checklist/controller/ChecklistE2ETest.java index 956c828c..e3bb7afe 100644 --- a/backend/bang-ggood/src/test/java/com/bang_ggood/checklist/controller/ChecklistE2ETest.java +++ b/backend/bang-ggood/src/test/java/com/bang_ggood/checklist/controller/ChecklistE2ETest.java @@ -5,7 +5,6 @@ import com.bang_ggood.checklist.domain.Checklist; import com.bang_ggood.checklist.repository.ChecklistRepository; import com.bang_ggood.checklist.service.ChecklistManageService; -import com.bang_ggood.question.repository.CustomChecklistQuestionRepository; import com.bang_ggood.room.RoomFixture; import com.bang_ggood.room.domain.Room; import com.bang_ggood.room.repository.RoomRepository; @@ -25,20 +24,6 @@ class ChecklistE2ETest extends AcceptanceTest { private ChecklistRepository checklistRepository; @Autowired private RoomRepository roomRepository; - @Autowired - private CustomChecklistQuestionRepository customChecklistQuestionRepository; - - @DisplayName("체크리스트 작성 성공") - @Test - void createChecklist() { - RestAssured.given().log().all() - .contentType(ContentType.JSON) - .headers(this.headers) - .body(ChecklistFixture.CHECKLIST_CREATE_REQUEST()) - .when().post("/checklists") - .then().log().all() - .statusCode(201); - } @DisplayName("체크리스트 작성 v1 성공") @Test @@ -46,8 +31,8 @@ void createChecklistV1() { RestAssured.given().log().all() .contentType(ContentType.JSON) .headers(this.headers) - .body(ChecklistFixture.CHECKLIST_CREATE_REQUEST_V1()) - .when().post("v1/checklists") + .body(ChecklistFixture.CHECKLIST_CREATE_REQUEST()) + .when().post("/v1/checklists") .then().log().all() .statusCode(201); } @@ -59,7 +44,7 @@ void createChecklist_noRoomName_exception() { .contentType(ContentType.JSON) .headers(this.headers) .body(ChecklistFixture.CHECKLIST_CREATE_REQUEST_NO_ROOM_NAME()) - .when().post("/checklists") + .when().post("/v1/checklists") .then().log().all() .statusCode(400) .body("message", containsString("방 이름이 존재하지 않습니다.")); @@ -72,7 +57,7 @@ void createChecklist_noQuestionId_exception() { .contentType(ContentType.JSON) .headers(this.headers) .body(ChecklistFixture.CHECKLIST_CREATE_REQUEST_NO_QUESTION_ID()) - .when().post("/checklists") + .when().post("/v1/checklists") .then().log().all() .statusCode(400) .body("message", containsString("질문 아이디가 존재하지 않습니다.")); @@ -98,7 +83,7 @@ void readChecklistById() { RestAssured.given().log().all() .contentType(ContentType.JSON) .headers(this.headers) - .when().get("/checklists/" + checklistId) + .when().get("/v1/checklists/" + checklistId) .then().log().all() .statusCode(200); /*.extract() @@ -131,7 +116,7 @@ void readLikedUserChecklistsPreview() { RestAssured.given().log().all() .contentType(ContentType.JSON) .headers(this.headers) - .when().get("/checklists/like") + .when().get("/v1/checklists/like") .then().log().all() .statusCode(200); } @@ -165,7 +150,7 @@ void updateChecklist() { .contentType(ContentType.JSON) .headers(this.headers) .body(ChecklistFixture.CHECKLIST_UPDATE_REQUEST()) - .when().put("/checklists/" + checklistId) + .when().put("/v1/checklists/" + checklistId) .then().log().all() .statusCode(204); } @@ -173,13 +158,13 @@ void updateChecklist() { @DisplayName("체크리스트 수정 v1 성공") @Test void updateChecklistV1() { - long checklistId = checklistManageService.createChecklistV1(this.getAuthenticatedUser(), - ChecklistFixture.CHECKLIST_CREATE_REQUEST_V1()); + long checklistId = checklistManageService.createChecklist(this.getAuthenticatedUser(), + ChecklistFixture.CHECKLIST_CREATE_REQUEST()); RestAssured.given().log().all() .contentType(ContentType.JSON) .headers(this.headers) - .body(ChecklistFixture.CHECKLIST_UPDATE_REQUEST_V1()) + .body(ChecklistFixture.CHECKLIST_UPDATE_REQUEST()) .when().put("/v1/checklists/" + checklistId) .then().log().all() .statusCode(204); @@ -195,7 +180,7 @@ void updateChecklist_noRoomName_exception() { .contentType(ContentType.JSON) .headers(this.headers) .body(ChecklistFixture.CHECKLIST_UPDATE_REQUEST_NO_ROOM_NAME()) - .when().put("/checklists/" + checklistId) + .when().put("/v1/checklists/" + checklistId) .then().log().all() .statusCode(400) .body("message", containsString("방 이름이 존재하지 않습니다.")); @@ -211,7 +196,7 @@ void updateChecklist_noQuestionId_exception() { .contentType(ContentType.JSON) .headers(this.headers) .body(ChecklistFixture.CHECKLIST_UPDATE_REQUEST_NO_QUESTION_ID()) - .when().put("/checklists/" + checklistId) + .when().put("/v1/checklists/" + checklistId) .then().log().all() .statusCode(400) .body("message", containsString("질문 아이디가 존재하지 않습니다.")); diff --git a/backend/bang-ggood/src/test/java/com/bang_ggood/checklist/service/ChecklistManageServiceTest.java b/backend/bang-ggood/src/test/java/com/bang_ggood/checklist/service/ChecklistManageServiceTest.java index 324dc063..5e5628b1 100644 --- a/backend/bang-ggood/src/test/java/com/bang_ggood/checklist/service/ChecklistManageServiceTest.java +++ b/backend/bang-ggood/src/test/java/com/bang_ggood/checklist/service/ChecklistManageServiceTest.java @@ -4,8 +4,7 @@ import com.bang_ggood.checklist.ChecklistFixture; import com.bang_ggood.checklist.domain.Checklist; import com.bang_ggood.checklist.dto.request.ChecklistRequest; -import com.bang_ggood.checklist.dto.request.ChecklistRequestV1; -import com.bang_ggood.checklist.dto.response.ChecklistCompareResponsesV1; +import com.bang_ggood.checklist.dto.response.ChecklistCompareResponses; import com.bang_ggood.checklist.dto.response.ChecklistPreviewResponse; import com.bang_ggood.checklist.dto.response.ChecklistsPreviewResponse; import com.bang_ggood.checklist.dto.response.SelectedChecklistResponse; @@ -59,29 +58,15 @@ void createChecklist() { assertThat(checklistId).isGreaterThan(0); } - @DisplayName("체크리스트 작성 v1 성공") + @DisplayName("체크리스트 작성 성공 : 위도, 경도가 null 인 경우") @Test - void createChecklistV1() { + void createChecklist_emptyLocation() { //given User user = userRepository.save(UserFixture.USER1()); - ChecklistRequestV1 checklistRequestV1 = ChecklistFixture.CHECKLIST_CREATE_REQUEST_V1(); + ChecklistRequest checklistRequest = ChecklistFixture.CHECKLIST_CREATE_REQUEST_EMPTY_LOCATION(); // when - long checklistId = checklistManageService.createChecklistV1(user, checklistRequestV1); - - //then - assertThat(checklistId).isGreaterThan(0); - } - - @DisplayName("체크리스트 작성 v1 성공 : 위도, 경도가 null 인 경우") - @Test - void createChecklistV1_emptyLocation() { - //given - User user = userRepository.save(UserFixture.USER1()); - ChecklistRequestV1 checklistRequestV1 = ChecklistFixture.CHECKLIST_CREATE_REQUEST_V1_EMPTY_LOCATION(); - - // when - long checklistId = checklistManageService.createChecklistV1(user, checklistRequestV1); + long checklistId = checklistManageService.createChecklist(user, checklistRequest); //then assertThat(checklistId).isGreaterThan(0); @@ -163,7 +148,7 @@ void compareChecklists_success() { List checklistIds = List.of(checklist1.getId(), checklist2.getId()); // when - ChecklistCompareResponsesV1 response = checklistManageService.compareChecklists(user, checklistIds); + ChecklistCompareResponses response = checklistManageService.compareChecklists(user, checklistIds); // then assertAll( diff --git a/backend/bang-ggood/src/test/java/com/bang_ggood/global/cache/CacheTest.java b/backend/bang-ggood/src/test/java/com/bang_ggood/global/cache/CacheTest.java index 96999054..0bfcac5c 100644 --- a/backend/bang-ggood/src/test/java/com/bang_ggood/global/cache/CacheTest.java +++ b/backend/bang-ggood/src/test/java/com/bang_ggood/global/cache/CacheTest.java @@ -3,8 +3,10 @@ import com.bang_ggood.article.domain.Article; import com.bang_ggood.article.dto.response.ArticleResponse; import com.bang_ggood.article.repository.ArticleRepository; +import com.bang_ggood.article.service.ArticleManageService; import com.bang_ggood.article.service.ArticleService; import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; import org.mockito.Mockito; @@ -23,14 +25,13 @@ class CacheTest { private ArticleRepository articleRepository; @Autowired - private ArticleService articleService; + private ArticleManageService articleManageService; private final Long cacheableArticleId = 1L; - private Article article; @BeforeEach void setUp() { - article = new Article("이름", "내용", "키워드", "요약", "썸네일"); + Article article = new Article("이름", "내용", "키워드", "요약", "썸네일"); Mockito.when(articleRepository.getById(cacheableArticleId)) .thenReturn(article); } @@ -38,12 +39,15 @@ void setUp() { @DisplayName("캐시가 정상적으로 작동한다.") @Test void cacheTest() { - ArticleResponse firstCallArticle = articleService.readArticle(cacheableArticleId); - ArticleResponse secondCallArticle = articleService.readArticle(cacheableArticleId); + ArticleResponse firstCallArticle = articleManageService.readArticle(cacheableArticleId); + ArticleResponse secondCallArticle = articleManageService.readArticle(cacheableArticleId); Mockito.verify(articleRepository, Mockito.times(1)).getById(cacheableArticleId); - assertThat(firstCallArticle).isEqualTo(secondCallArticle); + assertThat(firstCallArticle) + .usingRecursiveComparison() + .ignoringFields("viewCount") // viewCount 필드 제외 + .isEqualTo(secondCallArticle); } } diff --git a/backend/bang-ggood/src/test/resources/schema-test.sql b/backend/bang-ggood/src/test/resources/schema-test.sql index a00824b0..cae278dc 100644 --- a/backend/bang-ggood/src/test/resources/schema-test.sql +++ b/backend/bang-ggood/src/test/resources/schema-test.sql @@ -170,6 +170,7 @@ CREATE TABLE article keyword VARCHAR(255), summary VARCHAR(255), thumbnail VARCHAR(2500), + view_count BIGINT default 0, created_at TIMESTAMP(6), modified_at TIMESTAMP(6), deleted BOOLEAN diff --git a/backend/bang-ggood/src/test/resources/seoul_stations_241218.csv b/backend/bang-ggood/src/test/resources/seoul_stations_241218.csv new file mode 100644 index 00000000..2e76bf81 --- /dev/null +++ b/backend/bang-ggood/src/test/resources/seoul_stations_241218.csv @@ -0,0 +1,767 @@ +_ID,,ȣ,,浵 +4703,4.19ֹ,̽ż,37.649502,127.013684 +1907,,1ȣ,37.748577,127.044213 +340,,3ȣ,37.492245,127.117757 +2818,,8ȣ,37.492888,127.118398 +2748,д,7ȣ,37.480338,126.882656 +1702,д,1ȣ,37.481581,126.882581 +4107,,9ȣ,37.561391,126.854456 +4704,,̽ż,37.641537,127.016789 +3216,,õ2ȣ,37.484192,126.683673 +3211,(Ƽ),õ2ȣ,37.524649,126.675539 +3212,߾ӽ,õ2ȣ,37.517054,126.676672 +1265,,߾Ӽ,37.568491,126.915487 +1851,õ,κд缱,37.448605,127.126697 +1323,,ἱ,37.814536,127.510739 +1816,,1ȣ,37.464737,126.694181 +3123,Ÿ,õ1ȣ,37.467048,126.707938 +1312,,ἱ,37.634118,127.114757 +3117,,õ1ȣ,37.517268,126.721514 +222,,2ȣ,37.49799,127.027912 +4307,,źд缱,37.496837,127.028104 +2732,û,7ȣ,37.517179,127.041255 +1849,û,κд缱,37.517469,127.041151 +4502,,ο,37.270161,127.126033 +2549,,5ȣ,37.535804,127.132481 +2813,û,8ȣ,37.530341,127.120508 +1269,,߾Ӽ,37.612314,126.843223 +214,(͹̳),2ȣ,37.535095,127.094681 +9995,,5ȣ,37.55749,127.17593 +1326,,ἱ,37.805723,127.634146 +2559,,5ȣ,37.498079,127.13482 +1801,,1ȣ,37.494594,126.85968 +1027,,κд缱,37.489116,127.06614 +4101,ȭ,9ȣ,37.578608,126.798153 +2512,ȭ,5ȣ,37.572399,126.806171 +2560,ſ,5ȣ,37.493105,127.14415 +212,ǴԱ,2ȣ,37.540373,127.069191 +2729,ǴԱ,7ȣ,37.540786,127.071011 +4925,Ϻ,,37.63165,126.705975 +3203,˴ܻŸ,õ2ȣ,37.60185,126.657108 +3201,˴ܿ(˴ܻ),õ2ȣ,37.594877,126.627178 +3208,˹,õ2ȣ,37.561405,126.677566 +4209,˾,ö,37.569098,126.674007 +3207,˾,õ2ȣ,37.56866,126.675687 +1504,Ɽ,氭,37.399907,127.25263 +4610,⵵ûϺû,ΰö,37.75059,127.071495 +1451,渶,4ȣ,37.443885,127.007888 +317,溹(μû),3ȣ,37.575762,126.97353 +3115,αԱ,õ1ȣ,37.538157,126.722597 +4604,ö,ΰö,37.737202,127.043257 +341,,3ȣ,37.495918,127.12454 +3114,,õ1ȣ,37.543238,126.728128 +4208,,ö,37.571662,126.7363 +3110,,õ1ȣ,37.571449,126.73578 +2553,,5ȣ,37.555004,127.154151 +2641,(),6ȣ,37.590508,127.036296 +1873,,κд缱,37.24963,126.980248 +329,͹̳,3ȣ,37.504891,127.004916 +2736,͹̳,7ȣ,37.503367,127.005068 +4123,͹̳,9ȣ,37.50598,127.004403 +1757,,4ȣ,37.316784,126.823144 +4513,,ο,37.24484,127.214251 +4928,,,37.601243,126.770345 +1272,,߾Ӽ,37.645676,126.801762 +4612,,ΰö,37.750471,127.083715 +1506,,氭,37.351315,127.34674 +2530,,5ȣ,37.544431,126.951372 +2627,,6ȣ,37.543555,126.951678 +1292,,߾Ӽ,37.542596,126.952099 +4202,,ö,37.54253,126.952024 +2718,(б),7ȣ,37.625742,127.072896 +4103,׽,9ȣ,37.563726,126.810678 +4212,ȭû,ö,37.459041,126.477516 +1453,õ,4ȣ,37.433021,126.996568 +1705,,1ȣ,37.419232,126.908706 +4411,ǻ(),Ÿ,37.4691018,126.9450639 +4319,(),źд缱,37.30211,127.044483 +4318,߾(ִ),źд缱,37.288617,127.051478 +2547,(Ŵ),5ȣ,37.545303,127.10357 +1750,,1ȣ,37.416182,126.884466 +2750,Ÿ,7ȣ,37.479252,126.854876 +1019,,1ȣ,37.623632,127.061835 +2534,ȭ(ȭȸ),5ȣ,37.571525,126.97717 +2625,â(),6ȣ,37.547456,126.931993 +223,(.û),2ȣ,37.493961,127.014667 +330,(.û),3ȣ,37.493025,127.013786 +4921,,,37.645384,126.628633 +1701,,1ȣ,37.503039,126.881966 +232,εд,2ȣ,37.485266,126.901401 +1026,,κд缱,37.486839,127.058856 +1205,,߾Ӽ,37.603392,127.143869 +4121,,9ȣ,37.501364,126.987332 +2616,,6ȣ,37.611377,126.91727 +1863,,κд缱,37.298969,127.105664 +9009,,GTX-A,37.29913,127.10389 +213,(û),2ȣ,37.537077,127.085916 +1813,,1ȣ,37.496756,126.870793 +310,Ĺ,3ȣ,37.636763,126.918821 +1214,,߾Ӽ,37.516169,127.399367 +3138,,õ1ȣ,37.399907,126.630347 +4114,ȸǻ,9ȣ,37.528105,126.917874 +2545,(ɵ),5ȣ,37.557088,127.079577 +2727,(ɵ),7ȣ,37.556897,127.079338 +1709,,1ȣ,37.35356,126.948462 +1324,,ἱ,37.832067,127.557695 +2760,õ,7ȣ,37.506997,126.73128 +2551,ٸ(ȸ),5ȣ,37.545477,127.142853 +3111,,õ1ȣ,37.566379,126.742654 +1316,ݰ,ἱ,37.637382,127.207853 +1279,ݸ,߾Ӽ,37.751322,126.765347 +1708,,1ȣ,37.372221,126.943429 +1458,,4ȣ,37.372209,126.943417 +1703,õû,1ȣ,37.455626,126.89398 +1280,,߾Ӽ,37.766217,126.774644 +324,ȣ,3ȣ,37.548034,127.015872 +1865,,κд缱,37.275061,127.11591 +4501,,ο,37.275449,127.116665 +2550,浿,5ȣ,37.537801,127.140004 +417,,4ȣ,37.603407,127.025053 +4511,跮,ο,37.237247,127.198781 +1327,,ἱ,37.818466,127.71434 +2513,,5ȣ,37.562384,126.801292 +4102,,9ȣ,37.561916,126.802152 +4207,,ö,37.561842,126.801904 +4929,,,37.56236,126.801868 +1980,,ؼ,37.5617,126.8041 +2519,ġ,5ȣ,37.531768,126.846683 +2753,ġ,7ȣ,37.506207,126.810939 +227,,2ȣ,37.47693,126.963693 +2747,,7ȣ,37.486056,126.887249 +3225,û,õ2ȣ,37.448161,126.736939 +1883,δũ,κд缱,37.407722,126.695216 +331,͹̳(),3ȣ,37.485013,127.016189 +2739,,7ȣ,37.484596,126.971251 +1002,,1ȣ,37.541021,126.9713 +2828,,8ȣ,37.4624,127.13977 +1328,õ,ἱ,37.864007,127.723792 +434,·,4ȣ,37.463873,126.989134 +2823,ѻ꼺Ա(.û),8ȣ,37.451535,127.159816 +2737,,7ȣ,37.487618,126.993513 +4118,,9ȣ,37.512887,126.953222 +4117,뷮,9ȣ,37.513534,126.941005 +1004,뷮,1ȣ,37.514149,126.94271 +411,,4ȣ,37.65627,127.063276 +2715,,7ȣ,37.654836,127.060462 +313,,3ȣ,37.600927,126.935756 +2630,(걸û),6ȣ,37.534675,126.986695 +1908,,1ȣ,37.75938,127.042292 +1021,õ,1ȣ,37.644799,127.051269 +2734,,7ȣ,37.511093,127.021415 +4305,,źд缱,37.511093,127.021415 +1271,ɰ,߾Ӽ,37.618808,126.820783 +2824,ܴŸ,8ȣ,37.44521,127.156866 +4811,޹,ؼ,37.348847,126.809409 +1878,޿,κд缱,37.379681,126.745177 +2543,ʸ,5ȣ,37.566747,127.052704 +409,,4ȣ,37.670272,127.079066 +4407,,Ÿ,37.4902998,126.9275133 +237,,2ȣ,37.534946,126.902767 +4113,,9ȣ,37.533406,126.902809 +1729,,1ȣ,37.344285,126.948345 +9002,,GTX-A,37.63191,126.81113 +1953,,3ȣ,37.631626,126.811024 +1452,,4ȣ,37.435675,127.006523 +233,븲(αû),2ȣ,37.493243,126.894932 +2746,븲(αû),7ȣ,37.493013,126.897075 +1028,Ա,κд缱,37.491373,127.07272 +1005,,1ȣ,37.513342,126.926382 +4402,,Ÿ,37.5133059,126.9257265 +1320,뼺,ἱ,37.684071,127.379319 +1752,߹,4ȣ,37.328467,126.917332 +337,û,3ȣ,37.493514,127.079532 +335,ġ,3ȣ,37.494612,127.063642 +1958,ȭ,3ȣ,37.676087,126.747569 +2626,(),6ȣ,37.547771,126.942069 +1910,,1ȣ,37.818486,127.056486 +1208,,߾Ӽ,37.586781,127.208832 +1911,,1ȣ,37.843188,127.061277 +334,,3ȣ,37.490922,127.055452 +1025,,κд缱,37.491224,127.055186 +1206,,߾Ӽ,37.608806,127.161153 +247,õ,2ȣ,37.514287,126.882768 +1902,,1ȣ,37.679563,127.045595 +2712,,7ȣ,37.689241,127.046509 +1903,,1ȣ,37.689534,127.046049 +1209,,߾Ӽ,37.579622,127.222672 +1817,,1ȣ,37.468446,126.642706 +1823,ȭ,1ȣ,37.46607,126.668672 +316,,3ȣ,37.574571,126.957748 +2614,,6ȣ,37.618456,126.933031 +1714,,1ȣ,37.466613,126.889249 +3206,,õ2ȣ,37.585212,126.675844 +2644,,6ȣ,37.610537,127.056431 +155,빮,1ȣ,37.571687,127.01093 +421,빮,4ȣ,37.57093,127.009287 +205,빮繮ȭ,2ȣ,37.565613,127.009054 +422,빮繮ȭ,4ȣ,37.565133,127.007885 +2537,빮繮ȭ,5ȣ,37.564665,127.005353 +322,Ա,3ȣ,37.559052,127.005602 +1915,õ,1ȣ,37.927878,127.05479 +1913,õ߾,1ȣ,37.901885,127.056482 +3132,,õ1ȣ,37.397878,126.674005 +159,,1ȣ,37.573197,127.01648 +2637,,6ȣ,37.572279,127.015653 +4505,,ο,37.269043,127.152716 +3121,,õ1ȣ,37.485312,126.718247 +1808,,1ȣ,37.471408,126.702896 +4608,,ΰö,37.745271,127.056947 +1811,õ,1ȣ,37.475276,126.632802 +431,(),4ȣ,37.502852,126.980347 +4120,(),9ȣ,37.502878,126.978153 +4314,õ,źд缱,37.337928,127.102976 +3131,,õ1ȣ,37.404737,126.681015 +9010,ź,GTX-A,37.20034,127.09569 +1727,,1ȣ,36.833705,127.14896 +4515,,ο,37.267051,127.21364 +2555,̵,5ȣ,37.527788,127.136248 +4137,̿,9ȣ,37.519683,127.137989 +4109,,9ȣ,37.550632,126.865689 +2619,й̵Ƽ,6ȣ,37.576108,126.901391 +1294,й̵Ƽ,߾Ӽ,37.577475,126.900453 +4204,й̵Ƽ,ö,37.576958,126.898609 +210,Ҽ,2ȣ,37.547184,127.047367 +2730,Ҽ,7ȣ,37.53154,127.066704 +2515,,5ȣ,37.560183,126.825448 +4105,,9ȣ,37.566778,126.82731 +4206,,ö,37.565543,126.827378 +1955,,3ȣ,37.652206,126.77762 +2714,,7ȣ,37.66494,127.057675 +4922,,,37.640732,126.644344 +1319,,ἱ,37.652782,127.311767 +2542,,5ȣ,37.5661,127.042973 +3204,,õ2ȣ,37.597566,126.666998 +2561,õ,5ȣ,37.49499,127.152781 +2529,,5ȣ,37.539574,126.945932 +2621,û,6ȣ,37.563515,126.903343 +3224,,õ2ȣ,37.454911,126.732094 +1203,,߾Ӽ,37.59955,127.091909 +2622,,6ȣ,37.556094,126.910052 +1904,,1ȣ,37.709914,127.047455 +1869,,κд缱,37.245795,127.057353 +1872,ű,κд缱,37.265481,127.015678 +333,ź,3ȣ,37.486947,127.046769 +1870,źǼ,κд缱,37.252759,127.040566 +2720,԰,7ȣ,37.610637,127.077725 +2723,,7ȣ,37.588579,127.087503 +424,,4ȣ,37.560989,126.986325 +2552,,5ȣ,37.55137,127.143999 +4510,,ο,37.237964,127.190294 +1707,,1ȣ,37.384653,126.935433 +2827,,8ȣ,37.433824,127.129837 +1853,,κд缱,37.432052,127.129104 +3223,𷡳,õ2ȣ,37.45583,126.719298 +2521,,5ȣ,37.526065,126.864931 +2814,伺(ȭǹ),8ȣ,37.517409,127.112359 +315,,3ȣ,37.582299,126.950291 +235,,2ȣ,37.517933,126.89476 +1284,,߾Ӽ,37.854619,126.788047 +2819,,8ȣ,37.485855,127.1225 +3127,а,õ1ȣ,37.434935,126.698579 +1858,̱,κд缱,37.350077,127.10891 +4313,̱,źд缱,37.349982,127.108918 +9996,̻,5ȣ,37.560927,127.193877 +415,̾(̹),4ȣ,37.62667,127.025983 +416,̾ƻŸ,4ȣ,37.613292,127.030053 +3112,,õ1ȣ,37.553703,126.745077 +1753,ݿ,4ȣ,37.312212,126.903524 +2735,,7ȣ,37.508178,127.011727 +4601,߰,ΰö,37.727048,127.052803 +2516,߻,5ȣ,37.558598,126.837668 +225,,2ȣ,37.481426,126.997596 +2557,,5ȣ,37.508857,127.126133 +1901,,1ȣ,37.667503,127.044273 +2511,ȭ,5ȣ,37.577446,126.812741 +1405,,1ȣ,36.777629,127.052991 +1273,鸶,߾Ӽ,37.658239,126.794461 +1954,鼮,3ȣ,37.643114,126.78787 +1325,縮,ἱ,37.830779,127.58933 +1807,,1ȣ,37.483664,126.707704 +2633,Ƽ,6ȣ,37.548013,127.007055 +1457,,4ȣ,37.389793,126.950806 +4603,,ΰö,37.728755,127.04353 +1313,,ἱ,37.64202,127.12684 +408,,4ȣ,37.66778,127.11581 +1716,,1ȣ,37.207503,127.032731 +2744,,7ȣ,37.499872,126.920428 +4404,,Ÿ,37.5002739,126.9204355 +4405,Ű,Ÿ,37.4955691,126.9180827 +4406,ź,Ÿ,37.4929598,126.9234964 +2639,,6ȣ,37.585274,127.019351 +4712,,̽ż,37.585286,127.019381 +1914,,1ȣ,37.913702,127.057277 +1861,,κд缱,37.312752,127.108196 +4514,,ο,37.258965,127.218457 +2821,,8ȣ,37.471052,127.126732 +1031,,κд缱,37.470345,127.126658 +1401,,1ȣ,36.801215,127.135763 +4129,,9ȣ,37.514219,127.060245 +229,õ,2ȣ,37.482362,126.941892 +2648,ȭ(Ƿ),6ȣ,37.617283,127.091401 +1815,ΰ,1ȣ,37.488418,126.74109 +1509,ι,氭,37.260192,127.490277 +1804,õ,1ȣ,37.48405,126.782686 +2757,õû,7ȣ,37.504631,126.763538 +2754,õտ,7ȣ,37.50538,126.797337 +1982,õտ,ؼ,37.505457,126.797289 +1806,,1ȣ,37.489445,126.724506 +3120,,õ1ȣ,37.490535,126.723453 +2761,û,7ȣ,37.507394,126.721599 +3118,û,õ1ȣ,37.508407,126.720555 +3122,Ÿ,õ1ȣ,37.477679,126.710208 +3119,,õ1ȣ,37.498383,126.722244 +4709,ѻ꺸,̽ż,37.612072,127.008251 +4701,ѻ,̽ż,37.662909,127.012706 +312,ұ,3ȣ,37.610553,126.92982 +2613,ұ,6ȣ,37.610873,126.92939 +2724,簡,7ȣ,37.580894,127.088478 +226,,2ȣ,37.476538,126.981544 +433,,4ȣ,37.476955,126.981651 +1315,縪,ἱ,37.65108,127.176933 +1877,縮,κд缱,37.28998,126.85685 +4926,(û),,37.620249,126.719731 +4124,,9ȣ,37.504206,127.015259 +3762,,7ȣ,37.5086,126.7035277 +1751,꺻,4ȣ,37.358101,126.933274 +2822,꼺,8ȣ,37.457122,127.149908 +4508,ﰡ,ο,37.242115,127.168075 +428,ﰢ,4ȣ,37.534075,126.9726 +2629,ﰢ,6ȣ,37.535534,126.974032 +1503,ﵿ,氭,37.409522,127.20336 +2759,ü,7ȣ,37.506411,126.742153 +9006,Z,GTX-A,37.50887,127.06324 +219,Z(),2ȣ,37.508844,127.06316 +4128,Z߾,9ȣ,37.513011,127.053282 +1950,,3ȣ,37.653083,126.895558 +4706,,̽ż,37.626914,127.018106 +4707,Ÿ,̽ż,37.621337,127.020473 +4131,,9ȣ,37.504738,127.088025 +1866,,κд缱,37.26181,127.108847 +410,,4ȣ,37.660878,127.073572 +2741,,7ȣ,37.502834,126.94791 +3758,,7ȣ,37.505814,126.753163 +1754,ϼ,4ȣ,37.302795,126.866489 +2722,(ÿܹ͹̳),7ȣ,37.595577,127.085716 +1202,(ÿܹ͹̳),߾Ӽ,37.596678,127.08504 +2624,,6ȣ,37.547716,126.922852 +207,սʸ,2ȣ,37.564354,127.029354 +2643,(ѱб),6ȣ,37.606377,127.048491 +2554,ϵ,5ȣ,37.556712,127.166417 +1322,õ,ἱ,37.770246,127.454821 +4317,,źд缱,37.297664,127.069342 +4609,,ΰö,37.748885,127.06362 +2617,(Ż),6ȣ,37.591148,126.913629 +4116,,9ȣ,37.517274,126.928422 +4401,,Ÿ,37.5170969,126.929399 +1263,,߾Ӽ,37.551881,126.935711 +3210,û,õ2ȣ,37.543742,126.676787 +2533,빮,5ȣ,37.565773,126.966641 +1749,ź,1ȣ,37.195504,127.051672 +3214,οȸ,õ2ȣ,37.500168,126.675795 +1009,,߾Ӽ,37.519594,126.988537 +9005,,GTX-A,37.55569,126.97296 +4410,뺥óŸ,Ÿ,37.4720019,126.9339351 +228,Ա(DZû),2ȣ,37.481247,126.952739 +1847,」,κд缱,37.543617,127.044707 +426,↑,4ȣ,37.55281,126.972556 +1001,↑,1ȣ,37.554337,126.971134 +1291,↑,߾Ӽ,37.557231,126.97103 +4201,↑,ö,37.553247,126.969769 +4403,溴û,Ÿ,37.5060464,126.9227083 +4409,,Ÿ,37.4782341,126.9330365 +1722,,1ȣ,37.056496,127.052819 +224,,2ȣ,37.491897,127.007917 +1855,,κд缱,37.385126,127.123592 +2645,,6ȣ,37.614872,127.065595 +1018,,1ȣ,37.614532,127.065934 +3763,(źϽ),7ȣ,37.5062285,126.6762813 +3213,(źϽ),õ2ȣ,37.506193,126.676203 +3220,,õ2ȣ,37.457611,126.692575 +1704,,1ȣ,37.435047,126.902295 +3222,õŸ,õ2ȣ,37.456805,126.709986 +2816,,8ȣ,37.505557,127.106832 +4133,,9ȣ,37.505208,127.10704 +4132,̰,9ȣ,37.502558,127.097033 +220,,2ȣ,37.504286,127.048203 +1023,,κд缱,37.504856,127.048807 +1450,,4ȣ,37.451673,127.002303 +4812,,ؼ,37.334353,126.809904 +4112,,9ȣ,37.53802,126.893525 +4127,,9ȣ,37.510297,127.043999 +1850,,κд缱,37.510735,127.043677 +3128,,õ1ȣ,37.426684,126.698863 +1711,հ,1ȣ,37.300349,126.97075 +1512,,氭,37.39468,127.11945 +9008,,GTX-A,37.39467,127.12058 +4316,,źд缱,37.313335,127.0801 +211,,2ȣ,37.544581,127.055961 +418,ſԱ(),4ȣ,37.592612,127.016441 +4711,ſԱ(),̽ż,37.592467,127.016516 +1725,ȯ,1ȣ,36.916076,127.126964 +1715,,1ȣ,37.245025,127.013222 +1717,,1ȣ,37.187533,127.04318 +1510,ո,氭,37.295309,127.570938 +3137,Ʈũ,õ1ȣ,37.393054,126.634729 +1880,ҷ,κд缱,37.40095,126.733522 +1814,һ,1ȣ,37.482753,126.79544 +4804,һ,ؼ,37.483279,126.795023 +4805,һ,ؼ,37.468467,126.797252 +1916,ҿ,1ȣ,37.9481,127.061034 +4702,ֹ,̽ż,37.65603,127.013273 +4708,ֻ,̽ż,37.620238,127.013626 +1805,۳,1ȣ,37.4876,126.753664 +1886,۵,κд缱,37.428514,126.657772 +3139,۵޺,õ1ȣ,37.407143,126.62597 +4614,ۻ,ΰö,37.737279,127.087159 +2514,,5ȣ,37.561184,126.811973 +1721,ź,1ȣ,37.075696,127.054301 +2817,,8ȣ,37.499703,127.112183 +4134,ij,9ȣ,37.510372,127.112216 +1856,,κд缱,37.378455,127.114322 +2713,,7ȣ,37.67785,127.055315 +1763,,4ȣ,37.349801,126.925365 +1267,,߾Ӽ,37.580842,126.895611 +339,,3ȣ,37.487378,127.101907 +1030,,κд缱,37.487472,127.101422 +9007,,GTX-A,37.48637,127.10161 +1713,,1ȣ,37.266348,126.999561 +1846,,κд缱,37.265917,126.999422 +1871,û,κд缱,37.261911,127.030736 +414,(ϱû),4ȣ,37.638052,127.025732 +4315,û,źд缱,37.322702,127.095026 +2826,,8ȣ,37.437428,127.140722 +427,Ա(),4ȣ,37.54456,126.972106 +2740,ǴԱ(),7ȣ,37.496029,126.953822 +1889,,κд缱,37.460789,126.638297 +3219,ùΰ(ȭâ),õ2ȣ,37.458335,126.681192 +151,û,1ȣ,37.565715,126.977088 +201,û,2ȣ,37.563588,126.975411 +4509,û.δ,ο,37.239151,127.178406 +4810,ɰ,ؼ,37.369864,126.808573 +4806,,ؼ,37.450145,126.793041 +4809,û,ؼ,37.382223,126.805625 +1864,Ű,κд缱,37.286102,127.111313 +2539,űȣ,5ȣ,37.554548,127.020331 +2526,ű,5ȣ,37.517623,126.914839 +1032,ű,1ȣ,37.516862,126.917865 +1760,űõ,4ȣ,37.338212,126.765844 +2649,ų,6ȣ,37.613174,127.102231 +1311,ų,ἱ,37.612887,127.103218 +4125,ų,9ȣ,37.504598,127.02506 +4306,ų,źд缱,37.504598,127.02506 +245,Ŵ,2ȣ,37.57004,127.046481 +206,Ŵ,2ȣ,37.56564,127.019614 +2636,Ŵ,6ȣ,37.566154,127.016146 +231,Ŵ,2ȣ,37.487462,126.913149 +2743,ŴŸ,7ȣ,37.499701,126.928276 +234,ŵ,2ȣ,37.508961,126.891084 +1007,ŵ,1ȣ,37.508787,126.891144 +1507,ŵе,氭,37.317185,127.40476 +230,Ÿ,2ȣ,37.484201,126.929715 +4408,Ÿ,Ÿ,37.4849266,126.9296159 +4111,Ÿ,9ȣ,37.544277,126.88308 +4122,Ź,9ȣ,37.503415,126.995925 +4104,Źȭ,9ȣ,37.567532,126.816601 +327,Ż,3ȣ,37.516334,127.020114 +4304,Ż,źд缱,37.516334,127.020114 +156,ż,1ȣ,37.576048,127.024634 +246,ż,2ȣ,37.574747,127.024932 +4713,ż,̽ż,37.576095,127.023242 +3129,ſ,õ1ȣ,37.41804,126.693863 +429,ſ,4ȣ,37.52917,126.967894 +1213,ſ,߾Ӽ,37.525545,127.372921 +1017,̹,1ȣ,37.601854,127.067325 +2520,(),5ȣ,37.524997,126.856191 +249,װŸ,2ȣ,37.520074,126.852912 +3756,ߵ,7ȣ,37.50282,126.77566 +1408,â(õ),1ȣ,36.769502,126.951108 +4807,õ,ؼ,37.439066,126.786788 +240,,2ȣ,37.555131,126.936926 +1252,,߾Ӽ,37.559733,126.942597 +1890,,κд缱,37.46874,126.623853 +2745,dz,7ȣ,37.50008,126.90993 +4808,,ؼ,37.409008,126.788017 +2825,,8ȣ,37.440918,127.147564 +413,ֹ,4ȣ,37.648627,127.034709 +1402,ֿ(緿),1ȣ,36.793759,127.1214 +1403,ƻ,1ȣ,36.792053,127.104361 +3209,ƽþƵ(̻Ÿ),õ2ȣ,37.5517,126.677122 +1215,ƽ,߾Ӽ,37.51382,127.443173 +2546,(̴Ĺ),5ȣ,37.551691,127.089761 +242,,2ȣ,37.557345,126.956141 +318,ȱ,3ȣ,37.576477,126.985443 +1759,Ȼ,4ȣ,37.327082,126.788532 +2640,Ⱦ(뺴),6ȣ,37.586272,127.029005 +1706,Ⱦ,1ȣ,37.401592,126.922874 +2811,ϻ,8ȣ,37.55021,127.127562 +326,б,3ȣ,37.527072,127.028461 +1848,бε,κд缱,37.527381,127.040534 +2531,ֿ,5ȣ,37.553736,126.95682 +1277,ߴ,߾Ӽ,37.712327,126.761356 +1876,߸,κд缱,37.264179,126.879483 +1854,ž,κд缱,37.411185,127.128715 +323,,3ȣ,37.554867,127.010541 +2634,,6ȣ,37.554263,127.010358 +1212,,߾Ӽ,37.545981,127.329098 +1204,,߾Ӽ,37.606596,127.107906 +332,(ʱû),3ȣ,37.484477,127.033902 +4308,(ʱû),źд缱,37.483809,127.034653 +4309,ùǽ(),źд缱,37.470023,127.03842 +1207,,߾Ӽ,37.60533,127.19364 +1909,,1ȣ,37.774381,127.044708 +248,õû,2ȣ,37.512398,126.865819 +4106,õⱳ,9ȣ,37.568381,126.841333 +4920,,,37.642379,126.614309 +2523,,5ȣ,37.525569,126.886129 +1217,,߾Ӽ,37.492773,127.491837 +4613,,ΰö,37.742802,127.085035 +2728,̴(),7ȣ,37.548014,127.074658 +4504,,ο,37.274917,127.143714 +1875,õ,κд缱,37.250102,126.90879 +4126,,9ȣ,37.507287,127.033868 +2528,dz,5ȣ,37.527098,126.932901 +2527,ǵ,5ȣ,37.521747,126.924357 +4115,ǵ,9ȣ,37.52176,126.92403 +1511,,氭,37.282308,127.628816 +1803,,1ȣ,37.485178,126.811502 +221,,2ȣ,37.500622,127.036456 +2612,,6ȣ,37.606021,126.922744 +1885,,κд缱,37.417804,126.67894 +311,ų,3ȣ,37.619229,126.921038 +2615,ų,6ȣ,37.618636,126.920625 +9004,ų,GTX-A,37.61878,126.9213 +1919,õ,1ȣ,38.10073,127.07372 +4110,â,9ȣ,37.546936,126.874916 +1006,,1ȣ,37.515504,126.907628 +236,û,2ȣ,37.525706,126.89661 +2524,û,5ȣ,37.5242,126.89503 +2525,,5ȣ,37.522669,126.905139 +4217,,ö,37.51202,126.524254 +1868,,κд缱,37.251568,127.071394 +3125,ȸ,õ1ȣ,37.449396,126.701012 +342,,3ȣ,37.502129,127.128319 +2558,,5ȣ,37.502057,127.127938 +406,,4ȣ,37.705,127.19281 +1802,,1ȣ,37.494526,126.845365 +1859,,κд缱,37.339824,127.108942 +2522,(񵿿),5ȣ,37.524496,126.875181 +1874,õ,κд缱,37.24304,126.963676 +1216,,߾Ӽ,37.506062,127.473868 +1719,,1ȣ,37.145885,127.06672 +1718,,1ȣ,37.168953,127.063197 +1762,̵,4ȣ,37.362357,126.738714 +325,,3ȣ,37.541684,127.017269 +1011,,߾Ӽ,37.540446,127.018672 +2752,¼(ȸԱ),7ȣ,37.492092,126.823023 +1821,¼(ȸԱ),1ȣ,37.492433,126.824086 +1407,¾õ,1ȣ,36.780483,127.003249 +2556,øȰ(ѱü),5ȣ,37.516201,127.130923 +4136,øȰ(ѱü),9ȣ,37.516269,127.130288 +3205,,õ2ȣ,37.592928,126.673203 +3202,ձ,õ2ȣ,37.59518,126.642696 +208,սʸ(û),2ȣ,37.561238,127.036954 +2541,սʸ(û),5ȣ,37.56184,127.037059 +1013,սʸ(û),߾Ӽ,37.561827,127.038352 +1016,ܴ,1ȣ,37.596073,127.063549 +244,,2ȣ,37.561904,127.050899 +250,(빮û),2ȣ,37.574028,127.038091 +2725,븶,7ȣ,37.573647,127.086727 +1219,빮,߾Ӽ,37.48223,127.594647 +1003,,1ȣ,37.529849,126.964561 +2517,,5ȣ,37.548768,126.836318 +1211,,߾Ӽ,37.554669,127.310115 +4512,.۴,ο,37.237845,127.209198 +4211,,ö,37.492904,126.49379 +4924,,,37.653867,126.68393 +3227,(â),õ2ȣ,37.440127,126.75997 +1278,,߾Ӽ,37.725826,126.767257 +9000,,GTX-A,37.71614,126.72841 +1286,õ,߾Ӽ,37.879942,126.769999 +4814,,ؼ,37.31321,126.796261 +1951,,3ȣ,37.653324,126.843041 +1218,,߾Ӽ,37.468672,127.547076 +4815,,ؼ,37.302371,126.786691 +1884,,κд缱,37.413049,126.686648 +3130,,õ1ȣ,37.412333,126.687869 +1981,,ؼ,37.5239,126.8049 +1948,,3ȣ,37.650658,126.872642 +1020,,1ȣ,37.633212,127.058831 +2642,(),6ȣ,37.601948,127.041518 +1879,,κд缱,37.391769,126.742699 +2620,Ű(),6ȣ,37.569532,126.899298 +1282,,߾Ӽ,37.796188,126.792587 +203,3,2ȣ,37.566306,126.991696 +320,3,3ȣ,37.566672,126.992548 +204,4,2ȣ,37.566595,126.997817 +2536,4,5ȣ,37.567352,126.998032 +202,Ա,2ȣ,37.566014,126.982618 +1012,,߾Ӽ,37.549946,127.034538 +2611,,6ȣ,37.598605,126.915577 +1710,ǿ,1ȣ,37.320852,126.948217 +1906,,1ȣ,37.738415,127.045958 +4605,νû,ΰö,37.739256,127.034781 +4607,߾,ΰö,37.743676,127.049565 +241,̴,2ȣ,37.556733,126.946013 +1502,̸,氭,37.394655,127.127819 +1860,̸,κд缱,37.395371,127.128248 +2738,̼,7ȣ,37.485196,126.981605 +1508,õ,氭,37.265579,127.44226 +430,(߾ӹڹ),4ȣ,37.522295,126.974733 +1008,(߾ӹڹ),߾Ӽ,37.522427,126.973406 +2631,¿,6ȣ,37.534488,126.994302 +1455,δ,4ȣ,37.401553,126.976715 +1812,õ,1ȣ,37.476079,126.616801 +1891,õ,κд缱,37.476403,126.617326 +3215,õ,õ2ȣ,37.4897,126.675208 +4213,õ1͹̳,ö,37.447464,126.452508 +4215,õ2͹̳,ö,37.460699,126.441442 +1881,õ,κд缱,37.400614,126.722478 +3226,õ,õ2ȣ,37.448769,126.752618 +3136,õԱ,õ1ȣ,37.386007,126.639484 +3124,õû,õ1ȣ,37.457263,126.702143 +3221,õû,õ2ȣ,37.456833,126.701306 +3126,õ͹̳,õ1ȣ,37.442383,126.699706 +1888,ϴ,κд缱,37.448493,126.649619 +1275,ϻ,߾Ӽ,37.682077,126.769846 +338,Ͽ,3ȣ,37.483681,127.08439 +1285,,߾Ӽ,37.888421,126.746765 +3113,,õ1ȣ,37.545059,126.738665 +3116,,õ1ȣ,37.530415,126.722527 +216,(ıû),2ȣ,37.513262,127.100159 +2815,(ıû),8ȣ,37.514692,127.104338 +215,dz,2ȣ,37.520733,127.10379 +217,ǻ,2ȣ,37.511687,127.086162 +328,,3ȣ,37.512759,127.01122 +4923,,,37.643986,126.669017 +2742,¹,7ȣ,37.504898,126.93915 +2711,,7ȣ,37.700109,127.053196 +2820,,8ȣ,37.478703,127.126191 +2544,,5ȣ,37.56144,127.064623 +1918,,1ȣ,38.02458,127.0718 +4517,.,ο,37.285342,127.219561 +4710,,̽ż,37.603133,127.013396 +1956,߻,3ȣ,37.659477,126.773359 +1454,ΰõû,4ȣ,37.426513,126.98978 +1761,,4ȣ,37.351735,126.742989 +1857,,κд缱,37.365994,127.10807 +4312,,źд缱,37.367098,127.108403 +157,⵿,1ȣ,37.578103,127.034893 +1810,,1ȣ,37.466769,126.656666 +152,,1ȣ,37.570161,126.982923 +153,3,1ȣ,37.570406,126.991847 +319,3,3ȣ,37.571605,126.991791 +2535,3,5ȣ,37.57254,126.990305 +154,5,1ȣ,37.570926,127.001849 +218,տ,2ȣ,37.511022,127.073704 +4130,տ,9ȣ,37.511426,127.076275 +1809,־,1ȣ,37.465047,126.679742 +3218,־,õ2ȣ,37.464992,126.679098 +3217,־ȱ,õ2ȣ,37.473703,126.68113 +1957,ֿ,3ȣ,37.670072,126.761334 +1862,,κд缱,37.324753,127.107395 +2716,߰,7ȣ,37.644583,127.064303 +2726,߰,7ȣ,37.565923,127.08432 +1822,ߵ,1ȣ,37.486562,126.764843 +1201,߶,߾Ӽ,37.594917,127.076116 +1756,߾,4ȣ,37.315941,126.838573 +4138,߾Ӻƺ,9ȣ,37.529191,127.148739 +2721,ȭ,7ȣ,37.602545,127.079264 +4108,,9ȣ,37.557402,126.861939 +2618,(),6ȣ,37.583876,126.909645 +4503,,ο,37.269606,127.136515 +3135,,õ1ȣ,37.378384,126.645168 +1723,,1ȣ,37.0188,127.070444 +309,,3ȣ,37.648033,126.913917 +1220,,߾Ӽ,37.476393,127.629874 +1912,,1ȣ,37.892334,127.055716 +1726,,1ȣ,36.870593,127.143904 +1720,,1ȣ,37.109447,127.062278 +405,,4ȣ,37.7205,127.2034 +412,â,4ȣ,37.653088,127.047274 +1022,â,߾Ӽ,37.653007,127.047806 +2638,â,6ȣ,37.579661,127.015241 +1318,õ,ἱ,37.658978,127.285379 +1728,õ,1ȣ,36.810005,127.146826 +2751,õ,7ȣ,37.486637,126.838713 +2548,õȣ(dz伺),5ȣ,37.53864,127.123308 +2812,õȣ(dz伺),8ȣ,37.538113,127.123254 +2749,ö,7ȣ,37.47605,126.867911 +4310,ûԱ,źд缱,37.447211,127.055664 +2538,û,5ȣ,37.560276,127.013639 +2635,û,6ȣ,37.560608,127.013986 +2731,û,7ȣ,37.519365,127.05335 +4210,û,ö,37.556409,126.624648 +158,û(øԱ),1ȣ,37.579956,127.044585 +1014,û(øԱ),߾Ӽ,37.580759,127.0483 +1867,û,κд缱,37.259489,127.078934 +1321,û,ἱ,37.735488,127.42661 +4506,ʴ,ο,37.260752,127.159443 +1917,ʼ,1ȣ,37.98172,127.06912 +1505,ʿ,氭,37.374419,127.299 +4813,,ؼ,37.319619,126.808147 +1758,,4ȣ,37.320646,126.805913 +432,ѽŴԱ(̼),4ȣ,37.486263,126.981989 +3755,,7ȣ,37.50365,126.78828 +1329,õ,ἱ,37.885054,127.717023 +321,湫,3ȣ,37.56143,126.994072 +423,湫,4ȣ,37.561207,126.99408 +243,(Ա),2ȣ,37.559704,126.964378 +2532,(Ա),5ȣ,37.560236,126.9629 +3133,ķ۽Ÿ,õ1ȣ,37.387855,126.661673 +9001,Ųؽ,GTX-A,37.66532,126.74843 +1276,ź,߾Ӽ,37.694023,126.761086 +4615,ž,ΰö,37.733579,127.088704 +1404,,1ȣ,36.78866,127.08485 +2646,¸Ա,6ȣ,37.617338,127.074735 +2719,¸Ա,7ȣ,37.618294,127.075397 +1852,,κд缱,37.440019,127.127709 +3134,ũũ,õ1ȣ,37.382268,126.656365 +1314,,ἱ,37.648311,127.143952 +1283,,߾Ӽ,37.815298,126.792783 +1501,DZ,氭,37.394761,127.111217 +4311,DZ,źд缱,37.394761,127.112217 +1210,ȴ,߾Ӽ,37.547371,127.243939 +1317,ȣ,ἱ,37.653225,127.244493 +1456,,4ȣ,37.394287,126.963883 +1724,,1ȣ,36.990726,127.085159 +4927,dz,,37.612488,126.732387 +1274,dz,߾Ӽ,37.672346,126.786243 +2717,ϰ,7ȣ,37.636352,127.06799 +2565,ϳ˴ܻ,5ȣ,37.53972,127.22345 +2566,ϳû(dz-),5ȣ,37.54205,127.20612 +2564,ϳdz,5ȣ,37.552034,127.203864 +2733,е,7ȣ,37.514229,127.031656 +336,п,3ȣ,37.496663,127.070594 +2632,Ѱ,6ȣ,37.539631,127.001725 +1010,ѳ,߾Ӽ,37.52943,127.009169 +1755,Ѵ,4ȣ,37.309689,126.85344 +419,ѼԱ(Q),4ȣ,37.588458,127.006221 +4135,Ѽ,9ȣ,37.516404,127.116503 +209,Ѿ,2ȣ,37.555273,127.043655 +1024,Ƽ,κд缱,37.496237,127.052873 +238,,2ȣ,37.549457,126.913808 +2623,,6ȣ,37.549209,126.913366 +2540,,5ȣ,37.557322,127.029476 +1270,,߾Ӽ,37.612102,126.834146 +420,ȭ,4ȣ,37.582336,127.001844 +1882,ȣ,κд缱,37.401637,126.708627 +239,ȫԱ,2ȣ,37.55679,126.923708 +1293,ȫԱ,߾Ӽ,37.557641,126.926683 +1264,ȫԱ,߾Ӽ,37.557641,126.926683 +4203,ȫԱ,ö,37.557438,126.926715 +314,ȫ,3ȣ,37.589066,126.943736 +4705,ȭ,̽ż,37.634133,127.017511 +2518,ȭ,5ȣ,37.541513,126.840461 +2647,ȭ(←Ա),6ȣ,37.620064,127.084689 +1712,ȭ,1ȣ,37.283862,126.989627 +1268,ȭ,߾Ӽ,37.602888,126.868387 +1952,ȭ,3ȣ,37.634592,126.83265 +1015,ȸ,߾Ӽ,37.58946,127.057583 +1905,ȸ,1ȣ,37.724416,127.04736 +4602,ȸ,ΰö,37.725006,127.047073 +425,ȸ(빮),4ȣ,37.558514,126.978246 +4611,ȿ,ΰö,37.754025,127.076902 +2628,ȿâ,6ȣ,37.539233,126.961384 +1261,ȿâ,߾Ӽ,37.538579,126.96221 +4119,漮(߾ӴԱ),9ȣ,37.50877,126.963708 +4606,Q,ΰö,37.743302,127.037023 \ No newline at end of file