Skip to main content

Phound SDK

Project description

Installing

pip install phound

Usage

Create and fill in .env file within your project's directory with:

PERSONAS=<uid1> <uid2> ...
TOKEN=<token>

where uid1 uid2 etc. represent personas to listen. If no one specified(or omitted), all personas within an account will be listened to.

Please refer to support@phound.app to get a token

Simple python chatbot could look like:

import os
import time

from phound import Phound
from phound.handlers import BaseChatHandler


class ChatHandler(BaseChatHandler):
    def on_start(self):
        self.chat_history = self.get_history(depth=5)

    def on_message(self, message):
        print(f"Got new message: {message}")
        self.chat_history.append(message)
        self.show_typing()
        time.sleep(1)
        reply_items = [f"Initial message: {message.text}",
                       f"Response: {message.text[::-1]}",
                       f"Also has chat history with last {len(self.chat_history)} messages"]
        reply = self.send_message(os.linesep.join(reply_items))
        self.chat_history.append(reply)


if __name__ == "__main__":
    with Phound() as phound:
        phound.register_chat_handler(ChatHandler)
        phound.start_listen_events()

API Reference

Phound

Methods:

  • register_chat_handler(self, handler, chat_types=("private",)) - Registers specified chat handler.
    • handler: BaseChatHandler - The chat handler to register.
    • chat_types: Tuple[str, ...] - The chat types to handle, valid values are private and group
  • start_listen_events() - Starts listen events
  • send_message(self, text, from_persona_uid, chat_id="", persona_uid="", phone_number="", text_format=MessageTextFormat.PLAIN, attachments=None, app_meta=None) - Sends a message with the specified text to the chat.
    • text: str - The text content of the message.
    • from_persona_uid: str - The unique ID of the persona from which the message originated.
    • chat_id: str - The ID of the chat to send the message to.
    • persona_uid: str - The unique ID of the persona to send the message to.
    • phone_number: str - The phone number to send the message to.
    • text_format: MessageTextFormat - The text format of the message. One of MessageTextFormat.HTML, MessageTextFormat.PLAIN or MessageTextFormat.GPTMARKDOWN.
    • attachments: List[str] | None - A list of attachment as path to be added to the message.
    • app_meta: Dict[str, Any] | None - A dictionary of additional metadata to be added to the message. NOTE: from_persona_uid or chat_idor phone_number must be specified.
  • make_call(self, from_persona_uid, phone_number) - Makes a call to the specified phone number.

BaseChatHandler

  • persona_uid: str - The unique ID of the persona listening to the chat.
  • chat_type: str - Either "private" or "group".
  • chat_id: str - The ID of the chat.

Event handlers:

  • on_start(self) - Called once when the chat handler is started.
  • on_message(self, message) - Called when a new message is received in the chat.
    • message: ChatMessage - The message object.
  • on_message_status_changed(self, message) - Called when the status of a message changes.
    • message: ChatMessage - The message object.
  • on_voice_message_started(self, message) - Called when a voice message is started. It's expected that message would provide temporary_url.
    • message: VoiceMessage - The voice message object.
  • on_voice_message_completed(self, message) - Called when a voice message is completed. It's expected that message would provide transcription within text field and permanent_url.
    • message: VoiceMessage - The voice message object.

Methods:

Same as for Chat object, please refer to the documentation bellow.

BaseCallHandler

  • persona_uid: str - The unique ID of the persona listening to the call.
  • chat: Chat - The chat object associated with the call.

Event handlers:

  • on_start(self) - Called once when the call handler is started.
  • on_incoming_call(self, call) - Called when an incoming call is received.
    • call: Call - The call object.
  • on_call_ready(self) - Called when a call is ready.
  • on_playback_status(self, status) - Called when the playback status changes.
    • status: PlaybackStatus - Enum, one of PlaybackStatus.IN_PROGRESS or PlaybackStatus.COMPLETE.
  • on_audio_chunk_recorded(self, audio_chunk) - Called when an audio chunk is recorded.
    • audio_chunk: AudioChunk - The audio chunk object.
  • on_hangup(self) - Called when the call is hung up.
  • on_attendee_join(self, attendee) - Called when an attendee joins the call.
    • attendee: CallAttendee - The CallAttendee object.
  • on_attendee_drop(self, attendee) - Called when an attendee drops the call.
    • attendee: CallAttendee - The CallAttendee object.
  • on_dtmf(self, dtmf) - Called when a DTMF digit is received. Make sure to call start_listen_dtmf() first.
    • dtmf: str - The DTMF digit.
  • on_stream_update(self, stream) - Called when a stream update is received. Note that start_stream must be called first. Also note that starting stream with status "started" will contain stream url in stream.data.
    • stream: StreamUpdate - The StreamUpdate object.

