Use Instant in DTO

This commit is contained in:
René Pfeuffer
2018-06-01 14:19:12 +02:00
parent cb4f2e49d9
commit c62168274d
7 changed files with 66 additions and 12 deletions

View File

@@ -1,15 +1,13 @@
package sonia.scm.api.v2.resources;
import org.apache.shiro.SecurityUtils;
import org.mapstruct.AfterMapping;
import org.mapstruct.Context;
import org.mapstruct.Mapper;
import org.mapstruct.MappingTarget;
import org.mapstruct.*;
import sonia.scm.api.rest.resources.UserResource;
import sonia.scm.security.Role;
import sonia.scm.user.User;
import javax.ws.rs.core.UriInfo;
import java.time.Instant;
import java.util.HashMap;
import java.util.Map;
@@ -36,4 +34,9 @@ public abstract class User2UserDtoMapper {
}
target.setLinks(links);
}
@Mappings({@Mapping(target = "lastModified"), @Mapping(target = "creationDate")})
Instant mapTime(Long epochMilli) {
return epochMilli == null? null: Instant.ofEpochMilli(epochMilli);
}
}

View File

@@ -3,15 +3,16 @@ package sonia.scm.api.v2.resources;
import lombok.Data;
import javax.xml.bind.annotation.XmlElement;
import java.time.Instant;
import java.util.Map;
@Data
public class UserDto {
private boolean active;
private boolean admin;
private Long creationDate;
private Instant creationDate;
private String displayName;
private Long lastModified;
private Instant lastModified;
private String mail;
private String name;
private String password;

View File

@@ -2,12 +2,11 @@ package sonia.scm.api.v2.resources;
import com.google.inject.Inject;
import org.apache.shiro.authc.credential.PasswordService;
import org.mapstruct.Context;
import org.mapstruct.Mapper;
import org.mapstruct.Mapping;
import org.mapstruct.Named;
import org.mapstruct.*;
import sonia.scm.user.User;
import java.time.Instant;
import static sonia.scm.api.rest.resources.UserResource.DUMMY_PASSWORT;
@Mapper
@@ -30,6 +29,10 @@ public abstract class UserDto2UserMapper {
{
return passwordService.encryptPassword(password);
}
}
@Mappings({@Mapping(target = "lastModified"), @Mapping(target = "creationDate")})
Long mapTime(Instant instant) {
return instant == null? null: instant.toEpochMilli();
}
}