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


Python IIIFInfo.as_json方法代碼示例

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


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

示例1: test01_minmal

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [as 別名]
 def test01_minmal(self):
     # Just do the trivial JSON test
     ir = IIIFInfo(server_and_prefix="http://example.com",identifier="i1",api_version='1.1')
     self.assertEqual( ir.as_json(validate=False), '{\n  "@context": "http://library.stanford.edu/iiif/image-api/1.1/context.json", \n  "@id": "http://example.com/i1", \n  "profile": "http://library.stanford.edu/iiif/image-api/1.1/compliance.html#level1"\n}' )
     ir.width=100
     ir.height=200
     self.assertEqual( ir.as_json(), '{\n  "@context": "http://library.stanford.edu/iiif/image-api/1.1/context.json", \n  "@id": "http://example.com/i1", \n  "height": 200, \n  "profile": "http://library.stanford.edu/iiif/image-api/1.1/compliance.html#level1", \n  "width": 100\n}' )
開發者ID:pbinkley,項目名稱:iiif,代碼行數:9,代碼來源:test_info_1_1.py

示例2: test01_minmal

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [as 別名]
 def test01_minmal(self):
     # Just do the trivial JSON test
     ir = IIIFInfo(identifier="i1",api_version='1.0')
     self.assertEqual( ir.as_json(validate=False), '{\n  "identifier": "i1", \n  "profile": "http://library.stanford.edu/iiif/image-api/compliance.html#level1"\n}' )
     ir.width=100
     ir.height=200
     self.assertEqual( ir.as_json(), '{\n  "height": 200, \n  "identifier": "i1", \n  "profile": "http://library.stanford.edu/iiif/image-api/compliance.html#level1", \n  "width": 100\n}' )
開發者ID:pbinkley,項目名稱:iiif,代碼行數:9,代碼來源:test_info_1_0.py

示例3: test01_minmal

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [as 別名]
 def test01_minmal(self):
     # Just do the trivial JSON test
     # ?? should this empty case raise and error instead?
     ir = IIIFInfo(identifier="http://example.com/i1", api_version='2.1')
     self.assertEqual( ir.as_json(validate=False), '{\n  "@context": "http://iiif.io/api/image/2/context.json", \n  "@id": "http://example.com/i1", \n  "profile": [\n    "http://iiif.io/api/image/2/level1.json"\n  ], \n  "protocol": "http://iiif.io/api/image"\n}' )
     ir.width=100
     ir.height=200
     self.assertEqual( ir.as_json(), '{\n  "@context": "http://iiif.io/api/image/2/context.json", \n  "@id": "http://example.com/i1", \n  "height": 200, \n  "profile": [\n    "http://iiif.io/api/image/2/level1.json"\n  ], \n  "protocol": "http://iiif.io/api/image", \n  "width": 100\n}' )
開發者ID:pbinkley,項目名稱:iiif,代碼行數:10,代碼來源:test_info_2_1.py

示例4: generate

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [as 別名]
 def generate(self, src=None, identifier=None):
     """Generate static files for one source image."""
     self.src=src
     self.identifier=identifier
     # Get image details and calculate tiles
     im=IIIFManipulatorPIL()
     im.srcfile = self.src
     im.do_first()
     width = im.width
     height = im.height
     #print "w=%d h=%d ts=%d" % (im.width,im.height,tilesize)
     xtiles = int(width/self.tilesize)
     ytiles = int(height/self.tilesize)
     max_tiles = xtiles if (xtiles>ytiles) else ytiles
     scale_factors = [ 1 ]
     factor = 1
     for n in range(10):
         if (factor >= max_tiles):
             break
         factor = factor+factor
         scale_factors.append(factor)
     # Setup destination and IIIF identifier
     self.setup_destination()
     # Write out images
     for (region,size) in static_partial_tile_sizes(width,height,self.tilesize,scale_factors):
         self.generate_tile(region,size)
     sizes = []
     for (size) in static_full_sizes(width,height,self.tilesize):
         #FIXME - see https://github.com/zimeon/iiif/issues/9
         #sizes.append({'width': size[0], 'height': size[1]})
         self.generate_tile('full',size)
     # Write info.json
     qualities = ['default'] if (self.api_version>'1.1') else ['native']
     info=IIIFInfo(level=0, server_and_prefix=self.prefix, identifier=self.identifier,
                   width=width, height=height, scale_factors=scale_factors,
                   tile_width=self.tilesize, tile_height=self.tilesize,
                   formats=['jpg'], qualities=qualities, sizes=sizes,
                   api_version=self.api_version)
     json_file = os.path.join(self.dst,self.identifier,'info.json')
     if (self.dryrun):
         print "dryrun mode, would write the following files:"
         print "%s / %s/%s" % (self.dst, self.identifier, 'info.json')
         self.logger.info(info.as_json())
     else:
         with open(json_file,'w') as f:
             f.write(info.as_json())
             f.close()
         self.logger.info("Written %s"%(json_file))
     print
