Skip to main content

A simple Discord chat exporter for Python Discord bots.

Project description

Version Language Forks Stargazers Issues GPL License

Hikari-ChatExporter

Export Discord chats with your hikari bots!


Installation

To install the library to your virtual environment, for bot usage, run the command:

pip install hikari-chat-exporter

To clone the repository locally, run the command:

git clone https://github.com/EgehanKilicarslan/Hikari-ChatExporter

(back to top)


Usage

There are currently 3 methods (functions) to chat-exporter which you can use to export your chat.
Expand the blocks below to learn the functions, arguments and usages.

Basic Usage

.quick_export() is the simplest way of using chat-exporter.

Using the quick_export function will gather the history of the channel you give, build the transcript then post the file and embed directly to the channel - returning a message object gathered from the message it posted.

This is mostly seen as a demo function, as opposed to a command you should actually use.

Required Argument(s):
channel: hikari.channels.PartialChannel object, whether ctx.channel or any channel you gather.

Optional Argument(s):
bot: commands.Bot object to gather members who are no longer in your guild.

Return Argument:
hikari.messages.Message: The message quick_export will send, containing the embed and exported chat file.

Example:

import hikari
import lightbulb
import chat_exporter


bot = hikari.GatewayBot(token="...")
client = lightbulb.client_from_app(bot)
bot.subscribe(hikari.StartingEvent, client.start)

...

@client.register
class Save(
    lightbulb.SlashCommand, 
    name="save",
    description="Saves current chat transcript."
):
    @lightbulb.invoke
    async def invoke(self, ctx: lightbulb.Context) -> None:
        await chat_exporter.quick_export(ctx.interaction.get_channel())
        await ctx.respond("Transcript created!")

...
Customisable Usage

.export() is the most efficient and flexible method to export a chat using chat-exporter.

Using the export function will generate a transcript using the channel you pass in, along with using any of the custom kwargs passed in to set limits, timezone, 24h formats and more (listed below).

This would be the main function to use within chat-exporter.

Required Argument(s):
channel: hikari.channels.PartialChannel object, whether ctx.channel or any channel you gather.

Optional Argument(s):
limit: Integer value to set the limit (amount of messages) the chat exporter gathers when grabbing the history (default=unlimited).
tz_info: String value of a TZ Database name to set a custom timezone for the exported messages (default=UTC)
military_time: Boolean value to set a 24h format for times within your exported chat (default=False | 12h format)
fancy_times: Boolean value which toggles the 'fancy times' (Today|Yesterday|Day)
bot: commands.Bot object to gather members who are no longer in your guild.

Return Argument:
transcript: The HTML build-up for you to construct the HTML File with Discord.

Example:

import io
import hikari
import lightbulb
import chat_exporter


bot = hikari.GatewayBot(token="...")
client = lightbulb.client_from_app(bot)
bot.subscribe(hikari.StartingEvent, client.start)

...

@client.register
class Save(
    lightbulb.SlashCommand, 
    name="save",
    description="Saves current chat transcript."
):
    @lightbulb.invoke
    async def invoke(self, ctx: lightbulb.Context) -> None:
        limit: int = 100
        tz_info: str = "UTC"
        military_time: bool = True
        channel = ctx.interaction.get_channel()

        transcript = await chat_exporter.export(
            channel,
            limit=limit,
            tz_info=tz_info,
            military_time=military_time,
            bot=bot
        )

        if transcript is None:
            return

        transcript_file = hikari.files.Bytes(io.BytesIO(transcript.encode()), f"transcript-{channel.name}.html")

        await ctx.respond(transcript_file)
Raw Usage

.raw_export() is for the crazy people who like to do their own thing when using chat-exporter.

Using the raw_export function will generate a transcript using the list of messages you pass in, along with using any of the custom kwargs passed in to set limits, timezone, 24h formats and more (listed below).

This would be for people who want to filter what content to export.

Required Argument(s):
channel: hikari.channels.PartialChannel object, whether ctx.channel or any channel you gather (this is just for padding the header).
messages: A list of Message objects which you wish to export to an HTML file.

Optional Argument(s):
tz_info: String value of a TZ Database name to set a custom timezone for the exported messages (default=UTC)
military_time: Boolean value to set a 24h format for times within your exported chat (default=False | 12h format)
fancy_times: Boolean value which toggles the 'fancy times' (Today|Yesterday|Day)
bot: commands.Bot object to gather members who are no longer in your guild.

Return Argument:
transcript: The HTML build-up for you to construct the HTML File with Discord.

Example:

import io
import hikari
import lightbulb
import chat_exporter


bot = hikari.GatewayBot(token="...")
client = lightbulb.client_from_app(bot)
bot.subscribe(hikari.StartingEvent, client.start)

...

