/*- * ============LICENSE_START======================================================= * Copyright (C) 2019 Nordix Foundation. * Modifications Copyright (C) 2020-2021 AT&T Intellectual Property. All rights reserved. * ================================================================================ * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * SPDX-License-Identifier: Apache-2.0 * ============LICENSE_END========================================================= */ package org.onap.policy.common.utils.resources; import java.io.File; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.Reader; import java.nio.charset.StandardCharsets; import java.nio.file.Files; import org.apache.commons.io.IOUtils; /** * The Class TextFileUtils is class that provides useful functions for handling text files. Functions to read and write * text files to strings and strings are provided. * * @author Liam Fallon (liam.fallon@est.tech) */ public class TextFileUtils { private TextFileUtils() { // This class cannot be initialized } /** * Method to return the contents of a text file as a string. * * @param textFilePath The path to the file as a string * @return A string containing the contents of the file * @throws IOException on errors reading text from the file */ public static String getTextFileAsString(final String textFilePath) throws IOException { final var textFile = new File(textFilePath); return Files.readString(textFile.toPath()); } /** * Method to write contents of a string to a text file. * * @param outString The string to write * @param textFilePath The path to the file as a string * @throws IOException on errors reading text from the file */ public static void putStringAsTextFile(final String outString, final String textFilePath) throws IOException { final var textFile = new File(textFilePath); if (!textFile.getParentFile().exists()) { textFile.getParentFile().mkdirs(); } putStringAsFile(outString, textFile); } /** * Method to write contents of a string to a text file. * * @param outString The string to write * @param textFile The file to write the string to * @throws IOException on errors reading text from the file */ public static void putStringAsFile(final String outString, final File textFile) throws IOException { Files.writeString(textFile.toPath(), outString); } /** * Method to return the contents of a text steam as a string. * * @param textStream The stream * @return A string containing the output of the stream as text * @throws IOException on errors reading text from the file */ public static String getStreamAsString(final InputStream textStream) throws IOException { return getReaderAsString(new InputStreamReader(textStream, StandardCharsets.UTF_8)); } /** * Method to return the contents of a reader steam as a string. This closes the reader after use * * @param textReader The reader * @return A string containing the output of the reader as text * @throws IOException on errors reading text from the file */ public static String getReaderAsString(final Reader textReader) throws IOException { return IOUtils.toString(textReader); } }