API 1.0.37 faq, training plans
This commit is contained in:
parent
bd468c9135
commit
a38c244d79
@ -11,7 +11,7 @@ plugins {
|
|||||||
}
|
}
|
||||||
|
|
||||||
group = "com.aitrainer"
|
group = "com.aitrainer"
|
||||||
version = "1.0.36"
|
version = "1.0.37"
|
||||||
java.sourceCompatibility = JavaVersion.VERSION_1_8
|
java.sourceCompatibility = JavaVersion.VERSION_1_8
|
||||||
|
|
||||||
repositories {
|
repositories {
|
||||||
|
68
data/db/update_1_0_37.sql
Normal file
68
data/db/update_1_0_37.sql
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
START TRANSACTION;
|
||||||
|
|
||||||
|
CREATE TABLE `training_plan` (
|
||||||
|
`training_plan_id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` CHAR(50) NOT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
`type` CHAR(50) NULL DEFAULT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
PRIMARY KEY (`training_plan_id`) USING BTREE
|
||||||
|
)
|
||||||
|
COLLATE='utf8_hungarian_ci'
|
||||||
|
ENGINE=InnoDB
|
||||||
|
;
|
||||||
|
|
||||||
|
CREATE TABLE `training_plan_detail` (
|
||||||
|
`training_plan_detail_id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`training_plan_id` INT(11) NOT NULL,
|
||||||
|
`exercise_type_id` INT(11) NOT NULL,
|
||||||
|
`sort` INT(3) UNSIGNED ZEROFILL NULL DEFAULT NULL,
|
||||||
|
`set` INT(3) NULL DEFAULT NULL,
|
||||||
|
`repeats` INT(5) NULL DEFAULT NULL COMMENT '-1: max',
|
||||||
|
`weight` DOUBLE NULL DEFAULT NULL COMMENT '-1: calculated',
|
||||||
|
`resting_time` INT(3) NULL DEFAULT NULL,
|
||||||
|
`parallel` TINYINT(4) NULL DEFAULT NULL,
|
||||||
|
`day` CHAR(50) NULL DEFAULT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
PRIMARY KEY (`training_plan_detail_id`) USING BTREE
|
||||||
|
)
|
||||||
|
COLLATE='utf8_hungarian_ci'
|
||||||
|
ENGINE=InnoDB
|
||||||
|
;
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE `customer_training_plan` (
|
||||||
|
`customer_training_plan_id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`customer_id` INT(11) NOT NULL DEFAULT '0',
|
||||||
|
`training_plan_id` INT(11) NOT NULL DEFAULT '0',
|
||||||
|
`date_add` DATETIME NULL DEFAULT NULL,
|
||||||
|
PRIMARY KEY (`customer_training_plan_id`) USING BTREE
|
||||||
|
)
|
||||||
|
COLLATE='utf8_hungarian_ci'
|
||||||
|
ENGINE=InnoDB
|
||||||
|
;
|
||||||
|
|
||||||
|
CREATE TABLE `faq` (
|
||||||
|
`faq_id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` CHAR(50) NOT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
`description` TEXT NULL DEFAULT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
PRIMARY KEY (`faq_id`) USING BTREE
|
||||||
|
)
|
||||||
|
COLLATE='utf8_hungarian_ci'
|
||||||
|
ENGINE=InnoDB
|
||||||
|
;
|
||||||
|
|
||||||
|
CREATE TABLE `faq_translation` (
|
||||||
|
`translation_id` INT(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`faq_id` INT(11) NOT NULL DEFAULT '0',
|
||||||
|
`name_translation` CHAR(50) NOT NULL DEFAULT '0' COLLATE 'utf8_hungarian_ci',
|
||||||
|
`description_translation` TEXT NULL DEFAULT NULL COLLATE 'utf8_hungarian_ci',
|
||||||
|
`language_code` CHAR(2) NULL DEFAULT 'en' COLLATE 'utf8_hungarian_ci',
|
||||||
|
PRIMARY KEY (`translation_id`) USING BTREE,
|
||||||
|
INDEX `faq_id` (`faq_id`) USING BTREE
|
||||||
|
)
|
||||||
|
COLLATE='utf8_hungarian_ci'
|
||||||
|
ENGINE=InnoDB
|
||||||
|
;
|
||||||
|
|
||||||
|
|
||||||
|
UPDATE configuration set config_value = "1.0.37", date_change=CURRENT_DATE WHERE config_key = "db_version";
|
||||||
|
|
||||||
|
COMMIT;
|
@ -23,7 +23,9 @@ class PackageController(private val exerciseAbilityRepository: ExerciseAbilityRe
|
|||||||
private val evaluationRepository: EvaluationRepository,
|
private val evaluationRepository: EvaluationRepository,
|
||||||
private val sportRepository: SportRepository,
|
private val sportRepository: SportRepository,
|
||||||
private val tutorialRepository: TutorialRepository,
|
private val tutorialRepository: TutorialRepository,
|
||||||
private val descriptionRepository: DescriptionRepository
|
private val descriptionRepository: DescriptionRepository,
|
||||||
|
private val faqRepository: FaqRepository,
|
||||||
|
private val trainingPlanRepository: TrainingPlanRepository
|
||||||
) {
|
) {
|
||||||
private val logger = LoggerFactory.getLogger(javaClass)
|
private val logger = LoggerFactory.getLogger(javaClass)
|
||||||
|
|
||||||
@ -71,6 +73,12 @@ class PackageController(private val exerciseAbilityRepository: ExerciseAbilityRe
|
|||||||
val listDescriptions = descriptionRepository.findAll()
|
val listDescriptions = descriptionRepository.findAll()
|
||||||
val listDescriptionJson: String = gson.toJson(listDescriptions)
|
val listDescriptionJson: String = gson.toJson(listDescriptions)
|
||||||
|
|
||||||
|
val listFaq = faqRepository.findAll()
|
||||||
|
val listFaqJson: String = gson.toJson(listFaq)
|
||||||
|
|
||||||
|
val listTrainingPlan = trainingPlanRepository.findAll()
|
||||||
|
val listTrainingPlanJson = gson.toJson(listTrainingPlan)
|
||||||
|
|
||||||
val packageJson: String =
|
val packageJson: String =
|
||||||
getClassRecord(ExerciseDevice::class.simpleName, listDevicesJson) +
|
getClassRecord(ExerciseDevice::class.simpleName, listDevicesJson) +
|
||||||
"|||" + getClassRecord(Product::class.simpleName, listProductsJson) +
|
"|||" + getClassRecord(Product::class.simpleName, listProductsJson) +
|
||||||
@ -83,7 +91,9 @@ class PackageController(private val exerciseAbilityRepository: ExerciseAbilityRe
|
|||||||
"|||" + getClassRecord(Evaluation::class.simpleName, listEvaluationJson) +
|
"|||" + getClassRecord(Evaluation::class.simpleName, listEvaluationJson) +
|
||||||
"|||" + getClassRecord(Sport::class.simpleName, listSportsJson) +
|
"|||" + getClassRecord(Sport::class.simpleName, listSportsJson) +
|
||||||
"|||" + getClassRecord(Tutorial::class.simpleName, listTutorialJson) +
|
"|||" + getClassRecord(Tutorial::class.simpleName, listTutorialJson) +
|
||||||
"|||" + getClassRecord(Description::class.simpleName, listDescriptionJson)
|
"|||" + getClassRecord(Description::class.simpleName, listDescriptionJson) +
|
||||||
|
"|||" + getClassRecord(Faq::class.simpleName, listFaqJson) +
|
||||||
|
"|||" + getClassRecord(TrainingPlan::class.simpleName, listTrainingPlanJson)
|
||||||
|
|
||||||
return if (packageJson.isEmpty()) ResponseEntity.notFound().build() else
|
return if (packageJson.isEmpty()) ResponseEntity.notFound().build() else
|
||||||
ResponseEntity.ok().body(packageJson)
|
ResponseEntity.ok().body(packageJson)
|
||||||
|
20
src/main/kotlin/com/aitrainer/api/model/Faq.kt
Normal file
20
src/main/kotlin/com/aitrainer/api/model/Faq.kt
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
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 Faq (
|
||||||
|
@Expose @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @get: NonNull var faqId: Long = 0,
|
||||||
|
@Expose @get: NonNull var name: String,
|
||||||
|
@Expose @get: NonNull var description: String,
|
||||||
|
|
||||||
|
) {
|
||||||
|
@OneToMany(cascade = [(CascadeType.ALL)], fetch = FetchType.EAGER, mappedBy = "faq")
|
||||||
|
@Fetch(value = FetchMode.SUBSELECT)
|
||||||
|
@Expose val translations: List<FaqTranslation> = mutableListOf<FaqTranslation>().toList()
|
||||||
|
|
||||||
|
}
|
19
src/main/kotlin/com/aitrainer/api/model/FaqTranslation.kt
Normal file
19
src/main/kotlin/com/aitrainer/api/model/FaqTranslation.kt
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
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.NotBlank
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
data class FaqTranslation (
|
||||||
|
@Expose @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @get: NonNull var translationId: Long = 0,
|
||||||
|
@Expose @get: NotBlank var languageCode: String? = "hu",
|
||||||
|
@Expose @get: NonNull var nameTranslation: String? = null,
|
||||||
|
@Expose @get: NonNull var descriptionTranslation: String? = null
|
||||||
|
) {
|
||||||
|
@ManyToOne(fetch = FetchType.LAZY, optional = false)
|
||||||
|
@JoinColumn(name = "faqId", nullable = false)
|
||||||
|
@JsonIgnore val faq: Faq? = null
|
||||||
|
}
|
20
src/main/kotlin/com/aitrainer/api/model/TrainingPlan.kt
Normal file
20
src/main/kotlin/com/aitrainer/api/model/TrainingPlan.kt
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
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.*
|
||||||
|
import javax.validation.constraints.NotBlank
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
data class TrainingPlan (
|
||||||
|
@Expose @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @get: NonNull var trainingPlanId: Long = 0,
|
||||||
|
@Expose @get: NotBlank var name: String = "",
|
||||||
|
@Expose @get: NotBlank var type: String = "",
|
||||||
|
) {
|
||||||
|
@OneToMany(cascade = [(CascadeType.ALL)], fetch = FetchType.EAGER, mappedBy = "trainingPlan")
|
||||||
|
@Fetch(value = FetchMode.SUBSELECT)
|
||||||
|
@Expose val details: List<TrainingPlanDetail> = mutableListOf<TrainingPlanDetail>().toList()
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,30 @@
|
|||||||
|
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.NotBlank
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
data class TrainingPlanDetail (
|
||||||
|
@Expose @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @get: NonNull var trainingPlanDetailId: Long = 0,
|
||||||
|
@Expose @get: NotBlank var exerciseTypeId: Int = 0,
|
||||||
|
@Expose @get: NotBlank var sort: Int = 0,
|
||||||
|
@Expose @get: NotBlank var set: Int = 0,
|
||||||
|
@Expose @get: NotBlank var repeats: Int = 0,
|
||||||
|
@Expose @get: NotBlank var weight: Double = 0.0,
|
||||||
|
@Expose @get: NotBlank var restingTime: Int = 0,
|
||||||
|
@Expose @get: NotBlank var parallel: Boolean = false,
|
||||||
|
@Expose var day: String? = null,
|
||||||
|
|
||||||
|
) {
|
||||||
|
|
||||||
|
@ManyToOne(fetch = FetchType.LAZY, optional = false)
|
||||||
|
@JoinColumn(name = "trainingPlanId", nullable = false)
|
||||||
|
@JsonIgnore
|
||||||
|
val trainingPlan: TrainingPlan? = null
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,9 @@
|
|||||||
|
package com.aitrainer.api.repository
|
||||||
|
|
||||||
|
import com.aitrainer.api.model.Faq
|
||||||
|
import org.springframework.data.jpa.repository.JpaRepository
|
||||||
|
import org.springframework.stereotype.Repository
|
||||||
|
|
||||||
|
@Repository
|
||||||
|
interface FaqRepository: JpaRepository<Faq, Long> {
|
||||||
|
}
|
@ -0,0 +1,9 @@
|
|||||||
|
package com.aitrainer.api.repository
|
||||||
|
|
||||||
|
import com.aitrainer.api.model.TrainingPlan
|
||||||
|
import org.springframework.data.jpa.repository.JpaRepository
|
||||||
|
import org.springframework.stereotype.Repository
|
||||||
|
|
||||||
|
@Repository
|
||||||
|
interface TrainingPlanRepository: JpaRepository<TrainingPlan, Long> {
|
||||||
|
}
|
@ -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.36
|
application.version=1.0.37
|
||||||
|
|
||||||
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.36
|
application.version=1.0.37
|
||||||
|
|
||||||
jwt.secret=aitrainer
|
jwt.secret=aitrainer
|
@ -41,6 +41,10 @@ class AppPackageTest {
|
|||||||
private lateinit var tutorialRepository: TutorialRepository
|
private lateinit var tutorialRepository: TutorialRepository
|
||||||
@Autowired
|
@Autowired
|
||||||
private lateinit var descriptionRepository: DescriptionRepository
|
private lateinit var descriptionRepository: DescriptionRepository
|
||||||
|
@Autowired
|
||||||
|
private lateinit var faqRepository: FaqRepository
|
||||||
|
@Autowired
|
||||||
|
private lateinit var trainingPlanRepository: TrainingPlanRepository
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun testAppPackage() {
|
fun testAppPackage() {
|
||||||
@ -58,7 +62,9 @@ class AppPackageTest {
|
|||||||
evaluationRepository,
|
evaluationRepository,
|
||||||
sportRepository,
|
sportRepository,
|
||||||
tutorialRepository,
|
tutorialRepository,
|
||||||
descriptionRepository
|
descriptionRepository,
|
||||||
|
faqRepository,
|
||||||
|
trainingPlanRepository
|
||||||
)
|
)
|
||||||
val response: ResponseEntity<*> = controller.getPackageData()
|
val response: ResponseEntity<*> = controller.getPackageData()
|
||||||
|
|
||||||
@ -150,6 +156,21 @@ class AppPackageTest {
|
|||||||
assertEquals(descriptions.size, 2)
|
assertEquals(descriptions.size, 2)
|
||||||
assertEquals(descriptions[0].translations.size, 1)
|
assertEquals(descriptions[0].translations.size, 1)
|
||||||
assertEquals(descriptions[0].name, "sales_page")
|
assertEquals(descriptions[0].name, "sales_page")
|
||||||
|
} else if (record[0] == Faq::class.simpleName) {
|
||||||
|
val faqJson: String = record[1]
|
||||||
|
val type = object : TypeToken<List<Faq?>?>() {}.type
|
||||||
|
val faqs: List<Faq> = gson.fromJson(faqJson, type)
|
||||||
|
assertEquals(faqs.size,1)
|
||||||
|
assertEquals(faqs[0].name, "What is 1RM?")
|
||||||
|
assertEquals(faqs[0].translations[0].languageCode, "hu")
|
||||||
|
} else if (record[0] == TrainingPlan::class.simpleName) {
|
||||||
|
val trainingPlanJson: String = record[1]
|
||||||
|
val type = object : TypeToken<List<TrainingPlan?>?>() {}.type
|
||||||
|
val plans: List<TrainingPlan> = gson.fromJson(trainingPlanJson, type)
|
||||||
|
assertEquals(plans.size,2)
|
||||||
|
assertEquals(plans[1].name, "Biceps")
|
||||||
|
assertEquals(plans[0].details[0].exerciseTypeId, 63)
|
||||||
|
assertEquals(plans[0].details[1].weight, -1.0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user