Credit Card Flow | Magento Braintree | Paypal Payflow Pro | Pk Magento 2

Credit Card Flow | Magento Braintree | Paypal Payflow Pro 

 

  1. Users add products in cart then move on checkout. 

  1. User full fill all required fields then select shipping method and payment method 

  1. If payment is selected as Braintree credit card. Then user enters card details 

  1. Then Magento to validate all other field data like billing address, shipping address and shipping method etc.  

 

  1. Then User clicks on place order button.  

 

  1. Magento sends validation request to Braintree with Braintree (Merchant) credentials and Card Details. 

  1. After successful validation, Braintree sends back response token to Magento on real-time. 

  1. Magento now sends “Token, customer details & order details” to Braintree. 

*details like customer billing & shipping address, item total, discount., order ID etc. 

  1. Braintree validates the card details through token and charge the amount to customer and sends back response to Magento in real-time with below responses 

  1. Success – Response contains Success array  

  1. False– Response contains the Error details 

  1. Null – Blank Array with no details  

“Null” response is not handled currently which needs to be solutionized 

 

 

 

 

Request example in json. 

 

'request' =>  

  array ( 

    'customer' =>  

    array ( 

      'firstName' => 'xxrri-xxynn', 

      'lastName' => 'McKillop', 

      'company' => '', 

      'phone' => 'xxxxxxx', 

      'email' => 'xxxx@outlook.com', 

    ), 

    'amount' => '189.99', 

    'paymentMethodNonce' => 'tokencc_bd_wyn4wk_657vx3_gfkg9s_t85xkq_vr3', 

    'orderId' => 'xx171241xxx38921', 

    'channel' => 'MagxxxxxeneBT', 

    'options' =>  

    array ( 

      'skipAdvancedFraudChecking' => false, 

      'storeInVaultOnSuccess' => true, 

      'submitForSettlement' => true, 

    ), 

    'customFields' =>  

    array ( 

    ), 

    'billing' =>  

    array ( 

      'firstName' => 'Terri-Lynn', 

      'lastName' => 'McKillop', 

      'company' => '', 

      'streetAddress' => '724 xxxtherine Street', 

      'extendedAddress' => '', 

      'locality' => 'thunder bay', 

      'region' => 'ON', 

      'postalCode' => 'p7xxx', 

      'countryCodeAlpha2' => 'CA', 

    ), 

    'shipping' =>  

    array ( 

      'firstName' => 'Terri-Lynn', 

      'lastName' => 'McKillop', 

      'company' => NULL, 

      'streetAddress' => '724 Catherine Street', 

      'extendedAddress' => '', 

      'locality' => 'thunder bay', 

      'region' => 'ON', 

      'postalCode' => 'p7e1l5', 

      'countryCodeAlpha2' => 'CA', 

      'countryCodeAlpha3' => 'CAN', 

    ), 

    'purchaseOrderNumber' => 'xxx', 

    'taxAmount' => '21.86', 

    'discountAmount' => '137.57',     

           

 

Response sample 

 

 

Null 

 

Failed 

 

 

Response sample  

'client' => 'PayPal\\Braintree\\Gateway\\Http\\Client\\TransactionSale', 

  'response' =>  

  array ( 

    'success' => true, 

    '' . "\0" . 'Braintree\\Result\\Successful' . "\0" . '_returnObjectNames' =>  

    array ( 

      0 => 'transaction', 

    ), 

    '' . "\0" . '*' . "\0" . '_attributes' =>  

    array ( 

    ), 

    'transaction' =>  

    Braintree\Transaction::__set_state(array( 

       '_attributes' =>  

      array ( 

        'id' => 'xxxx', 

        'status' => 'submitted_for_settlement', 

        'type' => 'sale', 

        'currencyIsoCode' => 'USD', 

        'amount' => '19.95', 

        'amountRequested' => '19.95', 

        'merchantAccountId' => 'xxxxxx', 

        'subMerchantAccountId' => NULL, 

        'masterMerchantAccountId' => NULL, 

        'orderId' => 'xxxxx', 

        'createdAt' =>  

        DateTime::__set_state(array( 

           'date' => '2022-09-02 18:45:31.000000', 

           'timezone_type' => 3, 

           'timezone' => 'UTC', 

        )), 

        'updatedAt' =>  

        DateTime::__set_state(array( 

           'date' => '2022-09-02 18:45:32.000000', 

           'timezone_type' => 3, 

           'timezone' => 'UTC', 

        )), 

        'customer' =>  

        array ( 

          'id' => 'xxxx', 

          'firstName' => 'xxxx', 

          'lastName' => 'Wasserman', 

          'company' => NULL, 

          'email' => 'xxxxx@gmail.com', 

          'website' => NULL, 

          'phone' => 'xxxxxxx', 

          'fax' => NULL, 

          'globalId' => 'xxxxxx', 

        ), 

        'billing' =>  

        array ( 

          'id' => NULL, 

          'firstName' => 'Amanda', 

          'lastName' => 'xxxxx', 

          'company' => NULL, 

          'streetAddress' => '1008 xxxx Ave', 

          'extendedAddress' => NULL, 

          'locality' => 'Ann Arbor', 

          'region' => 'MI', 

          'postalCode' => 'xxx', 

          'countryName' => 'United States of America', 

          'countryCodeAlpha2' => 'US', 

          'countryCodeAlpha3' => 'USA', 

          'countryCodeNumeric' => '840', 

        ), 

        'refundId' => NULL, 

        'refundIds' =>  

        array ( 

        ), 

        'refundedTransactionId' => NULL, 

        'partialSettlementTransactionIds' =>  

        array ( 

        ), 

        'authorizedTransactionId' => NULL, 

        'settlementBatchId' => NULL, 

        'shipping' =>  

        array ( 

          'id' => NULL, 

          'firstName' => 'Amanda', 

          'lastName' => 'Wasserman', 

          'company' => NULL, 

          'streetAddress' => '1008 Oakland Ave', 

          'extendedAddress' => NULL, 

          'locality' => 'Ann Arbor', 

          'region' => 'MI', 

          'postalCode' => '48104', 

          'countryName' => 'United States of America', 

          'countryCodeAlpha2' => 'US', 

          'countryCodeAlpha3' => 'USA', 

          'countryCodeNumeric' => '840', 

        ), 

        'customFields' => NULL, 

        'accountFundingTransaction' => false, 

        'avsErrorResponseCode' => NULL, 

        'avsPostalCodeResponseCode' => 'N', 

        'avsStreetAddressResponseCode' => 'N', 

        'cvvResponseCode' => 'M', 

        'gatewayRejectionReason' => NULL, 

        'processorAuthorizationCode' => '006390', 

        'processorResponseCode' => '1000', 

        'processorResponseText' => 'Approved', 

        'additionalProcessorResponse' => NULL, 

        'voiceReferralNumber' => NULL, 

        'purchaseOrderNumber' => 'xxxx', 

        'taxAmount' => '0.00', 

        'taxExempt' => false, 

        'scaExemptionRequested' => NULL, 

        'processedWithNetworkToken' => false, 

        'creditCard' =>  

        array ( 

          'token' => 'xxxxx', 

          'bin' => '436618', 

          'last4' => '6871', 

          'cardType' => 'Visa', 

          'expirationMonth' => '08', 

          'expirationYear' => '2026', 

          'customerLocation' => 'US', 

          'cardholderName' => NULL, 

          'imageUrl' => 'https://assets.braintreegateway.com/payment_method_logo/visa.png?environment=production', 

          'prepaid' => 'No', 

          'healthcare' => 'No', 

          'debit' => 'Yes', 

          'durbinRegulated' => 'Yes', 

          'commercial' => 'Unknown', 

          'payroll' => 'No', 

          'issuingBank' => 'U.S. Bank National Association', 

          'countryOfIssuance' => 'USA', 

          'productId' => 'F', 

          'globalId' => 'xxxxx', 

          'accountType' => 'credit', 

          'uniqueNumberIdentifier' => 'xxxx', 

          'venmoSdk' => false, 

          'accountBalance' => NULL, 

        ), 

        'statusHistory' =>  

        array ( 

          0 =>  

          Braintree\Transaction\StatusDetails::__set_state(array( 

             '_attributes' =>  

            array ( 

              'timestamp' =>  

              DateTime::__set_state(array( 

                 'date' => '2022-09-02 18:45:31.000000', 

                 'timezone_type' => 3, 

                 'timezone' => 'UTC', 

              )), 

              'status' => 'authorized', 

              'amount' => '19.95', 

              'user' => 'vivyx_bt', 

              'transactionSource' => 'api', 

            ), 

          )), 

          1 =>  

          Braintree\Transaction\StatusDetails::__set_state(array( 

             '_attributes' =>  

            array ( 

              'timestamp' =>  

              DateTime::__set_state(array( 

                 'date' => '2022-09-02 18:45:31.000000', 

                 'timezone_type' => 3, 

                 'timezone' => 'UTC', 

              )), 

              'status' => 'submitted_for_settlement', 

              'amount' => '19.95', 

              'user' => 'vivyx_bt', 

              'transactionSource' => 'api', 

            ), 

          )), 

        ), 

        'planId' => NULL, 

        'subscriptionId' => NULL, 

        'subscription' =>  

        array ( 

          'billingPeriodEndDate' => NULL, 

          'billingPeriodStartDate' => NULL, 

        ), 

        'addOns' =>  

        array ( 

        ), 

        'discounts' =>  

        array ( 

        ), 

        'descriptor' =>  

        Braintree\Descriptor::__set_state(array( 

           '_attributes' =>  

          array ( 

            'name' => NULL, 

            'phone' => NULL, 

            'url' => NULL, 

          ), 

        )), 

        'recurring' => false, 

        'channel' => 'Magento2GeneBT', 

        'serviceFeeAmount' => NULL, 

        'escrowStatus' => NULL, 

        'disbursementDetails' =>  

        Braintree\DisbursementDetails::__set_state(array( 

           '_attributes' =>  

          array ( 

            'disbursementDate' => NULL, 

            'settlementAmount' => NULL, 

            'settlementCurrencyIsoCode' => NULL, 

            'settlementCurrencyExchangeRate' => NULL, 

            'settlementBaseCurrencyExchangeRate' => NULL, 

            'fundsHeld' => NULL, 

            'success' => NULL, 

          ), 

        )), 

        'disputes' =>  

        array ( 

        ), 

        'achReturnResponses' =>  

        array ( 

        ), 

        'authorizationAdjustments' =>  

        array ( 

        ), 

        'paymentInstrumentType' => 'credit_card', 

        'processorSettlementResponseCode' => NULL, 

        'processorSettlementResponseText' => NULL, 

        'networkResponseCode' => '00', 

        'networkResponseText' => 'Successful approval/completion or V.I.P. PIN verification is successful', 

        'threeDSecureInfo' => NULL, 

        'shipsFromPostalCode' => '30046', 

        'shippingAmount' => '0.00', 

        'discountAmount' => '0.00', 

        'networkTransactionId' => '462245675316191', 

        'processorResponseType' => 'approved', 

        'authorizationExpiresAt' =>  

        DateTime::__set_state(array( 

           'date' => '2022-09-09 18:45:31.000000', 

           'timezone_type' => 3, 

           'timezone' => 'UTC', 

        )), 

        'retryIds' =>  

        array ( 

        ), 

        'retriedTransactionId' => NULL, 

        'refundGlobalIds' =>  

        array ( 

        ), 

        'partialSettlementTransactionGlobalIds' =>  

        array ( 

        ), 

        'refundedTransactionGlobalId' => NULL, 

        'authorizedTransactionGlobalId' => NULL, 

        'globalId' => 'xxxxx', 

        'retryGlobalIds' =>  

        array ( 

        ), 

        'retriedTransactionGlobalId' => NULL, 

        'retrievalReferenceNumber' => NULL, 

        'installmentCount' => NULL, 

        'installments' =>  

        array ( 

        ), 

        'refundedInstallments' =>  

        array ( 

        ), 

        'responseEmvData' => NULL, 

        'acquirerReferenceNumber' => NULL, 

        'merchantIdentificationNumber' => 'xxxxx', 

        'terminalIdentificationNumber' => 'xxxxx', 

        'merchantName' => 'VIVYX PRINTING LLC', 

        'merchantAddress' =>  

        array ( 

          'streetAddress' => NULL, 

          'locality' => 'Phoenix', 

          'region' => 'AZ', 

          'postalCode' => '85034', 

          'phone' => '6786503559', 

        ), 

        'pinVerified' => false, 

        'debitNetwork' => NULL, 

        'processingMode' => NULL, 

        'paymentReceipt' =>  

        array ( 

          'id' => 'dxzfyakj', 

          'globalId' => 'dHJhbnNhY3Rpb25fZHh6Znlha2o', 

          'amount' => '19.95', 

          'currencyIsoCode' => 'USD', 

          'processorResponseCode' => '1000', 

          'processorResponseText' => 'Approved', 

          'processorAuthorizationCode' => '006390', 

          'merchantName' => 'VIVYX PRINTING LLC', 

          'merchantAddress' =>  

          array ( 

            'streetAddress' => NULL, 

            'locality' => 'Phoenix', 

            'region' => 'AZ', 

            'postalCode' => '85034', 

            'phone' => '6786503559', 

          ), 

          'merchantIdentificationNumber' => '4454xxxx96100998', 

          'terminalIdentificationNumber' => '00000001', 

          'type' => 'sale', 

          'pinVerified' => false, 

          'processingMode' => NULL, 

          'networkIdentificationCode' => NULL, 

          'cardType' => 'Visa', 

          'cardLast4' => '6871', 

          'accountBalance' => NULL, 

        ), 

        'creditCardDetails' =>  

        Braintree\Transaction\CreditCardDetails::__set_state(array( 

           '_attributes' =>  

          array ( 

            'token' => '9cjbcfz', 

            'bin' => '436618', 

            'last4' => '6871', 

            'cardType' => 'Visa', 

            'expirationMonth' => '08', 

            'expirationYear' => '2026', 

            'customerLocation' => 'US', 

            'cardholderName' => NULL, 

            'imageUrl' => 'https://assets.braintreegateway.com/payment_method_logo/visa.png?environment=production', 

            'prepaid' => 'No', 

            'healthcare' => 'No', 

            'debit' => 'Yes', 

            'durbinRegulated' => 'Yes', 

            'commercial' => 'Unknown', 

            'payroll' => 'No', 

            'issuingBank' => 'U.S. Bank National Association', 

            'countryOfIssuance' => 'USA', 

            'productId' => 'F', 

            'globalId' => 'cGF5bWVudG1ldGhvZF9jY185Y2piY2Z6', 

            'accountType' => 'credit', 

            'uniqueNumberIdentifier' => 'a5595b292d9ea1e711b4808e3677e4b2', 

            'venmoSdk' => false, 

            'accountBalance' => NULL, 

            'expirationDate' => '08/2026', 

            'maskedNumber' => '436618******6871', 

          ), 

        )), 

        'customerDetails' =>  

        Braintree\Transaction\CustomerDetails::__set_state(array( 

           '_attributes' =>  

          array ( 

            'id' => 'ccg854cb', 

            'firstName' => 'Amanda', 

            'lastName' => 'Wasserman', 

            'company' => NULL, 

            'email' => 'awwasserman@gmail.com', 

            'website' => NULL, 

            'phone' => '8589253310', 

            'fax' => NULL, 

            'globalId' => 'Y3VzdG9tZXJfY2NnODU0Y2I', 

          ), 

        )), 

        'billingDetails' =>  

        Braintree\Transaction\AddressDetails::__set_state(array( 

           '_attributes' =>  

          array ( 

            'id' => NULL, 

            'firstName' => 'Amanda', 

            'lastName' => 'Wasserman', 

            'company' => NULL, 

            'streetAddress' => '1008 Oakland Ave', 

            'extendedAddress' => NULL, 

            'locality' => 'Ann Arbor', 

            'region' => 'MI', 

            'postalCode' => '48104', 

            'countryName' => 'United States of America', 

            'countryCodeAlpha2' => 'US', 

            'countryCodeAlpha3' => 'USA', 

            'countryCodeNumeric' => '840', 

          ), 

        )), 

        'shippingDetails' =>  

        Braintree\Transaction\AddressDetails::__set_state(array( 

           '_attributes' =>  

          array ( 

            'id' => NULL, 

            'firstName' => 'Amanda', 

            'lastName' => 'Wasserman', 

            'company' => NULL, 

            'streetAddress' => '1008 Oakland Ave', 

            'extendedAddress' => NULL, 

            'locality' => 'Ann Arbor', 

            'region' => 'MI', 

            'postalCode' => '48104', 

            'countryName' => 'United States of America', 

            'countryCodeAlpha2' => 'US', 

            'countryCodeAlpha3' => 'USA', 

            'countryCodeNumeric' => '840', 

          ), 

        )), 

        'subscriptionDetails' =>  

        Braintree\Transaction\SubscriptionDetails::__set_state(array( 

           '_attributes' =>  

          array ( 

            'billingPeriodEndDate' => NULL, 

            'billingPeriodStartDate' => NULL, 

          ), 

        )), 

      ), 

    )), 

  ), 

) [] [] 

 

 

 

  1. In case user selects “PayPal” as payment method and places order, then 

  1. It redirects on a controller and generate a redirect URL of Paypal which contains all information regarding payment & redirect URL.   

  1. user gets redirected to “PayPal” website. 

  1. After making payment on “PayPal” website, user is redirected back to Magento website using the redirect URL which also contains the response success and failed.   

  1. Magento will now generate order according to response received 

  1.  If payment is successful, then order will get generated  

  1.  In case payment is failed user gets redirected to cart page as received the failure object on the redirect URL response. 

 

 

 

