PHPackages                             asimtariq/php-gae-utility - 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. asimtariq/php-gae-utility

ActiveLibrary

asimtariq/php-gae-utility
=========================

Utility belt for common tasks in Google App Engine for PHP.

011PHP

Since Dec 10Pushed 7y ago1 watchersCompare

[ Source](https://github.com/AsimTariq/php-gae-utility)[ Packagist](https://packagist.org/packages/asimtariq/php-gae-utility)[ RSS](/packages/asimtariq-php-gae-utility/feed)WikiDiscussions master Synced 1mo ago

READMEChangelogDependenciesVersions (1)Used By (0)

php-gae-util
============

[](#php-gae-util)

Utility belt for common tasks and patterns on Google App Engine for PHP. The goal is to make development of microservices on Google App Engine go fast and smooth. Handling common GAE scenarios with less code.

Modules
-------

[](#modules)

- **Auth:** Handles several issues around getting users autenticated.
- **Cached:** Just a simple wrapper for memcache to make this code better.
- **Conf:** A wrapper around `hassankhan/config` which provides a lightweighhed library for doing such stuff. This wrapper is adapted for GAE.
- **Fetch:** Simple module to ensure service to service communication.
- **JWT:** My module to handle all the work on JWT-tokens. Wrapper around `firebase/php-jwt`
- **Secrets:** Module to handle keeping secrets secret. Using Google KMS to secure passwords and tokens.
- **Workflow:** Module to handle the running of scheduled tasks on GAE its main contribution is to store the state of the job running. Saves State to DataStore.

### Login in to provide service account credentials in development

[](#login-in-to-provide-service-account-credentials-in-development)

For local developent its important to get [Application Default Credentials](https://cloud.google.com/sdk/gcloud/reference/auth/application-default/login)if you want to use resources on the Google Cloud platform. You log in by running this command:

```
$ gcloud auth application-default login
```

You need to restart the devserver to get this working as the credentials get set on startup time.

Testing and development
-----------------------

[](#testing-and-development)

### Testing

[](#testing)

Test-coverage is an important part of creating reusable, reliable code. The goal of this testing is to use phpunit as this is the most used PHP test framework. As several methods are dependent on Cloud Datastore installing understanding and being able to test against the emulator is quite important. The emulator is not the same as the built in emulator that is running inside the GAE devserver emulator.

#### Cloud datastore setup for testing

[](#cloud-datastore-setup-for-testing)

```
$ gcloud components install cloud-datastore-emulator
$ gcloud beta emulators datastore start
```

### For local development of packages

[](#for-local-development-of-packages)

My strategy for developing packages for packagist is as following.

- Create a local folder where you symlink packages

In `~/composer/config.json` add, this also works with using the projects composer.json file, but then you might get problems on other developers computers and in pipelines.

```
{
  "repositories": [
    {
      "type": "path",
      "url": "~/path/to/liberary/root",
      "options": {
        "symlink": true
      }
    }
  ]
}
```

This will now create a link. Two tricks for getting a more problem free start of development is to add your liberary with "\*" for and set minimum stability in the local composer.json for the liberary that requires your packages:

```
{
  "minimum-stability": "dev",
  "require": {
    "mijohansen/php-gae-util": "*"
  }
}
```

### Coding style

[](#coding-style)

The liberary consist of several separate Classes that really just form a set of functions which should be fairly simple to introduce to code. From version 0.7.0 every static method and function is written in camelCase. And I try to follow [PSR-1](https://www.php-fig.org/psr/psr-1/) and [PSR-2](https://www.php-fig.org/psr/psr-2/)

###  Health Score

19

—

LowBetter than 10% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity5

Limited adoption so far

Community4

Small or concentrated contributor base

Maturity38

Early-stage or recently created project

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.

### Community

Maintainers

![](https://www.gravatar.com/avatar/2b31b95f9c539162f6c1fb5ebd223ef9dad3e473684d5ba7948c07852e5dcb38?d=identicon)[AsimTariq](/maintainers/AsimTariq)

### Embed Badge

![Health badge](/badges/asimtariq-php-gae-utility/health.svg)

```
[![Health](https://phpackages.com/badges/asimtariq-php-gae-utility/health.svg)](https://phpackages.com/packages/asimtariq-php-gae-utility)
```

PHPackages © 2026

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