示例#1
0
文件: content.py 项目: tuxun/ludobox
def write_attachments(attachments, game_path):
    """Write all files contains in attachements into game directory"""

    # Create a directory to store the uploaded files
    attachments_path = os.path.join(game_path, "files")
    try:
        if not os.path.exists(attachments_path):
            os.makedirs(attachments_path)
    except Exception as e:
        message = "<Error> occured while "\
                  "writing game info to path '{path}'. "\
                  "Impossible to create "\
                  "directory '{attachments_path}' to store the attached "\
                  "files.".format(
                    path=game_path,
                    attachments_path=os.path.abspath(attachments_path))
        print message
        raise LudoboxError(message)

    # Write all the files
    for f in attachments:
        file_clean_name = secure_filename(f.filename)

        # check if extension is allowed
        # TODO: check for more security issues ?
        if not allowed_file(file_clean_name):
            message = "<{error}> occured while "\
                      "writing. Impossible to save file"\
                      "'{file_clean_name}' because exstension is not allowed".format(
                        error="FileNotAllowed", # TODO create ValidationError
                        file_clean_name=file_clean_name)

            raise LudoboxError(message)

        file_path = os.path.join(attachments_path, file_clean_name)
        print file_path
        try:
            f.save(file_path)
        except Exception as e:
            message = "<{error}> occured while "\
                      "writing game info to path '{path}'."\
                      "Impossible to save file"\
                      "'{file_path}' in the attachment directory "\
                      "'{attachments_path}'.".format(
                        error=e.strerror,
                        path=data_dir,
                        file_path=os.path.abspath(file_path),
                        attachments_path=os.path.abspath(attachments_path))
            raise LudoboxError(message)
示例#2
0
    def test_error_do_dict(self):
        message = "some message"
        with self.assertRaises(LudoboxError) as cm:
            raise LudoboxError(message)

        print cm.exception.to_dict()
        self.assertEqual({"message": message}, cm.exception.to_dict())
示例#3
0
文件: content.py 项目: tuxun/ludobox
def write_info_json(info, game_path):
    """Write a JSON file based on valid resource data"""

    # validate game data
    try:
        validate_game_data(info)
    except ValidationError as e:
        print e
        # Cleanup anything previously created
        clean_game(game_path)
        raise ValidationError(e)

    # Convert the data to JSON into file
    content = json.dumps(info, sort_keys=True, indent=4, default=json_serial)
    json_path = os.path.join(game_path, "info.json")

    try:
        with open(json_path, "w") as json_file:
            json_file.write(content.encode('utf-8'))
    except IOError as e:
        # Cleanup anything previously created
        clean_game(game_path)

        # TODO Handle more explicit message
        message = "<{error}> occured while "\
                  "writing game info file to path '{path}'"\
                  "Impossible to write JSON file '{json}'.".format(
                    error=e.strerror,
                    path=game_path,
                    json=json_path)
        raise LudoboxError(message)
示例#4
0
def write_info_json(info, resource_folder_path):
    """Write a JSON file based on valid resource data"""

    # remove stuff we don't need
    info.pop('files', None)
    info.pop('errors', None)
    info.pop('has_errors', None)

    # Convert the data to JSON into file
    content = json.dumps(info, sort_keys=True, indent=4, default=json_serial)
    json_path = os.path.join(resource_folder_path, "info.json")

    try:
        with open(json_path, "w") as json_file:
            json_file.write(content.encode('utf-8'))
    except IOError as e:
        # Cleanup anything previously created
        delete_resource_folder(resource_folder_path)

        # TODO Handle more explicit message
        message = "<{error}> occured while "\
                  "writing game info file to path '{path}'"\
                  "Impossible to write JSON file '{json}'.".format(
                    error=e.strerror,
                    path=resource_folder_path,
                    json=json_path)
        raise LudoboxError(message)
示例#5
0
 def test_status_code_payload(self):
     message = "some message"
     with self.assertRaises(LudoboxError) as cm:
         raise LudoboxError(message,
                            status_code=403,
                            payload={"data": "data"})
     self.assertEqual(403, cm.exception.status_code)
     self.assertEqual({"data": "data"}, cm.exception.payload)
示例#6
0
文件: content.py 项目: tuxun/ludobox
def read_game_info(path):
    """
    Read all the info available about the game stored at the provided path.

    Arguments:
    path -- directory where the game info and data are stored

    Returns a dictionary containing the game data.

    >>> data = read_game_info("tests/functional/data/hackathon/borgia-le-jeu-malsain")
    >>> print(', '.join(data['audience']))
    adults
    >>> print(', '.join(data['authors']))
    René
    >>> print(', '.join(data['themes']['fr']))
    Médiéval, Salopard

    If anythin goes wrong raise a LudoboxError containing description of the
    error and advice for fixing it.

    >>> try:
    ...     data = read_game_info("stupid_path/no_game")
    ... except LudoboxError as e:
    ...     print(e.message)
    <No such file or directory> occured while reading game 'no_game' info file 'stupid_path/no_game/info.json'

    The game data can come from:
    *   the info.json file
    *   the attached files found in the dir
    *   somme are also computed from other data like a cleaned name suitable
        for url generation (slugified name)
    """
    # Load JSON from the description file of the game
    json_path = os.path.join(path, "info.json")
    try:
        with open(json_path, "r") as json_file:
            data = json.load(json_file)
    except IOError as e:
        # TODO Handle more precisely the error and provide an advice for
        #   solving the problem
        # Create a very explicit message to explain the problem
        message = "<{error}> occured while "\
                  "reading game '{game}' info file '{json}'".format(
                    error=e.strerror,
                    game=os.path.basename(path),
                    json=e.filename)
        raise LudoboxError(message)

    # validate data
    validate_game_data(data)

    # TODO Add some attachment info

    # Add permalink
    data["slug"] = get_resource_slug(data)

    return data
示例#7
0
def check_attachments(attachments):
    """Make sure we can upload only safe files"""
    for f in attachments:
        if not allowed_extension(f.filename):
            message = "<{error}> occured while "\
                      "writing. Impossible to save file"\
                      "'{file_clean_name}' because exstension is not allowed".format(
                        error="FileNotAllowed", # TODO create ValidationError
                        file_clean_name=f.filename)
            raise LudoboxError(message)
示例#8
0
def create_resource_folder(resource_folder_path) :
    """Create the dir to store the game"""
    try:
        os.makedirs(resource_folder_path)
    except Exception as e:
        message = "<{error}> occured while writing game info file."\
                  "Impossible to create directory '{resource_folder_path}'.".format(
                    error=e.strerror,
                    resource_folder_path=os.path.abspath(resource_folder_path))
        raise LudoboxError(message)
示例#9
0
def write_attachments(attachments, game_path):
    """Write all files contains in attachements into game directory"""

    # Check files
    check_attachments(attachments)

    # Create a directory to store the uploaded files
    attachments_path = os.path.join(game_path, "files")
    try:
        if not os.path.exists(attachments_path):
            os.makedirs(attachments_path)
    except Exception as e:
        message = "<Error> occured while "\
                  "writing game info to path '{path}'. "\
                  "Impossible to create "\
                  "directory '{attachments_path}' to store the attached "\
                  "files.".format(
                    path=game_path,
                    attachments_path=os.path.abspath(attachments_path))
        raise LudoboxError(message)

    # Write all the files
    for f in attachments:
        file_clean_name = secure_filename(f.filename)
        file_path = os.path.join(attachments_path, file_clean_name)
        current_app.logger.debug("saving  %s" % file_path)
        try:
            f.save(file_path)
        except Exception as e:
            message = "<{error}> occured while "\
                      "writing game info to path '{path}'."\
                      "Impossible to save file"\
                      "'{file_path}' in the attachment directory "\
                      "'{attachments_path}'.".format(
                        error=e.strerror,
                        path=data_dir,
                        file_path=os.path.abspath(file_path),
                        attachments_path=os.path.abspath(attachments_path))
            raise LudoboxError(message)
示例#10
0
文件: content.py 项目: tuxun/ludobox
def get_resource_slug(data):
    """Get the slugified name of the game based on the data set"""
    try:
        slug = slugify(data["title"])
        # add language
        language = data["audience"]["language"]
        return "%s-%s"%(slug,language)
    except KeyError as e:
        # TODO more explicit error message
        message = "KeyError occured while "\
                  "writing game info file to path '{path}'. "\
                  "Impossible to access data['title'].".format(
                    path=data)
        raise LudoboxError(message)
示例#11
0
文件: content.py 项目: tuxun/ludobox
def create_game_path(game_path) :
    """Create the dir to store the game"""
    try:
        os.makedirs(game_path)
    except Exception as e:
        message = "<{error}> occured while "\
                  "writing game info file to path '{path}'."\
                  "Impossible to create "\
                  "directory '{game_path}'.".format(
                    error=e.strerror,
                    path=config['data_dir'],
                    game_path=os.path.abspath(game_path))
        raise LudoboxError(message)
    print "path created : %s"%game_path
示例#12
0
文件: content.py 项目: tuxun/ludobox
def store_files(game_path, attachments):
    """
    Write files

    - attachments: files to be uploaded to the game folder
    - path
    """
    print attachments

    # Write the attached files
    if attachments:
        try :
            write_attachments(attachments, game_path)
        except LudoboxError as e:
            raise LudoboxError(str(e))

    return game_path
示例#13
0
def store_files(game_path, attachments):
    """
    Write files

    - attachments: files to be uploaded to the game folder
    - path
    """
    current_app.logger.debug("attached files : %s" % attachments)

    # Write the attached files
    if attachments:
        try:
            write_attachments(attachments, game_path)
        except LudoboxError as e:
            raise LudoboxError(str(e))

    return game_path
示例#14
0
def update_content_state(resource_path, new_state):

    # get current state
    info = read_content(resource_path)
    old_state = info["state"]

    # validate state change
    if not is_valid_state_change(old_state, new_state):
        raise LudoboxError(
            "<Wrong State> Can not update state content to the same state.")

    # update info
    new_info = info.copy()
    new_info["state"] = new_state

    new_content = update_content_info(resource_path, new_info, state=new_state)

    return new_content
示例#15
0
文件: content.py 项目: tuxun/ludobox
def write_game(info, attachments, data_dir):
    """
    Write a JSON file description of a game according to the provided data and
    attachment files in a dedicated directory named after the game.

    Arguments:
    info -- a dictionnary storing all the information about the game. It
            exactly mimic the structure of the disired JSON file. The
            data["title"] must exist, no other verification is made to
            check it contains coherent structure or data.
    attachments -- list of files attached to the game (rules, images...).
    data_dir -- directory where all the game directories are stored i.e. where
                a directory named after the game will be created to store the
                JSON file. It must exist.

    Returns the path to the directory created to store the JSON file (it
    should be named after the game!).

    Raises a LudoboxError if anything goes wrong.

    the :func:`write_game_info()` and :func:`read_game_info()` function should
    work nicely together. Any file writen with the first should be readable by
    the second:
    """

    slugified_name = get_resource_slug(info)

    # Create a directory after the cleaned name of the game
    game_path = os.path.join(data_dir, slugified_name)
    create_game_path(game_path)

    # create JSON resource
    write_info_json(info, game_path)

    # Write the attached files
    if attachments:
        try :
            write_attachments(attachments, game_path)
        except LudoboxError as e:
            raise LudoboxError(str(e))

    return game_path
示例#16
0
def read_info_json(resource_folder_path):
    """Load JSON from the description file of the game"""

    json_path = os.path.join(resource_folder_path, "info.json")

    try:
        with open(json_path, "r") as json_file:
            data = json.load(json_file)
    except IOError as e:
        # TODO Handle more precisely the error and provide an advice for
        #   solving the problem
        # Create a very explicit message to explain the problem
        message = "<{error}> occured while "\
                  "reading game '{game}' info file '{json}'".format(
                    error=e.strerror,
                    game=os.path.basename(resource_folder_path),
                    json=e.filename)
        raise LudoboxError(message)

    return data
示例#17
0
def get_content_type(data):

    # try to guess the content type
    try :
        content_type = data["content_type"]
    except KeyError:
        message = "<Missing Content Type> You need to explicitely "\
        "define a 'content_type' property to read this content. "\
        "Authorized content types are : {allowed}".format(
            allowed=" ,".join(VALID_CONTENT_TYPES)
            )
        raise LudoboxError(message)

    assert content_type in VALID_CONTENT_TYPES

    # TODO : implement those guys
    if content_type in ["page", "workshop"] :
        raise NotImplementedError("Page and workshop... coming soon !")

    return content_type
示例#18
0
 def test_message(self):
     message = "some message"
     with self.assertRaises(LudoboxError) as cm:
         raise LudoboxError(message)
     self.assertEqual(message, cm.exception.message)
     self.assertEqual(400, cm.exception.status_code)