Magento 2 Design patterns | pk magento 2

 My youtube channel : https://www.youtube.com/channel/UChb7DM9SspzrUVh4hnWL50A

REQUESTED BY : ANKUR PORWAL

01 (MVC)  MODEL VIEW CONTROLLER PATTERN (MVVM) MODEL VIEW VIEWMODEL PATTERN 
Model View Controller, MVC in short. This is a design pattern where business, presentation and coupling logic are separated. Magento utilizing a DOM based configuration layer. It is used xml to drive the configuration and actions of the application on top of the regular Model-View-Controller architecture. 
MVVM design pattern is used in magento on checkout page with knockoutjs. 

02 FRONT CONTROLLER PATTERN
The front controller pattern to implement workflows for our application. It has a single entry point (index.php) for all requests. It have bootstrap file which is decied which controller will call. With (module name) / (folder name) / (Controller class name) with psr-4 stander.  

03 FACTORY PATTERN
The factory Method is using to create class in Magento. We instantiate a class in Magento by calling an appropriate method passing an abstract name repre, jdsenting a class group followed by a class name. Class groups and their appropriate abstractions are declared in our configuration XML files in our module’s /etc/ folder.

04 SINGLETON PATTERN
This is same like factory class abstraction and class groups in Magento, the Singleton pattern is instantiated for Blocks and Classes. It is restricts the instantiate of a class to one object and it is useful to restrict the limited number of connections in a database or limited amount of memory for a particular instance of class.

