Added UUID to PhaseDefinition
parent
1f8f89fa91
commit
bf8e592a51
|
|
@ -1,12 +1,12 @@
|
||||||
{
|
{
|
||||||
"name": "@librecms/ccm-cms",
|
"name": "@librecms/ccm-cms",
|
||||||
"version": "7.0.0-SNAPSHOT.2022-10-25T175437",
|
"version": "7.0.0-SNAPSHOT.2022-10-29T142641",
|
||||||
"lockfileVersion": 2,
|
"lockfileVersion": 2,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "@librecms/ccm-cms",
|
"name": "@librecms/ccm-cms",
|
||||||
"version": "7.0.0-SNAPSHOT.2022-10-25T175437",
|
"version": "7.0.0-SNAPSHOT.2022-10-29T142641",
|
||||||
"license": "LGPL-3.0-or-later",
|
"license": "LGPL-3.0-or-later",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@tiptap/core": "^2.0.0-beta.127",
|
"@tiptap/core": "^2.0.0-beta.127",
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "@librecms/ccm-cms",
|
"name": "@librecms/ccm-cms",
|
||||||
"version": "7.0.0-SNAPSHOT.2022-10-25T175437",
|
"version": "7.0.0-SNAPSHOT.2022-10-29T142641",
|
||||||
"description": "JavaScript stuff for ccm-cms",
|
"description": "JavaScript stuff for ccm-cms",
|
||||||
"main": "target/generated-resources/assets/@content-sections/cms-admin.js",
|
"main": "target/generated-resources/assets/@content-sections/cms-admin.js",
|
||||||
"types": "target/generated-resources/assets/@content-sections/cms-admin.d.ts",
|
"types": "target/generated-resources/assets/@content-sections/cms-admin.d.ts",
|
||||||
|
|
|
||||||
|
|
@ -19,6 +19,7 @@
|
||||||
package org.librecms.lifecycle;
|
package org.librecms.lifecycle;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonIdentityInfo;
|
import com.fasterxml.jackson.annotation.JsonIdentityInfo;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIdentityReference;
|
||||||
import com.fasterxml.jackson.annotation.ObjectIdGenerators;
|
import com.fasterxml.jackson.annotation.ObjectIdGenerators;
|
||||||
import org.hibernate.search.annotations.Field;
|
import org.hibernate.search.annotations.Field;
|
||||||
import org.libreccm.core.Identifiable;
|
import org.libreccm.core.Identifiable;
|
||||||
|
|
@ -107,6 +108,7 @@ public class LifecycleDefinition
|
||||||
|
|
||||||
@OneToMany
|
@OneToMany
|
||||||
@JoinColumn(name = "LIFECYCLE_DEFINITION_ID")
|
@JoinColumn(name = "LIFECYCLE_DEFINITION_ID")
|
||||||
|
@JsonIdentityReference(alwaysAsId = true)
|
||||||
private List<PhaseDefinition> phaseDefinitions;
|
private List<PhaseDefinition> phaseDefinitions;
|
||||||
|
|
||||||
public LifecycleDefinition() {
|
public LifecycleDefinition() {
|
||||||
|
|
|
||||||
|
|
@ -32,7 +32,10 @@ import javax.persistence.GenerationType;
|
||||||
import javax.persistence.Id;
|
import javax.persistence.Id;
|
||||||
import javax.persistence.JoinColumn;
|
import javax.persistence.JoinColumn;
|
||||||
import javax.persistence.JoinTable;
|
import javax.persistence.JoinTable;
|
||||||
|
import javax.persistence.NamedQueries;
|
||||||
|
import javax.persistence.NamedQuery;
|
||||||
import javax.persistence.Table;
|
import javax.persistence.Table;
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
|
||||||
import static org.librecms.CmsConstants.*;
|
import static org.librecms.CmsConstants.*;
|
||||||
|
|
||||||
|
|
@ -42,6 +45,12 @@ import static org.librecms.CmsConstants.*;
|
||||||
*/
|
*/
|
||||||
@Entity
|
@Entity
|
||||||
@Table(name = "LIFECYCLE_PHASE_DEFINITIONS", schema = DB_SCHEMA)
|
@Table(name = "LIFECYCLE_PHASE_DEFINITIONS", schema = DB_SCHEMA)
|
||||||
|
@NamedQueries({
|
||||||
|
@NamedQuery(
|
||||||
|
name = "PhaseDefinition.findByUuid",
|
||||||
|
query = "SELECT FROM PhaseDefinition p WHERE p.uuid = :uuid"
|
||||||
|
)
|
||||||
|
})
|
||||||
public class PhaseDefinition implements Serializable {
|
public class PhaseDefinition implements Serializable {
|
||||||
|
|
||||||
private static final long serialVersionUID = -7718926310758794075L;
|
private static final long serialVersionUID = -7718926310758794075L;
|
||||||
|
|
@ -51,24 +60,34 @@ public class PhaseDefinition implements Serializable {
|
||||||
@Column(name = "PHASE_DEFINITION_ID")
|
@Column(name = "PHASE_DEFINITION_ID")
|
||||||
private long definitionId;
|
private long definitionId;
|
||||||
|
|
||||||
|
@Column(name = "uuid", unique = true, nullable = false)
|
||||||
|
@NotNull
|
||||||
|
private String uuid;
|
||||||
|
|
||||||
@Embedded
|
@Embedded
|
||||||
@AssociationOverride(
|
@AssociationOverride(
|
||||||
name = "values",
|
name = "values",
|
||||||
joinTable = @JoinTable(name = "LIFECYCLE_PHASE_DEFINITION_LABELS",
|
joinTable = @JoinTable(
|
||||||
schema = DB_SCHEMA,
|
name = "LIFECYCLE_PHASE_DEFINITION_LABELS",
|
||||||
joinColumns = {
|
schema = DB_SCHEMA,
|
||||||
@JoinColumn(name = "OBJECT_ID")}
|
joinColumns = {
|
||||||
))
|
@JoinColumn(name = "OBJECT_ID")
|
||||||
|
}
|
||||||
|
)
|
||||||
|
)
|
||||||
private LocalizedString label;
|
private LocalizedString label;
|
||||||
|
|
||||||
@Embedded
|
@Embedded
|
||||||
@AssociationOverride(
|
@AssociationOverride(
|
||||||
name = "values",
|
name = "values",
|
||||||
joinTable = @JoinTable(name = "LIFECYCLE_PHASE_DEFINITION_DESCRIPTIONS",
|
joinTable = @JoinTable(
|
||||||
schema = DB_SCHEMA,
|
name = "LIFECYCLE_PHASE_DEFINITION_DESCRIPTIONS",
|
||||||
joinColumns = {
|
schema = DB_SCHEMA,
|
||||||
@JoinColumn(name = "OBJECT_ID")}
|
joinColumns = {
|
||||||
))
|
@JoinColumn(name = "OBJECT_ID")
|
||||||
|
}
|
||||||
|
)
|
||||||
|
)
|
||||||
private LocalizedString description;
|
private LocalizedString description;
|
||||||
|
|
||||||
@Column(name = "DEFAULT_DELAY")
|
@Column(name = "DEFAULT_DELAY")
|
||||||
|
|
@ -84,15 +103,23 @@ public class PhaseDefinition implements Serializable {
|
||||||
label = new LocalizedString();
|
label = new LocalizedString();
|
||||||
description = new LocalizedString();
|
description = new LocalizedString();
|
||||||
}
|
}
|
||||||
|
|
||||||
public long getDefinitionId() {
|
public long getDefinitionId() {
|
||||||
return definitionId;
|
return definitionId;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setDefinitionId(final long definitionId) {
|
protected void setDefinitionId(final long definitionId) {
|
||||||
this.definitionId = definitionId;
|
this.definitionId = definitionId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getUuid() {
|
||||||
|
return uuid;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void setUuid(final String uuid) {
|
||||||
|
this.uuid = uuid;
|
||||||
|
}
|
||||||
|
|
||||||
public LocalizedString getLabel() {
|
public LocalizedString getLabel() {
|
||||||
return label;
|
return label;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,73 @@
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2022 LibreCCM Foundation.
|
||||||
|
*
|
||||||
|
* This library is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
* License as published by the Free Software Foundation; either
|
||||||
|
* version 2.1 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with this library; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
package org.librecms.lifecycle;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.ObjectIdGenerator;
|
||||||
|
import com.fasterxml.jackson.annotation.ObjectIdResolver;
|
||||||
|
import org.libreccm.cdi.utils.CdiUtil;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
import javax.enterprise.context.RequestScoped;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
|
||||||
|
*/
|
||||||
|
@RequestScoped
|
||||||
|
public class PhaseDefinitionIdResolver
|
||||||
|
implements Serializable, ObjectIdResolver {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void bindItem(
|
||||||
|
final ObjectIdGenerator.IdKey id,
|
||||||
|
final Object object
|
||||||
|
) {
|
||||||
|
// According to the Jackson JavaDoc, this method can be used to keep
|
||||||
|
// track of objects directly in a resolver implementation. We don't need
|
||||||
|
// this here therefore this method is empty.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object resolveId(final ObjectIdGenerator.IdKey id) {
|
||||||
|
return CdiUtil
|
||||||
|
.createCdiUtil()
|
||||||
|
.findBean(PhaseDefinititionRepository.class)
|
||||||
|
.findByUuid(id.key.toString())
|
||||||
|
.orElseThrow(
|
||||||
|
() -> new IllegalArgumentException(
|
||||||
|
String.format(
|
||||||
|
"No PhaseDefinition with UUID %s in the database.",
|
||||||
|
id.key.toString()
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ObjectIdResolver newForDeserialization(final Object context) {
|
||||||
|
return new PhaseDefinitionIdResolver();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean canUseFor(final ObjectIdResolver resolverType) {
|
||||||
|
return resolverType instanceof PhaseDefinitionIdResolver;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -20,7 +20,10 @@ package org.librecms.lifecycle;
|
||||||
|
|
||||||
import org.libreccm.core.AbstractEntityRepository;
|
import org.libreccm.core.AbstractEntityRepository;
|
||||||
|
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
import javax.enterprise.context.RequestScoped;
|
import javax.enterprise.context.RequestScoped;
|
||||||
|
import javax.persistence.NoResultException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
|
@ -30,6 +33,8 @@ import javax.enterprise.context.RequestScoped;
|
||||||
public class PhaseDefinititionRepository
|
public class PhaseDefinititionRepository
|
||||||
extends AbstractEntityRepository<Long, PhaseDefinition> {
|
extends AbstractEntityRepository<Long, PhaseDefinition> {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Class<PhaseDefinition> getEntityClass() {
|
public Class<PhaseDefinition> getEntityClass() {
|
||||||
return PhaseDefinition.class;
|
return PhaseDefinition.class;
|
||||||
|
|
@ -50,4 +55,20 @@ public class PhaseDefinititionRepository
|
||||||
return phaseDefinition.getDefinitionId() == 0;
|
return phaseDefinition.getDefinitionId() == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Optional<PhaseDefinition> findByUuid(final String uuid) {
|
||||||
|
try {
|
||||||
|
return Optional.of(
|
||||||
|
getEntityManager()
|
||||||
|
.createNamedQuery(
|
||||||
|
"PhaseDefinition.findByUuid",
|
||||||
|
PhaseDefinition.class
|
||||||
|
)
|
||||||
|
.setParameter("uuid", uuid)
|
||||||
|
.getSingleResult()
|
||||||
|
);
|
||||||
|
} catch (NoResultException ex) {
|
||||||
|
return Optional.empty();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,5 @@
|
||||||
|
alter table CCM_CMS.LIFECYCLE_PHASE_DEFINITIONS add column UUID varchar(255);
|
||||||
|
update CCM_CMS.LIFECYCLE_PHASE_DEFINITIONS set UUID = random_uuid();
|
||||||
|
alter table CCM_CMS.LIFECYCLE_PHASE_DEFINITIONS alter column UUID not null;
|
||||||
|
alter table CCM_CMS.LIFECYCLE_PHASE_DEFINITIONS
|
||||||
|
add constraint UK_tcvepjkkbcehplxddnil66fwn unique (uuid);
|
||||||
|
|
@ -0,0 +1,5 @@
|
||||||
|
alter table CCM_CMS.LIFECYCLE_PHASE_DEFINITIONS add column UUID varchar(255);
|
||||||
|
update CCM_CMS.LIFECYCLE_PHASE_DEFINITIONS set UUID = gen_random_uuid();
|
||||||
|
alter table CCM_CMS.LIFECYCLE_PHASE_DEFINITIONS alter column UUID set not null;
|
||||||
|
alter table CCM_CMS.LIFECYCLE_PHASE_DEFINITIONS
|
||||||
|
add constraint UK_tcvepjkkbcehplxddnil66fwn unique (uuid);
|
||||||
Loading…
Reference in New Issue