@client.register
class Save(
    lightbulb.SlashCommand, 
    name="save",
    description="Saves current chat transcript."
):
    @lightbulb.invoke
    async def invoke(self, ctx: lightbulb.Context) -> None:
        tz_info: str = "UTC"
        military_time: bool = True
        channel = ctx.interaction.get_channel()
        messages = bot.rest.fetch_messages(channel)

        transcript = await chat_exporter.raw_export(
            channel,
            messages=messages,
            tz_info=tz_info,
            military_time=military_time,
            bot=bot
        )

        if transcript is None:
            return

        transcript_file = hikari.files.Bytes(io.BytesIO(transcript.encode()), f"transcript-{channel.name}.html")

        await ctx.respond(transcript_file)

(back to top)


Screenshots

General
    Discord
    Chat-Exporter

(back to top)


Additional Functions

Link Function Downloading exported chats can build up a bunch of unwanted files on your PC which can get annoying, additionally - not everyone wants to download content from Discord.

Due to these pain, and many requests - I have built a fancy PHP script which will show the transcript file within a browser.

    quick_link Similar in design to `.quick_export()` this is a bit of a demo function to produce a link and to give you an embed.

    Required Argument(s):
    channel: hikari.channels.PartialChannel object, whether ctx.channel or any channel you gather.
    message: The Discord message containing the transcript file

    Return Argument:
    hikari.messages.Message: The message quick_link will send, containing the embed.

    Example:

    import hikari
    import lightbulb
    import chat_exporter
    
    
    bot = hikari.GatewayBot(token="...")
    client = lightbulb.client_from_app(bot)
    bot.subscribe(hikari.StartingEvent, client.start)
    
    ...
    
    @client.register
    class Save(
        lightbulb.SlashCommand, 
        name="save",
        description="Saves current chat transcript."
    ):
        @lightbulb.invoke
        async def invoke(self, ctx: lightbulb.Context) -> None:
            channel = ctx.interaction.get_channel()
            message = await chat_exporter.quick_export(channel)
            await chat_exporter.quick_link(channel, message)
    
    link A simple function to return the link you will need to view the transcript online.

    Required Argument(s):
    message: The Discord message containing the transcript file

    Return Argument:
    link: The link to view the transcript file online

    Example:

    import io
    import hikari
    import lightbulb
    import chat_exporter
    
    
    bot = hikari.GatewayBot(token="...")
    client = lightbulb.client_from_app(bot)
    bot.subscribe(hikari.StartingEvent, client.start)
    
    ...
    
    @client.register
    class Save(
        lightbulb.SlashCommand, 
        name="save",
        description="Saves current chat transcript."
    ):
        @lightbulb.invoke
        async def invoke(self, ctx: lightbulb.Context) -> None:
            channel = ctx.interaction.get_channel()
            transcript = await chat_exporter.export(channel)
        
            if transcript is None:
                return
    
            transcript_file = hikari.File(
                io.BytesIO(transcript.encode()),
                filename=f"transcript-{channel.name}.html",
            )
    
            message = await ctx.respond(attachment=transcript_file)
            link = await chat_exporter.link(message)
    
            await ctx.respond("Click this link to view the transcript online: " + link)
    

Please note that the PHP script does NOT store any information.
It simply makes a request to the given URL and echos (prints) the content for you to be able to view it.


Attributions

This project borrows CSS and HTML code from Tyrrrz's C# DiscordChatExporter repository.

This project is based on DiscordChatExporterPy, the work of mahtoid.

(back to top)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hikari_chat_exporter-0.0.2.tar.gz (47.5 kB view details)

Uploaded Source

Built Distribution

hikari_chat_exporter-0.0.2-py3-none-any.whl (58.5 kB view details)

Uploaded Python 3

File details

Details for the file hikari_chat_exporter-0.0.2.tar.gz.

File metadata

  • Download URL: hikari_chat_exporter-0.0.2.tar.gz
  • Upload date:
  • Size: 47.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for hikari_chat_exporter-0.0.2.tar.gz
Algorithm Hash digest
SHA256 11e08c5a7e767a52d819d25973a9a1c91f44e23c592e30715b6ba653ba8cb920
MD5 94b179dfa4559a93528685334d68e043
BLAKE2b-256 b1ec17d2f544496ef5de01f6e60b37277b0111ec200cdf0e4d9818e57bdd805e

See more details on using hashes here.

File details

Details for the file hikari_chat_exporter-0.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for hikari_chat_exporter-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 48d6e1c3f316d0d37bfa79b34464e52fb9f736f27065636f992a0676518510a3
MD5 96aecde9ca8c91a511618509088d10d6
BLAKE2b-256 865b86f8ec895baad51523c3d855e3f0456372e07ff4f7289d68135f0afca966

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page