Methods:

  • answer(self) - Answers the call.
  • reject(self) - Rejects the call.
  • hangup(self) - Hangs up the call.
  • play(self, file_path) - Plays the specified audio file in the call.
    • file_path: str - The path to the audio file.
  • record(self, file_path, min_chunk_len=0, max_chunk_len=0, chunk_overlap=0) - Records the call and saves it to the specified file.
    • file_path: str - The path to the audio file.
    • min_chunk_len: int - The minimum length of the audio chunk in seconds.
    • max_chunk_len: int - The maximum length of the audio chunk in seconds.
    • chunk_overlap: int - The overlap of the audio chunks in seconds.
  • get_active_attendees(self) - Returns a list of active attendees (CallAttendee) in the call.
  • get_all_attendees(self) - Returns a list of all attendees (CallAttendee) in the call.
  • start_listen_dtmf(self) - Starts listening for DTMF digits. Note, call must be ready.
  • send_dtmf(self, dtmf) - Sends a DTMF digit to the call.
    • dtmf: str - The DTMF digit.
  • start_stream(self, audio_format, rate, samples) - Starts the audio stream. Note: on_stream_update should also be defined to receive the stream URL. (NOTE: currently is not supported for Windows)
    • audio_format: str - The audio format. One of "pcm" (wav), "g722".
    • rate: int - The sample rate.
    • samples: int - The number of samples per data chunk.
  • stop_stream(self) - Stops the audio stream.

Chat

  • persona_uid: str - The unique ID of the persona listening to the chat.
  • chat_id: str - The ID of the chat.

Methods:

  • show_typing(self, timeout=60, chat_id="", persona_uid="", phone_number="") - Displays a typing indicator in the chat. The indicator is shown for the specified timeout or until the next message is sent.
    • timeout: int - The timeout in seconds.
    • chat_id: str - The ID of the chat to show the typing indicator in. If not specified, the typing indicator is shown in the handled chat.
    • persona_uid: str - The unique ID of the persona to show the typing indicator in chat with. If not specified, the typing indicator is shown in the handled chat.
    • phone_number: str - The phone number to show the typing indicator in chat with. If not specified, the typing indicator is shown in the handled chat.
  • send_message(self, text, text_format=MessageTextFormat.PLAIN, attachments=None, app_meta=None, chat_id="", persona_uid="", phone_number="") - Sends a message with the specified text to the chat.
    • text: str - The text content of the message. Please see also the "Text helpers" section bellow.
    • text_format: MessageTextFormat | None - The text format of the message. One of MessageTextFormat.HTML, MessageTextFormat.PLAIN or MessageTextFormat.GPTMARKDOWN.
    • attachments: List[str] | None - A list of attachment as path to be added to the message.
    • app_meta: Dict[str, Any] | None - A dictionary of additional metadata to be added to the message.
    • chat_id: str - The ID of the chat to send the message to. If not specified, the message is sent to the handled chat.
    • persona_uid: str - The unique ID of the persona to send the message to. If not specified, the message is sent to the handled chat.
    • phone_number: str - The phone number to send the message to. If not specified, the message is sent to the handled chat.
  • wipe_message(self, message_id, chat_id="", persona_uid="", phone_number="") - Wipes the specified message from the chat.
    • message_id: str - The ID of the message to wipe.
    • chat_id: str - The ID of the chat to wipe the message from. If not specified, the message is wiped from the handled chat.
    • persona_uid: str - The unique ID of the persona to wipe the message from chat with. If not specified, the message is wiped from the handled chat.
    • phone_number: str - The phone number to wipe the message from chat with. If not specified, the message is wiped from the handled chat.
  • get_history(self, depth=10, start_message_id="0", chat_id="", persona_uid="", phone_number="") - Retrieves the chat history as a list of ChatMessage or VoiceMessage objects.
    • depth: int - The number of messages to retrieve.
    • start_message_id: str - The ID of the message to start from. Use "0"(default) to start from the last message.
    • chat_id: str - The ID of the chat to retrieve the history from. If not specified, the history is retrieved from the handled chat.
    • persona_uid: str - The unique ID of the persona to retrieve the history from chat with. If not specified, the history is retrieved from the handled chat.
    • phone_number: str - The phone number to retrieve the history from chat with. If not specified, the history is retrieved from the handled chat.

Call

  • id: str - The ID of the call.
  • persona_uid: str - The unique ID of the persona who is listening to the call.
  • from_persona_uid: str - The unique ID of the persona who is calling.
  • from_name: str - The name of the persona who is calling.

CallAttendee

  • id: str - The ID of the attendee.
  • number: str - The phone number of the attendee.
  • name: str - The name of the attendee.
  • persona_uid: str - The unique persona ID of the attendee.

