PHPackages                             sirclo-bachtiar/magento-helpers-v2 - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Logging &amp; Monitoring](/categories/logging)
4. /
5. sirclo-bachtiar/magento-helpers-v2

ActiveLibrary[Logging &amp; Monitoring](/categories/logging)

sirclo-bachtiar/magento-helpers-v2
==================================

Magento Helpers v2

1.1.5(3y ago)032MITPHP

Since Sep 14Pushed 3y ago1 watchersCompare

[ Source](https://github.com/sirclo-bachtiar/magento-helpers-v2)[ Packagist](https://packagist.org/packages/sirclo-bachtiar/magento-helpers-v2)[ Docs](https://github.com/sirclo-bachtiar/magento-helpers-v2)[ RSS](/packages/sirclo-bachtiar-magento-helpers-v2/feed)WikiDiscussions master Synced 3d ago

READMEChangelog (6)Dependencies (1)Versions (9)Used By (0)

Magento Helpers v2
==================

[](#magento-helpers-v2)

Service Helpers.
----------------

[](#service-helpers)

This service is used to help some activities during your work, which contains several functions that may make your job simpler. Personally, this library is used for magento.

Require
-------

[](#require)

This library requiring **[Laminas Log](https://github.com/laminas/laminas-log)** for create logger.

Installation
------------

[](#installation)

#### - Set Config to composer.json (not a mandatory)

[](#--set-config-to-composerjson-not-a-mandatory)

```
composer config repositories.sirclo-bachtiar/magento-helpers-v2 git git@github.com:sirclo-bachtiar/magento-helpers-v2.git
```

#### - Install library

[](#--install-library)

```
composer require sirclo-bachtiar/magento-helpers-v2
```

Usage
-----

[](#usage)

- ### Logger Service

    [](#logger-service)
- #### LogService::class

    [](#logserviceclass)

It's used for create log activity.

```
use Bachtiar\Helper\LaminasLogger\Service\LogService;

class LogServiceTest
{
    public function Log()
    {
        return LogService::channel('default')
            ->mode('default')
            ->title('log_title')
            ->log('message_to_log');
    }
}

#### Info ####
:: channel('default') => not required
    -> select channel, available [ emerg, alert, crit, err, warn, notice, info ], if null then auto set to default.

:: mode('default') => not required
    -> select log mode, available [ test, debug, develop ], if null then auto set to default.

:: title('default') => not required
    -> set log title, if null then auto set to default title.

:: log('default') => required
    -> set log message, if null then auto set to default message.
```

- #### SwiftLog::trait

    [](#swiftlogtrait)

It's use for logging activity based on Icube Custom Swift Log Rule.

```
use Bachtiar\Helper\LaminasLogger\Service\SwiftLog;

class SwiftLogTest
{
    use SwiftLog;

    public function __invoke()
    {
        return $this->channel('default')
            ->mode('default')
            ->classLimit('default')
            ->group('group_title')
            ->title('log_title')
            ->log('message_to_log');
    }
}

#### Info ####
:: channel('default') => not required
    -> select channel, available [ emerg, alert, crit, err, warn, notice, info ], if null then auto set to default.

:: mode('default') => not required
    -> select log mode, available [ test, debug, develop ], if null then auto set to default.

:: classLimit('default') => not required
    -> set module class namespace limit, if null then auto set to default.

:: group('default') => not required
    -> set group of log, if null then auto set to default.

:: title('default') => not required
    -> set log title, if null then auto set to default title.

:: log('default') => required
    -> set log message, if null then auto set to default message.
```

- ### Query Builder Service

    [](#query-builder-service)

It's used for custom query builder. (return query only).

```
use Bachtiar\Helper\CustomQueryGenerator\Service\QueryBuilderService;

class QueryBuilderTest
{
    public function __invoke()
    {
        return QueryBuilderService::select()
            ->from('base_table')
            ->join('relation_table', 'base_table.baseColumnId', '=', 'relation_table.relationColumnId')
            ->where('base_table.name', '=', 'test')
            ->andWhere('base_table.age', '=', 'age')
            ->orWhere('relation_table.address', 'like', '%ponorogo%')
            ->generate();
    }
}

#### Info ####
:: select() -> optional
    -> set select column, if null, then auto set to all (*).

:: from('base_table') -> ! must be included
    -> set base table query.

:: join('relation_table', 'baseColumnId', '=', 'relationColumnId')
    -> set inner join from query.

:: where('base_table.name', '=', 'test') -> optional
    -> set where clause from query

:: andWhere('base_table.age', '=', 'age') -> optional
    -> set or where clause from query

:: orWhere('relation_table.address', 'like', '%ponorogo%') -> optional
    -> set and where clause from query

:: generate()
    -> process to create query builder.
```

###  Health Score

25

—

LowBetter than 37% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity7

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity56

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~56 days

Total

7

Last Release

1362d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/88b127624b85b1e5f9f2f7fd10f1cb9df3f04a5e9f330540fd59ddbb2d59d6ee?d=identicon)[sirclo-bachtiar](/maintainers/sirclo-bachtiar)

---

Top Contributors

[![sirclo-bachtiar](https://avatars.githubusercontent.com/u/78332835?v=4)](https://github.com/sirclo-bachtiar "sirclo-bachtiar (23 commits)")

---

Tags

laminaslogger

### Embed Badge

![Health badge](/badges/sirclo-bachtiar-magento-helpers-v2/health.svg)

```
[![Health](https://phpackages.com/badges/sirclo-bachtiar-magento-helpers-v2/health.svg)](https://phpackages.com/packages/sirclo-bachtiar-magento-helpers-v2)
```

###  Alternatives

[analog/analog

Fast, flexible, easy PSR-3-compatible PHP logging package with dozens of handlers.

3451.5M24](/packages/analog-analog)[justbetter/magento2-sentry

Magento 2 Logger for Sentry

1851.5M3](/packages/justbetter-magento2-sentry)[marvinlabs/laravel-discord-logger

Logging to a discord channel in Laravel

2081.1M2](/packages/marvinlabs-laravel-discord-logger)[inpsyde/wonolog

Monolog-based logging package for WordPress.

183617.9k7](/packages/inpsyde-wonolog)[amphp/log

Non-blocking logging for PHP based on Amp, Revolt, and Monolog.

402.6M70](/packages/amphp-log)[apix/log

Minimalist, thin and fast PSR-3 compliant (multi-bucket) logger.

511.0M18](/packages/apix-log)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
