RENAME CompressionService to ClipService and update references
This commit is contained in:
@@ -8,10 +8,10 @@ import org.springframework.security.oauth2.core.user.OAuth2User;
|
|||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
@Getter
|
||||||
public class CustomOAuth2User implements OAuth2User {
|
public class CustomOAuth2User implements OAuth2User {
|
||||||
|
|
||||||
private final OAuth2User oauth2User;
|
private final OAuth2User oauth2User;
|
||||||
@Getter
|
|
||||||
private final User user;
|
private final User user;
|
||||||
|
|
||||||
public CustomOAuth2User(OAuth2User oauth2User, User user) {
|
public CustomOAuth2User(OAuth2User oauth2User, User user) {
|
||||||
|
|||||||
@@ -19,8 +19,8 @@ import org.slf4j.LoggerFactory;
|
|||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
public class CompressionService {
|
public class ClipService {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(CompressionService.class);
|
private static final Logger logger = LoggerFactory.getLogger(ClipService.class);
|
||||||
|
|
||||||
private static final float AUDIO_RATIO = 0.15f;
|
private static final float AUDIO_RATIO = 0.15f;
|
||||||
private static final float MAX_AUDIO_BITRATE = 128f;
|
private static final float MAX_AUDIO_BITRATE = 128f;
|
||||||
@@ -28,6 +28,38 @@ public class CompressionService {
|
|||||||
|
|
||||||
private final Pattern timePattern = Pattern.compile("out_time_ms=(\\d+)");
|
private final Pattern timePattern = Pattern.compile("out_time_ms=(\\d+)");
|
||||||
|
|
||||||
|
public void run(Job job) throws IOException, InterruptedException {
|
||||||
|
logger.info("FFMPEG starting...");
|
||||||
|
|
||||||
|
validateVideoMetadata(job.getInputVideoMetadata(), job.getOutputVideoMetadata());
|
||||||
|
|
||||||
|
ProcessBuilder pb = buildCommand(job.getInputFile(), job.getOutputFile(), job.getOutputVideoMetadata());
|
||||||
|
Process process = pb.start();
|
||||||
|
job.setStatus(JobStatus.RUNNING);
|
||||||
|
|
||||||
|
BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream()));
|
||||||
|
float length = job.getOutputVideoMetadata().getEndPoint() - job.getOutputVideoMetadata().getStartPoint();
|
||||||
|
|
||||||
|
String line;
|
||||||
|
while ((line = reader.readLine()) != null) {
|
||||||
|
logger.debug(line);
|
||||||
|
Matcher matcher = timePattern.matcher(line);
|
||||||
|
|
||||||
|
if (matcher.find()) {
|
||||||
|
Float progress = Long.parseLong(matcher.group(1))/(length*1000000);
|
||||||
|
job.setProgress(progress);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (process.waitFor() != 0) {
|
||||||
|
job.setStatus(JobStatus.FAILED);
|
||||||
|
throw new FFMPEGException("FFMPEG process failed");
|
||||||
|
}
|
||||||
|
|
||||||
|
job.setStatus(JobStatus.FINISHED);
|
||||||
|
logger.info("FFMPEG finished");
|
||||||
|
}
|
||||||
|
|
||||||
private void validateVideoMetadata(VideoMetadata inputFileMetadata, VideoMetadata outputFileMetadata) {
|
private void validateVideoMetadata(VideoMetadata inputFileMetadata, VideoMetadata outputFileMetadata) {
|
||||||
if (outputFileMetadata.getStartPoint() == null) {
|
if (outputFileMetadata.getStartPoint() == null) {
|
||||||
outputFileMetadata.setStartPoint(0f);
|
outputFileMetadata.setStartPoint(0f);
|
||||||
@@ -109,36 +141,4 @@ public class CompressionService {
|
|||||||
return new ProcessBuilder(command);
|
return new ProcessBuilder(command);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void run(Job job) throws IOException, InterruptedException {
|
|
||||||
logger.info("FFMPEG starting...");
|
|
||||||
|
|
||||||
validateVideoMetadata(job.getInputVideoMetadata(), job.getOutputVideoMetadata());
|
|
||||||
|
|
||||||
ProcessBuilder pb = buildCommand(job.getInputFile(), job.getOutputFile(), job.getOutputVideoMetadata());
|
|
||||||
Process process = pb.start();
|
|
||||||
job.setStatus(JobStatus.RUNNING);
|
|
||||||
|
|
||||||
BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream()));
|
|
||||||
float length = job.getOutputVideoMetadata().getEndPoint() - job.getOutputVideoMetadata().getStartPoint();
|
|
||||||
|
|
||||||
String line;
|
|
||||||
while ((line = reader.readLine()) != null) {
|
|
||||||
logger.debug(line);
|
|
||||||
Matcher matcher = timePattern.matcher(line);
|
|
||||||
|
|
||||||
if (matcher.find()) {
|
|
||||||
Float progress = Long.parseLong(matcher.group(1))/(length*1000000);
|
|
||||||
job.setProgress(progress);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (process.waitFor() != 0) {
|
|
||||||
job.setStatus(JobStatus.FAILED);
|
|
||||||
throw new FFMPEGException("FFMPEG process failed");
|
|
||||||
}
|
|
||||||
|
|
||||||
job.setStatus(JobStatus.FINISHED);
|
|
||||||
logger.info("FFMPEG finished");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -24,14 +24,14 @@ public class JobService {
|
|||||||
private static final Logger logger = LoggerFactory.getLogger(JobService.class);
|
private static final Logger logger = LoggerFactory.getLogger(JobService.class);
|
||||||
private final ConcurrentHashMap<String, Job> jobs = new ConcurrentHashMap<>();
|
private final ConcurrentHashMap<String, Job> jobs = new ConcurrentHashMap<>();
|
||||||
private final BlockingQueue<Job> jobQueue = new LinkedBlockingQueue<>();
|
private final BlockingQueue<Job> jobQueue = new LinkedBlockingQueue<>();
|
||||||
private final CompressionService compressionService;
|
private final ClipService clipService;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructs a JobService with the given CompressionService.
|
* Constructs a JobService with the given CompressionService.
|
||||||
* @param compressionService the compression service to use for processing jobs
|
* @param clipService the compression service to use for processing jobs
|
||||||
*/
|
*/
|
||||||
public JobService(CompressionService compressionService) {
|
public JobService(ClipService clipService) {
|
||||||
this.compressionService = compressionService;
|
this.clipService = clipService;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -78,7 +78,7 @@ public class JobService {
|
|||||||
*/
|
*/
|
||||||
private void processJob(Job job) {
|
private void processJob(Job job) {
|
||||||
try {
|
try {
|
||||||
compressionService.run(job);
|
clipService.run(job);
|
||||||
} catch (IOException | InterruptedException e) {
|
} catch (IOException | InterruptedException e) {
|
||||||
Thread.currentThread().interrupt();
|
Thread.currentThread().interrupt();
|
||||||
logger.error("Error while running job {}", job.getUuid(), e);
|
logger.error("Error while running job {}", job.getUuid(), e);
|
||||||
|
|||||||
Reference in New Issue
Block a user