AudioChunk

  • audio_file_path: str - The path to the audio file.
  • asn_file_path: str | None - The path to the ASN file.
  • duration: float - The duration of the audio file in seconds.
  • last_chunk: bool - Indicates whether the audio chunk is the last in the recording.
  • full_audio_file_path: str | None - The path to the full audio file, if available.
  • full_duration: float | None - The duration of the full audio file in seconds, if available.

StreamUpdate

  • status: StreamStatus - The status of the stream. Could be one of "started", "stopped", "connected", "disconnected".
  • data: str - The data of the stream.

ChatMessage

  • id: str - The ID of the message.
  • text: str - The text content of the message.
  • from_uid: str - The unique ID of the persona from which the message originated.
  • from_name: str - The name of the persona from which the message originated.
  • tagged: bool - Indicates whether the persona listening to the chat was tagged in the message.
  • quote: MessageQuote | None - The quote of the message, if any.
  • attachments: List[MessageAttachment] - A list of MessageAttachment objects.
  • status_code: str - The status code of the message.

VoiceMessage

  • id: str - The ID of the message.
  • text: str - The text transcription of the voice message.
  • from_uid: str - The unique ID of the persona from which the message originated.
  • from_name: str - The name of the persona from which the message originated.
  • temporary_url: str | None - The temporary URL of the voice message.
  • permanent_url: str - The permanent URL of the voice message.

MessageQuote

  • text: str - The text content of the quote.
  • from_uid: str - The unique ID of the persona from which the quoted message originated.
  • from_name: str - The name of the persona from which the quoted message originated.
  • message_id: str - The ID of the quoted message.

MessageAttachment

  • name: str - The name of the attachment.
  • size: int - The size of the attachment.
  • url: str - The URL of the attachment.

Text helpers

Text helpers are the set of functions that are used to help to format the text of the message.

  • mention(persona_uid, label="")

    • persona_uid: str - The unique ID of the persona to mention.
    • label: str - The label of the persona to mention. If not specified, the label is the same as the persona_uid.
  • bold(text)

    • text: str - The text to bold.
  • italic(text)

    • text: str - The text to italicize.
  • underline(text)

    • text: str - The text to underline.

Example

from phound.chats.text_helpers import bold, italic, underline, mention

class ChatHandler(BaseChatHandler):
    ...
    text = (f"It's possible to use pure html tags to make text <b>bold</b>, or do it with {bold('helper')}\n"
            f"same for <i>italic</i> and <u>underline</u> ({italic('italic')}, {underline('underline')})\n"
            f"To mention someone use {mention('<uid>', 'name')}")
    self.send_message(text)

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

phound-0.1.8-py3-none-win_amd64.whl (1.3 MB view details)

Uploaded Python 3Windows x86-64

phound-0.1.8-py3-none-manylinux_2_35_x86_64.whl (3.6 MB view details)

Uploaded Python 3manylinux: glibc 2.35+ x86-64

phound-0.1.8-py3-none-macosx_14_0_arm64.whl (1.4 MB view details)

Uploaded Python 3macOS 14.0+ ARM64

File details

Details for the file phound-0.1.8-py3-none-win_amd64.whl.

File metadata

  • Download URL: phound-0.1.8-py3-none-win_amd64.whl
  • Upload date:
  • Size: 1.3 MB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for phound-0.1.8-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 ec218c1d9fb61211d7139c22caa97b4b2d4a2c76475c74e936e600297f6e8fa1
MD5 a4d6eaff8c0019a543ad2fec398e777a
BLAKE2b-256 595cf8cf99cee39fd6e5b7a76d32ea71fa44b5ff45a9dd6c61933abab9213dc4

See more details on using hashes here.

File details

Details for the file phound-0.1.8-py3-none-manylinux_2_35_x86_64.whl.

File metadata

File hashes

Hashes for phound-0.1.8-py3-none-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 89808f175d569dcd23957c310ddf48601b8984fd3fe733a9aad0e1d022670d66
MD5 ff5645d679403ad4b9a88f9b235a5480
BLAKE2b-256 667cbda3cc0d5a9687b51fa6887b685104effe91fd25dc7b44581d0253da3bcb

See more details on using hashes here.

File details

Details for the file phound-0.1.8-py3-none-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for phound-0.1.8-py3-none-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 6da5ea29b9449fb3ed7923296ce4baf9fa83b63f68d19b9ac6e1868057e9f558
MD5 43aa2bbea1191b858b64b95ccaf27cc1
BLAKE2b-256 19e36e23bc86dfe86909c40863f83cd86058f381aa4e54ab59b20d8730e15fe4

See more details on using hashes here.

Supported by

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