- Pin troposphere version and update to 3.x (#1029)
- Relax stage name restrictions when not using apigateway (#993)
- Wait for lambda to become active during deploy/update (#992)
- add support for Python 3.9 (#1026)
- Deprecated ACME v1 for Lets Encrypt
- Global black formatting
- Update & deploy using a docker container
- See blog post for more details on the current functionality and how it works
- See PR or original issue for discussion around what is currently supported & next steps
- Remove dateutil version restriction
- Fix failed downloads of wheel packages with non-alphanumeric characters
- Last release from Miserlou/Zappa
- Removed references to zappa.io
- Lambda Layers
- Cognito support
- Skip venv check if --no_venv argument is passed
- Fix for abi3 filename matching
- Wait for the Load Balancer to become active before proceeding
- Add option 'Scheme' for alb config
- Allow full path exclusions while packaging
- Workaround for werkzeug incompatibility
- And assorted fixes
- Updated manylinux to support manylinux1/manylinux2010/manylinux2014 packages
- Fixed issue with duplicated cookie headers in API Gateway
- Various maintenance updates to the README file
- Remove old python 2.7 code (not all yet)
- Use pip-tools to manage dependencies (and remove pinned dependencies from the package)
- Add option for concurrency limit
- Use safe_load with YAML
- Support for ABI3 binary packages (particularly cryptography)
- Remove dependency on lambda-packages
- Added support for Python 3.8
- Fixed boto3 reporting of long names
- Added support for new AWS Regions
- Minor bug and README fixes
- Last version with Python 2.7 support.
- Fix for invalid values of HTTP_HOST and others (introduced in 0.48.0)
- Fix for an issue where you couldn't update a function if it had been deployed with a version prior to 0.48.0
- Support for private (VPC-only) API Gateway endpoints
- Deprecation of zappa.async because async is a reserved word in 3.7, please use zappa.asynchronous
- Support for Application Load Balancer as an alternative to API Gateway
- Improvements in manylinux wheel downloads
- Support for multi-value query strings
- Python 3.7 support
- Support for multi-value headers
- Support for the new 256kB async limit
- Bunch of small typos, fixes and documentation improvements
- Use Django 2 on tests with python 3
- Stop applying tags on buckets not created by zappa
- Be more forgiving on 504 errors during deployment
- Fix cleanup of DynamoDB table for async tasks
- Detection of invalid bucket names
- Flake8 checks added to tests
- Handle accounts with more than 100 domains in route 53
- Force requests upgrade to 2.20.0 for compatibility with urllib3 1.24
- Allow defining API Gateway policies (including restricting access to one IP address)
- Support for SQS events
- Added test to enforce running of doctoc
- Add support for running django as a WSGI app (for NewRelic and others)
- Updates AWS regions for lambda and API Gateway
- Fix support for gcloud and other packages with slim_handler
- Add --disable-keep-open to zappa tail
- Dependency updates
- Fix pyenv invocation
- Add custom base_path stripping support
- Multiple documentation fixes and improvements
- first iteration of a documented deploy policy
- hotfix for creating virtual environments
- Hotfix for pipenv support (pip >10.0.1)
- Adds AWS GovCloud support!
- Test fix
Okay, I dropped the ball for a long time. Bad BDFL! New releases will come much faster once again
- Pip10 compatibility
- Add support for base path configuration in API gateway custom domain.
- Fix path case sensitivity in get_installed_packages
- Move task decorator async decision from import time to call time.
- Fix documentation error in authorizer stanza of zappa_settings.json.
- Adding explicit UTF-8 encoding for Flask app detection
- Bump lambda packages version
- Fix for work with latest Werkezeug
- Fixed parameter name from 'FunctionNmae' -> 'FunctionName'
- Remove
use
; fixes #1522 - Philippe Trounev is awesome
- fix case sensitivity problem for comparing package location
- isBase64Encoded is a boolean flag instead of string true
- check pip return code as sometimes pypi lookup fails
- Add support to delete old versions of lambda functions.
- Reactor title casing of dict keys into a utility function
- Add
role_arn
settings variable - ..and too many more, check the changelog!
- Make
package_info.json
consistent across Python versions - Fixes to
task_sns
- Add support for SQLite on Python 3.6 (LP bump)
- Add unique package identifier file
- Fixes #1171 don't colorize partial words
- Various small changes
- More robust OpenSSL parsing for LE
- Update applies tags
- Allows deploying and updating from existing S3 package
- Slim handler packaging hotfix - thanks @mcrowson!
- Non-Dynamo asynx hotfix - thanks @jwkvam!
- Packaging hotfix - thank Yunseop!
- Async responses (thanks Sean!)
- Remove setLevel call from common log
- Fix #1023
- Merge #1058, 1059, 1073
- Allow overriding of endpoint_url arg
- Add support for API Gateway stage variables
- Add AWS X-Ray support (thanks @mathom!)
- Events take kwargs (Thanks @mcrowson!)
- Detect P2/3 during
init
- Include stage names in
slim_handler
zips - Allow
-s
withmanage
- Use same S3 bucket for global endpoints
- Fix bug with mixed-case packages
- Cache wheels, fix 0-byte wheels
- Add index prefix to each subsequent schedule expression for the same event (#1051)
- fix/Only update CORS on resources which have an OPTIONS method (#1036)
- Support for binary support and cors simultaneously (#1011)
- Set Flask script name based on domain which the request was made to (#1015)
- Fix SNS Async (#1055)
- GZip for slim handler
- Force color option
- Various dep bumps
- Fixes #1001, don't override AWS env vars if k:v not set. Thanks Nik and Sean!
- Checks for the key 'Environment' when fetching remote lambda env vars (#988)
- except BotoCoreError before general exception in zappa.cli.update
- make cookie hack case-insensitive
- Fix #998 - Make environment variable keys strings instead of byte arrays in python 3.6
- Add --disable_progress command line parameter
- #946 - Allow setting cors to false.
- #870 Lambda from outside
- Implement context header mappings - Feature Request Issue #939
- Separating out native AWS environment variables ##962
- Rule name shortening
- Splintering aws_environment_variables from environment_variables (to avoid overwriting AWS native env vars).
- Add exclude for pycache contents (#943)
- Fix #937 - Use get_data
- Add support for configuring APIGW cache TTL and encryption #942
- Addressing #909: Don't load credentials for 'package' command
- Small fixes for #918, #922, #803, #802, #799, #888, #903, #893, #828, #874, and others.
- Support for manylinux wheels Python 3.6 package downloading.
- Py3
certify
fixes. - Add support for multiple expressions when scheduling
- Fix content-type headers not passing through on DELETE
- Avoid creating init.py in a directory next to a module (.py file) with the same name
- Check recursively if there is any .py{,c} file in a directory before creating init.py
- Fix SNS event tasks
- Bump lambda-packages
- Cached manylinux wheel installed
- New dependency installation formatting
- Clarify "stage" vs "environment" terminology in code
- Fix problem with capitalized packages
- Delete local package if using wheels version. This saves several MBs on package size in some cases (e.g. numpy).
- Thanks to @mcrowson, @nikbora and @schuyler1d
- Various Python3 fixes
- Remove some dead code
- More binary package fixes thanks to and @nikbora and @bxm156
- Improved async tasks thanks to @schuyler1d
- Various small changes
- Support for new
lambda-packages
format (Python3 support) - Fix
setup.py
on Windows Python3 - Fix #818 - python3 import for LE
- Support AWS-specific environment variables (with KMS)
- Add
template
command - Add
--json
in more places - Add
--output
to package - Support for manylinux wheels Python 3.6 package downloading #803 from nikbora
- Fix PyEnv exit code #799
- Add Python3 Support! #793, #6
- Deprecate
lets_encrypt_expression
- Refactor a bunch of stuff to work with Python3 package restrictions >:[
- #776 fix for libmysqlclient.so.18 error when using
slim_handler
- add profile and region detection to init - thanks @pdpol
- #774 Wsgi environment improvements (Fix untrustworthy remote_addr)
- Only create
__init__.py
file if there are python files or sub dirs in the folder - Update docs to reflect lambda name prepended to role_name
- Guard log responses (thanks @scoates)
- Add Async Task Support! Lots of tickets and PRs related, including #61, #603, #694 and #732.
- More info here: https://blog.zappa.io/posts/zappa-introduces-seamless-asynchronous-task-execution
- Fix Django non-WSGI function initialization, #748
- Add support for AWS Lambda Dead Letter Queue, #740
- Fix API Gateway test button (the bolt button), #735
- Switch to using per-lambda-name (project-stage) rather than a single default LambdaExecutionRole
- Fix broken Let's Encrypt trying to use new ACM ARNs
- Add
apigateway_description
setting, fixes #722 - More aggressive virtualenvironment checking
- Add
certificate_arn
setting, support for AWS Certificate Manager (#710) - Fix zip permissions when building on Windows (#714)
- Change the active working directory to
/tmp
when using the slim handler so that relative filepaths work. (#711)
- Hotfix for broken Django deploys
- Add confirm to
certify
- Add
--manual
to--certify
- Fix
certify
for existing domains - Add
extra_permissions
setting - Add
shell
command
- Revert to Kappa 0.6.0 #684 and others
- Add binary support for more HTTP methods, #696
- Add binary upload support, fix #683
- Add support for custom, non-Let's Encrypt certificates, thanks to Benjamin Congdon
- Change default permissions to allow executable binaries, #682
- Fix binary support for Django POST, #677
- Remove Kappa 0.6 specific hack
- Bring back '-' substitution
- Add automatic support for serving binary files! Via @wobeng, closes #481
- Fixes
rollback
default back to 1 from 0, #673 - Ensure correct chmodding during package creation, #484
- Update regions that Zappa supports, #667
- Validate function names based on actual gateway rules #521
- Fix unschedule events with trimmed names #662
- Fix a few places where
extends
wasn't respectingstage_config
, #655 - Begin to remove some dead code
- Dependency bumps
- Adds
--non-http
totail
- Fix 64bit
lambda-packages
(#645) - Fix wheel packages (#642)
- Replace ZappaCookie with Set-Cookie permutation! :D (#636)
- Bump
lambda-packages
version - Fix installed_packages_name_set (#637)
- Add
slim_handler
(#548) - Various small requirements bumps and other fixes.
- Adds
--since
and--filter
totail
- Fixes
unschedule
command when used with specific stage
- Adds
package
command - Forbids the use of unicode environment variable keys
- Initialize wsgi.errors to sys.stderr (was '')
- Accept
AWS_SESSION_TOKEN
when executing via an IAM role (#589) - Set
REMOTE_USER
even when usingiam_authorization
- Rename
lets_encrypt_schedule
tolets_encrypt_expression
(#571) - Messages in
tail
are now sequential - Bump version requirements, update README
- Various other small changes
- File
tail
broken in CLI refactor
- Add Cognito Authorizers
- Refactor CLI, add Bash Completion
- Improve manylinux wheels
- Varios fixes and req bumps
- Adds the
cors
feature, big thanks to @AusIV! - Adds support for
-e
eggs, thanks to @schuyler1d and @xuru! - Adds support for YAML settings files. Eat up, hipsters.
- Add
--http
filter totail
- Prefer
apigateway_enabled
but still respectuse_apigateway
, #493
- Adds colors to
zappa tail
output, fixes #492 - Adds
--no-color
CLI argument - Adds fatal warning for bad
app_function
s, fixes #485.
- Fix S3 broken S3 events
- Move
use_apigateway
toapigateway_enabled
- Fixes progress bar error for manylinux packages
- Safely handle freezes when downloading from PyPI
- Adds
s3://
syntax for remote env files. (#478, thanks @Leandr!)
- Adds
extends
syntax to settings file. - Fixes Django migrations, #464
- Adds support for manylinux wheels! #398
- Fixes multiple events in
status
command - Fixes support for
certify
on apex domains, #451
- Filter private hosted zones to avoid conflicts while certifying
- Fix small Python3 bug (#457)
- Fix for #453 (windows os.path)
- Re-raise Zappa exception with full traceback
- Skip pyc on django migrations, fixes #436
- Delete correct domain name, #448
- added region and lambda name to not deployed error
- Add "global" mode to init. Expect a blog post soon!
- Small refactors and dependency upgrades.
--json
for machine readable status output--all
for global deployment prep- Better exit code handling
- Get AWS region from profile if not set in zappa_settings.json
- Fix broken Django management command invocation
- Add Kinesis permission
- Add capability to specify authoriser arn
- Various refactors and small fixes
- Bump lambda-packages
- Fix new Django unicode problems (#397)
- Ensure env vars are strings via @scoates
- Fix #382
- Remove many hacks using new API Gateway features.
- Closes #303, #363, #361
- See the blog post for more details!
- Bump dependencies - make sure you reinstall your requirements!
- Improved stack update handling.
- Warn on namespace collisions.
- Bump lambda-packages version.
- Use simplified API Gateway configuration, via @koriaf.
- Add better support for
use_apigateway
without any supplied app function. Reported by @mguidone. - Truncate illegally long event functions names. Reported by @mguidone.
- Remove 'boto' from default excludes. #333, thanks Claude!
- Don't allow invalid API Gateway characters in the config. Thanks @scoates!
- Better respect for
use_apigateway
inupdate
command. - Avoids hang with API Gateway limit reached.
- Fix DynamoDB/Kinesis event sources, add docs. Big thanks Claude!
-
Add ability to invoke raw python strings, like so:
zappa invoke dev "print 1+2+3" --raw
-
Fixes multi-argument
manage
commands. -
Updated related documentation.
-
Fixes places where program was exiting with status 0 instead of -1. Thanks @mattc!
-
Adds old-to-new-style check on delete, thanks @mathom.
- Fix a problem from trying to
update
old-style API routes using new Tropo code. Ensurestouch
works as intended again. Fix by @mathom.
- Add a helpful failure warning for users without permissions to automatically manage execution roles.
- Fix potential div by zero error in new Tropo code.
- Use Troposphere/CloudFormation to create API Gateway routes
- Thanks, @mathom!
zappa update
now updates changes to API Gateway routes- Redirect HTML content injection is fixed
- Redirect HTML content injection now only happens for 'text/html' content types. This is a partial solution to #303.
- Added CHANGELOG.md
- Didn't keep a changelog
- Sorry!
- Read the commit log :)