diff options
| author | Said Belhadj <71043286+Said-Belhadj@users.noreply.github.com> | 2021-06-27 15:43:57 +0200 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-06-27 15:43:57 +0200 | 
| commit | 703425d435ac7d0b6a3337f5730199fbaad82ff1 (patch) | |
| tree | 63c26d58a831eec503940ad616533f35b3b3ccfe /src/main/java/musichub | |
| parent | 6c977eff192830096d4d5cde27d31bfd21d16b7e (diff) | |
| parent | e13eea333d7af2786dbbbb5ed60cea4593d5ee12 (diff) | |
Merge branch 'develop' into feature/STZ-0008
Diffstat (limited to 'src/main/java/musichub')
| -rw-r--r-- | src/main/java/musichub/main/Main.java | 12 | ||||
| -rw-r--r-- | src/main/java/musichub/util/LogHandler.java | 68 | ||||
| -rw-r--r-- | src/main/java/musichub/util/PathValidation.java (renamed from src/main/java/musichub/business/PathValidation.java) | 2 | 
3 files changed, 79 insertions, 3 deletions
| diff --git a/src/main/java/musichub/main/Main.java b/src/main/java/musichub/main/Main.java index 19cbede..0669795 100644 --- a/src/main/java/musichub/main/Main.java +++ b/src/main/java/musichub/main/Main.java @@ -1,6 +1,7 @@  package musichub.main;  import musichub.business.*; +import musichub.util.LogHandler;  import javax.sound.sampled.LineUnavailableException;  import javax.sound.sampled.UnsupportedAudioFileException; @@ -9,7 +10,7 @@ import java.util.Iterator;  import java.util.List;  import java.util.Scanner; -import static musichub.business.PathValidation.isPathValid; +import static musichub.util.PathValidation.isPathValid;  public class Main {      public static void main(String[] args) throws UnsupportedAudioFileException, IOException, LineUnavailableException, NoAlbumFoundException { @@ -94,7 +95,9 @@ public class Main {                      System.out.println("Song content: ");                      String content = scan.nextLine();                      if (!isPathValid(content)) { -                        System.out.println("The music file was not found with the path you've provided.\nType h for available commands"); +                        String logMsg = "The music file was not found with the path you've provided."; +                        LogHandler.write(logMsg, "WARNING"); //write a line in the log file +                        System.out.println(logMsg + "\nType h for available commands");                          choice = scan.nextLine();                          break;                      } @@ -245,6 +248,10 @@ public class Main {                      //search a music                      theHub.searchAudioElement();                      printAvailableCommands(); +                case 'o': +                    //consult the app logs +                    LogHandler.read(); +                    System.out.println("Type h for available commands");                      choice = scan.nextLine();                      break;                  default: @@ -268,6 +275,7 @@ public class Main {          System.out.println("p: create a new playlist from existing songs and audio books");          System.out.println("-: delete an existing playlist");          System.out.println("s: save elements, albums, playlists"); +        System.out.println("o: consult the app logs");          System.out.println("q: quit program");      } diff --git a/src/main/java/musichub/util/LogHandler.java b/src/main/java/musichub/util/LogHandler.java new file mode 100644 index 0000000..988b149 --- /dev/null +++ b/src/main/java/musichub/util/LogHandler.java @@ -0,0 +1,68 @@ +package musichub.util; + +import java.io.IOException; +import java.nio.file.Files; +import java.nio.file.Path; +import java.nio.file.StandardOpenOption; +import java.sql.Timestamp; + +/** + * Class offering a log writing method. + * + * @author Aimeric ADJUTOR + * @version 1.0 + */ + +public final class LogHandler { + +    /** +     * Method that just throws an AssertionError if the class is called +     * +     * @throws AssertionError you can't instantiate this class +     * @author Aimeric ADJUTOR +     */ + +    public LogHandler() { +        throw new AssertionError("You just can't instantiate this class."); +    } + +    /** +     * Method that writes a log message to spoteezer.log +     * +     * @param msg  the message to write +     * @param type the type of log +     * @throws IOException if the file's not there +     */ +    public static void write(String msg, String type) throws IOException { + +        Timestamp timestamp = new Timestamp(System.currentTimeMillis()); + +        //Create the log using the given message +        String logMsg = "\n[" + timestamp + "] " + type + ": " + msg; + +        // Define the file name of the file +        Path fileName = Path.of("log/spoteezer.log"); + +        // Write into the file +        Files.writeString(fileName, logMsg, StandardOpenOption.APPEND); + + +    } + +    /** +     * Method that prints the content of spoteezer.log +     * +     * @throws IOException if the file's not there +     */ +    public static void read() throws IOException { +        Path fileName = Path.of("log/spoteezer.log"); + +        // Read the content of the file +        String file_content = Files.readString(fileName); + +        // Print the content inside the file +        System.out.println("\n" + file_content + "\n"); + +    } + +}
\ No newline at end of file diff --git a/src/main/java/musichub/business/PathValidation.java b/src/main/java/musichub/util/PathValidation.java index b0281ba..df11388 100644 --- a/src/main/java/musichub/business/PathValidation.java +++ b/src/main/java/musichub/util/PathValidation.java @@ -1,4 +1,4 @@ -package musichub.business; +package musichub.util;  import java.nio.file.Files;  import java.nio.file.Path; | 
