Download the PHP package 22digital/laravel-cashier-fastspring without Composer

On this page you can find all versions of the php package 22digital/laravel-cashier-fastspring. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package laravel-cashier-fastspring

Laravel Cashier FastSpring Beta

Packagist Build Status Coverage Status Style CI Laravel 5 License

Table of contents

Introduction

Cashier Fastspring is a cashier-like laravel package which provides interface to Fastspring subscription and payment services. This package handles webhooks and provides a simple API for Fastspring. Before using this package, looking at Fastspring documentation is strongly recommended.

Installation

Add 22digital/laravel-cashier-fastspring package to your dependencies.

After requiring package, add service provider of this package to providers in config/app.php.

Configuration

Migrations

Cashier Fastspring package comes with database migrations. After requiring the package, you can publish it with following command.

After publishing them, you can find migration files in your database/migrations folder. Remember that you can modify them according to your needs.

Billable Model

Next, add the Billable trait to your model definition. This trait provides various methods to allow you to perform common billing tasks, such as creating and checking subscriptions, getting orders etc.

API Keys

You should add Fastspring configuration to config/services.php file.

Webhook Route

Fastspring can notify your application of a variety of events via webhooks. To handle webhooks, define a route and also set it in Fastspring settings.

Webhooks & CSRF Protection

Fastspring webhook requests need to bypass CSRF protection. That's why be sure to list your webhook URI as an exception in your VerifyCsrfToken middleware.

Creating Plans

This package does not cover creating plans at Fastspring side or storing created plans. You should create your subscription plans at Fastspring's Dashboard.

Quick Start

Cashier Fastspring comes with built-in listeners which you can find in src/Events for quickstart. These listeners help you to sync subscriptions and invoices with your database.

Remember that you can create and use your listeners and database structure according to your needs. In order to customize, you can check Usage.

In Cashier Fastspring, every webhook request fires related events. You can register listeners to webhook events in app/providers/EventServiceProvider.php. You can see more at Webhooks.

You should create a session for subscription payment page. You can do it with newSubscription method as below.

You can provide session id $session->id to Fastspring's Popup Storefronts or Web Storefronts.

Note: newSubscription method does not create a subscription model. After a successful payment, you can use browser script to inform your app and create related models.

Usage

Cashier Fastspring comes with ready-to-use Subscription, Subscription Period, Invoice models and webhook handler. You can find detailed explanation below. Remember that you can easily replace these models and logic with yours.

Subscriptions

Cashier Fastspring provides a local type of subscription which lets you to create subscriptions without interacting with Fastspring. This may help you to create plans without payment info required. If a subscription has no fastspring_id, it is typed as local. You can check type using type(), isLocal(), isFastspring() methods.

Creating Subscriptions

To create a subscription, you can use newSubscription method of the Billable model. After creating session, you can provide session id $session->id to Fastspring's Popup Storefronts or Web Storefronts.

You can also provide coupon or quantity. As a hint, coupons also can be set on Fastspring's payment pages.

If the Billable model is not created as Fastspring customer yet newSubscription model creates it automatically and saves fastspring_id. If you want to do this manually you can use createAsFastspringCustomer method.

If details of a Billable model is updated, you can also update them at Fastspring side with updateAsFastspringCustomer method.

Checking Subscription Status

At Fastspring side, there are 5 states for subscriptions: active, overdue, canceled, deactivated, trial. The only state you should give up to serve your customer is deactivated state. Others are just informative states. Cashier Fastspring package keeps synchronized state of subscriptions with webhooks.

You can check if you should still serve to the Billable model by using subscribed method.

You can retrieve related subscription model by using subscription method and use methods of Subscription methods to check its status.

You can use the subscribedToPlan method to check if the user is subscribed to a given plan.

Changing Plans

You can change current plan of a Billable model by using swap method as below. Before using this, it is recommended to look at Prorating when Upgrading or Downgrading Subscription Plans.

