Merge branch 'tibor' into 'master'
API 1.0.26 ExercisePlanTemplate See merge request bossanyit/aitrainer_server!41
This commit is contained in:
commit
3ddcfa6c4d
@ -11,7 +11,7 @@ plugins {
|
|||||||
}
|
}
|
||||||
|
|
||||||
group = "com.aitrainer"
|
group = "com.aitrainer"
|
||||||
version = "1.0.25"
|
version = "1.0.26"
|
||||||
java.sourceCompatibility = JavaVersion.VERSION_1_8
|
java.sourceCompatibility = JavaVersion.VERSION_1_8
|
||||||
|
|
||||||
repositories {
|
repositories {
|
||||||
|
@ -529,16 +529,18 @@ CREATE TABLE IF NOT EXISTS `exercise_plan` (
|
|||||||
`private` tinyint(4) DEFAULT 0,
|
`private` tinyint(4) DEFAULT 0,
|
||||||
`date_add` datetime DEFAULT NULL,
|
`date_add` datetime DEFAULT NULL,
|
||||||
`date_upd` datetime DEFAULT NULL,
|
`date_upd` datetime DEFAULT NULL,
|
||||||
|
`type` ENUM('custom','mini_test_set','special') NULL DEFAULT NULL COLLATE 'utf8mb4_general_ci',
|
||||||
|
`exercise_plan_template_id` INT(11) NULL DEFAULT NULL,
|
||||||
PRIMARY KEY (`exercise_plan_id`)
|
PRIMARY KEY (`exercise_plan_id`)
|
||||||
) ENGINE=InnoDB AUTO_INCREMENT=104 DEFAULT CHARSET=utf8mb4;
|
) ENGINE=InnoDB AUTO_INCREMENT=104 DEFAULT CHARSET=utf8mb4;
|
||||||
|
|
||||||
-- Tábla adatainak mentése aitrainer2.exercise_plan: ~4 rows (hozzávetőleg)
|
-- Tábla adatainak mentése aitrainer2.exercise_plan: ~4 rows (hozzávetőleg)
|
||||||
/*!40000 ALTER TABLE `exercise_plan` DISABLE KEYS */;
|
/*!40000 ALTER TABLE `exercise_plan` DISABLE KEYS */;
|
||||||
REPLACE INTO `exercise_plan` (`exercise_plan_id`, `customer_id`, `name`, `description`, `private`, `date_add`, `date_upd`) VALUES
|
REPLACE INTO `exercise_plan` (`exercise_plan_id`, `customer_id`, `name`, `description`, `private`, `date_add`, `date_upd`) VALUES
|
||||||
(3, 90, 'Common', 'Common training plan', 0, NULL, NULL),
|
(3, 90, 'Common', 'Common training plan', 0, NULL, NULL, NULL, NULL),
|
||||||
(4, 90, 'Chuck Norris Plan', '', 0, NULL, NULL),
|
(4, 90, 'Chuck Norris Plan', '', 0, NULL, NULL, NULL, NULL),
|
||||||
(6, 90, 'Boss private', '', 1, '2020-09-08 00:06:26', NULL),
|
(6, 90, 'Boss private', '', 1, '2020-09-08 00:06:26', NULL, NULL, NULL),
|
||||||
(20, 90, 'Boss private 2', NULL, 1, '2020-09-09 00:06:19', NULL);
|
(20, 90, 'Boss private 2', NULL, 1, '2020-09-09 00:06:19', NULL, NULL, NULL);
|
||||||
/*!40000 ALTER TABLE `exercise_plan` ENABLE KEYS */;
|
/*!40000 ALTER TABLE `exercise_plan` ENABLE KEYS */;
|
||||||
|
|
||||||
-- Struktúra mentése tábla aitrainer2. exercise_plan_detail
|
-- Struktúra mentése tábla aitrainer2. exercise_plan_detail
|
||||||
@ -938,6 +940,46 @@ COLLATE='utf8_hungarian_ci'
|
|||||||
ENGINE=InnoDB
|
ENGINE=InnoDB
|
||||||
;
|
;
|
||||||
|
|
||||||
|
CREATE TABLE `exercise_plan_template` (
|
||||||
|
`exercise_plan_template_id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`template_type` ENUM('special','mini_test_set') NULL DEFAULT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
`name` CHAR(50) NULL DEFAULT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
`description` MEDIUMTEXT NULL DEFAULT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
PRIMARY KEY (`exercise_plan_template_id`) USING BTREE,
|
||||||
|
INDEX `template_type` (`template_type`) USING BTREE
|
||||||
|
)
|
||||||
|
COLLATE='utf8_hungarian_ci'
|
||||||
|
ENGINE=InnoDB
|
||||||
|
;
|
||||||
|
|
||||||
|
CREATE TABLE `exercise_plan_template_detail` (
|
||||||
|
`exercise_plan_template_detail_id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`exercise_plan_template_id` INT(11) NOT NULL DEFAULT '0',
|
||||||
|
`exercise_type_id` INT(11) NOT NULL DEFAULT '0',
|
||||||
|
`quantity` DOUBLE NULL DEFAULT '0',
|
||||||
|
`quantity_unit_quantity` DOUBLE NULL DEFAULT '0',
|
||||||
|
`serie` INT(11) NULL DEFAULT '0',
|
||||||
|
`resting_time` TIME NULL DEFAULT '00:00:00',
|
||||||
|
PRIMARY KEY (`exercise_plan_template_detail_id`) USING BTREE,
|
||||||
|
INDEX `exercise_type_id` (`exercise_type_id`) USING BTREE,
|
||||||
|
INDEX `exercise_plan_template_id` (`exercise_plan_template_id`) USING BTREE
|
||||||
|
)
|
||||||
|
COLLATE='utf8_hungarian_ci'
|
||||||
|
ENGINE=InnoDB
|
||||||
|
;
|
||||||
|
|
||||||
|
CREATE TABLE `exercise_plan_template_translation` (
|
||||||
|
`translation_id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`exercise_plan_template_id` INT(11) NULL DEFAULT NULL,
|
||||||
|
`language_code` CHAR(2) NOT NULL DEFAULT '0' COLLATE 'utf8mb4_general_ci',
|
||||||
|
`name` CHAR(50) NULL DEFAULT '0' COLLATE 'utf8mb4_general_ci',
|
||||||
|
`description` TEXT NULL DEFAULT NULL COLLATE 'utf8mb4_general_ci',
|
||||||
|
PRIMARY KEY (`translation_id`) USING BTREE
|
||||||
|
)
|
||||||
|
COLLATE='utf8mb4_general_ci'
|
||||||
|
ENGINE=InnoDB
|
||||||
|
;
|
||||||
|
|
||||||
|
|
||||||
/*!40101 SET SQL_MODE=IFNULL(@OLD_SQL_MODE, '') */;
|
/*!40101 SET SQL_MODE=IFNULL(@OLD_SQL_MODE, '') */;
|
||||||
/*!40014 SET FOREIGN_KEY_CHECKS=IF(@OLD_FOREIGN_KEY_CHECKS IS NULL, 1, @OLD_FOREIGN_KEY_CHECKS) */;
|
/*!40014 SET FOREIGN_KEY_CHECKS=IF(@OLD_FOREIGN_KEY_CHECKS IS NULL, 1, @OLD_FOREIGN_KEY_CHECKS) */;
|
||||||
|
50
data/db/update_1_0_26.sql
Normal file
50
data/db/update_1_0_26.sql
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
START TRANSACTION;
|
||||||
|
|
||||||
|
CREATE TABLE `exercise_plan_template` (
|
||||||
|
`exercise_plan_template_id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`template_type` ENUM('special','mini_test_set') NULL DEFAULT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
`name` CHAR(50) NULL DEFAULT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
`description` TEXT NULL DEFAULT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
PRIMARY KEY (`exercise_plan_template_id`) USING BTREE,
|
||||||
|
INDEX `template_type` (`template_type`) USING BTREE
|
||||||
|
)
|
||||||
|
COLLATE='utf8_hungarian_ci'
|
||||||
|
ENGINE=InnoDB
|
||||||
|
;
|
||||||
|
|
||||||
|
CREATE TABLE `exercise_plan_template_detail` (
|
||||||
|
`exercise_plan_template_detail_id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`exercise_plan_template_id` INT(11) NOT NULL DEFAULT '0',
|
||||||
|
`exercise_type_id` INT(11) NOT NULL DEFAULT '0',
|
||||||
|
`quantity` DOUBLE NULL DEFAULT '0',
|
||||||
|
`quantity_unit_quantity` DOUBLE NULL DEFAULT '0',
|
||||||
|
`serie` INT(11) NULL DEFAULT '0',
|
||||||
|
`resting_time` TIME NULL DEFAULT '00:00:00',
|
||||||
|
PRIMARY KEY (`exercise_plan_template_detail_id`) USING BTREE,
|
||||||
|
INDEX `exercise_type_id` (`exercise_type_id`) USING BTREE,
|
||||||
|
INDEX `exercise_plan_template_id` (`exercise_plan_template_id`) USING BTREE
|
||||||
|
)
|
||||||
|
COLLATE='utf8_hungarian_ci'
|
||||||
|
ENGINE=InnoDB
|
||||||
|
;
|
||||||
|
|
||||||
|
CREATE TABLE `exercise_plan_template_translation` (
|
||||||
|
`translation_id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`exercise_plan_template_id` INT(11) NULL DEFAULT NULL,
|
||||||
|
`language_code` CHAR(2) NOT NULL DEFAULT '0' COLLATE 'utf8_hungarian_ci',
|
||||||
|
`name` CHAR(50) NULL DEFAULT '0' COLLATE 'utf8_hungarian_ci',
|
||||||
|
`description` TEXT NULL DEFAULT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
PRIMARY KEY (`translation_id`) USING BTREE
|
||||||
|
)
|
||||||
|
COLLATE='utf8_hungarian_ci'
|
||||||
|
ENGINE=InnoDB
|
||||||
|
;
|
||||||
|
|
||||||
|
ALTER TABLE `exercise_plan`
|
||||||
|
ADD COLUMN `type` ENUM('custom','mini_test_set','special') NULL DEFAULT NULL AFTER `date_upd`,
|
||||||
|
ADD COLUMN `exercise_plan_template_id` INT NULL DEFAULT NULL AFTER `type`;
|
||||||
|
|
||||||
|
UPDATE configuration set config_value = "1.0.26", date_change=CURRENT_DATE WHERE config_key = "db_version";
|
||||||
|
|
||||||
|
COMMIT;
|
||||||
|
|
@ -18,7 +18,8 @@ class PackageController(private val exerciseAbilityRepository: ExerciseAbilityRe
|
|||||||
private val propertyRepository: PropertyRepository,
|
private val propertyRepository: PropertyRepository,
|
||||||
private val productRepository: ProductRepository,
|
private val productRepository: ProductRepository,
|
||||||
private val exerciseDeviceRepository: ExerciseDeviceRepository,
|
private val exerciseDeviceRepository: ExerciseDeviceRepository,
|
||||||
private val exerciseTreeParentsRepository: ExerciseTreeParentsRepository
|
private val exerciseTreeParentsRepository: ExerciseTreeParentsRepository,
|
||||||
|
private val exercisePlanTemplateRepository: ExercisePlanTemplateRepository
|
||||||
) {
|
) {
|
||||||
private val logger = LoggerFactory.getLogger(javaClass)
|
private val logger = LoggerFactory.getLogger(javaClass)
|
||||||
|
|
||||||
@ -51,6 +52,9 @@ class PackageController(private val exerciseAbilityRepository: ExerciseAbilityRe
|
|||||||
val listExerciseTreeParents = exerciseTreeParentsRepository.findAll()
|
val listExerciseTreeParents = exerciseTreeParentsRepository.findAll()
|
||||||
val listExerciseTreeParentsJson: String = gson.toJson(listExerciseTreeParents)
|
val listExerciseTreeParentsJson: String = gson.toJson(listExerciseTreeParents)
|
||||||
|
|
||||||
|
val listPlanTemplate = exercisePlanTemplateRepository.findAll()
|
||||||
|
val listPlanTemplateJson: String = gson.toJson(listPlanTemplate)
|
||||||
|
|
||||||
|
|
||||||
val packageJson: String =
|
val packageJson: String =
|
||||||
getClassRecord(ExerciseDevice::class.simpleName, listDevicesJson) +
|
getClassRecord(ExerciseDevice::class.simpleName, listDevicesJson) +
|
||||||
@ -59,7 +63,8 @@ class PackageController(private val exerciseAbilityRepository: ExerciseAbilityRe
|
|||||||
"|||" + getClassRecord(ExerciseTree::class.simpleName, listExerciseTreeJson) +
|
"|||" + getClassRecord(ExerciseTree::class.simpleName, listExerciseTreeJson) +
|
||||||
"|||" + getClassRecord(ExerciseType::class.simpleName, listExerciseTypeJson) +
|
"|||" + getClassRecord(ExerciseType::class.simpleName, listExerciseTypeJson) +
|
||||||
"|||" + getClassRecord(ExerciseAbility::class.simpleName, listExerciseAbilityJson) +
|
"|||" + getClassRecord(ExerciseAbility::class.simpleName, listExerciseAbilityJson) +
|
||||||
"|||" + getClassRecord(ExerciseTreeParents::class.simpleName, listExerciseTreeParentsJson)
|
"|||" + getClassRecord(ExerciseTreeParents::class.simpleName, listExerciseTreeParentsJson) +
|
||||||
|
"|||" + getClassRecord(ExercisePlanTemplate::class.simpleName, listPlanTemplateJson)
|
||||||
|
|
||||||
return if (packageJson.isEmpty()) ResponseEntity.notFound().build() else
|
return if (packageJson.isEmpty()) ResponseEntity.notFound().build() else
|
||||||
ResponseEntity.ok().body(packageJson)
|
ResponseEntity.ok().body(packageJson)
|
||||||
|
@ -0,0 +1,23 @@
|
|||||||
|
package com.aitrainer.api.model
|
||||||
|
|
||||||
|
import com.google.gson.annotations.Expose
|
||||||
|
import org.hibernate.annotations.Fetch
|
||||||
|
import org.hibernate.annotations.FetchMode
|
||||||
|
import org.springframework.lang.NonNull
|
||||||
|
import javax.persistence.*
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
data class ExercisePlanTemplate(
|
||||||
|
@Expose @Id @GeneratedValue(strategy = GenerationType.IDENTITY) var exercisePlanTemplateId: Int = 0,
|
||||||
|
@Expose @get: NonNull var name: String? = null,
|
||||||
|
@Expose @get: NonNull var description: String? = null,
|
||||||
|
@Expose @get: NonNull var templateType: String? = null
|
||||||
|
) {
|
||||||
|
@OneToMany(fetch = FetchType.EAGER, mappedBy = "exercisePlanTemplate")
|
||||||
|
@Fetch(value = FetchMode.SUBSELECT)
|
||||||
|
@Expose val translations: List<ExercisePlanTemplateTranslation> = mutableListOf<ExercisePlanTemplateTranslation>()
|
||||||
|
|
||||||
|
@OneToMany(fetch = FetchType.EAGER, mappedBy = "exercisePlanTemplate")
|
||||||
|
@Fetch(value = FetchMode.SUBSELECT)
|
||||||
|
@Expose val details: List<ExercisePlanTemplateDetail> = mutableListOf<ExercisePlanTemplateDetail>()
|
||||||
|
}
|
@ -0,0 +1,24 @@
|
|||||||
|
package com.aitrainer.api.model
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnore
|
||||||
|
import com.google.gson.annotations.Expose
|
||||||
|
import org.springframework.lang.NonNull
|
||||||
|
import javax.persistence.*
|
||||||
|
import javax.validation.constraints.Null
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
data class ExercisePlanTemplateDetail (
|
||||||
|
@Expose @Id @GeneratedValue(strategy = GenerationType.IDENTITY) var exercisePlanTemplateDetailId: Long = 0,
|
||||||
|
@Expose @get: NonNull var exerciseTypeId: Int = 0,
|
||||||
|
@Expose @get: Null var serie: Int? = 0,
|
||||||
|
@Expose @get: Null var quantity: Double? = 0.0,
|
||||||
|
@Expose @get: Null var quantityUnitQuantity: Double? = 0.0,
|
||||||
|
@Expose @get: NonNull var restingTime: String? = null
|
||||||
|
|
||||||
|
|
||||||
|
) {
|
||||||
|
@ManyToOne(fetch = FetchType.LAZY, optional = false)
|
||||||
|
@JoinColumn(name = "exercisePlanTemplateId", nullable = false)
|
||||||
|
@JsonIgnore
|
||||||
|
val exercisePlanTemplate: ExercisePlanTemplate? = null
|
||||||
|
}
|
@ -0,0 +1,23 @@
|
|||||||
|
package com.aitrainer.api.model
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnore
|
||||||
|
import com.google.gson.annotations.Expose
|
||||||
|
import javax.persistence.*
|
||||||
|
import javax.validation.constraints.NotBlank
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
data class ExercisePlanTemplateTranslation (
|
||||||
|
@Expose @Id @GeneratedValue(strategy = GenerationType.IDENTITY) val translationId: Long = 0,
|
||||||
|
|
||||||
|
@Expose @get: NotBlank var languageCode: String?,
|
||||||
|
@Expose @get: NotBlank var name: String = "",
|
||||||
|
@Expose @get: NotBlank var description: String = "",
|
||||||
|
|
||||||
|
|
||||||
|
) {
|
||||||
|
@ManyToOne(fetch = FetchType.EAGER, optional = false)
|
||||||
|
@JoinColumn(name = "exercisePlanTemplateId", nullable = false)
|
||||||
|
@JsonIgnore
|
||||||
|
val exercisePlanTemplate: ExercisePlanTemplate? = null
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,9 @@
|
|||||||
|
package com.aitrainer.api.repository
|
||||||
|
|
||||||
|
import com.aitrainer.api.model.ExercisePlanTemplate
|
||||||
|
import org.springframework.data.jpa.repository.JpaRepository
|
||||||
|
import org.springframework.stereotype.Repository
|
||||||
|
|
||||||
|
@Repository
|
||||||
|
interface ExercisePlanTemplateRepository: JpaRepository<ExercisePlanTemplate, Int> {
|
||||||
|
}
|
@ -17,6 +17,6 @@ logging.config=classpath:logback-spring.xml
|
|||||||
logging.file=logs
|
logging.file=logs
|
||||||
|
|
||||||
# if the database structure has been changed, increment this version number
|
# if the database structure has been changed, increment this version number
|
||||||
application.version=1.0.25
|
application.version=1.0.26
|
||||||
|
|
||||||
jwt.secret=aitrainer
|
jwt.secret=aitrainer
|
@ -17,6 +17,6 @@ logging.config=classpath:logback-spring.xml
|
|||||||
logging.file=logs
|
logging.file=logs
|
||||||
|
|
||||||
# if the database structure has been changed, increment this version number
|
# if the database structure has been changed, increment this version number
|
||||||
application.version=1.0.25
|
application.version=1.0.26
|
||||||
|
|
||||||
jwt.secret=aitrainer
|
jwt.secret=aitrainer
|
@ -31,6 +31,8 @@ class AppPackageTest {
|
|||||||
private lateinit var exerciseDeviceRepository: ExerciseDeviceRepository
|
private lateinit var exerciseDeviceRepository: ExerciseDeviceRepository
|
||||||
@Autowired
|
@Autowired
|
||||||
private lateinit var exerciseTreeParentsRepository: ExerciseTreeParentsRepository
|
private lateinit var exerciseTreeParentsRepository: ExerciseTreeParentsRepository
|
||||||
|
@Autowired
|
||||||
|
private lateinit var exercisePlanTemplateRepository: ExercisePlanTemplateRepository
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun testAppPackage() {
|
fun testAppPackage() {
|
||||||
@ -43,7 +45,8 @@ class AppPackageTest {
|
|||||||
propertyRepository,
|
propertyRepository,
|
||||||
productRepository,
|
productRepository,
|
||||||
exerciseDeviceRepository,
|
exerciseDeviceRepository,
|
||||||
exerciseTreeParentsRepository
|
exerciseTreeParentsRepository,
|
||||||
|
exercisePlanTemplateRepository
|
||||||
)
|
)
|
||||||
val response: ResponseEntity<*> = controller.getPackageData()
|
val response: ResponseEntity<*> = controller.getPackageData()
|
||||||
|
|
||||||
@ -86,6 +89,16 @@ class AppPackageTest {
|
|||||||
assertEquals(listParents[2].exerciseTreeParentId, 0)
|
assertEquals(listParents[2].exerciseTreeParentId, 0)
|
||||||
assertEquals(listParents[6].exerciseTreeParentId, 4)
|
assertEquals(listParents[6].exerciseTreeParentId, 4)
|
||||||
assertEquals(listParents[6].exerciseTreeChildId, 9)
|
assertEquals(listParents[6].exerciseTreeChildId, 9)
|
||||||
|
} else if (record[0] == ExercisePlanTemplate::class.simpleName) {
|
||||||
|
val exercisePlanTemplateJson: String = record[1]
|
||||||
|
val type = object : TypeToken<List<ExercisePlanTemplate?>?>() {}.type
|
||||||
|
val listTemplate: List<ExercisePlanTemplate> = gson.fromJson(exercisePlanTemplateJson, type)
|
||||||
|
assertTrue(listTemplate.isNotEmpty())
|
||||||
|
assertEquals(listTemplate[0].name, "Own Body")
|
||||||
|
assertEquals(listTemplate[0].templateType, "mini_test_set")
|
||||||
|
assertEquals(listTemplate[0].translations[0].name, "Saját testes tesztek")
|
||||||
|
assertEquals(listTemplate[0].details[0].exerciseTypeId, 2)
|
||||||
|
assertEquals(listTemplate[1].details[1].exerciseTypeId, 33)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user