/appwrite

End to end backend server for frontend and mobile developers. ๐Ÿ‘ฉโ€๐Ÿ’ป๐Ÿ‘จโ€๐Ÿ’ป

Primary LanguageJavaScriptBSD 3-Clause "New" or "Revised" LicenseBSD-3-Clause

Appwrite Logo

Simple Backend Server for your [Vue / Angular / React / iOS / Android / Flutter / *ANY OTHER*] Frontend App

Docker Pulls Chat With Us Build Status Follow  Appwrite on StackShare Follow new releases


Appwrite is a simple self-hosted backend server for web and mobile developers with a shiny dashboard and a very easy to use REST API.

Appwrite API services aim to make developer's life a lot easier by hiding the complexity of common and repetitive software development tasks.

Using Appwrite you can easily manage user authentication with multiple sign-in methods, a database for storing and querying user and teams data, storage and file management, image manipulation and cropping, scheduled cron tasks and many other features to help you get more results in faster times and with a lot less code.

https://appwrite.io

Appwrite

Installation

Appwrite backend server is designed to run in a container environment. Running your server is as easy as running one command from your terminal. You can either run Appwrite on your localhost using docker-compose or on any other container orchestration tool like Kubernetes, Docker Swarm or Rancher.

The easiest way to start running your Appwrite server is by running our docker-compose file:

mkdir appwrite-ce && \
cd appwrite-ce && \
curl -o docker-compose.yml https://appwrite.io/docker-compose.yml?version=0.2.0 && \
docker-compose up -d --remove-orphans

Once the Docker installation completes, go to http://localhost to access the Appwrite console from your browser. Please notice that on non-linux native hosts, the server might take a few minutes to start after installation completes.

For advanced, production and custom installation, check out our Docker environment variables docs.

Changing Port Number

In case your port 80 is already taken, change the port number in the command above. Make sure to set the correct endpoint in your selected SDK, including your new port number.

Getting Started

Getting started with Appwrite is as easy as creating a new project, choosing your platform and integrating its SDK in your code. You can easily get started with your platform of choice by reading one of our Getting Started tutorials.

Services

  • Auth - Manage user authentication using multiple sign-in methods and account recovery.
  • Account - Manage current user account. Track and manage the user sessions, devices, and security audit log.
  • Users - Manage and list all project users when in admin mode.
  • Teams - Manage and group users in teams. Manage memberships, invites and user roles within a team.
  • Database - Manage database collections and documents. Read, create, update and delete documents and filter lists of documents collections using an advanced filter with graph-like capabilities.
  • Storage - Manage storage files. Read, create, delete and preview files. Manipulate the preview of your files to fit your app perfectly. All files are scanned by ClamAV and stored in a secure and encrypted way.
  • Locale - Track user's location, and manage your app locale-based data.
  • Avatars - Manage your users' avatars, countries' flags, browser icons, credit card symbols and generate QR codes.

For the complete API documentation, visit https://appwrite.io/docs. For more tutorials, news and announcements check out our blog.

SDKs

Currently, we are supporting only a few SDK libraries and are constantly working on including new ones.

Below is a list of currently supported platforms and languages. If you wish to help us add support to your platform of choice, you can go over to our SDK Generator project and view our contribution guide.

  • โœ… JS (Maintained by the Appwrite Team)
  • โœ… PHP (Maintained by the Appwrite Team)
  • โœ… NodeJS (Maintained by the Appwrite Team)
  • โœ… Ruby - Work in progress (Maintained by the Appwrite Team)
  • โœ… Python - Work in progress (Maintained by the Appwrite Team)
  • โœณ๏ธ Looking for more SDKs? - Help us by contributing a pull request to our SDK Generator!

Security

For security issues, kindly email us security@appwrite.io instead of posting a public issue in GitHub.

Follow Us

Join our growing community around the world! Follow us on Twitter, Facebook Page, Facebook Group or join our live Gitter community for more help, ideas, and discussions.

Contributing

All code contributions - including those of people having commit access - must go through a pull request and approved by a core developer before being merged. This is to ensure proper review of all the code.

We truly โค๏ธ pull requests! If you wish to help, you can learn more about how you can contribute to this project in the contribution guide.

Credits

Created by Eldad Fux with the amazing help of our amazing contributors:

  • ๐Ÿ‡บ๐Ÿ‡ธ Justin Dorfman (GitHub, Twitter)
  • ๐Ÿ‡บ๐Ÿ‡ณ 0xflotus (GitHub)
  • ๐Ÿ‡ณ๐Ÿ‡ด Petter Charles Redfern (GitHub)
  • ๐Ÿ‡ง๐Ÿ‡ท Jessรฉ Souza (GitHub)
  • ๐Ÿ‡ช๐Ÿ‡ธ Esther รlvarez Feijoo (GitHub)
  • ๐Ÿ‡ฎ๐Ÿ‡ณ Christy Jacob (GitHub, LinkedIn)
  • ๐Ÿ‡บ๐Ÿ‡ฆ Dmitriy Danilov (GitHub, Twitter)
  • ๐Ÿ‡ฎ๐Ÿ‡ฉ Zeet (GitHub)
  • ๐Ÿ‡ซ๐Ÿ‡ฎ Pessi Pรคivรคrinne (GitHub)
  • ๐Ÿ‡บ๐Ÿ‡ณ Sergi Vos (GitHub, Twitter, LinkedIn)
  • ๐Ÿ‡ฎ๐Ÿ‡ฑ Tomer Cohen (GitHub, Twitter)
  • ๐Ÿ‡ฎ๐Ÿ‡น Tatiana (GitHub)
  • ๐Ÿ‡ฌ๐Ÿ‡ท Panagiotis Skarlas (GitHub, Twitter)
  • ๐Ÿ‡ท๐Ÿ‡บ Alexey Pyltsyn (GitHub)
  • ๐Ÿ‡ฉ๐Ÿ‡ช Robin C (GitHub)
  • ๐Ÿ‡ฎ๐Ÿ‡ณ Parikshit Hooda (GitHub)
  • ๐Ÿ‡ซ๐Ÿ‡ท Corentin Le Fur (GitHub)
  • ๐Ÿ‡ฌ๐Ÿ‡ง Callum Lowry (GitHub)
  • ๐Ÿ‡ท๐Ÿ‡ด Bogdan Covrig (GitHub, Twitter)
  • ๐Ÿ‡ณ๐Ÿ‡ฑ Kolkies (GitHub)
  • ๐Ÿ‡น๐Ÿ‡ท Mustafa Dur (GitHub)
  • ๐Ÿ‡ต๐Ÿ‡น Luรญs Pinto (GitHub)
  • ๐Ÿ‡ฎ๐Ÿ‡ณ Saksham Saxena (GitHub)
  • ๐Ÿ‡ฎ๐Ÿ‡ฑ Dima Vishnevetsky (GitHub, Twitter)
  • ๐Ÿ‡ญ๐Ÿ‡บ lacexd (GitHub)