Skip to content

joshkulesza/php-flagr

Repository files navigation

php-flagr

Flagr is a feature flagging, A/B testing and dynamic configuration microservice. The base path for all the APIs is "/api/v1".

This PHP package is automatically generated by the Swagger Codegen project:

  • API version: 1.1.12
  • Build package: io.swagger.codegen.v3.generators.php.PhpClientCodegen

Requirements

PHP 5.5 and later

Installation & Usage

Composer

To install the bindings via Composer, add the following to composer.json:

{
  "repositories": [
    {
      "type": "git",
      "url": "https://github.com/joshkulesza/php-flagr.git"
    }
  ],
  "require": {
    "joshkulesza/php-flagr": "*@dev"
  }
}

Then run composer install

Manual Installation

Download the files and include autoload.php:

    require_once('/path/to/php-flagr/vendor/autoload.php');

Tests

To run the unit tests:

composer install
./vendor/bin/phpunit

Getting Started

Please follow the installation procedure and then run the following:

<?php
require_once(__DIR__ . '/vendor/autoload.php');

$apiInstance = new Flagr\Client\Api\ConstraintApi(
    // If you want use custom http client, pass your client which implements `GuzzleHttp\ClientInterface`.
    // This is optional, `GuzzleHttp\Client` will be used as default.
    new GuzzleHttp\Client()
);
$body = new \Flagr\Client\Model\CreateConstraintRequest(); // \Flagr\Client\Model\CreateConstraintRequest | create a constraint
$flag_id = 789; // int | numeric ID of the flag
$segment_id = 789; // int | numeric ID of the segment

try {
    $result = $apiInstance->createConstraint($body, $flag_id, $segment_id);
    print_r($result);
} catch (Exception $e) {
    echo 'Exception when calling ConstraintApi->createConstraint: ', $e->getMessage(), PHP_EOL;
}

$apiInstance = new Flagr\Client\Api\ConstraintApi(
    // If you want use custom http client, pass your client which implements `GuzzleHttp\ClientInterface`.
    // This is optional, `GuzzleHttp\Client` will be used as default.
    new GuzzleHttp\Client()
);
$flag_id = 789; // int | numeric ID of the flag
$segment_id = 789; // int | numeric ID of the segment
$constraint_id = 789; // int | numeric ID of the constraint

try {
    $apiInstance->deleteConstraint($flag_id, $segment_id, $constraint_id);
} catch (Exception $e) {
    echo 'Exception when calling ConstraintApi->deleteConstraint: ', $e->getMessage(), PHP_EOL;
}

$apiInstance = new Flagr\Client\Api\ConstraintApi(
    // If you want use custom http client, pass your client which implements `GuzzleHttp\ClientInterface`.
    // This is optional, `GuzzleHttp\Client` will be used as default.
    new GuzzleHttp\Client()
);
$flag_id = 789; // int | numeric ID of the flag
$segment_id = 789; // int | numeric ID of the segment

try {
    $result = $apiInstance->findConstraints($flag_id, $segment_id);
    print_r($result);
} catch (Exception $e) {
    echo 'Exception when calling ConstraintApi->findConstraints: ', $e->getMessage(), PHP_EOL;
}

$apiInstance = new Flagr\Client\Api\ConstraintApi(
    // If you want use custom http client, pass your client which implements `GuzzleHttp\ClientInterface`.
    // This is optional, `GuzzleHttp\Client` will be used as default.
    new GuzzleHttp\Client()
);
$body = new \Flagr\Client\Model\CreateConstraintRequest(); // \Flagr\Client\Model\CreateConstraintRequest | create a constraint
$flag_id = 789; // int | numeric ID of the flag
$segment_id = 789; // int | numeric ID of the segment
$constraint_id = 789; // int | numeric ID of the constraint

try {
    $result = $apiInstance->putConstraint($body, $flag_id, $segment_id, $constraint_id);
    print_r($result);
} catch (Exception $e) {
    echo 'Exception when calling ConstraintApi->putConstraint: ', $e->getMessage(), PHP_EOL;
}
?>

Documentation for API Endpoints

All URIs are relative to /api/v1

Class Method HTTP request Description
ConstraintApi createConstraint POST /flags/{flagID}/segments/{segmentID}/constraints
ConstraintApi deleteConstraint DELETE /flags/{flagID}/segments/{segmentID}/constraints/{constraintID}
ConstraintApi findConstraints GET /flags/{flagID}/segments/{segmentID}/constraints
ConstraintApi putConstraint PUT /flags/{flagID}/segments/{segmentID}/constraints/{constraintID}
DistributionApi findDistributions GET /flags/{flagID}/segments/{segmentID}/distributions
DistributionApi putDistributions PUT /flags/{flagID}/segments/{segmentID}/distributions
EvaluationApi postEvaluation POST /evaluation
EvaluationApi postEvaluationBatch POST /evaluation/batch
ExportApi getExportEvalCacheJSON GET /export/eval_cache/json
ExportApi getExportSqlite GET /export/sqlite
FlagApi createFlag POST /flags
FlagApi deleteFlag DELETE /flags/{flagID}
FlagApi findFlags GET /flags
FlagApi getFlag GET /flags/{flagID}
FlagApi getFlagEntityTypes GET /flags/entity_types
FlagApi getFlagSnapshots GET /flags/{flagID}/snapshots
FlagApi putFlag PUT /flags/{flagID}
FlagApi restoreFlag PUT /flags/{flagID}/restore
FlagApi setFlagEnabled PUT /flags/{flagID}/enabled
HealthApi getHealth GET /health
SegmentApi createSegment POST /flags/{flagID}/segments
SegmentApi deleteSegment DELETE /flags/{flagID}/segments/{segmentID}
SegmentApi findSegments GET /flags/{flagID}/segments
SegmentApi putSegment PUT /flags/{flagID}/segments/{segmentID}
SegmentApi putSegmentsReorder PUT /flags/{flagID}/segments/reorder
TagApi createTag POST /flags/{flagID}/tags
TagApi deleteTag DELETE /flags/{flagID}/tags/{tagID}
TagApi findAllTags GET /tags
TagApi findTags GET /flags/{flagID}/tags
VariantApi createVariant POST /flags/{flagID}/variants
VariantApi deleteVariant DELETE /flags/{flagID}/variants/{variantID}
VariantApi findVariants GET /flags/{flagID}/variants
VariantApi putVariant PUT /flags/{flagID}/variants/{variantID}

Documentation For Models

Documentation For Authorization

All endpoints do not require authorization.

Author