我正在开发一个REST客户机库,最近开始添加对发送批处理消息的支持。你知道吗
但是,我不喜欢现在的设计。它要求您维护具有相同方法签名的大型客户机和RequestMessage类。你知道吗
我正在寻找一种方法来巩固这两个班。你知道吗
原始客户机类的方法包含准备和发送请求所需的所有代码:
class Client(object):
def __init__(self, config):
self.request = Request(config, "application/json")
def create_vertex(self, data):
path = "vertices"
params = remove_null_values(data)
self.request.post(path, params)
为了增加对批处理消息的支持,我从each Client方法中提取了一些代码,并将其放入一个单独的RequestMessage类中,这样您就可以在不发送消息的情况下将消息添加到批处理中,直到您准备好:
class Client(object):
def __init__(self, config):
self.request = Request(config, "application/json")
self.message = RequestMessage(config)
def create_vertex(self, data):
message = self.message.create_vertex(data)
return self.request.send(message)
# ...more REST client methods...
def batch(self, messages):
path = "batch"
params = messages
return self.request.post(path, params)
class RequestMessage(object):
def __init__(self, config):
self.config = config
def create_vertex(self, data):
path = "vertices"
params = remove_null_values(data)
return POST, path, params
# ...more REST client methods...
但是我不喜欢这种设计,因为现在您必须维护Client和RequestMessage类——两个具有相同签名的大型类。你知道吗
下面是批处理类的外观:
class Batch(object):
def __init__(self, client):
self.client = client
self.messages = []
def add(self, message):
self.messages.append(message)
def send(self):
return self.client.batch(self.messages)
下面是在服务器上创建顶点的示例用法:
>>> client = Client(config)
>>> vertex = client.create_vertex({'name':'James'})
下面是在服务器上创建一批顶点的示例用法:
>>> message1 = client.message.create_vertex({'name':'James'})
>>> message2 = client.message.create_vertex({'name':'Julie'})
>>> batch = Batch(client)
>>> batch.add(message1)
>>> batch.add(message2)
>>> batch.send()
批处理的使用频率低于客户机,所以我想让普通的客户机接口更易于使用。你知道吗
这里有一个想法,但我不太确定如何实现它,或者是否有其他更好的方法:
>>> vertex = client.create_vertex(data)
>>> message = client.create_vertex(data).message()
我个人喜欢的API是:
这样你使用完全相同的函数,你只是给它更多的数据。典型用法可能更像:
我同意@Karl的观点,但做了一些修改
这样您就不必检查输入的类型。更容易写,更容易使用。你知道吗
相关问题 更多 >
编程相关推荐