承接 appwrite/sdk-generator 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

appwrite/sdk-generator

最新稳定版本:1.29.0

Composer 安装命令:

composer require appwrite/sdk-generator

包简介

Appwrite PHP library for generating API SDKs for multiple programming languages and platforms

README 文档

README

Discord Twig Linting X Account appwrite.io

Appwrite SDK generator is a PHP library for auto-generating SDK libraries for multiple languages and platforms.

The SDK Generator uses predefined language settings as Twig templates to generate codebases based on different API specs.

Currently, the only spec supported is Swagger 2.0, but we intend to add support for more specifications in the near future. This generator is still lacking support for any definition/model specs.

Getting Started

Install using composer:

CLI

composer update --ignore-platform-reqs --optimize-autoloader

Docker (UNIX)

docker run --rm --interactive --tty --volume "$(pwd)":/app composer install --ignore-platform-reqs

Docker (Windows)

docker run --rm --interactive --tty --volume "%cd%":/app composer install --ignore-platform-reqs

Create language and SDK instances and generate code to target directory.

<?php

require_once 'vendor/autoload.php';

use Appwrite\Spec\Swagger2;
use Appwrite\SDK\SDK;
use Appwrite\SDK\Language\PHP;

// Read API specification file (Swagger 2) and create spec instance
$version = '1.9.x';
$platform = 'server';
$spec = new Swagger2(file_get_contents("https://raw.githubusercontent.com/appwrite/specs/main/specs/{$version}/swagger2-{$version}-{$platform}.json"));

// Create language instance
$lang = new PHP();

$lang // Set language or platform specific options
    ->setComposerPackage('my-api')
    ->setComposerVendor('my-company')
;

// Create the SDK object with the language and spec instances
$sdk  = new SDK($lang, $spec);

$sdk
    ->setLogo('https://appwrite.io/v1/images/console.png')
    ->setLicenseContent('License content here.')
    ->setVersion('v1.1.0')
;

$sdk->generate(__DIR__ . '/examples/php'); // Generate source code

For generated artifacts that do not need an API specification, use StaticSpec:

<?php

require_once 'vendor/autoload.php';

use Appwrite\Spec\StaticSpec;
use Appwrite\SDK\SDK;
use Appwrite\SDK\Language\AgentSkills;

$spec = new StaticSpec(
    title: 'Appwrite',
    description: 'Appwrite backend as a service',
    version: '1.9.x',
    licenseName: 'BSD-3-Clause',
    licenseURL: 'https://raw.githubusercontent.com/appwrite/appwrite/master/LICENSE',
);

$sdk = new SDK(new AgentSkills(), $spec);

$sdk
    ->setName('Appwrite')
    ->setVersion('1.9.x')
;

$sdk->generate(__DIR__ . '/examples/agent-skills');

Linting Twig Templates

This project uses djLint to lint Twig template files for syntax and common issues.

Note: Formatting is disabled as it breaks code generation syntax. Only linting is used.

Available command:

composer lint-twig  # Check for linting errors

Requires uv to be installed. Configuration is in pyproject.toml. The linter runs automatically on pull requests via GitHub Actions.

Supported Specs

Generated SDKs and Artifacts

The primary generation targets are defined in example.php. Run it without arguments to generate every target with the default console platform spec, or pass a target and optional platform to generate one SDK:

php example.php
php example.php <target>
php example.php <target> <platform>

<platform> can be console, client, or server. If omitted, it defaults to console.

Examples:

php example.php web client
php example.php node server
php example.php cli console
php example.php agent-skills

Client SDKs

Target Argument Supported Versions Coding Standards Package Manager Output
Web web ES5+; Node.js >=18 for builds NPM Coding Style NPM examples/web/
Flutter flutter Dart >=2.17 <4; Flutter stable Effective Dart pub examples/flutter/
Apple apple iOS 15+, macOS 11+, watchOS 7+, tvOS 13+ Swift Style Guide Swift Package Manager examples/apple/
Android android Android 5.0+; Java 17 in CI Android style guide Gradle, Maven examples/android/
React Native react-native React Native >=0.76.7 <1.0.0; Node.js >=18 NPM Coding Style NPM examples/react-native/

Server SDKs

Target Argument Supported Versions Coding Standards Package Manager Output
Node.js node Node.js 20 in CI NPM Coding Style NPM examples/node/
PHP php PHP >=8.2 PHP FIG Composer examples/php/
Python python Python >=3.9 PEP8 pip examples/python/
Ruby ruby Ruby 3.1 in CI Ruby Style Guide RubyGems, Bundler examples/ruby/
Dart dart Dart >=2.17 <4 Effective Dart pub examples/dart/
Go go Go 1.22.5 Effective Go Go modules examples/go/
Swift swift Swift 5.1+; Swift 5.9.2 in CI Swift Style Guide Swift Package Manager examples/swift/
.NET dotnet .NET Standard 2.0; .NET Framework 4.6.2 C# Coding Conventions NuGet examples/dotnet/
Kotlin kotlin JVM 1.8 target; Java 17 in CI Kotlin style guide Gradle, Maven examples/kotlin/
Rust rust Rust >=1.83 Rust API Guidelines Cargo examples/rust/

Tooling and Documentation

Target Argument Supported Versions Coding Standards Package Manager Output
CLI cli Node.js 20 and Bun 1.3.11 in CI NPM Coding Style NPM, Bun, native binaries examples/cli/
REST examples rest N/A Markdown N/A examples/REST/
GraphQL graphql N/A GraphQL N/A examples/graphql/
Markdown docs markdown N/A Markdown N/A examples/markdown/
Agent Skills agent-skills N/A Markdown N/A examples/agent-skills/
Cursor Plugin cursor-plugin N/A Markdown N/A examples/cursor-plugin/
Claude Plugin claude-plugin N/A Markdown N/A examples/claude-plugin/

Contributing

All code contributions, including those by people with commit access, must go through a pull request and be approved by a core developer before being merged. This is to ensure proper review of all the code.

We truly ❤️ pull requests! If you wish to help, you can learn more about how you can contribute to this project in the contribution guide.

Copyright and license

The MIT License (MIT) http://www.opensource.org/licenses/mit-license.php

统计信息

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

GitHub 信息

  • Stars: 316
  • Watchers: 21
  • Forks: 199
  • 开发语言: Twig

其他信息

  • 授权协议: MIT
  • 更新时间: 2019-05-23

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固