mirror of
https://github.com/libretro/RetroArch
synced 2025-01-30 03:32:46 +00:00
cd574f7f33
Also update to latest (last) version of GCDWebServer.
161 lines
5.1 KiB
Objective-C
161 lines
5.1 KiB
Objective-C
/*
|
|
Copyright (c) 2012-2019, Pierre-Olivier Latour
|
|
All rights reserved.
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
modification, are permitted provided that the following conditions are met:
|
|
* Redistributions of source code must retain the above copyright
|
|
notice, this list of conditions and the following disclaimer.
|
|
* Redistributions in binary form must reproduce the above copyright
|
|
notice, this list of conditions and the following disclaimer in the
|
|
documentation and/or other materials provided with the distribution.
|
|
* The name of Pierre-Olivier Latour may not be used to endorse
|
|
or promote products derived from this software without specific
|
|
prior written permission.
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
DISCLAIMED. IN NO EVENT SHALL PIERRE-OLIVIER LATOUR BE LIABLE FOR ANY
|
|
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
|
|
#import "GCDWebServer.h"
|
|
|
|
NS_ASSUME_NONNULL_BEGIN
|
|
|
|
@class GCDWebDAVServer;
|
|
|
|
/**
|
|
* Delegate methods for GCDWebDAVServer.
|
|
*
|
|
* @warning These methods are always called on the main thread in a serialized way.
|
|
*/
|
|
@protocol GCDWebDAVServerDelegate <GCDWebServerDelegate>
|
|
@optional
|
|
|
|
/**
|
|
* This method is called whenever a file has been downloaded.
|
|
*/
|
|
- (void)davServer:(GCDWebDAVServer*)server didDownloadFileAtPath:(NSString*)path;
|
|
|
|
/**
|
|
* This method is called whenever a file has been uploaded.
|
|
*/
|
|
- (void)davServer:(GCDWebDAVServer*)server didUploadFileAtPath:(NSString*)path;
|
|
|
|
/**
|
|
* This method is called whenever a file or directory has been moved.
|
|
*/
|
|
- (void)davServer:(GCDWebDAVServer*)server didMoveItemFromPath:(NSString*)fromPath toPath:(NSString*)toPath;
|
|
|
|
/**
|
|
* This method is called whenever a file or directory has been copied.
|
|
*/
|
|
- (void)davServer:(GCDWebDAVServer*)server didCopyItemFromPath:(NSString*)fromPath toPath:(NSString*)toPath;
|
|
|
|
/**
|
|
* This method is called whenever a file or directory has been deleted.
|
|
*/
|
|
- (void)davServer:(GCDWebDAVServer*)server didDeleteItemAtPath:(NSString*)path;
|
|
|
|
/**
|
|
* This method is called whenever a directory has been created.
|
|
*/
|
|
- (void)davServer:(GCDWebDAVServer*)server didCreateDirectoryAtPath:(NSString*)path;
|
|
|
|
@end
|
|
|
|
/**
|
|
* The GCDWebDAVServer subclass of GCDWebServer implements a class 1 compliant
|
|
* WebDAV server. It is also partially class 2 compliant but only when the
|
|
* client is the OS X WebDAV implementation (so it can work with the OS X Finder).
|
|
*
|
|
* See the README.md file for more information about the features of GCDWebDAVServer.
|
|
*/
|
|
@interface GCDWebDAVServer : GCDWebServer
|
|
|
|
/**
|
|
* Returns the upload directory as specified when the server was initialized.
|
|
*/
|
|
@property(nonatomic, readonly) NSString* uploadDirectory;
|
|
|
|
/**
|
|
* Sets the delegate for the server.
|
|
*/
|
|
@property(nonatomic, weak, nullable) id<GCDWebDAVServerDelegate> delegate;
|
|
|
|
/**
|
|
* Sets which files are allowed to be operated on depending on their extension.
|
|
*
|
|
* The default value is nil i.e. all file extensions are allowed.
|
|
*/
|
|
@property(nonatomic, copy) NSArray<NSString*>* allowedFileExtensions;
|
|
|
|
/**
|
|
* Sets if files and directories whose name start with a period are allowed to
|
|
* be operated on.
|
|
*
|
|
* The default value is NO.
|
|
*/
|
|
@property(nonatomic) BOOL allowHiddenItems;
|
|
|
|
/**
|
|
* This method is the designated initializer for the class.
|
|
*/
|
|
- (instancetype)initWithUploadDirectory:(NSString*)path;
|
|
|
|
@end
|
|
|
|
/**
|
|
* Hooks to customize the behavior of GCDWebDAVServer.
|
|
*
|
|
* @warning These methods can be called on any GCD thread.
|
|
*/
|
|
@interface GCDWebDAVServer (Subclassing)
|
|
|
|
/**
|
|
* This method is called to check if a file upload is allowed to complete.
|
|
* The uploaded file is available for inspection at "tempPath".
|
|
*
|
|
* The default implementation returns YES.
|
|
*/
|
|
- (BOOL)shouldUploadFileAtPath:(NSString*)path withTemporaryFile:(NSString*)tempPath;
|
|
|
|
/**
|
|
* This method is called to check if a file or directory is allowed to be moved.
|
|
*
|
|
* The default implementation returns YES.
|
|
*/
|
|
- (BOOL)shouldMoveItemFromPath:(NSString*)fromPath toPath:(NSString*)toPath;
|
|
|
|
/**
|
|
* This method is called to check if a file or directory is allowed to be copied.
|
|
*
|
|
* The default implementation returns YES.
|
|
*/
|
|
- (BOOL)shouldCopyItemFromPath:(NSString*)fromPath toPath:(NSString*)toPath;
|
|
|
|
/**
|
|
* This method is called to check if a file or directory is allowed to be deleted.
|
|
*
|
|
* The default implementation returns YES.
|
|
*/
|
|
- (BOOL)shouldDeleteItemAtPath:(NSString*)path;
|
|
|
|
/**
|
|
* This method is called to check if a directory is allowed to be created.
|
|
*
|
|
* The default implementation returns YES.
|
|
*/
|
|
- (BOOL)shouldCreateDirectoryAtPath:(NSString*)path;
|
|
|
|
@end
|
|
|
|
NS_ASSUME_NONNULL_END
|