Add new RPC method
This commit is contained in:
		@ -73,7 +73,7 @@ func (m *Match) MatchJoinAttempt(ctx context.Context, logger runtime.Logger, db
 | 
				
			|||||||
		return mState, false, "User already logged in."
 | 
							return mState, false, "User already logged in."
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		dataExist, err := entities.PlayerDataExists(ctx, nk, presence)
 | 
							dataExist, err := entities.PlayerDataExists(ctx, nk, presence.GetUserId())
 | 
				
			||||||
		if err != nil {
 | 
							if err != nil {
 | 
				
			||||||
			logger.Error(err.Error())
 | 
								logger.Error(err.Error())
 | 
				
			||||||
			return mState, false, err.Error()
 | 
								return mState, false, err.Error()
 | 
				
			||||||
 | 
				
			|||||||
@ -30,13 +30,13 @@ type PlayerPosResponse struct {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// PlayerDataExists checks if precense has saved data
 | 
					// PlayerDataExists checks if precense has saved data
 | 
				
			||||||
func PlayerDataExists(ctx context.Context, nk runtime.NakamaModule, presence runtime.Presence) (bool, error) {
 | 
					func PlayerDataExists(ctx context.Context, nk runtime.NakamaModule, userID string) (bool, error) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	Reads := []*runtime.StorageRead{
 | 
						Reads := []*runtime.StorageRead{
 | 
				
			||||||
		&runtime.StorageRead{
 | 
							&runtime.StorageRead{
 | 
				
			||||||
			Collection: "playerdata",
 | 
								Collection: "playerdata",
 | 
				
			||||||
			Key:        "data",
 | 
								Key:        "data",
 | 
				
			||||||
			UserID:     presence.GetUserId(),
 | 
								UserID:     userID,
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	records, err := nk.StorageRead(ctx, Reads)
 | 
						records, err := nk.StorageRead(ctx, Reads)
 | 
				
			||||||
@ -85,9 +85,15 @@ func LoadPlayer(ctx context.Context, nk runtime.NakamaModule, presence runtime.P
 | 
				
			|||||||
	return player, nil
 | 
						return player, nil
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Save saves player data to nakama
 | 
					// Save passes the precensce id to SaveUserID
 | 
				
			||||||
func (p *PlayerEntity) Save(ctx context.Context, nk runtime.NakamaModule) error {
 | 
					func (p *PlayerEntity) Save(ctx context.Context, nk runtime.NakamaModule) error {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return p.SaveUserID(ctx, nk, p.Presence.GetUserId())
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// SaveUserID saves player data to nakama
 | 
				
			||||||
 | 
					func (p *PlayerEntity) SaveUserID(ctx context.Context, nk runtime.NakamaModule, userID string) error {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	saveData := PlayerSaveData{
 | 
						saveData := PlayerSaveData{
 | 
				
			||||||
		Name:    p.Name,
 | 
							Name:    p.Name,
 | 
				
			||||||
		Faction: int(p.Faction),
 | 
							Faction: int(p.Faction),
 | 
				
			||||||
@ -103,7 +109,7 @@ func (p *PlayerEntity) Save(ctx context.Context, nk runtime.NakamaModule) error
 | 
				
			|||||||
			Collection: "playerdata",
 | 
								Collection: "playerdata",
 | 
				
			||||||
			Key:        "data",
 | 
								Key:        "data",
 | 
				
			||||||
			Value:      string(saveJSON),
 | 
								Value:      string(saveJSON),
 | 
				
			||||||
			UserID:     p.Presence.GetUserId(),
 | 
								UserID:     userID,
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -20,5 +20,9 @@ func InitModule(ctx context.Context, logger runtime.Logger, db *sql.DB, nk runti
 | 
				
			|||||||
		logger.Error("Unable to register: %v", err)
 | 
							logger.Error("Unable to register: %v", err)
 | 
				
			||||||
		return err
 | 
							return err
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
						if err := initializer.RegisterRpc("create_character", rpc.CreateCharacter); err != nil {
 | 
				
			||||||
 | 
							logger.Error("Unable to register: %v", err)
 | 
				
			||||||
 | 
							return err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
	return nil
 | 
						return nil
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -3,7 +3,11 @@ package rpc
 | 
				
			|||||||
import (
 | 
					import (
 | 
				
			||||||
	"context"
 | 
						"context"
 | 
				
			||||||
	"database/sql"
 | 
						"database/sql"
 | 
				
			||||||
 | 
						"encoding/json"
 | 
				
			||||||
 | 
						"errors"
 | 
				
			||||||
	"github.com/heroiclabs/nakama-common/runtime"
 | 
						"github.com/heroiclabs/nakama-common/runtime"
 | 
				
			||||||
 | 
						"github.com/josephbmanley/family/server/plugin/entities"
 | 
				
			||||||
 | 
						"github.com/josephbmanley/family/server/plugin/gameworld"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func getFirstWorld(ctx context.Context, logger runtime.Logger, nk runtime.NakamaModule) (string, error) {
 | 
					func getFirstWorld(ctx context.Context, logger runtime.Logger, nk runtime.NakamaModule) (string, error) {
 | 
				
			||||||
@ -47,3 +51,34 @@ func GetWorldId(ctx context.Context, logger runtime.Logger, db *sql.DB, nk runti
 | 
				
			|||||||
	matchID, err := getFirstWorld(ctx, logger, nk)
 | 
						matchID, err := getFirstWorld(ctx, logger, nk)
 | 
				
			||||||
	return matchID, err
 | 
						return matchID, err
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func CreateCharacter(ctx context.Context, logger runtime.Logger, db *sql.DB, nk runtime.NakamaModule, payload string) (string, error) {
 | 
				
			||||||
 | 
						userID, ok := ctx.Value(runtime.RUNTIME_CTX_USER_ID).(string)
 | 
				
			||||||
 | 
						if !ok {
 | 
				
			||||||
 | 
							dataExist, err := entities.PlayerDataExists(ctx, nk, userID)
 | 
				
			||||||
 | 
							if err != nil {
 | 
				
			||||||
 | 
								logger.Error(err.Error())
 | 
				
			||||||
 | 
								return "", err
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if dataExist {
 | 
				
			||||||
 | 
								return "", errors.New("user already has a character")
 | 
				
			||||||
 | 
							} else {
 | 
				
			||||||
 | 
								playerData := entities.PlayerSaveData{}
 | 
				
			||||||
 | 
								err := json.Unmarshal([]byte(payload), &playerData)
 | 
				
			||||||
 | 
								if err != nil {
 | 
				
			||||||
 | 
									return "", err
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								player := entities.PlayerEntity{
 | 
				
			||||||
 | 
									Name:    playerData.Name,
 | 
				
			||||||
 | 
									Faction: gameworld.Faction(playerData.Faction),
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								saveErr := player.SaveUserID(ctx, nk, userID)
 | 
				
			||||||
 | 
								if saveErr != nil {
 | 
				
			||||||
 | 
									return "", err
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								return "", nil
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return "", errors.New("Unknown error occured!")
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user