1
0
Fork 0
mirror of synced 2024-04-27 17:42:17 +12:00
Go to file
2022-01-16 18:37:32 +02:00
.github fix: disable github action 2022-01-04 17:02:23 +01:00
.travis-ci fix: update geo db to dec-21 2021-12-28 13:37:03 +01:00
app set proper domain name while setting cookie in mock api 2022-01-11 17:15:29 +05:45
bin Added spec generator CLI command, remove old HTTP endpoint 2022-01-01 14:07:11 +02:00
dev properly setup debugger for everyone and contribution guide 2021-07-11 17:20:03 +05:45
docs fix: sdks 2022-01-07 14:32:03 +01:00
public Added sum to request, added format to realtime 2022-01-07 11:15:20 +01:00
src/Appwrite Merge branch 'master' of https://github.com/appwrite/appwrite into feat-release-0-12-1 2022-01-07 13:58:44 +01:00
tests Merge pull request #2552 from appwrite/feat-enable-travis-again 2022-01-04 17:02:47 +01:00
.dockerignore add buildstep to docker 2021-10-21 19:20:41 +02:00
.env fix: replace internal and external database with project database 2021-12-27 13:45:23 +01:00
.gitattributes fix(git): .gitattributes syntax 2021-12-01 16:41:56 +01:00
.gitignore fix: .gitignore 2022-01-04 17:12:42 +01:00
.travis.yml fix: remove logs from travis job 2022-01-04 17:25:11 +01:00
CHANGES.md Update CHANGES.md 2022-01-07 14:38:10 +01:00
CODE_OF_CONDUCT.md Fixed Grammer and Typo 2019-10-02 15:15:34 +05:30
composer.json fix: sdks 2022-01-07 14:32:03 +01:00
composer.lock fix: sdks 2022-01-07 14:32:03 +01:00
CONTRIBUTING.md sdk generating check list 2022-01-04 20:27:31 +05:45
docker-compose.yml Fixed usage entrypoint in dev mode 2022-01-16 18:37:32 +02:00
Dockerfile Added spec generator CLI command, remove old HTTP endpoint 2022-01-01 14:07:11 +02:00
gulpfile.js Merge branch 'master' of https://github.com/appwrite/appwrite into feat-db-main-rebase 2021-12-01 14:19:41 +01:00
LICENSE Updated LICENSE 2019-05-12 08:00:06 +03:00
package-lock.json chore: update package.json 2021-12-31 15:54:59 +01:00
package.json chore: update package.json 2021-12-31 15:54:59 +01:00
phpunit.xml fix: tests 2022-01-04 16:50:48 +01:00
psalm.xml Feat psalm analysis (#699) 2020-10-27 02:08:29 +02:00
README.md Merge branch 'master' of https://github.com/appwrite/appwrite into feat-release-0-12-1 2022-01-07 13:58:44 +01:00
SECURITY.md Merge branch 'master' into patch-3 2020-10-12 08:57:24 +03:00


Appwrite Logo

A complete backend solution for your [Flutter / Vue / Angular / React / iOS / Android / *ANY OTHER*] app

Discord Docker Pulls Build Status Twitter Account Translate Swag Store

Appwrite 0.12 has been released! Learn what's new!

Appwrite is an end-to-end backend server for Web, Mobile, Native, or Backend apps packaged as a set of Docker microservices. Appwrite abstracts the complexity and repetitiveness required to build a modern backend API from scratch and allows you to build secure apps faster.

Using Appwrite, you can easily integrate your app with user authentication & multiple sign-in methods, a database for storing and querying users and team data, storage and file management, image manipulation, Cloud Functions, and more services.

Appwrite

Find out more at: https://appwrite.io

Table of Contents:

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. Before running the installation command make sure you have Docker installed on your machine:

Unix

docker run -it --rm \
    --volume /var/run/docker.sock:/var/run/docker.sock \
    --volume "$(pwd)"/appwrite:/usr/src/code/appwrite:rw \
    --entrypoint="install" \
    appwrite/appwrite:0.12.1

Windows

CMD

docker run -it --rm ^
    --volume //var/run/docker.sock:/var/run/docker.sock ^
    --volume "%cd%"/appwrite:/usr/src/code/appwrite:rw ^
    --entrypoint="install" ^
    appwrite/appwrite:0.12.1

PowerShell

docker run -it --rm ,
    --volume /var/run/docker.sock:/var/run/docker.sock ,
    --volume ${pwd}/appwrite:/usr/src/code/appwrite:rw ,
    --entrypoint="install" ,
    appwrite/appwrite:0.12.1

Once the Docker installation completes, go to http://localhost to access the Appwrite console from your browser. Please note 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. You can also use our public docker-compose.yml file to manually set up an environment.

Upgrade from an Older Version

If you are upgrading your Appwrite server from an older version, you should use the Appwrite migration tool once your setup is completed. For more information regarding this, check out the Installation Docs.

Getting Started

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

Services

  • Account - Manage current user authentication and account. Track and manage the user sessions, devices, sign-in methods, and security logs.
  • 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 document collections using advanced filters.
  • 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.
  • Functions - Customize your Appwrite server by executing your custom code in a secure, isolated environment. You can trigger your code on any Appwrite system event, manually or using a CRON schedule.
  • Locale - Track your 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 and Discord Server.

SDKs

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.

Client

  •   Web (Maintained by the Appwrite Team)
  •   Flutter (Maintained by the Appwrite Team)
  •   Apple - Beta (Maintained by the Appwrite Team)
  •   Android (Maintained by the Appwrite Team)

Server

  •   NodeJS (Maintained by the Appwrite Team)
  •   PHP (Maintained by the Appwrite Team)
  •   Dart - (Maintained by the Appwrite Team)
  •   Deno - Beta (Maintained by the Appwrite Team)
  •   Ruby (Maintained by the Appwrite Team)
  •   Python (Maintained by the Appwrite Team)
  •   Kotlin - Beta (Maintained by the Appwrite Team)
  •   Apple - Beta (Maintained by the Appwrite Team)
  •   .NET - Experimental (Maintained by the Appwrite Team)

Community

Looking for more SDKs? - Help us by contributing a pull request to our SDK Generator!

Architecture

Appwrite Architecture

Appwrite uses a microservices architecture that was designed for easy scaling and delegation of responsibilities. In addition, Appwrite supports multiple APIs (REST, WebSocket, and GraphQL-soon) to allow you to interact with your resources leveraging your existing knowledge and protocols of choice.

The Appwrite API layer was designed to be extremely fast by leveraging in-memory caching and delegating any heavy-lifting tasks to the Appwrite background workers. The background workers also allow you to precisely control your compute capacity and costs using a message queue to handle the load. You can learn more about our architecture in the contribution guide.

Contributing

All code contributions - including those of people having commit access - must go through a pull request and be approved by a core developer before being merged. This is to ensure a 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.

Security

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

Follow Us

Join our growing community around the world! See our official Blog. Follow us on Twitter, Facebook Page, Facebook Group , Dev Community or join our live Discord server for more help, ideas, and discussions.

License

This repository is available under the BSD 3-Clause License.