website/pkg/photo/filenames.go

68 lines
1.8 KiB
Go

package photo
import (
"fmt"
"os"
"path/filepath"
"code.nonshy.com/nonshy/website/pkg/config"
"code.nonshy.com/nonshy/website/pkg/log"
"github.com/google/uuid"
)
// Functions that deal with giving photos their:
// - Filename
// - URL prefix (/static/photos or maybe CDN?)
/*
NewFilename generates a Filename with an extension (".jpg").
The filename is a random UUID string, with a couple of directory
paths in front consisting of the first few characters (to keep
directory sizes under control over time). Example:
"91/b9/91b908db-4007-41b2-bbca-71a6526e59aa.jpg"
*/
func NewFilename(ext string) string {
basename := uuid.New().String()
first2 := basename[:2]
next2 := basename[2:4]
log.Debug("photo.NewFilename: UUID %s first2 %d next2 %d", basename, first2, next2)
return fmt.Sprintf(
"%s/%s/%s%s",
first2, next2, basename, ext,
)
}
// DiskPath returns the local disk path to a photo Filename.
func DiskPath(filename string) string {
return config.PhotoDiskPath + "/" + filename
}
// URLPath returns the public HTTP path to a photo. May be relative like "/static/photos" or could be a full CDN.
func URLPath(filename string) string {
return config.PhotoWebPath + "/" + filename
}
/*
EnsurePath makes sure the local './web/static/photos/' path is ready
to write an image to, taking into account path parameters in the
image filename.
The filename is like from NewFilename(), just the photo Filename portion.
It is appended to the PhotoDiskPath.
Returns the full path ("./web/static/photos/...") ready for the caller
to use it for writing.
*/
func EnsurePath(filename string) (string, error) {
fullpath := DiskPath(filename)
dir := filepath.Dir(fullpath)
log.Debug("photo.EnsurePath: check that %s exists", dir)
if err := os.MkdirAll(dir, 0755); err != nil {
return fullpath, fmt.Errorf("EnsurePath: %s", err)
} else {
return fullpath, nil
}
}