szymanski-luk/polish-profanity-filter 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

szymanski-luk/polish-profanity-filter

最新稳定版本:1.0.0

Composer 安装命令:

composer require szymanski-luk/polish-profanity-filter

包简介

Polish profanity filter with support for inflections, masking and detection

README 文档

README

Lightweight PHP library for detecting and masking Polish profanity in text.

Supports:

  • case-insensitive detection
  • Unicode-safe matching
  • configurable masking strategies
  • custom dictionary providers
  • custom search patterns
  • match position detection (start/end offsets)

Designed for moderation systems, comments filtering, validation pipelines, and content sanitization.

Requirements

  • PHP 8.1
  • ext-mbstring

Installation

composer require szymanski-luk/polish-profanity-filter

Basic usage

Checking if text contains profanity

use PolishProfanityFilter\PolishProfanityFilter;

$filter = new PolishProfanityFilter();

$filter->containsProfanity('To jest kurwa test.'); // true

Finding matches with offsets

$matches = $filter->findProfanities('To jest kurwa test.'); // MatchCollection object

foreach ($matches as $match) {
    echo $match->word;
    echo $match->start;
    echo $match->end;
}

Example result:

word: 'kurwa'
start: 8
end: 13

findProfanities() returns a MatchCollection object. Available methods:

  • isEmpty(): bool
  • all(): array
  • first(): ?MatchResult
  • last(): ?MatchResult
  • count(): int
  • containsWord(string $word, bool $caseInsensitive = true): bool

Masking profanity

$filter->maskProfanities('To jest kurwa test.'); // To jest k***a test.

Extending

This package can be extended with custom maskers, additional dictionary providers, and custom search patterns.

Custom Masker

To create a custom Masker, create a class that implements the MaskerInterface.

Example:

class CustomMasker implements MaskerInterface
{
    public function mask(string $word): string
    {
        $length = mb_strlen($word);
    
        return str_repeat('*', $length)
    }
}

Now you should instantiate PolishProfanityFilter as follows:

$filter = new PolishProfanityFilter(masker: new CustomMasker());

Additional Dictionary

To create an additional Dictionary, create a class that implements the DictionaryProviderInterface.

class AdditionalDictionaryProvider implements DictionaryProviderInterface
{
    public function getDictionary(): array
    {
        return ['word1', 'word2'];
    }
}

Now you should instantiate PolishProfanityFilter as follows:

$filter = new PolishProfanityFilter(additionalDictionaryProviders: [new AdditionalDictionaryProvider()]);

...or you can override default Dictionary:

$filter = new PolishProfanityFilter(defaultDictionaryProvider: new AdditionalDictionaryProvider());

Custom SearchPattern

To create a custom SearchPattern, create a class that implements the SearchPatternInterface.

class CustomSearchPattern implements SearchPatternInterface
{
    public function buildPattern(string $word): string
    {
        return '/(?<![\p{L}\p{N}_])' . preg_quote($word, '/') . '(?![\p{L}\p{N}_])/iu';
    }
}

Now you should instantiate PolishProfanityFilter as follows:

$filter = new PolishProfanityFilter(searchPattern: new CustomSearchPattern());

Advanced Usage

If you use Symfony and want to register PolishProfanityFilter as a service, you can do it like this:

# services.yaml

PolishProfanityFilter\PolishProfanityFilter: ~

or (in case you want to extend filter)

# services.yaml

App\Custom\CustomDictionaryProvider: ~

PolishProfanityFilter\PolishProfanityFilter:
    arguments:
        $additionalDictionaryProviders: ['@App\Custom\CustomDictionaryProvider']

Contributing

Contributions are welcome.

You can help by:

  • improving the default dictionary
  • improving search patterns
  • fixing bugs
  • adding tests and documentation

Please open an issue or submit a pull request.

Development

Run tests:

composer test

Run static analysis:

composer stan

Run code style:

composer cs-check 

Fix code style:

composer cs-fix

License

MIT

统计信息

  • 总下载量: 1
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 8
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-18

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固