當前位置: 首頁>>代碼示例>>Python>>正文


Python IIIFInfo.server_and_prefix方法代碼示例

本文整理匯總了Python中iiif.info.IIIFInfo.server_and_prefix方法的典型用法代碼示例。如果您正苦於以下問題:Python IIIFInfo.server_and_prefix方法的具體用法?Python IIIFInfo.server_and_prefix怎麽用?Python IIIFInfo.server_and_prefix使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在iiif.info.IIIFInfo的用法示例。


在下文中一共展示了IIIFInfo.server_and_prefix方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: image_information_response

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import server_and_prefix [as 別名]
 def image_information_response(self):
     """Parse image information request and create response."""
     dr = degraded_request(self.identifier)
     if (dr):
         self.logger.info("image_information: degraded %s -> %s" % (self.identifier,dr))
         self.degraded = self.identifier
         self.identifier = dr
     else:
         self.logger.info("image_information: %s" % (self.identifier))
     # get size
     self.manipulator.srcfile=self.file
     self.manipulator.do_first()
     # most of info.json comes from config, a few things specific to image
     info = { 'tile_height': self.config.tile_height,
              'tile_width': self.config.tile_width,
              'scale_factors' : self.config.scale_factors
            }
     i = IIIFInfo(conf=info,api_version=self.api_version)
     i.server_and_prefix = self.server_and_prefix
     i.identifier = self.iiif.identifier
     i.width = self.manipulator.width
     i.height = self.manipulator.height
     if (self.api_version>='2.0'):
         i.qualities = [ "default", "color", "gray" ] #FIXME - should come from manipulator
     else:
         i.qualities = [ "native", "color", "gray" ] #FIXME - should come from manipulator
     i.formats = [ "jpg", "png" ] #FIXME - should come from manipulator
     if (self.auth):
         self.auth.add_services(i)
     return self.make_response(i.as_json(),content_type=self.json_mime_type)
開發者ID:pbinkley,項目名稱:iiif,代碼行數:32,代碼來源:iiif_testserver.py

示例2: test02_id

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import server_and_prefix [as 別名]
    def test02_id(self):
        """Test identifier handling."""
        i = IIIFInfo()
        # setter
        i.id = ""
        self.assertEqual(i.server_and_prefix, "")
        self.assertEqual(i.identifier, "")
        i.id = "a"
        self.assertEqual(i.server_and_prefix, "")
        self.assertEqual(i.identifier, "a")
        i.id = "a/b"
        self.assertEqual(i.server_and_prefix, "a")
        self.assertEqual(i.identifier, "b")
        i.id = "a/b/c"
        self.assertEqual(i.server_and_prefix, "a/b")
        self.assertEqual(i.identifier, "c")
        i.id = "a//b"
        self.assertEqual(i.server_and_prefix, "a/")
        self.assertEqual(i.identifier, "b")
        i.id = "/d"
        self.assertEqual(i.server_and_prefix, "")
        self.assertEqual(i.identifier, "d")

        def xx(value):  # FIXME - better way to test setter?
            i.id = value

        self.assertRaises(AttributeError, xx, None)
        self.assertRaises(AttributeError, xx, 123)
        # property
        i.server_and_prefix = ""
        i.identifier = ""
        self.assertEqual(i.id, "")
        i.identifier = "abc"
        self.assertEqual(i.id, "abc")
        i.server_and_prefix = "def"
        self.assertEqual(i.id, "def/abc")
        i.identifier = ""
        self.assertEqual(i.id, "def/")
開發者ID:edsilv,項目名稱:iiif,代碼行數:40,代碼來源:test_info_common.py

示例3: test02_id

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import server_and_prefix [as 別名]
    def test02_id(self):
        """Test identifier handling."""
        i = IIIFInfo()
        # setter
        i.id = ''
        self.assertEqual(i.server_and_prefix, '')
        self.assertEqual(i.identifier, '')
        i.id = 'a'
        self.assertEqual(i.server_and_prefix, '')
        self.assertEqual(i.identifier, 'a')
        i.id = 'a/b'
        self.assertEqual(i.server_and_prefix, 'a')
        self.assertEqual(i.identifier, 'b')
        i.id = 'a/b/c'
        self.assertEqual(i.server_and_prefix, 'a/b')
        self.assertEqual(i.identifier, 'c')
        i.id = 'a//b'
        self.assertEqual(i.server_and_prefix, 'a/')
        self.assertEqual(i.identifier, 'b')
        i.id = '/d'
        self.assertEqual(i.server_and_prefix, '')
        self.assertEqual(i.identifier, 'd')

        def xx(value):  # FIXME - better way to test setter?
            i.id = value
        self.assertRaises(AttributeError, xx, None)
        self.assertRaises(AttributeError, xx, 123)
        # property
        i.server_and_prefix = ''
        i.identifier = ''
        self.assertEqual(i.id, '')
        i.identifier = 'abc'
        self.assertEqual(i.id, 'abc')
        i.server_and_prefix = 'def'
        self.assertEqual(i.id, 'def/abc')
        i.identifier = ''
        self.assertEqual(i.id, 'def/')
開發者ID:zimeon,項目名稱:iiif,代碼行數:39,代碼來源:test_info_common.py

示例4: image_information_response

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import server_and_prefix [as 別名]
 def image_information_response(self):
     """Parse image information request and create response."""
     dr = degraded_request(self.identifier)
     if dr:
         self.logger.info("image_information: degraded %s -> %s" % (self.identifier, dr))
         self.degraded = self.identifier
         self.identifier = dr
     else:
         self.logger.info("image_information: %s" % (self.identifier))
     # get size
     self.manipulator.srcfile = self.file
     self.manipulator.do_first()
     # most of info.json comes from config, a few things specific to image
     info = {
         "tile_height": self.config.tile_height,
         "tile_width": self.config.tile_width,
         "scale_factors": self.config.scale_factors,
     }
     # calculate scale factors if not hard-coded
     if "auto" in self.config.scale_factors:
         info["scale_factors"] = self.manipulator.scale_factors(self.config.tile_width, self.config.tile_height)
     i = IIIFInfo(conf=info, api_version=self.api_version)
     i.server_and_prefix = self.server_and_prefix
     i.identifier = self.iiif.identifier
     i.width = self.manipulator.width
     i.height = self.manipulator.height
     if self.api_version >= "2.0":
         # FIXME - should come from manipulator
         i.qualities = ["default", "color", "gray"]
     else:
         # FIXME - should come from manipulator
         i.qualities = ["native", "color", "gray"]
     i.formats = ["jpg", "png"]  # FIXME - should come from manipulator
     if self.auth:
         self.auth.add_services(i)
     return self.make_response(i.as_json(), headers={"Content-Type": self.json_mime_type})
開發者ID:edsilv,項目名稱:iiif,代碼行數:38,代碼來源:iiif_testserver.py

示例5: do_GET_body

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import server_and_prefix [as 別名]
    def do_GET_body(self):
        iiif=self.iiif
        if (len(self.path)>1024):
            raise IIIFError(code=414,
                            text="URI Too Long: Max 1024 chars, got %d\n" % len(self.path))
        #print "GET " + self.path
        try:
            iiif.parse_url(self.path)
        except IIIFRequestBaseURI as e:
            info_uri = self.server_and_prefix + '/' + urllib.quote(self.iiif.identifier) + '/info.json'
            raise IIIFError(code=303, 
                            headers={'Location': info_uri})
        except IIIFError as e:
            # Pass through
            raise e
        except Exception as e:
            # Something completely unexpected => 500
            raise IIIFError(code=500,
                            text="Internal Server Error: unexpected exception parsing request (" + str(e) + ")")
        # URL path parsed OK, now determine how to handle request
        if (re.match('[\w\.\-]+$',iiif.identifier)):
            file = os.path.join(IIIFRequestHandler.IMAGE_DIR,iiif.identifier)
            if (not os.path.isfile(file)):
                images_available=""
                for image_file in os.listdir(IIIFRequestHandler.IMAGE_DIR):
                    if (os.path.isfile(os.path.join(IIIFRequestHandler.IMAGE_DIR,image_file))):
                        images_available += "  "+image_file+"\n"
                raise IIIFError(code=404,parameter="identifier",
                                text="Image resource '"+iiif.identifier+"' not found. Local image files available:\n" + images_available)
        else:
            raise IIIFError(code=404,parameter="identifier",
                            text="Image resource '"+iiif.identifier+"' not found. Only local test images and http: URIs for images are supported.\n")
        # 
        self.compliance_level=self.manipulator.complianceLevel

        # Do we have auth?
        if (self.auth_type == 'basic'):
            auth_map = parse_authorization_header(self.headers.get('Authorization',''))
            if (auth_map and auth_map['type']=='basic' and
                auth_map['username']+':'+auth_map['password']==IIIFRequestHandler.USER_PASS):
                # authz, continue
                pass
            else:
                # failed, send 401 with null image info, no service link for auth as
                # basic auth is all done via the WWW-Authenticate header
                i = IIIFInfo(api_version=self.api_version)
                i.identifier = 'null'
                i.width = 0
                i.height = 0
                return self.send_json_response(json=i.as_json(),status=401)

        if (self.iiif.info):
            # get size
            self.manipulator.srcfile=file
            self.manipulator.do_first()
            # most of info.json comes from config, a few things specific to image
            i = IIIFInfo(conf=IIIFRequestHandler.INFO,api_version=self.api_version)
            i.server_and_prefix = self.server_and_prefix
            i.identifier = self.iiif.identifier
            i.width = self.manipulator.width
            i.height = self.manipulator.height 
            i.qualities = [ "native", "color" ] #FIXME - should come from manipulator
            i.formats = [ "jpg", "png" ] #FIXME - should come from manipulator
            return self.send_json_response(i.as_json(),200)
        else:
            if (self.api_version<'2.0' and
                self.iiif.format is None and
                'Accept' in self.headers):
                # In 1.0 and 1.1 conneg was specified as an alternative to format, see:
                # http://iiif.io/api/image/1.0/#format
                # http://iiif.io/api/image/1.1/#parameters-format
                formats = { 'image/jpeg': 'jpg', 'image/tiff': 'tif',
                            'image/png': 'png', 'image/gif': 'gif',
                            'image/jp2': 'jps', 'application/pdf': 'pdf' }
                accept = do_conneg( self.headers['Accept'], formats.keys() )
                # Ignore Accept header if not recognized, should this be an error instead?
                if (accept in formats):
                    self.iiif.format = formats[accept]
            (outfile,mime_type)=self.manipulator.derive(file,iiif)
            return self.send_good_response(open(outfile,'r'),mime_type)
開發者ID:edsu,項目名稱:iiif,代碼行數:82,代碼來源:iiif_testserver.py


注:本文中的iiif.info.IIIFInfo.server_and_prefix方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。