PHP 8 Library for Gemini Protocol
Go to file
2024-06-26 20:15:08 +03:00
src/Client drop Dokuwiki features from future release 2024-06-26 20:04:16 +03:00
.gitignore add ASCII table support 2024-02-06 02:21:45 +02:00
composer.json remove extra dependency, update tags 2024-06-26 20:15:08 +03:00
LICENSE Initial commit 2024-01-30 11:40:28 +02:00
README.md update readme 2024-06-26 20:12:29 +03:00

gemini-php

PHP 8 Library for Gemini Protocol

Extras

  • gemtext-php - Object-oriented PHP 8 library for Gemini / Gemtext operations

Usage

composer require yggverse/gemini

Client

PHP interface for Gemini protocol queries by TLS socket connection

Request

$request = new \Yggverse\Gemini\Client\Request(
    'gemini://yggverse.cities.yesterweb.org:1965/index.gmi'
);

Resolved request (SNI)

For direct connection provide resolved IP as the second argument

$request = new \Yggverse\Gemini\Client\Request(
    'gemini://yggverse.cities.yesterweb.org:1965/index.gmi' // target URL
    '68.133.1.71' // resolved IP, skip to use system-wide resolver
);

Alternatively, use setResolvedHost method of Request object before getResponse

Request::setResolvedHost

$request->setResolvedHost(
    '68.133.1.71'
)
  • to resolve network address with PHP, take a look on the net-php library!

Request::getResolvedHost

Get resolved host back

Request::setHost

Request::getHost

Request::setPort

Request::getPort

Request::setPath

Request::getPath

Request::setQuery

Request::getQuery

Request::getResponse

Execute requested URL and return raw response

var_dump(
    $request->getResponse()
);

Request::getOptions

Request::setOptions

$request = new \Yggverse\Gemini\Client\Request(
    'gemini://yggverse.cities.yesterweb.org',
    '68.133.1.71' // make direct request to the resolved host
);

$request->setOptions(
    [
        'ssl' =>
        [
            'peer_name'        => 'yggverse.cities.yesterweb.org', // SNI
            'verify_peer'      => false,
            'verify_peer_name' => false
        ]
    ]
);

Response

This class provides additional features for the raw response operations

$response = new \Yggverse\Gemini\Client\Response(
    $request->getResponse()
);

Response::setCode

Response::getCode

Response::setMeta

Response::getMeta

Response::setBody

Response::getBody

var_dump(
    $response->getBody()
);

Integrations

  • gemini-dl - CLI Batch downloader for Gemini Protocol
  • Yo! - Crawler for different networks
  • Yoda - PHP-GTK browser for Gemini Protocol
  • β-Doku - DokuWiki Satellite for Gemini Protocol