開發者ID:pbinkley,項目名稱:iiif,代碼行數:51,代碼來源:static.py

示例5: image_information_response

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [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

示例6: test20_write_example_in_spec

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [as 別名]
 def test20_write_example_in_spec(self):
     i = IIIFInfo(
         api_version='2.1',
         id="http://www.example.org/image-service/abcd1234/1E34750D-38DB-4825-A38A-B60A345E591C",
         #"protocol" : "http://iiif.io/api/image",
         width=6000,
         height=4000,
         sizes=[
             {"width" : 150, "height" : 100},
             {"width" : 600, "height" : 400},
             {"width" : 3000, "height": 2000}
             ],
         tiles=[
             {"width" : 512, "scaleFactors" : [1,2,4,8,16]}
             ],
         profile="http://iiif.io/api/image/2/level2.json",
         formats = [ "gif", "pdf" ],
         qualities = [ "color", "gray" ],
         supports = [ "canonicalLinkHeader", "rotationArbitrary", "profileLinkHeader", "http://example.com/feature/" ],
         service={
             "@context": "http://iiif.io/api/annex/service/physdim/1/context.json",
             "profile": "http://iiif.io/api/annex/service/physdim",
             "physicalScale": 0.0025,
             "physicalUnits": "in"
             }
         )
     reparsed_json = json.loads( i.as_json() )
     example_json = json.load( open('test_info/2.1/info_from_spec.json') )
     self.maxDiff = 4000
     self.assertEqual( reparsed_json, example_json )
開發者ID:pbinkley,項目名稱:iiif,代碼行數:32,代碼來源:test_info_2_1.py

示例7: do_GET_body

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [as 別名]
    def do_GET_body(self):
        """Create body of GET."""
        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))
        try:
            # self.path has leading / then identifier/params...
            self.path = self.path.lstrip("/")
            sys.stderr.write("path = %s" % (self.path))
            iiif.parse_url(self.path)
        except Exception as e:
            # Something completely unexpected => 500
            raise IIIFError(
                code=500, text="Internal Server Error: unexpected exception parsing request (" + str(e) + ")"
            )
        # Now we have a full iiif request
        if re.match("[\w\.\-]+$", iiif.identifier):
            file = os.path.join(TESTIMAGE_DIR, iiif.identifier)
            if not os.path.isfile(file):
                images_available = ""
                for image_file in os.listdir(TESTIMAGE_DIR):
                    if os.path.isfile(os.path.join(TESTIMAGE_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",
            )
        # Now know image is OK
        manipulator = IIIFRequestHandler.manipulator_class()
        # Stash manipulator object so we can cleanup after reading file
        self.manipulator = manipulator
        self.compliance_uri = manipulator.compliance_uri
        if iiif.info:
            # get size
            manipulator.srcfile = file
            manipulator.do_first()
            # most of info.json comes from config, a few things
            # specific to image
            i = IIIFInfo()
            i.identifier = self.iiif.identifier
            i.width = manipulator.width
            i.height = manipulator.height
            import io

            return (io.StringIO(i.as_json()), "application/json")
        else:
            (outfile, mime_type) = manipulator.derive(file, iiif)
            return (open(outfile, "r"), mime_type)
開發者ID:edsilv,項目名稱:iiif,代碼行數:62,代碼來源:iiif_cgi.py

示例8: test01_empty_auth_defined

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [as 別名]
 def test01_empty_auth_defined(self):
     """Test empty auth."""
     info = IIIFInfo(identifier="http://example.com/i1", api_version='2.1')
     auth = IIIFAuth()
     auth.add_services(info)
     self.assertJSONEqual(info.as_json(
         validate=False), '{\n  "@context": "http://iiif.io/api/image/2/context.json", \n  "@id": "http://example.com/i1", \n  "profile": [\n    "http://iiif.io/api/image/2/level1.json"\n  ], \n  "protocol": "http://iiif.io/api/image"\n}')
     self.assertEqual(info.service, None)
開發者ID:zimeon,項目名稱:iiif,代碼行數:10,代碼來源:test_info_2_1_auth_services.py

示例9: test02_scale_factor

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [as 別名]
 def test02_scale_factor(self):
     """Test scale factor."""
     ir = IIIFInfo(width=1, height=2, scale_factors=[
                   1, 2], api_version='1.1')
     # self.assertRegexpMatches( ir.as_json(validate=False),
     # r'"scale_factors": \[\s*1' ) #,\s*2\s*]' ) #no assertRegexpMatches in
     # 2.6
     json = ir.as_json(validate=False)
     self.assertTrue(re.search(r'"scale_factors": \[\s*1', json))
開發者ID:edsilv,項目名稱:iiif,代碼行數:11,代碼來源:test_info_1_1.py

示例10: test21_write_profile

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [as 別名]
 def test21_write_profile(self):
     """Test writing of profile information."""
     i = IIIFInfo(
         api_version='2.1',
         id="http://example.org/svc/a", width=1, height=2,
         profile=['pfl'], formats=["fmt1", "fmt2"])
     j = json.loads(i.as_json())
     self.assertEqual(len(j['profile']), 2)
     self.assertEqual(j['profile'][0], 'pfl')
     self.assertEqual(j['profile'][1], {'formats': ['fmt1', 'fmt2']})
     i = IIIFInfo(
         api_version='2.1',
         id="http://example.org/svc/a", width=1, height=2,
         profile=['pfl'], qualities=None)
     j = json.loads(i.as_json())
     self.assertEqual(len(j['profile']), 1)
     self.assertEqual(j['profile'][0], 'pfl')
     i = IIIFInfo(
         api_version='2.1',
         id="http://example.org/svc/a", width=1, height=2,
         profile=['pfl'], qualities=['q1', 'q2', 'q0'])
     j = json.loads(i.as_json())
     self.assertEqual(len(j['profile']), 2)
     self.assertEqual(j['profile'][0], 'pfl')
     self.assertEqual(j['profile'][1], {'qualities': ['q1', 'q2', 'q0']})
     i = IIIFInfo(
         api_version='2.1',
         id="http://example.org/svc/a", width=1, height=2,
         profile=['pfl'], supports=['a', 'b'])
     j = json.loads(i.as_json())
     self.assertEqual(len(j['profile']), 2)
     self.assertEqual(j['profile'][0], 'pfl')
     self.assertEqual(j['profile'][1], {'supports': ['a', 'b']})
     i = IIIFInfo(
         api_version='2.1',
         id="http://example.org/svc/a", width=1, height=2,
         profile=['pfl'], formats=["fmt1", "fmt2"],
         qualities=['q1', 'q2', 'q0'], supports=['a', 'b'])
     j = json.loads(i.as_json())
     self.assertEqual(len(j['profile']), 2)
     self.assertEqual(j['profile'][0], 'pfl')
     self.assertEqual(j['profile'][1]['formats'], ['fmt1', 'fmt2'])
     self.assertEqual(j['profile'][1]['qualities'], ['q1', 'q2', 'q0'])
     self.assertEqual(j['profile'][1]['supports'], ['a', 'b'])
開發者ID:edsilv,項目名稱:iiif,代碼行數:46,代碼來源:test_info_2_1.py

示例11: test21_write_profile

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [as 別名]
 def test21_write_profile(self):
     """Test writing of profile information."""
     i = IIIFInfo(id="http://example.org/svc/a", width=1, height=2, profile=["pfl"], formats=["fmt1", "fmt2"])
     j = json.loads(i.as_json())
     self.assertEqual(len(j["profile"]), 2)
     self.assertEqual(j["profile"][0], "pfl")
     self.assertEqual(j["profile"][1], {"formats": ["fmt1", "fmt2"]})
     i = IIIFInfo(id="http://example.org/svc/a", width=1, height=2, profile=["pfl"], qualities=None)
     j = json.loads(i.as_json())
     self.assertEqual(len(j["profile"]), 1)
     self.assertEqual(j["profile"][0], "pfl")
     i = IIIFInfo(id="http://example.org/svc/a", width=1, height=2, profile=["pfl"], qualities=["q1", "q2", "q0"])
     j = json.loads(i.as_json())
     self.assertEqual(len(j["profile"]), 2)
     self.assertEqual(j["profile"][0], "pfl")
     self.assertEqual(j["profile"][1], {"qualities": ["q1", "q2", "q0"]})
     i = IIIFInfo(id="http://example.org/svc/a", width=1, height=2, profile=["pfl"], supports=["a", "b"])
     j = json.loads(i.as_json())
     self.assertEqual(len(j["profile"]), 2)
     self.assertEqual(j["profile"][0], "pfl")
     self.assertEqual(j["profile"][1], {"supports": ["a", "b"]})
     i = IIIFInfo(
         id="http://example.org/svc/a",
         width=1,
         height=2,
         profile=["pfl"],
         formats=["fmt1", "fmt2"],
         qualities=["q1", "q2", "q0"],
         supports=["a", "b"],
     )
     j = json.loads(i.as_json())
     self.assertEqual(len(j["profile"]), 2)
     self.assertEqual(j["profile"][0], "pfl")
     self.assertEqual(j["profile"][1]["formats"], ["fmt1", "fmt2"])
     self.assertEqual(j["profile"][1]["qualities"], ["q1", "q2", "q0"])
     self.assertEqual(j["profile"][1]["supports"], ["a", "b"])
開發者ID:edsilv,項目名稱:iiif,代碼行數:38,代碼來源:test_info_2_0.py

示例12: test20_write_example_in_spec

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [as 別名]
 def test20_write_example_in_spec(self):
     """Create example info.json in spec."""
     i = IIIFInfo(
         api_version='2.1',
         id="http://www.example.org/image-service/abcd1234/1E34750D-38DB-4825-A38A-B60A345E591C",
         # "protocol" : "http://iiif.io/api/image",
         width=6000,
         height=4000,
         sizes=[
             {"width": 150, "height": 100},
             {"width": 600, "height": 400},
             {"width": 3000, "height": 2000}],
         tiles=[
             {"width": 512, "scaleFactors": [1, 2, 4]},
             {"width": 1024, "height": 2048, "scaleFactors": [8, 16]}],
         attribution=[
             {"@value": "<span>Provided by Example Organization</span>",
              "@language": "en"},
             {"@value": "<span>Darparwyd gan Enghraifft Sefydliad</span>",
              "@language": "cy"}],
         logo={"@id": "http://example.org/image-service/logo/full/200,/0/default.png",
               "service":
               {"@context": "http://iiif.io/api/image/2/context.json",
                "@id": "http://example.org/image-service/logo",
                "profile": "http://iiif.io/api/image/2/level2.json"}},
         license=[
             "http://example.org/rights/license1.html",
             "https://creativecommons.org/licenses/by/4.0/"],
         profile=["http://iiif.io/api/image/2/level2.json"],
         formats=["gif", "pdf"],
         qualities=["color", "gray"],
         supports=["canonicalLinkHeader", "rotationArbitrary",
                   "profileLinkHeader", "http://example.com/feature/"],
         service=[
             {"@context": "http://iiif.io/api/annex/service/physdim/1/context.json",
              "profile": "http://iiif.io/api/annex/service/physdim",
              "physicalScale": 0.0025,
              "physicalUnits": "in"},
             {"@context": "http://geojson.org/contexts/geojson-base.jsonld",
              "@id": "http://www.example.org/geojson/paris.json"}]
     )
     reparsed_json = json.loads(i.as_json())
     example_json = json.load(
         open('tests/testdata/info_json_2_1/info_from_spec_section_5_6.json'))
     self.maxDiff = 4000
     self.assertEqual(reparsed_json, example_json)
開發者ID:edsilv,項目名稱:iiif,代碼行數:48,代碼來源:test_info_2_1.py

示例13: image_information_response

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [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

示例14: test02_scale_factor

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [as 別名]
 def test02_scale_factor(self):
     ir = IIIFInfo(width=199,height=299,tile_width=100,tile_height=100,scale_factors=[1,2], api_version='2.1')
     #self.assertRegexpMatches( ir.as_json(validate=False), r'"scaleFactors": \[\s*1' ) #,\s*2\s*]' ) #no assertRegexpMatches in 2.6
     json = ir.as_json(validate=False)
     self.assertTrue( re.search(r'"width": 100',json) )
     self.assertTrue( re.search(r'"scaleFactors": \[\s*1',json) )
開發者ID:pbinkley,項目名稱:iiif,代碼行數:8,代碼來源:test_info_2_1.py

示例15: do_GET_body

# 需要導入模塊: from iiif.info import IIIFInfo [as 別名]
# 或者: from iiif.info.IIIFInfo import as_json [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.as_json方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。