123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320 |
- //
- // NCCapabilitiesViewController.swift
- // Nextcloud
- //
- // Created by Marino Faggiana on 28/07/2020.
- // Copyright © 2020 Marino Faggiana. All rights reserved.
- //
- // Author Marino Faggiana <marino.faggiana@nextcloud.com>
- //
- // This program is free software: you can redistribute it and/or modify
- // it under the terms of the GNU General Public License as published by
- // the Free Software Foundation, either version 3 of the License, or
- // (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
- // but WITHOUT ANY WARRANTY; without even the implied warranty of
- // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- // GNU General Public License for more details.
- //
- // You should have received a copy of the GNU General Public License
- // along with this program. If not, see <http://www.gnu.org/licenses/>.
- //
- import UIKit
- import NCCommunication
- class NCCapabilitiesViewController: UIViewController, UIDocumentInteractionControllerDelegate {
- @IBOutlet weak var textView: UITextView!
-
- @IBOutlet weak var imageFileSharing: UIImageView!
- @IBOutlet weak var statusFileSharing: UILabel!
-
- @IBOutlet weak var imageExternalSite: UIImageView!
- @IBOutlet weak var statusExternalSite: UILabel!
-
- @IBOutlet weak var imageEndToEndEncryption: UIImageView!
- @IBOutlet weak var statusEndToEndEncryption: UILabel!
-
- @IBOutlet weak var imageActivity: UIImageView!
- @IBOutlet weak var statusActivity: UILabel!
-
- @IBOutlet weak var imageNotification: UIImageView!
- @IBOutlet weak var statusNotification: UILabel!
-
- @IBOutlet weak var imageDeletedFiles: UIImageView!
- @IBOutlet weak var statusDeletedFiles: UILabel!
-
- @IBOutlet weak var imageUserStatus: UIImageView!
- @IBOutlet weak var statusUserStatus: UILabel!
-
- @IBOutlet weak var imageComments: UIImageView!
- @IBOutlet weak var statusComments: UILabel!
-
- @IBOutlet weak var imageText: UIImageView!
- @IBOutlet weak var statusText: UILabel!
-
- @IBOutlet weak var imageCollabora: UIImageView!
- @IBOutlet weak var statusCollabora: UILabel!
-
- @IBOutlet weak var imageOnlyOffice: UIImageView!
- @IBOutlet weak var statusOnlyOffice: UILabel!
-
- @IBOutlet weak var homeImage: UIImageView!
- @IBOutlet weak var homeServer: UILabel!
-
- private let appDelegate = UIApplication.shared.delegate as! AppDelegate
- private var documentController: UIDocumentInteractionController?
- private var account: String = ""
- private var capabilitiesText = ""
- //private var timer: Timer?
-
- // MARK: - View Life Cycle
- override func viewDidLoad() {
- super.viewDidLoad()
-
- self.title = NSLocalizedString("_capabilities_", comment: "")
-
- let shareImage = UIImage.init(named: "shareFill")!.image(color: .gray, size: 25)
- self.navigationItem.rightBarButtonItem = UIBarButtonItem(image: shareImage, style: UIBarButtonItem.Style.plain, target: self, action: #selector(share))
- self.navigationItem.leftBarButtonItem = UIBarButtonItem(title: NSLocalizedString("_done_", comment: ""), style: UIBarButtonItem.Style.plain, target: self, action: #selector(close))
- textView.layer.cornerRadius = 15
- textView.layer.masksToBounds = true
-
- statusFileSharing.layer.cornerRadius = 12.5
- statusFileSharing.layer.borderWidth = 0.5
- statusFileSharing.layer.borderColor = UIColor.gray.cgColor
- statusFileSharing.layer.masksToBounds = true
- statusExternalSite.layer.cornerRadius = 12.5
- statusExternalSite.layer.borderWidth = 0.5
- statusExternalSite.layer.borderColor = UIColor.gray.cgColor
- statusExternalSite.layer.masksToBounds = true
- statusEndToEndEncryption.layer.cornerRadius = 12.5
- statusEndToEndEncryption.layer.borderWidth = 0.5
- statusEndToEndEncryption.layer.borderColor = UIColor.gray.cgColor
- statusEndToEndEncryption.layer.masksToBounds = true
- statusActivity.layer.cornerRadius = 12.5
- statusActivity.layer.borderWidth = 0.5
- statusActivity.layer.borderColor = UIColor.gray.cgColor
- statusActivity.layer.masksToBounds = true
- statusNotification.layer.cornerRadius = 12.5
- statusNotification.layer.borderWidth = 0.5
- statusNotification.layer.borderColor = UIColor.gray.cgColor
- statusNotification.layer.masksToBounds = true
- statusDeletedFiles.layer.cornerRadius = 12.5
- statusDeletedFiles.layer.borderWidth = 0.5
- statusDeletedFiles.layer.borderColor = UIColor.gray.cgColor
- statusDeletedFiles.layer.masksToBounds = true
- statusText.layer.cornerRadius = 12.5
- statusText.layer.borderWidth = 0.5
- statusText.layer.borderColor = UIColor.gray.cgColor
- statusText.layer.masksToBounds = true
- statusCollabora.layer.cornerRadius = 12.5
- statusCollabora.layer.borderWidth = 0.5
- statusCollabora.layer.borderColor = UIColor.gray.cgColor
- statusCollabora.layer.masksToBounds = true
- statusOnlyOffice.layer.cornerRadius = 12.5
- statusOnlyOffice.layer.borderWidth = 0.5
- statusOnlyOffice.layer.borderColor = UIColor.gray.cgColor
- statusOnlyOffice.layer.masksToBounds = true
- statusUserStatus.layer.cornerRadius = 12.5
- statusUserStatus.layer.borderWidth = 0.5
- statusUserStatus.layer.borderColor = UIColor.gray.cgColor
- statusUserStatus.layer.masksToBounds = true
- statusComments.layer.cornerRadius = 12.5
- statusComments.layer.borderWidth = 0.5
- statusComments.layer.borderColor = UIColor.gray.cgColor
- statusComments.layer.masksToBounds = true
- imageFileSharing.image = UIImage.init(named: "share")!.image(color: NCBrandColor.shared.gray, size: 50)
- imageExternalSite.image = NCUtility.shared.loadImage(named: "network", color: NCBrandColor.shared.gray)
- imageEndToEndEncryption.image = NCUtility.shared.loadImage(named: "lock", color: NCBrandColor.shared.gray)
- imageActivity.image = UIImage.init(named: "bolt")!.image(color: NCBrandColor.shared.gray, size: 50)
- imageNotification.image = NCUtility.shared.loadImage(named: "bell", color: NCBrandColor.shared.gray)
- imageDeletedFiles.image = NCUtility.shared.loadImage(named: "trash", color: NCBrandColor.shared.gray)
- imageText.image = UIImage.init(named: "text")!.image(color: NCBrandColor.shared.gray, size: 50)
- imageCollabora.image = UIImage.init(named: "collabora")!.image(color: NCBrandColor.shared.gray, size: 50)
- imageOnlyOffice.image = UIImage.init(named: "onlyoffice")!.image(color: NCBrandColor.shared.gray, size: 50)
- imageUserStatus.image = UIImage.init(named: "userStatusAway")!.image(color: NCBrandColor.shared.gray, size: 50)
- imageComments.image = UIImage.init(named: "comments")!.image(color: NCBrandColor.shared.gray, size: 50)
- guard let activeAccount = NCManageDatabase.shared.getActiveAccount() else { return }
- self.account = activeAccount.account
-
- if let text = NCManageDatabase.shared.getCapabilities(account: activeAccount.account) {
- capabilitiesText = text
- updateCapabilities()
- } else {
- NCContentPresenter.shared.messageNotification("_error_", description: "_no_capabilities_found_", delay: NCGlobal.shared.dismissAfterSecond, type: NCContentPresenter.messageType.info, errorCode: NCGlobal.shared.errorInternalError, forced: true)
-
- DispatchQueue.main.asyncAfter(deadline: .now() + 0.3) {
- self.dismiss(animated: true, completion: nil)
- }
- }
-
- homeImage.image = UIImage.init(named: "home")!.image(color: NCBrandColor.shared.gray, size: 50)
- homeServer.text = NCUtilityFileSystem.shared.getHomeServer(account: appDelegate.account) + "/"
- }
- @objc func updateCapabilities() {
-
- NCCommunication.shared.getCapabilities() { (account, data, errorCode, errorDescription) in
- if errorCode == 0 && data != nil {
- NCManageDatabase.shared.addCapabilitiesJSon(data!, account: account)
-
- // EDITORS
- let serverVersionMajor = NCManageDatabase.shared.getCapabilitiesServerInt(account: account, elements: NCElementsJSON.shared.capabilitiesVersionMajor)
- if serverVersionMajor >= NCGlobal.shared.nextcloudVersion18 {
- NCCommunication.shared.NCTextObtainEditorDetails() { (account, editors, creators, errorCode, errorMessage) in
- if errorCode == 0 && account == self.appDelegate.account {
- NCManageDatabase.shared.addDirectEditing(account: account, editors: editors, creators: creators)
- self.readCapabilities()
- }
- if self.view.window != nil {
- //self.timer = Timer.scheduledTimer(timeInterval: 5, target: self, selector: #selector(self.updateCapabilities), userInfo: nil, repeats: false)
- }
- }
- } else {
- if self.view.window != nil {
- //self.timer = Timer.scheduledTimer(timeInterval: 5, target: self, selector: #selector(self.updateCapabilities), userInfo: nil, repeats: false)
- }
- }
-
- if let text = NCManageDatabase.shared.getCapabilities(account: account) {
- self.capabilitiesText = text
- }
- self.readCapabilities()
- }
- }
-
- readCapabilities()
- }
-
- @objc func share() {
- //timer?.invalidate()
- self.dismiss(animated: true) {
- let fileURL = NSURL.fileURL(withPath: NSTemporaryDirectory(), isDirectory: true).appendingPathComponent("capabilities.txt")
- do {
- try self.capabilitiesText.write(to: fileURL, atomically: true, encoding: .utf8)
-
- if let view = self.appDelegate.window?.rootViewController?.view {
- self.documentController = UIDocumentInteractionController(url: fileURL)
- self.documentController?.delegate = self
- self.documentController?.presentOptionsMenu(from: CGRect.zero, in: view, animated: true)
- }
- } catch { }
- }
- }
-
- @objc func close() {
- //timer?.invalidate()
- self.dismiss(animated: true, completion: nil)
- }
-
- func readCapabilities() {
-
- textView.text = capabilitiesText
-
- if NCManageDatabase.shared.getCapabilitiesServerBool(account: account, elements: NCElementsJSON.shared.capabilitiesFileSharingApiEnabled, exists: false) {
- statusFileSharing.text = "✓ " + NSLocalizedString("_available_", comment: "")
- } else {
- statusFileSharing.text = NSLocalizedString("_not_available_", comment: "")
- }
-
- if NCManageDatabase.shared.getCapabilitiesServerBool(account: account, elements: NCElementsJSON.shared.capabilitiesExternalSitesExists, exists: true) {
- statusExternalSite.text = "✓ " + NSLocalizedString("_available_", comment: "")
- } else {
- statusExternalSite.text = NSLocalizedString("_not_available_", comment: "")
- }
-
- let isE2EEEnabled = NCManageDatabase.shared.getCapabilitiesServerBool(account: account, elements: NCElementsJSON.shared.capabilitiesE2EEEnabled, exists: false)
- //let versionE2EE = NCManageDatabase.shared.getCapabilitiesServerString(account: account, elements: NCElementsJSON.shared.capabilitiesE2EEApiVersion)
-
- if isE2EEEnabled {
- statusEndToEndEncryption.text = "✓ " + NSLocalizedString("_available_", comment: "")
- } else {
- statusEndToEndEncryption.text = NSLocalizedString("_not_available_", comment: "")
- }
-
- let activity = NCManageDatabase.shared.getCapabilitiesServerArray(account: account, elements: NCElementsJSON.shared.capabilitiesActivity)
- if activity != nil {
- statusActivity.text = "✓ " + NSLocalizedString("_available_", comment: "")
- } else {
- statusActivity.text = NSLocalizedString("_not_available_", comment: "")
- }
-
- let notification = NCManageDatabase.shared.getCapabilitiesServerArray(account: account, elements: NCElementsJSON.shared.capabilitiesNotification)
- if notification != nil {
- statusNotification.text = "✓ " + NSLocalizedString("_available_", comment: "")
- } else {
- statusNotification.text = NSLocalizedString("_not_available_", comment: "")
- }
-
- let deleteFiles = NCManageDatabase.shared.getCapabilitiesServerBool(account: account, elements: NCElementsJSON.shared.capabilitiesFilesUndelete, exists: false)
- if deleteFiles {
- statusDeletedFiles.text = "✓ " + NSLocalizedString("_available_", comment: "")
- } else {
- statusDeletedFiles.text = NSLocalizedString("_not_available_", comment: "")
- }
-
- var textEditor = false
- var onlyofficeEditors = false
- if let editors = NCManageDatabase.shared.getDirectEditingEditors(account: account) {
- for editor in editors {
- if editor.editor == NCGlobal.shared.editorText {
- textEditor = true
- } else if editor.editor == NCGlobal.shared.editorOnlyoffice {
- onlyofficeEditors = true
- }
- }
- }
-
- if textEditor {
- statusText.text = "✓ " + NSLocalizedString("_available_", comment: "")
- } else {
- statusText.text = NSLocalizedString("_not_available_", comment: "")
- }
-
- let richdocumentsMimetypes = NCManageDatabase.shared.getCapabilitiesServerArray(account: account, elements: NCElementsJSON.shared.capabilitiesRichdocumentsMimetypes)
- if richdocumentsMimetypes != nil {
- statusCollabora.text = "✓ " + NSLocalizedString("_available_", comment: "")
- } else {
- statusCollabora.text = NSLocalizedString("_not_available_", comment: "")
- }
-
- if onlyofficeEditors {
- statusOnlyOffice.text = "✓ " + NSLocalizedString("_available_", comment: "")
- } else {
- statusOnlyOffice.text = NSLocalizedString("_not_available_", comment: "")
- }
-
- let userStatus = NCManageDatabase.shared.getCapabilitiesServerBool(account: account, elements: NCElementsJSON.shared.capabilitiesUserStatusEnabled, exists: false)
- if userStatus {
- statusUserStatus.text = "✓ " + NSLocalizedString("_available_", comment: "")
- } else {
- statusUserStatus.text = NSLocalizedString("_not_available_", comment: "")
- }
-
- let comments = NCManageDatabase.shared.getCapabilitiesServerBool(account: account, elements: NCElementsJSON.shared.capabilitiesFilesComments, exists: false)
- if comments {
- statusComments.text = "✓ " + NSLocalizedString("_available_", comment: "")
- } else {
- statusComments.text = NSLocalizedString("_not_available_", comment: "")
- }
-
- print("end.")
- }
- }
|