org.red5.server.stream.AbstractStream Maven / Gradle / Ivy
/*
* RED5 Open Source Media Server - https://github.com/Red5/
*
* Copyright 2006-2016 by respective authors (see below). All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.red5.server.stream;
import java.util.Map;
import java.util.concurrent.Semaphore;
import java.util.concurrent.atomic.AtomicReference;
import org.red5.codec.IStreamCodecInfo;
import org.red5.codec.StreamCodecInfo;
import org.red5.io.object.DataTypes;
import org.red5.io.object.Input;
import org.red5.server.api.scope.IScope;
import org.red5.server.api.scope.IScopeHandler;
import org.red5.server.api.stream.IStream;
import org.red5.server.api.stream.IStreamAwareScopeHandler;
import org.red5.server.api.stream.StreamState;
import org.red5.server.net.rtmp.event.Notify;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Abstract base implementation of IStream. Contains codec information, stream name, scope, event handling, and provides stream start and stop operations.
*
* @see org.red5.server.api.stream.IStream
*/
public abstract class AbstractStream implements IStream {
private static final Logger log = LoggerFactory.getLogger(AbstractStream.class);
/**
* Current state
*/
protected StreamState state = StreamState.UNINIT;
/**
* Stream name
*/
private String name;
/**
* Stream audio and video codec information
*/
private IStreamCodecInfo codecInfo = new StreamCodecInfo();
/**
* Stores the streams metadata
*/
private AtomicReference metaData = new AtomicReference<>();
/**
* Stream scope
*/
private IScope scope;
/**
* Timestamp the stream was created.
*/
protected long creationTime;
/**
* Lock for protecting critical sections
*/
protected final transient Semaphore lock = new Semaphore(1, true);
private long absoluteStartTimeMs;
/**
* Return stream name.
*
* @return Stream name
*/
public String getName() {
return name;
}
/**
* Return codec information.
*
* @return Stream codec information
*/
public IStreamCodecInfo getCodecInfo() {
return codecInfo;
}
/**
* Returns a copy of the metadata for the associated stream, if it exists.
*
* @return stream meta data
*/
public Notify getMetaData() {
Notify md = metaData.get();
if (md != null) {
try {
return md.duplicate();
} catch (Exception e) {
}
}
return md;
}
/**
* Set the metadata.
*
* @param metaData stream meta data
*/
public void setMetaData(Notify metaData) {
this.metaData.set(metaData);
Input input = new org.red5.io.amf.Input(metaData.getData());
byte object = input.readDataType();
if (object == DataTypes.CORE_SWITCH) {
input = new org.red5.io.amf3.Input(metaData.getData());
((org.red5.io.amf3.Input) input).enforceAMF3();
// re-read data type after switching decode
object = input.readDataType();
}
String actionOnFI = input.readString();
byte readDataType = input.readDataType();
if (readDataType == DataTypes.CORE_MAP) {
log.info("metadata read data type -->>>> core map");
Map