Metadata-Version: 2.1
Name: smpplib
Version: 2.1.0
Summary: SMPP library for python
Home-page: https://github.com/podshumok/python-smpplib
License: UNKNOWN
Description: `python-smpplib`
        ================
        
        [![Version](https://img.shields.io/pypi/v/smpplib.svg?style=flat)](https://pypi.org/project/smpplib/#history)
        [![Python versions](https://img.shields.io/pypi/pyversions/smpplib.svg?style=flat)](https://pypi.org/project/smpplib/)
        [![PyPI downloads](https://img.shields.io/pypi/dm/smpplib.svg?style=flat)](https://pypi.org/project/smpplib/#files)
        ![License](https://img.shields.io/pypi/l/smpplib.svg?style=flat)
        [![CircleCI](https://circleci.com/gh/python-smpplib/python-smpplib.svg?style=svg)](https://circleci.com/gh/python-smpplib/python-smpplib)
        
        SMPP library for Python. Forked from [Google Code](https://code.google.com/p/smpplib/).
        
        Example:
        
        ```python
        import logging
        import sys
        
        import smpplib.gsm
        import smpplib.client
        import smpplib.consts
        
        # if you want to know what's happening
        logging.basicConfig(level='DEBUG')
        
        # Two parts, UCS2, SMS with UDH
        parts, encoding_flag, msg_type_flag = smpplib.gsm.make_parts(u'Привет мир!\n'*10)
        
        client = smpplib.client.Client('example.com', SOMEPORTNUMBER)
        
        # Print when obtain message_id
        client.set_message_sent_handler(
            lambda pdu: sys.stdout.write('sent {} {}\n'.format(pdu.sequence, pdu.message_id)))
        client.set_message_received_handler(
            lambda pdu: sys.stdout.write('delivered {}\n'.format(pdu.receipted_message_id)))
        
        client.connect()
        client.bind_transceiver(system_id='login', password='secret')
        
        for part in parts:
            pdu = client.send_message(
                source_addr_ton=smpplib.consts.SMPP_TON_INTL,
                #source_addr_npi=smpplib.consts.SMPP_NPI_ISDN,
                # Make sure it is a byte string, not unicode:
                source_addr='SENDERPHONENUM',
        
                dest_addr_ton=smpplib.consts.SMPP_TON_INTL,
                #dest_addr_npi=smpplib.consts.SMPP_NPI_ISDN,
                # Make sure thease two params are byte strings, not unicode:
                destination_addr='PHONENUMBER',
                short_message=part,
        
                data_coding=encoding_flag,
                esm_class=msg_type_flag,
                registered_delivery=True,
            )
            print(pdu.sequence)
            
        # Enters a loop, waiting for incoming PDUs
        client.listen()
        ```
        You also may want to listen in a thread:
        ```python
        from threading import Thread
        t = Thread(target=client.listen)
        t.start()
        ```
        **Note:** When listening, the client will automatically send an `enquire_link` command when the socket timeouts. You may override that behavior by passing `auto_send_enquire_link=False` as an argument to `listen()`. In that case, `socket.timeout` exceptions will bubble up.
        
        The client supports setting a custom generator that produces sequence numbers for the PDU packages. Per default a simple in memory generator is used which in conclusion is reset on (re)instantiation of the client, e.g. by an application restart. If you want to keep the sequence number to be persisted across restarts you can implement your own storage backed generator.
        
        Example:
        
        ```python
        import smpplib.client
        
        import mymodule
        
        generator = mymodule.PersistentSequenceGenerator()
        client = smpplib.client.Client('example.com', SOMEPORTNUMBER, sequence_generator=generator)
        ...
        ```
        
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Telecommunications Industry
Classifier: License :: OSI Approved :: GNU Lesser General Public License v3 (LGPLv3)
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python
Classifier: Topic :: Communications :: Telephony
Classifier: Topic :: Communications
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: Software Development :: Libraries
Description-Content-Type: text/markdown
