aboutsummaryrefslogtreecommitdiff
path: root/backend/api
diff options
context:
space:
mode:
Diffstat (limited to 'backend/api')
-rw-r--r--backend/api/api/Controllers/DatasetController.cs4
-rw-r--r--backend/api/api/Controllers/ModelController.cs74
-rw-r--r--backend/api/api/Interfaces/IUserStoreDatabaseSettings.cs1
-rw-r--r--backend/api/api/Models/Dataset.cs2
-rw-r--r--backend/api/api/Program.cs2
-rw-r--r--backend/api/api/Services/IModelService.cs15
-rw-r--r--backend/api/api/Services/ModelService.cs47
-rw-r--r--backend/api/api/appsettings.json6
8 files changed, 144 insertions, 7 deletions
diff --git a/backend/api/api/Controllers/DatasetController.cs b/backend/api/api/Controllers/DatasetController.cs
index fcebc4b0..8ad92149 100644
--- a/backend/api/api/Controllers/DatasetController.cs
+++ b/backend/api/api/Controllers/DatasetController.cs
@@ -41,9 +41,9 @@ namespace api.Controllers
[HttpPost("post")]
public ActionResult<Dataset> Post([FromBody] Dataset dataset)
{
- var existingUser = _datasetService.GetOneDataset(dataset.uploaderId,dataset.name);
+ var existingDataset = _datasetService.GetOneDataset(dataset.uploaderId,dataset.name);
- if (existingUser != null)
+ if (existingDataset != null)
return NotFound($"Dateset with name = {dataset.name} exisits");
else
{
diff --git a/backend/api/api/Controllers/ModelController.cs b/backend/api/api/Controllers/ModelController.cs
index 5e22c61d..ac45f45b 100644
--- a/backend/api/api/Controllers/ModelController.cs
+++ b/backend/api/api/Controllers/ModelController.cs
@@ -1,4 +1,5 @@
-using api.Services;
+using api.Models;
+using api.Services;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
@@ -11,10 +12,13 @@ namespace api.Controllers
{
private IMlConnectionService _mlService;
+ private readonly IModelService _modelService;
+
- public ModelController(IMlConnectionService mlService)
+ public ModelController(IMlConnectionService mlService, IModelService modelService)
{
_mlService = mlService;
+ _modelService = modelService;
}
[HttpPost("sendModel")]
@@ -25,5 +29,71 @@ namespace api.Controllers
return Ok(result);
}
+ //id korisnika
+ // GET: api/<ModelController>/{id}/datasets
+ [HttpGet("{id}/models")]
+ public ActionResult<List<Model>> Get(string id)
+ {
+ return _modelService.GetAllModels(id);
+ }
+
+ //id korisnika, name modela
+ // GET api/<ModelController>/{id}/{name}
+ [HttpGet("{id}/{name}")]
+ public ActionResult<Model> Get(string id, string name)
+ {
+ var model = _modelService.GetOneModel(id, name);
+
+ if (model == null)
+ return NotFound($"Model with name = {name} or user with id = {id} not found");
+
+ return model;
+ }
+
+ // POST api/<ModelController>/post
+ [HttpPost("post")]
+ public ActionResult<Model> Post([FromBody] Model model)
+ {
+ var existingModel = _modelService.GetOneModel(model.uploaderId, model.name);
+
+ if (existingModel != null)
+ return NotFound($"Model with name = {model.name} exisits");
+ else
+ {
+ _modelService.Create(model);
+
+ return CreatedAtAction(nameof(Get), new { id = model._id }, model);
+ }
+ }
+
+ // PUT api/<ModelController>/{id}/{name}
+ [HttpPut("{id}/{name}")]
+ public ActionResult Put(string id, string name, [FromBody] Model model)
+ {
+ var existingModel = _modelService.GetOneModel(id, name);
+
+ //ne mora da se proverava
+ if (existingModel == null)
+ return NotFound($"Model with name = {name} or user with id = {id} not found");
+
+ _modelService.Update(id, name, model);
+ return NoContent();
+ }
+
+ // DELETE api/<ModelController>/5
+ [HttpDelete("{id}")]
+ public ActionResult Delete(string id, string name)
+ {
+ var model = _modelService.GetOneModel(id, name);
+
+ if (model == null)
+ return NotFound($"Model with name = {name} or user with id = {id} not found");
+
+ _modelService.Delete(model.uploaderId, model.name);
+
+ return Ok($"Model with name = {name} deleted");
+
+ }
+
}
}
diff --git a/backend/api/api/Interfaces/IUserStoreDatabaseSettings.cs b/backend/api/api/Interfaces/IUserStoreDatabaseSettings.cs
index 8d2a175f..46ece53c 100644
--- a/backend/api/api/Interfaces/IUserStoreDatabaseSettings.cs
+++ b/backend/api/api/Interfaces/IUserStoreDatabaseSettings.cs
@@ -6,5 +6,6 @@
string DatabaseName { get; set; }
string CollectionName { get; set; }
string DatasetCollectionName { get; set; }
+ string ModelCollectionName { get; }
}
}
diff --git a/backend/api/api/Models/Dataset.cs b/backend/api/api/Models/Dataset.cs
index d58b3143..de88fd4f 100644
--- a/backend/api/api/Models/Dataset.cs
+++ b/backend/api/api/Models/Dataset.cs
@@ -13,7 +13,7 @@ namespace api.Models
public string _id { get; set; }
public string name { get; set; }
public string description { get; set; }
- public string header { get; set; }
+ public string[] header { get; set; }
public int fileId { get; set; }
public string extension { get; set; }
public bool isPublic { get; set; }
diff --git a/backend/api/api/Program.cs b/backend/api/api/Program.cs
index 702ef259..24cc5cfe 100644
--- a/backend/api/api/Program.cs
+++ b/backend/api/api/Program.cs
@@ -29,6 +29,8 @@ builder.Services.AddScoped<IDatasetService, DatasetService>();
builder.Services.AddScoped<IUserService, UserService>();
builder.Services.AddScoped<IAuthService, AuthService>();
builder.Services.AddScoped<IMlConnectionService, MlConnectionService>();
+builder.Services.AddScoped<IModelService, ModelService>();
+
//Add Authentication
builder.Services.AddAuthentication(
diff --git a/backend/api/api/Services/IModelService.cs b/backend/api/api/Services/IModelService.cs
new file mode 100644
index 00000000..988f3ab9
--- /dev/null
+++ b/backend/api/api/Services/IModelService.cs
@@ -0,0 +1,15 @@
+using System;
+using api.Models;
+
+namespace api.Services
+{
+ public interface IModelService
+ {
+ Model GetOneModel(string uploaderId, string name);
+ List<Model> GetAllModels(string uploaderId);
+ Model Create(Model model);
+ void Update(string uploaderId, string name, Model model);
+ void Delete(string uploaderId, string name);
+ }
+}
+
diff --git a/backend/api/api/Services/ModelService.cs b/backend/api/api/Services/ModelService.cs
new file mode 100644
index 00000000..97402d90
--- /dev/null
+++ b/backend/api/api/Services/ModelService.cs
@@ -0,0 +1,47 @@
+using System;
+using api.Interfaces;
+using api.Models;
+using MongoDB.Driver;
+
+namespace api.Services
+{
+ public class ModelService : IModelService
+ {
+
+ private readonly IMongoCollection<Model> _model;
+
+ public ModelService(IUserStoreDatabaseSettings settings, IMongoClient mongoClient)
+ {
+ var database = mongoClient.GetDatabase(settings.DatabaseName);
+ _model = database.GetCollection<Model>(settings.ModelCollectionName);
+ }
+
+ public Model Create(Model model)
+ {
+ _model.InsertOne(model);
+ return model;
+ }
+
+ public void Delete(string uploaderId, string name)
+ {
+ _model.DeleteOne(model => (model.uploaderId == uploaderId && model.name == name));
+ }
+
+ public List<Model> GetAllModels(string uploaderId)
+ {
+ return _model.Find(model => model.uploaderId == uploaderId).ToList();
+ }
+
+ public Model GetOneModel(string uploaderId, string name)
+ {
+ return _model.Find(model => model.uploaderId == uploaderId && model.name == name).FirstOrDefault();
+ }
+
+ public void Update(string uploaderId, string name, Model model)
+ {
+ _model.ReplaceOne(model => model.uploaderId == uploaderId && model.name == name, model);
+ }
+
+ }
+}
+
diff --git a/backend/api/api/appsettings.json b/backend/api/api/appsettings.json
index 9b4f00a3..63030c15 100644
--- a/backend/api/api/appsettings.json
+++ b/backend/api/api/appsettings.json
@@ -14,11 +14,13 @@
"ConnectionString": "mongodb://127.0.0.1:27017/",
"DatabaseName": "si_project",
"CollectionName": "User",
- "DatasetCollectionName" : "Dataset"
+ "DatasetCollectionName" : "Dataset",
+ "ModelCollectionName" : "Model"
*/
"ConnectionString": "mongodb+srv://si_user:si_user@sidatabase.twtfm.mongodb.net/myFirstDatabase?retryWrites=true&w=majority",
"DatabaseName": "si_db",
"CollectionName": "users",
- "DatasetCollectionName": "Dataset"
+ "DatasetCollectionName": "Dataset",
+ "ModelCollectionName": "Model"
}
}