Giter Site home page Giter Site logo

gonreyna85code / php Goto Github PK

View Code? Open in Web Editor NEW

This project forked from vercel-community/php

0.0 0.0 0.0 109.61 MB

🐘 PHP Runtime for β–² Vercel Serverless Functions

Home Page: https://php.vercel.app

License: MIT License

JavaScript 9.60% PHP 18.61% TypeScript 70.71% Hack 0.02% Makefile 0.95% HTML 0.11%

php's Introduction

PHP Runtime for Vercel

Enjoyable & powerful 🐘 PHP Runtime (php.vercel.app) for Vercel platform.

πŸ‹οΈβ€β™€οΈ It works with these frameworks and tools. Discover more at examples.

Made with ❀️ by @f3l1x (f3l1x.io) β€’ 🐦 @xf3l1x


😎 Getting Started

Let's picture you want to deploy your awesome microproject written in PHP and you don't know where. You have found Vercel it's awesome, but for static sites. Not anymore! I would like to introduce you your new best friend vercel-php, PHP runtime for Vercel platform.

Most simple example project is this one, using following project structure.

project
β”œβ”€β”€ api
β”‚   └── index.php
└── vercel.json

First file api/index.php is entrypoint of our application. It should be placed in api folder, it's very standard location for Vercel.

<?php
phpinfo();

Second file vercel.json is pure gold here. Setup your project with configuration like this and voila. That's all.

{
  "functions": {
    "api/*.php": {
      "runtime": "[email protected]"
    }
  }
}

Last thing you have to do is call vercel. If you are more interested take a look at features and usage.

# Install it globally
npm i -g vercel

# Log in
vercel login

# Let's fly
vercel

Are you ready to deploy your first PHP project to Vercel? Click & Go!

πŸ€— Features

  • Architecture: PHP development server (πŸš€ fast enough)
  • PHP version: 8.1.4
  • Extensions: apcu, bcmath, brotli, bz2, calendar, Core, ctype, curl, date, dom, ds, exif, fileinfo, filter, ftp, geoip, gettext, hash, iconv, igbinary, imap, intl, json, libxml, lua, mbstring, mongodb, msgpack, mysqli, mysqlnd, openssl, pcntl, pcre, PDO, pdo_mysql, pdo_pgsql, pdo_sqlite, pgsql, phalcon, Phar, protobuf, readline, redis, Reflection, runkit7, session, SimpleXML, soap, sockets, sodium, SPL, sqlite3, standard, swoole, timecop, tokenizer, uuid, xml, xmlreader, xmlrpc, xmlwriter, xsl, Zend OPcache, zlib, zip
  • Speed: cold ~250ms / warm ~5ms
  • Memory: ~90mb
  • Frameworks: Nette, Symfony, Lumen, Slim, Phalcon

List of all installable extensions is on this page https://blog.remirepo.net/pages/PECL-extensions-RPM-status.

πŸ’― Versions

βš™οΈ Usage

Before you can start using this runtime, you should learn about Vercel and how runtimes works. Take a look at blogpost about Serverless Functions.

You should define functions property in vercel.json and list PHP files directly or using wildcard (*). If you need to route everything to index, use routes property.

{
  "functions": {
    "api/*.php": {
      "runtime": "[email protected]"
    }
  },
  "routes": [
    { "src": "/(.*)",  "dest": "/api/index.php" }
  ]
}

Do you have more questions (❓)? Let's move to FAQ.

πŸ‘¨β€πŸ’» vercel dev

For running vercel dev properly, you need to have PHP installed on your computer, learn more. But it's PHP and as you know PHP has built-in development server. It works out of box.

php -S localhost:8000 api/index.php

πŸ‘€ Demo

PHP

🎯Examples

Browse more examples. πŸ‘€

πŸ“œ Resources

🚧 Roadmap

See roadmap issue. Help wanted.

⁉️ FAQ

