simple internet radio built using web 2.0 technology
This commit is contained in:
commit
4d7001c399
23
channels.md
Normal file
23
channels.md
Normal file
|
@ -0,0 +1,23 @@
|
|||
Rainbow FM 6, https://air.pc.cdn.bitgravity.com/air/live/pbaudio022/playlist.m3u8
|
||||
Radio Mirchi Tamil, https://tamil.crabdance.com:8002/1
|
||||
Radio City Live, https://tamil.crabdance.com:8002/5
|
||||
MGR/Sivaji Hits, https://stream.zeno.fm/pq4yq4qri9yvv
|
||||
Chennai City FM, https://stream.zeno.fm/cn8sh3supsnvv
|
||||
American Tamil Radio, https://cp11.serverse.com/proxy/hgsmgluv/stream
|
||||
British Indian Tamil Radio, https://hello.citrus3.com:2020/stream/britishindiantamilradio
|
||||
Cuckoo Tamil Comedy Radio, https://radio-proxy.arulbalaji.xyz/audio-stream/cuckoo-tamil-comedy/
|
||||
Goundamani Senthil Radio, https://radio-proxy.arulbalaji.xyz/audio-stream/goundamanisenthil-radio/
|
||||
Vadivelu Comedy Radio, https://radio-proxy.arulbalaji.xyz/audio-stream/vadivelu-comedy-radio/
|
||||
Tamil Comedy Radio, https://radio-proxy.arulbalaji.xyz/audio-stream/tamil-comedy-radio/
|
||||
Sooriyan FM, https://www.liveradio.es/http://radio.lotustechnologieslk.net:8006/;stream.mp3
|
||||
Tamil 80s Radio, https://stream-164.zeno.fm/48w230kx8vzuv
|
||||
Tamil FM 89.4, https://centova.aarenworld.com/proxy/894tamilfm/stream
|
||||
Big FM 92.7, https://tamil.crabdance.com:8002/4
|
||||
Tamil Panpalai Radio, https://tamilpanpalai.radioca.st/ind
|
||||
Air Chennai FM Gold 102.3, https://air.pc.cdn.bitgravity.com/air/live/pbaudio021/playlist.m3u8
|
||||
IlayaRaja Voice, https://stream.zeno.fm/qfd4vokvu3dvv
|
||||
GV Prakash Radio, https://stream.zeno.fm/c9cxafngfekvv
|
||||
SPB Old Hits, https://stream.zeno.fm/lgukkevrihmvv
|
||||
AR Rahman FM, https://www.liveradio.es/http://stream.zeno.fm/ihpr0rqzoxquv
|
||||
Harris Jayaraj Radio, https://stream-158.zeno.fm/0bhsthssutzuv
|
||||
Santhosh Narayanan Radio, https://stream.zeno.fm/wkqvzsg1238uv
|
6
fix-permission
Executable file
6
fix-permission
Executable file
|
@ -0,0 +1,6 @@
|
|||
#!/bin/bash
|
||||
|
||||
sudo chown arul:arul /var/www/html/Internet-Radio/channels.md
|
||||
sudo chmod 644 /var/www/html/Internet-Radio/channels.md
|
||||
|
||||
|
171
index.html
Normal file
171
index.html
Normal file
|
@ -0,0 +1,171 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title>Radio Stream Player</title>
|
||||
<style>
|
||||
body {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
height: 100vh;
|
||||
margin: 0;
|
||||
font-family: Arial, sans-serif;
|
||||
background-color: #000;
|
||||
color: #fff;
|
||||
flex-direction: column;
|
||||
}
|
||||
.container {
|
||||
text-align: center;
|
||||
max-width: 90%;
|
||||
width: 400px;
|
||||
padding: 20px;
|
||||
background: transparent;
|
||||
border-radius: 10px;
|
||||
box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.3);
|
||||
border: 1px solid #fff;
|
||||
}
|
||||
h1 {
|
||||
margin-bottom: 10px;
|
||||
font-size: 1.5rem;
|
||||
}
|
||||
select {
|
||||
padding: 10px;
|
||||
font-size: 16px;
|
||||
border: 1px solid #fff;
|
||||
background-color: #333;
|
||||
color: #fff;
|
||||
cursor: pointer;
|
||||
width: 100%;
|
||||
max-width: 100%;
|
||||
margin-top: 10px;
|
||||
border-radius: 5px;
|
||||
}
|
||||
audio, iframe {
|
||||
width: 100%;
|
||||
margin-top: 15px;
|
||||
display: none; /* Initially hidden */
|
||||
}
|
||||
iframe {
|
||||
height: 250px;
|
||||
border-radius: 8px;
|
||||
border: none;
|
||||
object-fit: cover;
|
||||
}
|
||||
|
||||
/* Mobile responsiveness */
|
||||
@media (max-width: 768px) {
|
||||
.container {
|
||||
padding: 15px;
|
||||
}
|
||||
h1 {
|
||||
font-size: 1.3rem;
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
iframe {
|
||||
height: 200px;
|
||||
}
|
||||
}
|
||||
|
||||
@media (max-width: 480px) {
|
||||
h1 {
|
||||
font-size: 1.1rem;
|
||||
margin-bottom: 5px;
|
||||
}
|
||||
iframe {
|
||||
height: 180px;
|
||||
}
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<div class="container">
|
||||
<h1>Radio Stream Player</h1>
|
||||
<select id="channelSelect">
|
||||
<option value="off">OFF</option>
|
||||
</select>
|
||||
<audio id="audioPlayer" controls></audio>
|
||||
<iframe id="streamIframe" src="about:blank" allowfullscreen></iframe>
|
||||
</div>
|
||||
|
||||
<script src="https://cdn.jsdelivr.net/npm/hls.js@latest"></script>
|
||||
<script>
|
||||
const channelSelect = document.getElementById('channelSelect');
|
||||
const audioPlayer = document.getElementById('audioPlayer');
|
||||
const streamIframe = document.getElementById('streamIframe');
|
||||
|
||||
// Fetch channels from channels.md
|
||||
fetch('channels.md')
|
||||
.then(response => response.text())
|
||||
.then(text => {
|
||||
const lines = text.split('\n');
|
||||
lines.forEach(line => {
|
||||
const [name, url] = line.split(',').map(item => item.trim());
|
||||
if (name && url) {
|
||||
const option = document.createElement('option');
|
||||
option.value = url;
|
||||
option.textContent = name;
|
||||
channelSelect.appendChild(option);
|
||||
}
|
||||
});
|
||||
})
|
||||
.catch(error => console.error('Error loading channels.md:', error));
|
||||
|
||||
// Event listener for channel selection
|
||||
channelSelect.addEventListener('change', function() {
|
||||
const selectedUrl = this.value;
|
||||
resetPlayer(); // Reset player before selecting the new channel
|
||||
|
||||
if (selectedUrl === 'off') return; // Do nothing if 'OFF' is selected
|
||||
|
||||
if (selectedUrl.endsWith('.m3u8')) {
|
||||
playHLS(selectedUrl); // Play using HLS.js
|
||||
} else if (selectedUrl.includes('crabdance.com')) {
|
||||
streamIframe.src = selectedUrl;
|
||||
streamIframe.style.display = 'block';
|
||||
} else {
|
||||
playAudio(selectedUrl); // Regular audio stream
|
||||
}
|
||||
});
|
||||
|
||||
// Function to reset and stop any ongoing media
|
||||
function resetPlayer() {
|
||||
if (!audioPlayer.paused) {
|
||||
audioPlayer.pause();
|
||||
audioPlayer.src = ''; // Clear the audio source
|
||||
}
|
||||
audioPlayer.style.display = 'none'; // Hide audio player
|
||||
streamIframe.src = ''; // Clear iframe source
|
||||
streamIframe.style.display = 'none'; // Hide iframe
|
||||
}
|
||||
|
||||
// Function to play regular audio
|
||||
function playAudio(url) {
|
||||
audioPlayer.src = url;
|
||||
audioPlayer.style.display = 'block'; // Show the audio player
|
||||
audioPlayer.play().catch((error) => {
|
||||
console.error('Error playing audio:', error);
|
||||
});
|
||||
}
|
||||
|
||||
// Function to play HLS stream using Hls.js
|
||||
function playHLS(url) {
|
||||
if (Hls.isSupported()) {
|
||||
const hls = new Hls();
|
||||
hls.loadSource(url);
|
||||
hls.attachMedia(audioPlayer);
|
||||
hls.on(Hls.Events.MANIFEST_PARSED, () => {
|
||||
audioPlayer.style.display = 'block';
|
||||
audioPlayer.play().catch((error) => {
|
||||
console.error('Error playing HLS stream:', error);
|
||||
});
|
||||
});
|
||||
} else {
|
||||
alert('HLS is not supported in your browser');
|
||||
}
|
||||
}
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
|
14
server
Executable file
14
server
Executable file
|
@ -0,0 +1,14 @@
|
|||
#!/bin/bash
|
||||
|
||||
# Start a simple HTTP server using Python
|
||||
PORT=8001
|
||||
echo "Starting HTTP server on port $PORT..."
|
||||
|
||||
# Check if Python 3 is installed
|
||||
if command -v python3 &>/dev/null; then
|
||||
python3 -m http.server $PORT
|
||||
else
|
||||
echo "Python 3 is not installed. Please install it to run the server."
|
||||
exit 1
|
||||
fi
|
||||
|
Loading…
Reference in New Issue
Block a user