Files
java-design-patterns/serialized-lob/src/main/java/com/iluwatar/slob/App.java
T
Ilkka Seppälä 292554e76e docs: update slob
2024-05-20 10:57:38 +03:00

145 lines
5.8 KiB
Java

/*
* This project is licensed under the MIT license. Module model-view-viewmodel is using ZK framework licensed under LGPL (see lgpl-3.0.txt).
*
* The MIT License
* Copyright © 2014-2022 Ilkka Seppälä
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
package com.iluwatar.slob;
import com.iluwatar.slob.lob.Animal;
import com.iluwatar.slob.lob.Forest;
import com.iluwatar.slob.lob.Plant;
import com.iluwatar.slob.serializers.BlobSerializer;
import com.iluwatar.slob.serializers.ClobSerializer;
import com.iluwatar.slob.serializers.LobSerializer;
import java.io.IOException;
import java.sql.SQLException;
import java.util.Collections;
import java.util.Objects;
import java.util.Set;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.TransformerException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.xml.sax.SAXException;
/**
* SLOB Application using {@link LobSerializer} and H2 DB.
*/
public class App {
public static final String CLOB = "CLOB";
private static final Logger LOGGER = LoggerFactory.getLogger(App.class);
/**
* Main entry point to program.
* <p>In the SLOB pattern, the object graph is serialized into a single large object (a BLOB or
* CLOB, for Binary Large Object or Character Large Object, respectively) and stored in the
* database. When the object graph needs to be retrieved, it is read from the database and
* deserialized back into the original object graph.</p>
*
* <p>A Forest is created using {@link #createForest()} with Animals and Plants along with their
* respective relationships.</p>
*
* <p>Creates a {@link LobSerializer} using the method
* {@link #createLobSerializer(String[])}.</p>
*
* <p>Once created the serializer is passed to the
* {@link #executeSerializer(Forest, LobSerializer)} which handles the serialization,
* deserialization and persisting and loading from DB.</p>
*
* @param args if first arg is CLOB then ClobSerializer is used else BlobSerializer is used.
*/
public static void main(String[] args) throws SQLException {
Forest forest = createForest();
LobSerializer serializer = createLobSerializer(args);
executeSerializer(forest, serializer);
}
/**
* <p>Creates a {@link LobSerializer} on the basis of input args. </p>
* <p>If input args are not empty and the value equals {@link App#CLOB} then a
* {@link ClobSerializer} is created else a {@link BlobSerializer} is created.</p>
*
* @param args if first arg is {@link App#CLOB} then ClobSerializer is instantiated else
* BlobSerializer is instantiated.
*/
private static LobSerializer createLobSerializer(String[] args) throws SQLException {
LobSerializer serializer;
if (args.length > 0 && Objects.equals(args[0], CLOB)) {
serializer = new ClobSerializer();
} else {
serializer = new BlobSerializer();
}
return serializer;
}
/**
* Creates a Forest with {@link Animal} and {@link Plant} along with their respective
* relationships.
*
* <p> The method creates a {@link Forest} with 2 Plants Grass and Oak of type Herb and tree
* respectively.</p>
*
* <p> It also creates 3 animals Zebra and Buffalo which eat the plant grass. Lion consumes the
* Zebra and the Buffalo.</p>
*
* <p>With the above animals and plants and their relationships a forest
* object is created which represents the Object Graph.</p>
*
* @return Forest Object
*/
private static Forest createForest() {
Plant grass = new Plant("Grass", "Herb");
Plant oak = new Plant("Oak", "Tree");
Animal zebra = new Animal("Zebra", Set.of(grass), Collections.emptySet());
Animal buffalo = new Animal("Buffalo", Set.of(grass), Collections.emptySet());
Animal lion = new Animal("Lion", Collections.emptySet(), Set.of(zebra, buffalo));
return new Forest("Amazon", Set.of(lion, buffalo, zebra), Set.of(grass, oak));
}
/**
* Serialize the input object using the input serializer and persist to DB. After this it loads
* the same object back from DB and deserializes using the same serializer.
*
* @param forest Object to Serialize and Persist
* @param lobSerializer Serializer to Serialize and Deserialize Object
*/
private static void executeSerializer(Forest forest, LobSerializer lobSerializer) {
try (LobSerializer serializer = lobSerializer) {
Object serialized = serializer.serialize(forest);
int id = serializer.persistToDb(1, forest.getName(), serialized);
Object fromDb = serializer.loadFromDb(id, Forest.class.getSimpleName());
Forest forestFromDb = serializer.deSerialize(fromDb);
LOGGER.info(forestFromDb.toString());
} catch (SQLException | IOException | TransformerException | ParserConfigurationException
| SAXException
| ClassNotFoundException e) {
throw new RuntimeException(e);
}
}
}