问题描述
我是一个相当新鲜的Flutter程序员,所以请原谅以下问题中的任何缺陷……
我在结构/建筑困境中挣扎。这是背景: 应用原理:
- 我的应用程序允许其用户检查其所在地区的少量工作,以及他们是否有时间并且在适当的位置执行工作以获取报酬,
- 该应用使用标准的REST API(不是Firebase),因此不能依赖服务器发送状态更改通知来触发数据的重新获取,
- 关键要素是(1)给定地址的最新作业列表-其他用户可能已经在该地址进行了作业(定时刷新列表,例如每5分钟刷新一次),以及(2)应用需要跟踪用户的位置,并在不到刷新时间的情况下,如果用户重新定位的距离超过2公里,则向服务器询问作业,
挑战:
- 我猜该应用程序应该在基本级别上具有以下提供程序:(1)auth –提供authToken,(2)地理位置–定期检查用户的位置,(3)jobList-针对特定位置(获取高级职位) descriptions andaddresss(,(4)jobDetails –获取有关执行特定作业的确切说明,
- 您将看到:(2)地理位置和(3)jobList –需要以编程方式刷新(每隔一段时间或在地理位置发生某些更改时),而(1)auth,(4)jobDetails由用户触发。
最大的问题;)是……上述类型的应用程序的正确架构是什么?更具体地说:
- 我应该使用服务来连接服务器API吗,这些服务又将由提供商使用?
- 如何确保在计时器和重定位事件中以编程方式从地理位置重新获取jobList?
- 如何持续聆听位置变化以检测重定位,但又不会因处理而淹没应用程序?
- 我应该只在其对象类中存储(快速过时的)jobLIst数据,还是应该使用设置提供程序或本地数据库,或者是否可以通过一种简单的方法来存储最新的JSON响应而不必构建设置提供程序或数据库映射?
- 在我对Auth api的所有调用中,我需要提供deviceid-如何使其在整个应用程序中可用-这是非常静态的,但是在身份验证中是必需的,因此应检查它是否是auth提供程序的一部分? >
如果您可以对以上内容发表评论或提出相关示例的信息,我将不胜感激。
谢谢和欢呼!
解决方法
这是我的想法:
- 如何持续聆听位置变化以检测重定位,但又不会因处理而淹没应用程序?
您可以依靠第三方为您执行此操作。如:geolocator。这样,您可以指定用户在软件包通知您用户位置更改之前用户必须移动的距离。
- 我应该将(很快过时的)jobLIst数据存储在其对象类中还是...
由于工作清单应用程序可能经常在各个地方使用此数据,因此我更喜欢使用db。如果您打算在移动端进行某种分析或收集任何见解,从长远来看也将很有帮助。
- 在我对Auth api的所有调用中,我需要提供deviceId-如何使其在整个应用程序中都可用...
初始化应用后,您可以获取设备ID并将其存储在shared_preferences中。然后在auth api中,您可以在进行API调用之前检索它。
- 我应该使用服务来连接服务器API吗,这些服务又将由提供商使用?
对于地理位置,geolocator可以向您更新位置的变化,并且您可以基于此进行API调用。
但是,如果您打算采用基于计时器的方法来刷新您的工作清单,那么您必须意识到,用户可能会面临因数据不一致而引起的问题。如果您有解决的计划,那么此implementation here可能会有所帮助。但我强烈认为,支持推送通知或Web套接字方法的服务器在这里很理想。