05 REGISTRY PATTERN
The registry pattern is a pattern that allows any object or data to be available in a public global scope for any resource. All the singleton patterns are stored in the internal registry, a global scoped container for storing data. This pattern is not only for internal use.

06 PROTOTYPE PATTERN
The prototype pattern is used as an extension of the Abstract Factory pattern. It is ensures that an appropriate subclass is instantiated via appropriate types that are assigned to an object.

07 OBJECT POOL PATTERN
The object pool pattern is simply a box with objects so that they don't have to be allocated and destroyed over and over again. It is keeps objects ready for use over and over again instead of re-instantiating them and destroying them once finished. It is a great way to save on memory consumption.

08 ITERATOR PATTERN
The iterator pattern is a design pattern that allows specify an iterator and allow for multiple different sets of data to be passed without changing the underlying structure that allows the iteration. In Magento, this is handled by the Varien_Data_Collection which turn uses various baked-in PHP classes (like Array Iterator) for having a more Object Orient-interface to arrays. This is ensures that model-collections will always have a common API to iterate over without being dependent of the actual models.

09 LAZY LOADING PATTERN
The lazy Loading is a design pattern that delays the loading of an object until the time that the object is called upon. They don’t utilize with objects with Magento.

10 SERVICE LOCATOR PATTERN
The service locator pattern is a design pattern that allows a user to get a service by encapsulating the process inside an abstraction layer. This is allows the user to retrieve the appropriate or best services without knowing what that service is at runtime.

