Git Product home page Git Product logo

flow-php-sdk's Introduction

Flow PHP SDK

โš ๏ธ This is an alpha release; functionality may change.

This is a Laravel PHP package that allows you to interact with the Flow blockchain by using the Flow CLI.

In the future we'll make a full integration with the GRPC interface, but for now it's just a wrapper around the Flow CLI.

At the moment, the SDK includes the following features:

  • Wrapper around Flow CLI for basic scripts, transactions, events and block calls.
  • Communication with the Flow Access API over gRPC (coming soon)
  • Transaction preparation and signing (coming soon)
  • Events parsing (coming soon)

Installation

Composer

To add this SDK to your project using Composer, use the following:

composer require mayvenstudios/flow-php-sdk

Environment variables

After this, you should add the following variables in your .env file. This example shows the default Flow CLI path for macOS if you're using Homebrew, but on a Linux server it will likely be ~/.local/bin

FLOW_PATH=/opt/homebrew/bin/
FLOW_NETWORK=testnet

Cadence folder

It's very important that you put all your flow.json config file and the contracts, scripts and transactions in a folder called cadence in the root directory of your project. This folder will be used as the base path to run the flow command, so that it will be able to read all the necessary Flow configurations.

Config file (optional)

If you're using Laravel you can also run this command to publish the config files if you need.

php artisan vendor:publish

Install the grpc extension (optional)

This is only needed if you want to help develop the full GRPC version.

$ [sudo] pecl install grpc

Example Usage

Once you have added the package via Composer and setup the environment variables, you can use the Flow Facade in the following ways.

Please remember to import the class at the beginning of your PHP with use Flow;

All the output will be returned as PHP Object parsed from the JSON returned by the Flow CLI.

Get the latest Block

Flow::getLatestBlock();

Get the latest Block by ID

Flow::getBlock(123456);

Get Events within a range of Blocks (250 max)

Flow::event('event_name_with_address_goes_here')->minBlock(1)->maxBlock(100)->run();

Run a script

Flow::script('path_to_cadence_script_file')->run();

Execute a transaction

Flow::transaction('path_to_cadence_transaction_file')->run();

Arguments

You can easily pass arguments to the script and transactions by using the following methods

Integer (UInt64)

Flow::transaction('path_to_cadence_transaction_file')->argInt(100)->run();

Fix (UFix64)

Flow::transaction('path_to_cadence_transaction_file')->argFix(9.99)->run();

String

Flow::transaction('path_to_cadence_transaction_file')->argString('something')->run();

Address

Flow::transaction('path_to_cadence_transaction_file')->argAddress('0x711eba2a0d39d21a')->run();

Bool

Flow::transaction('path_to_cadence_transaction_file')->argBool(true)->run();

DictionaryString (Dictionary of {String:String})

Flow::transaction('path_to_cadence_transaction_file')->argDictionaryString(['key' => 'value'])->run();

Contribution

Project is in the very early phase, all contributions are welcomed.

Read the contributing guide to get started.

Dependencies

Protobuf-PHP Illuminate-Support

License

Apache License 2.0

flow-php-sdk's People

Contributors

luca-mayven avatar bluesign avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.