1. How to use more then one endpoint (index.php)?
project
β”œβ”€β”€ api
β”‚   β”œβ”€β”€ index.php
β”‚   β”œβ”€β”€ users.php
β”‚   └── books.php
└── vercel.json
{
  "functions": {
    "api/*.php": {
      "runtime": "[email protected]"
    },

    // Can be list also directly

    "api/index.php": {
      "runtime": "[email protected]"
    },
    "api/users.php": {
      "runtime": "[email protected]"
    },
    "api/books.php": {
      "runtime": "[email protected]"
    }
  }
}
2. How to route everything to index?
{
  "functions": {
    "api/index.php": {
      "runtime": "[email protected]"
    }
  },
  "routes": [
    { "src": "/(.*)",  "dest": "/api/index.php" }
  ]
}
3. How to update memory limit?

Additional function properties are memory, maxDuration. Learn more about functions.

{
  "functions": {
    "api/*.php": {
      "runtime": "[email protected]",
      "memory": 3008,
      "maxDuration": 60
    }
  }
}
4. How to use it with Composer?

Yes, Composer is fully supported.

project
β”œβ”€β”€ api
β”‚   └── index.php
β”œβ”€β”€ composer.json
└── vercel.json
{
  "functions": {
    "api/*.php": {
      "runtime": "[email protected]"
    }
  }
}
{
  "require": {
    "php": "^8.1",
    "tracy/tracy": "^2.0"
  }
}

It's also good thing to create .vercelignore file and put /vendor folder to this file. It will not upload /vendor folder to Vercel platform.

5. How to override php.ini / php configuration ?

Yes, you can override php configuration. Take a look at default configuration at first. Create a new file api/php.ini and place there your configuration. Don't worry, this particulary file will be removed during building phase on Vercel.

project
β”œβ”€β”€ api
β”‚   β”œβ”€β”€ index.php
β”‚   └── php.ini
└── vercel.json
{
  "functions": {
    "api/*.php": {
      "runtime": "[email protected]"
    }
  }
}
# Disable some functions
disable_functions = "exec, system"

# Update memory limit
memory_limit=1024M
6. How to exclude some files or folders ?

Runtimes support excluding some files or folders, take a look at doc.

{
  "functions": {
  "api/**/*.php": {
    "runtime": "[email protected]",
    "excludeFiles": "{foo/**,bar/config/*.yaml}",
  }
}

If you want to exclude files before uploading them to Vercel, use .vercelignore file.

7. How to call composer script(s) ?

Calling composer scripts during build phase on Vercel is supported via script named vercel. You can easilly call php, npm or node.

{
  "require": { ... },
  "require-dev": { ... },
  "scripts": {
    "vercel": [
      "@php -v",
      "npm -v"
    ]
  }
}

Files created during composer run vercel script can be used (require/include) in your PHP lambdas, but can't be accessed from browser (like assets). If you still want to access them, create fake assets.php lambda and require them. Example of PHP satis.

8. How to include some files of folders?

If you are looking for config.includeFiles in runtime, unfortunately you can't include extra files. All files in root folder are uploaded to Vercel, use .vercelignore to exclude them before upload.

9. How to develop locally?

I think the best way at this moment is use PHP Development Server.

php -S localhost:8000 api/index.php

πŸ‘¨πŸ»β€πŸ’»CHANGELOG

Show me CHANGELOG

πŸ§™Contribution

  1. Clone this repository.
  2. Install NPM dependencies
    • make install
  3. Make your changes
  4. Run TypeScript compiler
    • make build
  5. Run tests
    • make test
  6. Create a PR

πŸ“ License

Copyright Β© 2019 f3l1x. This project is MIT licensed.

php's People

Contributors

f3l1x avatar dependabot[bot] avatar ties-v avatar dominikvisek avatar styfle avatar agdholo avatar andybitz avatar nettum avatar tootallnate avatar robertdrakedennis avatar tuckerwhitehouse avatar eiriksm avatar itsgoingd 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.