11 MODULE PATTERN
The module pattern is basically defines that different domains are grouped into separate modules which function independent of each other and can be plugged-in to the main system as deemed appropriate. It is a form of modular programming that emphasizes the grouping of functionality of a program into independent, inter-changeable modules.

12 OBSERVER PATTERN
The observer pattern is set a certain point during an application’s execution. Other components of the application can "hook" into the event listener and execute their code during this point. Magento has its event-driven architecture and it is a result of an implementation of the observer pattern.

THERE ARE SOME ADDITIONAL DESIGN PATTERNS TO USE IN MAGENTO 2

01 SERVICE CONTRACT DESIGN PATTERN
Magento is an extension based system, which allows a third-party modules, which developer to customize and overwrite on the core parts of its framework. These customization may have many several issues, thus to overcome Magento comes up with service contract pattern. It is a set of the interfaces which act as a layers between end users and business layer.

02 OBJECT MANAGER
There is consist of various pattern such as Dependency injection, Singleton, Factory, Abstract Factory, Composite, strategy, CQRS, Decorator and many more. It has a very big role to run, Magento prohibits the direct use of it. Object manager is responsible for the implement singleton, factory and proxy patterns. It is automatically instantiates parameters in class constructors. Before moving future let’s understand about injectable and non-injectable objects.

