Skip to content
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
fbec6db
Add description
JavaWebinar Nov 5, 2016
81a0a1a
Add HW0 comments
JavaWebinar Nov 10, 2016
4f29fe7
Update README.md
JavaOPs Nov 30, 2016
fab7022
Update README.md
JavaOPs Dec 1, 2016
ce1caba
Update README.md
JavaOPs Dec 1, 2016
c01186b
Prepare to HW0
meirakhmetov Dec 4, 2016
25dc217
1_1_HW0
meirakhmetov Dec 21, 2016
f7860da
1_2_HW0_cycle
meirakhmetov Dec 21, 2016
f48e28a
1_3_switch_to_war
meirakhmetov Dec 21, 2016
1d4c218
1_4_add_servlet_api
meirakhmetov Dec 21, 2016
502dd4a
1_4_add_servlet_api2
meirakhmetov Dec 21, 2016
0f5921b
1_5_forward_to_redirect
meirakhmetov Dec 22, 2016
f0250cb
1_6_logging
meirakhmetov Dec 22, 2016
6b461d9
1_6_remote_jmx
meirakhmetov Dec 22, 2016
24b92d1
HW1
meirakhmetov Dec 23, 2016
274b8ef
HW1_CRUD
meirakhmetov Jan 16, 2017
d18ae8d
2_3_app_layers
meirakhmetov Jan 16, 2017
b7c1ab2
2_4_add_spring_context
meirakhmetov Jan 17, 2017
fc99f7b
2_5_add_dependency_injection
meirakhmetov Jan 17, 2017
9f611f4
2_5_add_dependency_injection
meirakhmetov Jan 17, 2017
14ffad3
2_6_add_annotation_processing
meirakhmetov Jan 17, 2017
2aa144c
3_0_fix_validate
meirakhmetov Jan 17, 2017
951c7d1
3_01_HW2_repository
meirakhmetov Jan 17, 2017
564049b
3_01_HW2_repository
meirakhmetov Jan 17, 2017
379c502
3_02_HW2_meal_layers
meirakhmetov Jan 17, 2017
07a9a74
3_03_HW2_optional_MealServlet
meirakhmetov Jan 17, 2017
6ed96bf
3_4_HW2_optional_filter
meirakhmetov Jan 17, 2017
bb68b77
3_5_HW2_optional_select_user
meirakhmetov Jan 17, 2017
1106ce7
3_06_bean_life_cycle
meirakhmetov Jan 17, 2017
0eed750
3_07_add_junit
meirakhmetov Jan 17, 2017
e1f7370
3_08_add_spring_test
meirakhmetov Jan 17, 2017
f2e869e
3_09_add_postgresql
meirakhmetov Jan 17, 2017
cd1216f
3_10_populate_and_init_db
meirakhmetov Jan 18, 2017
f7a4702
3_11_impl_JdbcUserRepository
meirakhmetov Jan 18, 2017
970bbd3
3_12_test_UserService
meirakhmetov Jan 18, 2017
3330e80
3_13_test_logging
meirakhmetov Jan 18, 2017
710f0b2
3_14_fix_servlet
meirakhmetov Jan 18, 2017
0b9d329
4_0_fix
meirakhmetov Jan 19, 2017
f0c9bcb
4_1_HW3
meirakhmetov Jan 19, 2017
071a6d5
4_2_HW3_optional
meirakhmetov Jan 19, 2017
da0852d
4_3_improve_code
meirakhmetov Jan 19, 2017
74a7205
4_4_init_and_populate_db
meirakhmetov Jan 19, 2017
577298e
4_5_create_mock_test_ctx
meirakhmetov Jan 19, 2017
21a38c3
Update README.md
meirakhmetov Nov 25, 2024
59b9c05
Update Main.java
meirakhmetov Nov 25, 2024
ade580e
added var test to Main.java
meirakhmetov Nov 25, 2024
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
Prev Previous commit
Next Next commit
3_02_HW2_meal_layers
  • Loading branch information
meirakhmetov committed Jan 17, 2017
commit 379c5024d4f1a5ede48cb3443af030747676c36c
14 changes: 14 additions & 0 deletions src/main/java/ru/javawebinar/topjava/SpringMain.java
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,15 @@
import org.springframework.context.support.ClassPathXmlApplicationContext;
import ru.javawebinar.topjava.model.Role;
import ru.javawebinar.topjava.model.User;
import ru.javawebinar.topjava.to.MealWithExceed;
import ru.javawebinar.topjava.web.meal.MealRestController;
import ru.javawebinar.topjava.web.user.AdminRestController;

import java.time.LocalDate;
import java.time.LocalTime;
import java.time.Month;
import java.util.Arrays;
import java.util.List;

