altostrat/tools 问题修复 & 功能扩展

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

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

altostrat/tools

最新稳定版本:v1.5.4

Composer 安装命令:

composer require altostrat/tools

包简介

Tooling for Laravel microservices

README 文档

README

Installation

composer require altostrat/altostrat

Environment Variables

Add the following environment variables to your .env file:

AUTH0_CLIENT_ID=
AUTH0_COOKIE_SECRET=
API_PREFIX=

AUTH0_CLIENT_ID should be the client ID of the Altostrat Auth0 tenant application. AUTH0_COOKIE_SECRET should be a random string of at least 32 characters. API_PREFIX should be the prefix for your API routes, e.g. v1/my-service.

Installation Command

Run the following command run through some boilerplate installation steps:

php artisan altostrat:install

Afterward run the following command to verify that everything is working:

php artisan altostrat:check

Usage

Authenticated routes

Whenever you want to register a route that requires authentication, add it to the routes/authenticated.php file. This will require the user to be authenticated and have the correct scopes to access the route.

During the installation a model called Customer was created. You can use this model to create relationships with your own models. The Customer model is read-only and only acts as a way to leverage eloquent relationships.

Billable Models

When creating a billable service, commonly a particular model is used to represent the billable item. If you want to make a model billable, simply extend the model from Altostrat\Billable\BillableModel.

namespace App\Models;

use Altostrat\Billable\BillableModel;
use Illuminate\Database\Eloquent\Concerns\HasUuids;

class MyModel extends BillableModel
{
    use HasUuids;
    
    protected $fillable = [
        'customer_id',
    ];
    
    //
}

The model that you wish to make billable must have a UUID customer_id column and the id column must be a UUID.

Nothing more is needed, when a user attempts to create an item, a check will be performed to see if the user has a valid subscription. If the user is not allowed to create the item, execution will be halted and a response will be returned to the user.

WARNING: When making a model billable, only an authenticated user can create the model. That means it must come in through an authenticated route and the auth()->user() must be set. You cannot create a billable model through a job or a command.

HTTP requests only.

Helpers

The following helpers are available:

  • new ipv4Address(string $address) - Creates a new IPv4Address object - use the ->withIsp() method to get the ISP name.
  • IpLookup::info(string $address) - Returns an array with information about the IP address.
  • Websocket::push(string $userId, string $event, array $data) - Pushes an event to the user's websocket connection.
  • GeographicHelper::class - Helper class for geographic items, like a list of currencies, countries, etc.

Implementation Notes

Remember to ask the infrastructure team to add the prefix to the ALB with these paths:

  • v1/my-service/*
  • v1/my-service

Service Count Routes

Billable models are automatically made countable.

As an example, if you set the prefix to v1/my-service, the following route will be available:

GET /v1/my-service/billable-count/{model}

The model parameter is the name of the model, e.g. my-model. Model names should be converted to kebab-case. E.g. MyModel becomes my-model.

You may optionally pass the count=1 URL parameter to get the count of the model.

If count=1 is not passed, the route will return a list like this:

[
    {
        "id": "....", // The ID of the model
        "site_id": "...." // Only if the model has a site_id column otherwise this will be null
    }
]

If count=1 is passed, the route will return a count like this:

{
    "count": 1
}

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: proprietary
  • 更新时间: 2025-01-07