Serve fonts
This commit is contained in:
parent
b98b7244f6
commit
d742672238
3 changed files with 68 additions and 3 deletions
42
src/serve_font.js
Normal file
42
src/serve_font.js
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var path = require('path'),
|
||||||
|
fs = require('fs');
|
||||||
|
|
||||||
|
var clone = require('clone'),
|
||||||
|
express = require('express');
|
||||||
|
|
||||||
|
|
||||||
|
module.exports = function(fontPath, allowedFonts) {
|
||||||
|
var app = express().disable('x-powered-by');
|
||||||
|
|
||||||
|
var rootPath = path.join(process.cwd(), fontPath || '');
|
||||||
|
|
||||||
|
app.get('/fonts/:fontstack/:range([\\d]+-[\\d]+).pbf',
|
||||||
|
function(req, res, next) {
|
||||||
|
var fontstack = decodeURI(req.params.fontstack);
|
||||||
|
var range = req.params.range;
|
||||||
|
|
||||||
|
var fonts = fontstack.split(',');
|
||||||
|
if (fonts.length == 1) {
|
||||||
|
if (allowedFonts[fonts[0]]) {
|
||||||
|
var filename = rootPath + '/' + fonts[0] + '/' + range + '.pbf';
|
||||||
|
return fs.readFile(filename, function(err, data) {
|
||||||
|
if (err) {
|
||||||
|
console.log('Font load error:', filename);
|
||||||
|
return res.status(404).send('File not found');
|
||||||
|
} else {
|
||||||
|
res.header('Content-type', 'application/x-protobuf');
|
||||||
|
return res.send(data);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
return res.status(403).send('Forbidden');
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return res.status(501).send('Not Yet Implemented');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return app;
|
||||||
|
};
|
|
@ -7,7 +7,7 @@ var clone = require('clone'),
|
||||||
express = require('express');
|
express = require('express');
|
||||||
|
|
||||||
|
|
||||||
module.exports = function(repo, options, id, reportVector) {
|
module.exports = function(repo, options, id, reportVector, reportFont) {
|
||||||
var app = express().disable('x-powered-by');
|
var app = express().disable('x-powered-by');
|
||||||
|
|
||||||
var rootPath = path.join(process.cwd(), options.root || '');
|
var rootPath = path.join(process.cwd(), options.root || '');
|
||||||
|
@ -25,6 +25,20 @@ module.exports = function(repo, options, id, reportVector) {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
var findFontReferences = function(obj) {
|
||||||
|
Object.keys(obj).forEach(function(key) {
|
||||||
|
var value = obj[key];
|
||||||
|
if (key == 'text-font') {
|
||||||
|
if (value && value.length > 0) {
|
||||||
|
value.forEach(reportFont);
|
||||||
|
}
|
||||||
|
} else if (value && typeof value == 'object') {
|
||||||
|
findFontReferences(value);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
styleJSON.layers.forEach(findFontReferences);
|
||||||
|
|
||||||
var spritePath = path.join(rootPath, styleJSON.sprite);
|
var spritePath = path.join(rootPath, styleJSON.sprite);
|
||||||
|
|
||||||
styleJSON.sprite = 'local://styles/' + id + '/sprite';
|
styleJSON.sprite = 'local://styles/' + id + '/sprite';
|
||||||
|
|
|
@ -12,7 +12,8 @@ var clone = require('clone'),
|
||||||
express = require('express'),
|
express = require('express'),
|
||||||
morgan = require('morgan');
|
morgan = require('morgan');
|
||||||
|
|
||||||
var serve_raster = require('./serve_raster'),
|
var serve_font = require('./serve_font'),
|
||||||
|
serve_raster = require('./serve_raster'),
|
||||||
serve_style = require('./serve_style'),
|
serve_style = require('./serve_style'),
|
||||||
serve_vector = require('./serve_vector'),
|
serve_vector = require('./serve_vector'),
|
||||||
utils = require('./utils');
|
utils = require('./utils');
|
||||||
|
@ -22,7 +23,11 @@ module.exports = function(opts, callback) {
|
||||||
serving = {
|
serving = {
|
||||||
styles: {},
|
styles: {},
|
||||||
raster: {},
|
raster: {},
|
||||||
vector: {}
|
vector: {},
|
||||||
|
fonts: { // default fonts, always expose these (if they exist)
|
||||||
|
'Open Sans Regular': true,
|
||||||
|
'Arial Unicode MS Regular': true
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
app.enable('trust proxy');
|
app.enable('trust proxy');
|
||||||
|
@ -65,6 +70,8 @@ module.exports = function(opts, callback) {
|
||||||
};
|
};
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
}, function(font) {
|
||||||
|
serving.fonts[font] = true;
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
if (item.raster !== false) {
|
if (item.raster !== false) {
|
||||||
|
@ -72,6 +79,8 @@ module.exports = function(opts, callback) {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
app.use('/', serve_font('glyphs', serving.fonts));
|
||||||
|
|
||||||
//TODO: cors
|
//TODO: cors
|
||||||
|
|
||||||
Object.keys(vector).forEach(function(id) {
|
Object.keys(vector).forEach(function(id) {
|
||||||
|
|
Loading…
Reference in a new issue