2015-10-01 39 views
4

我正在构建一个简单的内容拦截应用程序。 它的工作原理,但我想应用UISwitches(保存到NSUserDefaults)过滤器(哪些网络阻止和哪些不)。 因为内容阻塞扩展使用JSON,所以我不清楚如何选择多个JSON文件同时工作。用于Safari内容拦截的多个过滤器Swift

任何想法如何实现?多个扩展?以某种方式组合和分割json文件?

+0

嘿大卫,即使我有这个类似的要求,并寻找灵魂。你有这样做吗? –

回答

0

我一直处于同样的情况。对此的回答有点棘手,请耐心等待。您不能写入文件,即blockerList.json不可写入。以下是你需要做什么,

  1. TARGETS启用应用程序组 - >YOUR MAIN APP - >Capabilities - >App Groups。并为应用程序组添加唯一标识符。与扩展名相同。 (使用与您为主应用程序输入的组名相同的标识符)
  2. 在Container目录中创建文件。
  3. 将规则(json)写入该文件。
  4. 重新加载扩展程序,一旦你有书面规则。
  5. 从内容阻塞扩展中的容器目录读取规则。

从您的主应用程序创建的文件,并写入JSON规则到该文件中:

let jsonData = try! JSONSerialization.data(withJSONObject: webFilters, options: JSONSerialization.WritingOptions.prettyPrinted) 

//Convert back to string. Usually only do this for debugging 

if let JSONString = String(data: jsonData, encoding: String.Encoding.utf8) { 

         let file = "conbo.json" 


         if let dir = FileManager.default.containerURL(forSecurityApplicationGroupIdentifier: "YOUR_GROUP_IDENTIFIER") { 

          let path  = dir.appendingPathComponent(file) 

          do { 

           try JSONString.write(to: path, atomically: false, encoding: String.Encoding.utf8) 

           let id = "YOUR_CONTENT_BLOCKER_BUNDLE_IDENTIFIER" 
           SFContentBlockerManager.reloadContentBlocker(withIdentifier: id) {error in 



            guard error == nil else { 
             print(error ?? "Error") 
             return 
            } 

            print("Reloaded") 
           } 

          } 
          catch { 
          } 
         } 


        } 

现在延长从容器中读取文件:

class ContentBlockerRequestHandler: NSObject, NSExtensionRequestHandling { 

func beginRequest(with context: NSExtensionContext) { 

    let file = "conbo.json" 


    if let dir = FileManager.default.containerURL(forSecurityApplicationGroupIdentifier: "YOUR_APP_GROUP_IDENTIFIER") { 

     let path  = dir.appendingPathComponent(file) 

     do { 



      do { 
       let attachment = NSItemProvider(contentsOf: path)! 

       let item = NSExtensionItem() 
       item.attachments = [attachment] 

       context.completeRequest(returningItems: [item], completionHandler: nil) 


      } 



     } 

    } 



} 



}