Added link info endpoint
This commit is contained in:
		
							
								
								
									
										12
									
								
								5feet11.api
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								5feet11.api
									
									
									
									
									
								
							| @@ -27,10 +27,22 @@ type ( | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| type ( | ||||
| 	GetLinkResp { | ||||
| 		ID        string `json:"id"` | ||||
| 		LongUrl   string `json:"longUrl"` | ||||
| 		CreatedAt string `json:"createdAt"` | ||||
| 		Lifespan  int64  `json:"lifespan"` | ||||
| 	} | ||||
| ) | ||||
|  | ||||
| service fivefeeteleven-api { | ||||
| 	@handler ExpandUrl | ||||
| 	get /:id(ExpandReq) returns(ExpandResp) | ||||
| 	 | ||||
| 	@handler ShortenUrl | ||||
| 	post /api/v1/links(ShortenReq) returns(ShortenResp) | ||||
| 	 | ||||
| 	@handler GetLink | ||||
| 	get /api/v1/links/:id(ExpandReq) returns(GetLinkResp) | ||||
| } | ||||
| @@ -8,7 +8,7 @@ import ( | ||||
|  | ||||
| var UrlTable = table.New(table.Metadata{ | ||||
| 	Name:    "fivefeeteleven.urls", | ||||
| 	Columns: []string{"id", "long_url", "created_at"}, | ||||
| 	Columns: []string{"id", "long_url", "lifespan", "created_at"}, | ||||
| 	PartKey: []string{"id"}, | ||||
| 	SortKey: []string{}, | ||||
| }) | ||||
| @@ -16,5 +16,6 @@ var UrlTable = table.New(table.Metadata{ | ||||
| type UrlModel struct { | ||||
| 	ID        string | ||||
| 	LongUrl   string | ||||
| 	Lifespan  int64 | ||||
| 	CreatedAt time.Time | ||||
| } | ||||
|   | ||||
| @@ -16,7 +16,8 @@ func Seed(session gocqlx.Session) error { | ||||
| 		CREATE TABLE IF NOT EXISTS fivefeeteleven.urls ( | ||||
| 			id text PRIMARY KEY, | ||||
| 			long_url text, | ||||
| 			created_at timestamp | ||||
| 			created_at timestamp, | ||||
| 			lifespan bigint | ||||
| 		)`) | ||||
|  | ||||
| 	if err != nil { | ||||
|   | ||||
							
								
								
									
										28
									
								
								internal/handler/getlinkhandler.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								internal/handler/getlinkhandler.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | ||||
| package handler | ||||
|  | ||||
| import ( | ||||
| 	"net/http" | ||||
|  | ||||
| 	"5feet11/internal/logic" | ||||
| 	"5feet11/internal/svc" | ||||
| 	"5feet11/internal/types" | ||||
| 	"github.com/zeromicro/go-zero/rest/httpx" | ||||
| ) | ||||
|  | ||||
| func GetLinkHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||||
| 	return func(w http.ResponseWriter, r *http.Request) { | ||||
| 		var req types.ExpandReq | ||||
| 		if err := httpx.Parse(r, &req); err != nil { | ||||
| 			httpx.Error(w, err) | ||||
| 			return | ||||
| 		} | ||||
|  | ||||
| 		l := logic.NewGetLinkLogic(r.Context(), svcCtx) | ||||
| 		resp, err := l.GetLink(&req) | ||||
| 		if err != nil { | ||||
| 			httpx.Error(w, err) | ||||
| 		} else { | ||||
| 			httpx.OkJson(w, resp) | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @@ -22,6 +22,11 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) { | ||||
| 				Path:    "/api/v1/links", | ||||
| 				Handler: ShortenUrlHandler(serverCtx), | ||||
| 			}, | ||||
| 			{ | ||||
| 				Method:  http.MethodGet, | ||||
| 				Path:    "/api/v1/links/:id", | ||||
| 				Handler: GetLinkHandler(serverCtx), | ||||
| 			}, | ||||
| 		}, | ||||
| 	) | ||||
| } | ||||
|   | ||||
							
								
								
									
										49
									
								
								internal/logic/getlinklogic.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								internal/logic/getlinklogic.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | ||||
| package logic | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"fmt" | ||||
|  | ||||
| 	"5feet11/internal/db" | ||||
| 	"5feet11/internal/svc" | ||||
| 	"5feet11/internal/types" | ||||
|  | ||||
| 	"github.com/zeromicro/go-zero/core/logx" | ||||
| ) | ||||
|  | ||||
| type GetLinkLogic struct { | ||||
| 	logx.Logger | ||||
| 	ctx    context.Context | ||||
| 	svcCtx *svc.ServiceContext | ||||
| } | ||||
|  | ||||
| func NewGetLinkLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetLinkLogic { | ||||
| 	return &GetLinkLogic{ | ||||
| 		Logger: logx.WithContext(ctx), | ||||
| 		ctx:    ctx, | ||||
| 		svcCtx: svcCtx, | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (l *GetLinkLogic) GetLink(req *types.ExpandReq) (resp *types.GetLinkResp, err error) { | ||||
| 	queryUrl := db.UrlTable.SelectQuery(l.svcCtx.DB) | ||||
| 	queryUrl.BindStruct(db.UrlModel{ID: req.ID}) | ||||
|  | ||||
| 	var urls []db.UrlModel | ||||
| 	if err := queryUrl.Select(&urls); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	if len(urls) != 1 { | ||||
| 		return nil, fmt.Errorf("no URL found") | ||||
| 	} | ||||
|  | ||||
| 	resp = &types.GetLinkResp{ | ||||
| 		ID:        urls[0].ID, | ||||
| 		LongUrl:   urls[0].LongUrl, | ||||
| 		CreatedAt: urls[0].CreatedAt.String(), | ||||
| 		Lifespan:  urls[0].Lifespan, | ||||
| 	} | ||||
|  | ||||
| 	return resp, err | ||||
| } | ||||
| @@ -38,6 +38,7 @@ func (l *ShortenUrlLogic) ShortenUrl(req *types.ShortenReq) (resp *types.Shorten | ||||
| 	insertUrl.BindStruct(db.UrlModel{ | ||||
| 		ID:        id, | ||||
| 		LongUrl:   req.LongUrl, | ||||
| 		Lifespan:  req.ExpiresAfter, | ||||
| 		CreatedAt: time.Now(), | ||||
| 	}) | ||||
|  | ||||
| @@ -48,5 +49,6 @@ func (l *ShortenUrlLogic) ShortenUrl(req *types.ShortenReq) (resp *types.Shorten | ||||
| 	resp = &types.ShortenResp{ | ||||
| 		ID: id, | ||||
| 	} | ||||
|  | ||||
| 	return resp, nil | ||||
| } | ||||
|   | ||||
| @@ -17,3 +17,10 @@ type ShortenReq struct { | ||||
| type ShortenResp struct { | ||||
| 	ID string `json:"id"` | ||||
| } | ||||
|  | ||||
| type GetLinkResp struct { | ||||
| 	ID        string `json:"id"` | ||||
| 	LongUrl   string `json:"longUrl"` | ||||
| 	CreatedAt string `json:"createdAt"` | ||||
| 	Lifespan  int64  `json:"lifespan"` | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user