mirror of
https://github.com/ipxe/ipxe
synced 2025-12-13 07:20:47 +03:00
[settings] Re-add "uristring" setting type
Commit09b057c("[settings] Remove "uristring" setting type") removed support for URI-encoded settings via the "uristring" setting type, on the basis that such encoding was no longer necessary to avoid problems with the command line parser. Other valid use cases for the "uristring" setting type do exist: for example, a password containing a '/' character expanded via chain http://username:${password:uristring}@server.name/boot.php Restore the existence of the "uristring" setting, avoiding the potentially large stack allocations that were used in the old code prior to commit09b057c("[settings] Remove "uristring" setting type"). Requested-by: Robin Smidsrød <robin@smidsrod.no> Signed-off-by: Michael Brown <mcb30@ipxe.org>
This commit is contained in:
@@ -191,8 +191,11 @@ uri_put ( struct uri *uri ) {
|
||||
|
||||
extern struct uri *cwuri;
|
||||
|
||||
extern size_t uri_encode ( const char *string, unsigned int field,
|
||||
extern size_t uri_decode ( const char *encoded, void *buf, size_t len );
|
||||
extern size_t uri_encode ( unsigned int field, const void *raw, size_t raw_len,
|
||||
char *buf, ssize_t len );
|
||||
extern size_t uri_encode_string ( unsigned int field, const char *string,
|
||||
char *buf, ssize_t len );
|
||||
extern struct uri * parse_uri ( const char *uri_string );
|
||||
extern size_t format_uri ( const struct uri *uri, char *buf, size_t len );
|
||||
extern char * format_uri_alloc ( const struct uri *uri );
|
||||
|
||||
Reference in New Issue
Block a user