Есть ли более эффективный способ определить класс в Swift для обработки вызовов API? [закрыто]IOS

Программируем под IOS
Ответить
Anonymous
 Есть ли более эффективный способ определить класс в Swift для обработки вызовов API? [закрыто]

Сообщение Anonymous »

Я в настоящее время изучаю Swift и пытаюсь реализовать сетевого менеджера, который выполняет вызовы API (Get and Post).
Вот моя текущая реализация: < /p>
import Foundation

protocol ProductManagerDelegate {
func didUploadProducts(products: [ProductModel])
}

struct ProductManager {

let productURL = "https://fakestoreapi.com/products"

var delegate: ProductManagerDelegate?

func fetchProducts() {
performRequest(stringUrl: productURL)
}

func performRequest(stringUrl: String) {
let url = URL(string: stringUrl)!

let task = URLSession.shared.dataTask(with: url) { (data, response, error) in
if let error = error {
print("Error: \(error)")
return
}

if let responseData = data {
if let products = self.parseJSON(productData: responseData) {
self.delegate?.didUploadProducts(products: products)
}
}
}
task.resume()
}

func parseJSON(productData: Data) -> [ProductModel]? {
let decoder = JSONDecoder()
do {
let decodedData = try decoder.decode([ProductData].self, from: productData)
var products: [ProductModel] = []

for product in decodedData {
let productModel = ProductModel(
title: product.title,
price: product.price,
description: product.description,
category: product.category,
image: product.image
)
products.append(productModel)
}
return products
} catch {
print(error)
return nil
}
}

func createProduct(product: ProductPostRequest) {
let url = URL(string: productURL)!
var request = URLRequest(url: url)
request.httpMethod = "POST"
request.setValue("application/json", forHTTPHeaderField: "Content-Type")

do {
request.httpBody = try JSONEncoder().encode(product)
} catch {
print("Failed to encode product \(error)")
return
}

let task = URLSession.shared.dataTask(with: request) { data, response, error in
guard let data = data, error == nil else {
print(error?.localizedDescription ?? "No data")
return
}
let responseJSON = try? JSONSerialization.jsonObject(with: data, options: [])
if let responseJSON = responseJSON as? [String: Any] {
print("response json: \(responseJSON)")
}
}
task.resume()
}
}

< /code>
Я попытался внедрить структуру ProductManager, которая выполняет как GET, так и публикацию запросов с использованием URLSession.
Код работает - я могу приносить продукты, а также создавать новые. < /p>
Что я ожидал: < /p>
Чистый и повторный сетевой менеджер для API. /> Код кажется повторяющимся и не очень масштабируемым.
Я не уверен, что использование структуры с делегатом является лучшим подходом, или я должен использовать класс, асинхро>

Подробнее здесь: https://stackoverflow.com/questions/797 ... -api-calls
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «IOS»