podcasthosting/socialiteprovider-podcastde

podcast.de OAuth2 Provider for Laravel Socialite

Maintainers

Package info

github.com/podcasthosting/SocialiteProvider-podcastde

Homepage

Issues

pkg:composer/podcasthosting/socialiteprovider-podcastde

Statistics

Installs: 10

Dependents: 0

Suggesters: 0

Stars: 0

v0.2 2026-05-13 08:08 UTC

This package is auto-updated.

Last update: 2026-05-13 08:14:56 UTC


README

OAuth2 driver for podcast.de, built on top of SocialiteProviders/Manager.

Installation

composer require podcasthosting/socialiteprovider-podcastde

Configuration

1. .env

PODCASTDE_CLIENT_ID=your-client-id
PODCASTDE_CLIENT_SECRET=your-client-secret
PODCASTDE_REDIRECT_URI=https://your-app.test/auth/podcastde/callback

2. config/services.php

'podcastde' => [
    'client_id'     => env('PODCASTDE_CLIENT_ID'),
    'client_secret' => env('PODCASTDE_CLIENT_SECRET'),
    'redirect'      => env('PODCASTDE_REDIRECT_URI'),
],

3. Register the event listener

In app/Providers/EventServiceProvider.php:

protected $listen = [
    \SocialiteProviders\Manager\SocialiteWasCalled::class => [
        \Podcasthosting\Podcastde\PodcastdeExtendSocialite::class,
    ],
];

Usage

use Laravel\Socialite\Facades\Socialite;

Route::get('/auth/podcastde', fn () => Socialite::driver('podcastde')->redirect());

Route::get('/auth/podcastde/callback', function () {
    $user = Socialite::driver('podcastde')->user();

    // $user->getId(), $user->getNickname(), $user->getName(),
    // $user->getEmail(), $user->getAvatar(), $user->token, ...
});

PKCE (optional)

For public clients (SPA, mobile) you can enable PKCE (S256):

Socialite::driver('podcastde')->enablePKCE()->redirect();

Development

composer install
./vendor/bin/phpunit
./vendor/bin/phpstan analyse
./vendor/bin/php-cs-fixer fix

License

MIT