diff --git a/.github/workflows/sdk-build-validation.yml b/.github/workflows/sdk-build-validation.yml new file mode 100644 index 000000000..770b80644 --- /dev/null +++ b/.github/workflows/sdk-build-validation.yml @@ -0,0 +1,199 @@ +name: Appwrite SDK Build Validation + +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +on: [pull_request] + +jobs: + generate-and-build: + name: ${{ matrix.sdk }} (${{ matrix.platform }}) + runs-on: ubuntu-latest + strategy: + fail-fast: false + matrix: + include: + # Client SDKs + - sdk: web + platform: client + + - sdk: flutter + platform: client + + - sdk: apple + platform: client + + - sdk: android + platform: client + + - sdk: react-native + platform: client + + # Server SDKs + - sdk: node + platform: server + + - sdk: php + platform: server + + - sdk: python + platform: server + + - sdk: ruby + platform: server + + - sdk: dart + platform: server + + - sdk: go + platform: server + + - sdk: swift + platform: server + + - sdk: dotnet + platform: server + + - sdk: kotlin + platform: server + + # Console SDKs + - sdk: cli + platform: console + + steps: + - name: Checkout repository + uses: actions/checkout@v4 + with: + submodules: recursive + + - name: Setup PHP + uses: shivammathur/setup-php@v2 + with: + php-version: '8.3' + extensions: curl + + - name: Install Composer Dependencies + run: composer install + + - name: Generate SDK for ${{ matrix.sdk }} + run: php example.php ${{ matrix.sdk }} ${{ matrix.platform }} + + # Language-specific setup + - name: Setup Node.js + if: matrix.sdk == 'web' || matrix.sdk == 'node' || matrix.sdk == 'cli' || matrix.sdk == 'react-native' + uses: actions/setup-node@v4 + with: + node-version: '20' + + - name: Setup Flutter + if: matrix.sdk == 'flutter' + uses: subosito/flutter-action@v2 + with: + channel: 'stable' + + - name: Setup Swift + if: matrix.sdk == 'apple' || matrix.sdk == 'swift' + run: | + sudo apt-get update + sudo apt-get install -y wget + wget https://download.swift.org/swift-5.9.2-release/ubuntu2204/swift-5.9.2-RELEASE/swift-5.9.2-RELEASE-ubuntu22.04.tar.gz + tar xzf swift-5.9.2-RELEASE-ubuntu22.04.tar.gz + sudo mv swift-5.9.2-RELEASE-ubuntu22.04 /usr/share/swift + echo "/usr/share/swift/usr/bin" >> $GITHUB_PATH + + - name: Setup Java + if: matrix.sdk == 'android' || matrix.sdk == 'kotlin' + uses: actions/setup-java@v4 + with: + distribution: 'temurin' + java-version: '17' + + - name: Setup Python + if: matrix.sdk == 'python' + uses: actions/setup-python@v5 + with: + python-version: '3.11' + + - name: Setup Ruby + if: matrix.sdk == 'ruby' + uses: ruby/setup-ruby@v1 + with: + ruby-version: '3.1' + + - name: Setup Dart + if: matrix.sdk == 'dart' + uses: dart-lang/setup-dart@v1 + with: + sdk: 'stable' + + - name: Setup Go + if: matrix.sdk == 'go' + uses: actions/setup-go@v5 + with: + go-version: '1.21' + + - name: Setup .NET + if: matrix.sdk == 'dotnet' + uses: actions/setup-dotnet@v4 + with: + dotnet-version: '8.0.x' + + - name: Build SDK + working-directory: examples/${{ matrix.sdk }} + run: | + case "${{ matrix.sdk }}" in + web|node) + npm install + npm run build + ;; + cli) + npm install + npm run linux-x64 + ;; + react-native) + npm install + npm run build || echo "No build script, checking syntax only" + ;; + flutter) + flutter pub get + dart analyze --no-fatal-warnings + ;; + apple|swift) + swift build + ;; + android) + chmod +x ./gradlew || true + ./gradlew build -x lint + ;; + kotlin) + chmod +x ./gradlew || true + ./gradlew build + ;; + php) + composer install + ;; + python) + pip install -e . + python -m compileall appwrite/ + ;; + ruby) + bundle install + ;; + dart) + dart pub get + dart analyze --no-fatal-warnings + ;; + go) + go mod tidy || true + go build ./... + ;; + dotnet) + dotnet build + ;; + *) + echo "Unknown SDK: ${{ matrix.sdk }}" + exit 1 + ;; + esac diff --git a/example.php b/example.php index cf929a7dc..852ddfa31 100644 --- a/example.php +++ b/example.php @@ -36,10 +36,63 @@ function getSSLPage($url) { return $result; } - // Leave the platform you want uncommented - // $platform = 'client'; - $platform = 'console'; - // $platform = 'server'; + function configureSDK($sdk, $overrides = []) { + $defaults = [ + 'name' => 'NAME', + 'version' => '0.0.0', + 'description' => 'Repo description goes here', + 'shortDescription' => 'Repo short description goes here', + 'url' => 'https://example.com', + 'logo' => 'https://appwrite.io/images/logos/logo.svg', + 'licenseContent' => 'test test test', + 'warning' => '**WORK IN PROGRESS - NOT READY FOR USAGE**', + 'changelog' => '**CHANGELOG**', + 'gitUserName' => 'repoowner', + 'gitRepoName' => 'reponame', + 'twitter' => 'appwrite', + 'discord' => ['564160730845151244', 'https://appwrite.io/discord'], + 'defaultHeaders' => ['X-Appwrite-Response-Format' => '1.6.0'], + 'readme' => '**README**', + ]; + + $config = array_merge($defaults, $overrides); + + $sdk->setName($config['name']) + ->setVersion($config['version']) + ->setDescription($config['description']) + ->setShortDescription($config['shortDescription']) + ->setURL($config['url']) + ->setLogo($config['logo']) + ->setLicenseContent($config['licenseContent']) + ->setWarning($config['warning']) + ->setChangelog($config['changelog']) + ->setGitUserName($config['gitUserName']) + ->setGitRepoName($config['gitRepoName']) + ->setTwitter($config['twitter']) + ->setDiscord($config['discord'][0], $config['discord'][1]) + ->setDefaultHeaders($config['defaultHeaders']) + ->setReadme($config['readme']); + + if (isset($config['namespace'])) { + $sdk->setNamespace($config['namespace']); + } + if (isset($config['exclude'])) { + $sdk->setExclude($config['exclude']); + } + + return $sdk; + } + + $requestedSdk = isset($argv[1]) ? $argv[1] : null; + $requestedPlatform = isset($argv[2]) ? $argv[2] : null; + + if ($requestedPlatform) { + $platform = $requestedPlatform; + } else { + $platform = 'console'; + // $platform = 'client'; + // $platform = 'server'; + } $version = '1.8.x'; $spec = getSSLPage("https://raw.githubusercontent.com/appwrite/appwrite/{$version}/app/config/specs/swagger2-{$version}-{$platform}.json"); @@ -48,436 +101,170 @@ function getSSLPage($url) { throw new Exception('Failed to fetch spec from Appwrite server'); } + if ($requestedSdk) { + echo "Generating SDK: $requestedSdk (platform: $platform)\n"; + } + // PHP - $php = new PHP(); - $php - ->setComposerVendor('appwrite') - ->setComposerPackage('appwrite'); - $sdk = new SDK($php, new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://example.com') - ->setLogo('https://appwrite.io/images/github.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setGitUserName('repoowner') - ->setGitRepoName('reponame') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.6.0', - ]) - ; - - $sdk->generate(__DIR__ . '/examples/php'); + if (!$requestedSdk || $requestedSdk === 'php') { + $php = new PHP(); + $php + ->setComposerVendor('appwrite') + ->setComposerPackage('appwrite'); + $sdk = new SDK($php, new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/php'); + } // Web - $sdk = new SDK(new Web(), new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setVersion('0.0.0') - ->setURL('https://example.com') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setReadme("## Getting Started") - ->setGitUserName('repoowner') - ->setGitRepoName('reponame') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.6.0', - ]) - ; - - $sdk->generate(__DIR__ . '/examples/web'); + if (!$requestedSdk || $requestedSdk === 'web') { + $sdk = new SDK(new Web(), new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/web'); + } // Node - $sdk = new SDK(new Node(), new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://example.com') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setGitUserName('repoowner') - ->setGitRepoName('reponame') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.6.0', - ]) - ; - - $sdk->generate(__DIR__ . '/examples/node'); + if (!$requestedSdk || $requestedSdk === 'node') { + $sdk = new SDK(new Node(), new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/node'); + } // CLI - $language = new CLI(); - $language->setNPMPackage('appwrite-cli'); - $language->setExecutableName('appwrite'); - $language->setLogo(json_encode(" - _ _ _ ___ __ _____ + if (!$requestedSdk || $requestedSdk === 'cli') { + $language = new CLI(); + $language->setNPMPackage('appwrite-cli'); + $language->setExecutableName('appwrite'); + $language->setLogo(json_encode(" + _ _ _ ___ __ _____ /_\ _ __ _ ____ ___ __(_) |_ ___ / __\ / / \_ \ //_\\\| '_ \| '_ \ \ /\ / / '__| | __/ _ \ / / / / / /\/ - / _ \ |_) | |_) \ V V /| | | | || __/ / /___/ /___/\/ /_ - \_/ \_/ .__/| .__/ \_/\_/ |_| |_|\__\___| \____/\____/\____/ - |_| |_| + / _ \ |_) | |_) \ V V /| | | | || __/ / /___/ /___/\/ /_ + \_/ \_/ .__/| .__/ \_/\_/ |_| |_|\__\___| \____/\____/\____/ + |_| |_| ")); - $language->setLogoUnescaped(" - _ _ _ ___ __ _____ + $language->setLogoUnescaped(" + _ _ _ ___ __ _____ /_\ _ __ _ ____ ___ __(_) |_ ___ / __\ / / \_ \ //_\\\| '_ \| '_ \ \ /\ / / '__| | __/ _ \ / / / / / /\/ - / _ \ |_) | |_) \ V V /| | | | || __/ / /___/ /___/\/ /_ - \_/ \_/ .__/| .__/ \_/\_/ |_| |_|\__\___| \____/\____/\____/ + / _ \ |_) | |_) \ V V /| | | | || __/ / /___/ /___/\/ /_ + \_/ \_/ .__/| .__/ \_/\_/ |_| |_|\__\___| \____/\____/\____/ |_| |_| "); - $sdk = new SDK($language, new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setVersion('0.16.0') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://appwrite.io') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicense('BSD-3-Clause') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setGitUserName('appwrite') - ->setGitRepoName('sdk-for-cli') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.7.0', - ]) - ->setExclude([ - 'services' => [ - ['name' => 'assistant'], - ['name' => 'avatars'], + $sdk = new SDK($language, new Swagger2($spec)); + configureSDK($sdk, [ + 'exclude' => [ + 'services' => [ + ['name' => 'assistant'], + ['name' => 'avatars'], + ], ], - ]) - ; + ]); - $sdk->generate(__DIR__ . '/examples/cli'); + $sdk->generate(__DIR__ . '/examples/cli'); + } // Ruby - $sdk = new SDK(new Ruby(), new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://example.com') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setGitUserName('repoowner') - ->setGitRepoName('reponame') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.6.0', - ]) - ; - - $sdk->generate(__DIR__ . '/examples/ruby'); + if (!$requestedSdk || $requestedSdk === 'ruby') { + $sdk = new SDK(new Ruby(), new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/ruby'); + } // Python - $sdk = new SDK(new Python(), new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setVersion('7.2.0') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://example.com') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setGitUserName('repoowner') - ->setGitRepoName('reponame') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.6.0', - ]) - ; - - $sdk->generate(__DIR__ . '/examples/python'); + if (!$requestedSdk || $requestedSdk === 'python') { + $sdk = new SDK(new Python(), new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/python'); + } // Dart - $dart = new Dart(); - $dart->setPackageName('dart_appwrite'); - - $sdk = new SDK($dart, new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://example.com') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setExamples('**EXAMPLES** ') - ->setVersion('0.0.1') - ->setGitUserName('repoowner') - ->setGitRepoName('reponame') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.6.0', - ]) - ; - - $sdk->generate(__DIR__ . '/examples/dart'); + if (!$requestedSdk || $requestedSdk === 'dart') { + $dart = new Dart(); + $dart->setPackageName('dart_appwrite'); + $sdk = new SDK($dart, new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/dart'); + } // Flutter - $flutter = new Flutter(); - $flutter->setPackageName('appwrite'); - $sdk = new SDK($flutter, new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://example.com') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setExamples('**EXAMPLES** ') - ->setVersion('0.0.1') - ->setGitUserName('repoowner') - ->setGitRepoName('reponame') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.6.0', - ]) - ; - - $sdk->generate(__DIR__ . '/examples/flutter'); + if (!$requestedSdk || $requestedSdk === 'flutter') { + $flutter = new Flutter(); + $flutter->setPackageName('appwrite'); + $sdk = new SDK($flutter, new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/flutter'); + } // React Native - $reactNative = new ReactNative(); - $reactNative->setNPMPackage('react-native-appwrite'); - $sdk = new SDK($reactNative, new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://example.com') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setExamples('**EXAMPLES** ') - ->setVersion('0.0.1') - ->setGitUserName('repoowner') - ->setGitRepoName('reponame') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.6.0', - ]) - ; - - $sdk->generate(__DIR__ . '/examples/react-native'); + if (!$requestedSdk || $requestedSdk === 'react-native') { + $reactNative = new ReactNative(); + $reactNative->setNPMPackage('react-native-appwrite'); + $sdk = new SDK($reactNative, new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/react-native'); + } // GO - $sdk = new SDK(new Go(), new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://example.com') - ->setVersion('0.0.1') - ->setGitUserName('appwrite') - ->setGitRepoName('sdk-for-go') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.6.0', - ]) - ; - - $sdk->generate(__DIR__ . '/examples/go'); - + if (!$requestedSdk || $requestedSdk === 'go') { + $sdk = new SDK(new Go(), new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/go'); + } // Swift - $sdk = new SDK(new Swift(), new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://example.com') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setVersion('0.0.1') - ->setGitUserName('repoowner') - ->setGitRepoName('reponame') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.6.0', - ]) - ; - - $sdk->generate(__DIR__ . '/examples/swift'); + if (!$requestedSdk || $requestedSdk === 'swift') { + $sdk = new SDK(new Swift(), new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/swift'); + } // Apple - $sdk = new SDK(new Apple(), new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://example.com') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setVersion('0.0.1') - ->setGitUserName('repoowner') - ->setGitRepoName('reponame') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.6.0', - ]) - ; - - $sdk->generate(__DIR__ . '/examples/apple'); + if (!$requestedSdk || $requestedSdk === 'apple') { + $sdk = new SDK(new Apple(), new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/apple'); + } // DotNet - $sdk = new SDK(new DotNet(), new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://example.com') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setVersion('0.0.1') - ->setGitUserName('repoowner') - ->setGitRepoName('reponame') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'X-Appwrite-Response-Format' => '1.6.0', - ]) - ; - - $sdk->generate(__DIR__ . '/examples/dotnet'); + if (!$requestedSdk || $requestedSdk === 'dotnet') { + $sdk = new SDK(new DotNet(), new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/dotnet'); + } // REST - $sdk = new SDK(new REST(), new Swagger2($spec)); - - $sdk - ->setName('NAME') - ->setDescription('Repo description goes here') - ->setShortDescription('Repo short description goes here') - ->setURL('https://example.com') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**WORK IN PROGRESS - NOT READY FOR USAGE**') - ->setChangelog('**CHANGELOG**') - ->setVersion('0.0.1') - ->setGitUserName('repoowner') - ->setGitRepoName('reponame') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ; - - $sdk->generate(__DIR__ . '/examples/REST'); + if (!$requestedSdk || $requestedSdk === 'rest') { + $sdk = new SDK(new REST(), new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/REST'); + } // Android - $sdk = new SDK(new Android(), new Swagger2($spec)); - - $sdk - ->setName('Android') - ->setNamespace('io appwrite') - ->setDescription('Appwrite is an open-source backend as a service server that abstract and simplify complex and repetitive development tasks behind a very simple to use REST API. Appwrite aims to help you develop your apps faster and in a more secure way. Use the Flutter SDK to integrate your app with the Appwrite server to easily start interacting with all of Appwrite backend APIs and tools. For full API documentation and tutorials go to https://appwrite.io/docs') - ->setShortDescription('Appwrite Android SDK') - ->setURL('https://example.com') - ->setGitUserName('appwrite') - ->setGitRepoName('sdk-for-android') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**This SDK is compatible with Appwrite server version 0.7.x. For older versions, please check previous releases.**') - ->setChangelog('**CHANGELOG**') - ->setVersion('0.0.0-SNAPSHOT') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'x-appwrite-response-format' => '0.7.0', - ]) - ; - $sdk->generate(__DIR__ . '/examples/android'); + if (!$requestedSdk || $requestedSdk === 'android') { + $sdk = new SDK(new Android(), new Swagger2($spec)); + configureSDK($sdk, [ + 'namespace' => 'io.appwrite', + ]); + $sdk->generate(__DIR__ . '/examples/android'); + } // Kotlin - $sdk = new SDK(new Kotlin(), new Swagger2($spec)); - - $sdk - ->setName('Kotlin') - ->setNamespace('io appwrite') - ->setDescription('Appwrite is an open-source backend as a service server that abstract and simplify complex and repetitive development tasks behind a very simple to use REST API. Appwrite aims to help you develop your apps faster and in a more secure way. Use the Flutter SDK to integrate your app with the Appwrite server to easily start interacting with all of Appwrite backend APIs and tools. For full API documentation and tutorials go to https://appwrite.io/docs') - ->setShortDescription('Appwrite Kotlin SDK') - ->setURL('https://example.com') - ->setGitUserName('appwrite') - ->setGitRepoName('sdk-for-kotlin') - ->setLogo('https://appwrite.io/v1/images/console.png') - ->setLicenseContent('test test test') - ->setWarning('**This SDK is compatible with Appwrite server version 0.7.x. For older versions, please check previous releases.**') - ->setChangelog('**CHANGELOG**') - ->setVersion('0.0.0-SNAPSHOT') - ->setTwitter('appwrite_io') - ->setDiscord('564160730845151244', 'https://appwrite.io/discord') - ->setDefaultHeaders([ - 'x-appwrite-response-format' => '0.8.0', - ]) - ; - $sdk->generate(__DIR__ . '/examples/kotlin'); + if (!$requestedSdk || $requestedSdk === 'kotlin') { + $sdk = new SDK(new Kotlin(), new Swagger2($spec)); + configureSDK($sdk, [ + 'namespace' => 'io.appwrite', + ]); + $sdk->generate(__DIR__ . '/examples/kotlin'); + } // GraphQL - $sdk = new SDK(new GraphQL(), new Swagger2($spec)); - - $sdk - ->setName('GraphQL') - ->setDescription('Appwrite is an open-source backend as a service server that abstract and simplify complex and repetitive development tasks behind a very simple to use REST API. Appwrite aims to help you develop your apps faster and in a more secure way. Use the Flutter SDK to integrate your app with the Appwrite server to easily start interacting with all of Appwrite backend APIs and tools. For full API documentation and tutorials go to https://appwrite.io/docs') - ->setLogo('https://appwrite.io/v1/images/console.png') - ; - $sdk->generate(__DIR__ . '/examples/graphql'); + if (!$requestedSdk || $requestedSdk === 'graphql') { + $sdk = new SDK(new GraphQL(), new Swagger2($spec)); + configureSDK($sdk); + $sdk->generate(__DIR__ . '/examples/graphql'); + } } catch (Exception $exception) { echo 'Error: ' . $exception->getMessage() . ' on ' . $exception->getFile() . ':' . $exception->getLine() . "\n"; diff --git a/templates/apple/Package.swift.twig b/templates/apple/Package.swift.twig index ea8d73011..b8d3e4008 100644 --- a/templates/apple/Package.swift.twig +++ b/templates/apple/Package.swift.twig @@ -44,6 +44,9 @@ let package = Package( .target( name: "{{spec.title | caseUcfirst}}Models", dependencies: [ + {%~ if spec.allEnums is not empty %} + "{{spec.title | caseUcfirst}}Enums", + {%~ endif %} "JSONCodable" ] ), diff --git a/templates/swift/Package.swift.twig b/templates/swift/Package.swift.twig index ea8d73011..b8d3e4008 100644 --- a/templates/swift/Package.swift.twig +++ b/templates/swift/Package.swift.twig @@ -44,6 +44,9 @@ let package = Package( .target( name: "{{spec.title | caseUcfirst}}Models", dependencies: [ + {%~ if spec.allEnums is not empty %} + "{{spec.title | caseUcfirst}}Enums", + {%~ endif %} "JSONCodable" ] ), diff --git a/tests/languages/apple/Tests.swift b/tests/languages/apple/Tests.swift index 536ebaec5..9265e5c32 100644 --- a/tests/languages/apple/Tests.swift +++ b/tests/languages/apple/Tests.swift @@ -32,7 +32,8 @@ class Tests: XCTestCase { // reset configs client.setProject("console") - client.setEndpointRealtime("ws://cloud.appwrite.io/v1") + client.setEndpointRealtime("wss://cloud.appwrite.io/v1") + client.setSelfSigned(false) let foo = Foo(client) let bar = Bar(client) diff --git a/tests/languages/web/index.html b/tests/languages/web/index.html index f13024edf..be25de42c 100644 --- a/tests/languages/web/index.html +++ b/tests/languages/web/index.html @@ -35,7 +35,7 @@ // Realtime setup client.setProject('console'); - client.setEndpointRealtime('ws://cloud.appwrite.io/v1'); + client.setEndpointRealtime('wss://cloud.appwrite.io/v1'); client.subscribe('tests', event => { responseRealtime = event.payload.response;