03 INJECTABLE OBJECTS
They don't have any own identity such as Event Manager, Customer Account Management Service.

04 NON- INJECTABLE OBJECTS
They entities usually have their identities and state, since they have their identities, such as customer, product etc.

05 DEPENDENCY INJECTION
The dependency injection is an alternative to Mage in Magento 1. It is a concepts of injecting the dependent object through external environment rather than creating them internally. Thus we will be using with resource when our object is being created instead of creating resource when needed. This helps in future modification or customization and testing becomes very easy by mocking required objects.

06 FACTORY PATTERN OR FACTORY CLASSES
The factory classes create a layer between the object manager and business code in Magento 2. It is a classes need not define explicitly as they are auto-generated.

07 PROXY PATTERN
The proxy classes are used to work in place of another class and in Magento 2, they are sometimes used in place of resource needed classes. As per Magento uses constructor injection for object creation and when we instantiate an object all the classes. The constructor will also instantiate thus leading to a chaining of instantiation of the constructor. It can really slow down the process and impact on the performance of an application, however to stop chain instantiation Magento uses proxy classes.

Mysql create user and privileges assign.

 Remove privileges

REVOKE ALL PRIVILEGES ON aws_oxtoolstaging.* FROM 'aws_oxtoolstaging'@'localhost';



