Add ffmpeg converter to ogg format
This commit is contained in:
@@ -20,3 +20,7 @@ type TranscriptJobRepository interface {
|
||||
|
||||
type ObjectStorage interface {
|
||||
}
|
||||
|
||||
type FileConverter interface {
|
||||
Convert(src, dest string) error
|
||||
}
|
||||
|
47
internal/repo/ffmpeg/conv.go
Normal file
47
internal/repo/ffmpeg/conv.go
Normal file
@@ -0,0 +1,47 @@
|
||||
package ffmpeg
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"os"
|
||||
"os/exec"
|
||||
)
|
||||
|
||||
type FileConverter struct {
|
||||
}
|
||||
|
||||
func NewFileConverter() *FileConverter {
|
||||
return &FileConverter{}
|
||||
}
|
||||
|
||||
func (c *FileConverter) Convert(src, dest string) error {
|
||||
// Проверяем существование исходного файла
|
||||
if _, err := os.Stat(src); os.IsNotExist(err) {
|
||||
return fmt.Errorf("input file does not exist: %s", src)
|
||||
}
|
||||
|
||||
// Проверяем, что ffmpeg доступен в системе
|
||||
if _, err := exec.LookPath("ffmpeg"); err != nil {
|
||||
return fmt.Errorf("ffmpeg not found in PATH: %w", err)
|
||||
}
|
||||
|
||||
// Создаем команду ffmpeg для конвертации в OGG
|
||||
cmd := exec.Command("ffmpeg",
|
||||
"-i", src, // входной файл
|
||||
"-c:a", "libvorbis", // кодек Vorbis для OGG
|
||||
"-q:a", "4", // качество аудио (0-10, где 4 - хорошее качество)
|
||||
"-y", // перезаписать выходной файл если существует
|
||||
dest, // выходной файл
|
||||
)
|
||||
|
||||
// Выполняем команду
|
||||
if err := cmd.Run(); err != nil {
|
||||
return fmt.Errorf("ffmpeg conversion failed: %w", err)
|
||||
}
|
||||
|
||||
// Проверяем, что выходной файл был создан
|
||||
if _, err := os.Stat(dest); os.IsNotExist(err) {
|
||||
return fmt.Errorf("output file was not created: %s", dest)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
@@ -21,6 +21,7 @@ func (repo *FileRepository) Create(file *entity.File) error {
|
||||
record := goqu.Record{
|
||||
"id": file.Id,
|
||||
"storage": file.Storage,
|
||||
"file_name": file.FileName,
|
||||
"size": file.Size,
|
||||
"created_at": file.CreatedAt,
|
||||
}
|
||||
@@ -39,14 +40,14 @@ func (repo *FileRepository) Create(file *entity.File) error {
|
||||
}
|
||||
|
||||
func (repo *FileRepository) GetByID(id string) (*entity.File, error) {
|
||||
query := repo.gq.From("files").Select("id", "storage", "size", "created_at").Where(goqu.C("id").Eq(id))
|
||||
query := repo.gq.From("files").Select("id", "storage", "file_name", "size", "created_at").Where(goqu.C("id").Eq(id))
|
||||
sql, args, err := query.ToSQL()
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("failed to build query: %w", err)
|
||||
}
|
||||
|
||||
var file entity.File
|
||||
err = repo.db.QueryRow(sql, args...).Scan(&file.Id, &file.Storage, &file.Size, &file.CreatedAt)
|
||||
err = repo.db.QueryRow(sql, args...).Scan(&file.Id, &file.Storage, &file.FileName, &file.Size, &file.CreatedAt)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("failed to get file: %w", err)
|
||||
}
|
Reference in New Issue
Block a user