/**
* User: gkislin
Expand All @@ -19,6 +25,14 @@ public static void main(String[] args) {
System.out.println("Bean definition names: " + Arrays.toString(appCtx.getBeanDefinitionNames()));
AdminRestController adminUserController = appCtx.getBean(AdminRestController.class);
adminUserController.create(new User(null, "userName", "email", "password", Role.ROLE_ADMIN));
System.out.println();

MealRestController mealController = appCtx.getBean(MealRestController.class);
List<MealWithExceed> filteredMealsWithExceeded =
mealController.getBetween(
LocalDate.of(2015, Month.MAY, 30), LocalTime.of(7, 0),
LocalDate.of(2015, Month.MAY, 31), LocalTime.of(11, 0));
filteredMealsWithExceeded.forEach(System.out::println);
}
}
}
18 changes: 2 additions & 16 deletions src/main/java/ru/javawebinar/topjava/model/Meal.java
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,7 @@
* GKislin
* 11.01.2015.
*/
public class Meal {
private Integer id;

public class Meal extends BaseEntity {
private final LocalDateTime dateTime;

private final String description;
Expand All @@ -22,20 +20,12 @@ public Meal(LocalDateTime dateTime, String description, int calories) {
}

public Meal(Integer id, LocalDateTime dateTime, String description, int calories) {
this.id = id;
super(id);
this.dateTime = dateTime;
this.description = description;
this.calories = calories;
}

public Integer getId() {
return id;
}

public void setId(Integer id) {
this.id = id;
}

public LocalDateTime getDateTime() {
return dateTime;
}
Expand All @@ -56,10 +46,6 @@ public LocalTime getTime() {
return dateTime.toLocalTime();
}

public boolean isNew() {
return id == null;
}

@Override
public String toString() {
return "Meal{" +
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package ru.javawebinar.topjava.repository.mock;

import org.springframework.stereotype.Repository;
import ru.javawebinar.topjava.model.Meal;
import ru.javawebinar.topjava.repository.MealRepository;
import ru.javawebinar.topjava.util.DateTimeUtil;
Expand All @@ -23,6 +24,7 @@
* GKislin
* 15.09.2015.
*/
@Repository
public class InMemoryMealRepositoryImpl implements MealRepository {

private static final Comparator<Meal> MEAL_COMPARATOR = Comparator.comparing(Meal::getDateTime).reversed();
Expand Down
23 changes: 23 additions & 0 deletions src/main/java/ru/javawebinar/topjava/service/MealService.java
Original file line number Diff line number Diff line change
@@ -1,8 +1,31 @@
package ru.javawebinar.topjava.service;

import ru.javawebinar.topjava.model.Meal;
import ru.javawebinar.topjava.util.exception.NotFoundException;

import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.util.Collection;

/**
* GKislin
* 15.06.2015.
*/
public interface MealService {
Meal get(int id, int userId) throws NotFoundException;

void delete(int id, int userId) throws NotFoundException;

default Collection<Meal> getBetweenDates(LocalDate startDate, LocalDate endDate, int userId) {
return getBetweenDateTimes(LocalDateTime.of(startDate, LocalTime.MIN), LocalDateTime.of(endDate, LocalTime.MAX), userId);
}

Collection<Meal> getBetweenDateTimes(LocalDateTime startDateTime, LocalDateTime endDateTime, int userId);

Collection<Meal> getAll(int userId);

Meal update(Meal meal, int userId) throws NotFoundException;

Meal save(Meal meal, int userId);
}
39 changes: 39 additions & 0 deletions src/main/java/ru/javawebinar/topjava/service/MealServiceImpl.java
Original file line number Diff line number Diff line change
@@ -1,13 +1,52 @@
package ru.javawebinar.topjava.service;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import ru.javawebinar.topjava.model.Meal;
import ru.javawebinar.topjava.repository.MealRepository;

import java.time.LocalDateTime;
import java.util.Collection;

import static ru.javawebinar.topjava.util.ValidationUtil.checkNotFoundWithId;

/**
* GKislin
* 06.03.2015.
*/
@Service
public class MealServiceImpl implements MealService {

@Autowired
private MealRepository repository;

@Override
public Meal get(int id, int userId) {
return checkNotFoundWithId(repository.get(id, userId), id);
}

@Override
public void delete(int id, int userId) {
checkNotFoundWithId(repository.delete(id, userId), id);
}

@Override
public Collection<Meal> getBetweenDateTimes(LocalDateTime startDateTime, LocalDateTime endDateTime, int userId) {
return repository.getBetween(startDateTime, endDateTime, userId);
}

@Override
public Collection<Meal> getAll(int userId) {
return repository.getAll(userId);
}

@Override
public Meal update(Meal meal, int userId) {
return checkNotFoundWithId(repository.save(meal, userId), meal.getId());
}

@Override
public Meal save(Meal meal, int userId) {
return repository.save(meal, userId);
}
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package ru.javawebinar.topjava.model;
package ru.javawebinar.topjava.to;

import java.time.LocalDateTime;

Expand Down
4 changes: 4 additions & 0 deletions src/main/java/ru/javawebinar/topjava/util/DateTimeUtil.java
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package ru.javawebinar.topjava.util;

import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;

Expand All @@ -10,6 +11,9 @@
public class DateTimeUtil {
public static final DateTimeFormatter DATE_TIME_FORMATTER = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm");

public static final LocalDate MIN_DATE = LocalDate.of(1, 1, 1);
public static final LocalDate MAX_DATE = LocalDate.of(3000, 1, 1);

public static <T extends Comparable<? super T>> boolean isBetween(T value, T start, T end) {
return value.compareTo(start) >= 0 && value.compareTo(end) <= 0;
}
Expand Down
4 changes: 2 additions & 2 deletions src/main/java/ru/javawebinar/topjava/util/MealsUtil.java
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package ru.javawebinar.topjava.util;

import ru.javawebinar.topjava.model.Meal;
import ru.javawebinar.topjava.model.MealWithExceed;
import ru.javawebinar.topjava.to.MealWithExceed;

import java.time.LocalDate;
import java.time.LocalDateTime;
Expand Down Expand Up @@ -67,4 +67,4 @@ public static List<MealWithExceed> getFilteredWithExceededByCycle(List<Meal> mea
public static MealWithExceed createWithExceed(Meal meal, boolean exceeded) {
return new MealWithExceed(meal.getId(), meal.getDateTime(), meal.getDescription(), meal.getCalories(), exceeded);
}
}
}
Original file line number Diff line number Diff line change
@@ -1,12 +1,77 @@
package ru.javawebinar.topjava.web.meal;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import ru.javawebinar.topjava.AuthorizedUser;
import ru.javawebinar.topjava.model.Meal;
import ru.javawebinar.topjava.service.MealService;
import ru.javawebinar.topjava.to.MealWithExceed;
import ru.javawebinar.topjava.util.DateTimeUtil;
import ru.javawebinar.topjava.util.MealsUtil;

import java.time.LocalDate;
import java.time.LocalTime;
import java.util.List;

import static ru.javawebinar.topjava.util.ValidationUtil.checkIdConsistent;
import static ru.javawebinar.topjava.util.ValidationUtil.checkNew;

/**
* GKislin
* 06.03.2015.
*/
@Controller
public class MealRestController {
private static final Logger LOG = LoggerFactory.getLogger(MealRestController.class);

@Autowired
private MealService service;

public Meal get(int id) {
int userId = AuthorizedUser.id();
LOG.info("get meal {} for User {}", id, userId);
return service.get(id, userId);
}

public void delete(int id) {
int userId = AuthorizedUser.id();
LOG.info("delete meal {} for User {}", id, userId);
service.delete(id, userId);
}

public List<MealWithExceed> getAll() {
int userId = AuthorizedUser.id();
LOG.info("getAll for User {}", userId);
return MealsUtil.getWithExceeded(service.getAll(userId), AuthorizedUser.getCaloriesPerDay());
}

public Meal create(Meal meal) {
checkNew(meal);
int userId = AuthorizedUser.id();
LOG.info("create {} for User {}", meal, userId);
return service.save(meal, userId);
}

public void update(Meal meal, int id) {
checkIdConsistent(meal, id);
int userId = AuthorizedUser.id();
LOG.info("update {} for User {}", meal, userId);
service.update(meal, userId);
}

public List<MealWithExceed> getBetween(LocalDate startDate, LocalTime startTime, LocalDate endDate, LocalTime endTime) {
int userId = AuthorizedUser.id();
LOG.info("getBetween dates {} - {} for time {} - {} for User {}", startDate, endDate, startTime, endTime, userId);

return MealsUtil.getFilteredWithExceeded(
service.getBetweenDates(
startDate != null ? startDate : DateTimeUtil.MIN_DATE,
endDate != null ? endDate : DateTimeUtil.MAX_DATE, userId),
startTime != null ? startTime : LocalTime.MIN,
endTime != null ? endTime : LocalTime.MAX,
AuthorizedUser.getCaloriesPerDay()
);
}
}
2 changes: 1 addition & 1 deletion src/main/webapp/meals.jsp
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@
</tr>
</thead>
<c:forEach items="${meals}" var="meal">
<jsp:useBean id="meal" scope="page" type="ru.javawebinar.topjava.model.MealWithExceed"/>
<jsp:useBean id="meal" scope="page" type="ru.javawebinar.topjava.to.MealWithExceed"/>
<tr class="${meal.exceed ? 'exceeded' : 'normal'}">
<td>
<%--${meal.dateTime.toLocalDate()} ${meal.dateTime.toLocalTime()}--%>
Expand Down