Assign privileges

CREATE USER 'username'@'localhost' IDENTIFIED BY 'S1@gingin';

GRANT ALL PRIVILEGES ON databases . * TO 'username'@'localhost';


show privileges

show grants for 'username'@'localhost';

magento 2 how to disable inventory modules.

please look below link it would help. to disable MSI module

 https://meetanshi.com/blog/disable-magento-msi/

Product saleable qty not showing and update in magento 2.x

 I have same issue with resolved, take inventory_source_item table backup first.

Run sql query:

INSERT IGNORE INTO `inventory_source_item` (source_code, sku, quantity, status)
select 'default', sku, qty, stock_status from (`cataloginventory_stock_status` as `lg` join `catalog_product_entity` as `prd` on((`lg`.`product_id` = `prd`.`entity_id`)))

Apply command:

php bin/magento indexer:reindex

php bin/magento cache:flush

How To Install PHP 7.4 / 7.3 / 7.2 on Ubuntu 18.04 / Ubuntu 16.04

 PHP is an open-source programming language widely used for web development. It is an HTML-embedded scripting language for building dynamic web sites.

By default, Ubuntu 18.04 and Ubuntu 16.04 ships PHP v7.2 (EOL) and PHP v7.0 (EOL), respectively.

In this post, we will see how to install PHP 7.4 / 7.3 / 7.2 on Ubuntu 18.04 / Ubuntu 16.04.

Add PHP Repository

OndÅ™ej Surý, a third-party repository, hosted on the launchpad, which offers PHP 7.4 / 7.3 / 7.2 for Ubuntu operating system.

Update the repository cache.

sudo apt update

Install the below packages.

sudo apt install -y curl wget gnupg2 ca-certificates lsb-release apt-transport-https

Add the repository to your system.

sudo apt-add-repository ppa:ondrej/php

Update the repository index.

sudo apt update

Install PHP

Install PHP 7.4 on Ubuntu 18.04 / Ubuntu 16.04

Install PHP 7.4 with the below command.

