Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -205,6 +205,15 @@ public Page<Item> filterItems(
}

case RECOMMENDED: {
if (longitude != null && latitude != null && radiusInMeters != null) {
BooleanExpression within = Expressions.booleanTemplate(
"function('ST_DistanceSphere', {0}, function('ST_SetSRID', function('ST_MakePoint', {1}, {2}), 4326)) <= {3}",
ITEM.location, longitude, latitude, radiusInMeters
);
content.where(within);
count.where(within);
}

NumberExpression<Double> recommendedScoreExpr = buildRecommendedScoreExpression(
memberId,
userInteractionScores,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -217,7 +217,7 @@ public ItemResponse getItemList(ItemRequest request) {
// 회원 위치 조회
Double longitude = null;
Double latitude = null;
if (sortField == ItemSortField.DISTANCE) {
if (sortField == ItemSortField.DISTANCE || sortField == ItemSortField.RECOMMENDED) {
Point<G2D> geom = memberLocationRepository.findByMemberMemberId(request.getMember().getMemberId())
.orElseThrow(() -> new CustomException(ErrorCode.MEMBER_LOCATION_NOT_FOUND))
.getGeom();
Expand All @@ -226,13 +226,18 @@ public ItemResponse getItemList(ItemRequest request) {
}

// 회원 탐색 범위 조회
Double radiusInMeters;
if (request.getMember().getSearchRadiusInMeters() != null) {
radiusInMeters = request.getMember().getSearchRadiusInMeters();
} else {
Double radiusInMeters = request.getMember().getSearchRadiusInMeters();

if (radiusInMeters == null) {
radiusInMeters = request.getRadiusInMeters();
}

// 회원 탐색 범위 미설정 시 10km로 적용
if (radiusInMeters == null) {
radiusInMeters = 10000.0;
log.debug("회원 탐색 범위 미설정 - 10km 적용: memberId={}", request.getMember().getMemberId());
}

List<UserInteractionScore> userScores = null;
List<ItemCategory> preferredCategories = null;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -126,6 +126,7 @@ ResponseEntity<ItemResponse> postLike(
);

@ApiChangeLogs({
@ApiChangeLog(date = "2026.02.27", author = Author.KIMNAYOUNG, issueNumber = 538, description = "추천 물품 리스트 조회 시 사용자 반경내 물품만 반환"),
@ApiChangeLog(date = "2026.02.10", author = Author.SUHSAECHAN, issueNumber = 496, description = "물품 리스트 조회 시 각 Item 내부에 신고 여부(isReported) 플래그 추가"),
@ApiChangeLog(date = "2026.01.20", author = Author.KIMNAYOUNG, issueNumber = 443, description = "사용자 맞춤형 추천 시스템 추가"),
@ApiChangeLog(date = "2026.01.03", author = Author.WISEUNGJAE, issueNumber = 428, description = "물품 탐색 시, 차단된 회원의 물품을 제외하는 로직 추가"),
Expand Down Expand Up @@ -340,6 +341,10 @@ ResponseEntity<ItemResponse> postLike(
- PREFERRED_CATEGORY / ASC : 선호 카테고리와 물품 간의 유사도가 높은 순으로 정렬된 물품 리스트
- RECOMMENDED / ASC : 추천 순으로 정렬된 물품 리스트
- sortField, sortDirection이 null인 경우 기본값은 CREATED_DATE, DESC

## 에러코드
- **`EMBEDDING_NOT_FOUND`**: 임베딩을 찾을 수 없습니다. (회원 선호 카테고리 임베딩)
- **`MEMBER_LOCATION_NOT_FOUND`**: 회원 위치 정보가 등록되지 않았습니다.
"""
)
ResponseEntity<ItemResponse> getItemList(
Expand Down