Go to file
Alexander Pankratov 775921723e Basic functions:
- server
 - parsing
 - json encoding
2019-01-07 15:24:29 +03:00
src Basic functions: 2019-01-07 15:24:29 +03:00
.env.example Basic functions: 2019-01-07 15:24:29 +03:00
.gitignore Add composer.json and .gitignore 2018-12-24 15:34:04 +03:00
bootstrap.php Basic functions: 2019-01-07 15:24:29 +03:00
composer.json Basic functions: 2019-01-07 15:24:29 +03:00
config.php Basic functions: 2019-01-07 15:24:29 +03:00
LICENSE Initial commit 2018-12-24 14:48:21 +03:00
README.md Basic functions: 2019-01-07 15:24:29 +03:00
server.php Basic functions: 2019-01-07 15:24:29 +03:00

TelegramSwooleClient

Fast, simple, async php telegram client and parser: MadelineProto + Swoole Server

Features

  • Fast async swoole server
  • Use as micro-service
  • Get any public telegram posts from groups as json

TODO

  • RSS output
  • flood protection (for use in public)
  • logging

Installation

  1. Get app_id and app_hash at my.telegram.org

  2. Swoole extension required: Install swoole

  3. Install this package:

    a. Standalone:

    1. download files from github and extract.
    2. Run composer install inside unpacked directory

    b. Existing project:

    1. Add following into your project's composer.json
    "repositories": [
        {
           "type": "git",
           "url": "https://github.com/xtrime-ru/TelegramSwooleClient.git"
        }
    ],
    "require": {
        "xtrime-ru/telegramswooleclient": "dev-master",
    }
    

Usage

  1. Install

  2. Fill options in .env file (see .env.example)

  3. Run server/parser

    php server.php [--help] [-a|--address=127.0.0.1] [-p|--port=9503]
    
    Options:
    
            --help      Show this message
        -a  --address   Server ip (optional) (example: 127.0.0.1 or 0.0.0.0 to listen all hosts)
        -p  --port      Server port (optional) (example: 9503)
    
    Also all options can be set in .env file (see .env.example)
    
  4. Get posts from any open channel

    • Get 10 latests posts from any open channel via GET request: http://%address%:%port%/json/%channel% Example: http://127.0.0.1:9503/json/breakingmash

    • Get posts from multiple channels via POST:

      Url: http://127.0.0.1:9503/json/

      Headers: Content-Type: application/json

      form-data and x-www-form-urlencoded should work, but was not tested

      Body:

      {
         	"getHistory": [
         		{
         		    "peer":"channel#1259060275"
         		}, 
         		{
         		    "peer": "breakingmash",
         		    "limit": 30,
                  "max_id": 200,
         		}
         	]
      
         }
      

      You can use any other options from https://docs.madelineproto.xyz/API_docs/methods/messages_getHistory.html peer name can be provided in different formats: https://docs.madelineproto.xyz/API_docs/types/InputPeer.html

Contacts

  • Telegram: @xtrime
  • Email: alexander(at)i-c-a.su