Example #1
0
        public async Task <IActionResult> Create([FromBody] AdDesignModels.Create.Request request)
        {
            // Check session validation
            if (await CheckSessionValidationAndSignOutAsync() == false)
            {
                return(APIResponse(ErrorCode.InvalidSession));
            }

            // Check valid parameters
            if (request == null || request.IsValidParameters() == false)
            {
                return(APIResponse(ErrorCode.InvalidParameters));
            }

            // Check validation
            CampaignData campaignData = new CampaignData();

            if (await campaignData.FromDBAsync(request.CampaignId) == false)
            {
                return(APIResponse(ErrorCode.InvalidParameters));
            }

            if (campaignData.UserId != UserId)
            {
                return(APIResponse(ErrorCode.BadRequest));
            }

            AdResourceData adResourceData = new AdResourceData();

            if (await adResourceData.FromDBAsync(request.AdResourceId) == false)
            {
                return(APIResponse(ErrorCode.InvalidParameters));
            }

            // Insert to db
            var insertQuery = new DBQuery_AdDesign_Insert();
            var item        = insertQuery.IN.Item;

            request.Copy(item);
            item.UserId       = UserId;
            item.AdDesignId   = IDGenerator.NewAdDesignId;
            item.AdDesignType = adResourceData.AdDesignType;

            if (await DBThread.Instance.ReqQueryAsync(insertQuery) == false)
            {
                return(APIResponse(ErrorCode.DatabaseError));
            }

            // Response
            var response = new AdDesignModels.Create.Response();

            if (await response.FromDBAsync(item.AdDesignId) == false)
            {
                return(APIResponse(ErrorCode.DatabaseError));
            }

            return(Success(response));
        }
Example #2
0
        public async Task <IActionResult> Modify([FromBody] AdDesignModels.Modify.Request request)
        {
            // Check session validation
            if (await CheckSessionValidationAndSignOutAsync() == false)
            {
                return(APIResponse(ErrorCode.InvalidSession));
            }

            // Check valid parameters
            if (request == null || request.IsValidParameters() == false)
            {
                return(APIResponse(ErrorCode.InvalidParameters));
            }

            DBKey        adDesignId   = request.AdDesignId;
            AdDesignData adDesignData = new AdDesignData();

            // Check validation
            if (await adDesignData.FromDBAsync(adDesignId) == false)
            {
                return(APIResponse(ErrorCode.InvalidParameters));
            }

            if (UserId != adDesignData.UserId)
            {
                return(APIResponse(ErrorCode.BadRequest));
            }

            AdResourceData adResourceData = new AdResourceData();

            if (await adResourceData.FromDBAsync(request.AdResourceId) == false)
            {
                return(APIResponse(ErrorCode.InvalidParameters));
            }

            // Update to db
            var updateQuery = new DBQuery_AdDesign_Update();
            var item        = updateQuery.IN.Item;

            request.Copy(item);
            item.UserId       = UserId;
            item.AdDesignType = adResourceData.AdDesignType;
            if (await DBThread.Instance.ReqQueryAsync(updateQuery) == false)
            {
                return(APIResponse(ErrorCode.DatabaseError));
            }

            // Response
            var response = new AdDesignModels.Modify.Response();

            if (await response.FromDBAsync(item.AdDesignId) == false)
            {
                return(APIResponse(ErrorCode.DatabaseError));
            }

            return(Success(response));
        }
Example #3
0
 public bool FromDataTable(DataTable table)
 {
     try
     {
         foreach (DataRow row in table.Rows)
         {
             var item = new AdResourceData();
             item.FromDBTable(row);
             Items.Add(item);
         }
         return(true);
     }
     catch
     {
         return(false);
     }
 }
Example #4
0
        public async Task <IActionResult> Delete([FromBody] AdResourceModels.Delete.Request request)
        {
            // Check session validation
            if (await CheckSessionValidationAndSignOutAsync() == false)
            {
                return(APIResponse(ErrorCode.InvalidSession));
            }

            // Check valid parameters
            if (request == null || request.IsValidParameters() == false)
            {
                return(APIResponse(ErrorCode.InvalidParameters));
            }

            DBKey          adResourceId   = request.AdResourceId;
            AdResourceData adResourceData = new AdResourceData();

            // Check validation
            if (await adResourceData.FromDBAsync(adResourceId) == false)
            {
                return(APIResponse(ErrorCode.DatabaseError));
            }

            if (UserId != adResourceData.UserId)
            {
                return(APIResponse(ErrorCode.BadRequest));
            }

            // Delete from db
            var deleteQuery = new DBQuery_AdResource_Delete();

            deleteQuery.IN.DBKey = request.AdResourceId;
            if (await DBThread.Instance.ReqQueryAsync(deleteQuery) == false)
            {
                return(APIResponse(ErrorCode.DatabaseError));
            }

            // Response
            return(Success());
        }