public inbox for network@lists.ipfire.org
 help / color / mirror / Atom feed
* [PATCH v2 1/5] util: refactor fwrite
@ 2017-07-17 18:19 Jonatan Schlag
  2017-07-17 18:19 ` [PATCH v2 2/5] util: add new function copy Jonatan Schlag
                   ` (3 more replies)
  0 siblings, 4 replies; 5+ messages in thread
From: Jonatan Schlag @ 2017-07-17 18:19 UTC (permalink / raw)
  To: network

[-- Attachment #1: Type: text/plain, Size: 1118 bytes --]

This functions now:
	- return an error when the destination is a directory
	- creates the destination if the destination not exist

Signed-off-by: Jonatan Schlag <jonatan.schlag(a)ipfire.org>
---
 src/functions/functions.util | 20 +++++++++++++++++---
 1 file changed, 17 insertions(+), 3 deletions(-)

diff --git a/src/functions/functions.util b/src/functions/functions.util
index 381208c..3bcd00f 100644
--- a/src/functions/functions.util
+++ b/src/functions/functions.util
@@ -179,12 +179,26 @@ fwrite() {
 	assert isset file
 	shift
 
-	if [ ! -w "${file}" ]; then
-		log ERROR "${file}: No such file"
+	if [ -d "${file}" ]; then
+		log ERROR "${file} is a directory"
 		return ${EXIT_ERROR}
 	fi
 
-	print "%s" "$@" >> ${file} 2>/dev/null
+	if [ -f "${file}" ]; then
+		if [ -w "${file}" ]; then
+			print "%s" "$@" >> ${file} 2>/dev/null
+		else
+			log ERROR "${file} is not writeable"
+			return ${EXIT_ERROR}
+		fi
+	else
+		if ! touch "${file}"; then
+			log ERROR "Could not touch ${file}"
+			return ${EXIT_ERROR}
+		fi
+
+		print "%s" "$@" >> ${file} 2>/dev/null
+	fi
 }
 
 make_parent_dir() {
-- 
2.6.3


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2017-07-17 18:19 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-07-17 18:19 [PATCH v2 1/5] util: refactor fwrite Jonatan Schlag
2017-07-17 18:19 ` [PATCH v2 2/5] util: add new function copy Jonatan Schlag
2017-07-17 18:19 ` [PATCH v2 3/5] constants: add new constant NETWORK_SHARE_DIR Jonatan Schlag
2017-07-17 18:19 ` [PATCH v2 4/5] add new feature vpn security policies Jonatan Schlag
2017-07-17 18:19 ` [PATCH v2 5/5] Add vpn security policies to cli Jonatan Schlag

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox