base on Distributed server for social and realtime games and apps. ![Nakama](.github/logo.png?raw=true "Nakama logo") ====== [![GitHub release](https://img.shields.io/github/release/heroiclabs/nakama.svg)](https://heroiclabs.com/docs/nakama/getting-started/install/) [![Forum](https://img.shields.io/badge/forum-online-success.svg)](https://forum.heroiclabs.com) [![License](https://img.shields.io/github/license/heroiclabs/nakama.svg)](https://github.com/heroiclabs/nakama/blob/master/LICENSE) > Distributed server for social and realtime games and apps. ## Features * **Users** - Register/login new users via social networks, email, or device ID. * **Storage** - Store user records, settings, and other objects in collections. * **Social** - Users can connect with friends, and join groups. Builtin social graph to see how users can be connected. * **Chat** - 1-on-1, group, and global chat between users. Persist messages for chat history. * **Multiplayer** - Realtime, or turn-based active and passive multiplayer. * **Leaderboards** - Dynamic, seasonal, get top members, or members around a user. Have as many as you need. * **Tournaments** - Invite players to compete together over prizes. Link many together to create leagues. * **Parties** - Add team play to a game. Users can form a party and communicate with party members. * **Purchase Validation** - Validate in-app purchases and subscriptions. * **In-App Notifications** - Send messages and notifications to connected client sockets. * **Runtime code** - Extend the server with custom logic written in Lua, TypeScript/JavaScript, or native Go code. * **Matchmaker**, **dashboard**, **metrics**, and [more](https://heroiclabs.com/docs). Build scalable games and apps with a production ready server used by ambitious game studios and app developers [all around the world](https://heroiclabs.com/customers/). Have a look at the [documentation](https://heroiclabs.com/docs) and join the [developer community](https://forum.heroiclabs.com) for more info. ## Getting Started The server is simple to setup and run for local development and can be deployed to any cloud provider. See the [deployment notes](#deployment) for recommendations on how to deploy the project for production. Nakama server requires CockroachDB or another Postgres wire-compatible server as it's database. ### Docker <a href="https://heroiclabs.com/docs/install-docker-quickstart/"><img src="https://upload.wikimedia.org/wikipedia/commons/7/79/Docker_%28container_engine%29_logo.png" width="170"></a> The fastest way to run the server and the database is with Docker. Setup Docker and start the daemon. 1. Set up a [docker-compose file](https://heroiclabs.com/docs/nakama/getting-started/install/docker/#running-nakama) and place it in a folder for your project. 2. Run `docker-compose -f ./docker-compose.yml up` to download container images and run the servers. For more detailed instructions have a look at our [Docker quickstart](https://heroiclabs.com/docs/nakama/getting-started/install/docker) guide. Nakama Docker images are maintained on [Docker Hub](https://hub.docker.com/r/heroiclabs/nakama/tags) and [prerelease](https://hub.docker.com/r/heroiclabs/nakama-prerelease/tags) images are occasionally published for cutting edge features of the server. ### Binaries You can run the servers with native binaries for your platform. 1. Download the server from our [releases](https://github.com/heroiclabs/nakama/releases) page and the [database](https://www.cockroachlabs.com/docs/stable/install-cockroachdb.html). 2. Follow the database [instructions](https://www.cockroachlabs.com/docs/stable/start-a-local-cluster.html#before-you-begin) to start it. 3. Run a migration which will setup or upgrade the database schema: ```shell nakama migrate up --database.address "root@127.0.0.1:26257" ``` 4. Start Nakama and connect to the database: ```shell nakama --database.address "root@127.0.0.1:26257" ``` When connected you'll see server output which describes all settings the server uses for [configuration](https://heroiclabs.com/docs/nakama/getting-started/configuration). > {"level":"info","ts":"2018-04-29T10:14:41.249+0100","msg":"Node","name":"nakama","version":"2.0.0+7e18b09","runtime":"go1.10.1","cpu":4} <br/> > {"level":"info","ts":"2018-04-29T10:14:41.249+0100","msg":"Database connections","dsns":["root@127.0.0.1:26257"]} <br/> > ... ## Usage Nakama supports a variety of protocols optimized for various gameplay or app use cases. For request/response it can use GRPC or the HTTP1.1+JSON fallback (REST). For realtime communication you can use WebSockets or rUDP. For example with the REST API to authenticate a user account with a device identifier. ```shell curl "127.0.0.1:7350/v2/account/authenticate/device?create=true" \ --user "defaultkey:" \ --data '{"id": "someuniqueidentifier"}' ``` Response: > { <br> > "token":"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE1MjQ5OTU2NDksInVpZCI6Ijk5Y2Q1YzUyLWE5ODgtNGI2NC04YThhLTVmMTM5YTg4MTgxMiIsInVzbiI6InhBb1RxTUVSdFgifQ.-3_rXNYx3Q4jKuS7RkxeMWBzMNAm0vl93QxzRI8p_IY" <br> > } There's a number of official [client libraries](https://github.com/heroiclabs) available on GitHub with [documentation](https://heroiclabs.com/docs). The current platform/language support includes: .NET (in C#), Unity engine, JavaScript, Java (with Android), Unreal engine, Godot, Defold, and Swift (with iOS). If you'd like to contribute a client or request one let us know. ## Nakama Console The server provides a web UI which teams can use to inspect various data stored through the server APIs, view lightweight service metrics, manage player data, update storage objects, restrict access to production with permission profiles, and gain visibility into realtime features like active multiplayer matches. There is no separate installation required as it is embedded as part of the single server binary. You can navigate to it on your browser on [http://127.0.0.1:7351](http://127.0.0.1:7351). <img src=".github/accounts.jpg?raw=true" title="Account listing" width="1024" align="center"> <img src=".github/status.jpg?raw=true" title="Status view" width="125" align="left"> <img src=".github/storage.jpg?raw=true" title="Storage record view" width="125" align="left"> <img src=".github/match.jpg?raw=true" title="Running matches view" width="125" align="left"> <img src=".github/users.jpg?raw=true" title="Console users view" width="125" align="left"> <img src=".github/modules.jpg?raw=true" title="Loaded modules view" width="125"> ## Deployment Nakama can be deployed to any cloud provider such as Google Cloud, Azure, AWS, Digital Ocean, Heroku, or your own private cloud. You should setup and provision separate nodes for Nakama and CockroachDB. The recommended minimum production infrastructure for CockroachDB is outlined in [these docs](https://www.cockroachlabs.com/docs/stable/recommended-production-settings.html#basic-hardware-recommendations) and Nakama can be run on instance types as small as "g1-small" on Google Cloud although we recommend a minimum of "n1-standard-1" in production. The specific hardware requirements will depend on what features of the server are used. Reach out to us for help and advice on what servers to run. ### Heroic Cloud You can support development, new features, and maintainance of the server by using the Heroic Labs' [Heroic Cloud](https://heroiclabs.com/heroic-cloud/) for deployment. This service handles the uptime, replication, backups, logs, data upgrades, and all other tasks involved with production server environments. Have a look at our [Heroic Cloud](https://heroiclabs.com/heroic-cloud/) service for more details. ## Contribute The development roadmap is managed as GitHub issues and pull requests are welcome. If you're interested to add a feature which is not mentioned on the issue tracker please open one to create a discussion or drop in and discuss it in the [community forum](https://forum.heroiclabs.com). ### Simple Builds All dependencies required for a build are vendored as part of the Go project. We recommend a modern release of the Go toolchain and do not store the codebase in the old GOPATH. 1. Download the source tree. ```shell git clone "https://github.com/heroiclabs/nakama" nakama cd nakama ``` 2. Build the project from source. ```shell go build -trimpath -mod=vendor ./nakama --version ``` ### Full Source Builds The codebase uses Protocol Buffers, GRPC, GRPC-Gateway, and the OpenAPI spec as part of the project. These dependencies are generated as sources and committed to the repository to simplify builds for contributors. To build the codebase and generate all sources follow these steps. 1. Install the toolchain. ```shell go install \ "google.golang.org/protobuf/cmd/protoc-gen-go" \ "google.golang.org/grpc/cmd/protoc-gen-go-grpc" \ "github.com/grpc-ecosystem/grpc-gateway/v2/protoc-gen-grpc-gateway" \ "github.com/grpc-ecosystem/grpc-gateway/v2/protoc-gen-openapiv2" ``` 2. If you've made changes to the embedded Console. ```shell cd console/ui ng serve ``` 3. Re-generate the protocol buffers, gateway code and console UI. ```shell env PATH="$HOME/go/bin:$PATH" go generate -x ./... ``` 4. Build the codebase. ```shell go build -trimpath -mod=vendor ``` ### Testing In order to run all the unit and integration tests run: ```shell docker-compose -f ./docker-compose-tests.yml up --build --abort-on-container-exit; docker-compose -f ./docker-compose-tests.yml down -v ``` This will create an isolated environment with Nakama and database instances, run all the tests, and drop the environment afterwards. ### License This project is licensed under the [Apache-2 License](https://github.com/heroiclabs/nakama/blob/master/LICENSE). ", Assign "at most 3 tags" to the expected json: {"id":"1546","tags":[]} "only from the tags list I provide: [{"id":77,"name":"3d"},{"id":89,"name":"agent"},{"id":17,"name":"ai"},{"id":54,"name":"algorithm"},{"id":24,"name":"api"},{"id":44,"name":"authentication"},{"id":3,"name":"aws"},{"id":27,"name":"backend"},{"id":60,"name":"benchmark"},{"id":72,"name":"best-practices"},{"id":39,"name":"bitcoin"},{"id":37,"name":"blockchain"},{"id":1,"name":"blog"},{"id":45,"name":"bundler"},{"id":58,"name":"cache"},{"id":21,"name":"chat"},{"id":49,"name":"cicd"},{"id":4,"name":"cli"},{"id":64,"name":"cloud-native"},{"id":48,"name":"cms"},{"id":61,"name":"compiler"},{"id":68,"name":"containerization"},{"id":92,"name":"crm"},{"id":34,"name":"data"},{"id":47,"name":"database"},{"id":8,"name":"declarative-gui "},{"id":9,"name":"deploy-tool"},{"id":53,"name":"desktop-app"},{"id":6,"name":"dev-exp-lib"},{"id":59,"name":"dev-tool"},{"id":13,"name":"ecommerce"},{"id":26,"name":"editor"},{"id":66,"name":"emulator"},{"id":62,"name":"filesystem"},{"id":80,"name":"finance"},{"id":15,"name":"firmware"},{"id":73,"name":"for-fun"},{"id":2,"name":"framework"},{"id":11,"name":"frontend"},{"id":22,"name":"game"},{"id":81,"name":"game-engine "},{"id":23,"name":"graphql"},{"id":84,"name":"gui"},{"id":91,"name":"http"},{"id":5,"name":"http-client"},{"id":51,"name":"iac"},{"id":30,"name":"ide"},{"id":78,"name":"iot"},{"id":40,"name":"json"},{"id":83,"name":"julian"},{"id":38,"name":"k8s"},{"id":31,"name":"language"},{"id":10,"name":"learning-resource"},{"id":33,"name":"lib"},{"id":41,"name":"linter"},{"id":28,"name":"lms"},{"id":16,"name":"logging"},{"id":76,"name":"low-code"},{"id":90,"name":"message-queue"},{"id":42,"name":"mobile-app"},{"id":18,"name":"monitoring"},{"id":36,"name":"networking"},{"id":7,"name":"node-version"},{"id":55,"name":"nosql"},{"id":57,"name":"observability"},{"id":46,"name":"orm"},{"id":52,"name":"os"},{"id":14,"name":"parser"},{"id":74,"name":"react"},{"id":82,"name":"real-time"},{"id":56,"name":"robot"},{"id":65,"name":"runtime"},{"id":32,"name":"sdk"},{"id":71,"name":"search"},{"id":63,"name":"secrets"},{"id":25,"name":"security"},{"id":85,"name":"server"},{"id":86,"name":"serverless"},{"id":70,"name":"storage"},{"id":75,"name":"system-design"},{"id":79,"name":"terminal"},{"id":29,"name":"testing"},{"id":12,"name":"ui"},{"id":50,"name":"ux"},{"id":88,"name":"video"},{"id":20,"name":"web-app"},{"id":35,"name":"web-server"},{"id":43,"name":"webassembly"},{"id":69,"name":"workflow"},{"id":87,"name":"yaml"}]" returns me the "expected json"