Creating M3U Playlists for xPola Player

Creating M3U Playlists for xPola Player


This tutorial walks you through creating an M3U playlist that’s compatible with the xPola Player, an advanced media player capable of playing multiple formats. The steps below will help you structure and customize your M3U playlist to include features like logos, user-agent headers, and multi-server support.

Steps to Create an M3U Playlist
Step 1: Start by opening a text editor, such as Notepad++ or any other code editor, and create a new file. Save it with a relevant name, such as playlist.m3u.

Step 2: At the very beginning of your playlist file, add the following line to indicate that the file is an M3U playlist:
Step 2: At the very beginning of your playlist file, add the following line to indicate that the file is an M3U playlist:

#EXTM3U
Enter fullscreen mode

Exit fullscreen mode

Step 3: Add each media entry following this structure. You can include details like group titles, channel logos, and video names. Below is an example:

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
https://example.com/file/video.m3u8
Enter fullscreen mode

Exit fullscreen mode

To configure the playlist with specific headers like user-agent, referrer, or player type, use the appropriate commands as shown below.
Adding User-Agent
To include a specific user-agent header for the stream, use:

#EXTVLCOPT:http-user-agent=your-agent-here
Enter fullscreen mode

Exit fullscreen mode

For example:

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
#EXTVLCOPT:http-user-agent=your-agent-here
https://example.com/file/video.m3u8
Enter fullscreen mode

Exit fullscreen mode

Adding Referrer
To specify a referrer, add:

#EXTVLCOPT:http-referrer=https://domaine.com/
Enter fullscreen mode

Exit fullscreen mode

Example:

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
#EXTVLCOPT:http-referrer=https://domaine.com/
https://example.com/file/video.m3u8
Enter fullscreen mode

Exit fullscreen mode

Setting the HTTP Origin
To set the HTTP origin for a video link, use the following line:

#EXTVLCOPT:http-origin=https://domaine.com
Enter fullscreen mode

Exit fullscreen mode

Example:

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
#EXTVLCOPT:http-origin=https://domaine.com
https://example.com/file/video.m3u8
Enter fullscreen mode

Exit fullscreen mode

This option is used to specify the HTTP origin header when accessing the video link. It’s essential for certain streams or servers that require an origin value to ensure the request is valid, usually to check the origin of the request for security or access control purposes.

Setting the X-Requested-With Header
To set the X-Requested-With header for a video link, use the following line:

#EXTVLCOPT:http-requested=com.android.browser
Enter fullscreen mode

Exit fullscreen mode

Example:

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
#EXTVLCOPT:http-requested=com.android.browser
https://example.com/file/video.m3u8
Enter fullscreen mode

Exit fullscreen mode

This option is used to specify the X-Requested-With HTTP header when accessing the video link. This header is often required by servers to identify the client making the request, commonly for security, access control, or compatibility purposes.

Setting Custom Cookies for a Video Stream
This option allows you to pass custom cookies to the video stream URL. Cookies can be used for authentication, session handling, or other purposes required by the server to grant access to the media content.

#EXTVLCOPT:http-cookie=name=value;name2=value2
Enter fullscreen mode

Exit fullscreen mode

Example:

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
#EXTVLCOPT:http-cookie=name=value;name2=value2
https://example.com/file/example.m3u8
Enter fullscreen mode

Exit fullscreen mode

How it works: You define one or more cookies using the format name=value. You can set multiple cookies by separating them with semicolons. When the media player sends the request to access the video, it will include these cookies in the request headers, just as a browser would. This is useful when the server requires specific cookie values to grant access to the video stream.

For example, if the server requires session authentication or other information stored in cookies, you can set these values to ensure the player can access and play the content properly.

Setting the Player Type to Web Player
To configure the player type as “webplayer”, use the following line:

#EXTVLCOPT:http-player-type=webplayer
Enter fullscreen mode

Exit fullscreen mode

#EXTVLCOPT:http-player-type=browser
Enter fullscreen mode

Exit fullscreen mode

#EXTVLCOPT:http-player-type=browser
Enter fullscreen mode

Exit fullscreen mode

#EXTVLCOPT:http-player-type=external
Enter fullscreen mode

Exit fullscreen mode

#EXTVLCOPT:http-player-type=m3u
Enter fullscreen mode

Exit fullscreen mode

Example:

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
#EXTVLCOPT:http-player-type=webplayer
https://example.com/file/video.html
Enter fullscreen mode

Exit fullscreen mode

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
#EXTVLCOPT:http-player-type=m3u
https://example.com/file/playlist.m3u
Enter fullscreen mode

Exit fullscreen mode

This option tells the player to open the link in a web player format. It’s useful when the content is designed to be played directly in a browser or web-based media player rather than a standalone app or media player.

Advanced Configurations
To handle multi-server streams or advanced player configurations, you can add multiple server links in the following format:

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
servers=["https://server1.com/playlist.m3u8|referer=https://example.com/", 
         "https://server2.com/playlist.m3u8|user-agent=CustomAgent"]
Enter fullscreen mode

Exit fullscreen mode

You can also specify DRM license configurations for ClearKey, Widevine, or PlayReady:

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
#EXTVLCOPT:http-drm-scheme=clearkey
#EXTVLCOPT:http-drm-license=xxxxxxxxxxxxxxxxx:yyyyyyyyyyyyyyyyyy
https://example.com/file/stream.mpd
Enter fullscreen mode

Exit fullscreen mode

OR

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
#KODIPROP:inputstream.adaptive.license_type=clearkey
#KODIPROP:inputstream.adaptive.license_key=xxxxxxxxxxxxxxxxx:yyyyyyyyyyyyyyyyyy
https://example.com/file/stream.mpd
Enter fullscreen mode

Exit fullscreen mode

OR

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
https://example.com/file/stream.mpd?|drmScheme=clearkey&drmLicense=xxxxxxxxxxxxxxxxx:yyyyyyyyyyyyyyyyyy
Enter fullscreen mode

Exit fullscreen mode

Automatically Fetching a Video Stream from a Webpage
This option is particularly useful when you have a webpage with an embedded video player or video link, and you want the media player to find and play the video stream without showing the webpage itself.

#EXTVLCOPT:http-find=any_key_word_in_the_link;m3u8
Enter fullscreen mode

Exit fullscreen mode

Example:

#EXTINF:-1 group-title="Group Name" tvg-logo="https://example.com/images/logo.jpeg", Video Name 1
#EXTVLCOPT:http-find=any_key_word_in_the_link;m3u8
https://example.com/file/example.html
Enter fullscreen mode

Exit fullscreen mode

How it works: You provide the link to a webpage that contains the video player or video URL, and specify a keyword (like “m3u8”) that is part of the actual video link. The player will open the webpage in the background, search for the video link that matches the keyword, extract it, and play the video directly in the player without displaying the webpage.

This is useful for avoiding unnecessary webpage content and directly streaming the video by automatically finding the correct video link from the page.

PHP and HTML Integration

If you want to open videos in the xPola Player app directly from a web page, you can use the following PHP or HTML code snippets. These examples show how to encode a video URL and pass it to the xPola Player via an intent in Android:

<?php
$videoUrl = "https://example.com/file/playlist.m3u8";
?>
<button onClick="location.href="https://dev.to/adama_bongado_a857dfff7ed/intent://<?php echo base64_encode($videoUrl); ?>#Intent;scheme=xmtv;package=com.xpola.player;end"">Play</button>
Enter fullscreen mode

Exit fullscreen mode

Similar HTML-based buttons can be created to trigger playback directly in xPola Player:

<!DOCTYPE html>
<html>
<head>
    <title>Play Video</title>
</head>
<body>
    <button onclick="playVideo()">Play Video</button>
    <script>
        function playVideo() {
            let videoUrl = "https://example.com/file/playlist.m3u8|referer=https://example.com/";
            location.href="https://dev.to/adama_bongado_a857dfff7ed/intent://" + btoa(videoUrl) + '#Intent;scheme=xmtv;package=com.xpola.player;end';
        }
    </script>
</body>
</html>
Enter fullscreen mode

Exit fullscreen mode



Source link
lol

By stp2y

Leave a Reply

Your email address will not be published. Required fields are marked *

No widgets found. Go to Widget page and add the widget in Offcanvas Sidebar Widget Area.