mirror of
				https://gitlab.crans.org/nounous/ghostream.git
				synced 2025-10-25 09:23:03 +02:00 
			
		
		
		
	Compare commits
	
		
			6 Commits
		
	
	
		
			ovenmediae
			...
			8d2adad509
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 8d2adad509 | ||
|  | 0035c63c22 | ||
|  | 849196b4cb | ||
|  | 205c4b526c | ||
|  | 1d117ea480 | ||
|  | 45cb61e436 | 
| @@ -3,12 +3,14 @@ package ldap | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"github.com/go-ldap/ldap/v3" | 	"github.com/go-ldap/ldap/v3" | ||||||
|  | 	"log" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| // Options holds package configuration | // Options holds package configuration | ||||||
| type Options struct { | type Options struct { | ||||||
| 	URI    string | 	Aliases map[string]string | ||||||
| 	UserDn string | 	URI     string | ||||||
|  | 	UserDn  string | ||||||
| } | } | ||||||
|  |  | ||||||
| // LDAP authentification backend | // LDAP authentification backend | ||||||
| @@ -20,6 +22,12 @@ type LDAP struct { | |||||||
| // Login tries to bind to LDAP | // Login tries to bind to LDAP | ||||||
| // Returns (true, nil) if success | // Returns (true, nil) if success | ||||||
| func (a LDAP) Login(username string, password string) (bool, error) { | func (a LDAP) Login(username string, password string) (bool, error) { | ||||||
|  | 	// Resolve stream alias if necessary | ||||||
|  | 	for aliasFor, ok := a.Cfg.Aliases[username]; ok; aliasFor, ok = a.Cfg.Aliases[username] { | ||||||
|  | 		log.Printf("[LDAP] Use stream alias %s for username %s", username, aliasFor) | ||||||
|  | 		username = aliasFor | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	// Try to bind as user | 	// Try to bind as user | ||||||
| 	bindDn := "cn=" + username + "," + a.Cfg.UserDn | 	bindDn := "cn=" + username + "," + a.Cfg.UserDn | ||||||
| 	err := a.Conn.Bind(bindDn, password) | 	err := a.Conn.Bind(bindDn, password) | ||||||
|   | |||||||
| @@ -21,8 +21,11 @@ | |||||||
|                 </IceCandidates> |                 </IceCandidates> | ||||||
|             </WebRTC> |             </WebRTC> | ||||||
|             <HLS> |             <HLS> | ||||||
|                 <Port>80</Port> |               <Port>80</Port> | ||||||
|             </HLS> |             </HLS> | ||||||
|  |             <DASH> | ||||||
|  |                 <Port>80</Port> | ||||||
|  |             </DASH> | ||||||
|         </Publishers> |         </Publishers> | ||||||
|     </Bind> |     </Bind> | ||||||
|  |  | ||||||
| @@ -52,14 +55,15 @@ | |||||||
|                             </Video> |                             </Video> | ||||||
|                         </Encode> |                         </Encode> | ||||||
|                         <Encode> |                         <Encode> | ||||||
|                             <Name>BYPASS</Name> |                             <Name>bypass</Name> | ||||||
|                             <Video> |  | ||||||
|                                 <Bypass>true</Bypass> |  | ||||||
|                             </Video> |  | ||||||
|                             <Audio> |                             <Audio> | ||||||
|                                 <Bypass>true</Bypass> |                                 <Bypass>true</Bypass> | ||||||
|                             </Audio> |                             </Audio> | ||||||
|  |                             <Video> | ||||||
|  |                                 <Bypass>true</Bypass> | ||||||
|  |                             </Video> | ||||||
|                         </Encode> |                         </Encode> | ||||||
|  |  | ||||||
|                     </Encodes> |                     </Encodes> | ||||||
|                     <Streams> |                     <Streams> | ||||||
|                         <Stream> |                         <Stream> | ||||||
| @@ -71,9 +75,10 @@ | |||||||
|                         <Stream> |                         <Stream> | ||||||
|                             <Name>${OriginStreamName}_bypass</Name> |                             <Name>${OriginStreamName}_bypass</Name> | ||||||
|                             <Profiles> |                             <Profiles> | ||||||
|                                 <Profile>BYPASS</Profile> |                                 <Profile>bypass</Profile> | ||||||
|                             </Profiles> |                             </Profiles> | ||||||
|                         </Stream> |                         </Stream> | ||||||
|  |  | ||||||
|                     </Streams> |                     </Streams> | ||||||
|                     <Providers> |                     <Providers> | ||||||
|                         <RTMP> |                         <RTMP> | ||||||
| @@ -86,12 +91,25 @@ | |||||||
|                             <Timeout>30000</Timeout> |                             <Timeout>30000</Timeout> | ||||||
|                         </WebRTC> |                         </WebRTC> | ||||||
|                         <HLS> |                         <HLS> | ||||||
|                             <SegmentDuration>5</SegmentDuration> |                             <SegmentDuration>2</SegmentDuration> | ||||||
|                             <SegmentCount>2</SegmentCount> |                             <SegmentCount>2</SegmentCount> | ||||||
|                             <CrossDomain> |                             <CrossDomain> | ||||||
|                                 <Url>*</Url> |                                 <Url>*</Url> | ||||||
|                             </CrossDomain> |                             </CrossDomain> | ||||||
|                         </HLS> |                         </HLS> | ||||||
|  |                         <DASH> | ||||||
|  |                             <SegmentDuration>2</SegmentDuration> | ||||||
|  |                             <SegmentCount>2</SegmentCount> | ||||||
|  |                             <CrossDomain> | ||||||
|  |                                 <Url>*</Url> | ||||||
|  |                             </CrossDomain> | ||||||
|  |                         </DASH> | ||||||
|  |                         <LLDASH> | ||||||
|  |                             <SegmentDuration>2</SegmentDuration> | ||||||
|  |                             <CrossDomain> | ||||||
|  |                                 <Url>*</Url> | ||||||
|  |                             </CrossDomain> | ||||||
|  |                         </LLDASH> | ||||||
|                     </Publishers> |                     </Publishers> | ||||||
|                 </Application> |                 </Application> | ||||||
|             </Applications> |             </Applications> | ||||||
|   | |||||||
| @@ -34,6 +34,11 @@ auth: | |||||||
|   #ldap: |   #ldap: | ||||||
|   #  uri: ldap://127.0.0.1:389 |   #  uri: ldap://127.0.0.1:389 | ||||||
|   #  userdn: cn=users,dc=example,dc=com |   #  userdn: cn=users,dc=example,dc=com | ||||||
|  |   # | ||||||
|  |   #  # You can define aliases, to stream on stream.example.com/example with the credentials of the demo account. | ||||||
|  |   #  aliases: | ||||||
|  |   #    example: demo | ||||||
|  |   # | ||||||
|  |  | ||||||
| ## Stream forwarding ## | ## Stream forwarding ## | ||||||
| # Forward an incoming stream to other servers | # Forward an incoming stream to other servers | ||||||
|   | |||||||
| @@ -42,8 +42,9 @@ func New() *Config { | |||||||
| 				Credentials: make(map[string]string), | 				Credentials: make(map[string]string), | ||||||
| 			}, | 			}, | ||||||
| 			LDAP: ldap.Options{ | 			LDAP: ldap.Options{ | ||||||
| 				URI:    "ldap://127.0.0.1:389", | 				Aliases: make(map[string]string), | ||||||
| 				UserDn: "cn=users,dc=example,dc=com", | 				URI:     "ldap://127.0.0.1:389", | ||||||
|  | 				UserDn:  "cn=users,dc=example,dc=com", | ||||||
| 			}, | 			}, | ||||||
| 		}, | 		}, | ||||||
| 		Forwarding: make(map[string][]string), | 		Forwarding: make(map[string][]string), | ||||||
|   | |||||||
| @@ -47,10 +47,20 @@ export function initViewerPage(stream, omeApp, viewersCounterRefreshPeriod, post | |||||||
|                 "label": " WebRTC - Source" |                 "label": " WebRTC - Source" | ||||||
|             }, |             }, | ||||||
|             { |             { | ||||||
|                 "type": "hls", |  | ||||||
|                 "file": "https://" + window.location.host + "/" + omeApp + "/" + stream + "_bypass/playlist.m3u8", |                 "file": "https://" + window.location.host + "/" + omeApp + "/" + stream + "_bypass/playlist.m3u8", | ||||||
|  |                 "type": "hls", | ||||||
|                 "label": " HLS" |                 "label": " HLS" | ||||||
|             } |             }, | ||||||
|  |             { | ||||||
|  |                 "file": "https://" + window.location.host + "/" + omeApp + "/" + stream + "_bypass/manifest.mpd", | ||||||
|  |                 "type": "dash", | ||||||
|  |                 "label": "DASH" | ||||||
|  |             }, | ||||||
|  |             { | ||||||
|  |                 "file": "https://" + window.location.host + "/" + omeApp + "/" + stream + "_bypass/manifest_ll.mpd", | ||||||
|  |                 "type": "dash", | ||||||
|  |                 "label": "LL-DASH" | ||||||
|  |             }, | ||||||
|         ] |         ] | ||||||
|     }); |     }); | ||||||
|     player.on("stateChanged", function (data) { |     player.on("stateChanged", function (data) { | ||||||
|   | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										2
									
								
								web/static/ovenplayer/ovenplayer.provider.Html5-0.9.0.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								web/static/ovenplayer/ovenplayer.provider.Html5-0.9.0.js
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | /*! OvenPlayerv0.9.0 | (c)2020 AirenSoft Co., Ltd. | MIT license (https://github.com/AirenSoft/OvenPlayerPrivate/blob/master/LICENSE) | Github : https://github.com/AirenSoft/OvenPlayer */ | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										2
									
								
								web/static/ovenplayer/ovenplayer.sdk.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								web/static/ovenplayer/ovenplayer.sdk.js
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										1
									
								
								web/static/ovenplayer/ovenplayer.sdk.js.LICENSE
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								web/static/ovenplayer/ovenplayer.sdk.js.LICENSE
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | /*! OvenPlayerv0.9.0 | (c)2020 AirenSoft Co., Ltd. | MIT license (https://github.com/AirenSoft/OvenPlayerPrivate/blob/master/LICENSE) | Github : https://github.com/AirenSoft/OvenPlayer */ | ||||||
| @@ -36,6 +36,7 @@ | |||||||
|  |  | ||||||
| {{if .OMECfg.Enabled}} | {{if .OMECfg.Enabled}} | ||||||
|   <script src="https://cdn.jsdelivr.net/npm/hls.js@latest"></script> |   <script src="https://cdn.jsdelivr.net/npm/hls.js@latest"></script> | ||||||
|  |   <script src="https://cdnjs.cloudflare.com/ajax/libs/dashjs/2.9.3/dash.all.min.js"></script> | ||||||
|   <script src="/static/ovenplayer/ovenplayer.js"></script> |   <script src="/static/ovenplayer/ovenplayer.js"></script> | ||||||
|   <script src="/static/js/ovenplayer.js"></script> |   <script src="/static/js/ovenplayer.js"></script> | ||||||
| {{end}} | {{end}} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user