sudo apt install -y php7.4 php7.4-cli php7.4-common

Install PHP 7.3 on Ubuntu 18.04 / Ubuntu 16.04

Install PHP 7.3 with the below command.

sudo apt install -y php7.3 php7.3-cli php7.3-common

Install PHP 7.2 on Ubuntu 18.04 / Ubuntu 16.04

Install PHP 7.2 with the below command.

sudo apt install -y php7.2 php7.2-cli php7.2-common
You can also have multiple PHP versions on your system. Each PHP version will have separate configuration files under /etc/php/7.X directory.

Verify PHP Version

Once you have installed the PHP package, check its version.

php -v

Output:

PHP 7.4.5 (cli) (built: Apr 19 2020 07:36:30) ( NTS )
Copyright (c) The PHP Group
Zend Engine v3.4.0, Copyright (c) Zend Technologies
    with Zend OPcache v7.4.5, Copyright (c), by Zend Technologies

PHP Support for Web Server

Both Apache and Nginx do not support the processing of PHP files by default when the browser requests the PHP page. So, we need to install the PHP package on the server to support PHP files.

PHP Support for Apache

You can install a below package with Apache webserver to support PHP for the LAMP stack. This package provides the PHP modules for Apache 2 web server.

ADVERTISEMENT

READ: How To Install LAMP Stack on Ubuntu 18.04 / Ubuntu 16.04

Change PHP version, if required

sudo apt install -y apache2 libapache2-mod-php7.4

PHP Support for Ngnix

Nginx does not have a PHP modules package to support PHP for the LEMP stack. To have PHP support for Nginx, we can use the PHP FastCGI Process Manager to handle PHP requests.

READ: How To Install LEMP Stack on Ubuntu 18.04 / Ubuntu 16.04

Change PHP version, if required

sudo apt install -y php7.4-fpm

PHP-FPM listens on the socket run/php/php7.4-fpm.sock by default.

To make PHP-FPM use TCP connection, edit the below file.

sudo nano /etc/php/7.4/fpm/pool.d/www.conf

Then, change the listen parameter.

FROM:

listen = /run/php/php7.4-fpm.sock

TO:

listen = 127.0.0.1:9000

Add socket details in Nginx virtual host.

server {

# other codes

  location ~* \.php$ {
    fastcgi_pass    127.0.0.1:9000;
    include         fastcgi_params;
    fastcgi_param   SCRIPT_FILENAME    $document_root$fastcgi_script_name;
    fastcgi_param   SCRIPT_NAME        $fastcgi_script_name;
  }
}

Install PHP Extensions

PHP extensions enable specific functions/support for your code. For example, installing PHP MySQL extension will let your PHP code to connect with the MySQL database.

PHP extensions package is normally named like php<version>-<extn_name>.

To install MySQL support for PHP v7.4, you can install a php7.4-mysql package.

sudo apt install -y php7.4-mysql

Once you have installed a required extension, use the below command to verify it.

php -m | grep -i mysql

Output:

mysqli
mysqlnd
pdo_mysql

PHP Extensions for CMS

PHP Extensions for WordPress

The following extensions are required to install and run WordPress on Ubuntu. WordPress recommends having PHP v7.3 for the installation.

sudo apt install -y php7.3-mysql php7.3-dom php7.3-simplexml php7.3-ssh2 php7.3-xml php7.3-xmlreader php7.3-curl  php7.3-exif  php7.3-ftp php7.3-gd  php7.3-iconv php7.3-imagick php7.3-json  php7.3-mbstring php7.3-posix php7.3-sockets php7.3-tokenizer

PHP Extensions for Joomla

The following extensions are required to install and run Joomla on Ubuntu. Joomla requires PHP v7.1 and above.

sudo apt install -y php7.3-mysql php7.3-xml php-pear php7.3-json

PHP Extensions for Drupal

The following extensions are required to install and run Drupal on Ubuntu. Drupal requires PHP v7.1 and above.

sudo apt install -y php7.3-mysql php7.3-dom php7.3-gd php7.3-json php7.3-pdo php7.3-simplexml php7.3-tokenizer php7.3-xml

How to check if Magento is running in production mode or developer mode

If you want to know. your Magento 2 website is running on which environment you can run below command on terminal and very easily you can kn...

Popular Posts

Posts