mirror of
https://github.com/tiennm99/java-design-patterns.git
synced 2026-05-14 18:58:44 +00:00
145 lines
5.8 KiB
Java
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);
|
|
}
|
|
}
|
|
}
|