All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.beangle.ems.app.blob.LocalRepository.scala Maven / Gradle / Ivy

/*
 * Copyright (C) 2005, The Beangle Software.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published
 * by the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program.  If not, see .
 */

package org.beangle.ems.app.blob

import org.beangle.commons.activation.MediaTypes
import org.beangle.commons.file.digest.Sha1
import org.beangle.commons.io.IOs

import java.io.{File, FileOutputStream, InputStream}
import java.net.URL
import java.time.Instant

class LocalRepository(val base: String, val dir: String) extends Repository {

  override def remove(p: String): Boolean = {
    require(p.startsWith("/"))
    val path = s"$base$dir${p}"
    val file = new File(path)
    if (file.exists()) {
      file.delete()
    } else {
      false
    }
  }

  override def path(p: String): Option[String] = {
    require(p.startsWith("/"))
    val file = new File(s"$base$dir${p}")
    if (file.exists()) {
      Some(file.getAbsolutePath)
    } else {
      None
    }
  }

  override def url(path: String): Option[URL] = {
    require(path.startsWith("/"))
    val file = new File(s"$base$dir${path}")
    if (file.exists()) {
      Some(file.toURI.toURL)
    } else {
      None
    }
  }

  override def upload(folder: String, is: InputStream, fileName: String, owner: String): BlobMeta = {
    require(folder.startsWith("/"))
    val time = System.currentTimeMillis();
    val file = new File(s"$base$dir$folder/$time")
    file.getParentFile.mkdirs()
    val os = new FileOutputStream(file)
    IOs.copy(is, os)
    IOs.close(os)
    val sha = Sha1.digest(file)
    val target = new File(s"$base$dir$folder/$sha")
    file.renameTo(target)
    val ext = getExt(fileName)
    val meta = new BlobMeta()
    meta.name = fileName
    meta.sha = sha
    meta.updatedAt = Instant.now
    meta.fileSize = target.length().asInstanceOf[Int]
    meta.mediaType = MediaTypes.get(ext, MediaTypes.ApplicationOctetStream).toString()
    meta.filePath = s"$folder/$sha"
    meta
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy