mirror of
https://github.com/immich-app/immich.git
synced 2026-05-23 08:02:29 -04:00
1fcc2b704b
* feat(server)!: add owned filter to albums API BREAKING CHANGE: GET /albums with no parameters now returns all accessible albums (owned + shared-with-me) instead of only owned albums. * document tri-state matrix * web impl * collapse to single method and handover branching to sql * dedupe * verify that owned, shared, and notShared counts are mapped independently from their respective queries * refactor(server): add select:['id'] overload to albumRepository.getAll Avoid fetching full album rows (with albumUsers/sharedLinks subqueries) in map.service where only album IDs are needed. * focus relevant test filters * fmt * Revert "verify that owned, shared, and notShared counts are mapped independently from their respective queries" This reverts commit 47aab458192c766de4662aada5a6841b091d2a80. * sync sql * Revert "document tri-state matrix" This reverts commit a5b2355d0c6a084f2c021d517bf5ee80123d108c. * address review comments * inline shared condition and return as ternary * sync sql * use [...albums].sort Array.toSorted() is not supported in Chrome 109 * use isShared and isOwned nomenclature * fix e2e tests * add params to sql query
28 lines
1.1 KiB
TypeScript
28 lines
1.1 KiB
TypeScript
import { Injectable } from '@nestjs/common';
|
|
import { AuthDto } from 'src/dtos/auth.dto';
|
|
import { MapMarkerDto, MapMarkerResponseDto, MapReverseGeocodeDto } from 'src/dtos/map.dto';
|
|
import { BaseService } from 'src/services/base.service';
|
|
import { getMyPartnerIds } from 'src/utils/asset.util';
|
|
|
|
@Injectable()
|
|
export class MapService extends BaseService {
|
|
async getMapMarkers(auth: AuthDto, options: MapMarkerDto): Promise<MapMarkerResponseDto[]> {
|
|
const userIds = [auth.user.id];
|
|
if (options.withPartners) {
|
|
const partnerIds = await getMyPartnerIds({ userId: auth.user.id, repository: this.partnerRepository });
|
|
userIds.push(...partnerIds);
|
|
}
|
|
|
|
const albumIds = options.withSharedAlbums ? await this.albumRepository.getAllIds(auth.user.id) : [];
|
|
|
|
return this.mapRepository.getMapMarkers(userIds, albumIds, options);
|
|
}
|
|
|
|
async reverseGeocode(dto: MapReverseGeocodeDto) {
|
|
const { lat: latitude, lon: longitude } = dto;
|
|
// eventually this should probably return an array of results
|
|
const result = await this.mapRepository.reverseGeocode({ latitude, longitude });
|
|
return result ? [result] : [];
|
|
}
|
|
}
|