io.antmedia.security.ITokenService Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ant-media-server Show documentation
Show all versions of ant-media-server Show documentation
Ant Media Server supports RTMP, RTSP, MP4, HLS, WebRTC, Adaptive Streaming, etc.
package io.antmedia.security;
import java.util.Map;
import io.antmedia.datastore.db.types.Token;
public interface ITokenService {
public enum BeanName {
TOKEN_SERVICE("token.service");
private String originName;
BeanName(String name) {
this.originName = name;
}
@Override
public String toString() {
return this.originName;
}
}
/**
* Compare hash string with computed one which is based on streamId,type and secret
* @param hash - client hash
* @param streamId - id of the stream
* @param sessionId - session of the request
* @param type - type of the request (publish/play)
* @return
*/
boolean checkHash(String hash, String streamId, String sessionId, String type);
/**
* Checks the token validity
* @param tokenId - requested token id
* @param streamId - id of the stream
* @param sessionId - id of the current session
* @param type - type of the token (play/publish)
* @return true or false
*/
boolean checkToken (String tokenId, String streamId, String sessionId, String type);
/**
* Checks the time based token validity
* @param subscriberId - requested subscriberId
* @param streamId - id of the stream
* @param sessionId - id of the current session
* @param subscriberCode - with TOTP generated code
* @return true or false
*/
boolean checkTimeBasedSubscriber(String subscriberId, String streamId, String sessionId, String subscriberCode, boolean forPublish);
/**
* Checks the JWT token validity
* @param jwtTokenId - requested token id
* @param streamId - id of the stream
* @param type - type of the token (play/publish)
* @return true or false
*/
boolean checkJwtToken (String jwtTokenId, String streamId, String type);
/**
* creates token according to the provided parameters
* @param streamId - id of the requested stream for token creation
* @param exprireDate - expire date of the token
* @param type type of the token (play/publish)
* @param roomId- id of the room for playing streams in the room
* @return token
*/
Token createToken(String streamId, long exprireDate, String type, String roomId);
/**
* creates token according to the provided parameters
* @param streamId - id of the requested stream for token creation
* @param exprireDate - expire date of the token (unix timestamp)
* @param type type of the token (play/publish)
* @param roomId- id of the room for playing streams in the room
* @return token
*/
Token createJwtToken(String streamId, long exprireDate, String type, String roomId);
/**
* gets map of authenticated sessions
* @return list
*/
Map getAuthenticatedMap();
/**
* gets map of authenticated subscriber sessions
* @return list
*/
Map getSubscriberAuthenticatedMap();
}