From 4adb994ce48fd2d2f8dd2a9e4675ea615c9581bc Mon Sep 17 00:00:00 2001 From: Mike Schinkel Date: Sat, 23 Mar 2019 22:36:52 -0400 Subject: [PATCH 1/2] Adding RouteNamer interface --- api.go | 6 ++++++ jsonapi/route_namer.go | 9 +++++++++ 2 files changed, 15 insertions(+) create mode 100644 jsonapi/route_namer.go diff --git a/api.go b/api.go index 40893eb..ce6e732 100644 --- a/api.go +++ b/api.go @@ -244,6 +244,12 @@ func (api *API) addResource(prototype jsonapi.MarshalIdentifier, source interfac return info } + // check if EntityNamer interface is implemented and use that as name + routeName, ok := prototype.(jsonapi.RouteNamer) + if ok { + name = routeName.GetRouteName() + } + prefix := strings.Trim(api.info.prefix, "/") baseURL := "/" + name if prefix != "" { diff --git a/jsonapi/route_namer.go b/jsonapi/route_namer.go new file mode 100644 index 0000000..46c77a0 --- /dev/null +++ b/jsonapi/route_namer.go @@ -0,0 +1,9 @@ +package jsonapi + +// The RouteNamer interface can be optionally implemented to directly return the +// name of route used for the "type" field. +// +// Note: By default the name is guessed from the struct name or from EntityNamer. +type RouteNamer interface { + GetRouteName() string +} From cd844dbe1b2d56e0e7b0e0eb98321ca1665f7026 Mon Sep 17 00:00:00 2001 From: Mike Schinkel Date: Sat, 23 Mar 2019 23:58:52 -0400 Subject: [PATCH 2/2] Added getRouteName() --- jsonapi/marshal.go | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/jsonapi/marshal.go b/jsonapi/marshal.go index 2db7250..699f72b 100644 --- a/jsonapi/marshal.go +++ b/jsonapi/marshal.go @@ -393,13 +393,13 @@ func getStructRelationships(relationer MarshalLinkedRelations, information Serve func getLinkBaseURL(element MarshalIdentifier, information ServerInformation) string { prefix := strings.Trim(information.GetBaseURL(), "/") namespace := strings.Trim(information.GetPrefix(), "/") - structType := getStructType(element) + routeName := getRouteName(element) if namespace != "" { prefix += "/" + namespace } - return fmt.Sprintf("%s/%s/%s", prefix, structType, element.GetID()) + return fmt.Sprintf("%s/%s/%s", prefix, routeName, element.GetID()) } func getLinksForServerInformation(relationer MarshalLinkedRelations, name string, information ServerInformation) Links { @@ -458,3 +458,11 @@ func getStructType(data interface{}) string { return Pluralize(Jsonify(reflectType.Name())) } + +func getRouteName(data interface{}) string { + routeName, ok := data.(RouteNamer) + if ok { + return routeName.GetRouteName() + } + return getStructType(data) +}