mirror of
https://github.com/elyby/accounts-profiles-endpoint.git
synced 2025-01-06 20:13:55 +05:30
feat: sign custom Ely property (#2)
* feat: sign custom Ely property Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * fix: avoid duplicating custom property value across code Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> * Remove customPropertySignature cache (and fix race condition) --------- Signed-off-by: Octol1ttle <l1ttleofficial@outlook.com> Co-authored-by: ErickSkrauch <erickskrauch@yandex.ru>
This commit is contained in:
parent
ffd55e6512
commit
ebe85fba93
@ -15,6 +15,7 @@ import (
|
||||
var timeNow = time.Now
|
||||
|
||||
var emptyTextures = []byte("{}")
|
||||
var customPropertyValue = []byte("but why are you asking?")
|
||||
|
||||
type AccountsRepository interface {
|
||||
FindUsernameByUuid(ctx context.Context, uuid string) (string, error)
|
||||
@ -83,7 +84,7 @@ func (s *MojangApi) getProfileByUuidHandler(c *gin.Context) {
|
||||
textures = emptyTextures
|
||||
}
|
||||
|
||||
serializedProfile, err := s.createProfileResponse(uuid, username, textures, c.Query("unsigned") == "false")
|
||||
serializedProfile, err := s.createProfileResponse(c.Request.Context(), uuid, username, textures, c.Query("unsigned") == "false")
|
||||
if err != nil {
|
||||
c.Error(fmt.Errorf("unable to create a profile response: %w", err))
|
||||
return
|
||||
@ -111,6 +112,7 @@ func (s *MojangApi) getUuidByUsernameHandler(c *gin.Context) {
|
||||
}
|
||||
|
||||
func (s *MojangApi) createProfileResponse(
|
||||
ctx context.Context,
|
||||
uuid string,
|
||||
username string,
|
||||
texturesJson []byte,
|
||||
@ -139,22 +141,45 @@ func (s *MojangApi) createProfileResponse(
|
||||
)
|
||||
|
||||
if sign {
|
||||
signature, err := s.SignerService.Sign(context.Background(), encodedTexturesBuf)
|
||||
textureSignature, err := s.signAndEncodeBase64(ctx, encodedTexturesBuf)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("unable to sign textures: %w", err)
|
||||
}
|
||||
|
||||
encodedSignatureBuf := make([]byte, base64.StdEncoding.EncodedLen(len(signature)))
|
||||
base64.StdEncoding.Encode(encodedSignatureBuf, signature)
|
||||
|
||||
result = fmt.Appendf(result, `,"signature":%q`, encodedSignatureBuf)
|
||||
result = fmt.Appendf(result, `,"signature":%q`, textureSignature)
|
||||
}
|
||||
|
||||
result = fmt.Appendf(result, `},{"name":"ely","value":"but why are you asking?"}]}`)
|
||||
result = fmt.Appendf(result, `},{"name":"ely","value":%q`, customPropertyValue)
|
||||
|
||||
if sign {
|
||||
// Despite the fact that the signed value itself is always the same,
|
||||
// the signature service may rotate keys and at some point the signature will change.
|
||||
// It is better to avoid the cache for now and add it on the signature service side later.
|
||||
customPropertySignature, err := s.signAndEncodeBase64(ctx, customPropertyValue)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("unable to sign custom property: %w", err)
|
||||
}
|
||||
|
||||
result = fmt.Appendf(result, `,"signature":%q`, customPropertySignature)
|
||||
}
|
||||
|
||||
result = fmt.Appendf(result, `}]}`)
|
||||
|
||||
return result, nil
|
||||
}
|
||||
|
||||
func (s *MojangApi) signAndEncodeBase64(ctx context.Context, data []byte) ([]byte, error) {
|
||||
signature, err := s.SignerService.Sign(ctx, data)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
encodedSignatureBuf := make([]byte, base64.StdEncoding.EncodedLen(len(signature)))
|
||||
base64.StdEncoding.Encode(encodedSignatureBuf, signature)
|
||||
|
||||
return encodedSignatureBuf, nil
|
||||
}
|
||||
|
||||
var invalidUuid = errors.New("invalid uuid")
|
||||
|
||||
func formatUuid(input string) (string, error) {
|
||||
|
Loading…
Reference in New Issue
Block a user