NCEndToEndEncryption.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. //
  2. // NCEndToEndEncryption.h
  3. // Nextcloud
  4. //
  5. // Created by Marino Faggiana on 19/09/17.
  6. // Copyright © 2017 Marino Faggiana. All rights reserved.
  7. //
  8. // Author Marino Faggiana <marino.faggiana@nextcloud.com>
  9. //
  10. // This program is free software: you can redistribute it and/or modify
  11. // it under the terms of the GNU General Public License as published by
  12. // the Free Software Foundation, either version 3 of the License, or
  13. // (at your option) any later version.
  14. //
  15. // This program is distributed in the hope that it will be useful,
  16. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. // GNU General Public License for more details.
  19. //
  20. // You should have received a copy of the GNU General Public License
  21. // along with this program. If not, see <http://www.gnu.org/licenses/>.
  22. //
  23. #import <Foundation/Foundation.h>
  24. #import <OpenSSL/OpenSSL.h>
  25. @class tableMetadata;
  26. @interface NCEndToEndEncryption : NSObject
  27. + (instancetype)sharedManager;
  28. @property (nonatomic, strong) NSString *generatedPublicKey;
  29. @property (nonatomic, strong) NSString *generatedPrivateKey;
  30. // Certificate
  31. - (NSString *)createCSR:(NSString *)userId directory:(NSString *)directory;
  32. - (NSString *)encryptPrivateKey:(NSString *)userId directory: (NSString *)directory passphrase:(NSString *)passphrase privateKey:(NSString **)privateKey;
  33. - (NSData *)decryptPrivateKey:(NSString *)privateKey passphrase:(NSString *)passphrase publicKey:(NSString *)publicKey;
  34. // Encrypt / Decrypt file material
  35. - (NSString *)encryptPayloadFile:(NSString *)encrypted key:(NSString *)key;
  36. - (NSString *)encryptPayloadFile:(NSString *)encrypted key:(NSString *)key initializationVector:(NSString **)initializationVector authenticationTag:(NSString **)authenticationTag;
  37. - (NSData *)decryptPayloadFile:(NSString *)encrypted key:(NSString *)key;
  38. - (NSData *)decryptPayloadFile:(NSString *)encrypted key:(NSString *)key initializationVector:(NSString *)initializationVector authenticationTag:(NSString *)authenticationTag;
  39. // Encrypt/Decrypt asymmetric
  40. - (NSData *)encryptAsymmetricString:(NSString *)plain publicKey:(NSString *)publicKey privateKey:(NSString *)privateKey;
  41. - (NSData *)decryptAsymmetricData:(NSData *)cipherData privateKey:(NSString *)privateKey;
  42. // Encrypt / Decrypt file
  43. - (BOOL)encryptFile:(NSString *)fileName fileNameIdentifier:(NSString *)fileNameIdentifier directory:(NSString *)directory key:(NSString **)key initializationVector:(NSString **)initializationVector authenticationTag:(NSString **)authenticationTag;
  44. - (BOOL)decryptFile:(NSString *)fileName fileNameView:(NSString *)fileNameView ocId:(NSString *)ocId key:(NSString *)key initializationVector:(NSString *)initializationVector authenticationTag:(NSString *)authenticationTag;
  45. // Signature CMS
  46. - (NSData *)generateSignatureCMS:(NSData *)data certificate:(NSString *)certificate privateKey:(NSString *)privateKey publicKey:(NSString *)publicKey userId:(NSString *)userId;
  47. - (BOOL)verifySignatureCMS:(NSData *)cmsContent data:(NSData *)data publicKey:(NSString *)publicKey userId:(NSString *)userId;
  48. // Utility
  49. - (void)Encodedkey:(NSString **)key initializationVector:(NSString **)initializationVector;
  50. - (NSData *)generateKey;
  51. - (NSString *)createSHA512:(NSString *)string;
  52. - (NSString *)createSHA256:(NSString *)string;
  53. - (NSString *)extractPublicKeyFromCertificate:(NSString *)pemCertificate;
  54. @end