Merge pull request #7 from yauthdev/implement-token-verification-resolver
feat: add resolver for token verification
This commit is contained in:
commit
336fe10ca4
|
@ -16,7 +16,10 @@ type Manager interface {
|
||||||
AddUser(user User) (User, error)
|
AddUser(user User) (User, error)
|
||||||
GetUsers() ([]User, error)
|
GetUsers() ([]User, error)
|
||||||
GetUserByEmail(email string) (User, error)
|
GetUserByEmail(email string) (User, error)
|
||||||
|
UpdateVerificationTime(verifiedAt int64, email string) error
|
||||||
AddVerification(verification Verification) (Verification, error)
|
AddVerification(verification Verification) (Verification, error)
|
||||||
|
GetVerificationByToken(token string) (Verification, error)
|
||||||
|
DeleteToken(email string) error
|
||||||
}
|
}
|
||||||
|
|
||||||
type manager struct {
|
type manager struct {
|
||||||
|
|
|
@ -60,3 +60,13 @@ func (mgr *manager) GetUserByEmail(email string) (User, error) {
|
||||||
|
|
||||||
return user, nil
|
return user, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (mgr *manager) UpdateVerificationTime(verifiedAt int64, email string) error {
|
||||||
|
result := mgr.db.Model(&User{}).Where("email = ?", email).Update("email_verified_at", verifiedAt)
|
||||||
|
|
||||||
|
if result.Error != nil {
|
||||||
|
return result.Error
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
|
@ -8,7 +8,7 @@ import (
|
||||||
|
|
||||||
type Verification struct {
|
type Verification struct {
|
||||||
ID uint `gorm:"primaryKey"`
|
ID uint `gorm:"primaryKey"`
|
||||||
Token string
|
Token string `gorm:"index"`
|
||||||
Identifier string
|
Identifier string
|
||||||
ExpiresAt int64
|
ExpiresAt int64
|
||||||
CreatedAt int64 `gorm:"autoCreateTime"`
|
CreatedAt int64 `gorm:"autoCreateTime"`
|
||||||
|
@ -28,3 +28,27 @@ func (mgr *manager) AddVerification(verification Verification) (Verification, er
|
||||||
}
|
}
|
||||||
return verification, nil
|
return verification, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (mgr *manager) GetVerificationByToken(token string) (Verification, error) {
|
||||||
|
var verification Verification
|
||||||
|
result := mgr.db.Where("token = ?", token).First(&verification)
|
||||||
|
|
||||||
|
if result.Error != nil {
|
||||||
|
log.Println(`Error getting verification token:`, result.Error)
|
||||||
|
return verification, result.Error
|
||||||
|
}
|
||||||
|
|
||||||
|
return verification, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mgr *manager) DeleteToken(email string) error {
|
||||||
|
var verification Verification
|
||||||
|
result := mgr.db.Where("email = ?", email).Delete(&verification)
|
||||||
|
|
||||||
|
if result.Error != nil {
|
||||||
|
log.Println(`Error deleting token:`, result.Error)
|
||||||
|
return result.Error
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
|
@ -6,7 +6,6 @@ import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"context"
|
"context"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
|
||||||
"strconv"
|
"strconv"
|
||||||
"sync"
|
"sync"
|
||||||
"sync/atomic"
|
"sync/atomic"
|
||||||
|
@ -69,12 +68,20 @@ type ComplexityRoot struct {
|
||||||
Mutation struct {
|
Mutation struct {
|
||||||
BasicAuthLogin func(childComplexity int, params model.BasicAuthLoginInput) int
|
BasicAuthLogin func(childComplexity int, params model.BasicAuthLoginInput) int
|
||||||
BasicAuthSignUp func(childComplexity int, params model.BasicAuthSignupInput) int
|
BasicAuthSignUp func(childComplexity int, params model.BasicAuthSignupInput) int
|
||||||
|
VerifySignupToken func(childComplexity int, params model.VerifySignupTokenInput) int
|
||||||
}
|
}
|
||||||
|
|
||||||
Query struct {
|
Query struct {
|
||||||
Users func(childComplexity int) int
|
Users func(childComplexity int) int
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Response struct {
|
||||||
|
Errors func(childComplexity int) int
|
||||||
|
Message func(childComplexity int) int
|
||||||
|
StatusCode func(childComplexity int) int
|
||||||
|
Success func(childComplexity int) int
|
||||||
|
}
|
||||||
|
|
||||||
User struct {
|
User struct {
|
||||||
CreatedAt func(childComplexity int) int
|
CreatedAt func(childComplexity int) int
|
||||||
Email func(childComplexity int) int
|
Email func(childComplexity int) int
|
||||||
|
@ -100,6 +107,7 @@ type ComplexityRoot struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
type MutationResolver interface {
|
type MutationResolver interface {
|
||||||
|
VerifySignupToken(ctx context.Context, params model.VerifySignupTokenInput) (*model.Response, error)
|
||||||
BasicAuthSignUp(ctx context.Context, params model.BasicAuthSignupInput) (*model.BasicAuthSignupResponse, error)
|
BasicAuthSignUp(ctx context.Context, params model.BasicAuthSignupInput) (*model.BasicAuthSignupResponse, error)
|
||||||
BasicAuthLogin(ctx context.Context, params model.BasicAuthLoginInput) (*model.BasicAuthLoginResponse, error)
|
BasicAuthLogin(ctx context.Context, params model.BasicAuthLoginInput) (*model.BasicAuthLoginResponse, error)
|
||||||
}
|
}
|
||||||
|
@ -237,6 +245,18 @@ func (e *executableSchema) Complexity(typeName, field string, childComplexity in
|
||||||
|
|
||||||
return e.complexity.Mutation.BasicAuthSignUp(childComplexity, args["params"].(model.BasicAuthSignupInput)), true
|
return e.complexity.Mutation.BasicAuthSignUp(childComplexity, args["params"].(model.BasicAuthSignupInput)), true
|
||||||
|
|
||||||
|
case "Mutation.verifySignupToken":
|
||||||
|
if e.complexity.Mutation.VerifySignupToken == nil {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
args, err := ec.field_Mutation_verifySignupToken_args(context.TODO(), rawArgs)
|
||||||
|
if err != nil {
|
||||||
|
return 0, false
|
||||||
|
}
|
||||||
|
|
||||||
|
return e.complexity.Mutation.VerifySignupToken(childComplexity, args["params"].(model.VerifySignupTokenInput)), true
|
||||||
|
|
||||||
case "Query.users":
|
case "Query.users":
|
||||||
if e.complexity.Query.Users == nil {
|
if e.complexity.Query.Users == nil {
|
||||||
break
|
break
|
||||||
|
@ -244,6 +264,34 @@ func (e *executableSchema) Complexity(typeName, field string, childComplexity in
|
||||||
|
|
||||||
return e.complexity.Query.Users(childComplexity), true
|
return e.complexity.Query.Users(childComplexity), true
|
||||||
|
|
||||||
|
case "Response.errors":
|
||||||
|
if e.complexity.Response.Errors == nil {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
return e.complexity.Response.Errors(childComplexity), true
|
||||||
|
|
||||||
|
case "Response.message":
|
||||||
|
if e.complexity.Response.Message == nil {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
return e.complexity.Response.Message(childComplexity), true
|
||||||
|
|
||||||
|
case "Response.statusCode":
|
||||||
|
if e.complexity.Response.StatusCode == nil {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
return e.complexity.Response.StatusCode(childComplexity), true
|
||||||
|
|
||||||
|
case "Response.success":
|
||||||
|
if e.complexity.Response.Success == nil {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
return e.complexity.Response.Success(childComplexity), true
|
||||||
|
|
||||||
case "User.createdAt":
|
case "User.createdAt":
|
||||||
if e.complexity.User.CreatedAt == nil {
|
if e.complexity.User.CreatedAt == nil {
|
||||||
break
|
break
|
||||||
|
@ -460,14 +508,14 @@ type Error {
|
||||||
reason: String!
|
reason: String!
|
||||||
}
|
}
|
||||||
|
|
||||||
interface Response {
|
type Response {
|
||||||
success: Boolean!
|
success: Boolean!
|
||||||
message: String!
|
message: String!
|
||||||
errors: [Error!]
|
errors: [Error!]
|
||||||
statusCode: Int!
|
statusCode: Int!
|
||||||
}
|
}
|
||||||
|
|
||||||
type BasicAuthLoginResponse implements Response {
|
type BasicAuthLoginResponse {
|
||||||
success: Boolean!
|
success: Boolean!
|
||||||
message: String!
|
message: String!
|
||||||
errors: [Error!]
|
errors: [Error!]
|
||||||
|
@ -476,7 +524,7 @@ type BasicAuthLoginResponse implements Response {
|
||||||
user: User
|
user: User
|
||||||
}
|
}
|
||||||
|
|
||||||
type BasicAuthSignupResponse implements Response {
|
type BasicAuthSignupResponse {
|
||||||
success: Boolean!
|
success: Boolean!
|
||||||
message: String!
|
message: String!
|
||||||
errors: [Error!]
|
errors: [Error!]
|
||||||
|
@ -502,7 +550,12 @@ input BasicAuthLoginInput {
|
||||||
password: String!
|
password: String!
|
||||||
}
|
}
|
||||||
|
|
||||||
|
input VerifySignupTokenInput {
|
||||||
|
token: String!
|
||||||
|
}
|
||||||
|
|
||||||
type Mutation {
|
type Mutation {
|
||||||
|
verifySignupToken(params: VerifySignupTokenInput!): Response!
|
||||||
basicAuthSignUp(params: BasicAuthSignupInput!): BasicAuthSignupResponse!
|
basicAuthSignUp(params: BasicAuthSignupInput!): BasicAuthSignupResponse!
|
||||||
basicAuthLogin(params: BasicAuthLoginInput!): BasicAuthLoginResponse!
|
basicAuthLogin(params: BasicAuthLoginInput!): BasicAuthLoginResponse!
|
||||||
}
|
}
|
||||||
|
@ -544,6 +597,21 @@ func (ec *executionContext) field_Mutation_basicAuthSignUp_args(ctx context.Cont
|
||||||
return args, nil
|
return args, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) field_Mutation_verifySignupToken_args(ctx context.Context, rawArgs map[string]interface{}) (map[string]interface{}, error) {
|
||||||
|
var err error
|
||||||
|
args := map[string]interface{}{}
|
||||||
|
var arg0 model.VerifySignupTokenInput
|
||||||
|
if tmp, ok := rawArgs["params"]; ok {
|
||||||
|
ctx := graphql.WithPathContext(ctx, graphql.NewPathWithField("params"))
|
||||||
|
arg0, err = ec.unmarshalNVerifySignupTokenInput2githubᚗcomᚋyauthdevᚋyauthᚋserverᚋgraphᚋmodelᚐVerifySignupTokenInput(ctx, tmp)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
args["params"] = arg0
|
||||||
|
return args, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (ec *executionContext) field_Query___type_args(ctx context.Context, rawArgs map[string]interface{}) (map[string]interface{}, error) {
|
func (ec *executionContext) field_Query___type_args(ctx context.Context, rawArgs map[string]interface{}) (map[string]interface{}, error) {
|
||||||
var err error
|
var err error
|
||||||
args := map[string]interface{}{}
|
args := map[string]interface{}{}
|
||||||
|
@ -1037,6 +1105,48 @@ func (ec *executionContext) _Error_reason(ctx context.Context, field graphql.Col
|
||||||
return ec.marshalNString2string(ctx, field.Selections, res)
|
return ec.marshalNString2string(ctx, field.Selections, res)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) _Mutation_verifySignupToken(ctx context.Context, field graphql.CollectedField) (ret graphql.Marshaler) {
|
||||||
|
defer func() {
|
||||||
|
if r := recover(); r != nil {
|
||||||
|
ec.Error(ctx, ec.Recover(ctx, r))
|
||||||
|
ret = graphql.Null
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
fc := &graphql.FieldContext{
|
||||||
|
Object: "Mutation",
|
||||||
|
Field: field,
|
||||||
|
Args: nil,
|
||||||
|
IsMethod: true,
|
||||||
|
IsResolver: true,
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx = graphql.WithFieldContext(ctx, fc)
|
||||||
|
rawArgs := field.ArgumentMap(ec.Variables)
|
||||||
|
args, err := ec.field_Mutation_verifySignupToken_args(ctx, rawArgs)
|
||||||
|
if err != nil {
|
||||||
|
ec.Error(ctx, err)
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
fc.Args = args
|
||||||
|
resTmp, err := ec.ResolverMiddleware(ctx, func(rctx context.Context) (interface{}, error) {
|
||||||
|
ctx = rctx // use context from middleware stack in children
|
||||||
|
return ec.resolvers.Mutation().VerifySignupToken(rctx, args["params"].(model.VerifySignupTokenInput))
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
ec.Error(ctx, err)
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
if resTmp == nil {
|
||||||
|
if !graphql.HasFieldError(ctx, fc) {
|
||||||
|
ec.Errorf(ctx, "must not be null")
|
||||||
|
}
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
res := resTmp.(*model.Response)
|
||||||
|
fc.Result = res
|
||||||
|
return ec.marshalNResponse2ᚖgithubᚗcomᚋyauthdevᚋyauthᚋserverᚋgraphᚋmodelᚐResponse(ctx, field.Selections, res)
|
||||||
|
}
|
||||||
|
|
||||||
func (ec *executionContext) _Mutation_basicAuthSignUp(ctx context.Context, field graphql.CollectedField) (ret graphql.Marshaler) {
|
func (ec *executionContext) _Mutation_basicAuthSignUp(ctx context.Context, field graphql.CollectedField) (ret graphql.Marshaler) {
|
||||||
defer func() {
|
defer func() {
|
||||||
if r := recover(); r != nil {
|
if r := recover(); r != nil {
|
||||||
|
@ -1227,6 +1337,143 @@ func (ec *executionContext) _Query___schema(ctx context.Context, field graphql.C
|
||||||
return ec.marshalO__Schema2ᚖgithubᚗcomᚋ99designsᚋgqlgenᚋgraphqlᚋintrospectionᚐSchema(ctx, field.Selections, res)
|
return ec.marshalO__Schema2ᚖgithubᚗcomᚋ99designsᚋgqlgenᚋgraphqlᚋintrospectionᚐSchema(ctx, field.Selections, res)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) _Response_success(ctx context.Context, field graphql.CollectedField, obj *model.Response) (ret graphql.Marshaler) {
|
||||||
|
defer func() {
|
||||||
|
if r := recover(); r != nil {
|
||||||
|
ec.Error(ctx, ec.Recover(ctx, r))
|
||||||
|
ret = graphql.Null
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
fc := &graphql.FieldContext{
|
||||||
|
Object: "Response",
|
||||||
|
Field: field,
|
||||||
|
Args: nil,
|
||||||
|
IsMethod: false,
|
||||||
|
IsResolver: false,
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx = graphql.WithFieldContext(ctx, fc)
|
||||||
|
resTmp, err := ec.ResolverMiddleware(ctx, func(rctx context.Context) (interface{}, error) {
|
||||||
|
ctx = rctx // use context from middleware stack in children
|
||||||
|
return obj.Success, nil
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
ec.Error(ctx, err)
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
if resTmp == nil {
|
||||||
|
if !graphql.HasFieldError(ctx, fc) {
|
||||||
|
ec.Errorf(ctx, "must not be null")
|
||||||
|
}
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
res := resTmp.(bool)
|
||||||
|
fc.Result = res
|
||||||
|
return ec.marshalNBoolean2bool(ctx, field.Selections, res)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) _Response_message(ctx context.Context, field graphql.CollectedField, obj *model.Response) (ret graphql.Marshaler) {
|
||||||
|
defer func() {
|
||||||
|
if r := recover(); r != nil {
|
||||||
|
ec.Error(ctx, ec.Recover(ctx, r))
|
||||||
|
ret = graphql.Null
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
fc := &graphql.FieldContext{
|
||||||
|
Object: "Response",
|
||||||
|
Field: field,
|
||||||
|
Args: nil,
|
||||||
|
IsMethod: false,
|
||||||
|
IsResolver: false,
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx = graphql.WithFieldContext(ctx, fc)
|
||||||
|
resTmp, err := ec.ResolverMiddleware(ctx, func(rctx context.Context) (interface{}, error) {
|
||||||
|
ctx = rctx // use context from middleware stack in children
|
||||||
|
return obj.Message, nil
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
ec.Error(ctx, err)
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
if resTmp == nil {
|
||||||
|
if !graphql.HasFieldError(ctx, fc) {
|
||||||
|
ec.Errorf(ctx, "must not be null")
|
||||||
|
}
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
res := resTmp.(string)
|
||||||
|
fc.Result = res
|
||||||
|
return ec.marshalNString2string(ctx, field.Selections, res)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) _Response_errors(ctx context.Context, field graphql.CollectedField, obj *model.Response) (ret graphql.Marshaler) {
|
||||||
|
defer func() {
|
||||||
|
if r := recover(); r != nil {
|
||||||
|
ec.Error(ctx, ec.Recover(ctx, r))
|
||||||
|
ret = graphql.Null
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
fc := &graphql.FieldContext{
|
||||||
|
Object: "Response",
|
||||||
|
Field: field,
|
||||||
|
Args: nil,
|
||||||
|
IsMethod: false,
|
||||||
|
IsResolver: false,
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx = graphql.WithFieldContext(ctx, fc)
|
||||||
|
resTmp, err := ec.ResolverMiddleware(ctx, func(rctx context.Context) (interface{}, error) {
|
||||||
|
ctx = rctx // use context from middleware stack in children
|
||||||
|
return obj.Errors, nil
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
ec.Error(ctx, err)
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
if resTmp == nil {
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
res := resTmp.([]*model.Error)
|
||||||
|
fc.Result = res
|
||||||
|
return ec.marshalOError2ᚕᚖgithubᚗcomᚋyauthdevᚋyauthᚋserverᚋgraphᚋmodelᚐErrorᚄ(ctx, field.Selections, res)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) _Response_statusCode(ctx context.Context, field graphql.CollectedField, obj *model.Response) (ret graphql.Marshaler) {
|
||||||
|
defer func() {
|
||||||
|
if r := recover(); r != nil {
|
||||||
|
ec.Error(ctx, ec.Recover(ctx, r))
|
||||||
|
ret = graphql.Null
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
fc := &graphql.FieldContext{
|
||||||
|
Object: "Response",
|
||||||
|
Field: field,
|
||||||
|
Args: nil,
|
||||||
|
IsMethod: false,
|
||||||
|
IsResolver: false,
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx = graphql.WithFieldContext(ctx, fc)
|
||||||
|
resTmp, err := ec.ResolverMiddleware(ctx, func(rctx context.Context) (interface{}, error) {
|
||||||
|
ctx = rctx // use context from middleware stack in children
|
||||||
|
return obj.StatusCode, nil
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
ec.Error(ctx, err)
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
if resTmp == nil {
|
||||||
|
if !graphql.HasFieldError(ctx, fc) {
|
||||||
|
ec.Errorf(ctx, "must not be null")
|
||||||
|
}
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
res := resTmp.(int)
|
||||||
|
fc.Result = res
|
||||||
|
return ec.marshalNInt2int(ctx, field.Selections, res)
|
||||||
|
}
|
||||||
|
|
||||||
func (ec *executionContext) _User_id(ctx context.Context, field graphql.CollectedField, obj *model.User) (ret graphql.Marshaler) {
|
func (ec *executionContext) _User_id(ctx context.Context, field graphql.CollectedField, obj *model.User) (ret graphql.Marshaler) {
|
||||||
defer func() {
|
defer func() {
|
||||||
if r := recover(); r != nil {
|
if r := recover(); r != nil {
|
||||||
|
@ -2958,38 +3205,35 @@ func (ec *executionContext) unmarshalInputBasicAuthSignupInput(ctx context.Conte
|
||||||
return it, nil
|
return it, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) unmarshalInputVerifySignupTokenInput(ctx context.Context, obj interface{}) (model.VerifySignupTokenInput, error) {
|
||||||
|
var it model.VerifySignupTokenInput
|
||||||
|
var asMap = obj.(map[string]interface{})
|
||||||
|
|
||||||
|
for k, v := range asMap {
|
||||||
|
switch k {
|
||||||
|
case "token":
|
||||||
|
var err error
|
||||||
|
|
||||||
|
ctx := graphql.WithPathContext(ctx, graphql.NewPathWithField("token"))
|
||||||
|
it.Token, err = ec.unmarshalNString2string(ctx, v)
|
||||||
|
if err != nil {
|
||||||
|
return it, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return it, nil
|
||||||
|
}
|
||||||
|
|
||||||
// endregion **************************** input.gotpl *****************************
|
// endregion **************************** input.gotpl *****************************
|
||||||
|
|
||||||
// region ************************** interface.gotpl ***************************
|
// region ************************** interface.gotpl ***************************
|
||||||
|
|
||||||
func (ec *executionContext) _Response(ctx context.Context, sel ast.SelectionSet, obj model.Response) graphql.Marshaler {
|
|
||||||
switch obj := (obj).(type) {
|
|
||||||
case nil:
|
|
||||||
return graphql.Null
|
|
||||||
case model.BasicAuthLoginResponse:
|
|
||||||
return ec._BasicAuthLoginResponse(ctx, sel, &obj)
|
|
||||||
case *model.BasicAuthLoginResponse:
|
|
||||||
if obj == nil {
|
|
||||||
return graphql.Null
|
|
||||||
}
|
|
||||||
return ec._BasicAuthLoginResponse(ctx, sel, obj)
|
|
||||||
case model.BasicAuthSignupResponse:
|
|
||||||
return ec._BasicAuthSignupResponse(ctx, sel, &obj)
|
|
||||||
case *model.BasicAuthSignupResponse:
|
|
||||||
if obj == nil {
|
|
||||||
return graphql.Null
|
|
||||||
}
|
|
||||||
return ec._BasicAuthSignupResponse(ctx, sel, obj)
|
|
||||||
default:
|
|
||||||
panic(fmt.Errorf("unexpected type %T", obj))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// endregion ************************** interface.gotpl ***************************
|
// endregion ************************** interface.gotpl ***************************
|
||||||
|
|
||||||
// region **************************** object.gotpl ****************************
|
// region **************************** object.gotpl ****************************
|
||||||
|
|
||||||
var basicAuthLoginResponseImplementors = []string{"BasicAuthLoginResponse", "Response"}
|
var basicAuthLoginResponseImplementors = []string{"BasicAuthLoginResponse"}
|
||||||
|
|
||||||
func (ec *executionContext) _BasicAuthLoginResponse(ctx context.Context, sel ast.SelectionSet, obj *model.BasicAuthLoginResponse) graphql.Marshaler {
|
func (ec *executionContext) _BasicAuthLoginResponse(ctx context.Context, sel ast.SelectionSet, obj *model.BasicAuthLoginResponse) graphql.Marshaler {
|
||||||
fields := graphql.CollectFields(ec.OperationContext, sel, basicAuthLoginResponseImplementors)
|
fields := graphql.CollectFields(ec.OperationContext, sel, basicAuthLoginResponseImplementors)
|
||||||
|
@ -3032,7 +3276,7 @@ func (ec *executionContext) _BasicAuthLoginResponse(ctx context.Context, sel ast
|
||||||
return out
|
return out
|
||||||
}
|
}
|
||||||
|
|
||||||
var basicAuthSignupResponseImplementors = []string{"BasicAuthSignupResponse", "Response"}
|
var basicAuthSignupResponseImplementors = []string{"BasicAuthSignupResponse"}
|
||||||
|
|
||||||
func (ec *executionContext) _BasicAuthSignupResponse(ctx context.Context, sel ast.SelectionSet, obj *model.BasicAuthSignupResponse) graphql.Marshaler {
|
func (ec *executionContext) _BasicAuthSignupResponse(ctx context.Context, sel ast.SelectionSet, obj *model.BasicAuthSignupResponse) graphql.Marshaler {
|
||||||
fields := graphql.CollectFields(ec.OperationContext, sel, basicAuthSignupResponseImplementors)
|
fields := graphql.CollectFields(ec.OperationContext, sel, basicAuthSignupResponseImplementors)
|
||||||
|
@ -3120,6 +3364,11 @@ func (ec *executionContext) _Mutation(ctx context.Context, sel ast.SelectionSet)
|
||||||
switch field.Name {
|
switch field.Name {
|
||||||
case "__typename":
|
case "__typename":
|
||||||
out.Values[i] = graphql.MarshalString("Mutation")
|
out.Values[i] = graphql.MarshalString("Mutation")
|
||||||
|
case "verifySignupToken":
|
||||||
|
out.Values[i] = ec._Mutation_verifySignupToken(ctx, field)
|
||||||
|
if out.Values[i] == graphql.Null {
|
||||||
|
invalids++
|
||||||
|
}
|
||||||
case "basicAuthSignUp":
|
case "basicAuthSignUp":
|
||||||
out.Values[i] = ec._Mutation_basicAuthSignUp(ctx, field)
|
out.Values[i] = ec._Mutation_basicAuthSignUp(ctx, field)
|
||||||
if out.Values[i] == graphql.Null {
|
if out.Values[i] == graphql.Null {
|
||||||
|
@ -3185,6 +3434,45 @@ func (ec *executionContext) _Query(ctx context.Context, sel ast.SelectionSet) gr
|
||||||
return out
|
return out
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var responseImplementors = []string{"Response"}
|
||||||
|
|
||||||
|
func (ec *executionContext) _Response(ctx context.Context, sel ast.SelectionSet, obj *model.Response) graphql.Marshaler {
|
||||||
|
fields := graphql.CollectFields(ec.OperationContext, sel, responseImplementors)
|
||||||
|
|
||||||
|
out := graphql.NewFieldSet(fields)
|
||||||
|
var invalids uint32
|
||||||
|
for i, field := range fields {
|
||||||
|
switch field.Name {
|
||||||
|
case "__typename":
|
||||||
|
out.Values[i] = graphql.MarshalString("Response")
|
||||||
|
case "success":
|
||||||
|
out.Values[i] = ec._Response_success(ctx, field, obj)
|
||||||
|
if out.Values[i] == graphql.Null {
|
||||||
|
invalids++
|
||||||
|
}
|
||||||
|
case "message":
|
||||||
|
out.Values[i] = ec._Response_message(ctx, field, obj)
|
||||||
|
if out.Values[i] == graphql.Null {
|
||||||
|
invalids++
|
||||||
|
}
|
||||||
|
case "errors":
|
||||||
|
out.Values[i] = ec._Response_errors(ctx, field, obj)
|
||||||
|
case "statusCode":
|
||||||
|
out.Values[i] = ec._Response_statusCode(ctx, field, obj)
|
||||||
|
if out.Values[i] == graphql.Null {
|
||||||
|
invalids++
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
panic("unknown field " + strconv.Quote(field.Name))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
out.Dispatch()
|
||||||
|
if invalids > 0 {
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
return out
|
||||||
|
}
|
||||||
|
|
||||||
var userImplementors = []string{"User"}
|
var userImplementors = []string{"User"}
|
||||||
|
|
||||||
func (ec *executionContext) _User(ctx context.Context, sel ast.SelectionSet, obj *model.User) graphql.Marshaler {
|
func (ec *executionContext) _User(ctx context.Context, sel ast.SelectionSet, obj *model.User) graphql.Marshaler {
|
||||||
|
@ -3613,6 +3901,20 @@ func (ec *executionContext) marshalNInt2int(ctx context.Context, sel ast.Selecti
|
||||||
return res
|
return res
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) marshalNResponse2githubᚗcomᚋyauthdevᚋyauthᚋserverᚋgraphᚋmodelᚐResponse(ctx context.Context, sel ast.SelectionSet, v model.Response) graphql.Marshaler {
|
||||||
|
return ec._Response(ctx, sel, &v)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) marshalNResponse2ᚖgithubᚗcomᚋyauthdevᚋyauthᚋserverᚋgraphᚋmodelᚐResponse(ctx context.Context, sel ast.SelectionSet, v *model.Response) graphql.Marshaler {
|
||||||
|
if v == nil {
|
||||||
|
if !graphql.HasFieldError(ctx, graphql.GetFieldContext(ctx)) {
|
||||||
|
ec.Errorf(ctx, "must not be null")
|
||||||
|
}
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
return ec._Response(ctx, sel, v)
|
||||||
|
}
|
||||||
|
|
||||||
func (ec *executionContext) unmarshalNString2string(ctx context.Context, v interface{}) (string, error) {
|
func (ec *executionContext) unmarshalNString2string(ctx context.Context, v interface{}) (string, error) {
|
||||||
res, err := graphql.UnmarshalString(v)
|
res, err := graphql.UnmarshalString(v)
|
||||||
return res, graphql.ErrorOnPath(ctx, err)
|
return res, graphql.ErrorOnPath(ctx, err)
|
||||||
|
@ -3675,6 +3977,11 @@ func (ec *executionContext) marshalNUser2ᚖgithubᚗcomᚋyauthdevᚋyauthᚋse
|
||||||
return ec._User(ctx, sel, v)
|
return ec._User(ctx, sel, v)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) unmarshalNVerifySignupTokenInput2githubᚗcomᚋyauthdevᚋyauthᚋserverᚋgraphᚋmodelᚐVerifySignupTokenInput(ctx context.Context, v interface{}) (model.VerifySignupTokenInput, error) {
|
||||||
|
res, err := ec.unmarshalInputVerifySignupTokenInput(ctx, v)
|
||||||
|
return res, graphql.ErrorOnPath(ctx, err)
|
||||||
|
}
|
||||||
|
|
||||||
func (ec *executionContext) marshalN__Directive2githubᚗcomᚋ99designsᚋgqlgenᚋgraphqlᚋintrospectionᚐDirective(ctx context.Context, sel ast.SelectionSet, v introspection.Directive) graphql.Marshaler {
|
func (ec *executionContext) marshalN__Directive2githubᚗcomᚋ99designsᚋgqlgenᚋgraphqlᚋintrospectionᚐDirective(ctx context.Context, sel ast.SelectionSet, v introspection.Directive) graphql.Marshaler {
|
||||||
return ec.___Directive(ctx, sel, &v)
|
return ec.___Directive(ctx, sel, &v)
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,10 +2,6 @@
|
||||||
|
|
||||||
package model
|
package model
|
||||||
|
|
||||||
type Response interface {
|
|
||||||
IsResponse()
|
|
||||||
}
|
|
||||||
|
|
||||||
type BasicAuthLoginInput struct {
|
type BasicAuthLoginInput struct {
|
||||||
Email string `json:"email"`
|
Email string `json:"email"`
|
||||||
Password string `json:"password"`
|
Password string `json:"password"`
|
||||||
|
@ -20,8 +16,6 @@ type BasicAuthLoginResponse struct {
|
||||||
User *User `json:"user"`
|
User *User `json:"user"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (BasicAuthLoginResponse) IsResponse() {}
|
|
||||||
|
|
||||||
type BasicAuthSignupInput struct {
|
type BasicAuthSignupInput struct {
|
||||||
FirstName *string `json:"firstName"`
|
FirstName *string `json:"firstName"`
|
||||||
LastName *string `json:"lastName"`
|
LastName *string `json:"lastName"`
|
||||||
|
@ -39,13 +33,18 @@ type BasicAuthSignupResponse struct {
|
||||||
User *User `json:"user"`
|
User *User `json:"user"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (BasicAuthSignupResponse) IsResponse() {}
|
|
||||||
|
|
||||||
type Error struct {
|
type Error struct {
|
||||||
Message string `json:"message"`
|
Message string `json:"message"`
|
||||||
Reason string `json:"reason"`
|
Reason string `json:"reason"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type Response struct {
|
||||||
|
Success bool `json:"success"`
|
||||||
|
Message string `json:"message"`
|
||||||
|
Errors []*Error `json:"errors"`
|
||||||
|
StatusCode int `json:"statusCode"`
|
||||||
|
}
|
||||||
|
|
||||||
type User struct {
|
type User struct {
|
||||||
ID string `json:"id"`
|
ID string `json:"id"`
|
||||||
Email string `json:"email"`
|
Email string `json:"email"`
|
||||||
|
@ -68,3 +67,7 @@ type VerificationRequest struct {
|
||||||
CreatedAt *int64 `json:"createdAt"`
|
CreatedAt *int64 `json:"createdAt"`
|
||||||
UpdatedAt *int64 `json:"updatedAt"`
|
UpdatedAt *int64 `json:"updatedAt"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type VerifySignupTokenInput struct {
|
||||||
|
Token string `json:"token"`
|
||||||
|
}
|
||||||
|
|
|
@ -31,14 +31,14 @@ type Error {
|
||||||
reason: String!
|
reason: String!
|
||||||
}
|
}
|
||||||
|
|
||||||
interface Response {
|
type Response {
|
||||||
success: Boolean!
|
success: Boolean!
|
||||||
message: String!
|
message: String!
|
||||||
errors: [Error!]
|
errors: [Error!]
|
||||||
statusCode: Int!
|
statusCode: Int!
|
||||||
}
|
}
|
||||||
|
|
||||||
type BasicAuthLoginResponse implements Response {
|
type BasicAuthLoginResponse {
|
||||||
success: Boolean!
|
success: Boolean!
|
||||||
message: String!
|
message: String!
|
||||||
errors: [Error!]
|
errors: [Error!]
|
||||||
|
@ -47,7 +47,7 @@ type BasicAuthLoginResponse implements Response {
|
||||||
user: User
|
user: User
|
||||||
}
|
}
|
||||||
|
|
||||||
type BasicAuthSignupResponse implements Response {
|
type BasicAuthSignupResponse {
|
||||||
success: Boolean!
|
success: Boolean!
|
||||||
message: String!
|
message: String!
|
||||||
errors: [Error!]
|
errors: [Error!]
|
||||||
|
@ -73,7 +73,12 @@ input BasicAuthLoginInput {
|
||||||
password: String!
|
password: String!
|
||||||
}
|
}
|
||||||
|
|
||||||
|
input VerifySignupTokenInput {
|
||||||
|
token: String!
|
||||||
|
}
|
||||||
|
|
||||||
type Mutation {
|
type Mutation {
|
||||||
|
verifySignupToken(params: VerifySignupTokenInput!): Response!
|
||||||
basicAuthSignUp(params: BasicAuthSignupInput!): BasicAuthSignupResponse!
|
basicAuthSignUp(params: BasicAuthSignupInput!): BasicAuthSignupResponse!
|
||||||
basicAuthLogin(params: BasicAuthLoginInput!): BasicAuthLoginResponse!
|
basicAuthLogin(params: BasicAuthLoginInput!): BasicAuthLoginResponse!
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,6 +16,52 @@ import (
|
||||||
"github.com/yauthdev/yauth/server/utils"
|
"github.com/yauthdev/yauth/server/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func (r *mutationResolver) VerifySignupToken(ctx context.Context, params model.VerifySignupTokenInput) (*model.Response, error) {
|
||||||
|
// // verify if token is valid
|
||||||
|
var res *model.Response
|
||||||
|
_, err := db.Mgr.GetVerificationByToken(params.Token)
|
||||||
|
if err != nil {
|
||||||
|
res = &model.Response{
|
||||||
|
Success: false,
|
||||||
|
Message: `Invalid token`,
|
||||||
|
StatusCode: 400,
|
||||||
|
Errors: []*model.Error{&model.Error{
|
||||||
|
Message: `Invalid token`,
|
||||||
|
Reason: `invalid token`,
|
||||||
|
}},
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
|
||||||
|
// verify if token exists in db
|
||||||
|
claim, err := utils.VerifyVerificationToken(params.Token)
|
||||||
|
if err != nil {
|
||||||
|
res = &model.Response{
|
||||||
|
Success: false,
|
||||||
|
Message: `Invalid token`,
|
||||||
|
StatusCode: 400,
|
||||||
|
Errors: []*model.Error{&model.Error{
|
||||||
|
Message: `Invalid token`,
|
||||||
|
Reason: `invalid token`,
|
||||||
|
}},
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
res = &model.Response{
|
||||||
|
Success: true,
|
||||||
|
Message: `Email verified successfully. Login to access the system.`,
|
||||||
|
StatusCode: 200,
|
||||||
|
}
|
||||||
|
|
||||||
|
// update email_verified_at in users table
|
||||||
|
db.Mgr.UpdateVerificationTime(time.Now().Unix(), claim.Email)
|
||||||
|
// delete from verification table
|
||||||
|
db.Mgr.DeleteToken(claim.Email)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return res, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (r *mutationResolver) BasicAuthSignUp(ctx context.Context, params model.BasicAuthSignupInput) (*model.BasicAuthSignupResponse, error) {
|
func (r *mutationResolver) BasicAuthSignUp(ctx context.Context, params model.BasicAuthSignupInput) (*model.BasicAuthSignupResponse, error) {
|
||||||
var res *model.BasicAuthSignupResponse
|
var res *model.BasicAuthSignupResponse
|
||||||
if params.CofirmPassword != params.Password {
|
if params.CofirmPassword != params.Password {
|
||||||
|
|
|
@ -21,8 +21,8 @@ func main() {
|
||||||
|
|
||||||
srv := handler.NewDefaultServer(generated.NewExecutableSchema(generated.Config{Resolvers: &graph.Resolver{}}))
|
srv := handler.NewDefaultServer(generated.NewExecutableSchema(generated.Config{Resolvers: &graph.Resolver{}}))
|
||||||
|
|
||||||
http.Handle("/", playground.Handler("GraphQL playground", "/query"))
|
http.Handle("/", playground.Handler("GraphQL playground", "/graphql"))
|
||||||
http.Handle("/query", srv)
|
http.Handle("/graphql", srv)
|
||||||
|
|
||||||
log.Printf("connect to http://localhost:%s/ for GraphQL playground", port)
|
log.Printf("connect to http://localhost:%s/ for GraphQL playground", port)
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@ type UserInfo struct {
|
||||||
Email string `json:"email"`
|
Email string `json:"email"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type CustomClaimsExample struct {
|
type CustomClaim struct {
|
||||||
*jwt.StandardClaims
|
*jwt.StandardClaims
|
||||||
TokenType string `json:"token_type"`
|
TokenType string `json:"token_type"`
|
||||||
UserInfo
|
UserInfo
|
||||||
|
@ -21,7 +21,7 @@ type CustomClaimsExample struct {
|
||||||
func CreateVerificationToken(email string, tokenType string) (string, error) {
|
func CreateVerificationToken(email string, tokenType string) (string, error) {
|
||||||
t := jwt.New(jwt.GetSigningMethod(constants.JWT_TYPE))
|
t := jwt.New(jwt.GetSigningMethod(constants.JWT_TYPE))
|
||||||
|
|
||||||
t.Claims = &CustomClaimsExample{
|
t.Claims = &CustomClaim{
|
||||||
&jwt.StandardClaims{
|
&jwt.StandardClaims{
|
||||||
|
|
||||||
ExpiresAt: time.Now().Add(time.Minute * 30).Unix(),
|
ExpiresAt: time.Now().Add(time.Minute * 30).Unix(),
|
||||||
|
@ -33,17 +33,14 @@ func CreateVerificationToken(email string, tokenType string) (string, error) {
|
||||||
return t.SignedString([]byte(constants.JWT_SECRET))
|
return t.SignedString([]byte(constants.JWT_SECRET))
|
||||||
}
|
}
|
||||||
|
|
||||||
func VerifyVerificationToken(email string, tokenType string) (string, error) {
|
func VerifyVerificationToken(token string) (*CustomClaim, error) {
|
||||||
t := jwt.New(jwt.GetSigningMethod(constants.JWT_TYPE))
|
claims := &CustomClaim{}
|
||||||
|
_, err := jwt.ParseWithClaims(token, claims, func(token *jwt.Token) (interface{}, error) {
|
||||||
t.Claims = &CustomClaimsExample{
|
return []byte(constants.JWT_SECRET), nil
|
||||||
&jwt.StandardClaims{
|
})
|
||||||
|
if err != nil {
|
||||||
ExpiresAt: time.Now().Add(time.Minute * 30).Unix(),
|
return claims, err
|
||||||
},
|
|
||||||
tokenType,
|
|
||||||
UserInfo{Email: email},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return t.SignedString([]byte(constants.JWT_SECRET))
|
return claims, nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user