com.structurizr.model.ModelItem Maven / Gradle / Ivy
package com.structurizr.model;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.structurizr.util.StringUtils;
import java.util.*;
/**
* The base class for elements and relationships.
*/
abstract class ModelItem {
private String id = "";
private Set tags = new LinkedHashSet<>();
private Map properties = new HashMap<>();
private Set perspectives = new HashSet<>();
protected abstract Set getRequiredTags();
/**
* Gets the ID of this item in the model.
*
* @return the ID, as a String
*/
public String getId() {
return id;
}
void setId(String id) {
this.id = id;
}
/**
* Gets the comma separated list of tags.
*
* @return a comma separated list of tags,
* or an empty string if there are no tags
*/
public String getTags() {
Set setOfTags = getTagsAsSet();
if (setOfTags.isEmpty()) {
return "";
}
StringBuilder buf = new StringBuilder();
for (String tag : setOfTags) {
buf.append(tag);
buf.append(",");
}
String tagsAsString = buf.toString();
return tagsAsString.substring(0, tagsAsString.length()-1);
}
@JsonIgnore
public Set getTagsAsSet() {
Set setOfTags = new LinkedHashSet<>(getRequiredTags());
setOfTags.addAll(tags);
return setOfTags;
}
void setTags(String tags) {
this.tags.clear();
if (tags == null) {
return;
}
Collections.addAll(this.tags, tags.split(","));
}
public void addTags(String... tags) {
if (tags == null) {
return;
}
for (String tag : tags) {
if (tag != null) {
this.tags.add(tag);
}
}
}
public void removeTag(String tag) {
if (tag != null) {
this.tags.remove(tag);
}
}
public boolean hasTag(String tag) {
return this.tags.contains(tag);
}
/**
* Gets the collection of name-value property pairs associated with this element, as a Map.
*
* @return a Map (String, String) (empty if there are no properties)
*/
public Map getProperties() {
return new HashMap<>(properties);
}
/**
* Adds a name-value pair property to this element.
*
* @param name the name of the property
* @param value the value of the property
*/
public void addProperty(String name, String value) {
if (name == null || name.trim().length() == 0) {
throw new IllegalArgumentException("A property name must be specified.");
}
if (value == null || value.trim().length() == 0) {
throw new IllegalArgumentException("A property value must be specified.");
}
properties.put(name, value);
}
void setProperties(Map properties) {
if (properties != null) {
this.properties = new HashMap<>(properties);
}
}
/**
* Gets the set of perspectives associated with this model item.
*
* @return a Set of Perspective objects (empty if there are none)
*/
public Set getPerspectives() {
return new HashSet<>(perspectives);
}
void setPerspectives(Set perspectives) {
this.perspectives.clear();
if (perspectives == null) {
return;
}
this.perspectives.addAll(perspectives);
}
/**
* Adds a perspective to this model item.
*
* @param name the name of the perspective (e.g. "Security", must be unique)
* @param description a description of the perspective
* @return a Perspective object
* @throws IllegalArgumentException if perspective details are not specified, or the named perspective exists already
*/
public Perspective addPerspective(String name, String description) {
if (StringUtils.isNullOrEmpty(name)) {
throw new IllegalArgumentException("A name must be specified.");
}
if (StringUtils.isNullOrEmpty(description)) {
throw new IllegalArgumentException("A description must be specified.");
}
if (perspectives.stream().filter(p -> p.getName().equals(name)).count() > 0) {
throw new IllegalArgumentException("A perspective named \"" + name + "\" already exists.");
}
Perspective perspective = new Perspective(name, description);
perspectives.add(perspective);
return perspective;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy