Browse Source

add auto command to populate some standard fields, e.g. mimetype

main
John-Mark Gurney 2 years ago
parent
commit
cd9159ddf3
4 changed files with 66 additions and 4 deletions
  1. +31
    -0
      ui/fixtures/cmd.auto.json
  2. BIN
      ui/fixtures/testfiles/z.jpg
  3. +34
    -4
      ui/medashare/cli.py
  4. +1
    -0
      ui/setup.py

+ 31
- 0
ui/fixtures/cmd.auto.json View File

@@ -0,0 +1,31 @@
[
{
"title": "gen ident",
"cmd": [ "genident", "name=A Test User" ],
"exit": 0
},
{
"title": "Test auto detection of file",
"cmd": [ "auto", "test.txt" ],
"stdin": "y\n",
"stdout": "Set:\n\tmimetype:\ttext/plain; charset=us-ascii\n\nApply (y/N)?\n"
},
{
"title": "Verify modification",
"cmd": [ "list", "test.txt" ],
"stdin": "y\n",
"stdout_re": ".*mimetype:\ttext/plain; charset=us-ascii.*"
},
{
"title": "Test auto detection of jpeg file",
"cmd": [ "auto", "z.jpg" ],
"stdin": "y\n",
"stdout": "Set:\n\tmimetype:\timage/jpeg\n\nApply (y/N)?\n"
},
{
"title": "Verify modification",
"cmd": [ "list", "z.jpg" ],
"stdin": "y\n",
"stdout_re": ".*mimetype:\timage/jpeg"
}
]

BIN
ui/fixtures/testfiles/z.jpg View File

Before After
Width: 1  |  Height: 1  |  Size: 332 B

+ 34
- 4
ui/medashare/cli.py View File

@@ -20,6 +20,7 @@ import hashlib
import io import io
import itertools import itertools
import json import json
import magic
import os.path import os.path
import pathlib import pathlib
import pasn1 import pasn1
@@ -670,7 +671,7 @@ def enumeratedir(_dir, created_by_ref):
Returned is a list of FileObjects.''' Returned is a list of FileObjects.'''


return [FileObject.from_file(os.path.join(_dir, x), return [FileObject.from_file(os.path.join(_dir, x),
created_by_ref) for x in os.listdir(_dir) if not
created_by_ref) for x in sorted(os.listdir(_dir)) if not
os.path.isdir(os.path.join(_dir, x)) ] os.path.isdir(os.path.join(_dir, x)) ]


def get_objstore(options): def get_objstore(options):
@@ -820,6 +821,26 @@ def cmd_dump(options):
for i in objstr: for i in objstr:
print(i.encode('json')) print(i.encode('json'))


def cmd_auto(options):
for i in options.files:
mf = magic.detect_from_filename(i)

primary = mf[0].split('/', 1)[0]
mt = mf[0]
if primary == 'text':
mt += '; charset=%s' % mf[1]

print('Set:')
print('\tmimetype:\t%s' % mt)
print()
print('Apply (y/N)?')

inp = sys.stdin.readline()

if inp.strip().lower() in ('y', 'yes'):
options.modtagvalues = [ '+mimetype=%s' % mt ]
cmd_modify(options)

def cmd_list(options): def cmd_list(options):
persona, objstr = get_objstore(options) persona, objstr = get_objstore(options)


@@ -837,7 +858,6 @@ def cmd_list(options):
except (FileNotFoundError, KeyError) as e: except (FileNotFoundError, KeyError) as e:
print('ERROR: file not found: %s' % repr(i), file=sys.stderr) print('ERROR: file not found: %s' % repr(i), file=sys.stderr)
sys.exit(1) sys.exit(1)

except FileNotFoundError: except FileNotFoundError:
# XXX - tell the difference? # XXX - tell the difference?
print('ERROR: file not found: %s' % repr(i), print('ERROR: file not found: %s' % repr(i),
@@ -912,6 +932,11 @@ def main():
help='files to modify') help='files to modify')
parser_mod.set_defaults(func=cmd_modify) parser_mod.set_defaults(func=cmd_modify)


parser_auto = subparsers.add_parser('auto', help='automatic detection of file properties')
parser_auto.add_argument('files', nargs='+',
help='files to modify')
parser_auto.set_defaults(func=cmd_auto)

parser_list = subparsers.add_parser('list', help='list tags on file(s)') parser_list = subparsers.add_parser('list', help='list tags on file(s)')
parser_list.add_argument('files', nargs='+', parser_list.add_argument('files', nargs='+',
help='files to modify') help='files to modify')
@@ -1141,7 +1166,7 @@ class _TestCases(unittest.TestCase):


def test_enumeratedir(self): def test_enumeratedir(self):
files = enumeratedir(self.tempdir, self.created_by_ref) files = enumeratedir(self.tempdir, self.created_by_ref)
ftest = files[1]
ftest = [ x for x in files if x.filename == 'test.txt' ][0]
fname = 'test.txt' fname = 'test.txt'


# make sure that they are of type MDBase # make sure that they are of type MDBase
@@ -1459,6 +1484,7 @@ class _TestCases(unittest.TestCase):
self.assertRegex(stdout.getvalue(), outre) self.assertRegex(stdout.getvalue(), outre)
else: else:
self.assertEqual(stdout.getvalue(), cmd.get('stdout', '')) self.assertEqual(stdout.getvalue(), cmd.get('stdout', ''))

self.assertEqual(stderr.getvalue(), cmd.get('stderr', '')) self.assertEqual(stderr.getvalue(), cmd.get('stderr', ''))


self.assertEqual(cm.exception.code, cmd.get('exit', 0)) self.assertEqual(cm.exception.code, cmd.get('exit', 0))
@@ -1468,9 +1494,13 @@ class _TestCases(unittest.TestCase):
i.stop() i.stop()


def test_cmds(self): def test_cmds(self):
cmds = self.fixtures.glob('cmd.*.json')
cmds = sorted(self.fixtures.glob('cmd.*.json'))


for i in cmds: for i in cmds:
# make sure each file starts with a clean slate
self.tearDown()
self.setUp()

os.chdir(self.tempdir) os.chdir(self.tempdir)
self.run_command_file(i) self.run_command_file(i)




+ 1
- 0
ui/setup.py View File

@@ -28,6 +28,7 @@ setup(
'hypercorn', # option, for server only? 'hypercorn', # option, for server only?
'orm', 'orm',
'pasn1 @ git+https://www.funkthat.com/gitea/jmg/pasn1.git@c6c64510b42292557ace2b77272eb32cb647399d#egg=pasn1', 'pasn1 @ git+https://www.funkthat.com/gitea/jmg/pasn1.git@c6c64510b42292557ace2b77272eb32cb647399d#egg=pasn1',
'file-magic @ git+https://github.com/file/file.git#egg=file-magic&subdirectory=python',
'pydantic[dotenv]', 'pydantic[dotenv]',
], ],
extras_require = { extras_require = {


Loading…
Cancel
Save