The swap method communicates with Fastspring and updates the subscription model according to response. If you plan to swap plan without prorating, plan doesn't change immediately. In that case, future plan and swap date are saved to swap_to and swap_at columns. End of the current subscription period, Fastspring sends you webhook request about subscription change. That's why if you think to use prorating, remember to set webhooks right.

Subscription Trials

You can handle trial days of your plans at Fastspring Dashboard.

Cancelling Subscriptions

To cancel a subscription, call the cancel method on the subscription model.

If you want to cancel a subscription immediately, you can use cancelNow method.

Both methods update the subscription model according to response of Fastspring. The cancel method saves cancellation time to the swap_at column.

Resuming Subscriptions

To resume a subscription, you can use resume method on the subscription model. The user must be still on grace period. Otherwise, this method throws a LogicException.

This method updates the subscription model's state and set swap_to, swap_at columns null according to response.

Subscription Period

Cashier Fastspring package has also built-in subscription period model and related methods in order to help you to manage payment periods of subscription. This may help you to keep usage of particular resources of users between payment periods.

You can call activePeriodOrCreate method of Subscription model and retrieve current SubscriptionPeriod model which involves id, start_date, end_date information. If the current active period is not created yet, this method fetches it from Fastspring API and creates. If the subscription is a local subscription, it also creates a new period according to the last subscription period (if there is none, it assumes today is the start day of the subscription period).

Updating Credit Cards

Fastspring does not provide any API to update credit card or any other payment information directly. You should redirect your customers to the their account management panel at Fastspring side. You can generate account management panel URL by using accountManagementURI method of the Billable model.

Webhooks

Cashier Fastspring package provides an easy way to handle webhooks. It fires related events for each webhook request and provides request payload data as a parameter. It also handles message security if you set FASTSPRING_HMAC_SECRET. You can find sample listeners in src/Listeners folder.

Beside webhook specific events, there are also category and any events. For instance, if you want to listen all webhook requests, you can register your listener to TwentyTwoDigital\CashierFastspring\Events\Any event. Also, if you want to listen all subscription related webhook requests, you can use TwentyTwoDigital\CashierFastspring\Events\SubscriptionAny event.

You can see relation between package events and webhook requests at the table below.

Webhook Request Fired Cashier Fastspring Events
account.created TwentyTwoDigital\CashierFastspring\Events\AccountCreated, TwentyTwoDigital\CashierFastspring\Events\AccountAny, TwentyTwoDigital\CashierFastspring\Events\Any
fulfillment.failed TwentyTwoDigital\CashierFastspring\Events\FulfillmentFailed, TwentyTwoDigital\CashierFastspring\Events\FulfillmentAny, TwentyTwoDigital\CashierFastspring\Events\Any
mailingListEntry.removed TwentyTwoDigital\CashierFastspring\Events\MailingListEntryRemoved, TwentyTwoDigital\CashierFastspring\Events\MailingListEntryAny, TwentyTwoDigital\CashierFastspring\Events\Any
mailingListEntry.updated TwentyTwoDigital\CashierFastspring\Events\MailingListEntryUpdated, TwentyTwoDigital\CashierFastspring\Events\MailingListEntryAny, TwentyTwoDigital\CashierFastspring\Events\Any
order.approval.pending TwentyTwoDigital\CashierFastspring\Events\OrderApprovalPending, TwentyTwoDigital\CashierFastspring\Events\OrderAny, TwentyTwoDigital\CashierFastspring\Events\Any
order.canceled TwentyTwoDigital\CashierFastspring\Events\OrderCanceled, TwentyTwoDigital\CashierFastspring\Events\OrderAny, TwentyTwoDigital\CashierFastspring\Events\Any
order.payment.pending TwentyTwoDigital\CashierFastspring\Events\OrderPaymentPending, TwentyTwoDigital\CashierFastspring\Events\OrderAny, TwentyTwoDigital\CashierFastspring\Events\Any
order.completed TwentyTwoDigital\CashierFastspring\Events\OrderCompleted, TwentyTwoDigital\CashierFastspring\Events\OrderAny, TwentyTwoDigital\CashierFastspring\Events\Any
order.failed TwentyTwoDigital\CashierFastspring\Events\OrderFailed, TwentyTwoDigital\CashierFastspring\Events\OrderAny, TwentyTwoDigital\CashierFastspring\Events\Any
payoutEntry.created TwentyTwoDigital\CashierFastspring\Events\PayoutEntryCreated, TwentyTwoDigital\CashierFastspring\Events\PayoutEntryAny, TwentyTwoDigital\CashierFastspring\Events\Any
return.created TwentyTwoDigital\CashierFastspring\Events\ReturnCreated, TwentyTwoDigital\CashierFastspring\Events\ReturnAny, TwentyTwoDigital\CashierFastspring\Events\Any
subscription.activated TwentyTwoDigital\CashierFastspring\Events\SubscriptionActivated, TwentyTwoDigital\CashierFastspring\Events\SubscriptionAny, TwentyTwoDigital\CashierFastspring\Events\Any
subscription.canceled TwentyTwoDigital\CashierFastspring\Events\SubscriptionCanceled, TwentyTwoDigital\CashierFastspring\Events\SubscriptionAny, TwentyTwoDigital\CashierFastspring\Events\Any
subscription.charge.completed TwentyTwoDigital\CashierFastspring\Events\SubscriptionChargeCompleted, TwentyTwoDigital\CashierFastspring\Events\SubscriptionAny, TwentyTwoDigital\CashierFastspring\Events\Any
subscription.charge.failed TwentyTwoDigital\CashierFastspring\Events\SubscriptionChargeFailed, TwentyTwoDigital\CashierFastspring\Events\SubscriptionAny, TwentyTwoDigital\CashierFastspring\Events\Any
subscription.deactivated TwentyTwoDigital\CashierFastspring\Events\SubscriptionDeactivated, TwentyTwoDigital\CashierFastspring\Events\SubscriptionAny, TwentyTwoDigital\CashierFastspring\Events\Any
subscription.payment.overdue TwentyTwoDigital\CashierFastspring\Events\SubscriptionPaymentOverdue, TwentyTwoDigital\CashierFastspring\Events\SubscriptionAny, TwentyTwoDigital\CashierFastspring\Events\Any
subscription.payment.reminder TwentyTwoDigital\CashierFastspring\Events\SubscriptionPaymentReminder, TwentyTwoDigital\CashierFastspring\Events\SubscriptionAny, TwentyTwoDigital\CashierFastspring\Events\Any
subscription.trial.reminder TwentyTwoDigital\CashierFastspring\Events\SubscriptionTrialReminder, TwentyTwoDigital\CashierFastspring\Events\SubscriptionAny, TwentyTwoDigital\CashierFastspring\Events\Any
subscription.updated TwentyTwoDigital\CashierFastspring\Events\SubscriptionUpdated, TwentyTwoDigital\CashierFastspring\Events\SubscriptionAny, TwentyTwoDigital\CashierFastspring\Events\Any

To listen an event, you can register listeners in app/providers/EventServiceProvider.php.

Single Charges

Not implemented yet. If you need it you can contribute to the package. Please check Contributing.

Invoices

In Fastspring, invoices are generated by Fastspring. You don't need to generate official or unofficial invoices. If you are using default webhook listeners, your invoices will be sync to your database. You can get invoices URL with the Invoice model or over the Billable trait.

Contributing

Thank you for considering contributing to the Cashier Fastspring. You can read the contribution guide lines issues to improve this package.

Credits

Cashier Fastspring package is developed by Bilal Gultekin over Taylor Otwell's Cashier package. You can see all contributors here.

License

Cashier Fastspring is open-sourced software licensed under the MIT license.


All versions of laravel-cashier-fastspring with dependencies

PHP Build Version
Package Version
Requires php Version >=7.1.3
illuminate/database Version ~5.6
illuminate/support Version ~5.6
nesbot/carbon Version ^2.0
symfony/http-kernel Version ~2.7|~3.0|~4.0
guzzlehttp/guzzle Version ^6.0
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package 22digital/laravel-cashier-fastspring contains the following files

Loading the files please wait ....