From 28ef4b18edb2cef276586de45dd611b1fdd0118b Mon Sep 17 00:00:00 2001 From: Raul Metsma Date: Fri, 1 Sep 2023 10:39:39 +0300 Subject: [PATCH 1/2] Increase minimum iOS and macOS supported versions - use more std::filesystem IB-7483 Signed-off-by: Raul Metsma --- build-library.sh | 8 +- .../libdigidocpp.xcodeproj/project.pbxproj | 108 ++++++------------ examples/ios/libdigidocpp/AppDelegate.mm | 22 +--- .../libdigidocpp/Base.lproj/LaunchScreen.xib | 43 ------- .../ios/libdigidocpp/LaunchScreen.storyboard | 48 ++++++++ .../ios/libdigidocpp/MasterViewController.mm | 12 +- prepare_osx_build_environment.sh | 12 +- src/ASiContainer.cpp | 2 +- src/digidoc-tool.cpp | 1 - src/util/File.cpp | 102 +++++------------ src/util/File.h | 19 +-- src/util/ZipSerialize.cpp | 6 +- src/xml/URIResolver.cpp | 15 +-- 13 files changed, 144 insertions(+), 254 deletions(-) delete mode 100644 examples/ios/libdigidocpp/Base.lproj/LaunchScreen.xib create mode 100644 examples/ios/libdigidocpp/LaunchScreen.storyboard diff --git a/build-library.sh b/build-library.sh index 07ec33b9f..b38bc53c5 100755 --- a/build-library.sh +++ b/build-library.sh @@ -8,8 +8,8 @@ if [ "$#" -eq 0 ]; then echo " target: osx ios iossimulator ioscatalyst androidarm androidarm64 androidx86_64" echo "To control iOS, macOS builds set environment variables:" echo " minimum deployment target" - echo " - MACOSX_DEPLOYMENT_TARGET=10.15" - echo " - IPHONEOS_DEPLOYMENT_TARGET=12.0" + echo " - MACOSX_DEPLOYMENT_TARGET=11.0" + echo " - IPHONEOS_DEPLOYMENT_TARGET=13.0" echo " archs to build on macOS/iOS" echo " - ARCHS=\"arm64 x86_64\" (macOS)" echo " - ARCHS=\"arm64\" (iOS)" @@ -69,7 +69,7 @@ case "$@" in ;; esac TARGET_PATH=/Library/libdigidocpp.${TARGET} - : ${IPHONEOS_DEPLOYMENT_TARGET:="12.0"} + : ${IPHONEOS_DEPLOYMENT_TARGET:="13.0"} export IPHONEOS_DEPLOYMENT_TARGET CMAKEARGS=" -DCMAKE_OSX_SYSROOT=${SYSROOT} \ @@ -85,7 +85,7 @@ case "$@" in TARGET=macOS TARGET_PATH=/Library/libdigidocpp : ${ARCHS:="arm64 x86_64"} - : ${MACOSX_DEPLOYMENT_TARGET:="10.15"} + : ${MACOSX_DEPLOYMENT_TARGET:="11.0"} export MACOSX_DEPLOYMENT_TARGET esac diff --git a/examples/ios/libdigidocpp.xcodeproj/project.pbxproj b/examples/ios/libdigidocpp.xcodeproj/project.pbxproj index c62f6eb9e..4ed89b7b1 100644 --- a/examples/ios/libdigidocpp.xcodeproj/project.pbxproj +++ b/examples/ios/libdigidocpp.xcodeproj/project.pbxproj @@ -9,12 +9,12 @@ /* Begin PBXBuildFile section */ 4E25CC401B5D1D85005E0B79 /* test.bdoc in Resources */ = {isa = PBXBuildFile; fileRef = 4E25CC3F1B5D1D85005E0B79 /* test.bdoc */; }; 4E25CC421B5D1EDA005E0B79 /* schema in Resources */ = {isa = PBXBuildFile; fileRef = 4E25CC411B5D1EDA005E0B79 /* schema */; }; + 4E26A2292AB4E38600E2B732 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 4E26A2282AB4E38600E2B732 /* LaunchScreen.storyboard */; }; 4E76639E1B5A37AC00672ACF /* main.mm in Sources */ = {isa = PBXBuildFile; fileRef = 4E76639D1B5A37AC00672ACF /* main.mm */; }; 4E7663A11B5A37AC00672ACF /* AppDelegate.mm in Sources */ = {isa = PBXBuildFile; fileRef = 4E7663A01B5A37AC00672ACF /* AppDelegate.mm */; }; 4E7663A41B5A37AC00672ACF /* MasterViewController.mm in Sources */ = {isa = PBXBuildFile; fileRef = 4E7663A31B5A37AC00672ACF /* MasterViewController.mm */; }; 4E7663AA1B5A37AC00672ACF /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 4E7663A81B5A37AC00672ACF /* Main.storyboard */; }; 4E7663AC1B5A37AC00672ACF /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 4E7663AB1B5A37AC00672ACF /* Images.xcassets */; }; - 4E7663AF1B5A37AC00672ACF /* LaunchScreen.xib in Resources */ = {isa = PBXBuildFile; fileRef = 4E7663AD1B5A37AC00672ACF /* LaunchScreen.xib */; }; 4E85E5F7285364BF00A65763 /* libdigidocpp_util.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 4E85E5F6285364BF00A65763 /* libdigidocpp_util.a */; }; 4ECD5FAA2010A15A00BCC616 /* libcrypto.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 4ECD5FA92010A15A00BCC616 /* libcrypto.a */; }; 4ECD5FB02010A1B700BCC616 /* libssl.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 4ECD5FAB2010A1B700BCC616 /* libssl.a */; }; @@ -32,6 +32,7 @@ /* Begin PBXFileReference section */ 4E25CC3F1B5D1D85005E0B79 /* test.bdoc */ = {isa = PBXFileReference; lastKnownFileType = file; path = test.bdoc; sourceTree = ""; }; 4E25CC411B5D1EDA005E0B79 /* schema */ = {isa = PBXFileReference; lastKnownFileType = folder; name = schema; path = "$(SDKPATH)/etc/digidocpp/schema"; sourceTree = ""; }; + 4E26A2282AB4E38600E2B732 /* LaunchScreen.storyboard */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; path = LaunchScreen.storyboard; sourceTree = ""; }; 4E7663981B5A37AC00672ACF /* libdigidocpp.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = libdigidocpp.app; sourceTree = BUILT_PRODUCTS_DIR; }; 4E76639C1B5A37AC00672ACF /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; 4E76639D1B5A37AC00672ACF /* main.mm */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.objcpp; path = main.mm; sourceTree = ""; }; @@ -40,7 +41,6 @@ 4E7663A31B5A37AC00672ACF /* MasterViewController.mm */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.objcpp; path = MasterViewController.mm; sourceTree = ""; }; 4E7663A91B5A37AC00672ACF /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = ""; }; 4E7663AB1B5A37AC00672ACF /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Images.xcassets; sourceTree = ""; }; - 4E7663AE1B5A37AC00672ACF /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/LaunchScreen.xib; sourceTree = ""; }; 4E85E5F6285364BF00A65763 /* libdigidocpp_util.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = libdigidocpp_util.a; path = "$(SDKPATH)/lib/libdigidocpp_util.a"; sourceTree = ""; }; 4EAC9AA729125D5200A39880 /* libdigidocpp.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = libdigidocpp.entitlements; sourceTree = ""; }; 4ECD5FA92010A15A00BCC616 /* libcrypto.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = libcrypto.a; path = "$(SDKPATH)/lib/libcrypto.a"; sourceTree = ""; }; @@ -106,22 +106,14 @@ 4E7663A01B5A37AC00672ACF /* AppDelegate.mm */, 4E7663A31B5A37AC00672ACF /* MasterViewController.mm */, 4E7663A81B5A37AC00672ACF /* Main.storyboard */, + 4E26A2282AB4E38600E2B732 /* LaunchScreen.storyboard */, 4E7663AB1B5A37AC00672ACF /* Images.xcassets */, - 4E7663AD1B5A37AC00672ACF /* LaunchScreen.xib */, - 4E76639B1B5A37AC00672ACF /* Supporting Files */, - ); - path = libdigidocpp; - sourceTree = ""; - }; - 4E76639B1B5A37AC00672ACF /* Supporting Files */ = { - isa = PBXGroup; - children = ( - 4E25CC411B5D1EDA005E0B79 /* schema */, - 4E25CC3F1B5D1D85005E0B79 /* test.bdoc */, 4E76639C1B5A37AC00672ACF /* Info.plist */, 4E76639D1B5A37AC00672ACF /* main.mm */, + 4E25CC3F1B5D1D85005E0B79 /* test.bdoc */, + 4E25CC411B5D1EDA005E0B79 /* schema */, ); - name = "Supporting Files"; + path = libdigidocpp; sourceTree = ""; }; 4ECD5FA82010A15A00BCC616 /* Frameworks */ = { @@ -170,13 +162,11 @@ isa = PBXProject; attributes = { BuildIndependentTargetsInParallel = YES; - LastUpgradeCheck = 1430; + LastUpgradeCheck = 1500; ORGANIZATIONNAME = RIA; TargetAttributes = { 4E7663971B5A37AC00672ACF = { CreatedOnToolsVersion = 6.4; - DevelopmentTeam = ET847QJV9F; - ProvisioningStyle = Automatic; }; }; }; @@ -205,8 +195,8 @@ files = ( 4E25CC421B5D1EDA005E0B79 /* schema in Resources */, 4E7663AA1B5A37AC00672ACF /* Main.storyboard in Resources */, - 4E7663AF1B5A37AC00672ACF /* LaunchScreen.xib in Resources */, 4E7663AC1B5A37AC00672ACF /* Images.xcassets in Resources */, + 4E26A2292AB4E38600E2B732 /* LaunchScreen.storyboard in Resources */, 4E25CC401B5D1D85005E0B79 /* test.bdoc in Resources */, ); runOnlyForDeploymentPostprocessing = 0; @@ -235,14 +225,6 @@ name = Main.storyboard; sourceTree = ""; }; - 4E7663AD1B5A37AC00672ACF /* LaunchScreen.xib */ = { - isa = PBXVariantGroup; - children = ( - 4E7663AE1B5A37AC00672ACF /* Base */, - ); - name = LaunchScreen.xib; - sourceTree = ""; - }; /* End PBXVariantGroup section */ /* Begin XCBuildConfiguration section */ @@ -250,16 +232,19 @@ isa = XCBuildConfiguration; buildSettings = { ALWAYS_SEARCH_USER_PATHS = NO; - CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; CLANG_CXX_LANGUAGE_STANDARD = "gnu++17"; CLANG_ENABLE_MODULES = YES; CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; CLANG_WARN_BOOL_CONVERSION = YES; CLANG_WARN_COMMA = YES; CLANG_WARN_CONSTANT_CONVERSION = YES; CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; CLANG_WARN_EMPTY_BODY = YES; CLANG_WARN_ENUM_CONVERSION = YES; CLANG_WARN_INFINITE_RECURSION = YES; @@ -272,14 +257,14 @@ CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; CLANG_WARN_STRICT_PROTOTYPES = YES; CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; CLANG_WARN_UNREACHABLE_CODE = YES; CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; - "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; COPY_PHASE_STRIP = NO; - DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; - ENABLE_BITCODE = NO; + DEBUG_INFORMATION_FORMAT = dwarf; ENABLE_STRICT_OBJC_MSGSEND = YES; ENABLE_TESTABILITY = YES; + ENABLE_USER_SCRIPT_SANDBOXING = YES; GCC_C_LANGUAGE_STANDARD = gnu11; GCC_DYNAMIC_NO_PIC = NO; GCC_NO_COMMON_BLOCKS = YES; @@ -288,14 +273,13 @@ "DEBUG=1", "$(inherited)", ); - GCC_SYMBOLS_PRIVATE_EXTERN = NO; GCC_WARN_64_TO_32_BIT_CONVERSION = YES; GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; GCC_WARN_UNDECLARED_SELECTOR = YES; GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; GCC_WARN_UNUSED_FUNCTION = YES; GCC_WARN_UNUSED_VARIABLE = YES; - IPHONEOS_DEPLOYMENT_TARGET = 12.0; + IPHONEOS_DEPLOYMENT_TARGET = 13.0; ONLY_ACTIVE_ARCH = YES; SDKROOT = iphoneos; TARGETED_DEVICE_FAMILY = "1,2"; @@ -306,16 +290,19 @@ isa = XCBuildConfiguration; buildSettings = { ALWAYS_SEARCH_USER_PATHS = NO; - CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; CLANG_CXX_LANGUAGE_STANDARD = "gnu++17"; CLANG_ENABLE_MODULES = YES; CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; CLANG_WARN_BOOL_CONVERSION = YES; CLANG_WARN_COMMA = YES; CLANG_WARN_CONSTANT_CONVERSION = YES; CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; CLANG_WARN_EMPTY_BODY = YES; CLANG_WARN_ENUM_CONVERSION = YES; CLANG_WARN_INFINITE_RECURSION = YES; @@ -328,14 +315,13 @@ CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; CLANG_WARN_STRICT_PROTOTYPES = YES; CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; CLANG_WARN_UNREACHABLE_CODE = YES; CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; - "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; COPY_PHASE_STRIP = NO; - DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; - ENABLE_BITCODE = NO; ENABLE_NS_ASSERTIONS = NO; ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_USER_SCRIPT_SANDBOXING = YES; GCC_C_LANGUAGE_STANDARD = gnu11; GCC_NO_COMMON_BLOCKS = YES; GCC_WARN_64_TO_32_BIT_CONVERSION = YES; @@ -344,7 +330,7 @@ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; GCC_WARN_UNUSED_FUNCTION = YES; GCC_WARN_UNUSED_VARIABLE = YES; - IPHONEOS_DEPLOYMENT_TARGET = 12.0; + IPHONEOS_DEPLOYMENT_TARGET = 13.0; SDKROOT = iphoneos; TARGETED_DEVICE_FAMILY = "1,2"; VALIDATE_PRODUCT = YES; @@ -357,13 +343,11 @@ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; BUILD_NUMBER = 0; CODE_SIGN_ENTITLEMENTS = libdigidocpp/libdigidocpp.entitlements; - CODE_SIGN_IDENTITY = "iPhone Developer"; + CODE_SIGN_IDENTITY = "Apple Development"; "CODE_SIGN_IDENTITY[sdk=macosx*]" = "-"; + CODE_SIGN_STYLE = Automatic; CURRENT_PROJECT_VERSION = "$(BUILD_NUMBER)"; - FRAMEWORK_SEARCH_PATHS = ( - "$(inherited)", - "$(PROJECT_DIR)/libdigidocpp", - ); + DEVELOPMENT_TEAM = ET847QJV9F; GCC_PREPROCESSOR_DEFINITIONS = ( "$(inherited)", "TESTING=$(TESTING)", @@ -374,19 +358,13 @@ "$(MINIZIP)", ); INFOPLIST_FILE = libdigidocpp/Info.plist; - INFOPLIST_KEY_CFBundleDisplayName = Libdigidocpp; INFOPLIST_KEY_LSApplicationCategoryType = "public.app-category.productivity"; - INFOPLIST_KEY_UILaunchStoryboardName = LaunchScreen.xib; + INFOPLIST_KEY_LSSupportsOpeningDocumentsInPlace = YES; + INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES; + INFOPLIST_KEY_UILaunchStoryboardName = LaunchScreen; INFOPLIST_KEY_UIMainStoryboardFile = Main; INFOPLIST_KEY_UISupportedInterfaceOrientations = "UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown"; - LD_RUNPATH_SEARCH_PATHS = ( - "$(inherited)", - "@executable_path/Frameworks", - ); - LIBRARY_SEARCH_PATHS = ( - "$(SDKPATH)/lib", - "$(PROJECT_DIR)", - ); + LIBRARY_SEARCH_PATHS = "$(SDKPATH)/lib"; MARKETING_VERSION = 1.0; MINIZIP = "$(PROJECT_DIR)/../../src/minizip"; PRODUCT_BUNDLE_IDENTIFIER = "ee.ria.$(PRODUCT_NAME:rfc1034identifier)"; @@ -394,10 +372,8 @@ SDKPATH = /Library/libdigidocpp.iphoneos; "SDKPATH[sdk=iphonesimulator*]" = /Library/libdigidocpp.iphonesimulator; "SDKPATH[sdk=macosx*]" = /Library/libdigidocpp.iphonecatalyst; - SUPPORTED_PLATFORMS = "iphoneos iphonesimulator"; SUPPORTS_MACCATALYST = YES; SUPPORTS_MAC_DESIGNED_FOR_IPHONE_IPAD = NO; - TARGETED_DEVICE_FAMILY = "1,2"; TESTING = 0; }; name = Debug; @@ -408,13 +384,11 @@ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; BUILD_NUMBER = 0; CODE_SIGN_ENTITLEMENTS = libdigidocpp/libdigidocpp.entitlements; - CODE_SIGN_IDENTITY = "iPhone Developer"; + CODE_SIGN_IDENTITY = "Apple Development"; "CODE_SIGN_IDENTITY[sdk=macosx*]" = "-"; + CODE_SIGN_STYLE = Automatic; CURRENT_PROJECT_VERSION = "$(BUILD_NUMBER)"; - FRAMEWORK_SEARCH_PATHS = ( - "$(inherited)", - "$(PROJECT_DIR)/libdigidocpp", - ); + DEVELOPMENT_TEAM = ET847QJV9F; GCC_PREPROCESSOR_DEFINITIONS = ( "$(inherited)", "TESTING=$(TESTING)", @@ -425,19 +399,13 @@ "$(MINIZIP)", ); INFOPLIST_FILE = libdigidocpp/Info.plist; - INFOPLIST_KEY_CFBundleDisplayName = Libdigidocpp; INFOPLIST_KEY_LSApplicationCategoryType = "public.app-category.productivity"; - INFOPLIST_KEY_UILaunchStoryboardName = LaunchScreen.xib; + INFOPLIST_KEY_LSSupportsOpeningDocumentsInPlace = YES; + INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES; + INFOPLIST_KEY_UILaunchStoryboardName = LaunchScreen; INFOPLIST_KEY_UIMainStoryboardFile = Main; INFOPLIST_KEY_UISupportedInterfaceOrientations = "UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown"; - LD_RUNPATH_SEARCH_PATHS = ( - "$(inherited)", - "@executable_path/Frameworks", - ); - LIBRARY_SEARCH_PATHS = ( - "$(SDKPATH)/lib", - "$(PROJECT_DIR)", - ); + LIBRARY_SEARCH_PATHS = "$(SDKPATH)/lib"; MARKETING_VERSION = 1.0; MINIZIP = "$(PROJECT_DIR)/../../src/minizip"; PRODUCT_BUNDLE_IDENTIFIER = "ee.ria.$(PRODUCT_NAME:rfc1034identifier)"; @@ -445,10 +413,8 @@ SDKPATH = /Library/libdigidocpp.iphoneos; "SDKPATH[sdk=iphonesimulator*]" = /Library/libdigidocpp.iphonesimulator; "SDKPATH[sdk=macosx*]" = /Library/libdigidocpp.iphonecatalyst; - SUPPORTED_PLATFORMS = "iphoneos iphonesimulator"; SUPPORTS_MACCATALYST = YES; SUPPORTS_MAC_DESIGNED_FOR_IPHONE_IPAD = NO; - TARGETED_DEVICE_FAMILY = "1,2"; TESTING = 0; }; name = Release; diff --git a/examples/ios/libdigidocpp/AppDelegate.mm b/examples/ios/libdigidocpp/AppDelegate.mm index 8f8463ad2..dca970e74 100644 --- a/examples/ios/libdigidocpp/AppDelegate.mm +++ b/examples/ios/libdigidocpp/AppDelegate.mm @@ -48,7 +48,7 @@ - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:( digidoc::initialize("libdigidocpp iOS"); // Skip URL will be opened in application: openURL: if (launchOptions[UIApplicationLaunchOptionsURLKey] == nil) { - [self openFile:[NSBundle.mainBundle pathForResource:@"test" ofType:@"bdoc"] copy:YES]; + [self openFile:[NSBundle.mainBundle pathForResource:@"test" ofType:@"bdoc"]]; } } catch(const digidoc::Exception &e) { NSLog(@"%s", e.msg().c_str()); @@ -59,30 +59,14 @@ - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:( - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url options:(NSDictionary *)options { delete self.doc; self.doc = nullptr; - BOOL result = [self openFile:url.path copy:YES]; + BOOL result = [self openFile:url.path]; UITableViewController *master = (UITableViewController*)self.window.rootViewController; [master.tableView reloadData]; return result; } -- (BOOL)openFile:(NSString*)from copy:(BOOL)copy { +- (BOOL)openFile:(NSString*)path { try { - NSArray *documentPath = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES); - NSString *path = [NSString stringWithFormat:@"%@/%@", documentPath.firstObject, from.lastPathComponent]; - NSError *error; - [NSFileManager.defaultManager removeItemAtPath:path error:&error]; - if (error) { - NSLog(@"Failed to remove file %@", error); - error = nil; - } - if (copy) - [NSFileManager.defaultManager copyItemAtPath:from toPath:path error:&error]; - else - [NSFileManager.defaultManager moveItemAtPath:from toPath:path error:&error]; - if (error) { - NSLog(@"Failed to copy/move file %@", error); - return NO; - } self.doc = digidoc::Container::openPtr(path.UTF8String).release(); return YES; } catch(const digidoc::Exception &e) { diff --git a/examples/ios/libdigidocpp/Base.lproj/LaunchScreen.xib b/examples/ios/libdigidocpp/Base.lproj/LaunchScreen.xib deleted file mode 100644 index 2971f2fa1..000000000 --- a/examples/ios/libdigidocpp/Base.lproj/LaunchScreen.xib +++ /dev/null @@ -1,43 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/examples/ios/libdigidocpp/LaunchScreen.storyboard b/examples/ios/libdigidocpp/LaunchScreen.storyboard new file mode 100644 index 000000000..af34ebaa1 --- /dev/null +++ b/examples/ios/libdigidocpp/LaunchScreen.storyboard @@ -0,0 +1,48 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/examples/ios/libdigidocpp/MasterViewController.mm b/examples/ios/libdigidocpp/MasterViewController.mm index a8b1b89be..bef6eb98f 100644 --- a/examples/ios/libdigidocpp/MasterViewController.mm +++ b/examples/ios/libdigidocpp/MasterViewController.mm @@ -83,7 +83,7 @@ - (IBAction)runTest:(id)sender { if(unzResult != UNZ_OK) break; std::string fileNameTmp(fileInfo.size_filename, 0); - unzResult = unzGetCurrentFileInfo(open, &fileInfo, &fileNameTmp[0], uLong(fileNameTmp.size()), nullptr, 0, nullptr, 0); + unzResult = unzGetCurrentFileInfo(open, &fileInfo, fileNameTmp.c_str(), uLong(fileNameTmp.size()), nullptr, 0, nullptr, 0); if(unzResult != UNZ_OK) break; @@ -113,11 +113,11 @@ - (IBAction)runTest:(id)sender { try { std::unique_ptr d(digidoc::Container::open(file.UTF8String)); for (const digidoc::DataFile *f: d->dataFiles()) { - NSMutableDictionary *tmp = [[NSMutableDictionary alloc] init]; - tmp[@"f"] = [NSString stdstring:f->fileName()]; - tmp[@"m"] = [NSString stdstring:f->mediaType()]; - tmp[@"s"] = @(f->fileSize()); - [dataFiles addObject:tmp]; + [dataFiles addObject:@{ + @"f": [NSString stdstring:f->fileName()], + @"m": [NSString stdstring:f->mediaType()], + @"s": @(f->fileSize()), + }]; } for (const digidoc::Signature *s: d->signatures()) { diff --git a/prepare_osx_build_environment.sh b/prepare_osx_build_environment.sh index c861cd2c7..871e407aa 100755 --- a/prepare_osx_build_environment.sh +++ b/prepare_osx_build_environment.sh @@ -62,7 +62,7 @@ case "$@" in CONFIGURE="--host=aarch64-apple-darwin --enable-static --disable-shared --disable-dependency-tracking" SYSROOT=$(xcrun -sdk iphonesimulator --show-sdk-path) : ${ARCHS:="arm64 x86_64"} - : ${IPHONEOS_DEPLOYMENT_TARGET:="12.0"} + : ${IPHONEOS_DEPLOYMENT_TARGET:="13.0"} export IPHONEOS_DEPLOYMENT_TARGET export CFLAGS="-arch ${ARCHS// / -arch } -isysroot ${SYSROOT}" ;; @@ -72,7 +72,7 @@ case "$@" in CONFIGURE="--host=aarch64-apple-darwin --enable-static --disable-shared --disable-dependency-tracking" SYSROOT=$(xcrun -sdk macosx --show-sdk-path) : ${ARCHS:="arm64 x86_64"} - : ${IPHONEOS_DEPLOYMENT_TARGET:="12.0"} + : ${IPHONEOS_DEPLOYMENT_TARGET:="13.0"} export IPHONEOS_DEPLOYMENT_TARGET export CFLAGS="-arch ${ARCHS// / -arch } -target x86_64-apple-ios-macabi -isysroot ${SYSROOT}" ;; @@ -82,7 +82,7 @@ case "$@" in CONFIGURE="--host=aarch64-apple-darwin --enable-static --disable-shared --disable-dependency-tracking" SYSROOT=$(xcrun -sdk iphoneos --show-sdk-path) : ${ARCHS:="arm64"} - : ${IPHONEOS_DEPLOYMENT_TARGET:="12.0"} + : ${IPHONEOS_DEPLOYMENT_TARGET:="13.0"} export IPHONEOS_DEPLOYMENT_TARGET export CFLAGS="-arch ${ARCHS// / -arch } -isysroot ${SYSROOT}" ;; @@ -92,7 +92,7 @@ case "$@" in CONFIGURE="--disable-static --enable-shared --disable-dependency-tracking" SYSROOT=$(xcrun -sdk macosx --show-sdk-path) : ${ARCHS:="arm64 x86_64"} - : ${MACOSX_DEPLOYMENT_TARGET:="10.15"} + : ${MACOSX_DEPLOYMENT_TARGET:="11.0"} export MACOSX_DEPLOYMENT_TARGET export CFLAGS="-arch ${ARCHS// / -arch } " ;; @@ -408,8 +408,8 @@ case "$@" in echo " tasks: xerces, xalan, openssl, xmlsec, xsd, all, help" echo "To control iOS, macOS builds set environment variables:" echo " minimum deployment target" - echo " - MACOSX_DEPLOYMENT_TARGET=10.15" - echo " - IPHONEOS_DEPLOYMENT_TARGET=12.0" + echo " - MACOSX_DEPLOYMENT_TARGET=11.0" + echo " - IPHONEOS_DEPLOYMENT_TARGET=13.0" echo " archs to build on macOS/iOS" echo " - ARCHS=\"arm64 x86_64\" (macOS)" echo " - ARCHS=\"arm64\" (iOS)" diff --git a/src/ASiContainer.cpp b/src/ASiContainer.cpp index d77705984..5f158ce8d 100644 --- a/src/ASiContainer.cpp +++ b/src/ASiContainer.cpp @@ -152,7 +152,7 @@ unique_ptr ASiContainer::dataStream(const string &path, const ZipSeria { unique_ptr data; if(d->properties[path].size > MAX_MEM_FILE) - data = make_unique(File::encodeName(File::tempFileName()), fstream::in|fstream::out|fstream::binary|fstream::trunc); + data = make_unique(File::tempFileName(), fstream::in|fstream::out|fstream::binary|fstream::trunc); else data = make_unique(); z.extract(path, *data); diff --git a/src/digidoc-tool.cpp b/src/digidoc-tool.cpp index 6973ea02a..70e496f49 100644 --- a/src/digidoc-tool.cpp +++ b/src/digidoc-tool.cpp @@ -32,7 +32,6 @@ #include "util/log.h" #include -#include #include #include #include diff --git a/src/util/File.cpp b/src/util/File.cpp index c4dfbf958..4827e9abd 100644 --- a/src/util/File.cpp +++ b/src/util/File.cpp @@ -23,7 +23,6 @@ #include #include -#include #include #include #include @@ -62,7 +61,7 @@ using f_statbuf = struct stat; using f_utimbuf = struct utimbuf; #endif -stack File::tempFiles; +stack File::tempFiles; string File::confPath() { @@ -73,63 +72,21 @@ string File::confPath() #elif defined(_WIN32) return dllPath("digidocpp.dll"); #else - return path(env("SNAP"), DIGIDOCPP_CONFIG_DIR "/"); + fs::path result; + if(char *var = getenv("SNAP")) + result = fs::path(var); + return (result / DIGIDOCPP_CONFIG_DIR "/").u8string(); #endif } -#ifndef _WIN32 -string File::env(string_view varname) -{ - if(char *var = getenv(varname.data())) - return decodeName(var); - return {}; -} -#endif - /** * Encodes path to compatible std lib * @param fileName path * @return encoded path */ -File::f_string File::encodeName(string_view fileName) -{ - if(fileName.empty()) - return {}; -#ifdef __APPLE__ - CFStringRef ref = CFStringCreateWithBytesNoCopy({}, (UInt8 *)fileName.data(), - CFIndex(fileName.size()), kCFStringEncodingUTF8, FALSE, kCFAllocatorNull); - string out(fileName.size() * 2, 0); - CFStringGetFileSystemRepresentation(ref, out.data(), CFIndex(out.size())); - CFRelease(ref); - out.resize(strlen(out.c_str())); -#else - f_string out = fs::u8path(fileName); -#endif - return out; -} - -/** - * Decodes path from std lib path - * @param localFileName path - * @return decoded path - */ -string File::decodeName(const f_string_view &localFileName) +fs::path File::encodeName(string_view fileName) { - if(localFileName.empty()) - return {}; -#ifdef __APPLE__ - CFMutableStringRef ref = CFStringCreateMutable(nullptr, 0); - CFStringAppendCString(ref, localFileName.data(), kCFStringEncodingUTF8); - CFStringNormalize(ref, kCFStringNormalizationFormC); - - string out(localFileName.size() * 2, 0); - CFStringGetCString(ref, out.data(), CFIndex(out.size()), kCFStringEncodingUTF8); - CFRelease(ref); - out.resize(strlen(out.c_str())); -#else - string out = fs::path(localFileName).u8string(); -#endif - return out; + return fs::u8path(fileName); } /** @@ -140,8 +97,7 @@ string File::decodeName(const f_string_view &localFileName) */ bool File::fileExists(const string& path) { - f_statbuf fileInfo; - return f_stat(encodeName(path).c_str(), &fileInfo) == 0 && (fileInfo.st_mode & S_IFMT) == S_IFREG; + return fs::is_regular_file(fs::u8path(path)); } #ifdef _WIN32 @@ -167,14 +123,13 @@ string File::dllPath(string_view dll) time_t File::modifiedTime(const string &path) { f_statbuf fileInfo; - return f_stat(encodeName(path).c_str(), &fileInfo) ? time(nullptr) : fileInfo.st_mtime; + return f_stat(fs::u8path(path).c_str(), &fileInfo) ? time(nullptr) : fileInfo.st_mtime; } void File::updateModifiedTime(const string &path, time_t time) { - f_string _path = encodeName(path); f_utimbuf u_time { time, time }; - if(f_utime(_path.c_str(), &u_time)) + if(f_utime(fs::u8path(path).c_str(), &u_time)) THROW("Failed to update file modified time."); } @@ -193,8 +148,7 @@ string File::fileExtension(const string &path) */ unsigned long File::fileSize(const string &path) { - f_statbuf fileInfo; - return f_stat(encodeName(path).c_str(), &fileInfo) ? 0 : (unsigned long)fileInfo.st_size; + return fs::file_size(fs::u8path(path)); } /** @@ -266,26 +220,22 @@ string File::path(string dir, string_view relativePath) /** * @return returns temporary filename. */ -string File::tempFileName() +fs::path File::tempFileName() { #ifdef _WIN32 // requires TMP environment variable to be set wchar_t *fileName = _wtempnam(nullptr, nullptr); // TODO: static buffer, not thread-safe if(!fileName) THROW("Failed to create a temporary file name."); - string path = fs::path(fileName).u8string(); + tempFiles.emplace(fileName); free(fileName); #else -#ifdef __APPLE__ - string path = File::path(env("TMPDIR"), "XXXXXX"); -#else - string path = "/tmp/XXXXXX"; -#endif - if(mkstemp(path.data()) == -1) + string tmp = "XXXXXX"; + if(mkstemp(tmp.data()) == -1) THROW("Failed to create a temporary file name."); + tempFiles.push(fs::temp_directory_path() / tmp); #endif - tempFiles.push(path); - return path; + return tempFiles.top(); } /** @@ -300,7 +250,7 @@ void File::createDirectory(string path) THROW("Can not create directory with no name."); if(path.back() == '/' || path.back() == '\\') path.pop_back(); - f_string _path = encodeName(path); + auto _path = fs::u8path(path); #ifdef _WIN32 int result = _wmkdir(_path.c_str()); #else @@ -327,7 +277,9 @@ string File::digidocppPath() CoTaskMemFree(knownFolder); return appData; #elif defined(ANDROID) - return path(env("HOME"), ".digidocpp"); + if(char *var = getenv("HOME")) + return (fs::path(var) / ".digidocpp").u8string(); + return {}; #else string buf(sysconf(_SC_GETPW_R_SIZE_MAX), 0); passwd pwbuf {}; @@ -362,21 +314,19 @@ string File::fullPathUrl(string path) */ void File::deleteTempFiles() { + error_code ec; while(!tempFiles.empty()) { - if(!removeFile(tempFiles.top())) - WARN( "Tried to remove the temporary file or directory '%s', but failed.", tempFiles.top().c_str() ); + if(!fs::remove(tempFiles.top(), ec) || ec) + WARN("Tried to remove the temporary file or directory '%s', but failed.", tempFiles.top().u8string().c_str()); tempFiles.pop(); } } bool File::removeFile(const string &path) { -#ifdef _WIN32 - return _wremove(fs::u8path(path).c_str()) == 0; -#else - return remove(encodeName(path).c_str()) == 0; -#endif + error_code ec; + return fs::remove(fs::u8path(path), ec); } /** diff --git a/src/util/File.h b/src/util/File.h index 5eefeb4b3..a2aa2130f 100644 --- a/src/util/File.h +++ b/src/util/File.h @@ -21,6 +21,7 @@ #include "../Exception.h" +#include #include namespace digidoc @@ -34,18 +35,9 @@ namespace digidoc class File { public: -#ifdef _WIN32 - using f_string = std::wstring; - using f_string_view = std::wstring_view; -#else - using f_string = std::string; - using f_string_view = std::string_view; -#endif static std::string confPath(); static std::string digidocppPath(); - static f_string encodeName(std::string_view fileName); - static std::string decodeName(const f_string_view &localFileName); - static bool isRelative(const std::string &path); + static std::filesystem::path encodeName(std::string_view fileName); static time_t modifiedTime(const std::string &path); static void updateModifiedTime(const std::string &path, time_t time); static bool fileExists(const std::string& path); @@ -55,7 +47,7 @@ namespace digidoc static std::string directory(const std::string& path); static std::string path(std::string dir, std::string_view relativePath); static std::string fullPathUrl(std::string path); - static std::string tempFileName(); + static std::filesystem::path tempFileName(); static void createDirectory(std::string path); static void deleteTempFiles(); static bool removeFile(const std::string &path); @@ -71,10 +63,7 @@ namespace digidoc #ifdef __APPLE__ static std::string frameworkResourcesPath(std::string_view name); #endif - static std::stack tempFiles; -#ifndef _WIN32 - static std::string env(std::string_view varname); -#endif + static std::stack tempFiles; }; } diff --git a/src/util/ZipSerialize.cpp b/src/util/ZipSerialize.cpp index cae1ebe95..c3236cc77 100644 --- a/src/util/ZipSerialize.cpp +++ b/src/util/ZipSerialize.cpp @@ -20,7 +20,6 @@ #include "ZipSerialize.h" #include "DateTime.h" -#include "File.h" #include "log.h" #include @@ -30,6 +29,7 @@ #endif #include +#include #include using namespace digidoc; @@ -63,14 +63,14 @@ ZipSerialize::ZipSerialize(string path, bool create) if(create) { DEBUG("ZipSerialize::create(%s)", d->path.c_str()); - d->create = zipOpen2((const char*)util::File::encodeName(d->path).c_str(), APPEND_STATUS_CREATE, nullptr, &d->def); + d->create = zipOpen2((const char*)filesystem::u8path(d->path).c_str(), APPEND_STATUS_CREATE, nullptr, &d->def); if(!d->create) THROW("Failed to create ZIP file '%s'.", d->path.c_str()); } else { DEBUG("ZipSerialize::open(%s)", d->path.c_str()); - d->open = unzOpen2((const char*)util::File::encodeName(d->path).c_str(), &d->def); + d->open = unzOpen2((const char*)filesystem::u8path(d->path).c_str(), &d->def); if(!d->open) THROW("Failed to open ZIP file '%s'.", d->path.c_str()); } diff --git a/src/xml/URIResolver.cpp b/src/xml/URIResolver.cpp index f67343e66..78d8e706f 100644 --- a/src/xml/URIResolver.cpp +++ b/src/xml/URIResolver.cpp @@ -75,24 +75,21 @@ BinInputStream* URIResolver::resolveURI(const XMLCh *uri) throw XSECException(XSECException::ErrorOpeningURI, "XSECURIResolverXerces - anonymous references not supported in default URI Resolvers"); -#ifdef _WIN32 - string _uri = File::decodeName(reinterpret_cast(uri)); -#else - string _uri = xsd::cxx::xml::transcode(uri); -#endif - if(strncmp(_uri.c_str(), "/", 1) == 0) _uri.erase(0, 1); + string _uri = File::fromUriPath(xsd::cxx::xml::transcode(uri)); + if(_uri.front() == '/') + _uri.erase(0); for(const DataFile *file: doc_->dataFiles()) { - if(file->fileName() == File::fromUriPath(_uri)) + if(file->fileName() == _uri) return new IStreamInputStream(static_cast(file)->m_is.get()); } if(doc_->mediaType() == ASiC_E::MIMETYPE_ADOC) { - ASiC_E *adoc = static_cast(doc_); + auto *adoc = static_cast(doc_); for(const DataFile *file: adoc->metaFiles()) { - if(file->fileName() == File::fromUriPath(_uri)) + if(file->fileName() == _uri) return new IStreamInputStream(static_cast(file)->m_is.get()); } } From 3ff26b63b68302a439050a3fb725ea1a35729639 Mon Sep 17 00:00:00 2001 From: Raul Metsma Date: Wed, 4 Oct 2023 22:19:13 +0300 Subject: [PATCH 2/2] Add unicode issuer name compare test IB-7810 Signed-off-by: Raul Metsma --- test/data/gencerts.sh | 3 ++ test/data/unicode.crt | 11 +++++ test/libdigidocpp_boost.cpp | 99 +++++++++++++++++++------------------ test/test.h | 21 ++------ 4 files changed, 68 insertions(+), 66 deletions(-) create mode 100644 test/data/unicode.crt diff --git a/test/data/gencerts.sh b/test/data/gencerts.sh index a15128ce5..edf9829a1 100755 --- a/test/data/gencerts.sh +++ b/test/data/gencerts.sh @@ -23,3 +23,6 @@ done openssl req -out signerEC.req -new -newkey ec:<(openssl ecparam -name secp384r1) -nodes -keyout signerEC.key -subj "/C=EE/CN=signer EC" openssl x509 -req -in signerEC.req -out signerEC.crt -CA inter.crt -CAkey inter.key -CAserial interserial.txt -extfile openssl.conf -extensions v3_usr -days 3650 openssl pkcs12 -export -nodes -in signerEC.crt -inkey signerEC.key -out signerEC.p12 -password pass:signerEC + +openssl req -out unicode.req -new -newkey ec:<(openssl ecparam -name secp384r1) -nodes -keyout unicode.key -subj "/C=EE/CN=unicodeöäüõ" -utf8 +openssl x509 -req -in unicode.req -out unicode.crt -signkey unicode.key -days 365 diff --git a/test/data/unicode.crt b/test/data/unicode.crt new file mode 100644 index 000000000..2ae99a4f6 --- /dev/null +++ b/test/data/unicode.crt @@ -0,0 +1,11 @@ +-----BEGIN CERTIFICATE----- +MIIBhzCCAQwCFHwlKK7JnqHZRCECmbJz/7VNRNMEMAoGCCqGSM49BAMCMCcxCzAJ +BgNVBAYTAkVFMRgwFgYDVQQDDA91bmljb2Rlw7bDpMO8w7UwHhcNMjMxMDA0MTM0 +MTM4WhcNMjQxMDAzMTM0MTM4WjAnMQswCQYDVQQGEwJFRTEYMBYGA1UEAwwPdW5p +Y29kZcO2w6TDvMO1MHYwEAYHKoZIzj0CAQYFK4EEACIDYgAE6Sx6tkRnC2b/J91s +mmL5VhrywL/kGcxJV+bX4ThM+zY3+P59VULwuhCFV3ShjC8Xt8I4iBIhMZQmBfIa +s6jDI7oHxRQWUIG9BCAjnyEUDJIb7PvLRKmf2CsJhmfC+94yMAoGCCqGSM49BAMC +A2kAMGYCMQD4jHmeKWn6YJ0D8S6+2TdFdkeawlD6yoL1HtOVxYxHmVu/wtbSAVM+ +R8uJeR8tg6oCMQDt43YaOQEKgX1T3kBn2Fna8ovhwOVBJUYlVWDW88Sm5qi+ilOn +KRRV6XxGYDbwpRU= +-----END CERTIFICATE----- diff --git a/test/libdigidocpp_boost.cpp b/test/libdigidocpp_boost.cpp index 783728975..045b86407 100644 --- a/test/libdigidocpp_boost.cpp +++ b/test/libdigidocpp_boost.cpp @@ -30,8 +30,6 @@ #include #include -#include - namespace digidoc { @@ -41,7 +39,7 @@ class TestFixture: public DigiDocPPFixture TestFixture() { copyTSL("EE_T-good.xml"); - digidoc::initialize("untitestboost"); + initialize("untitestboost"); } }; @@ -123,9 +121,9 @@ BOOST_AUTO_TEST_SUITE_END() BOOST_AUTO_TEST_SUITE(X509CertSuite) BOOST_AUTO_TEST_CASE(parameters) { - auto signer1 = make_unique("signer1.p12", "signer1"); - X509Cert c = signer1->cert(); - BOOST_CHECK_EQUAL(c, signer1->cert()); + PKCS12Signer signer1("signer1.p12", "signer1"); + X509Cert c = signer1.cert(); + BOOST_CHECK_EQUAL(c, signer1.cert()); BOOST_CHECK_EQUAL(!c, false); BOOST_CHECK_EQUAL(c, true); @@ -143,27 +141,30 @@ BOOST_AUTO_TEST_CASE(parameters) } BOOST_AUTO_TEST_SUITE_END() -BOOST_AUTO_TEST_SUITE(X509Crypto) +BOOST_AUTO_TEST_SUITE(X509CryptoSuite) BOOST_AUTO_TEST_CASE(parameters) { X509Cert cert("47101010033.cer", X509Cert::Pem); - digidoc::X509Crypto crypto(cert); + X509Crypto crypto(cert); BOOST_CHECK_EQUAL(crypto.isRSAKey(), true); BOOST_CHECK_EQUAL(crypto.compareIssuerToString(cert.issuerName()), 0); BOOST_CHECK_EQUAL(crypto.compareIssuerToString("emailAddress=pki@sk.ee,CN=TEST of ESTEID-SK 2015,O=AS Sertifitseerimiskeskus,C=EE"), -1); BOOST_CHECK_EQUAL(crypto.compareIssuerToString("emailAddress=pki@sk.ee,CN=TEST of EST\\45ID-SK 2015,O=AS Sertifitseerimiskeskus,C=EE"), -1); BOOST_CHECK_EQUAL(crypto.compareIssuerToString(cert.issuerName()+"EE"), -1); - digidoc::X509Crypto test(X509Cert("test.crt", X509Cert::Pem)); + X509Cert cert1("unicode.crt", X509Cert::Pem); + BOOST_CHECK_EQUAL(X509Crypto(cert1).compareIssuerToString(cert1.issuerName()), 0); + + X509Crypto test(X509Cert("test.crt", X509Cert::Pem)); BOOST_CHECK_EQUAL(test.compareIssuerToString("CN=\\\"test\\\""), 0); - auto signer1 = make_unique("signer1.p12", "signer1"); + PKCS12Signer signer1("signer1.p12", "signer1"); const vector data{'H','e','l','l','o',' ','w','o','r','l','d'}; vector digest = Digest(URI_SHA256).result(data); - vector signature = signer1->sign(URI_SHA256, digest); - BOOST_CHECK_EQUAL(digidoc::X509Crypto(signer1->cert()).verify(URI_SHA256, digest, signature), true); + vector signature = signer1.sign(URI_SHA256, digest); + BOOST_CHECK_EQUAL(X509Crypto(signer1.cert()).verify(URI_SHA256, digest, signature), true); digest[0] += 1; - BOOST_CHECK_EQUAL(digidoc::X509Crypto(signer1->cert()).verify(URI_SHA256, digest, signature), false); + BOOST_CHECK_EQUAL(X509Crypto(signer1.cert()).verify(URI_SHA256, digest, signature), false); } BOOST_AUTO_TEST_SUITE_END() @@ -291,17 +292,17 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(signature, Doc, DocTypes) BOOST_CHECK_THROW(d->removeSignature(0U), Exception); - auto signer1 = make_unique("signer1.p12", "signer1"); - signer1->setProfile("time-stamp"); - BOOST_CHECK_THROW(d->sign(signer1.get()), Exception); + PKCS12Signer signer1("signer1.p12", "signer1"); + signer1.setProfile("time-stamp"); + BOOST_CHECK_THROW(d->sign(&signer1), Exception); // Add first Signature BOOST_CHECK_NO_THROW(d->addDataFile("test1.txt", "text/plain")); - BOOST_CHECK_NO_THROW(d->sign(signer1.get())); + BOOST_CHECK_NO_THROW(d->sign(&signer1)); BOOST_CHECK_EQUAL(d->signatures().size(), 1U); if(d->signatures().size() == 1) { - BOOST_CHECK_EQUAL(d->signatures().at(0)->signingCertificate(), signer1->cert()); + BOOST_CHECK_EQUAL(d->signatures().at(0)->signingCertificate(), signer1.cert()); BOOST_CHECK_NO_THROW(d->signatures().at(0)->validate()); } BOOST_CHECK_NO_THROW(d->save(Doc::EXT + ".tmp")); @@ -311,12 +312,12 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(signature, Doc, DocTypes) BOOST_CHECK_THROW(d->removeDataFile(0U), Exception); // Add second Signature - auto signer2 = make_unique("signer2.p12", "signer2"); - BOOST_CHECK_NO_THROW(d->sign(signer2.get())); + PKCS12Signer signer2("signer2.p12", "signer2"); + BOOST_CHECK_NO_THROW(d->sign(&signer2)); BOOST_CHECK_EQUAL(d->signatures().size(), 2U); if(d->signatures().size() == 2) { - BOOST_CHECK_EQUAL(d->signatures().at(1)->signingCertificate(), signer2->cert()); + BOOST_CHECK_EQUAL(d->signatures().at(1)->signingCertificate(), signer2.cert()); BOOST_CHECK_NO_THROW(d->signatures().at(1)->validate()); } BOOST_CHECK_NO_THROW(d->save()); @@ -325,18 +326,18 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(signature, Doc, DocTypes) BOOST_CHECK_NO_THROW(d->removeSignature(0U)); BOOST_CHECK_EQUAL(d->signatures().size(), 1U); if(d->signatures().size() == 1) - BOOST_CHECK_EQUAL(d->signatures().at(0)->signingCertificate(), signer2->cert()); + BOOST_CHECK_EQUAL(d->signatures().at(0)->signingCertificate(), signer2.cert()); if(d->mediaType() == ASiCE::TYPE) { - auto signer3 = make_unique("signerEC.p12", "signerEC"); + PKCS12Signer signer3("signerEC.p12", "signerEC"); Signature *s3 = nullptr; - BOOST_CHECK_NO_THROW(s3 = d->sign(signer3.get())); + BOOST_CHECK_NO_THROW(s3 = d->sign(&signer3)); BOOST_CHECK_EQUAL(d->signatures().size(), 2U); if(s3) { BOOST_CHECK_EQUAL(s3->signatureMethod(), URI_ECDSA_SHA256); - BOOST_CHECK_EQUAL(s3->signingCertificate(), signer3->cert()); + BOOST_CHECK_EQUAL(s3->signingCertificate(), signer3.cert()); BOOST_CHECK_NO_THROW(s3->validate()); } BOOST_CHECK_NO_THROW(d->save()); @@ -344,9 +345,9 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(signature, Doc, DocTypes) // Reload from file and validate d = Container::openPtr(Doc::EXT + ".tmp"); BOOST_CHECK_EQUAL(d->signatures().size(), 2U); - if((s3 = d->signatures().back())) + if(s3 = d->signatures().back(); s3) { - BOOST_CHECK_EQUAL(s3->signingCertificate(), signer3->cert()); + BOOST_CHECK_EQUAL(s3->signingCertificate(), signer3.cert()); BOOST_CHECK_NO_THROW(s3->validate()); } @@ -355,43 +356,43 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(signature, Doc, DocTypes) BOOST_CHECK_EQUAL(d->signatures().size(), 1U); // TSA signature - signer2->setProfile("time-stamp-archive"); - BOOST_CHECK_NO_THROW(s3 = d->sign(signer2.get())); - //BOOST_CHECK_EQUAL(s3->TSCertificate(), signer2->cert()); + signer2.setProfile("time-stamp-archive"); + BOOST_CHECK_NO_THROW(s3 = d->sign(&signer2)); + //BOOST_CHECK_EQUAL(s3->TSCertificate(), signer2.cert()); //BOOST_CHECK_NO_THROW(s3->validate()); BOOST_CHECK_NO_THROW(d->save(Doc::EXT + "-TSA.tmp")); BOOST_CHECK_NO_THROW(d->removeSignature(1U)); BOOST_CHECK_EQUAL(d->signatures().size(), 1U); // Save with no SignatureValue and later add signautre value - signer2->setProfile("time-stamp"); + signer2.setProfile("time-stamp"); d = Container::createPtr(Doc::EXT + ".tmp"); BOOST_CHECK_NO_THROW(d->addDataFile("test1.txt", "text/plain")); Signature *s = nullptr; - BOOST_CHECK_NO_THROW(s = d->prepareSignature(signer2.get())); + BOOST_CHECK_NO_THROW(s = d->prepareSignature(&signer2)); vector signatureValue; - BOOST_CHECK_NO_THROW(signatureValue = signer2->sign(s->signatureMethod(), s->dataToSign())); + BOOST_CHECK_NO_THROW(signatureValue = signer2.sign(s->signatureMethod(), s->dataToSign())); BOOST_CHECK_NO_THROW(d->save()); d = Container::openPtr(Doc::EXT + ".tmp"); s = d->signatures().back(); BOOST_CHECK_NO_THROW(s->setSignatureValue(signatureValue)); - BOOST_CHECK_NO_THROW(s->extendSignatureProfile(signer2->profile())); + BOOST_CHECK_NO_THROW(s->extendSignatureProfile(signer2.profile())); BOOST_CHECK_NO_THROW(d->save()); BOOST_CHECK_NO_THROW(s->validate()); // RSA PSS tests d = Container::createPtr(Doc::EXT + ".tmp"); BOOST_CHECK_NO_THROW(d->addDataFile("test1.txt", "text/plain")); - signer1->setMethod(URI_RSA_PSS_SHA256); - BOOST_CHECK_NO_THROW(s = d->sign(signer1.get())); + signer1.setMethod(URI_RSA_PSS_SHA256); + BOOST_CHECK_NO_THROW(s = d->sign(&signer1)); BOOST_CHECK_NO_THROW(s->validate()); - BOOST_CHECK_EQUAL(s->signatureMethod(), signer1->method()); - auto signer4 = make_unique("signerEC384.p12", "signerEC"); - signer4->setProfile("BES"); // Not signed with same Issuer + BOOST_CHECK_EQUAL(s->signatureMethod(), signer1.method()); + PKCS12Signer signer4("signerEC384.p12", "signerEC"); + signer4.setProfile("BES"); // Not signed with same Issuer d = Container::createPtr(Doc::EXT + ".tmp"); BOOST_CHECK_NO_THROW(d->addDataFile("test1.txt", "text/plain")); Signature *s4 = nullptr; - BOOST_CHECK_NO_THROW(s4 = d->sign(signer4.get())); + BOOST_CHECK_NO_THROW(s4 = d->sign(&signer4)); BOOST_CHECK_EQUAL(s4->signatureMethod(), URI_ECDSA_SHA384); } @@ -402,13 +403,13 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(signature, Doc, DocTypes) BOOST_AUTO_TEST_CASE_TEMPLATE(files, Doc, DocTypes) { - auto signer1 = make_unique("signer1.p12", "signer1"); + PKCS12Signer signer1("signer1.p12", "signer1"); for(const string &data : {"0123456789~#%&()=`@{[]}'", "öäüõ"}) { auto d = Container::createPtr("test." + Doc::EXT); const Signature *s1 = nullptr; BOOST_CHECK_NO_THROW(d->addDataFile(data + ".txt", "text/plain")); - BOOST_CHECK_NO_THROW(s1 = d->sign(signer1.get())); + BOOST_CHECK_NO_THROW(s1 = d->sign(&signer1)); if(s1) s1->validate(); d->save(data + Doc::EXT + ".tmp"); @@ -422,23 +423,23 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(files, Doc, DocTypes) BOOST_AUTO_TEST_CASE_TEMPLATE(signatureParameters, Doc, DocTypes) { auto d = Container::createPtr("test." + Doc::EXT); - auto signer1 = make_unique("signer1.p12", "signer1"); + PKCS12Signer signer1("signer1.p12", "signer1"); - signer1->setSignatureProductionPlace("Tartu", "Tartumaa", "12345", "Estonia"); + signer1.setSignatureProductionPlace("Tartu", "Tartumaa", "12345", "Estonia"); vector roles{"Role1"}; - signer1->setSignerRoles( roles ); + signer1.setSignerRoles( roles ); const Signature *s1 = nullptr; BOOST_CHECK_NO_THROW(d->addDataFile("test1.txt", "text/plain")); BOOST_CHECK_NO_THROW(d->addDataFile("test2.bin", "text/plain")); - BOOST_CHECK_NO_THROW(s1 = d->sign(signer1.get())); + BOOST_CHECK_NO_THROW(s1 = d->sign(&signer1)); BOOST_CHECK_EQUAL(d->signatures().size(), 1U); if(s1) { BOOST_CHECK_NO_THROW(s1->validate()); BOOST_CHECK_EQUAL(s1->id(), "S0"); - BOOST_CHECK_EQUAL(s1->signingCertificate(), signer1->cert()); + BOOST_CHECK_EQUAL(s1->signingCertificate(), signer1.cert()); BOOST_CHECK_EQUAL(s1->signerRoles(), roles); BOOST_CHECK_EQUAL(s1->city(), "Tartu"); BOOST_CHECK_EQUAL(s1->stateOrProvince(), "Tartumaa"); @@ -455,8 +456,8 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(signatureParameters, Doc, DocTypes) if(d->signatures().size() == 1U) BOOST_CHECK_NO_THROW(d->signatures().front()->validate()); - auto signer3 = make_unique("signer3.p12", "signer3"); - BOOST_CHECK_THROW(d->sign(signer3.get()), Exception); // OCSP UNKNOWN + PKCS12Signer signer3("signer3.p12", "signer3"); + BOOST_CHECK_THROW(d->sign(&signer3), Exception); // OCSP UNKNOWN } BOOST_AUTO_TEST_SUITE_END() diff --git a/test/test.h b/test/test.h index b61948664..0fe9138a3 100644 --- a/test/test.h +++ b/test/test.h @@ -27,15 +27,9 @@ #include #include -#ifdef _WIN32 -#include -#define chdir _chdir -#else -#include -#endif - using namespace digidoc; using namespace std; +namespace fs = filesystem; namespace std { @@ -102,7 +96,6 @@ class TestConfig: public ConfCurrent profiles.emplace("1.3.6.1.4.1.10015.3.1.1"); return profiles; } - bool PKCS12Disable() const override { return true; } string TSUrl() const override { return "http://demo.sk.ee/tsa/"; } bool TSLAutoUpdate() const override { return false; } string TSLCache() const override { return path; } @@ -128,10 +121,7 @@ class DigiDocPPFixture if(argc > 1) { //BOOST_MESSAGE("Data path " + string(boost::unit_test::framework::master_test_suite().argv[argc-1])); -DIGIDOCPP_WARNING_PUSH -DIGIDOCPP_WARNING_DISABLE_GCC("-Wunused-result") - chdir(boost::unit_test::framework::master_test_suite().argv[argc-1]); -DIGIDOCPP_WARNING_POP + fs::current_path(boost::unit_test::framework::master_test_suite().argv[argc-1]); path = conf->path = boost::unit_test::framework::master_test_suite().argv[argc-1]; } boost::unit_test::unit_test_monitor.register_exception_translator(&translate_exception); @@ -155,11 +145,8 @@ DIGIDOCPP_WARNING_POP void copyTSL(const string &from) { - ifstream i(util::File::encodeName(from).c_str(), ofstream::binary); - ofstream o(util::File::encodeName(path + "/EE_T.xml").c_str(), ifstream::binary); - o << i.rdbuf(); - o.close(); - i.close(); + ofstream(util::File::encodeName(path + "/EE_T.xml"), ifstream::binary) + << ifstream(util::File::encodeName(from), ofstream::binary).rdbuf(); } string path = ".";