mirror of https://github.com/pikami/cosmium.git
Added Collections CRUD
This commit is contained in:
parent
f30d0528bc
commit
5dc7d87fba
|
@ -0,0 +1,84 @@
|
|||
package handlers
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
"github.com/pikami/cosmium/internal/repositories"
|
||||
)
|
||||
|
||||
func GetAllCollections(c *gin.Context) {
|
||||
databaseId := c.Param("databaseId")
|
||||
|
||||
collections, status := repositories.GetAllCollections(databaseId)
|
||||
if status == repositories.StatusOk {
|
||||
c.IndentedJSON(http.StatusOK, gin.H{"_rid": "", "DocumentCollections": collections})
|
||||
return
|
||||
}
|
||||
|
||||
c.IndentedJSON(http.StatusInternalServerError, gin.H{"message": "Unknown error"})
|
||||
}
|
||||
|
||||
func GetCollection(c *gin.Context) {
|
||||
databaseId := c.Param("databaseId")
|
||||
id := c.Param("collId")
|
||||
|
||||
collection, status := repositories.GetCollection(databaseId, id)
|
||||
if status == repositories.StatusOk {
|
||||
c.IndentedJSON(http.StatusOK, collection)
|
||||
return
|
||||
}
|
||||
|
||||
if status == repositories.StatusNotFound {
|
||||
c.IndentedJSON(http.StatusNotFound, gin.H{"message": "NotFound"})
|
||||
return
|
||||
}
|
||||
|
||||
c.IndentedJSON(http.StatusInternalServerError, gin.H{"message": "Unknown error"})
|
||||
}
|
||||
|
||||
func DeleteCollection(c *gin.Context) {
|
||||
databaseId := c.Param("databaseId")
|
||||
id := c.Param("collId")
|
||||
|
||||
status := repositories.DeleteCollection(databaseId, id)
|
||||
if status == repositories.StatusOk {
|
||||
c.Status(http.StatusNoContent)
|
||||
return
|
||||
}
|
||||
|
||||
if status == repositories.StatusNotFound {
|
||||
c.IndentedJSON(http.StatusNotFound, gin.H{"message": "NotFound"})
|
||||
return
|
||||
}
|
||||
|
||||
c.IndentedJSON(http.StatusInternalServerError, gin.H{"message": "Unknown error"})
|
||||
}
|
||||
|
||||
func CreateCollection(c *gin.Context) {
|
||||
databaseId := c.Param("databaseId")
|
||||
var newCollection repositories.Collection
|
||||
|
||||
if err := c.BindJSON(&newCollection); err != nil {
|
||||
c.JSON(http.StatusBadRequest, gin.H{"message": err.Error()})
|
||||
return
|
||||
}
|
||||
|
||||
if newCollection.ID == "" {
|
||||
c.JSON(http.StatusBadRequest, gin.H{"message": "BadRequest"})
|
||||
return
|
||||
}
|
||||
|
||||
status := repositories.CreateCollection(databaseId, newCollection)
|
||||
if status == repositories.Conflict {
|
||||
c.IndentedJSON(http.StatusConflict, gin.H{"message": "Conflict"})
|
||||
return
|
||||
}
|
||||
|
||||
if status == repositories.StatusOk {
|
||||
c.IndentedJSON(http.StatusCreated, newCollection)
|
||||
return
|
||||
}
|
||||
|
||||
c.IndentedJSON(http.StatusInternalServerError, gin.H{"message": "Unknown error"})
|
||||
}
|
|
@ -18,7 +18,7 @@ func GetAllDatabases(c *gin.Context) {
|
|||
}
|
||||
|
||||
func GetDatabase(c *gin.Context) {
|
||||
id := c.Param("id")
|
||||
id := c.Param("databaseId")
|
||||
|
||||
database, status := repositories.GetDatabase(id)
|
||||
if status == repositories.StatusOk {
|
||||
|
@ -35,7 +35,7 @@ func GetDatabase(c *gin.Context) {
|
|||
}
|
||||
|
||||
func DeleteDatabase(c *gin.Context) {
|
||||
id := c.Param("id")
|
||||
id := c.Param("databaseId")
|
||||
|
||||
status := repositories.DeleteDatabase(id)
|
||||
if status == repositories.StatusOk {
|
||||
|
|
|
@ -8,10 +8,16 @@ import (
|
|||
func CreateRouter() *gin.Engine {
|
||||
router := gin.Default()
|
||||
|
||||
router.GET("/dbs/:id", handlers.GetDatabase)
|
||||
router.DELETE("/dbs/:id", handlers.DeleteDatabase)
|
||||
router.GET("/dbs", handlers.GetAllDatabases)
|
||||
router.POST("/dbs/:databaseId/colls", handlers.CreateCollection)
|
||||
router.GET("/dbs/:databaseId/colls", handlers.GetAllCollections)
|
||||
router.GET("/dbs/:databaseId/colls/:collId", handlers.GetCollection)
|
||||
router.DELETE("/dbs/:databaseId/colls/:collId", handlers.DeleteCollection)
|
||||
|
||||
router.POST("/dbs", handlers.CreateDatabase)
|
||||
router.GET("/dbs", handlers.GetAllDatabases)
|
||||
router.GET("/dbs/:databaseId", handlers.GetDatabase)
|
||||
router.DELETE("/dbs/:databaseId", handlers.DeleteDatabase)
|
||||
|
||||
router.GET("/", handlers.GetServerInfo)
|
||||
|
||||
return router
|
||||
|
|
|
@ -0,0 +1,50 @@
|
|||
package repositories
|
||||
|
||||
var collections = []Collection{
|
||||
{ID: "db1"},
|
||||
{ID: "db2"},
|
||||
}
|
||||
|
||||
func GetAllCollections(databaseId string) ([]Collection, RepositoryStatus) {
|
||||
var dbCollections []Collection
|
||||
|
||||
for _, coll := range collections {
|
||||
if coll.internals.databaseId == databaseId {
|
||||
dbCollections = append(dbCollections, coll)
|
||||
}
|
||||
}
|
||||
|
||||
return dbCollections, StatusOk
|
||||
}
|
||||
|
||||
func GetCollection(databaseId string, id string) (Collection, RepositoryStatus) {
|
||||
for _, coll := range collections {
|
||||
if coll.internals.databaseId == databaseId && coll.ID == id {
|
||||
return coll, StatusOk
|
||||
}
|
||||
}
|
||||
|
||||
return Collection{}, StatusNotFound
|
||||
}
|
||||
|
||||
func DeleteCollection(databaseId string, id string) RepositoryStatus {
|
||||
for index, coll := range collections {
|
||||
if coll.internals.databaseId == databaseId && coll.ID == id {
|
||||
collections = append(collections[:index], collections[index+1:]...)
|
||||
return StatusOk
|
||||
}
|
||||
}
|
||||
|
||||
return StatusNotFound
|
||||
}
|
||||
|
||||
func CreateCollection(databaseId string, newCollection Collection) RepositoryStatus {
|
||||
for _, coll := range collections {
|
||||
if coll.internals.databaseId == databaseId && coll.ID == newCollection.ID {
|
||||
return Conflict
|
||||
}
|
||||
}
|
||||
|
||||
collections = append(collections, newCollection)
|
||||
return StatusOk
|
||||
}
|
|
@ -11,3 +11,37 @@ const (
|
|||
StatusNotFound = 2
|
||||
Conflict = 3
|
||||
)
|
||||
|
||||
type Collection struct {
|
||||
ID string `json:"id"`
|
||||
IndexingPolicy struct {
|
||||
IndexingMode string `json:"indexingMode"`
|
||||
Automatic bool `json:"automatic"`
|
||||
IncludedPaths []struct {
|
||||
Path string `json:"path"`
|
||||
Indexes []struct {
|
||||
Kind string `json:"kind"`
|
||||
DataType string `json:"dataType"`
|
||||
Precision int `json:"precision"`
|
||||
} `json:"indexes"`
|
||||
} `json:"includedPaths"`
|
||||
ExcludedPaths []any `json:"excludedPaths"`
|
||||
} `json:"indexingPolicy"`
|
||||
PartitionKey struct {
|
||||
Paths []string `json:"paths"`
|
||||
Kind string `json:"kind"`
|
||||
Version int `json:"Version"`
|
||||
} `json:"partitionKey"`
|
||||
Rid string `json:"_rid"`
|
||||
Ts int `json:"_ts"`
|
||||
Self string `json:"_self"`
|
||||
Etag string `json:"_etag"`
|
||||
Docs string `json:"_docs"`
|
||||
Sprocs string `json:"_sprocs"`
|
||||
Triggers string `json:"_triggers"`
|
||||
Udfs string `json:"_udfs"`
|
||||
Conflicts string `json:"_conflicts"`
|
||||
internals struct {
|
||||
databaseId string
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue