50)return!1;if(a.type===i.default.OPEN_PAREN)r++;else if(a.type===i.default.CLOSE_PAREN&&0===--r)return!0;if(this.isForbiddenToken(a))return!1}return!1},t.prototype.isForbiddenToken=function(t){var e=t.type,n=t.value;return e===i.default.RESERVED_TOPLEVEL||e===i.default.RESERVED_NEWLINE||e===i.default.COMMENT||e===i.default.BLOCK_COMMENT||";"===n},t}();e.default=a,t.exports=e.default},function(t,e,n){"use strict";e.__esModule=!0;var r=function(){function t(e){!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,t),this.params=e,this.index=0}return t.prototype.get=function(t){var e=t.key,n=t.value;return this.params?e?this.params[e]:this.params[this.index++]:n},t}();e.default=r,t.exports=e.default},function(t,e,n){var r=n(74),o=n(76),i=n(45),a=n(9),s=n(41),c=n(46),u=n(75),l=n(47),f="[object Map]",p="[object Set]",d=Object.prototype.hasOwnProperty;t.exports=function(t){if(null==t)return!0;if(s(t)&&(a(t)||"string"==typeof t||"function"==typeof t.splice||c(t)||l(t)||i(t)))return!t.length;var e=o(t);if(e==f||e==p)return!t.size;if(u(t))return!r(t).length;for(var n in t)if(d.call(t,n))return!1;return!0}},function(t,e,n){var r=n(197)(Object.keys,Object);t.exports=r},function(t,e){t.exports=function(t,e){return function(n){return t(e(n))}}},function(t,e,n){var r=n(12)(n(8),"DataView");t.exports=r},function(t,e,n){var r=n(73),o=n(200),i=n(19),a=n(77),s=/^\[object .+?Constructor\]$/,c=Function.prototype,u=Object.prototype,l=c.toString,f=u.hasOwnProperty,p=RegExp("^"+l.call(f).replace(/[\\^$.*+?()[\]{}|]/g,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");t.exports=function(t){return!(!i(t)||o(t))&&(r(t)?p:s).test(a(t))}},function(t,e,n){var r,o=n(201),i=(r=/[^.]+$/.exec(o&&o.keys&&o.keys.IE_PROTO||""))?"Symbol(src)_1."+r:"";t.exports=function(t){return!!i&&i in t}},function(t,e,n){var r=n(8)["__core-js_shared__"];t.exports=r},function(t,e){t.exports=function(t,e){return null==t?void 0:t[e]}},function(t,e,n){var r=n(12)(n(8),"Promise");t.exports=r},function(t,e,n){var r=n(12)(n(8),"WeakMap");t.exports=r},function(t,e,n){var r=n(17),o=n(18),i="[object Arguments]";t.exports=function(t){return o(t)&&r(t)==i}},function(t,e){t.exports=function(){return!1}},function(t,e,n){var r=n(17),o=n(42),i=n(18),a={};a["[object Float32Array]"]=a["[object Float64Array]"]=a["[object Int8Array]"]=a["[object Int16Array]"]=a["[object Int32Array]"]=a["[object Uint8Array]"]=a["[object Uint8ClampedArray]"]=a["[object Uint16Array]"]=a["[object Uint32Array]"]=!0,a["[object Arguments]"]=a["[object Array]"]=a["[object ArrayBuffer]"]=a["[object Boolean]"]=a["[object DataView]"]=a["[object Date]"]=a["[object Error]"]=a["[object Function]"]=a["[object Map]"]=a["[object Number]"]=a["[object Object]"]=a["[object RegExp]"]=a["[object Set]"]=a["[object String]"]=a["[object WeakMap]"]=!1,t.exports=function(t){return i(t)&&o(t.length)&&!!a[r(t)]}},function(t,e){t.exports=function(t){return function(e){return t(e)}}},function(t,e,n){(function(t){var r=n(71),o=e&&!e.nodeType&&e,i=o&&"object"==typeof t&&t&&!t.nodeType&&t,a=i&&i.exports===o&&r.process,s=function(){try{var t=i&&i.require&&i.require("util").types;return t||a&&a.binding&&a.binding("util")}catch(t){}}();t.exports=s}).call(this,n(21)(t))},function(t,e,n){var r=n(16),o=/[\\^$.*+?()[\]{}|]/g,i=RegExp(o.source);t.exports=function(t){return(t=r(t))&&i.test(t)?t.replace(o,"\\$&"):t}},function(t,e,n){"use strict";e.__esModule=!0;var r=i(n(24)),o=i(n(25));function i(t){return t&&t.__esModule?t:{default:t}}var a=["ALL","ALTER","ANALYZE","AND","ANY","ARRAY","AS","ASC","BEGIN","BETWEEN","BINARY","BOOLEAN","BREAK","BUCKET","BUILD","BY","CALL","CASE","CAST","CLUSTER","COLLATE","COLLECTION","COMMIT","CONNECT","CONTINUE","CORRELATE","COVER","CREATE","DATABASE","DATASET","DATASTORE","DECLARE","DECREMENT","DELETE","DERIVED","DESC","DESCRIBE","DISTINCT","DO","DROP","EACH","ELEMENT","ELSE","END","EVERY","EXCEPT","EXCLUDE","EXECUTE","EXISTS","EXPLAIN","FALSE","FETCH","FIRST","FLATTEN","FOR","FORCE","FROM","FUNCTION","GRANT","GROUP","GSI","HAVING","IF","IGNORE","ILIKE","IN","INCLUDE","INCREMENT","INDEX","INFER","INLINE","INNER","INSERT","INTERSECT","INTO","IS","JOIN","KEY","KEYS","KEYSPACE","KNOWN","LAST","LEFT","LET","LETTING","LIKE","LIMIT","LSM","MAP","MAPPING","MATCHED","MATERIALIZED","MERGE","MINUS","MISSING","NAMESPACE","NEST","NOT","NULL","NUMBER","OBJECT","OFFSET","ON","OPTION","OR","ORDER","OUTER","OVER","PARSE","PARTITION","PASSWORD","PATH","POOL","PREPARE","PRIMARY","PRIVATE","PRIVILEGE","PROCEDURE","PUBLIC","RAW","REALM","REDUCE","RENAME","RETURN","RETURNING","REVOKE","RIGHT","ROLE","ROLLBACK","SATISFIES","SCHEMA","SELECT","SELF","SEMI","SET","SHOW","SOME","START","STATISTICS","STRING","SYSTEM","THEN","TO","TRANSACTION","TRIGGER","TRUE","TRUNCATE","UNDER","UNION","UNIQUE","UNKNOWN","UNNEST","UNSET","UPDATE","UPSERT","USE","USER","USING","VALIDATE","VALUE","VALUED","VALUES","VIA","VIEW","WHEN","WHERE","WHILE","WITH","WITHIN","WORK","XOR"],s=["DELETE FROM","EXCEPT ALL","EXCEPT","EXPLAIN DELETE FROM","EXPLAIN UPDATE","EXPLAIN UPSERT","FROM","GROUP BY","HAVING","INFER","INSERT INTO","INTERSECT ALL","INTERSECT","LET","LIMIT","MERGE","NEST","ORDER BY","PREPARE","SELECT","SET CURRENT SCHEMA","SET SCHEMA","SET","UNION ALL","UNION","UNNEST","UPDATE","UPSERT","USE KEYS","VALUES","WHERE"],c=["AND","INNER JOIN","JOIN","LEFT JOIN","LEFT OUTER JOIN","OR","OUTER JOIN","RIGHT JOIN","RIGHT OUTER JOIN","XOR"],u=void 0,l=function(){function t(e){!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,t),this.cfg=e}return t.prototype.format=function(t){return u||(u=new o.default({reservedWords:a,reservedToplevelWords:s,reservedNewlineWords:c,stringTypes:['""',"''","``"],openParens:["(","[","{"],closeParens:[")","]","}"],namedPlaceholderTypes:["$"],lineCommentTypes:["#","--"]})),new r.default(this.cfg,u).format(t)},t}();e.default=l,t.exports=e.default},function(t,e,n){"use strict";e.__esModule=!0;var r=i(n(24)),o=i(n(25));function i(t){return t&&t.__esModule?t:{default:t}}var a=["A","ACCESSIBLE","AGENT","AGGREGATE","ALL","ALTER","ANY","ARRAY","AS","ASC","AT","ATTRIBUTE","AUTHID","AVG","BETWEEN","BFILE_BASE","BINARY_INTEGER","BINARY","BLOB_BASE","BLOCK","BODY","BOOLEAN","BOTH","BOUND","BULK","BY","BYTE","C","CALL","CALLING","CASCADE","CASE","CHAR_BASE","CHAR","CHARACTER","CHARSET","CHARSETFORM","CHARSETID","CHECK","CLOB_BASE","CLONE","CLOSE","CLUSTER","CLUSTERS","COALESCE","COLAUTH","COLLECT","COLUMNS","COMMENT","COMMIT","COMMITTED","COMPILED","COMPRESS","CONNECT","CONSTANT","CONSTRUCTOR","CONTEXT","CONTINUE","CONVERT","COUNT","CRASH","CREATE","CREDENTIAL","CURRENT","CURRVAL","CURSOR","CUSTOMDATUM","DANGLING","DATA","DATE_BASE","DATE","DAY","DECIMAL","DEFAULT","DEFINE","DELETE","DESC","DETERMINISTIC","DIRECTORY","DISTINCT","DO","DOUBLE","DROP","DURATION","ELEMENT","ELSIF","EMPTY","ESCAPE","EXCEPTIONS","EXCLUSIVE","EXECUTE","EXISTS","EXIT","EXTENDS","EXTERNAL","EXTRACT","FALSE","FETCH","FINAL","FIRST","FIXED","FLOAT","FOR","FORALL","FORCE","FROM","FUNCTION","GENERAL","GOTO","GRANT","GROUP","HASH","HEAP","HIDDEN","HOUR","IDENTIFIED","IF","IMMEDIATE","IN","INCLUDING","INDEX","INDEXES","INDICATOR","INDICES","INFINITE","INSTANTIABLE","INT","INTEGER","INTERFACE","INTERVAL","INTO","INVALIDATE","IS","ISOLATION","JAVA","LANGUAGE","LARGE","LEADING","LENGTH","LEVEL","LIBRARY","LIKE","LIKE2","LIKE4","LIKEC","LIMITED","LOCAL","LOCK","LONG","MAP","MAX","MAXLEN","MEMBER","MERGE","MIN","MINUS","MINUTE","MLSLABEL","MOD","MODE","MONTH","MULTISET","NAME","NAN","NATIONAL","NATIVE","NATURAL","NATURALN","NCHAR","NEW","NEXTVAL","NOCOMPRESS","NOCOPY","NOT","NOWAIT","NULL","NULLIF","NUMBER_BASE","NUMBER","OBJECT","OCICOLL","OCIDATE","OCIDATETIME","OCIDURATION","OCIINTERVAL","OCILOBLOCATOR","OCINUMBER","OCIRAW","OCIREF","OCIREFCURSOR","OCIROWID","OCISTRING","OCITYPE","OF","OLD","ON","ONLY","OPAQUE","OPEN","OPERATOR","OPTION","ORACLE","ORADATA","ORDER","ORGANIZATION","ORLANY","ORLVARY","OTHERS","OUT","OVERLAPS","OVERRIDING","PACKAGE","PARALLEL_ENABLE","PARAMETER","PARAMETERS","PARENT","PARTITION","PASCAL","PCTFREE","PIPE","PIPELINED","PLS_INTEGER","PLUGGABLE","POSITIVE","POSITIVEN","PRAGMA","PRECISION","PRIOR","PRIVATE","PROCEDURE","PUBLIC","RAISE","RANGE","RAW","READ","REAL","RECORD","REF","REFERENCE","RELEASE","RELIES_ON","REM","REMAINDER","RENAME","RESOURCE","RESULT_CACHE","RESULT","RETURN","RETURNING","REVERSE","REVOKE","ROLLBACK","ROW","ROWID","ROWNUM","ROWTYPE","SAMPLE","SAVE","SAVEPOINT","SB1","SB2","SB4","SECOND","SEGMENT","SELF","SEPARATE","SEQUENCE","SERIALIZABLE","SHARE","SHORT","SIZE_T","SIZE","SMALLINT","SOME","SPACE","SPARSE","SQL","SQLCODE","SQLDATA","SQLERRM","SQLNAME","SQLSTATE","STANDARD","START","STATIC","STDDEV","STORED","STRING","STRUCT","STYLE","SUBMULTISET","SUBPARTITION","SUBSTITUTABLE","SUBTYPE","SUCCESSFUL","SUM","SYNONYM","SYSDATE","TABAUTH","TABLE","TDO","THE","THEN","TIME","TIMESTAMP","TIMEZONE_ABBR","TIMEZONE_HOUR","TIMEZONE_MINUTE","TIMEZONE_REGION","TO","TRAILING","TRANSACTION","TRANSACTIONAL","TRIGGER","TRUE","TRUSTED","TYPE","UB1","UB2","UB4","UID","UNDER","UNIQUE","UNPLUG","UNSIGNED","UNTRUSTED","USE","USER","USING","VALIDATE","VALIST","VALUE","VARCHAR","VARCHAR2","VARIABLE","VARIANCE","VARRAY","VARYING","VIEW","VIEWS","VOID","WHENEVER","WHILE","WITH","WORK","WRAPPED","WRITE","YEAR","ZONE"],s=["ADD","ALTER COLUMN","ALTER TABLE","BEGIN","CONNECT BY","DECLARE","DELETE FROM","DELETE","END","EXCEPT","EXCEPTION","FETCH FIRST","FROM","GROUP BY","HAVING","INSERT INTO","INSERT","INTERSECT","LIMIT","LOOP","MODIFY","ORDER BY","SELECT","SET CURRENT SCHEMA","SET SCHEMA","SET","START WITH","UNION ALL","UNION","UPDATE","VALUES","WHERE"],c=["AND","CROSS APPLY","CROSS JOIN","ELSE","END","INNER JOIN","JOIN","LEFT JOIN","LEFT OUTER JOIN","OR","OUTER APPLY","OUTER JOIN","RIGHT JOIN","RIGHT OUTER JOIN","WHEN","XOR"],u=void 0,l=function(){function t(e){!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,t),this.cfg=e}return t.prototype.format=function(t){return u||(u=new o.default({reservedWords:a,reservedToplevelWords:s,reservedNewlineWords:c,stringTypes:['""',"N''","''","``"],openParens:["(","CASE"],closeParens:[")","END"],indexedPlaceholderTypes:["?"],namedPlaceholderTypes:[":"],lineCommentTypes:["--"],specialWordChars:["_","$","#",".","@"]})),new r.default(this.cfg,u).format(t)},t}();e.default=l,t.exports=e.default},function(t,e,n){"use strict";e.__esModule=!0;var r=i(n(24)),o=i(n(25));function i(t){return t&&t.__esModule?t:{default:t}}var a=["ACCESSIBLE","ACTION","AGAINST","AGGREGATE","ALGORITHM","ALL","ALTER","ANALYSE","ANALYZE","AS","ASC","AUTOCOMMIT","AUTO_INCREMENT","BACKUP","BEGIN","BETWEEN","BINLOG","BOTH","CASCADE","CASE","CHANGE","CHANGED","CHARACTER SET","CHARSET","CHECK","CHECKSUM","COLLATE","COLLATION","COLUMN","COLUMNS","COMMENT","COMMIT","COMMITTED","COMPRESSED","CONCURRENT","CONSTRAINT","CONTAINS","CONVERT","CREATE","CROSS","CURRENT_TIMESTAMP","DATABASE","DATABASES","DAY","DAY_HOUR","DAY_MINUTE","DAY_SECOND","DEFAULT","DEFINER","DELAYED","DELETE","DESC","DESCRIBE","DETERMINISTIC","DISTINCT","DISTINCTROW","DIV","DO","DROP","DUMPFILE","DUPLICATE","DYNAMIC","ELSE","ENCLOSED","END","ENGINE","ENGINES","ENGINE_TYPE","ESCAPE","ESCAPED","EVENTS","EXEC","EXECUTE","EXISTS","EXPLAIN","EXTENDED","FAST","FETCH","FIELDS","FILE","FIRST","FIXED","FLUSH","FOR","FORCE","FOREIGN","FULL","FULLTEXT","FUNCTION","GLOBAL","GRANT","GRANTS","GROUP_CONCAT","HEAP","HIGH_PRIORITY","HOSTS","HOUR","HOUR_MINUTE","HOUR_SECOND","IDENTIFIED","IF","IFNULL","IGNORE","IN","INDEX","INDEXES","INFILE","INSERT","INSERT_ID","INSERT_METHOD","INTERVAL","INTO","INVOKER","IS","ISOLATION","KEY","KEYS","KILL","LAST_INSERT_ID","LEADING","LEVEL","LIKE","LINEAR","LINES","LOAD","LOCAL","LOCK","LOCKS","LOGS","LOW_PRIORITY","MARIA","MASTER","MASTER_CONNECT_RETRY","MASTER_HOST","MASTER_LOG_FILE","MATCH","MAX_CONNECTIONS_PER_HOUR","MAX_QUERIES_PER_HOUR","MAX_ROWS","MAX_UPDATES_PER_HOUR","MAX_USER_CONNECTIONS","MEDIUM","MERGE","MINUTE","MINUTE_SECOND","MIN_ROWS","MODE","MODIFY","MONTH","MRG_MYISAM","MYISAM","NAMES","NATURAL","NOT","NOW()","NULL","OFFSET","ON DELETE","ON UPDATE","ON","ONLY","OPEN","OPTIMIZE","OPTION","OPTIONALLY","OUTFILE","PACK_KEYS","PAGE","PARTIAL","PARTITION","PARTITIONS","PASSWORD","PRIMARY","PRIVILEGES","PROCEDURE","PROCESS","PROCESSLIST","PURGE","QUICK","RAID0","RAID_CHUNKS","RAID_CHUNKSIZE","RAID_TYPE","RANGE","READ","READ_ONLY","READ_WRITE","REFERENCES","REGEXP","RELOAD","RENAME","REPAIR","REPEATABLE","REPLACE","REPLICATION","RESET","RESTORE","RESTRICT","RETURN","RETURNS","REVOKE","RLIKE","ROLLBACK","ROW","ROWS","ROW_FORMAT","SECOND","SECURITY","SEPARATOR","SERIALIZABLE","SESSION","SHARE","SHOW","SHUTDOWN","SLAVE","SONAME","SOUNDS","SQL","SQL_AUTO_IS_NULL","SQL_BIG_RESULT","SQL_BIG_SELECTS","SQL_BIG_TABLES","SQL_BUFFER_RESULT","SQL_CACHE","SQL_CALC_FOUND_ROWS","SQL_LOG_BIN","SQL_LOG_OFF","SQL_LOG_UPDATE","SQL_LOW_PRIORITY_UPDATES","SQL_MAX_JOIN_SIZE","SQL_NO_CACHE","SQL_QUOTE_SHOW_CREATE","SQL_SAFE_UPDATES","SQL_SELECT_LIMIT","SQL_SLAVE_SKIP_COUNTER","SQL_SMALL_RESULT","SQL_WARNINGS","START","STARTING","STATUS","STOP","STORAGE","STRAIGHT_JOIN","STRING","STRIPED","SUPER","TABLE","TABLES","TEMPORARY","TERMINATED","THEN","TO","TRAILING","TRANSACTIONAL","TRUE","TRUNCATE","TYPE","TYPES","UNCOMMITTED","UNIQUE","UNLOCK","UNSIGNED","USAGE","USE","USING","VARIABLES","VIEW","WHEN","WITH","WORK","WRITE","YEAR_MONTH"],s=["ADD","AFTER","ALTER COLUMN","ALTER TABLE","DELETE FROM","EXCEPT","FETCH FIRST","FROM","GROUP BY","GO","HAVING","INSERT INTO","INSERT","INTERSECT","LIMIT","MODIFY","ORDER BY","SELECT","SET CURRENT SCHEMA","SET SCHEMA","SET","UNION ALL","UNION","UPDATE","VALUES","WHERE"],c=["AND","CROSS APPLY","CROSS JOIN","ELSE","INNER JOIN","JOIN","LEFT JOIN","LEFT OUTER JOIN","OR","OUTER APPLY","OUTER JOIN","RIGHT JOIN","RIGHT OUTER JOIN","WHEN","XOR"],u=void 0,l=function(){function t(e){!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,t),this.cfg=e}return t.prototype.format=function(t){return u||(u=new o.default({reservedWords:a,reservedToplevelWords:s,reservedNewlineWords:c,stringTypes:['""',"N''","''","``","[]"],openParens:["(","CASE"],closeParens:[")","END"],indexedPlaceholderTypes:["?"],namedPlaceholderTypes:["@",":"],lineCommentTypes:["#","--"]})),new r.default(this.cfg,u).format(t)},t}();e.default=l,t.exports=e.default},function(t,e){t.exports=function(t){const e={className:"variable",begin:"\\$+[a-zA-Z_-ÿ][a-zA-Z0-9_-ÿ]*(?![A-Za-z0-9])(?![$])"},n={className:"meta",variants:[{begin:/<\?php/,relevance:10},{begin:/<\?[=]?/},{begin:/\?>/}]},r={className:"subst",variants:[{begin:/\$\w+/},{begin:/\{\$/,end:/\}/}]},o=t.inherit(t.APOS_STRING_MODE,{illegal:null}),i=t.inherit(t.QUOTE_STRING_MODE,{illegal:null,contains:t.QUOTE_STRING_MODE.contains.concat(r)}),a=t.END_SAME_AS_BEGIN({begin:/<<<[ \t]*(\w+)\n/,end:/[ \t]*(\w+)\b/,contains:t.QUOTE_STRING_MODE.contains.concat(r)}),s={className:"string",contains:[t.BACKSLASH_ESCAPE,n],variants:[t.inherit(o,{begin:"b'",end:"'"}),t.inherit(i,{begin:'b"',end:'"'}),i,o,a]},c={variants:[t.BINARY_NUMBER_MODE,t.C_NUMBER_MODE]},u={keyword:"__CLASS__ __DIR__ __FILE__ __FUNCTION__ __LINE__ __METHOD__ __NAMESPACE__ __TRAIT__ die echo exit include include_once print require require_once array abstract and as binary bool boolean break callable case catch class clone const continue declare default do double else elseif empty enddeclare endfor endforeach endif endswitch endwhile eval extends final finally float for foreach from global goto if implements instanceof insteadof int integer interface isset iterable list match|0 new object or private protected public real return string switch throw trait try unset use var void while xor yield",literal:"false null true",built_in:"Error|0 AppendIterator ArgumentCountError ArithmeticError ArrayIterator ArrayObject AssertionError BadFunctionCallException BadMethodCallException CachingIterator CallbackFilterIterator CompileError Countable DirectoryIterator DivisionByZeroError DomainException EmptyIterator ErrorException Exception FilesystemIterator FilterIterator GlobIterator InfiniteIterator InvalidArgumentException IteratorIterator LengthException LimitIterator LogicException MultipleIterator NoRewindIterator OutOfBoundsException OutOfRangeException OuterIterator OverflowException ParentIterator ParseError RangeException RecursiveArrayIterator RecursiveCachingIterator RecursiveCallbackFilterIterator RecursiveDirectoryIterator RecursiveFilterIterator RecursiveIterator RecursiveIteratorIterator RecursiveRegexIterator RecursiveTreeIterator RegexIterator RuntimeException SeekableIterator SplDoublyLinkedList SplFileInfo SplFileObject SplFixedArray SplHeap SplMaxHeap SplMinHeap SplObjectStorage SplObserver SplObserver SplPriorityQueue SplQueue SplStack SplSubject SplSubject SplTempFileObject TypeError UnderflowException UnexpectedValueException ArrayAccess Closure Generator Iterator IteratorAggregate Serializable Throwable Traversable WeakReference Directory __PHP_Incomplete_Class parent php_user_filter self static stdClass"};return{aliases:["php","php3","php4","php5","php6","php7","php8"],case_insensitive:!0,keywords:u,contains:[t.HASH_COMMENT_MODE,t.COMMENT("//","$",{contains:[n]}),t.COMMENT("/\\*","\\*/",{contains:[{className:"doctag",begin:"@[A-Za-z]+"}]}),t.COMMENT("__halt_compiler.+?;",!1,{endsWithParent:!0,keywords:"__halt_compiler"}),n,{className:"keyword",begin:/\$this\b/},e,{begin:/(::|->)+[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*/},{className:"function",relevance:0,beginKeywords:"fn function",end:/[;{]/,excludeEnd:!0,illegal:"[$%\\[]",contains:[t.UNDERSCORE_TITLE_MODE,{begin:"=>"},{className:"params",begin:"\\(",end:"\\)",excludeBegin:!0,excludeEnd:!0,keywords:u,contains:["self",e,t.C_BLOCK_COMMENT_MODE,s,c]}]},{className:"class",beginKeywords:"class interface",relevance:0,end:/\{/,excludeEnd:!0,illegal:/[:($"]/,contains:[{beginKeywords:"extends implements"},t.UNDERSCORE_TITLE_MODE]},{beginKeywords:"namespace",relevance:0,end:";",illegal:/[.']/,contains:[t.UNDERSCORE_TITLE_MODE]},{beginKeywords:"use",relevance:0,end:";",contains:[t.UNDERSCORE_TITLE_MODE]},s,c]}}},function(t,e,n){var r=n(79),o=n(235),i=n(236),a=n(80),s=n(237),c=n(49),u=200;t.exports=function(t,e,n){var l=-1,f=o,p=t.length,d=!0,h=[],g=h;if(n)d=!1,f=i;else if(p>=u){var m=e?null:s(t);if(m)return c(m);d=!1,f=a,g=new r}else g=e?[]:h;t:for(;++l-1}},function(t,e,n){var r=n(28);t.exports=function(t,e){var n=this.__data__,o=r(n,t);return o<0?(++this.size,n.push([t,e])):n[o][1]=e,this}},function(t,e,n){var r=n(29);t.exports=function(t){var e=r(this,t).delete(t);return this.size-=e?1:0,e}},function(t,e){t.exports=function(t){var e=typeof t;return"string"==e||"number"==e||"symbol"==e||"boolean"==e?"__proto__"!==t:null===t}},function(t,e,n){var r=n(29);t.exports=function(t){return r(this,t).get(t)}},function(t,e,n){var r=n(29);t.exports=function(t){return r(this,t).has(t)}},function(t,e,n){var r=n(29);t.exports=function(t,e){var n=r(this,t),o=n.size;return n.set(t,e),this.size+=n.size==o?0:1,this}},function(t,e){var n="__lodash_hash_undefined__";t.exports=function(t){return this.__data__.set(t,n),this}},function(t,e){t.exports=function(t){return this.__data__.has(t)}},function(t,e,n){var r=n(72);t.exports=function(t,e){return!!(null==t?0:t.length)&&r(t,e,0)>-1}},function(t,e){t.exports=function(t,e,n){for(var r=-1,o=null==t?0:t.length;++r>>32-e},rotr:function(t,e){return t<<32-e|t>>>e},endian:function(t){if(t.constructor==Number)return 16711935&r.rotl(t,8)|4278255360&r.rotl(t,24);for(var e=0;e0;t--)e.push(Math.floor(256*Math.random()));return e},bytesToWords:function(t){for(var e=[],n=0,r=0;n>>5]|=t[n]<<24-r%32;return e},wordsToBytes:function(t){for(var e=[],n=0;n<32*t.length;n+=8)e.push(t[n>>>5]>>>24-n%32&255);return e},bytesToHex:function(t){for(var e=[],n=0;n>>4).toString(16)),e.push((15&t[n]).toString(16));return e.join("")},hexToBytes:function(t){for(var e=[],n=0;n>>6*(3-i)&63)):e.push("=");return e.join("")},base64ToBytes:function(t){t=t.replace(/[^A-Z0-9+\/]/gi,"");for(var e=[],r=0,o=0;r>>6-2*o);return e}},t.exports=r},function(t,e){function n(t){return!!t.constructor&&"function"==typeof t.constructor.isBuffer&&t.constructor.isBuffer(t)}
+/*!
+ * Determine if an object is a Buffer
+ *
+ * @author Feross Aboukhadijeh
+ * @license MIT
+ */
+t.exports=function(t){return null!=t&&(n(t)||function(t){return"function"==typeof t.readFloatLE&&"function"==typeof t.slice&&n(t.slice(0,0))}(t)||!!t._isBuffer)}},function(t,e,n){"use strict";n.r(e);n(93);var r,o,i,a=n(6),s=n.n(a),c=n(31),u=n.n(c),l=n(32),f=n.n(l),p=n(7),d=n(0),h=Object(d.a)({},(function(){var t=this.$createElement,e=this._self._c||t;return e("svg",{staticStyle:{display:"none"},attrs:{xmlns:"http://www.w3.org/2000/svg"}},[e("symbol",{attrs:{id:"arrow-down-icon",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 448 512"}},[e("path",{attrs:{d:"M413.1 222.5l22.2 22.2c9.4 9.4 9.4 24.6 0 33.9L241 473c-9.4 9.4-24.6 9.4-33.9 0L12.7 278.6c-9.4-9.4-9.4-24.6 0-33.9l22.2-22.2c9.5-9.5 25-9.3 34.3.4L184 343.4V56c0-13.3 10.7-24 24-24h32c13.3 0 24 10.7 24 24v287.4l114.8-120.5c9.3-9.8 24.8-10 34.3-.4z"}})]),this._v(" "),e("symbol",{attrs:{id:"arrow-up-icon",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 448 512"}},[e("path",{attrs:{d:"M34.9 289.5l-22.2-22.2c-9.4-9.4-9.4-24.6 0-33.9L207 39c9.4-9.4 24.6-9.4 33.9 0l194.3 194.3c9.4 9.4 9.4 24.6 0 33.9L413 289.4c-9.5 9.5-25 9.3-34.3-.4L264 168.6V456c0 13.3-10.7 24-24 24h-32c-13.3 0-24-10.7-24-24V168.6L69.2 289.1c-9.3 9.8-24.8 10-34.3.4z"}})]),this._v(" "),e("symbol",{attrs:{id:"clipboard-icon",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 384 512"}},[e("path",{attrs:{d:"M336 64h-80c0-35.3-28.7-64-64-64s-64 28.7-64 64H48C21.5 64 0 85.5 0 112v352c0 26.5 21.5 48 48 48h288c26.5 0 48-21.5 48-48V112c0-26.5-21.5-48-48-48zM192 40c13.3 0 24 10.7 24 24s-10.7 24-24 24-24-10.7-24-24 10.7-24 24-24zm144 418c0 3.3-2.7 6-6 6H54c-3.3 0-6-2.7-6-6V118c0-3.3 2.7-6 6-6h42v36c0 6.6 5.4 12 12 12h168c6.6 0 12-5.4 12-12v-36h42c3.3 0 6 2.7 6 6z"}})]),this._v(" "),e("symbol",{attrs:{id:"lightbulb-icon",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 352 512"}},[e("path",{attrs:{d:"M176 80c-52.94 0-96 43.06-96 96 0 8.84 7.16 16 16 16s16-7.16 16-16c0-35.3 28.72-64 64-64 8.84 0 16-7.16 16-16s-7.16-16-16-16zM96.06 459.17c0 3.15.93 6.22 2.68 8.84l24.51 36.84c2.97 4.46 7.97 7.14 13.32 7.14h78.85c5.36 0 10.36-2.68 13.32-7.14l24.51-36.84c1.74-2.62 2.67-5.7 2.68-8.84l.05-43.18H96.02l.04 43.18zM176 0C73.72 0 0 82.97 0 176c0 44.37 16.45 84.85 43.56 115.78 16.64 18.99 42.74 58.8 52.42 92.16v.06h48v-.12c-.01-4.77-.72-9.51-2.15-14.07-5.59-17.81-22.82-64.77-62.17-109.67-20.54-23.43-31.52-53.15-31.61-84.14-.2-73.64 59.67-128 127.95-128 70.58 0 128 57.42 128 128 0 30.97-11.24 60.85-31.65 84.14-39.11 44.61-56.42 91.47-62.1 109.46a47.507 47.507 0 0 0-2.22 14.3v.1h48v-.05c9.68-33.37 35.78-73.18 52.42-92.16C335.55 260.85 352 220.37 352 176 352 78.8 273.2 0 176 0z"}})]),this._v(" "),e("symbol",{attrs:{id:"pencil-icon",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 512 512"}},[e("path",{attrs:{d:"M497.9 142.1l-46.1 46.1c-4.7 4.7-12.3 4.7-17 0l-111-111c-4.7-4.7-4.7-12.3 0-17l46.1-46.1c18.7-18.7 49.1-18.7 67.9 0l60.1 60.1c18.8 18.7 18.8 49.1 0 67.9zM284.2 99.8L21.6 362.4.4 483.9c-2.9 16.4 11.4 30.6 27.8 27.8l121.5-21.3 262.6-262.6c4.7-4.7 4.7-12.3 0-17l-111-111c-4.8-4.7-12.4-4.7-17.1 0zM124.1 339.9c-5.5-5.5-5.5-14.3 0-19.8l154-154c5.5-5.5 14.3-5.5 19.8 0s5.5 14.3 0 19.8l-154 154c-5.5 5.5-14.3 5.5-19.8 0zM88 424h48v36.3l-64.5 11.3-31.1-31.1L51.7 376H88v48z"}})]),this._v(" "),e("symbol",{attrs:{id:"plus-icon",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 512 512"}},[e("path",{attrs:{d:"M256 8C119 8 8 119 8 256s111 248 248 248 248-111 248-248S393 8 256 8zm144 276c0 6.6-5.4 12-12 12h-92v92c0 6.6-5.4 12-12 12h-56c-6.6 0-12-5.4-12-12v-92h-92c-6.6 0-12-5.4-12-12v-56c0-6.6 5.4-12 12-12h92v-92c0-6.6 5.4-12 12-12h56c6.6 0 12 5.4 12 12v92h92c6.6 0 12 5.4 12 12v56z"}})]),this._v(" "),e("symbol",{attrs:{id:"share-icon",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 512 512"}},[e("path",{attrs:{d:"M503.691 189.836L327.687 37.851C312.281 24.546 288 35.347 288 56.015v80.053C127.371 137.907 0 170.1 0 322.326c0 61.441 39.581 122.309 83.333 154.132 13.653 9.931 33.111-2.533 28.077-18.631C66.066 312.814 132.917 274.316 288 272.085V360c0 20.7 24.3 31.453 39.687 18.164l176.004-152c11.071-9.562 11.086-26.753 0-36.328z"}})])])}),[],!1,null,null,null).exports,g=n(5),m=n(13),v={props:{name:{required:!0}},data:function(){return{fullException:!1}},methods:{removeClamp:function(){this.fullException||(this.fullException=!0)}}},b=Object(d.a)(v,(function(){var t=this.$createElement;return(this._self._c||t)("div",{staticClass:"ui-exception-message",class:this.fullException?"ui-exception-message-full":"",on:{mousedown:this.removeClamp}},[this._v("\n "+this._s(this.name)+"\n")])}),[],!1,null,null,null).exports,_={components:{ExceptionClass:n(14).a,ExceptionMessage:b,LineNumber:m.a,FilePath:g.a},inject:["report"],computed:{firstFrame:function(){return this.report.stacktrace[0]}}},y={inject:["report","telescopeUrl","config"],components:{OccurrenceDetails:Object(d.a)(_,(function(){var t=this,e=t.$createElement,n=t._self._c||e;return n("div",{staticClass:"card-details-overflow scrollbar p-12 pt-10"},[n("div",{staticClass:"text-2xl"},[n("ExceptionClass",{attrs:{name:t.report.exception_class}}),t._v(" "),n("ExceptionMessage",{attrs:{name:t.report.message}})],1),t._v(" "),n("div",[n("a",{staticClass:"ui-url",attrs:{href:t.report.context.request.url,target:"_blank"}},[t._v("\n "+t._s(t.report.context.request.url)+"\n ")])])])}),[],!1,null,null,null).exports,FilePath:g.a}},E=Object(d.a)(y,(function(){var t=this,e=t.$createElement,n=t._self._c||e;return n("div",{staticClass:"mt-12 card card-has-header card-no-props"},[n("div",{staticClass:"card-header"},[n("div",{staticClass:"grid items-center rounded-t border-b border-tint-300 text-xs text-tint-600 ",staticStyle:{"grid-template-columns":"1fr 1fr"}},[n("div",{staticClass:"grid cols-auto justify-start gap-2 px-4 py-2"},[n("div",{staticClass:"flex items-center"},[n("a",{attrs:{href:"http://flareapp.io/docs/ignition-for-laravel/introduction",target:"_blank",title:"Ignition docs"}},[n("svg",{staticClass:"w-4 h-5 mr-4",attrs:{viewBox:"0 0 428 988"}},[n("polygon",{staticStyle:{fill:"#FA4E79"},attrs:{points:"428,247.1 428,494.1 214,617.5 214,369.3 \t\t"}}),t._v(" "),n("polygon",{staticStyle:{fill:"#FFF082"},attrs:{points:"0,988 0,741 214,617.5 214,864.1 \t\t"}}),t._v(" "),n("polygon",{staticStyle:{fill:"#E6003A"},attrs:{points:"214,123.9 214,617.5 0,494.1 0,0 \t\t"}}),t._v(" "),n("polygon",{staticStyle:{fill:"#FFE100"},attrs:{points:"214,864.1 214,617.5 428,741 428,988 \t\t"}})])]),t._v(" "),n("FilePath",{attrs:{pathClass:"font-normal",file:t.report.application_path+t.config.directorySeparator,relative:!1}})],1)]),t._v(" "),n("div",{staticClass:"grid cols-auto items-center justify-end gap-4 px-4 py-2"},[t.telescopeUrl?n("div",[n("a",{staticClass:"link-dimmed sm:ml-6",attrs:{href:t.telescopeUrl,target:"_blank"}},[t._v("Telescope")])]):t._e()])])]),t._v(" "),n("div"),t._v(" "),n("div",{staticClass:"card-details"},[n("OccurrenceDetails")],1)])}),[],!1,null,null,null).exports,x=n(10),k=n.n(x),w=n(20),C=n.n(w),A=n(100)(),T=null,S={inject:["config"],props:{solution:{required:!0}},data:function(){return{isHidingSolutions:this.hasHideSolutionsCookie(),canExecuteSolutions:null,runningSolution:!1,executionSuccessful:null}},computed:{healthCheckEndpoint:function(){return this.solution.execute_endpoint.replace("execute-solution","health-check")}},created:function(){this.configureRunnableSolutions()},mounted:function(){this.isHidingSolutions&&this.$refs.solutionCard.classList.add("solution-hidden")},methods:{configureRunnableSolutions:function(){this.config.enableRunnableSolutions?this.checkExecutionEndpoint():this.canExecuteSolutions=!1},markdown:function(t){return A.render(t)},checkExecutionEndpoint:(o=C()(k.a.mark((function t(){var e;return k.a.wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return t.prev=0,t.next=3,fetch(this.healthCheckEndpoint);case 3:return t.next=5,t.sent.json();case 5:e=t.sent,this.canExecuteSolutions=e.can_execute_commands,t.next=12;break;case 9:t.prev=9,t.t0=t.catch(0),this.canExecuteSolutions=!1;case 12:case"end":return t.stop()}}),t,this,[[0,9]])}))),function(){return o.apply(this,arguments)}),execute:(r=C()(k.a.mark((function t(){var e;return k.a.wrap((function(t){for(;;)switch(t.prev=t.next){case 0:if(!this.runningSolution){t.next=2;break}return t.abrupt("return");case 2:return t.prev=2,this.runningSolution=!0,t.next=6,fetch(this.solution.execute_endpoint,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({solution:this.solution.class,parameters:this.solution.run_parameters})});case 6:e=t.sent,this.executionSuccessful=200===e.status,t.next=14;break;case 10:t.prev=10,t.t0=t.catch(2),console.error(t.t0),this.executionSuccessful=!1;case 14:return t.prev=14,this.runningSolution=!1,t.finish(14);case 17:case"end":return t.stop()}}),t,this,[[2,10,14,17]])}))),function(){return r.apply(this,arguments)}),refresh:function(){location.reload()},getUrlLabel:function(t){var e=document.createElement("a");return e.href=t,e.hostname},toggleSolutions:function(){var t=this;this.isHidingSolutions?(window.clearTimeout(T),this.toggleHidingSolutions()):(this.$refs.solutionCard.classList.add("solution-hiding"),T=window.setTimeout((function(){t.$refs.solutionCard.classList.remove("solution-hiding"),t.toggleHidingSolutions()}),100))},toggleHidingSolutions:function(){if(this.isHidingSolutions)return document.cookie="".concat("hide_solutions","=;expires=Thu, 01 Jan 1970 00:00:00 UTC;path=/;"),void(this.isHidingSolutions=!1);var t=new Date;t.setTime(t.getTime()+31536e6),document.cookie="".concat("hide_solutions","=true;expires=").concat(t.toUTCString(),";path=/;"),this.isHidingSolutions=!0},hasHideSolutionsCookie:function(){return document.cookie.includes("hide_solutions")}}},R={components:{SolutionCard:Object(d.a)(S,(function(){var t=this,e=t.$createElement,n=t._self._c||e;return n("div",[n("div",{staticClass:"solution-toggle",class:{"solution-toggle-show":t.isHidingSolutions},on:{click:t.toggleSolutions}},[t.isHidingSolutions?n("a",{staticClass:"link-solution",attrs:{target:"_blank"}},[n("Icon",{staticClass:"text-xs mr-1",attrs:{name:"lightbulb"}}),t._v(" Show solutions")],1):n("a",{staticClass:"link-solution",attrs:{target:"_blank"}},[t._v("Hide solutions")])]),t._v(" "),n("div",{ref:"solutionCard",staticClass:"solution",class:{"solution-hidden":t.isHidingSolutions}},[n("div",{staticClass:"solution-main"},[n("div",{staticClass:"solution-background mx-0"},[n("svg",{staticClass:"hidden absolute right-0 h-full | md:block",attrs:{x:"0px",y:"0px",viewBox:"0 0 299 452"}},[n("g",{staticStyle:{opacity:"0.075"}},[n("polygon",{staticStyle:{fill:"rgb(63,63,63)"},attrs:{points:"298.1,451.9 150.9,451.9 21,226.9 298.1,227.1"}}),t._v(" "),n("polygon",{staticStyle:{fill:"rgb(151,151,151)"},attrs:{points:"298.1,227.1 21,226.9 150.9,1.9 298.1,1.9"}})])])]),t._v(" "),n("div",{staticClass:"p-12"},[n("div",{staticClass:"solution-content ml-0"},[""!==t.solution.title?n("h2",{staticClass:"solution-title"},[t._v("\n "+t._s(t.solution.title)+"\n ")]):t._e(),t._v(" "),t.solution.description?n("div",{domProps:{innerHTML:t._s(t.markdown(t.solution.description))}}):t._e(),t._v(" "),t.solution.is_runnable?n("div",[n("p",{domProps:{innerHTML:t._s(t.markdown(t.solution.action_description))}}),t._v(" "),null===t.canExecuteSolutions?n("p",{staticClass:"py-4 text-sm italic"},[t._v("\n Loading...\n ")]):t._e(),t._v(" "),n("div",{staticClass:"mt-4"},[t.solution.is_runnable&&!0===t.canExecuteSolutions&&null===t.executionSuccessful?n("button",{staticClass:"button-secondary button-lg bg-tint-300 hover:bg-tint-400",attrs:{disabled:t.runningSolution},on:{click:t.execute}},[t.runningSolution?n("span",[t._v("Running...")]):t._e(),t._v(" "),t.runningSolution?t._e():n("span",[t._v(t._s(t.solution.run_button_text))])]):t._e(),t._v(" "),t.executionSuccessful?n("p",[n("strong",{staticClass:"font-semibold"},[t._v("The solution was executed successfully.")]),t._v(" "),n("a",{staticClass:"link-solution",attrs:{href:"#"},on:{click:function(e){return e.preventDefault(),t.refresh(e)}}},[t._v("Refresh now.")])]):t._e(),t._v(" "),!1===t.executionSuccessful?n("p",[t._v("\n Something went wrong when executing the solution. Please try\n refreshing the page and try again.\n ")]):t._e()])]):t._e(),t._v(" "),Object.entries(t.solution.links).length>0?n("div",{staticClass:"mt-8 grid justify-start"},[n("div",{staticClass:"border-t-2 border-gray-700 opacity-25 "}),t._v(" "),n("div",{staticClass:"pt-2 grid cols-auto-1fr gapx-4 gapy-2 text-sm"},[n("label",{staticClass:"font-semibold uppercase tracking-wider"},[t._v("Read more")]),t._v(" "),n("ul",t._l(t.solution.links,(function(e,r){return n("li",{key:r},[n("a",{staticClass:"link-solution",attrs:{href:e,target:"_blank"}},[t._v(t._s(r))])])})),0)])]):t._e()])])])])])}),[],!1,null,null,null).exports,ErrorCard:E,FilePath:g.a},inject:["report","solutions"],data:function(){return{activeSolutionKey:0}},computed:{firstFrame:function(){return this.report.stacktrace[0]},solution:function(){return this.solutions[this.activeSolutionKey]}}},O=Object(d.a)(R,(function(){var t=this,e=t.$createElement,n=t._self._c||e;return n("div",[n("div",{staticClass:"layout-col z-10"},[n("ErrorCard")],1),t._v(" "),t.solutions.length>0?n("div",{staticClass:"layout-col z-1"},[n("SolutionCard",t._b({},"SolutionCard",{solution:t.solution},!1)),t._v(" "),t.solutions.length>1?n("div",{staticClass:"absolute left-0 bottom-0 w-full h-8 mb-2 px-4 text-sm z-10"},[n("ul",{staticClass:"grid cols-auto place-center gap-1"},t._l(t.solutions,(function(e,r){return n("li",{key:e.class,on:{click:function(e){t.activeSolutionKey=r}}},[n("a",{staticClass:"grid place-center h-8 min-w-8 px-2 rounded-full",class:{"bg-tint-200 font-semibold":t.activeSolutionKey===r,"hover:bg-tint-100 cursor-pointer":t.activeSolutionKey!==r}},[t._v("\n "+t._s(r+1)+"\n ")])])})),0)]):t._e()],1):t._e()])}),[],!1,null,null,null).exports,N={components:{CheckboxField:n(35).a},props:["error","isLoading"],computed:{selectedTabs:function(){return this.tabs.filter((function(t){return t.checked})).map((function(t){return t.name}))}},data:function(){return{tabs:[{label:"Stack trace",name:"stackTraceTab",checked:!0},{label:"Request",name:"requestTab",checked:!0},{label:"App",name:"appTab",checked:!0},{label:"User",name:"userTab",checked:!0},{label:"Context",name:"contextTab",checked:!0},{label:"Debug",name:"debugTab",checked:!0}]}},methods:{shareError:function(){this.isLoading||this.$emit("share",this.selectedTabs)}}},I=Object(d.a)(N,(function(){var t=this,e=t.$createElement,n=t._self._c||e;return n("div",[n("div",{staticClass:"grid cols-2 justify-start gapx-6 gapy-2"},t._l(t.tabs,(function(e){return n("CheckboxField",{key:e.name,staticClass:"text-gray-200 hover:text-white",attrs:{label:e.label,name:e.name},on:{change:function(t){e.checked=!e.checked}},model:{value:e.checked,callback:function(n){t.$set(e,"checked",n)},expression:"tab.checked"}})})),1),t._v(" "),n("div",{staticClass:"mt-4"},[t.error?n("div",{staticClass:"mb-3"},[t._v("\n We were unable to share your error."),n("br"),t._v("\n Please try again later.\n ")]):t._e(),t._v(" "),n("button",{staticClass:"button-secondary button-sm text-white bg-tint-600",attrs:{disabled:t.isLoading},on:{click:t.shareError}},[t._v("\n "+t._s(t.isLoading?"Sharing…":"Share")+"\n ")])])])}),[],!1,null,null,null).exports,L={props:{text:{required:!0}},data:function(){return{copied:!1,timeout:!1}},methods:{copy:function(t){var e=this;this.timeout&&window.clearTimeout(this.timeout);var n=document.createElement("textarea");n.value=t,document.body.appendChild(n),n.select(),document.execCommand("copy"),document.body.removeChild(n),this.copied=!0,this.timeout=window.setTimeout((function(){return e.copied=!1}),3e3)}}},D={components:{CopyButton:Object(d.a)(L,(function(){var t=this,e=t.$createElement,n=t._self._c||e;return n("button",{attrs:{title:"Copy to clipboard"},on:{click:function(e){return t.copy(t.text)}}},[n("Icon",{class:t.copied?"fill-green-300":"fill-gray-200 hover:fill-white",attrs:{name:"clipboard"}}),t._v(" "),t.copied?n("div",{staticClass:"ml-2 absolute top-0 left-full text-green-300"},[t._v("\n Copied!\n ")]):t._e()],1)}),[],!1,null,null,null).exports},props:{publicUrl:{required:!0},ownerUrl:{required:!0}}},M={components:{ShareLinks:Object(d.a)(D,(function(){var t=this,e=t.$createElement,n=t._self._c||e;return n("div",{staticClass:"text-left"},[n("p",{staticClass:"mt-2 text-gray-300"},[t._v("Share your error with others:")]),t._v(" "),n("div",{staticClass:"grid cols-auto items-center justify-start gap-2 mt-2"},[n("a",{staticClass:"button-secondary button-sm bg-tint-600 hover:bg-tint-700 text-white",attrs:{href:t.publicUrl,target:"_blank"}},[t._v("Open public share")]),t._v(" "),n("CopyButton",{attrs:{text:t.publicUrl}})],1),t._v(" "),n("p",{staticClass:"mt-4 text-gray-300"},[t._v("Administer your shared error here:")]),t._v(" "),n("div",{staticClass:"grid cols-auto items-center justify-start gap-2 mt-2"},[n("a",{staticClass:"button-secondary button-sm bg-tint-600 hover:bg-tint-700 text-white",attrs:{href:t.ownerUrl,target:"_blank"}},[t._v("Open share admin")]),t._v(" "),n("CopyButton",{attrs:{text:t.ownerUrl}})],1)])}),[],!1,null,null,null).exports,ShareForm:I},inject:["report","shareEndpoint"],data:function(){return{shareHadError:!1,sharedErrorUrls:null,menuVisible:!1,isShareLoading:!1}},watch:{menuVisible:function(t){t?window.addEventListener("click",this.toggleMenu):window.removeEventListener("click",this.toggleMenu)}},methods:{toggleMenu:function(){this.menuVisible=!this.menuVisible},shareError:(i=C()(k.a.mark((function t(e){var n,r;return k.a.wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return this.isShareLoading=!0,t.prev=1,t.next=4,fetch(this.shareEndpoint,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({report:JSON.stringify(this.report),tabs:e,lineSelection:window.location.hash})});case 4:return n=t.sent,t.next=7,n.json();case 7:r=t.sent,n.ok?this.sharedErrorUrls=r:this.shareHadError=!0,t.next=14;break;case 11:t.prev=11,t.t0=t.catch(1),this.shareHadError=!0;case 14:this.isShareLoading=!1;case 15:case"end":return t.stop()}}),t,this,[[1,11]])}))),function(t){return i.apply(this,arguments)})}},P={inject:["config"],components:{ShareButton:Object(d.a)(M,(function(){var t=this,e=t.$createElement,n=t._self._c||e;return n("div",{on:{click:function(t){t.stopPropagation()}}},[n("button",{staticClass:"tab",class:t.menuVisible?"tab-active":"",on:{click:t.toggleMenu}},[t._v("\n Share\n "),n("Icon",{staticClass:"ml-2",attrs:{name:"share"}})],1),t._v(" "),n("div",{staticClass:"dropdown z-10 right-0 top-full p-4 overflow-visible",class:{hidden:!t.menuVisible},staticStyle:{"min-width":"18rem","margin-right":"-1px"},on:{click:function(t){t.stopPropagation()}}},[n("div",{staticClass:"flex items-center mb-4"},[n("svg",{staticClass:"w-4 h-5 mr-2",attrs:{viewBox:"0 0 682 1024"}},[n("polygon",{staticStyle:{fill:"#51DB9E"},attrs:{points:"235.3,510.5 21.5,387 21.5,140.2 236.5,264.1 "}}),t._v(" "),n("polygon",{staticStyle:{fill:"#7900F5"},attrs:{points:"235.3,1004.8 21.5,881.4 21.5,634.5 234.8,757.9 "}}),t._v(" "),n("polygon",{staticStyle:{fill:"#94F2C8"},attrs:{points:"448.9,386.9 21.5,140.2 235.3,16.7 663.2,263.4 "}}),t._v(" "),n("polygon",{staticStyle:{fill:"#A475F4"},attrs:{points:"234.8,757.9 21.5,634.5 235.3,511 449.1,634.5 "}})]),t._v(" "),n("h5",{staticClass:"text-left font-semibold uppercase tracking-wider whitespace-no-wrap"},[t._v("\n "+t._s(t.sharedErrorUrls?"Shared":"Share")+" on Flare\n ")]),t._v(" "),n("a",{staticClass:"ml-auto underline",attrs:{target:"_blank",href:"https://flareapp.io/docs/ignition-for-laravel/sharing-errors",title:"Flare documentation"}},[t._v("Docs\n ")])]),t._v(" "),t.sharedErrorUrls?n("div",[n("ShareLinks",{attrs:{publicUrl:t.sharedErrorUrls.public_url,ownerUrl:t.sharedErrorUrls.owner_url}})],1):n("ShareForm",{attrs:{error:t.shareHadError,"is-loading":t.isShareLoading},on:{share:t.shareError}})],1)])}),[],!1,null,null,null).exports},props:{value:{required:!0},customTabs:{required:!0}},data:function(){return{defaultTabs:[{component:"StackTab",title:"Stack trace"},{component:"RequestTab",title:"Request"},{component:"AppTab",title:"App"},{component:"UserTab",title:"User"},{component:"ContextTab",title:"Context"},{component:"DebugTab",title:"Debug"}],shareButtonEnabled:this.config.enableShareButton}},mounted:function(){this.applyDefaultTabProps(),this.$emit("input",this.tabs[this.currentTabIndex])},computed:{currentTabIndex:function(){var t=this;return this.tabs.findIndex((function(e){return e.component===t.value.component}))},nextTab:function(){return this.tabs[this.currentTabIndex+1]||this.tabs[0]},previousTab:function(){return this.tabs[this.currentTabIndex-1]||this.tabs[this.tabs.length-1]},tabs:function(){var t={};return this.defaultTabs.forEach((function(e){t[e.component]=e})),this.customTabs.forEach((function(e){t[e.component]=e})),Object.values(t)}},methods:{applyDefaultTabProps:function(){var t=this;this.defaultTabs.map((function(e){return e.component===t.value.component&&(e.props=t.value.props||{}),e}))}}},j={props:{tab:{required:!0}},render:function(t){return t(this.tab.component,{props:this.tab.props||{}})}},F={props:{report:{required:!0},config:{required:!0},solutions:{required:!0},telescopeUrl:{required:!0},shareEndpoint:{required:!0},defaultTab:{required:!0},defaultTabProps:{required:!1}},data:function(){return{customTabs:window.tabs,tab:{component:this.defaultTab,props:this.defaultTabProps||{}}}},provide:function(){return{config:this.config,report:this.report,solutions:this.solutions,telescopeUrl:this.telescopeUrl,shareEndpoint:this.shareEndpoint,setTab:this.setTab}},components:{Summary:O,Tabs:Object(d.a)(P,(function(){var t=this,e=t.$createElement,n=t._self._c||e;return n("nav",{staticClass:"tab-nav"},[n("ul",{staticClass:"tab-bar"},t._l(t.tabs,(function(e){return n("li",{key:e.component},[n("button",{staticClass:"tab",class:t.value.component===e.component?"tab-active":"",on:{click:function(n){return n.preventDefault(),t.$emit("input",e)}}},[t._v("\n "+t._s(e.title)+"\n ")])])})),0),t._v(" "),t.shareButtonEnabled?[n("div",{staticClass:"tab-delimiter"}),t._v(" "),n("ShareButton")]:t._e()],2)}),[],!1,null,null,null).exports,Details:Object(d.a)(j,void 0,void 0,!1,null,null,null).exports,IconSymbols:h},methods:{setTab:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};this.tab={component:t,props:e}}},created:function(){}},U=Object(d.a)(F,(function(){var t=this,e=t.$createElement,n=t._self._c||e;return n("div",[n("IconSymbols"),t._v(" "),n("Summary"),t._v(" "),n("div",{staticClass:"layout-col mt-12"},[n("div",{staticClass:"tabs"},[n("Tabs",t._b({model:{value:t.tab,callback:function(e){t.tab=e},expression:"tab"}},"Tabs",{customTabs:t.customTabs},!1)),t._v(" "),n("div",{staticClass:"tab-main"},[n("Details",t._b({},"Details",{tab:t.tab},!1))],1)],1)])],1)}),[],!1,null,null,null).exports;function $(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function B(t){for(var e=1;e=this.selectedRange[0]&&t<=this.selectedRange[1])},editorUrl:function(t){return Object(c.a)(this.config,this.selectedFrame.file,t)},highlightedCode:function(t){var e=o.a.highlight("php",t||"",!0,this.highlightState);return this.highlightState=e.top,e.value||" "}}},l=n(0),f=Object(l.a)(u,(function(){var t=this,e=t.$createElement,n=t._self._c||e;return n("div",{staticClass:"stack-main"},[n("div",{staticClass:"stack-main-header"},[n("div",{staticClass:"grid cols-auto gap-2 justify-start items-center"},[n("ExceptionClass",{attrs:{name:t.selectedFrame.class||"",method:t.selectedFrame.method||""}})],1),t._v(" "),t.selectedFrame.file?n("FilePath",{staticClass:"mt-1",attrs:{"line-number":t.selectedFrame.line_number,file:t.selectedFrame.file,editable:!0}}):t._e()],1),t._v(" "),n("div",{staticClass:"stack-main-content"},[n("div",{staticClass:"stack-viewer scrollbar"},[n("div",{staticClass:"stack-ruler"},[n("div",{staticClass:"stack-lines"},t._l(t.selectedFrame.code_snippet,(function(e,r){return n("p",{key:r,staticClass:"stack-line cursor-pointer",class:{"stack-line-selected":t.withinSelectedRange(parseInt(r)),"stack-line-highlight":parseInt(r)===t.selectedFrame.line_number},on:{click:function(e){t.handleLineNumberClick(e,parseInt(r))}}},[t._v("\n "+t._s(r)+"\n ")])})),0)]),t._v(" "),n("pre",{ref:"codeContainer",staticClass:"stack-code",class:t.highlightTheme},[t._l(t.selectedFrame.code_snippet,(function(e,r){return n("p",{key:r,staticClass:"stack-code-line",class:{"stack-code-line-highlight":parseInt(r)===t.selectedFrame.line_number,"stack-code-line-selected":t.withinSelectedRange(parseInt(r))}},[n("span",{domProps:{innerHTML:t._s(t.highlightedCode(e))}}),n("a",{staticClass:"editor-link",attrs:{href:t.editorUrl(r)}},[n("Icon",{attrs:{name:"pencil"}})],1)])})),t._v("\n ")],2)])])])}),[],!1,null,null,null).exports,p={props:{frameGroup:{required:!0}},components:{ExceptionClass:i.a,FilePath:a.a,LineNumber:s.a}},d=Object(l.a)(p,(function(){var t=this,e=t.$createElement,n=t._self._c||e;return t.frameGroup.expanded||"vendor"!==t.frameGroup.type?"unknown"===t.frameGroup.type?n("li",{staticClass:"stack-frame-group stack-frame-group-unknown"},[n("div",{staticClass:"stack-frame"},[n("button",{staticClass:"stack-frame-number"}),t._v(" "),n("div",{staticClass:"span-2 stack-frame-text"},[n("span",{staticClass:"text-left text-gray-500"},[t._v("\n "+t._s(t.frameGroup.frames.length>1?t.frameGroup.frames.length+" unknown frames":"1 unknown frame")+"\n ")])])])]):n("li",[n("ul",{staticClass:"stack-frame-group",class:"vendor"===t.frameGroup.type?"stack-frame-group-vendor":""},t._l(t.frameGroup.frames,(function(e,r){return n("li",{key:r,staticClass:"stack-frame | cursor-pointer",class:e.selected?"stack-frame-selected":"",on:{click:function(n){return t.$emit("select",e.frame_number)}}},[n("div",{staticClass:"stack-frame-number"},[t._v(t._s(e.frame_number))]),t._v(" "),n("div",{staticClass:"stack-frame-text"},[0===r?n("header",{staticClass:"stack-frame-header",class:e.class?"mb-1":""},[n("FilePath",{staticClass:"stack-frame-path",attrs:{pathClass:"vendor"===t.frameGroup.type?"text-gray-800":"text-purple-800",file:e.relative_file}})],1):t._e(),t._v(" "),e.class?n("span",{staticClass:"stack-frame-exception-class"},[n("ExceptionClass",{staticClass:"stack-frame-exception-class",attrs:{name:e.class}})],1):t._e()]),t._v(" "),n("div",{staticClass:"stack-frame-line"},[n("LineNumber",{attrs:{lineNumber:e.line_number}})],1)])})),0)]):n("li",{staticClass:"stack-frame-group stack-frame-group-vendor",on:{click:function(e){return t.$emit("expand")}}},[n("div",{staticClass:"stack-frame | cursor-pointer"},[n("button",{staticClass:"stack-frame-number"},[n("Icon",{staticClass:"align-middle text-gray-500",attrs:{name:"plus"}})],1),t._v(" "),n("div",{staticClass:"span-2 stack-frame-text"},[n("button",{staticClass:"text-left text-gray-500"},[t._v("\n "+t._s(t.frameGroup.frames.length>1?t.frameGroup.frames.length+" vendor frames…":"1 vendor frame…")+"\n ")])])])])}),[],!1,null,null,null).exports,h=n(6),g=n.n(h),m=n(4),v=n.n(m),b=n(15),_=n.n(b);function y(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function E(t){return t.map((function(e,n){return function(t){for(var e=1;e
+
+
+
+
+
+ Vue App
+
+
+
+
+
diff --git a/vendor/facade/ignition/resources/views/errorPage.php b/vendor/facade/ignition/resources/views/errorPage.php
new file mode 100644
index 00000000..9600cbf0
--- /dev/null
+++ b/vendor/facade/ignition/resources/views/errorPage.php
@@ -0,0 +1,63 @@
+
+
+
+
+
+
+
+
+
+
+
+
+ = $title ?>
+
+
+
+
+
+
+
+
+
+
+=$throwableString?>
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/vendor/facade/ignition/src/Actions/ShareReportAction.php b/vendor/facade/ignition/src/Actions/ShareReportAction.php
new file mode 100644
index 00000000..a21c5cc4
--- /dev/null
+++ b/vendor/facade/ignition/src/Actions/ShareReportAction.php
@@ -0,0 +1,167 @@
+client = $client;
+ }
+
+ public function handle(array $report, array $tabs, ?string $lineSelection = null)
+ {
+ $this->tabs = $tabs;
+
+ $report = $this->filterReport($report);
+
+ try {
+ return $this->client->post('public-reports', [
+ 'report' => $this->trimReport($report),
+ 'tabs' => $tabs,
+ 'lineSelection' => $lineSelection,
+ ]);
+ } catch (Exception $exception) {
+ throw new UnableToShareErrorException($exception->getMessage());
+ }
+ }
+
+ public function filterReport(array $report): array
+ {
+ if (! $this->hasTab('stackTraceTab')) {
+ $report['stacktrace'] = array_slice($report['stacktrace'], 0, 1);
+ }
+
+ if (! $this->hasTab('debugTab')) {
+ $report['glows'] = [];
+ }
+
+ $report['context'] = $this->filterContextItems($report['context']);
+
+ return $report;
+ }
+
+ protected function hasTab(string $tab): bool
+ {
+ return in_array($tab, $this->tabs);
+ }
+
+ protected function filterContextItems(array $contextItems): array
+ {
+ if (! $this->hasTab('requestTab')) {
+ $contextItems = $this->removeRequestInformation($contextItems);
+ }
+
+ if (! $this->hasTab('appTab')) {
+ $contextItems = $this->removeAppInformation($contextItems);
+ }
+
+ if (! $this->hasTab('userTab')) {
+ $contextItems = $this->removeUserInformation($contextItems);
+ }
+
+ if (! $this->hasTab('contextTab')) {
+ $contextItems = $this->removeContextInformation($contextItems);
+ }
+
+ if (! $this->hasTab('debugTab')) {
+ $contextItems = $this->removeDebugInformation($contextItems);
+ }
+
+ return $contextItems;
+ }
+
+ protected function removeRequestInformation(array $contextItems): array
+ {
+ Arr::forget($contextItems, 'request');
+ Arr::forget($contextItems, 'request_data');
+ Arr::forget($contextItems, 'headers');
+ Arr::forget($contextItems, 'session');
+ Arr::forget($contextItems, 'cookies');
+
+ return $contextItems;
+ }
+
+ protected function removeAppInformation(array $contextItems): array
+ {
+ Arr::forget($contextItems, 'view');
+ Arr::forget($contextItems, 'route');
+
+ return $contextItems;
+ }
+
+ protected function removeUserInformation(array $contextItems): array
+ {
+ Arr::forget($contextItems, 'user');
+ Arr::forget($contextItems, 'request.ip');
+ Arr::forget($contextItems, 'request.useragent');
+
+ return $contextItems;
+ }
+
+ protected function removeContextInformation(array $contextItems): array
+ {
+ Arr::forget($contextItems, 'env');
+ Arr::forget($contextItems, 'git');
+ Arr::forget($contextItems, 'context');
+
+ Arr::forget($contextItems, $this->getCustomContextGroups($contextItems));
+
+ return $contextItems;
+ }
+
+ protected function removeDebugInformation(array $contextItems): array
+ {
+ Arr::forget($contextItems, 'dumps');
+ Arr::forget($contextItems, 'glows');
+ Arr::forget($contextItems, 'logs');
+ Arr::forget($contextItems, 'queries');
+
+ return $contextItems;
+ }
+
+ protected function getCustomContextGroups(array $contextItems): array
+ {
+ $predefinedContextItemGroups = [
+ 'request',
+ 'request_data',
+ 'headers',
+ 'session',
+ 'cookies',
+ 'view',
+ 'queries',
+ 'route',
+ 'user',
+ 'env',
+ 'git',
+ 'context',
+ 'logs',
+ 'dumps',
+ ];
+
+ return Collection::make($contextItems)
+ ->reject(function ($value, $group) use ($predefinedContextItemGroups) {
+ return in_array($group, $predefinedContextItemGroups);
+ })
+ ->keys()
+ ->toArray();
+ }
+
+ protected function trimReport(array $report): array
+ {
+ return (new ReportTrimmer())->trim($report);
+ }
+}
diff --git a/vendor/facade/ignition/src/Commands/SolutionMakeCommand.php b/vendor/facade/ignition/src/Commands/SolutionMakeCommand.php
new file mode 100644
index 00000000..a9e2fc9c
--- /dev/null
+++ b/vendor/facade/ignition/src/Commands/SolutionMakeCommand.php
@@ -0,0 +1,65 @@
+option('runnable')
+ ? __DIR__.'/stubs/runnable-solution.stub'
+ : __DIR__.'/stubs/solution.stub';
+ }
+
+ /**
+ * Get the default namespace for the class.
+ *
+ * @param string $rootNamespace
+ * @return string
+ */
+ protected function getDefaultNamespace($rootNamespace)
+ {
+ return $rootNamespace.'\Solutions';
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['runnable', null, InputOption::VALUE_NONE, 'Create runnable solution'],
+ ];
+ }
+}
diff --git a/vendor/facade/ignition/src/Commands/SolutionProviderMakeCommand.php b/vendor/facade/ignition/src/Commands/SolutionProviderMakeCommand.php
new file mode 100644
index 00000000..2c87fa4b
--- /dev/null
+++ b/vendor/facade/ignition/src/Commands/SolutionProviderMakeCommand.php
@@ -0,0 +1,50 @@
+config = $config;
+
+ $this->checkFlareKey();
+
+ if (app()->make('log') instanceof LogManager) {
+ $this->checkFlareLogger();
+ }
+
+ $this->sendTestException();
+ }
+
+ protected function checkFlareKey()
+ {
+ $message = empty($this->config->get('flare.key'))
+ ? '❌ Flare key not specified. Make sure you specify a value in the `key` key of the `flare` config file.'
+ : '✅ Flare key specified';
+
+ $this->info($message);
+
+ return $this;
+ }
+
+ public function checkFlareLogger()
+ {
+ $defaultLogChannel = $this->config->get('logging.default');
+
+ $activeStack = $this->config->get("logging.channels.{$defaultLogChannel}");
+
+ if (is_null($activeStack)) {
+ $this->info("❌ The default logging channel `{$defaultLogChannel}` is not configured in the `logging` config file");
+ }
+
+ if (! isset($activeStack['channels']) || ! in_array('flare', $activeStack['channels'])) {
+ $this->info("❌ The logging channel `{$defaultLogChannel}` does not contain the 'flare' channel");
+ }
+
+ if (is_null($this->config->get('logging.channels.flare'))) {
+ $this->info('❌ There is no logging channel named `flare` in the `logging` config file');
+ }
+
+ if ($this->config->get('logging.channels.flare.driver') !== 'flare') {
+ $this->info('❌ The `flare` logging channel defined in the `logging` config file is not set to `flare`.');
+ }
+
+ $this->info('✅ The Flare logging driver was configured correctly.');
+
+ return $this;
+ }
+
+ protected function sendTestException()
+ {
+ $testException = new Exception('This is an exception to test if the integration with Flare works.');
+
+ try {
+ app(Flare::class)->sendTestReport($testException);
+ $this->info(PHP_EOL);
+ } catch (Exception $exception) {
+ $this->warn('❌ We were unable to send an exception to Flare. Make sure that your key is correct and that you have a valid subscription. '.PHP_EOL.PHP_EOL.'For more info visit the docs on installing Flare in a Laravel project: https://flareapp.io/docs/ignition-for-laravel/introduction');
+
+ return;
+ }
+
+ $this->info('We tried to send an exception to Flare. Please check if it arrived!');
+ }
+}
diff --git a/vendor/facade/ignition/src/Commands/stubs/runnable-solution.stub b/vendor/facade/ignition/src/Commands/stubs/runnable-solution.stub
new file mode 100644
index 00000000..cf4f53fd
--- /dev/null
+++ b/vendor/facade/ignition/src/Commands/stubs/runnable-solution.stub
@@ -0,0 +1,43 @@
+runningInConsole()) {
+ return new LaravelConsoleContext($_SERVER['argv'] ?? []);
+ }
+
+ return new LaravelRequestContext(app(Request::class));
+ }
+}
diff --git a/vendor/facade/ignition/src/Context/LaravelRequestContext.php b/vendor/facade/ignition/src/Context/LaravelRequestContext.php
new file mode 100644
index 00000000..d9537da2
--- /dev/null
+++ b/vendor/facade/ignition/src/Context/LaravelRequestContext.php
@@ -0,0 +1,88 @@
+request = $request;
+ }
+
+ public function getUser(): array
+ {
+ try {
+ $user = $this->request->user();
+
+ if (! $user) {
+ return [];
+ }
+ } catch (\Throwable $e) {
+ return [];
+ }
+
+ try {
+ if (method_exists($user, 'toFlare')) {
+ return $user->toFlare();
+ }
+
+ if (method_exists($user, 'toArray')) {
+ return $user->toArray();
+ }
+ } catch (\Throwable $e) {
+ return [];
+ }
+
+ return [];
+ }
+
+ public function getRoute(): array
+ {
+ $route = $this->request->route();
+
+ return [
+ 'route' => optional($route)->getName(),
+ 'routeParameters' => $this->getRouteParameters(),
+ 'controllerAction' => optional($route)->getActionName(),
+ 'middleware' => array_values(optional($route)->gatherMiddleware() ?? []),
+ ];
+ }
+
+ public function getRequest(): array
+ {
+ $properties = parent::getRequest();
+
+
+ if ($this->request->hasHeader('x-livewire') && $this->request->hasHeader('referer')) {
+ $properties['url'] = $this->request->header('referer');
+ }
+
+ return $properties;
+ }
+
+ protected function getRouteParameters(): array
+ {
+ try {
+ return collect(optional($this->request->route())->parameters ?? [])->toArray();
+ } catch (\Throwable $e) {
+ return [];
+ }
+ }
+
+ public function toArray(): array
+ {
+ $properties = parent::toArray();
+
+ $properties['route'] = $this->getRoute();
+
+ $properties['user'] = $this->getUser();
+
+ return $properties;
+ }
+}
diff --git a/vendor/facade/ignition/src/DumpRecorder/Dump.php b/vendor/facade/ignition/src/DumpRecorder/Dump.php
new file mode 100644
index 00000000..f68191e0
--- /dev/null
+++ b/vendor/facade/ignition/src/DumpRecorder/Dump.php
@@ -0,0 +1,36 @@
+htmlDump = $htmlDump;
+ $this->file = $file;
+ $this->lineNumber = $lineNumber;
+ $this->microtime = $microtime ?? microtime(true);
+ }
+
+ public function toArray(): array
+ {
+ return [
+ 'html_dump' => $this->htmlDump,
+ 'file' => $this->file,
+ 'line_number' => $this->lineNumber,
+ 'microtime' => $this->microtime,
+ ];
+ }
+}
diff --git a/vendor/facade/ignition/src/DumpRecorder/DumpHandler.php b/vendor/facade/ignition/src/DumpRecorder/DumpHandler.php
new file mode 100644
index 00000000..44fe2172
--- /dev/null
+++ b/vendor/facade/ignition/src/DumpRecorder/DumpHandler.php
@@ -0,0 +1,23 @@
+dumpRecorder = $dumpRecorder;
+ }
+
+ public function dump($value)
+ {
+ $data = (new VarCloner)->cloneVar($value);
+
+ $this->dumpRecorder->record($data);
+ }
+}
diff --git a/vendor/facade/ignition/src/DumpRecorder/DumpRecorder.php b/vendor/facade/ignition/src/DumpRecorder/DumpRecorder.php
new file mode 100644
index 00000000..ef1fad37
--- /dev/null
+++ b/vendor/facade/ignition/src/DumpRecorder/DumpRecorder.php
@@ -0,0 +1,112 @@
+app = $app;
+ }
+
+ public function register(): self
+ {
+ $multiDumpHandler = new MultiDumpHandler();
+
+ $this->app->singleton(MultiDumpHandler::class, function () use ($multiDumpHandler) {
+ return $multiDumpHandler;
+ });
+
+ $previousHandler = VarDumper::setHandler(function ($var) use ($multiDumpHandler) {
+ $multiDumpHandler->dump($var);
+ });
+
+ if ($previousHandler) {
+ $multiDumpHandler->addHandler($previousHandler);
+ } else {
+ $multiDumpHandler->addHandler($this->getDefaultHandler());
+ }
+
+ $multiDumpHandler->addHandler(function ($var) {
+ (new DumpHandler($this))->dump($var);
+ });
+
+ return $this;
+ }
+
+ public function record(Data $data)
+ {
+ $backtrace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 8);
+ $file = (string)Arr::get($backtrace, '6.file');
+ $lineNumber = (int)Arr::get($backtrace, '6.line');
+
+ if (! Arr::exists($backtrace, '7.class') && (string)Arr::get($backtrace, '7.function') === 'ddd') {
+ $file = (string)Arr::get($backtrace, '7.file');
+ $lineNumber = (int)Arr::get($backtrace, '7.line');
+ }
+
+ $htmlDump = (new HtmlDumper())->dump($data);
+
+ $this->dumps[] = new Dump($htmlDump, $file, $lineNumber);
+ }
+
+ public function getDumps(): array
+ {
+ return $this->toArray();
+ }
+
+ public function reset()
+ {
+ $this->dumps = [];
+ }
+
+ public function toArray(): array
+ {
+ $dumps = [];
+
+ foreach ($this->dumps as $dump) {
+ $dumps[] = $dump->toArray();
+ }
+
+ return $dumps;
+ }
+
+ protected function getDefaultHandler()
+ {
+ return function ($value) {
+ $data = (new VarCloner)->cloneVar($value);
+
+ $this->getDumper()->dump($data);
+ };
+ }
+
+ protected function getDumper()
+ {
+ if (isset($_SERVER['VAR_DUMPER_FORMAT'])) {
+ if ($_SERVER['VAR_DUMPER_FORMAT'] === 'html') {
+ return new BaseHtmlDumper();
+ }
+
+ return new CliDumper();
+ }
+
+ if (in_array(PHP_SAPI, ['cli', 'phpdbg'])) {
+ return new CliDumper() ;
+ }
+
+ return new BaseHtmlDumper();
+ }
+}
diff --git a/vendor/facade/ignition/src/DumpRecorder/HtmlDumper.php b/vendor/facade/ignition/src/DumpRecorder/HtmlDumper.php
new file mode 100644
index 00000000..d4cf0c3f
--- /dev/null
+++ b/vendor/facade/ignition/src/DumpRecorder/HtmlDumper.php
@@ -0,0 +1,29 @@
+cloneVar($variable)->withMaxDepth(3);
+
+ return $this->dump($clonedData);
+ }
+
+ public function dump(Data $data, $output = null, array $extraDisplayOptions = []): string
+ {
+ return (string)parent::dump($data, true, [
+ 'maxDepth' => 3,
+ 'maxStringLength' => 160,
+ ]);
+ }
+}
diff --git a/vendor/facade/ignition/src/DumpRecorder/MultiDumpHandler.php b/vendor/facade/ignition/src/DumpRecorder/MultiDumpHandler.php
new file mode 100644
index 00000000..2902a7f5
--- /dev/null
+++ b/vendor/facade/ignition/src/DumpRecorder/MultiDumpHandler.php
@@ -0,0 +1,23 @@
+handlers as $handler) {
+ $handler($value);
+ }
+ }
+
+ public function addHandler(callable $callable = null): self
+ {
+ $this->handlers[] = $callable;
+
+ return $this;
+ }
+}
diff --git a/vendor/facade/ignition/src/ErrorPage/ErrorPageHandler.php b/vendor/facade/ignition/src/ErrorPage/ErrorPageHandler.php
new file mode 100644
index 00000000..637b84c2
--- /dev/null
+++ b/vendor/facade/ignition/src/ErrorPage/ErrorPageHandler.php
@@ -0,0 +1,77 @@
+flareClient = $app->make(Flare::class);
+ $this->ignitionConfig = $ignitionConfig;
+ $this->renderer = $renderer;
+ $this->solutionProviderRepository = $solutionProviderRepository;
+ }
+
+ public function handle(Throwable $throwable, $defaultTab = null, $defaultTabProps = [])
+ {
+ $report = $this->flareClient->createReport($throwable);
+
+ $solutions = $this->solutionProviderRepository->getSolutionsForThrowable($throwable);
+
+ $viewModel = new ErrorPageViewModel(
+ $throwable,
+ $this->ignitionConfig,
+ $report,
+ $solutions
+ );
+
+ $viewModel->defaultTab($defaultTab, $defaultTabProps);
+
+ $this->renderException($viewModel);
+ }
+
+ public function handleReport(Report $report, $defaultTab = null, $defaultTabProps = [])
+ {
+ $viewModel = new ErrorPageViewModel(
+ $report->getThrowable(),
+ $this->ignitionConfig,
+ $report,
+ []
+ );
+
+ $viewModel->defaultTab($defaultTab, $defaultTabProps);
+
+ $this->renderException($viewModel);
+ }
+
+ protected function renderException(ErrorPageViewModel $exceptionViewModel)
+ {
+ echo $this->renderer->render(
+ 'errorPage',
+ $exceptionViewModel->toArray()
+ );
+ }
+}
diff --git a/vendor/facade/ignition/src/ErrorPage/ErrorPageViewModel.php b/vendor/facade/ignition/src/ErrorPage/ErrorPageViewModel.php
new file mode 100644
index 00000000..768b3a53
--- /dev/null
+++ b/vendor/facade/ignition/src/ErrorPage/ErrorPageViewModel.php
@@ -0,0 +1,189 @@
+throwable = $throwable;
+
+ $this->ignitionConfig = $ignitionConfig;
+
+ $this->report = $report;
+
+ $this->solutions = $solutions;
+ }
+
+ public function throwableString(): string
+ {
+ if (! $this->throwable) {
+ return '';
+ }
+
+ $throwableString = sprintf(
+ "%s: %s in file %s on line %d\n\n%s\n",
+ get_class($this->throwable),
+ $this->throwable->getMessage(),
+ $this->throwable->getFile(),
+ $this->throwable->getLine(),
+ $this->report->getThrowable()->getTraceAsString()
+ );
+
+ return htmlspecialchars($throwableString);
+ }
+
+ public function telescopeUrl(): ?string
+ {
+ try {
+ if (! class_exists(Telescope::class)) {
+ return null;
+ }
+
+ if (! count(Telescope::$entriesQueue)) {
+ return null;
+ }
+
+ $telescopeEntry = collect(Telescope::$entriesQueue)->first(function ($entry) {
+ return $entry instanceof IncomingExceptionEntry;
+ });
+
+ if (is_null($telescopeEntry)) {
+ return null;
+ }
+
+ $telescopeEntryId = (string) $telescopeEntry->uuid;
+
+ return url(action([HomeController::class, 'index'])."/exceptions/{$telescopeEntryId}");
+ } catch (Exception $exception) {
+ return null;
+ }
+ }
+
+ public function title(): string
+ {
+ $message = htmlspecialchars($this->report->getMessage());
+
+ return "🧨 {$message}";
+ }
+
+ public function config(): array
+ {
+ return $this->ignitionConfig->toArray();
+ }
+
+ public function solutions(): array
+ {
+ $solutions = [];
+
+ foreach ($this->solutions as $solution) {
+ $solutions[] = (new SolutionTransformer($solution))->toArray();
+ }
+
+ return $solutions;
+ }
+
+ protected function shareEndpoint(): string
+ {
+ try {
+ // use string notation as L5.5 and L5.6 don't support array notation yet
+ return action('\Facade\Ignition\Http\Controllers\ShareReportController');
+ } catch (Exception $exception) {
+ return '';
+ }
+ }
+
+ public function report(): array
+ {
+ return $this->report->toArray();
+ }
+
+ public function jsonEncode($data): string
+ {
+ $jsonOptions = JSON_PARTIAL_OUTPUT_ON_ERROR | JSON_HEX_TAG | JSON_HEX_APOS | JSON_HEX_AMP | JSON_HEX_QUOT;
+
+ return json_encode($data, $jsonOptions);
+ }
+
+ public function getAssetContents(string $asset): string
+ {
+ $assetPath = __DIR__."/../../resources/compiled/{$asset}";
+
+ return file_get_contents($assetPath);
+ }
+
+ public function styles(): array
+ {
+ return array_keys(Ignition::styles());
+ }
+
+ public function scripts(): array
+ {
+ return array_keys(Ignition::scripts());
+ }
+
+ public function tabs(): string
+ {
+ return json_encode(Ignition::$tabs);
+ }
+
+ public function defaultTab(?string $defaultTab, ?array $defaultTabProps)
+ {
+ $this->defaultTab = $defaultTab ?? 'StackTab';
+
+ if ($defaultTabProps) {
+ $this->defaultTabProps = $defaultTabProps;
+ }
+ }
+
+ public function toArray(): array
+ {
+ return [
+ 'throwableString' => $this->throwableString(),
+ 'telescopeUrl' => $this->telescopeUrl(),
+ 'shareEndpoint' => $this->shareEndpoint(),
+ 'title' => $this->title(),
+ 'config' => $this->config(),
+ 'solutions' => $this->solutions(),
+ 'report' => $this->report(),
+ 'housekeepingEndpoint' => url(config('ignition.housekeeping_endpoint_prefix', '_ignition')),
+ 'styles' => $this->styles(),
+ 'scripts' => $this->scripts(),
+ 'tabs' => $this->tabs(),
+ 'jsonEncode' => Closure::fromCallable([$this, 'jsonEncode']),
+ 'getAssetContents' => Closure::fromCallable([$this, 'getAssetContents']),
+ 'defaultTab' => $this->defaultTab,
+ 'defaultTabProps' => $this->defaultTabProps,
+ ];
+ }
+}
diff --git a/vendor/facade/ignition/src/ErrorPage/IgnitionWhoopsHandler.php b/vendor/facade/ignition/src/ErrorPage/IgnitionWhoopsHandler.php
new file mode 100644
index 00000000..fda4d5c9
--- /dev/null
+++ b/vendor/facade/ignition/src/ErrorPage/IgnitionWhoopsHandler.php
@@ -0,0 +1,48 @@
+errorPageHandler = $errorPageHandler;
+ }
+
+ public function handle(): ?int
+ {
+ try {
+ $this->errorPageHandler->handle($this->exception);
+ } catch (Error $error) {
+ // Errors aren't caught by Whoops.
+ // Convert the error to an exception and throw again.
+
+ throw new ErrorException(
+ $error->getMessage(),
+ $error->getCode(),
+ 1,
+ $error->getFile(),
+ $error->getLine(),
+ $error
+ );
+ }
+
+ return Handler::QUIT;
+ }
+
+ /** @param \Throwable $exception */
+ public function setException($exception): void
+ {
+ $this->exception = $exception;
+ }
+}
diff --git a/vendor/facade/ignition/src/ErrorPage/Renderer.php b/vendor/facade/ignition/src/ErrorPage/Renderer.php
new file mode 100644
index 00000000..9141f1cc
--- /dev/null
+++ b/vendor/facade/ignition/src/ErrorPage/Renderer.php
@@ -0,0 +1,43 @@
+viewPath = $this->formatPath($viewPath);
+ }
+
+ public function render(string $viewName, array $_data): string
+ {
+ ob_start();
+
+ $viewFile = "{$this->viewPath}/{$viewName}.php";
+
+ try {
+ extract((array) $_data, EXTR_OVERWRITE);
+
+ include $viewFile;
+ } catch (Exception $exception) {
+ $viewException = new ViewException($exception->getMessage());
+ $viewException->setView($viewFile);
+ $viewException->setViewData($_data);
+
+ throw $viewException;
+ }
+
+ return ob_get_clean();
+ }
+
+ protected function formatPath(string $path): string
+ {
+ return preg_replace('/(?:\/)+$/u', '', $path).'/';
+ }
+}
diff --git a/vendor/facade/ignition/src/Exceptions/InvalidConfig.php b/vendor/facade/ignition/src/Exceptions/InvalidConfig.php
new file mode 100644
index 00000000..e48a2812
--- /dev/null
+++ b/vendor/facade/ignition/src/Exceptions/InvalidConfig.php
@@ -0,0 +1,29 @@
+setSolutionDescription("Please change the log level in your `config/logging.php` file. Valid log levels are {$validLogLevelsString}.");
+ }
+}
diff --git a/vendor/facade/ignition/src/Exceptions/UnableToShareErrorException.php b/vendor/facade/ignition/src/Exceptions/UnableToShareErrorException.php
new file mode 100644
index 00000000..408bdefe
--- /dev/null
+++ b/vendor/facade/ignition/src/Exceptions/UnableToShareErrorException.php
@@ -0,0 +1,9 @@
+viewData = $data;
+ }
+
+ public function getViewData(): array
+ {
+ return $this->viewData;
+ }
+
+ public function setView(string $path)
+ {
+ $this->view = $path;
+ }
+
+ protected function dumpViewData($variable): string
+ {
+ return (new HtmlDumper())->dumpVariable($variable);
+ }
+
+ public function context(): array
+ {
+ $context = [
+ 'view' => [
+ 'view' => $this->view,
+ ],
+ ];
+
+ if (config('flare.reporting.report_view_data')) {
+ $context['view']['data'] = array_map([$this, 'dumpViewData'], $this->viewData);
+ }
+
+ return $context;
+ }
+}
diff --git a/vendor/facade/ignition/src/Exceptions/ViewExceptionWithSolution.php b/vendor/facade/ignition/src/Exceptions/ViewExceptionWithSolution.php
new file mode 100644
index 00000000..96319aaf
--- /dev/null
+++ b/vendor/facade/ignition/src/Exceptions/ViewExceptionWithSolution.php
@@ -0,0 +1,22 @@
+solution = $solution;
+ }
+
+ public function getSolution(): Solution
+ {
+ return $this->solution;
+ }
+}
diff --git a/vendor/facade/ignition/src/Facades/Flare.php b/vendor/facade/ignition/src/Facades/Flare.php
new file mode 100644
index 00000000..1999e967
--- /dev/null
+++ b/vendor/facade/ignition/src/Facades/Flare.php
@@ -0,0 +1,22 @@
+getRunnableSolution();
+
+ $solution->run($request->get('parameters', []));
+
+ return response('');
+ }
+}
diff --git a/vendor/facade/ignition/src/Http/Controllers/HealthCheckController.php b/vendor/facade/ignition/src/Http/Controllers/HealthCheckController.php
new file mode 100644
index 00000000..fb4082a8
--- /dev/null
+++ b/vendor/facade/ignition/src/Http/Controllers/HealthCheckController.php
@@ -0,0 +1,25 @@
+ $this->canExecuteCommands(),
+ ];
+ }
+
+ protected function canExecuteCommands(): bool
+ {
+ Artisan::call('help', ['--version']);
+
+ $output = Artisan::output();
+
+ return Str::contains($output, app()->version());
+ }
+}
diff --git a/vendor/facade/ignition/src/Http/Controllers/ScriptController.php b/vendor/facade/ignition/src/Http/Controllers/ScriptController.php
new file mode 100644
index 00000000..ccb70fef
--- /dev/null
+++ b/vendor/facade/ignition/src/Http/Controllers/ScriptController.php
@@ -0,0 +1,20 @@
+script]
+ ),
+ 200,
+ ['Content-Type' => 'application/javascript']
+ );
+ }
+}
diff --git a/vendor/facade/ignition/src/Http/Controllers/ShareReportController.php b/vendor/facade/ignition/src/Http/Controllers/ShareReportController.php
new file mode 100644
index 00000000..a56ae405
--- /dev/null
+++ b/vendor/facade/ignition/src/Http/Controllers/ShareReportController.php
@@ -0,0 +1,19 @@
+handle(json_decode($request->get('report'), true), $request->get('tabs'), $request->get('lineSelection'));
+ } catch (UnableToShareErrorException $exception) {
+ abort(500, 'Unable to share the error '.$exception->getMessage());
+ }
+ }
+}
diff --git a/vendor/facade/ignition/src/Http/Controllers/StyleController.php b/vendor/facade/ignition/src/Http/Controllers/StyleController.php
new file mode 100644
index 00000000..1bcfecdf
--- /dev/null
+++ b/vendor/facade/ignition/src/Http/Controllers/StyleController.php
@@ -0,0 +1,18 @@
+style]),
+ 200,
+ ['Content-Type' => 'text/css']
+ );
+ }
+}
diff --git a/vendor/facade/ignition/src/Http/Middleware/IgnitionConfigValueEnabled.php b/vendor/facade/ignition/src/Http/Middleware/IgnitionConfigValueEnabled.php
new file mode 100644
index 00000000..c9293121
--- /dev/null
+++ b/vendor/facade/ignition/src/Http/Middleware/IgnitionConfigValueEnabled.php
@@ -0,0 +1,27 @@
+ignitionConfig = $ignitionConfig;
+ }
+
+ public function handle(Request $request, Closure $next, string $value)
+ {
+ if (! $this->ignitionConfig->toArray()[$value]) {
+ abort(404);
+ }
+
+ return $next($request);
+ }
+}
diff --git a/vendor/facade/ignition/src/Http/Middleware/IgnitionEnabled.php b/vendor/facade/ignition/src/Http/Middleware/IgnitionEnabled.php
new file mode 100644
index 00000000..25a0926e
--- /dev/null
+++ b/vendor/facade/ignition/src/Http/Middleware/IgnitionEnabled.php
@@ -0,0 +1,30 @@
+ignitionEnabled()) {
+ abort(404);
+ }
+
+ return $next($request);
+ }
+
+ protected function ignitionEnabled(): bool
+ {
+ return config('app.debug');
+ }
+}
diff --git a/vendor/facade/ignition/src/Http/Requests/ExecuteSolutionRequest.php b/vendor/facade/ignition/src/Http/Requests/ExecuteSolutionRequest.php
new file mode 100644
index 00000000..28d46c7f
--- /dev/null
+++ b/vendor/facade/ignition/src/Http/Requests/ExecuteSolutionRequest.php
@@ -0,0 +1,41 @@
+ 'required',
+ 'parameters' => 'array',
+ ];
+ }
+
+ public function getSolution(): Solution
+ {
+ $solution = app(SolutionProviderRepository::class)
+ ->getSolutionForClass($this->get('solution'));
+
+ abort_if(is_null($solution), 404, 'Solution could not be found');
+
+ /** @var Solution */
+ return $solution;
+ }
+
+ public function getRunnableSolution(): RunnableSolution
+ {
+ $solution = $this->getSolution();
+
+ if (! $solution instanceof RunnableSolution) {
+ abort(404, 'Runnable solution could not be found');
+ }
+
+ return $solution;
+ }
+}
diff --git a/vendor/facade/ignition/src/Http/Requests/ShareReportRequest.php b/vendor/facade/ignition/src/Http/Requests/ShareReportRequest.php
new file mode 100644
index 00000000..11363e6b
--- /dev/null
+++ b/vendor/facade/ignition/src/Http/Requests/ShareReportRequest.php
@@ -0,0 +1,17 @@
+ 'required',
+ 'tabs' => 'required|array|min:1',
+ 'lineSelection' => [],
+ ];
+ }
+}
diff --git a/vendor/facade/ignition/src/Ignition.php b/vendor/facade/ignition/src/Ignition.php
new file mode 100644
index 00000000..4bebaf4b
--- /dev/null
+++ b/vendor/facade/ignition/src/Ignition.php
@@ -0,0 +1,43 @@
+flatMap(function ($tab) {
+ return $tab->styles;
+ })
+ ->unique()
+ ->toArray();
+ }
+
+ public static function scripts(): array
+ {
+ return collect(static::$tabs)->flatMap(function ($tab) {
+ return $tab->scripts;
+ })
+ ->unique()
+ ->toArray();
+ }
+
+ public static function registerAssets(Closure $callable)
+ {
+ static::$callBeforeShowingErrorPage[] = $callable;
+ }
+}
diff --git a/vendor/facade/ignition/src/IgnitionConfig.php b/vendor/facade/ignition/src/IgnitionConfig.php
new file mode 100644
index 00000000..d6304cd5
--- /dev/null
+++ b/vendor/facade/ignition/src/IgnitionConfig.php
@@ -0,0 +1,75 @@
+options = $this->mergeWithDefaultConfig($options);
+ }
+
+ public function getEditor(): ?string
+ {
+ return Arr::get($this->options, 'editor');
+ }
+
+ public function getRemoteSitesPath(): ?string
+ {
+ return Arr::get($this->options, 'remote_sites_path');
+ }
+
+ public function getLocalSitesPath(): ?string
+ {
+ return Arr::get($this->options, 'local_sites_path');
+ }
+
+ public function getTheme(): ?string
+ {
+ return Arr::get($this->options, 'theme');
+ }
+
+ public function getEnableShareButton(): bool
+ {
+ if (! app()->isBooted()) {
+ return false;
+ }
+
+ return Arr::get($this->options, 'enable_share_button', true);
+ }
+
+ public function getEnableRunnableSolutions(): bool
+ {
+ $enabled = Arr::get($this->options, 'enable_runnable_solutions', null);
+
+ if ($enabled === null) {
+ $enabled = config('app.debug');
+ }
+
+ return $enabled ?? false;
+ }
+
+ public function toArray(): array
+ {
+ return [
+ 'editor' => $this->getEditor(),
+ 'remoteSitesPath' => $this->getRemoteSitesPath(),
+ 'localSitesPath' => $this->getLocalSitesPath(),
+ 'theme' => $this->getTheme(),
+ 'enableShareButton' => $this->getEnableShareButton(),
+ 'enableRunnableSolutions' => $this->getEnableRunnableSolutions(),
+ 'directorySeparator' => DIRECTORY_SEPARATOR,
+ ];
+ }
+
+ protected function mergeWithDefaultConfig(array $options = []): array
+ {
+ return array_merge(config('ignition') ?: include __DIR__.'/../config/ignition.php', $options);
+ }
+}
diff --git a/vendor/facade/ignition/src/IgnitionServiceProvider.php b/vendor/facade/ignition/src/IgnitionServiceProvider.php
new file mode 100644
index 00000000..5f5bbe06
--- /dev/null
+++ b/vendor/facade/ignition/src/IgnitionServiceProvider.php
@@ -0,0 +1,472 @@
+app->runningInConsole()) {
+ $this->publishes([
+ __DIR__.'/../config/flare.php' => config_path('flare.php'),
+ ], 'flare-config');
+
+ $this->publishes([
+ __DIR__.'/../config/ignition.php' => config_path('ignition.php'),
+ ], 'ignition-config');
+
+ if (isset($_SERVER['argv']) && ['artisan', 'tinker'] === $_SERVER['argv']) {
+ Api::sendReportsInBatches(false);
+ }
+ }
+
+ $this
+ ->registerViewEngines()
+ ->registerHousekeepingRoutes()
+ ->registerLogHandler()
+ ->registerCommands();
+
+ if ($this->app->bound('queue')) {
+ $this->setupQueue($this->app->get('queue'));
+ }
+
+ if (config('flare.reporting.report_logs')) {
+ $this->app->make(LogRecorder::class)->register();
+ }
+
+ if (config('flare.reporting.report_queries')) {
+ $this->app->make(QueryRecorder::class)->register();
+ }
+
+ $this->app->make(DumpRecorder::class)->register();
+ }
+
+ public function register()
+ {
+ $this->mergeConfigFrom(__DIR__.'/../config/flare.php', 'flare');
+ $this->mergeConfigFrom(__DIR__.'/../config/ignition.php', 'ignition');
+
+ $this
+ ->registerSolutionProviderRepository()
+ ->registerExceptionRenderer()
+ ->registerWhoopsHandler()
+ ->registerIgnitionConfig()
+ ->registerFlare()
+ ->registerDumpCollector();
+
+ if (config('flare.reporting.report_logs')) {
+ $this->registerLogRecorder();
+ }
+
+ if (config('flare.reporting.report_queries')) {
+ $this->registerQueryRecorder();
+ }
+
+ if (config('flare.reporting.anonymize_ips')) {
+ $this->app->get(Flare::class)->anonymizeIp();
+ }
+
+ $this->registerBuiltInMiddleware();
+ }
+
+ protected function registerViewEngines()
+ {
+ if (! $this->hasCustomViewEnginesRegistered()) {
+ return $this;
+ }
+
+ $this->app->make('view.engine.resolver')->register('php', function () {
+ return new PhpEngine($this->app['files']);
+ });
+
+ $this->app->make('view.engine.resolver')->register('blade', function () {
+ if (class_exists(\Livewire\CompilerEngineForIgnition::class)) {
+ return new \Livewire\CompilerEngineForIgnition($this->app['blade.compiler']);
+ }
+
+ return new CompilerEngine($this->app['blade.compiler']);
+ });
+
+ return $this;
+ }
+
+ protected function registerHousekeepingRoutes()
+ {
+ if ($this->app->runningInConsole()) {
+ return $this;
+ }
+
+ Route::group([
+ 'as' => 'ignition.',
+ 'prefix' => config('ignition.housekeeping_endpoint_prefix', '_ignition'),
+ 'middleware' => [IgnitionEnabled::class],
+ ], function () {
+ Route::get('health-check', HealthCheckController::class)->name('healthCheck');
+
+ Route::post('execute-solution', ExecuteSolutionController::class)
+ ->middleware(IgnitionConfigValueEnabled::class.':enableRunnableSolutions')
+ ->name('executeSolution');
+
+ Route::post('share-report', ShareReportController::class)
+ ->middleware(IgnitionConfigValueEnabled::class.':enableShareButton')
+ ->name('shareReport');
+
+ Route::get('scripts/{script}', ScriptController::class)->name('scripts');
+ Route::get('styles/{style}', StyleController::class)->name('styles');
+ });
+
+ return $this;
+ }
+
+ protected function registerSolutionProviderRepository()
+ {
+ $this->app->singleton(SolutionProviderRepositoryContract::class, function () {
+ $defaultSolutions = $this->getDefaultSolutions();
+
+ return new SolutionProviderRepository($defaultSolutions);
+ });
+
+ return $this;
+ }
+
+ protected function registerExceptionRenderer()
+ {
+ $this->app->bind(Renderer::class, function () {
+ return new Renderer(__DIR__.'/../resources/views/');
+ });
+
+ return $this;
+ }
+
+ protected function registerWhoopsHandler()
+ {
+ $this->app->bind(HandlerInterface::class, function (Application $app) {
+ return $app->make(IgnitionWhoopsHandler::class);
+ });
+
+ return $this;
+ }
+
+ protected function registerIgnitionConfig()
+ {
+ $this->app->singleton(IgnitionConfig::class, function () {
+ $options = [];
+
+ try {
+ if ($configPath = $this->getConfigFileLocation()) {
+ $options = require $configPath;
+ }
+ } catch (Throwable $e) {
+ // possible open_basedir restriction
+ }
+
+ return new IgnitionConfig($options);
+ });
+
+ return $this;
+ }
+
+ protected function registerFlare()
+ {
+ $this->app->singleton('flare.http', function () {
+ return new Client(
+ config('flare.key'),
+ config('flare.secret'),
+ config('flare.base_url', 'https://flareapp.io/api')
+ );
+ });
+
+ $this->app->alias('flare.http', Client::class);
+
+ $this->app->singleton(Flare::class, function () {
+ $client = new Flare($this->app->get('flare.http'), new LaravelContextDetector, $this->app);
+ $client->applicationPath(base_path());
+ $client->stage(config('app.env'));
+
+ return $client;
+ });
+
+ return $this;
+ }
+
+ protected function registerLogHandler()
+ {
+ $this->app->singleton('flare.logger', function ($app) {
+ $handler = new FlareHandler($app->make(Flare::class));
+
+ $logLevelString = config('logging.channels.flare.level', 'error');
+
+ $logLevel = $this->getLogLevel($logLevelString);
+
+ $handler->setMinimumReportLogLevel($logLevel);
+
+ $logger = new Logger('Flare');
+ $logger->pushHandler($handler);
+
+ return $logger;
+ });
+
+ if ($this->app['log'] instanceof LogManager) {
+ Log::extend('flare', function ($app) {
+ return $app['flare.logger'];
+ });
+ } else {
+ $this->bindLogListener();
+ }
+
+ return $this;
+ }
+
+ protected function getLogLevel(string $logLevelString): int
+ {
+ $logLevel = Logger::getLevels()[strtoupper($logLevelString)] ?? null;
+
+ if (! $logLevel) {
+ throw InvalidConfig::invalidLogLevel($logLevelString);
+ }
+
+ return $logLevel;
+ }
+
+ protected function registerLogRecorder(): self
+ {
+ $this->app->singleton(LogRecorder::class, function (Application $app): LogRecorder {
+ return new LogRecorder(
+ $app,
+ $app->get('config')->get('flare.reporting.maximum_number_of_collected_logs')
+ );
+ });
+
+ return $this;
+ }
+
+ protected function registerDumpCollector()
+ {
+ $dumpCollector = $this->app->make(DumpRecorder::class);
+
+ $this->app->singleton(DumpRecorder::class);
+
+ $this->app->instance(DumpRecorder::class, $dumpCollector);
+
+ return $this;
+ }
+
+ protected function registerCommands()
+ {
+ $this->app->bind('command.flare:test', TestCommand::class);
+ $this->app->bind('command.make:solution', SolutionMakeCommand::class);
+ $this->app->bind('command.make:solution-provider', SolutionProviderMakeCommand::class);
+
+ if ($this->app['config']->get('flare.key')) {
+ $this->commands(['command.flare:test']);
+ }
+
+ if ($this->app['config']->get('ignition.register_commands', false)) {
+ $this->commands(['command.make:solution']);
+ $this->commands(['command.make:solution-provider']);
+ }
+
+ return $this;
+ }
+
+ protected function registerQueryRecorder(): self
+ {
+ $this->app->singleton(QueryRecorder::class, function (Application $app): QueryRecorder {
+ return new QueryRecorder(
+ $app,
+ $app->get('config')->get('flare.reporting.report_query_bindings'),
+ $app->get('config')->get('flare.reporting.maximum_number_of_collected_queries')
+ );
+ });
+
+ return $this;
+ }
+
+ protected function registerBuiltInMiddleware()
+ {
+ $middlewares = [
+ SetNotifierName::class,
+ AddEnvironmentInformation::class,
+ ];
+
+ if (config('flare.reporting.report_logs')) {
+ $middlewares[] = AddLogs::class;
+ }
+
+ $middlewares[] = AddDumps::class;
+
+ if (config('flare.reporting.report_queries')) {
+ $middlewares[] = AddQueries::class;
+ }
+
+ $middlewares[] = AddSolutions::class;
+
+ $middleware = collect($middlewares)
+ ->map(function (string $middlewareClass) {
+ return $this->app->make($middlewareClass);
+ });
+
+ if (config('flare.reporting.collect_git_information')) {
+ $middleware[] = (new AddGitInformation());
+ }
+
+ foreach ($middleware as $singleMiddleware) {
+ $this->app->get(Flare::class)->registerMiddleware($singleMiddleware);
+ }
+
+ return $this;
+ }
+
+ protected function getDefaultSolutions(): array
+ {
+ return [
+ IncorrectValetDbCredentialsSolutionProvider::class,
+ MissingAppKeySolutionProvider::class,
+ DefaultDbNameSolutionProvider::class,
+ BadMethodCallSolutionProvider::class,
+ TableNotFoundSolutionProvider::class,
+ MissingImportSolutionProvider::class,
+ MissingPackageSolutionProvider::class,
+ InvalidRouteActionSolutionProvider::class,
+ ViewNotFoundSolutionProvider::class,
+ UndefinedVariableSolutionProvider::class,
+ MergeConflictSolutionProvider::class,
+ RunningLaravelDuskInProductionProvider::class,
+ MissingColumnSolutionProvider::class,
+ UnknownValidationSolutionProvider::class,
+ UndefinedPropertySolutionProvider::class,
+ MissingMixManifestSolutionProvider::class,
+ MissingLivewireComponentSolutionProvider::class,
+ ];
+ }
+
+ protected function hasCustomViewEnginesRegistered()
+ {
+ $resolver = $this->app->make('view.engine.resolver');
+
+ if (! $resolver->resolve('php') instanceof LaravelPhpEngine) {
+ return false;
+ }
+
+ if (! $resolver->resolve('blade') instanceof LaravelCompilerEngine) {
+ return false;
+ }
+
+ return true;
+ }
+
+ protected function bindLogListener()
+ {
+ $this->app['log']->listen(function (MessageLogged $messageLogged) {
+ if (config('flare.key')) {
+ try {
+ $this->app['flare.logger']->log(
+ $messageLogged->level,
+ $messageLogged->message,
+ $messageLogged->context
+ );
+ } catch (Exception $exception) {
+ return;
+ }
+ }
+ });
+ }
+
+ protected function getConfigFileLocation(): ?string
+ {
+ $configFullPath = base_path().DIRECTORY_SEPARATOR.'.ignition';
+
+ if (file_exists($configFullPath)) {
+ return $configFullPath;
+ }
+
+ $configFullPath = Arr::get($_SERVER, 'HOME', '').DIRECTORY_SEPARATOR.'.ignition';
+
+ if (file_exists($configFullPath)) {
+ return $configFullPath;
+ }
+
+ return null;
+ }
+
+ protected function setupQueue(QueueManager $queue)
+ {
+ $queue->looping(function () {
+ $this->app->get(Flare::class)->reset();
+
+ if (config('flare.reporting.report_logs')) {
+ $this->app->make(LogRecorder::class)->reset();
+ }
+
+ if (config('flare.reporting.report_queries')) {
+ $this->app->make(QueryRecorder::class)->reset();
+ }
+
+ $this->app->make(DumpRecorder::class)->reset();
+ });
+ }
+}
diff --git a/vendor/facade/ignition/src/LogRecorder/LogMessage.php b/vendor/facade/ignition/src/LogRecorder/LogMessage.php
new file mode 100644
index 00000000..faf55be9
--- /dev/null
+++ b/vendor/facade/ignition/src/LogRecorder/LogMessage.php
@@ -0,0 +1,47 @@
+message = $message;
+ $this->level = $level;
+ $this->context = $context;
+ $this->microtime = $microtime ?? microtime(true);
+ }
+
+ public static function fromMessageLoggedEvent(MessageLogged $event): self
+ {
+ return new self(
+ $event->message,
+ $event->level,
+ $event->context
+ );
+ }
+
+ public function toArray()
+ {
+ return [
+ 'message' => $this->message,
+ 'level' => $this->level,
+ 'context' => $this->context,
+ 'microtime' => $this->microtime,
+ ];
+ }
+}
diff --git a/vendor/facade/ignition/src/LogRecorder/LogRecorder.php b/vendor/facade/ignition/src/LogRecorder/LogRecorder.php
new file mode 100644
index 00000000..31b3706e
--- /dev/null
+++ b/vendor/facade/ignition/src/LogRecorder/LogRecorder.php
@@ -0,0 +1,91 @@
+app = $app;
+ $this->maxLogs = $maxLogs;
+ }
+
+ public function register(): self
+ {
+ $this->app['events']->listen(MessageLogged::class, [$this, 'record']);
+
+ return $this;
+ }
+
+ public function record(MessageLogged $event): void
+ {
+ if ($this->shouldIgnore($event)) {
+ return;
+ }
+
+ $this->logMessages[] = LogMessage::fromMessageLoggedEvent($event);
+
+ if (is_int($this->maxLogs)) {
+ $this->logMessages = array_slice($this->logMessages, -$this->maxLogs);
+ }
+ }
+
+ public function getLogMessages(): array
+ {
+ return $this->toArray();
+ }
+
+ public function toArray(): array
+ {
+ $logMessages = [];
+
+ foreach ($this->logMessages as $log) {
+ $logMessages[] = $log->toArray();
+ }
+
+ return $logMessages;
+ }
+
+ protected function shouldIgnore($event): bool
+ {
+ if (! isset($event->context['exception'])) {
+ return false;
+ }
+
+ if (! $event->context['exception'] instanceof Throwable) {
+ return false;
+ }
+
+ return true;
+ }
+
+ public function reset(): void
+ {
+ $this->logMessages = [];
+ }
+
+ public function getMaxLogs(): ?int
+ {
+ return $this->maxLogs;
+ }
+
+ public function setMaxLogs(?int $maxLogs): self
+ {
+ $this->maxLogs = $maxLogs;
+
+ return $this;
+ }
+}
diff --git a/vendor/facade/ignition/src/Logger/FlareHandler.php b/vendor/facade/ignition/src/Logger/FlareHandler.php
new file mode 100644
index 00000000..acb26f8b
--- /dev/null
+++ b/vendor/facade/ignition/src/Logger/FlareHandler.php
@@ -0,0 +1,87 @@
+flare = $flare;
+
+ parent::__construct($level, $bubble);
+ }
+
+ public function setMinimumReportLogLevel(int $level)
+ {
+ if (! in_array($level, Logger::getLevels())) {
+ throw new \InvalidArgumentException('The given minimum log level is not supported.');
+ }
+
+ $this->minimumReportLogLevel = $level;
+ }
+
+ protected function write(array $report): void
+ {
+ if (! $this->shouldReport($report)) {
+ return;
+ }
+
+ if ($this->hasException($report)) {
+ /** @var Throwable $throwable */
+ $throwable = $report['context']['exception'];
+
+ collect(Ignition::$tabs)
+ ->each(function (Tab $tab) use ($throwable) {
+ $tab->beforeRenderingErrorPage($this->flare, $throwable);
+ });
+
+ $this->flare->report($report['context']['exception']);
+
+ return;
+ }
+
+ if (config('flare.send_logs_as_events')) {
+ if ($this->hasValidLogLevel($report)) {
+ $this->flare->reportMessage(
+ $report['message'],
+ 'Log ' . Logger::getLevelName($report['level']),
+ function (Report $flareReport) use ($report) {
+ foreach ($report['context'] as $key => $value) {
+ $flareReport->context($key, $value);
+ }
+ }
+ );
+ }
+ }
+ }
+
+ protected function shouldReport(array $report): bool
+ {
+ return $this->hasException($report) || $this->hasValidLogLevel($report);
+ }
+
+ protected function hasException(array $report): bool
+ {
+ $context = $report['context'];
+
+ return isset($context['exception']) && $context['exception'] instanceof Throwable;
+ }
+
+ protected function hasValidLogLevel(array $report): bool
+ {
+ return $report['level'] >= $this->minimumReportLogLevel;
+ }
+}
diff --git a/vendor/facade/ignition/src/Middleware/AddDumps.php b/vendor/facade/ignition/src/Middleware/AddDumps.php
new file mode 100644
index 00000000..8afffa6f
--- /dev/null
+++ b/vendor/facade/ignition/src/Middleware/AddDumps.php
@@ -0,0 +1,24 @@
+dumpRecorder = $dumpRecorder;
+ }
+
+ public function handle(Report $report, $next)
+ {
+ $report->group('dumps', $this->dumpRecorder->getDumps());
+
+ return $next($report);
+ }
+}
diff --git a/vendor/facade/ignition/src/Middleware/AddEnvironmentInformation.php b/vendor/facade/ignition/src/Middleware/AddEnvironmentInformation.php
new file mode 100644
index 00000000..ed74ab63
--- /dev/null
+++ b/vendor/facade/ignition/src/Middleware/AddEnvironmentInformation.php
@@ -0,0 +1,22 @@
+frameworkVersion(app()->version());
+
+ $report->group('env', [
+ 'laravel_version' => app()->version(),
+ 'laravel_locale' => app()->getLocale(),
+ 'laravel_config_cached' => app()->configurationIsCached(),
+ 'php_version' => phpversion(),
+ ]);
+
+ return $next($report);
+ }
+}
diff --git a/vendor/facade/ignition/src/Middleware/AddGitInformation.php b/vendor/facade/ignition/src/Middleware/AddGitInformation.php
new file mode 100644
index 00000000..b767c38d
--- /dev/null
+++ b/vendor/facade/ignition/src/Middleware/AddGitInformation.php
@@ -0,0 +1,58 @@
+group('git', [
+ 'hash' => $this->hash(),
+ 'message' => $this->message(),
+ 'tag' => $this->tag(),
+ 'remote' => $this->remote(),
+ 'isDirty' => ! $this->isClean(),
+ ]);
+
+ return $next($report);
+ }
+
+ public function hash(): ?string
+ {
+ return $this->command("git log --pretty=format:'%H' -n 1");
+ }
+
+ public function message(): ?string
+ {
+ return $this->command("git log --pretty=format:'%s' -n 1");
+ }
+
+ public function tag(): ?string
+ {
+ return $this->command('git describe --tags --abbrev=0');
+ }
+
+ public function remote(): ?string
+ {
+ return $this->command('git config --get remote.origin.url');
+ }
+
+ public function isClean(): bool
+ {
+ return empty($this->command('git status -s'));
+ }
+
+ protected function command($command)
+ {
+ $process = (new \ReflectionClass(Process::class))->hasMethod('fromShellCommandline')
+ ? Process::fromShellCommandline($command, base_path())
+ : new Process($command, base_path());
+
+ $process->run();
+
+ return trim($process->getOutput());
+ }
+}
diff --git a/vendor/facade/ignition/src/Middleware/AddLogs.php b/vendor/facade/ignition/src/Middleware/AddLogs.php
new file mode 100644
index 00000000..ea1d320c
--- /dev/null
+++ b/vendor/facade/ignition/src/Middleware/AddLogs.php
@@ -0,0 +1,24 @@
+logRecorder = $logRecorder;
+ }
+
+ public function handle(Report $report, $next)
+ {
+ $report->group('logs', $this->logRecorder->getLogMessages());
+
+ return $next($report);
+ }
+}
diff --git a/vendor/facade/ignition/src/Middleware/AddQueries.php b/vendor/facade/ignition/src/Middleware/AddQueries.php
new file mode 100644
index 00000000..f55094fe
--- /dev/null
+++ b/vendor/facade/ignition/src/Middleware/AddQueries.php
@@ -0,0 +1,24 @@
+queryRecorder = $queryRecorder;
+ }
+
+ public function handle(Report $report, $next)
+ {
+ $report->group('queries', $this->queryRecorder->getQueries());
+
+ return $next($report);
+ }
+}
diff --git a/vendor/facade/ignition/src/Middleware/AddSolutions.php b/vendor/facade/ignition/src/Middleware/AddSolutions.php
new file mode 100644
index 00000000..e0dc7ec6
--- /dev/null
+++ b/vendor/facade/ignition/src/Middleware/AddSolutions.php
@@ -0,0 +1,30 @@
+solutionProviderRepository = $solutionProviderRepository;
+ }
+
+ public function handle(Report $report, $next)
+ {
+ if ($throwable = $report->getThrowable()) {
+ $solutions = $this->solutionProviderRepository->getSolutionsForThrowable($throwable);
+
+ foreach ($solutions as $solution) {
+ $report->addSolution($solution);
+ }
+ }
+
+ return $next($report);
+ }
+}
diff --git a/vendor/facade/ignition/src/Middleware/SetNotifierName.php b/vendor/facade/ignition/src/Middleware/SetNotifierName.php
new file mode 100644
index 00000000..943fd3f4
--- /dev/null
+++ b/vendor/facade/ignition/src/Middleware/SetNotifierName.php
@@ -0,0 +1,17 @@
+notifierName(static::NOTIFIER_NAME);
+
+ return $next($report);
+ }
+}
diff --git a/vendor/facade/ignition/src/QueryRecorder/Query.php b/vendor/facade/ignition/src/QueryRecorder/Query.php
new file mode 100644
index 00000000..98885759
--- /dev/null
+++ b/vendor/facade/ignition/src/QueryRecorder/Query.php
@@ -0,0 +1,58 @@
+sql,
+ $queryExecuted->time,
+ $queryExecuted->connectionName ?? '',
+ $reportBindings ? $queryExecuted->bindings : null
+ );
+ }
+
+ protected function __construct(
+ string $sql,
+ float $time,
+ string $connectionName,
+ ?array $bindings = null,
+ ?float $microtime = null
+ ) {
+ $this->sql = $sql;
+ $this->time = $time;
+ $this->connectionName = $connectionName;
+ $this->bindings = $bindings;
+ $this->microtime = $microtime ?? microtime(true);
+ }
+
+ public function toArray(): array
+ {
+ return [
+ 'sql' => $this->sql,
+ 'time' => $this->time,
+ 'connection_name' => $this->connectionName,
+ 'bindings' => $this->bindings,
+ 'microtime' => $this->microtime,
+ ];
+ }
+}
diff --git a/vendor/facade/ignition/src/QueryRecorder/QueryRecorder.php b/vendor/facade/ignition/src/QueryRecorder/QueryRecorder.php
new file mode 100644
index 00000000..423d67c7
--- /dev/null
+++ b/vendor/facade/ignition/src/QueryRecorder/QueryRecorder.php
@@ -0,0 +1,87 @@
+app = $app;
+ $this->reportBindings = $reportBindings;
+ $this->maxQueries = $maxQueries;
+ }
+
+ public function register()
+ {
+ $this->app['events']->listen(QueryExecuted::class, [$this, 'record']);
+
+ return $this;
+ }
+
+ public function record(QueryExecuted $queryExecuted)
+ {
+ $this->queries[] = Query::fromQueryExecutedEvent($queryExecuted, $this->reportBindings);
+
+ if (is_int($this->maxQueries)) {
+ $this->queries = array_slice($this->queries, -$this->maxQueries);
+ }
+ }
+
+ public function getQueries(): array
+ {
+ $queries = [];
+
+ foreach ($this->queries as $query) {
+ $queries[] = $query->toArray();
+ }
+
+ return $queries;
+ }
+
+ public function reset()
+ {
+ $this->queries = [];
+ }
+
+ public function getReportBindings(): bool
+ {
+ return $this->reportBindings;
+ }
+
+ public function setReportBindings(bool $reportBindings): self
+ {
+ $this->reportBindings = $reportBindings;
+
+ return $this;
+ }
+
+ public function getMaxQueries(): ?int
+ {
+ return $this->maxQueries;
+ }
+
+ public function setMaxQueries(?int $maxQueries): self
+ {
+ $this->maxQueries = $maxQueries;
+
+ return $this;
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/BadMethodCallSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/BadMethodCallSolutionProvider.php
new file mode 100644
index 00000000..4aa85871
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/BadMethodCallSolutionProvider.php
@@ -0,0 +1,79 @@
+getClassAndMethodFromExceptionMessage($throwable->getMessage()))) {
+ return false;
+ }
+
+ return true;
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [
+ BaseSolution::create('Bad Method Call')
+ ->setSolutionDescription($this->getSolutionDescription($throwable)),
+ ];
+ }
+
+ public function getSolutionDescription(Throwable $throwable): string
+ {
+ if (! $this->canSolve($throwable)) {
+ return '';
+ }
+
+ extract($this->getClassAndMethodFromExceptionMessage($throwable->getMessage()), EXTR_OVERWRITE);
+
+ $possibleMethod = $this->findPossibleMethod($class, $method);
+
+ return "Did you mean {$class}::{$possibleMethod->name}() ?";
+ }
+
+ protected function getClassAndMethodFromExceptionMessage(string $message): ?array
+ {
+ if (! preg_match(self::REGEX, $message, $matches)) {
+ return null;
+ }
+
+ return [
+ 'class' => $matches[1],
+ 'method' => $matches[2],
+ ];
+ }
+
+ protected function findPossibleMethod(string $class, string $invalidMethodName)
+ {
+ return $this->getAvailableMethods($class)
+ ->sortByDesc(function (ReflectionMethod $method) use ($invalidMethodName) {
+ similar_text($invalidMethodName, $method->name, $percentage);
+
+ return $percentage;
+ })->first();
+ }
+
+ protected function getAvailableMethods($class): Collection
+ {
+ $class = new ReflectionClass($class);
+
+ return Collection::make($class->getMethods());
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/DefaultDbNameSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/DefaultDbNameSolutionProvider.php
new file mode 100644
index 00000000..f15fb366
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/DefaultDbNameSolutionProvider.php
@@ -0,0 +1,35 @@
+getCode() !== self::MYSQL_UNKNOWN_DATABASE_CODE) {
+ return false;
+ }
+
+ if (! in_array(env('DB_DATABASE'), ['homestead', 'laravel'])) {
+ return false;
+ }
+
+ return true;
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [new SuggestUsingCorrectDbNameSolution()];
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/IncorrectValetDbCredentialsSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/IncorrectValetDbCredentialsSolutionProvider.php
new file mode 100644
index 00000000..26798d0c
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/IncorrectValetDbCredentialsSolutionProvider.php
@@ -0,0 +1,67 @@
+isAccessDeniedCode($throwable->getCode())) {
+ return false;
+ }
+
+ if (! $this->envFileExists()) {
+ return false;
+ }
+
+ if (! $this->isValetInstalled()) {
+ return false;
+ }
+
+ if ($this->usingCorrectDefaultCredentials()) {
+ return false;
+ }
+
+ return true;
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [new UseDefaultValetDbCredentialsSolution()];
+ }
+
+ protected function envFileExists(): bool
+ {
+ return file_exists(base_path('.env'));
+ }
+
+ protected function isAccessDeniedCode($code): bool
+ {
+ return $code === static::MYSQL_ACCESS_DENIED_CODE;
+ }
+
+ protected function isValetInstalled(): bool
+ {
+ return file_exists('/usr/local/bin/valet');
+ }
+
+ protected function usingCorrectDefaultCredentials(): bool
+ {
+ return env('DB_USERNAME') === 'root' && env('DB_PASSWORD') === '';
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/InvalidRouteActionSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/InvalidRouteActionSolutionProvider.php
new file mode 100644
index 00000000..605415b3
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/InvalidRouteActionSolutionProvider.php
@@ -0,0 +1,79 @@
+getMessage(), $matches)) {
+ return false;
+ }
+
+ return Str::startsWith($throwable->getMessage(), 'Invalid route action: ');
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ preg_match(self::REGEX, $throwable->getMessage(), $matches);
+
+ $invalidController = $matches[1] ?? null;
+
+ $suggestedController = $this->findRelatedController($invalidController);
+
+ if ($suggestedController === $invalidController) {
+ return [
+ BaseSolution::create("`{$invalidController}` is not invokable.")
+ ->setSolutionDescription("The controller class `{$invalidController}` is not invokable. Did you forget to add the `__invoke` method or is the controller's method missing in your routes file?"),
+ ];
+ }
+
+ if ($suggestedController) {
+ return [
+ BaseSolution::create("`{$invalidController}` was not found.")
+ ->setSolutionDescription("Controller class `{$invalidController}` for one of your routes was not found. Did you mean `{$suggestedController}`?"),
+ ];
+ }
+
+ return [
+ BaseSolution::create("`{$invalidController}` was not found.")
+ ->setSolutionDescription("Controller class `{$invalidController}` for one of your routes was not found. Are you sure this controller exists and is imported correctly?"),
+ ];
+ }
+
+ protected function findRelatedController(string $invalidController): ?string
+ {
+ $composerClassMap = app(ComposerClassMap::class);
+
+ $controllers = collect($composerClassMap->listClasses())
+ ->filter(function (string $file, string $fqcn) {
+ return Str::endsWith($fqcn, 'Controller');
+ })
+ ->mapWithKeys(function (string $file, string $fqcn) {
+ return [$fqcn => class_basename($fqcn)];
+ })
+ ->toArray();
+
+ $basenameMatch = StringComparator::findClosestMatch($controllers, $invalidController, 4);
+
+ $controllers = array_flip($controllers);
+
+ $fqcnMatch = StringComparator::findClosestMatch($controllers, $invalidController, 4);
+
+ return $fqcnMatch ?? $basenameMatch;
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/MergeConflictSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/MergeConflictSolutionProvider.php
new file mode 100644
index 00000000..d667d433
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/MergeConflictSolutionProvider.php
@@ -0,0 +1,75 @@
+hasMergeConflictExceptionMessage($throwable)) {
+ return false;
+ }
+
+ $file = file_get_contents($throwable->getFile());
+
+ if (strpos($file, '=======') === false) {
+ return false;
+ }
+
+ if (strpos($file, '>>>>>>>') === false) {
+ return false;
+ }
+
+ return true;
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ $file = file_get_contents($throwable->getFile());
+ preg_match('/\>\>\>\>\>\>\> (.*?)\n/', $file, $matches);
+ $source = $matches[1];
+
+ $target = $this->getCurrentBranch(basename($throwable->getFile()));
+
+ return [
+ BaseSolution::create("Merge conflict from branch '$source' into $target")
+ ->setSolutionDescription('You have a Git merge conflict. To undo your merge do `git reset --hard HEAD`'),
+ ];
+ }
+
+ protected function getCurrentBranch(string $directory): string
+ {
+ $branch = "'".trim(shell_exec("cd ${directory}; git branch | grep \\* | cut -d ' ' -f2"))."'";
+
+ if (! isset($branch) || $branch === "''") {
+ $branch = 'current branch';
+ }
+
+ return $branch;
+ }
+
+ protected function hasMergeConflictExceptionMessage(Throwable $throwable): bool
+ {
+ // For PHP 7.x and below
+ if (Str::startsWith($throwable->getMessage(), 'syntax error, unexpected \'<<\'')) {
+ return true;
+ }
+
+ // For PHP 8+
+ if (Str::startsWith($throwable->getMessage(), 'syntax error, unexpected token "<<"')) {
+ return true;
+ }
+
+ return false;
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/MissingAppKeySolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/MissingAppKeySolutionProvider.php
new file mode 100644
index 00000000..c0648dca
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/MissingAppKeySolutionProvider.php
@@ -0,0 +1,25 @@
+getMessage() === 'No application encryption key has been specified.';
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [new GenerateAppKeySolution()];
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/MissingColumnSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/MissingColumnSolutionProvider.php
new file mode 100644
index 00000000..c14a93cd
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/MissingColumnSolutionProvider.php
@@ -0,0 +1,35 @@
+isBadTableErrorCode($throwable->getCode());
+ }
+
+ protected function isBadTableErrorCode($code): bool
+ {
+ return $code === static::MYSQL_BAD_FIELD_CODE;
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [new RunMigrationsSolution('A column was not found')];
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/MissingImportSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/MissingImportSolutionProvider.php
new file mode 100644
index 00000000..55aaadc9
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/MissingImportSolutionProvider.php
@@ -0,0 +1,48 @@
+getMessage(), $matches)) {
+ return false;
+ }
+
+ $class = $matches[1];
+
+ $this->composerClassMap = new ComposerClassMap();
+
+ $this->search($class);
+
+ return ! is_null($this->foundClass);
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [new SuggestImportSolution($this->foundClass)];
+ }
+
+ protected function search(string $missingClass)
+ {
+ $this->foundClass = $this->composerClassMap->searchClassMap($missingClass);
+
+ if (is_null($this->foundClass)) {
+ $this->foundClass = $this->composerClassMap->searchPsrMaps($missingClass);
+ }
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/MissingLivewireComponentSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/MissingLivewireComponentSolutionProvider.php
new file mode 100644
index 00000000..bddf8915
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/MissingLivewireComponentSolutionProvider.php
@@ -0,0 +1,42 @@
+livewireIsInstalled()) {
+ return false;
+ }
+
+ if (! $throwable instanceof ComponentNotFoundException) {
+ return false;
+ }
+
+ return true;
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [new LivewireDiscoverSolution('A Livewire component was not found')];
+ }
+
+ public function livewireIsInstalled(): bool
+ {
+ if (! class_exists(ComponentNotFoundException::class)) {
+ return false;
+ }
+ if (! class_exists(LivewireComponentsFinder::class)) {
+ return false;
+ }
+
+ return true;
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/MissingMixManifestSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/MissingMixManifestSolutionProvider.php
new file mode 100644
index 00000000..1f3ac216
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/MissingMixManifestSolutionProvider.php
@@ -0,0 +1,25 @@
+getMessage(), 'The Mix manifest does not exist');
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [
+ BaseSolution::create('Missing Mix Manifest File')
+ ->setSolutionDescription('Did you forget to run `npm install && npm run dev`?'),
+ ];
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/MissingPackageSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/MissingPackageSolutionProvider.php
new file mode 100644
index 00000000..2eed0410
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/MissingPackageSolutionProvider.php
@@ -0,0 +1,58 @@
+getMessage(), $matches)) {
+ return false;
+ }
+
+ $class = $matches[1];
+
+ if (Str::startsWith($class, app()->getNamespace())) {
+ return false;
+ }
+
+ $this->package = $this->findPackageFromClassName($class);
+
+ return ! is_null($this->package);
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [new MissingPackageSolution($this->package)];
+ }
+
+ protected function findPackageFromClassName(string $missingClassName): ?Package
+ {
+ if (! $package = $this->findComposerPackageForClassName($missingClassName)) {
+ return null;
+ }
+
+ return $package->hasNamespaceThatContainsClassName($missingClassName)
+ ? $package
+ : null;
+ }
+
+ protected function findComposerPackageForClassName(string $className): ?Package
+ {
+ $packages = Packagist::findPackagesForClassName($className);
+
+ return $packages[0] ?? null;
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/RouteNotDefinedSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/RouteNotDefinedSolutionProvider.php
new file mode 100644
index 00000000..b866d616
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/RouteNotDefinedSolutionProvider.php
@@ -0,0 +1,63 @@
+=')) {
+ if (! $throwable instanceof RouteNotFoundException) {
+ return false;
+ }
+ }
+
+ if (version_compare(Application::VERSION, '6.0.0', '<')) {
+ if (! $throwable instanceof InvalidArgumentException && ! $throwable instanceof ViewException) {
+ return false;
+ }
+ }
+
+ return (bool)preg_match(self::REGEX, $throwable->getMessage(), $matches);
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ preg_match(self::REGEX, $throwable->getMessage(), $matches);
+
+ $missingRoute = $matches[1] ?? null;
+
+ $suggestedRoute = $this->findRelatedRoute($missingRoute);
+
+ if ($suggestedRoute) {
+ return [
+ BaseSolution::create("{$missingRoute} was not defined.")
+ ->setSolutionDescription("Did you mean `{$suggestedRoute}`?"),
+ ];
+ }
+
+ return [
+ BaseSolution::create("{$missingRoute} was not defined.")
+ ->setSolutionDescription('Are you sure that the route is defined'),
+ ];
+ }
+
+ protected function findRelatedRoute(string $missingRoute): ?string
+ {
+ Route::getRoutes()->refreshNameLookups();
+
+ return StringComparator::findClosestMatch(array_keys(Route::getRoutes()->getRoutesByName()), $missingRoute);
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/RunningLaravelDuskInProductionProvider.php b/vendor/facade/ignition/src/SolutionProviders/RunningLaravelDuskInProductionProvider.php
new file mode 100644
index 00000000..e1474835
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/RunningLaravelDuskInProductionProvider.php
@@ -0,0 +1,30 @@
+getMessage() === 'It is unsafe to run Dusk in production.';
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [
+ BaseSolution::create('Laravel Dusk should not be run in production.')
+ ->setSolutionDescription('Install the dependencies with the `--no-dev` flag.'),
+ BaseSolution::create('Laravel Dusk can be run in other environments.')
+ ->setSolutionDescription('Consider setting the `APP_ENV` to something other than `production` like `local` for example.'),
+ ];
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/SolutionProviderRepository.php b/vendor/facade/ignition/src/SolutionProviders/SolutionProviderRepository.php
new file mode 100644
index 00000000..01b2ca90
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/SolutionProviderRepository.php
@@ -0,0 +1,95 @@
+solutionProviders = Collection::make($solutionProviders);
+ }
+
+ public function registerSolutionProvider(string $solutionProviderClass): SolutionProviderRepositoryContract
+ {
+ $this->solutionProviders->push($solutionProviderClass);
+
+ return $this;
+ }
+
+ public function registerSolutionProviders(array $solutionProviderClasses): SolutionProviderRepositoryContract
+ {
+ $this->solutionProviders = $this->solutionProviders->merge($solutionProviderClasses);
+
+ return $this;
+ }
+
+ public function getSolutionsForThrowable(Throwable $throwable): array
+ {
+ $solutions = [];
+
+ if ($throwable instanceof Solution) {
+ $solutions[] = $throwable;
+ }
+
+ if ($throwable instanceof ProvidesSolution) {
+ $solutions[] = $throwable->getSolution();
+ }
+
+ $providedSolutions = $this->solutionProviders
+ ->filter(function (string $solutionClass) {
+ if (! in_array(HasSolutionsForThrowable::class, class_implements($solutionClass))) {
+ return false;
+ }
+
+ if (in_array($solutionClass, config('ignition.ignored_solution_providers', []))) {
+ return false;
+ }
+
+ return true;
+ })
+ ->map(function (string $solutionClass) {
+ return app($solutionClass);
+ })
+ ->filter(function (HasSolutionsForThrowable $solutionProvider) use ($throwable) {
+ try {
+ return $solutionProvider->canSolve($throwable);
+ } catch (Throwable $e) {
+ return false;
+ }
+ })
+ ->map(function (HasSolutionsForThrowable $solutionProvider) use ($throwable) {
+ try {
+ return $solutionProvider->getSolutions($throwable);
+ } catch (Throwable $e) {
+ return [];
+ }
+ })
+ ->flatten()
+ ->toArray();
+
+ return array_merge($solutions, $providedSolutions);
+ }
+
+ public function getSolutionForClass(string $solutionClass): ?Solution
+ {
+ if (! class_exists($solutionClass)) {
+ return null;
+ }
+
+ if (! in_array(Solution::class, class_implements($solutionClass))) {
+ return null;
+ }
+
+ return app($solutionClass);
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/TableNotFoundSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/TableNotFoundSolutionProvider.php
new file mode 100644
index 00000000..b5cbb711
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/TableNotFoundSolutionProvider.php
@@ -0,0 +1,35 @@
+isBadTableErrorCode($throwable->getCode());
+ }
+
+ protected function isBadTableErrorCode($code): bool
+ {
+ return $code === static::MYSQL_BAD_TABLE_CODE;
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [new RunMigrationsSolution('A table was not found')];
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/UndefinedPropertySolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/UndefinedPropertySolutionProvider.php
new file mode 100644
index 00000000..09ea19b1
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/UndefinedPropertySolutionProvider.php
@@ -0,0 +1,98 @@
+getClassAndPropertyFromExceptionMessage($throwable->getMessage()))) {
+ return false;
+ }
+
+ if (! $this->similarPropertyExists($throwable)) {
+ return false;
+ }
+
+ return true;
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [
+ BaseSolution::create('Unknown Property')
+ ->setSolutionDescription($this->getSolutionDescription($throwable)),
+ ];
+ }
+
+ public function getSolutionDescription(Throwable $throwable): string
+ {
+ if (! $this->canSolve($throwable) || ! $this->similarPropertyExists($throwable)) {
+ return '';
+ }
+
+ extract($this->getClassAndPropertyFromExceptionMessage($throwable->getMessage()), EXTR_OVERWRITE);
+
+ $possibleProperty = $this->findPossibleProperty($class, $property);
+
+ return "Did you mean {$class}::\${$possibleProperty->name} ?";
+ }
+
+ protected function similarPropertyExists(Throwable $throwable)
+ {
+ extract($this->getClassAndPropertyFromExceptionMessage($throwable->getMessage()), EXTR_OVERWRITE);
+
+ $possibleProperty = $this->findPossibleProperty($class, $property);
+
+ return $possibleProperty !== null;
+ }
+
+ protected function getClassAndPropertyFromExceptionMessage(string $message): ?array
+ {
+ if (! preg_match(self::REGEX, $message, $matches)) {
+ return null;
+ }
+
+ return [
+ 'class' => $matches[1],
+ 'property' => $matches[2],
+ ];
+ }
+
+ protected function findPossibleProperty(string $class, string $invalidPropertyName)
+ {
+ return $this->getAvailableProperties($class)
+ ->sortByDesc(function (ReflectionProperty $property) use ($invalidPropertyName) {
+ similar_text($invalidPropertyName, $property->name, $percentage);
+
+ return $percentage;
+ })
+ ->filter(function (ReflectionProperty $property) use ($invalidPropertyName) {
+ similar_text($invalidPropertyName, $property->name, $percentage);
+
+ return $percentage >= self::MINIMUM_SIMILARITY;
+ })->first();
+ }
+
+ protected function getAvailableProperties($class): Collection
+ {
+ $class = new ReflectionClass($class);
+
+ return Collection::make($class->getProperties());
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/UndefinedVariableSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/UndefinedVariableSolutionProvider.php
new file mode 100644
index 00000000..d2b37891
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/UndefinedVariableSolutionProvider.php
@@ -0,0 +1,89 @@
+getNameAndView($throwable) !== null;
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ $solutions = [];
+
+ extract($this->getNameAndView($throwable));
+
+ if (! isset($variableName)) {
+ return [];
+ }
+
+ $solutions = $this->findCorrectVariableSolutions($throwable, $variableName, $viewFile);
+ $solutions[] = $this->findOptionalVariableSolution($variableName, $viewFile);
+
+ return $solutions;
+ }
+
+ protected function findCorrectVariableSolutions(
+ ViewException $throwable,
+ string $variableName,
+ string $viewFile
+ ): array {
+ return collect($throwable->getViewData())->map(function ($value, $key) use ($variableName) {
+ similar_text($variableName, $key, $percentage);
+
+ return ['match' => $percentage, 'value' => $value];
+ })->sortByDesc('match')->filter(function ($var, $key) {
+ return $var['match'] > 40;
+ })->keys()->map(function ($suggestion) use ($variableName, $viewFile) {
+ return new SuggestCorrectVariableNameSolution($variableName, $viewFile, $suggestion);
+ })->map(function ($solution) {
+ return $solution->isRunnable()
+ ? $solution
+ : BaseSolution::create($solution->getSolutionTitle())
+ ->setSolutionDescription($solution->getSolutionDescription());
+ })->toArray();
+ }
+
+ protected function findOptionalVariableSolution(string $variableName, string $viewFile)
+ {
+ $optionalSolution = new MakeViewVariableOptionalSolution($variableName, $viewFile);
+
+ return $optionalSolution->isRunnable()
+ ? $optionalSolution
+ : BaseSolution::create($optionalSolution->getSolutionTitle())
+ ->setSolutionDescription($optionalSolution->getSolutionDescription());
+ }
+
+ protected function getNameAndView(Throwable $throwable): ?array
+ {
+ $pattern = '/Undefined variable:? (.*?) \(View: (.*?)\)/';
+
+ preg_match($pattern, $throwable->getMessage(), $matches);
+
+ if (count($matches) === 3) {
+ [, $variableName, $viewFile] = $matches;
+ $variableName = ltrim($variableName, '$');
+
+ return compact('variableName', 'viewFile');
+ }
+
+ return null;
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/UnknownValidationSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/UnknownValidationSolutionProvider.php
new file mode 100644
index 00000000..99d3e24b
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/UnknownValidationSolutionProvider.php
@@ -0,0 +1,83 @@
+validate(?!(Attribute|UsingCustomRule))[A-Z][a-zA-Z]+)/m';
+
+ public function canSolve(Throwable $throwable): bool
+ {
+ if (! $throwable instanceof BadMethodCallException) {
+ return false;
+ }
+
+ return ! is_null($this->getMethodFromExceptionMessage($throwable->getMessage()));
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ return [
+ BaseSolution::create('Unknown Validation Rule')
+ ->setSolutionDescription($this->getSolutionDescription($throwable)),
+ ];
+ }
+
+ protected function getSolutionDescription(Throwable $throwable): string
+ {
+ $method = $this->getMethodFromExceptionMessage($throwable->getMessage());
+
+ $possibleMethod = StringComparator::findSimilarText(
+ $this->getAvailableMethods()->toArray(),
+ $method
+ );
+
+ if (empty($possibleMethod)) {
+ return '';
+ }
+
+ $rule = Str::snake(str_replace('validate', '', $possibleMethod));
+
+ return "Did you mean `{$rule}` ?";
+ }
+
+ protected function getMethodFromExceptionMessage(string $message): ?string
+ {
+ if (! preg_match(self::REGEX, $message, $matches)) {
+ return null;
+ }
+
+ return $matches['method'];
+ }
+
+ protected function getAvailableMethods(): Collection
+ {
+ $class = new ReflectionClass(Validator::class);
+
+ $extensions = Collection::make((app('validator')->make([], []))->extensions)
+ ->keys()
+ ->map(function (string $extension) {
+ return 'validate'.Str::studly($extension);
+ });
+
+ return Collection::make($class->getMethods())
+ ->filter(function (ReflectionMethod $method) {
+ return preg_match('/(validate(?!(Attribute|UsingCustomRule))[A-Z][a-zA-Z]+)/', $method->name);
+ })
+ ->map(function (ReflectionMethod $method) {
+ return $method->name;
+ })
+ ->merge($extensions);
+ }
+}
diff --git a/vendor/facade/ignition/src/SolutionProviders/ViewNotFoundSolutionProvider.php b/vendor/facade/ignition/src/SolutionProviders/ViewNotFoundSolutionProvider.php
new file mode 100644
index 00000000..54d087ad
--- /dev/null
+++ b/vendor/facade/ignition/src/SolutionProviders/ViewNotFoundSolutionProvider.php
@@ -0,0 +1,117 @@
+getMessage(), $matches);
+ }
+
+ public function getSolutions(Throwable $throwable): array
+ {
+ preg_match(self::REGEX, $throwable->getMessage(), $matches);
+
+ $missingView = $matches[1] ?? null;
+
+ $suggestedView = $this->findRelatedView($missingView);
+
+ if ($suggestedView) {
+ return [
+ BaseSolution::create("{$missingView} was not found.")
+ ->setSolutionDescription("Did you mean `{$suggestedView}`?"),
+ ];
+ }
+
+ return [
+ BaseSolution::create("{$missingView} was not found.")
+ ->setSolutionDescription('Are you sure the view exists and is a `.blade.php` file?'),
+ ];
+ }
+
+ protected function findRelatedView(string $missingView): ?string
+ {
+ $views = $this->getAllViews();
+
+ return StringComparator::findClosestMatch($views, $missingView);
+ }
+
+ protected function getAllViews(): array
+ {
+ /** @var \Illuminate\View\FileViewFinder $fileViewFinder */
+ $fileViewFinder = View::getFinder();
+
+ $extensions = $fileViewFinder->getExtensions();
+
+ $viewsForHints = collect($fileViewFinder->getHints())
+ ->flatMap(function ($paths, string $namespace) use ($extensions) {
+ $paths = Arr::wrap($paths);
+
+ return collect($paths)
+ ->flatMap(function (string $path) use ($extensions) {
+ return $this->getViewsInPath($path, $extensions);
+ })
+ ->map(function (string $view) use ($namespace) {
+ return "{$namespace}::{$view}";
+ })
+ ->toArray();
+ });
+
+ $viewsForViewPaths = collect($fileViewFinder->getPaths())
+ ->flatMap(function (string $path) use ($extensions) {
+ return $this->getViewsInPath($path, $extensions);
+ });
+
+ return $viewsForHints->merge($viewsForViewPaths)->toArray();
+ }
+
+ protected function getViewsInPath(string $path, array $extensions): array
+ {
+ $filePatterns = array_map(function (string $extension) {
+ return "*.{$extension}";
+ }, $extensions);
+
+ $extensionsWithDots = array_map(function (string $extension) {
+ return ".{$extension}";
+ }, $extensions);
+
+ $files = (new Finder())
+ ->in($path)
+ ->files();
+
+ foreach ($filePatterns as $filePattern) {
+ $files->name($filePattern);
+ }
+
+ $views = [];
+
+ foreach ($files as $file) {
+ if ($file instanceof SplFileInfo) {
+ $view = $file->getRelativePathname();
+ $view = str_replace($extensionsWithDots, '', $view);
+ $view = str_replace('/', '.', $view);
+ $views[] = $view;
+ }
+ }
+
+ return $views;
+ }
+}
diff --git a/vendor/facade/ignition/src/Solutions/GenerateAppKeySolution.php b/vendor/facade/ignition/src/Solutions/GenerateAppKeySolution.php
new file mode 100644
index 00000000..fe570476
--- /dev/null
+++ b/vendor/facade/ignition/src/Solutions/GenerateAppKeySolution.php
@@ -0,0 +1,46 @@
+ 'https://laravel.com/docs/master/installation#configuration',
+ ];
+ }
+
+ public function getSolutionActionDescription(): string
+ {
+ return 'Generate your application encryption key using `php artisan key:generate`.';
+ }
+
+ public function getRunButtonText(): string
+ {
+ return 'Generate app key';
+ }
+
+ public function getSolutionDescription(): string
+ {
+ return '';
+ }
+
+ public function getRunParameters(): array
+ {
+ return [];
+ }
+
+ public function run(array $parameters = [])
+ {
+ Artisan::call('key:generate');
+ }
+}
diff --git a/vendor/facade/ignition/src/Solutions/LivewireDiscoverSolution.php b/vendor/facade/ignition/src/Solutions/LivewireDiscoverSolution.php
new file mode 100644
index 00000000..87b5c0bb
--- /dev/null
+++ b/vendor/facade/ignition/src/Solutions/LivewireDiscoverSolution.php
@@ -0,0 +1,53 @@
+customTitle = $customTitle;
+ }
+
+ public function getSolutionTitle(): string
+ {
+ return $this->customTitle;
+ }
+
+ public function getSolutionDescription(): string
+ {
+ return 'You might have forgotten to discover your Livewire components. You can discover your Livewire components using `php artisan livewire:discover`.';
+ }
+
+ public function getDocumentationLinks(): array
+ {
+ return [
+ 'Livewire: Artisan Commands' => 'https://laravel-livewire.com/docs/2.x/artisan-commands',
+ ];
+ }
+
+ public function getRunParameters(): array
+ {
+ return [];
+ }
+
+ public function getSolutionActionDescription(): string
+ {
+ return 'Pressing the button below will try to discover your Livewire components.';
+ }
+
+ public function getRunButtonText(): string
+ {
+ return 'Run livewire:discover';
+ }
+
+ public function run(array $parameters = [])
+ {
+ app(LivewireComponentsFinder::class)->build();
+ }
+}
diff --git a/vendor/facade/ignition/src/Solutions/MakeViewVariableOptionalSolution.php b/vendor/facade/ignition/src/Solutions/MakeViewVariableOptionalSolution.php
new file mode 100644
index 00000000..d9e815ee
--- /dev/null
+++ b/vendor/facade/ignition/src/Solutions/MakeViewVariableOptionalSolution.php
@@ -0,0 +1,122 @@
+variableName = $variableName;
+ $this->viewFile = $viewFile;
+ }
+
+ public function getSolutionTitle(): string
+ {
+ return "$$this->variableName is undefined";
+ }
+
+ public function getDocumentationLinks(): array
+ {
+ return [];
+ }
+
+ public function getSolutionActionDescription(): string
+ {
+ $output = [
+ 'Make the variable optional in the blade template.',
+ "Replace `{{ $$this->variableName }}` with `{{ $$this->variableName ?? '' }}`",
+ ];
+
+ return implode(PHP_EOL, $output);
+ }
+
+ public function getRunButtonText(): string
+ {
+ return 'Make variable optional';
+ }
+
+ public function getSolutionDescription(): string
+ {
+ return '';
+ }
+
+ public function getRunParameters(): array
+ {
+ return [
+ 'variableName' => $this->variableName,
+ 'viewFile' => $this->viewFile,
+ ];
+ }
+
+ public function isRunnable(array $parameters = [])
+ {
+ return $this->makeOptional($this->getRunParameters()) !== false;
+ }
+
+ public function run(array $parameters = [])
+ {
+ $output = $this->makeOptional($parameters);
+ if ($output !== false) {
+ file_put_contents($parameters['viewFile'], $output);
+ }
+ }
+
+ protected function isSafePath(string $path): bool
+ {
+ if (! Str::startsWith($path, ['/', './'])) {
+ return false;
+ }
+ if (! Str::endsWith($path, '.blade.php')) {
+ return false;
+ }
+
+ return true;
+ }
+
+ public function makeOptional(array $parameters = [])
+ {
+ if (! $this->isSafePath($parameters['viewFile'])) {
+ return false;
+ }
+
+ $originalContents = file_get_contents($parameters['viewFile']);
+ $newContents = str_replace('$'.$parameters['variableName'], '$'.$parameters['variableName']." ?? ''", $originalContents);
+
+ $originalTokens = token_get_all(Blade::compileString($originalContents));
+ $newTokens = token_get_all(Blade::compileString($newContents));
+
+ $expectedTokens = $this->generateExpectedTokens($originalTokens, $parameters['variableName']);
+
+ if ($expectedTokens !== $newTokens) {
+ return false;
+ }
+
+ return $newContents;
+ }
+
+ protected function generateExpectedTokens(array $originalTokens, string $variableName): array
+ {
+ $expectedTokens = [];
+ foreach ($originalTokens as $token) {
+ $expectedTokens[] = $token;
+ if ($token[0] === T_VARIABLE && $token[1] === '$'.$variableName) {
+ $expectedTokens[] = [T_WHITESPACE, ' ', $token[2]];
+ $expectedTokens[] = [T_COALESCE, '??', $token[2]];
+ $expectedTokens[] = [T_WHITESPACE, ' ', $token[2]];
+ $expectedTokens[] = [T_CONSTANT_ENCAPSED_STRING, "''", $token[2]];
+ }
+ }
+
+ return $expectedTokens;
+ }
+}
diff --git a/vendor/facade/ignition/src/Solutions/MissingPackageSolution.php b/vendor/facade/ignition/src/Solutions/MissingPackageSolution.php
new file mode 100644
index 00000000..832597c9
--- /dev/null
+++ b/vendor/facade/ignition/src/Solutions/MissingPackageSolution.php
@@ -0,0 +1,42 @@
+possiblePackage = $possiblePackage;
+ }
+
+ public function getSolutionTitle(): string
+ {
+ return 'A composer dependency is missing';
+ }
+
+ public function getSolutionDescription(): string
+ {
+ $output = [
+ 'You might be missing a composer dependency.',
+ 'A possible package that was found is `'.$this->possiblePackage->name.'`.',
+ '',
+ 'See if this is the package that you need and install it via `composer require '.$this->possiblePackage->name.'`.',
+ ];
+
+ return implode(PHP_EOL, $output);
+ }
+
+ public function getDocumentationLinks(): array
+ {
+ return [
+ 'Git repository' => $this->possiblePackage->repository,
+ 'Package on Packagist' => $this->possiblePackage->url,
+ ];
+ }
+}
diff --git a/vendor/facade/ignition/src/Solutions/RunMigrationsSolution.php b/vendor/facade/ignition/src/Solutions/RunMigrationsSolution.php
new file mode 100644
index 00000000..29f391bd
--- /dev/null
+++ b/vendor/facade/ignition/src/Solutions/RunMigrationsSolution.php
@@ -0,0 +1,53 @@
+customTitle = $customTitle;
+ }
+
+ public function getSolutionTitle(): string
+ {
+ return $this->customTitle;
+ }
+
+ public function getSolutionDescription(): string
+ {
+ return 'You might have forgotten to run your migrations. You can run your migrations using `php artisan migrate`.';
+ }
+
+ public function getDocumentationLinks(): array
+ {
+ return [
+ 'Database: Running Migrations docs' => 'https://laravel.com/docs/master/migrations#running-migrations',
+ ];
+ }
+
+ public function getRunParameters(): array
+ {
+ return [];
+ }
+
+ public function getSolutionActionDescription(): string
+ {
+ return 'Pressing the button below will try to run your migrations.';
+ }
+
+ public function getRunButtonText(): string
+ {
+ return 'Run migrations';
+ }
+
+ public function run(array $parameters = [])
+ {
+ Artisan::call('migrate');
+ }
+}
diff --git a/vendor/facade/ignition/src/Solutions/SolutionTransformer.php b/vendor/facade/ignition/src/Solutions/SolutionTransformer.php
new file mode 100644
index 00000000..db2080cd
--- /dev/null
+++ b/vendor/facade/ignition/src/Solutions/SolutionTransformer.php
@@ -0,0 +1,45 @@
+solution = $solution;
+ }
+
+ public function toArray(): array
+ {
+ $isRunnable = ($this->solution instanceof RunnableSolution);
+
+ return [
+ 'class' => get_class($this->solution),
+ 'title' => $this->solution->getSolutionTitle(),
+ 'description' => $this->solution->getSolutionDescription(),
+ 'links' => $this->solution->getDocumentationLinks(),
+ 'is_runnable' => $isRunnable,
+ 'run_button_text' => $isRunnable ? $this->solution->getRunButtonText() : '',
+ 'run_parameters' => $isRunnable ? $this->solution->getRunParameters() : [],
+ 'action_description' => $isRunnable ? $this->solution->getSolutionActionDescription() : '',
+ 'execute_endpoint' => $this->executeEndpoint(),
+ ];
+ }
+
+ protected function executeEndpoint(): string
+ {
+ try {
+ return action('\Facade\Ignition\Http\Controllers\ExecuteSolutionController');
+ } catch (Throwable $exception) {
+ return '';
+ }
+ }
+}
diff --git a/vendor/facade/ignition/src/Solutions/SuggestCorrectVariableNameSolution.php b/vendor/facade/ignition/src/Solutions/SuggestCorrectVariableNameSolution.php
new file mode 100644
index 00000000..e1681768
--- /dev/null
+++ b/vendor/facade/ignition/src/Solutions/SuggestCorrectVariableNameSolution.php
@@ -0,0 +1,44 @@
+variableName = $variableName;
+ $this->viewFile = $viewFile;
+ $this->suggested = $suggested;
+ }
+
+ public function getSolutionTitle(): string
+ {
+ return 'Possible typo $'.$this->variableName;
+ }
+
+ public function getDocumentationLinks(): array
+ {
+ return [];
+ }
+
+ public function getSolutionDescription(): string
+ {
+ return "Did you mean `$$this->suggested`?";
+ }
+
+ public function isRunnable(): bool
+ {
+ return false;
+ }
+}
diff --git a/vendor/facade/ignition/src/Solutions/SuggestImportSolution.php b/vendor/facade/ignition/src/Solutions/SuggestImportSolution.php
new file mode 100644
index 00000000..7779c97a
--- /dev/null
+++ b/vendor/facade/ignition/src/Solutions/SuggestImportSolution.php
@@ -0,0 +1,31 @@
+class = $class;
+ }
+
+ public function getSolutionTitle(): string
+ {
+ return 'A class import is missing';
+ }
+
+ public function getSolutionDescription(): string
+ {
+ return 'You have a missing class import. Try importing this class: `'.$this->class.'`.';
+ }
+
+ public function getDocumentationLinks(): array
+ {
+ return [];
+ }
+}
diff --git a/vendor/facade/ignition/src/Solutions/SuggestUsingCorrectDbNameSolution.php b/vendor/facade/ignition/src/Solutions/SuggestUsingCorrectDbNameSolution.php
new file mode 100644
index 00000000..c1fb3bd0
--- /dev/null
+++ b/vendor/facade/ignition/src/Solutions/SuggestUsingCorrectDbNameSolution.php
@@ -0,0 +1,27 @@
+ 'https://laravel.com/docs/master/database#configuration',
+ ];
+ }
+}
diff --git a/vendor/facade/ignition/src/Solutions/UseDefaultValetDbCredentialsSolution.php b/vendor/facade/ignition/src/Solutions/UseDefaultValetDbCredentialsSolution.php
new file mode 100644
index 00000000..d0c40362
--- /dev/null
+++ b/vendor/facade/ignition/src/Solutions/UseDefaultValetDbCredentialsSolution.php
@@ -0,0 +1,64 @@
+ensureLineExists('DB_USERNAME', 'root');
+ $this->ensureLineExists('DB_PASSWORD', '');
+ }
+
+ protected function ensureLineExists(string $key, string $value)
+ {
+ $envPath = base_path('.env');
+
+ $envLines = array_map(function (string $envLine) use ($value, $key) {
+ return Str::startsWith($envLine, $key)
+ ? "{$key}={$value}".PHP_EOL
+ : $envLine;
+ }, file($envPath));
+
+ file_put_contents($envPath, implode('', $envLines));
+ }
+
+ public function getDocumentationLinks(): array
+ {
+ return [];
+ }
+
+ public function getRunParameters(): array
+ {
+ return [
+ 'Valet documentation' => 'https://laravel.com/docs/master/valet',
+ ];
+ }
+
+ public function getSolutionDescription(): string
+ {
+ return 'You seem to be using Valet, but the .env file does not contain the right default database credentials.';
+ }
+}
diff --git a/vendor/facade/ignition/src/Support/ComposerClassMap.php b/vendor/facade/ignition/src/Support/ComposerClassMap.php
new file mode 100644
index 00000000..541bdab3
--- /dev/null
+++ b/vendor/facade/ignition/src/Support/ComposerClassMap.php
@@ -0,0 +1,125 @@
+composer = require $autoloaderPath;
+ } else {
+ $this->composer = new FakeComposer();
+ }
+ $this->basePath = app_path();
+ }
+
+ public function listClasses(): array
+ {
+ $classes = $this->composer->getClassMap();
+
+ return array_merge($classes, $this->listClassesInPsrMaps());
+ }
+
+ public function searchClassMap(string $missingClass): ?string
+ {
+ foreach ($this->composer->getClassMap() as $fqcn => $file) {
+ $basename = basename($file, '.php');
+
+ if ($basename === $missingClass) {
+ return $fqcn;
+ }
+ }
+
+ return null;
+ }
+
+ public function listClassesInPsrMaps(): array
+ {
+ // TODO: This is incorrect. Doesnt list all fqcns. Need to parse namespace? e.g. App\LoginController is wrong
+
+ $prefixes = array_merge(
+ $this->composer->getPrefixes(),
+ $this->composer->getPrefixesPsr4()
+ );
+
+ $classes = [];
+
+ foreach ($prefixes as $namespace => $directories) {
+ foreach ($directories as $directory) {
+ if (file_exists($directory)) {
+ $files = (new Finder)
+ ->in($directory)
+ ->files()
+ ->name('*.php');
+
+ foreach ($files as $file) {
+ if ($file instanceof SplFileInfo) {
+ $fqcn = $this->getFullyQualifiedClassNameFromFile($namespace, $file);
+
+ $classes[$fqcn] = $file->getRelativePathname();
+ }
+ }
+ }
+ }
+ }
+
+ return $classes;
+ }
+
+ public function searchPsrMaps(string $missingClass): ?string
+ {
+ $prefixes = array_merge(
+ $this->composer->getPrefixes(),
+ $this->composer->getPrefixesPsr4()
+ );
+
+ foreach ($prefixes as $namespace => $directories) {
+ foreach ($directories as $directory) {
+ if (file_exists($directory)) {
+ $files = (new Finder)
+ ->in($directory)
+ ->files()
+ ->name('*.php');
+
+ foreach ($files as $file) {
+ if ($file instanceof SplFileInfo) {
+ $basename = basename($file->getRelativePathname(), '.php');
+
+ if ($basename === $missingClass) {
+ return $namespace.basename($file->getRelativePathname(), '.php');
+ }
+ }
+ }
+ }
+ }
+ }
+
+ return null;
+ }
+
+ protected function getFullyQualifiedClassNameFromFile(string $rootNamespace, SplFileInfo $file): string
+ {
+ $class = trim(str_replace($this->basePath, '', $file->getRealPath()), DIRECTORY_SEPARATOR);
+
+ $class = str_replace(
+ [DIRECTORY_SEPARATOR, 'App\\'],
+ ['\\', app()->getNamespace()],
+ ucfirst(Str::replaceLast('.php', '', $class))
+ );
+
+ return $rootNamespace.$class;
+ }
+}
diff --git a/vendor/facade/ignition/src/Support/FakeComposer.php b/vendor/facade/ignition/src/Support/FakeComposer.php
new file mode 100644
index 00000000..ac725931
--- /dev/null
+++ b/vendor/facade/ignition/src/Support/FakeComposer.php
@@ -0,0 +1,21 @@
+name = $properties['name'];
+
+ $this->url = $properties['url'];
+
+ $this->repository = $properties['repository'];
+ }
+
+ public function hasNamespaceThatContainsClassName(string $className): bool
+ {
+ return $this->getNamespaces()->contains(function ($namespace) use ($className) {
+ return Str::startsWith(strtolower($className), strtolower($namespace));
+ });
+ }
+
+ protected function getNamespaces(): Collection
+ {
+ $details = json_decode(file_get_contents("https://packagist.org/packages/{$this->name}.json"), true);
+
+ return collect($details['package']['versions'])
+ ->map(function ($version) {
+ return collect($version['autoload'] ?? [])
+ ->map(function ($autoload) {
+ return array_keys($autoload);
+ })
+ ->flatten();
+ })
+ ->flatten()
+ ->unique();
+ }
+}
diff --git a/vendor/facade/ignition/src/Support/Packagist/Packagist.php b/vendor/facade/ignition/src/Support/Packagist/Packagist.php
new file mode 100644
index 00000000..a6f481e3
--- /dev/null
+++ b/vendor/facade/ignition/src/Support/Packagist/Packagist.php
@@ -0,0 +1,29 @@
+results);
+ }
+}
diff --git a/vendor/facade/ignition/src/Support/StringComparator.php b/vendor/facade/ignition/src/Support/StringComparator.php
new file mode 100644
index 00000000..5db7273a
--- /dev/null
+++ b/vendor/facade/ignition/src/Support/StringComparator.php
@@ -0,0 +1,51 @@
+sortByDesc(function (string $string) use ($input) {
+ similar_text($input, $string, $percentage);
+
+ return $percentage;
+ })
+ ->first();
+ }
+}
diff --git a/vendor/facade/ignition/src/Tabs/Tab.php b/vendor/facade/ignition/src/Tabs/Tab.php
new file mode 100644
index 00000000..d71bdc74
--- /dev/null
+++ b/vendor/facade/ignition/src/Tabs/Tab.php
@@ -0,0 +1,75 @@
+registerAssets();
+ }
+
+ public function name(): string
+ {
+ return Str::studly(class_basename(get_called_class()));
+ }
+
+ public function component(): string
+ {
+ return Str::snake(class_basename(get_called_class()), '-');
+ }
+
+ public function beforeRenderingErrorPage(Flare $flare, Throwable $throwable)
+ {
+ $this->flare = $flare;
+
+ $this->throwable = $throwable;
+ }
+
+ public function script(string $name, string $path)
+ {
+ $this->scripts[$name] = $path;
+
+ return $this;
+ }
+
+ public function style(string $name, string $path)
+ {
+ $this->styles[$name] = $path;
+
+ return $this;
+ }
+
+ abstract protected function registerAssets();
+
+ public function meta(): array
+ {
+ return [];
+ }
+
+ public function jsonSerialize()
+ {
+ return [
+ 'title' => $this->name(),
+ 'component' => $this->component(),
+ 'props' => [
+ 'meta' => $this->meta(),
+ ],
+ ];
+ }
+}
diff --git a/vendor/facade/ignition/src/Views/Compilers/BladeSourceMapCompiler.php b/vendor/facade/ignition/src/Views/Compilers/BladeSourceMapCompiler.php
new file mode 100644
index 00000000..f7089ee2
--- /dev/null
+++ b/vendor/facade/ignition/src/Views/Compilers/BladeSourceMapCompiler.php
@@ -0,0 +1,94 @@
+compileString(file_get_contents($filename));
+ } catch (ErrorException $e) {
+ return 1;
+ }
+
+ $map = explode("\n", $map);
+
+ $line = $map[$exceptionLineNumber - 1] ?? $exceptionLineNumber;
+ $pattern = '/\|---LINE:([0-9]+)---\|/m';
+
+ if (preg_match($pattern, (string)$line, $matches)) {
+ return (int)$matches[1];
+ }
+
+ return $exceptionLineNumber;
+ }
+
+ public function compileString($value)
+ {
+ try {
+ $value = $this->addEchoLineNumbers($value);
+
+ $value = $this->addStatementLineNumbers($value);
+
+ $value = parent::compileString($value);
+
+ return $this->trimEmptyLines($value);
+ } catch (\Exception $e) {
+ return $value;
+ }
+ }
+
+ protected function addEchoLineNumbers(string $value)
+ {
+ $pattern = sprintf('/(@)?%s\s*(.+?)\s*%s(\r?\n)?/s', $this->contentTags[0], $this->contentTags[1]);
+
+ if (preg_match_all($pattern, $value, $matches, PREG_OFFSET_CAPTURE)) {
+ foreach (array_reverse($matches[0]) as $match) {
+ $position = mb_strlen(substr($value, 0, $match[1]));
+
+ $value = $this->insertLineNumberAtPosition($position, $value);
+ }
+ }
+
+ return $value;
+ }
+
+ protected function addStatementLineNumbers(string $value)
+ {
+ $shouldInsertLineNumbers = preg_match_all(
+ '/\B@(@?\w+(?:::\w+)?)([ \t]*)(\( ( (?>[^()]+) | (?3) )* \))?/x',
+ $value,
+ $matches,
+ PREG_OFFSET_CAPTURE
+ );
+
+ if ($shouldInsertLineNumbers) {
+ foreach (array_reverse($matches[0]) as $match) {
+ $position = mb_strlen(substr($value, 0, $match[1]));
+
+ $value = $this->insertLineNumberAtPosition($position, $value);
+ }
+ }
+
+ return $value;
+ }
+
+ protected function insertLineNumberAtPosition(int $position, string $value)
+ {
+ $before = mb_substr($value, 0, $position);
+ $lineNumber = count(explode("\n", $before));
+
+ return mb_substr($value, 0, $position)."|---LINE:{$lineNumber}---|".mb_substr($value, $position);
+ }
+
+ protected function trimEmptyLines(string $value)
+ {
+ $value = preg_replace('/^\|---LINE:([0-9]+)---\|$/m', '', $value);
+
+ return ltrim($value, PHP_EOL);
+ }
+}
diff --git a/vendor/facade/ignition/src/Views/Concerns/CollectsViewExceptions.php b/vendor/facade/ignition/src/Views/Concerns/CollectsViewExceptions.php
new file mode 100644
index 00000000..e064842b
--- /dev/null
+++ b/vendor/facade/ignition/src/Views/Concerns/CollectsViewExceptions.php
@@ -0,0 +1,67 @@
+lastCompiledData[] = [
+ 'path' => $path,
+ 'compiledPath' => $this->getCompiledPath($path),
+ 'data' => $this->filterViewData($data),
+ ];
+ }
+
+ public function filterViewData(array $data): array
+ {
+ // By default, Laravel views get two shared data keys:
+ // __env and app. We try to filter them out.
+ return array_filter($data, function ($value, $key) {
+ if ($key === 'app') {
+ return ! $value instanceof Application;
+ }
+
+ return $key !== '__env';
+ }, ARRAY_FILTER_USE_BOTH);
+ }
+
+ public function getCompiledViewData($compiledPath): array
+ {
+ $compiledView = $this->findCompiledView($compiledPath);
+
+ return $compiledView['data'] ?? [];
+ }
+
+ public function getCompiledViewName($compiledPath): string
+ {
+ $compiledView = $this->findCompiledView($compiledPath);
+
+ return $compiledView['path'] ?? $compiledPath;
+ }
+
+ protected function findCompiledView($compiledPath): ?array
+ {
+ return Collection::make($this->lastCompiledData)
+ ->first(function ($compiledData) use ($compiledPath) {
+ $comparePath = $compiledData['compiledPath'];
+
+ return realpath(dirname($comparePath)).DIRECTORY_SEPARATOR.basename($comparePath) === $compiledPath;
+ });
+ }
+
+ protected function getCompiledPath($path): string
+ {
+ if ($this instanceof CompilerEngine) {
+ return $this->getCompiler()->getCompiledPath($path);
+ }
+
+ return $path;
+ }
+}
diff --git a/vendor/facade/ignition/src/Views/Engines/CompilerEngine.php b/vendor/facade/ignition/src/Views/Engines/CompilerEngine.php
new file mode 100644
index 00000000..59b028b9
--- /dev/null
+++ b/vendor/facade/ignition/src/Views/Engines/CompilerEngine.php
@@ -0,0 +1,117 @@
+currentPath = $path;
+
+ $this->collectViewData($path, $data);
+
+ return parent::get($path, $data);
+ }
+
+ /**
+ * Handle a view exception.
+ *
+ * @param \Throwable $baseException
+ * @param int $obLevel
+ *
+ * @return void
+ *
+ * @throws \Throwable
+ */
+ protected function handleViewException(Throwable $baseException, $obLevel)
+ {
+ while (ob_get_level() > $obLevel) {
+ ob_end_clean();
+ }
+
+ if ($baseException instanceof ViewException) {
+ throw $baseException;
+ }
+
+ $viewExceptionClass = ViewException::class;
+
+ if ($baseException instanceof ProvidesSolution) {
+ $viewExceptionClass = ViewExceptionWithSolution::class;
+ }
+
+ $exception = new $viewExceptionClass(
+ $this->getMessage($baseException),
+ 0,
+ 1,
+ $this->getCompiledViewName($baseException->getFile()),
+ $this->getBladeLineNumber($baseException->getFile(), $baseException->getLine()),
+ $baseException
+ );
+
+ if ($baseException instanceof ProvidesSolution) {
+ $exception->setSolution($baseException->getSolution());
+ }
+
+
+ $this->modifyViewsInTrace($exception);
+
+ $exception->setView($this->getCompiledViewName($baseException->getFile()));
+ $exception->setViewData($this->getCompiledViewData($baseException->getFile()));
+
+ throw $exception;
+ }
+
+ protected function getBladeLineNumber(string $compiledPath, int $exceptionLineNumber): int
+ {
+ $viewPath = $this->getCompiledViewName($compiledPath);
+
+ if (! $viewPath) {
+ return $exceptionLineNumber;
+ }
+
+ $sourceMapCompiler = new BladeSourceMapCompiler(app(Filesystem::class), 'not-needed');
+
+ return $sourceMapCompiler->detectLineNumber($viewPath, $exceptionLineNumber);
+ }
+
+ protected function modifyViewsInTrace(ViewException $exception)
+ {
+ $trace = Collection::make($exception->getPrevious()->getTrace())
+ ->map(function ($trace) {
+ if ($compiledData = $this->findCompiledView(Arr::get($trace, 'file', ''))) {
+ $trace['file'] = $compiledData['path'];
+ $trace['line'] = $this->getBladeLineNumber($trace['file'], $trace['line']);
+ }
+
+ return $trace;
+ })->toArray();
+
+ $traceProperty = new ReflectionProperty('Exception', 'trace');
+ $traceProperty->setAccessible(true);
+ $traceProperty->setValue($exception, $trace);
+ }
+}
diff --git a/vendor/facade/ignition/src/Views/Engines/PhpEngine.php b/vendor/facade/ignition/src/Views/Engines/PhpEngine.php
new file mode 100644
index 00000000..25ad8b51
--- /dev/null
+++ b/vendor/facade/ignition/src/Views/Engines/PhpEngine.php
@@ -0,0 +1,47 @@
+collectViewData($path, $data);
+
+ return parent::get($path, $data);
+ }
+
+ /**
+ * Handle a view exception.
+ *
+ * @param \Throwable $baseException
+ * @param int $obLevel
+ *
+ * @return void
+ *
+ * @throws \Throwable
+ */
+ protected function handleViewException(Throwable $baseException, $obLevel)
+ {
+ $exception = new ViewException($baseException->getMessage(), 0, 1, $baseException->getFile(), $baseException->getLine(), $baseException);
+
+ $exception->setView($this->getCompiledViewName($baseException->getFile()));
+ $exception->setViewData($this->getCompiledViewData($baseException->getFile()));
+
+ parent::handleViewException($exception, $obLevel);
+ }
+}
diff --git a/vendor/facade/ignition/src/helpers.php b/vendor/facade/ignition/src/helpers.php
new file mode 100644
index 00000000..81b0992a
--- /dev/null
+++ b/vendor/facade/ignition/src/helpers.php
@@ -0,0 +1,31 @@
+make(Flare::class);
+
+ $report = $client->createReportFromMessage('Dump, Die, Debug', 'info');
+
+ $handler->handleReport($report, 'DebugTab', [
+ 'dump' => true,
+ 'glow' => false,
+ 'log' => false,
+ 'query' => false,
+ ]);
+
+ die();
+ }
+}
diff --git a/vendor/fakerphp/faker/CHANGELOG.md b/vendor/fakerphp/faker/CHANGELOG.md
new file mode 100644
index 00000000..130b72a6
--- /dev/null
+++ b/vendor/fakerphp/faker/CHANGELOG.md
@@ -0,0 +1,71 @@
+# CHANGELOG
+
+## 2020-12-18, v1.13.0
+
+Several fixes and new additions in this release. A lot of cleanup has been done
+on the codebase on both tests and consistency.
+
+- Feature/pl pl license plate (#62)
+- Fix greek phone numbers (#16)
+- Move AT payment provider logic to de_AT (#72)
+- Fix wiktionary links (#73)
+- Fix AT person links (#74)
+- Fix AT cities (#75)
+- Deprecate at_AT providers (#78)
+- Add Austrian `ssn()` to `Person` provider (#79)
+- Fix typos in id_ID Address (#83)
+- Austrian post codes (#86)
+- Updated Polish data (#70)
+- Improve Austrian social security number generation (#88)
+- Move US phone numbers with extension to own method (#91)
+- Add UK National Insurance number generator (#89)
+- Fix en_SG phone number generator (#100)
+- Remove usage of mt_rand (#87)
+- Remove whitespace from beginning of el_GR phone numbers (#105)
+- Building numbers can not be 0, 00, 000 (#107)
+- Add 172.16/12 local IPv4 block (#121)
+- Add JCB credit card type (#124)
+- Remove json_decode from emoji generation (#123)
+- Remove ro street address (#146)
+
+## 2020-12-11, v1.12.1
+
+This is a security release that prevents a hacker to execute code on the server.
+
+## 2020-11-23, v1.12.0
+
+- Fix ro_RO first and last day of year calculation offset (#65)
+- Fix en_NG locale test namespaces that did not match PSR-4 (#57)
+- Added Singapore NRIC/FIN provider (#56)
+- Added provider for Lithuanian municipalities (#58)
+- Added blood types provider (#61)
+
+## 2020-11-15, v1.11.0
+
+- Added Provider for Swedish Municipalities
+- Updates to person names in pt_BR
+- Many code style changes
+
+## 2020-10-28, v1.10.1
+
+- Updates the Danish addresses in dk_DK
+- Removed offense company names in nl_NL
+- Clarify changelog with original fork
+- Standin replacement for LoremPixel to Placeholder.com (#11)
+
+## 2020-10-27, v1.10.0
+
+- Support PHP 7.1-8.0
+- Fix typo in de_DE Company Provider
+- Fix dateTimeThisYear method
+- Fix typo in de_DE jobTitleFormat
+- Fix IBAN generation for CR
+- Fix typos in greek first names
+- Fix US job title typo
+- Do not clear entity manager for doctrine orm populator
+- Remove persian rude words
+- Corrections to RU names
+
+## 2020-10-27, v1.9.1
+
+- Initial version. Same as `fzaninotto/Faker:v1.9.1`.
diff --git a/vendor/fakerphp/faker/LICENSE b/vendor/fakerphp/faker/LICENSE
new file mode 100644
index 00000000..99ed0075
--- /dev/null
+++ b/vendor/fakerphp/faker/LICENSE
@@ -0,0 +1,22 @@
+Copyright (c) 2011 François Zaninotto
+Portions Copyright (c) 2008 Caius Durling
+Portions Copyright (c) 2008 Adam Royle
+Portions Copyright (c) 2008 Fiona Burrows
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in
+all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
diff --git a/vendor/fakerphp/faker/README.md b/vendor/fakerphp/faker/README.md
new file mode 100644
index 00000000..3e8ae377
--- /dev/null
+++ b/vendor/fakerphp/faker/README.md
@@ -0,0 +1,70 @@
+# Faker
+
+[![Packagist Downloads](https://img.shields.io/packagist/dm/FakerPHP/Faker)](https://packagist.org/packages/fakerphp/faker)
+[![GitHub Workflow Status](https://img.shields.io/github/workflow/status/FakerPHP/Faker/Continuous%20Integration/main)](https://github.com/FakerPHP/Faker/actions)
+[![StyleCI](https://github.styleci.io/repos/307658860/shield?branch=main&style=flat)](https://github.styleci.io/repos/307658860?branch=main)
+
+Faker is a PHP library that generates fake data for you. Whether you need to bootstrap your database, create good-looking XML documents, fill-in your persistence to stress test it, or anonymize data taken from a production service, Faker is for you.
+
+It's heavily inspired by Perl's [Data::Faker](https://metacpan.org/pod/Data::Faker), and by Ruby's [Faker](https://rubygems.org/gems/faker).
+
+## Getting Started
+
+### Installation
+
+Faker requires PHP >= 7.1.
+
+```shell
+composer require fakerphp/faker
+```
+
+### Documentation
+
+Full documentation can be found over on [fakerphp.github.io](https://fakerphp.github.io).
+
+### Basic Usage
+
+Use `Faker\Factory::create()` to create and initialize a faker generator, which can generate data by accessing properties named after the type of data you want.
+
+```php
+name;
+// 'Lucy Cechtelar';
+echo $faker->address;
+// "426 Jordy Lodge
+// Cartwrightshire, SC 88120-6700"
+echo $faker->text;
+// Dolores sit sint laboriosam dolorem culpa et autem. Beatae nam sunt fugit
+// et sit et mollitia sed.
+// Fuga deserunt tempora facere magni omnis. Omnis quia temporibus laudantium
+// sit minima sint.
+```
+
+Even if this example shows a property access, each call to `$faker->name` yields a different (random) result. This is because Faker uses `__get()` magic, and forwards `Faker\Generator->$property` calls to `Faker\Generator->format($property)`.
+
+```php
+name, "\n";
+}
+
+// Adaline Reichel
+// Dr. Santa Prosacco DVM
+// Noemy Vandervort V
+// Lexi O'Conner
+// Gracie Weber
+// Roscoe Johns
+// Emmett Lebsack
+// Keegan Thiel
+// Wellington Koelpin II
+// Ms. Karley Kiehn V
+```
+
+## License
+
+Faker is released under the MIT License. See [`LICENSE`](LICENSE) for details.
diff --git a/vendor/fakerphp/faker/composer.json b/vendor/fakerphp/faker/composer.json
new file mode 100644
index 00000000..52db7a5a
--- /dev/null
+++ b/vendor/fakerphp/faker/composer.json
@@ -0,0 +1,40 @@
+{
+ "name": "fakerphp/faker",
+ "type": "library",
+ "description": "Faker is a PHP library that generates fake data for you.",
+ "keywords": [
+ "faker",
+ "fixtures",
+ "data"
+ ],
+ "license": "MIT",
+ "authors": [
+ {
+ "name": "François Zaninotto"
+ }
+ ],
+ "require": {
+ "php": "^7.1 || ^8.0"
+ },
+ "require-dev": {
+ "ext-intl": "*",
+ "bamarni/composer-bin-plugin": "^1.4.1",
+ "phpunit/phpunit": "^7.5.20 || ^8.5.8 || ^9.4.2"
+ },
+ "autoload": {
+ "psr-4": {
+ "Faker\\": "src/Faker/"
+ }
+ },
+ "autoload-dev": {
+ "psr-4": {
+ "Faker\\Test\\": "test/Faker/"
+ }
+ },
+ "conflict": {
+ "fzaninotto/faker": "*"
+ },
+ "config": {
+ "sort-packages": true
+ }
+}
diff --git a/vendor/fakerphp/faker/psalm.baseline.xml b/vendor/fakerphp/faker/psalm.baseline.xml
new file mode 100644
index 00000000..20d67d91
--- /dev/null
+++ b/vendor/fakerphp/faker/psalm.baseline.xml
@@ -0,0 +1,236 @@
+
+
+
+
+ 0
+
+
+ string
+
+
+
+
+ TableRegistry
+
+
+
+
+ ClassMetadata
+
+
+
+
+ $this->class
+ $this->class
+ $this->class
+ $this->class->associationMappings
+ $this->class->fieldMappings
+ ClassMetadata
+ ObjectManager
+ ObjectManager
+ \Doctrine\ODM\MongoDB\Mapping\ClassMetadata
+ \Doctrine\ODM\MongoDB\Mapping\ClassMetadata
+ \Doctrine\ODM\MongoDB\Mapping\ClassMetadata
+ \Doctrine\ORM\Mapping\ClassMetadata
+ \Doctrine\ORM\Mapping\ClassMetadata
+
+
+ $this->class
+ $this->class
+ $this->class
+ $this->class
+ $this->class
+ $this->class->reflFields
+ ClassMetadata
+
+
+
+
+ ObjectManager|null
+
+
+ $this->manager
+ ObjectManager|null
+ null|EntityManager
+
+
+
+
+ Mandango
+ Mandango
+
+
+
+
+ $this->mandango
+ Mandango
+
+
+
+
+ ColumnMap
+
+
+
+
+ $columnMap
+ $columnMap
+ $columnMap
+ $columnMap
+ $columnMap
+ $columnMap
+ $columnMap
+ $columnMap
+ ColumnMap
+
+
+
+
+ \Propel
+
+
+ PropelPDO
+
+
+
+
+ ColumnMap
+
+
+
+
+ $columnMap
+ $columnMap
+ $columnMap
+ $columnMap
+ $columnMap
+ $columnMap
+ $columnMap
+ $columnMap
+ ColumnMap
+
+
+
+
+ Propel
+
+
+ PropelPDO
+
+
+
+
+ $this->mapper
+
+
+ string
+
+
+ $relation
+ $relation
+ BelongsTo
+ Locator
+ Mapper
+
+
+ $locator
+ $this->mapper
+ $this->mapper
+ $this->mapper
+ $this->mapper
+ $this->mapper
+ Locator
+ Mapper
+
+
+
+
+ $this->locator
+ Locator|null
+
+
+ Locator
+
+
+
+
+ Closure
+
+
+
+
+ false
+
+
+
+
+ $imei
+
+
+ int
+
+
+
+
+ static::$cityPrefix
+
+
+
+
+ $birthNumber
+
+
+ czech
+
+
+ static::birthNumber(static::GENDER_FEMALE)
+ static::birthNumber(static::GENDER_MALE)
+
+
+ czech
+
+
+
+
+
+ Icelandic
+
+
+
+
+ static::$middleName
+
+
+ $ref[$i]
+
+
+
+
+
+ static::split($text)
+
+
+
+
+ implode('', $result)
+
+
+ 14
+
+
+
+
+ static::title()
+ static::title()
+
+
+ DateTime
+
+
+
+
+ static::lastName()
+ static::lastName()
+
+
+
diff --git a/vendor/fakerphp/faker/src/Faker/Calculator/Ean.php b/vendor/fakerphp/faker/src/Faker/Calculator/Ean.php
new file mode 100644
index 00000000..63c0d456
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Calculator/Ean.php
@@ -0,0 +1,48 @@
+ $digit) {
+ $sums += ((int) $digit) * $sequence[$n % 2];
+ }
+
+ return (10 - $sums % 10) % 10;
+ }
+
+ /**
+ * Checks whether the provided number is an EAN compliant number and that
+ * the checksum is correct.
+ *
+ * @param string $ean An EAN number
+ * @return bool
+ */
+ public static function isValid($ean)
+ {
+ if (!preg_match(self::PATTERN, $ean)) {
+ return false;
+ }
+
+ return self::checksum(substr($ean, 0, -1)) === (int) substr($ean, -1);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Calculator/Iban.php b/vendor/fakerphp/faker/src/Faker/Calculator/Iban.php
new file mode 100644
index 00000000..6350db67
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Calculator/Iban.php
@@ -0,0 +1,73 @@
+= 0; $i -= 2) {
+ $sum += $number[$i];
+ }
+ for ($i = $length - 2; $i >= 0; $i -= 2) {
+ $sum += array_sum(str_split($number[$i] * 2));
+ }
+
+ return $sum % 10;
+ }
+
+ /**
+ * @param string $partialNumber
+ * @return string
+ */
+ public static function computeCheckDigit($partialNumber)
+ {
+ $checkDigit = self::checksum($partialNumber . '0');
+ if ($checkDigit === 0) {
+ return 0;
+ }
+
+ return (string) (10 - $checkDigit);
+ }
+
+ /**
+ * Checks whether a number (partial number + check digit) is Luhn compliant
+ *
+ * @param string $number
+ * @return bool
+ */
+ public static function isValid($number)
+ {
+ return self::checksum($number) === 0;
+ }
+
+ /**
+ * Generate a Luhn compliant number.
+ *
+ * @param string $partialValue
+ *
+ * @return string
+ */
+ public static function generateLuhnNumber($partialValue)
+ {
+ if (!preg_match('/^\d+$/', $partialValue)) {
+ throw new InvalidArgumentException('Argument should be an integer.');
+ }
+ return $partialValue . Luhn::computeCheckDigit($partialValue);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Calculator/TCNo.php b/vendor/fakerphp/faker/src/Faker/Calculator/TCNo.php
new file mode 100644
index 00000000..c90eb354
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Calculator/TCNo.php
@@ -0,0 +1,52 @@
+ $digit) {
+ if ($index % 2 == 0) {
+ $evenSum += $digit;
+ } else {
+ $oddSum += $digit;
+ }
+ }
+
+ $tenthDigit = (7 * $evenSum - $oddSum) % 10;
+ $eleventhDigit = ($evenSum + $oddSum + $tenthDigit) % 10;
+
+ return $tenthDigit . $eleventhDigit;
+ }
+
+ /**
+ * Checks whether a TCNo has a valid checksum
+ *
+ * @param string $tcNo
+ * @return bool
+ */
+ public static function isValid($tcNo)
+ {
+ return self::checksum(substr($tcNo, 0, -2)) === substr($tcNo, -2, 2);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/DefaultGenerator.php b/vendor/fakerphp/faker/src/Faker/DefaultGenerator.php
new file mode 100644
index 00000000..eafd2eca
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/DefaultGenerator.php
@@ -0,0 +1,38 @@
+optional().
+ */
+class DefaultGenerator
+{
+ protected $default;
+
+ public function __construct($default = null)
+ {
+ $this->default = $default;
+ }
+
+ /**
+ * @param string $attribute
+ *
+ * @return mixed
+ */
+ public function __get($attribute)
+ {
+ return $this->default;
+ }
+
+ /**
+ * @param string $method
+ * @param array $attributes
+ *
+ * @return mixed
+ */
+ public function __call($method, $attributes)
+ {
+ return $this->default;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Documentor.php b/vendor/fakerphp/faker/src/Faker/Documentor.php
new file mode 100644
index 00000000..bd6b659f
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Documentor.php
@@ -0,0 +1,66 @@
+generator = $generator;
+ }
+
+ /**
+ * @return array
+ */
+ public function getFormatters()
+ {
+ $formatters = [];
+ $providers = array_reverse($this->generator->getProviders());
+ $providers[]= new Provider\Base($this->generator);
+ foreach ($providers as $provider) {
+ $providerClass = get_class($provider);
+ $formatters[$providerClass] = [];
+ $refl = new \ReflectionObject($provider);
+ foreach ($refl->getMethods(\ReflectionMethod::IS_PUBLIC) as $reflmethod) {
+ if ($reflmethod->getDeclaringClass()->getName() == 'Faker\Provider\Base' && $providerClass != 'Faker\Provider\Base') {
+ continue;
+ }
+ $methodName = $reflmethod->name;
+ if ($reflmethod->isConstructor()) {
+ continue;
+ }
+ $parameters = [];
+ foreach ($reflmethod->getParameters() as $reflparameter) {
+ $parameter = '$' . $reflparameter->getName();
+ if ($reflparameter->isDefaultValueAvailable()) {
+ $parameter .= ' = ' . var_export($reflparameter->getDefaultValue(), true);
+ }
+ $parameters []= $parameter;
+ }
+ $parameters = $parameters ? '(' . implode(', ', $parameters) . ')' : '';
+ try {
+ $example = $this->generator->format($methodName);
+ } catch (\InvalidArgumentException $e) {
+ $example = '';
+ }
+ if (is_array($example)) {
+ $example = "array('" . implode("', '", $example) . "')";
+ } elseif ($example instanceof \DateTime) {
+ $example = "DateTime('" . $example->format('Y-m-d H:i:s') . "')";
+ } elseif ($example instanceof Generator || $example instanceof UniqueGenerator) { // modifier
+ $example = '';
+ } else {
+ $example = var_export($example, true);
+ }
+ $formatters[$providerClass][$methodName . $parameters] = $example;
+ }
+ }
+
+ return $formatters;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Factory.php b/vendor/fakerphp/faker/src/Faker/Factory.php
new file mode 100644
index 00000000..07fb938b
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Factory.php
@@ -0,0 +1,63 @@
+addProvider(new $providerClassName($generator));
+ }
+
+ return $generator;
+ }
+
+ /**
+ * @param string $provider
+ * @param string $locale
+ * @return string
+ */
+ protected static function getProviderClassname($provider, $locale = '')
+ {
+ if ($providerClass = self::findProviderClassname($provider, $locale)) {
+ return $providerClass;
+ }
+ // fallback to default locale
+ if ($providerClass = self::findProviderClassname($provider, static::DEFAULT_LOCALE)) {
+ return $providerClass;
+ }
+ // fallback to no locale
+ if ($providerClass = self::findProviderClassname($provider)) {
+ return $providerClass;
+ }
+ throw new \InvalidArgumentException(sprintf('Unable to find provider "%s" with locale "%s"', $provider, $locale));
+ }
+
+ /**
+ * @param string $provider
+ * @param string $locale
+ * @return string|null
+ */
+ protected static function findProviderClassname($provider, $locale = '')
+ {
+ $providerClass = 'Faker\\' . ($locale ? sprintf('Provider\%s\%s', $locale, $provider) : sprintf('Provider\%s', $provider));
+ if (class_exists($providerClass, true)) {
+ return $providerClass;
+ }
+
+ return null;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Generator.php b/vendor/fakerphp/faker/src/Faker/Generator.php
new file mode 100644
index 00000000..84bdd5da
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Generator.php
@@ -0,0 +1,297 @@
+providers, $provider);
+ }
+
+ public function getProviders()
+ {
+ return $this->providers;
+ }
+
+ public function seed($seed = null)
+ {
+ if ($seed === null) {
+ mt_srand();
+ } else {
+ mt_srand((int) $seed, MT_RAND_PHP);
+ }
+ }
+
+ public function format($formatter, $arguments = [])
+ {
+ return call_user_func_array($this->getFormatter($formatter), $arguments);
+ }
+
+ /**
+ * @param string $formatter
+ *
+ * @return callable
+ */
+ public function getFormatter($formatter)
+ {
+ if (isset($this->formatters[$formatter])) {
+ return $this->formatters[$formatter];
+ }
+ foreach ($this->providers as $provider) {
+ if (method_exists($provider, $formatter)) {
+ $this->formatters[$formatter] = [$provider, $formatter];
+
+ return $this->formatters[$formatter];
+ }
+ }
+ throw new \InvalidArgumentException(sprintf('Unknown formatter "%s"', $formatter));
+ }
+
+ /**
+ * Replaces tokens ('{{ tokenName }}') with the result from the token method call
+ *
+ * @param string $string String that needs to bet parsed
+ * @return string
+ */
+ public function parse($string)
+ {
+ return preg_replace_callback('/\{\{\s?(\w+)\s?\}\}/u', [$this, 'callFormatWithMatches'], $string);
+ }
+
+ protected function callFormatWithMatches($matches)
+ {
+ return $this->format($matches[1]);
+ }
+
+ /**
+ * @param string $attribute
+ *
+ * @return mixed
+ */
+ public function __get($attribute)
+ {
+ return $this->format($attribute);
+ }
+
+ /**
+ * @param string $method
+ * @param array $attributes
+ *
+ * @return mixed
+ */
+ public function __call($method, $attributes)
+ {
+ return $this->format($method, $attributes);
+ }
+
+ public function __destruct()
+ {
+ $this->seed();
+ }
+
+ public function __wakeup()
+ {
+ $this->formatters = [];
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Guesser/Name.php b/vendor/fakerphp/faker/src/Faker/Guesser/Name.php
new file mode 100644
index 00000000..4be58d03
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Guesser/Name.php
@@ -0,0 +1,158 @@
+generator = $generator;
+ }
+
+ /**
+ * @param string $name
+ * @param int|null $size Length of field, if known
+ * @return callable|null
+ */
+ public function guessFormat($name, $size = null)
+ {
+ $name = Base::toLower($name);
+ $generator = $this->generator;
+ if (preg_match('/^is[_A-Z]/', $name)) {
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ }
+ if (preg_match('/(_a|A)t$/', $name)) {
+ return function () use ($generator) {
+ return $generator->dateTime;
+ };
+ }
+ switch (str_replace('_', '', $name)) {
+ case 'firstname':
+ return function () use ($generator) {
+ return $generator->firstName;
+ };
+ case 'lastname':
+ return function () use ($generator) {
+ return $generator->lastName;
+ };
+ case 'username':
+ case 'login':
+ return function () use ($generator) {
+ return $generator->userName;
+ };
+ case 'email':
+ case 'emailaddress':
+ return function () use ($generator) {
+ return $generator->email;
+ };
+ case 'phonenumber':
+ case 'phone':
+ case 'telephone':
+ case 'telnumber':
+ return function () use ($generator) {
+ return $generator->phoneNumber;
+ };
+ case 'address':
+ return function () use ($generator) {
+ return $generator->address;
+ };
+ case 'city':
+ case 'town':
+ return function () use ($generator) {
+ return $generator->city;
+ };
+ case 'streetaddress':
+ return function () use ($generator) {
+ return $generator->streetAddress;
+ };
+ case 'postcode':
+ case 'zipcode':
+ return function () use ($generator) {
+ return $generator->postcode;
+ };
+ case 'state':
+ return function () use ($generator) {
+ return $generator->state;
+ };
+ case 'county':
+ if ($this->generator->locale == 'en_US') {
+ return function () use ($generator) {
+ return sprintf('%s County', $generator->city);
+ };
+ }
+
+ return function () use ($generator) {
+ return $generator->state;
+ };
+ case 'country':
+ switch ($size) {
+ case 2:
+ return function () use ($generator) {
+ return $generator->countryCode;
+ };
+ case 3:
+ return function () use ($generator) {
+ return $generator->countryISOAlpha3;
+ };
+ case 5:
+ case 6:
+ return function () use ($generator) {
+ return $generator->locale;
+ };
+ default:
+ return function () use ($generator) {
+ return $generator->country;
+ };
+ }
+ break;
+ case 'locale':
+ return function () use ($generator) {
+ return $generator->locale;
+ };
+ case 'currency':
+ case 'currencycode':
+ return function () use ($generator) {
+ return $generator->currencyCode;
+ };
+ case 'url':
+ case 'website':
+ return function () use ($generator) {
+ return $generator->url;
+ };
+ case 'company':
+ case 'companyname':
+ case 'employer':
+ return function () use ($generator) {
+ return $generator->company;
+ };
+ case 'title':
+ if ($size !== null && $size <= 10) {
+ return function () use ($generator) {
+ return $generator->title;
+ };
+ }
+
+ return function () use ($generator) {
+ return $generator->sentence;
+ };
+ case 'body':
+ case 'summary':
+ case 'article':
+ case 'description':
+ return function () use ($generator) {
+ return $generator->text;
+ };
+ }
+
+ return null;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/CakePHP/ColumnTypeGuesser.php b/vendor/fakerphp/faker/src/Faker/ORM/CakePHP/ColumnTypeGuesser.php
new file mode 100644
index 00000000..eeef217f
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/CakePHP/ColumnTypeGuesser.php
@@ -0,0 +1,71 @@
+generator = $generator;
+ }
+
+ /**
+ * @return \Closure|null
+ */
+ public function guessFormat($column, $table)
+ {
+ $generator = $this->generator;
+ $schema = $table->schema();
+
+ switch ($schema->columnType($column)) {
+ case 'boolean':
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ case 'integer':
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 2147483647);
+ };
+ case 'biginteger':
+ return function () use ($generator) {
+ return $generator->numberBetween(0, PHP_INT_MAX);
+ };
+ case 'decimal':
+ case 'float':
+ return function () use ($generator) {
+ return $generator->randomFloat();
+ };
+ case 'uuid':
+ return function () use ($generator) {
+ return $generator->uuid();
+ };
+ case 'string':
+ if (method_exists($schema, 'getColumn')) {
+ $columnData = $schema->getColumn($column);
+ } else {
+ $columnData = $schema->column($column);
+ }
+ $length = $columnData['length'];
+ return function () use ($generator, $length) {
+ return $generator->text($length);
+ };
+ case 'text':
+ return function () use ($generator) {
+ return $generator->text();
+ };
+ case 'date':
+ case 'datetime':
+ case 'timestamp':
+ case 'time':
+ return function () use ($generator) {
+ return $generator->datetime();
+ };
+
+ case 'binary':
+ default:
+ return null;
+ }
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/CakePHP/EntityPopulator.php b/vendor/fakerphp/faker/src/Faker/ORM/CakePHP/EntityPopulator.php
new file mode 100644
index 00000000..2ec312aa
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/CakePHP/EntityPopulator.php
@@ -0,0 +1,166 @@
+class = $class;
+ }
+
+ /**
+ * @param string $name
+ */
+ public function __get($name)
+ {
+ return $this->{$name};
+ }
+
+ /**
+ * @param string $name
+ */
+ public function __set($name, $value)
+ {
+ $this->{$name} = $value;
+ }
+
+ public function mergeColumnFormattersWith($columnFormatters)
+ {
+ $this->columnFormatters = array_merge($this->columnFormatters, $columnFormatters);
+ }
+
+ public function mergeModifiersWith($modifiers)
+ {
+ $this->modifiers = array_merge($this->modifiers, $modifiers);
+ }
+
+ /**
+ * @return array
+ */
+ public function guessColumnFormatters($populator)
+ {
+ $formatters = [];
+ $class = $this->class;
+ $table = $this->getTable($class);
+ $schema = $table->schema();
+ $pk = $schema->primaryKey();
+ $guessers = $populator->getGuessers() + ['ColumnTypeGuesser' => new ColumnTypeGuesser($populator->getGenerator())];
+ $isForeignKey = function ($column) use ($table) {
+ foreach ($table->associations()->type('BelongsTo') as $assoc) {
+ if ($column == $assoc->foreignKey()) {
+ return true;
+ }
+ }
+ return false;
+ };
+
+
+ foreach ($schema->columns() as $column) {
+ if ($column == $pk[0] || $isForeignKey($column)) {
+ continue;
+ }
+
+ foreach ($guessers as $guesser) {
+ if ($formatter = $guesser->guessFormat($column, $table)) {
+ $formatters[$column] = $formatter;
+ break;
+ }
+ }
+ }
+
+ return $formatters;
+ }
+
+ /**
+ * @return array
+ */
+ public function guessModifiers()
+ {
+ $modifiers = [];
+ $table = $this->getTable($this->class);
+
+ $belongsTo = $table->associations()->type('BelongsTo');
+ foreach ($belongsTo as $assoc) {
+ $modifiers['belongsTo' . $assoc->name()] = function ($data, $insertedEntities) use ($assoc) {
+ $table = $assoc->target();
+ $foreignModel = $table->alias();
+
+ $foreignKeys = [];
+ if (!empty($insertedEntities[$foreignModel])) {
+ $foreignKeys = $insertedEntities[$foreignModel];
+ } else {
+ $foreignKeys = $table->find('all')
+ ->select(['id'])
+ ->map(function ($row) {
+ return $row->id;
+ })
+ ->toArray();
+ }
+
+ if (empty($foreignKeys)) {
+ throw new \Exception(sprintf('%s belongsTo %s, which seems empty at this point.', $this->getTable($this->class)->table(), $assoc->table()));
+ }
+
+ $foreignKey = $foreignKeys[array_rand($foreignKeys)];
+ $data[$assoc->foreignKey()] = $foreignKey;
+ return $data;
+ };
+ }
+
+ // TODO check if TreeBehavior attached to modify lft/rgt cols
+
+ return $modifiers;
+ }
+
+ /**
+ * @param array $options
+ */
+ public function execute($class, $insertedEntities, $options = [])
+ {
+ $table = $this->getTable($class);
+ $entity = $table->newEntity();
+
+ foreach ($this->columnFormatters as $column => $format) {
+ if (!is_null($format)) {
+ $entity->{$column} = is_callable($format) ? $format($insertedEntities, $table) : $format;
+ }
+ }
+
+ foreach ($this->modifiers as $modifier) {
+ $entity = $modifier($entity, $insertedEntities);
+ }
+
+ if (!$entity = $table->save($entity, $options)) {
+ throw new \RuntimeException("Failed saving $class record");
+ }
+
+ $pk = $table->primaryKey();
+ if (is_string($pk)) {
+ return $entity->{$pk};
+ }
+
+ return $entity->{$pk[0]};
+ }
+
+ public function setConnection($name)
+ {
+ $this->connectionName = $name;
+ }
+
+ protected function getTable($class)
+ {
+ $options = [];
+ if (!empty($this->connectionName)) {
+ $options['connection'] = $this->connectionName;
+ }
+ return TableRegistry::get($class, $options);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/CakePHP/Populator.php b/vendor/fakerphp/faker/src/Faker/ORM/CakePHP/Populator.php
new file mode 100644
index 00000000..7ecc2ef6
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/CakePHP/Populator.php
@@ -0,0 +1,108 @@
+generator = $generator;
+ }
+
+ /**
+ * @return \Faker\Generator
+ */
+ public function getGenerator()
+ {
+ return $this->generator;
+ }
+
+ /**
+ * @return array
+ */
+ public function getGuessers()
+ {
+ return $this->guessers;
+ }
+
+ /**
+ * @return $this
+ */
+ public function removeGuesser($name)
+ {
+ if ($this->guessers[$name]) {
+ unset($this->guessers[$name]);
+ }
+ return $this;
+ }
+
+ /**
+ * @return $this
+ * @throws \Exception
+ */
+ public function addGuesser($class)
+ {
+ if (!is_object($class)) {
+ $class = new $class($this->generator);
+ }
+
+ if (!method_exists($class, 'guessFormat')) {
+ throw new \Exception('Missing required custom guesser method: ' . get_class($class) . '::guessFormat()');
+ }
+
+ $this->guessers[get_class($class)] = $class;
+ return $this;
+ }
+
+ /**
+ * @param array $customColumnFormatters
+ * @param array $customModifiers
+ * @return $this
+ */
+ public function addEntity($entity, $number, $customColumnFormatters = [], $customModifiers = [])
+ {
+ if (!$entity instanceof EntityPopulator) {
+ $entity = new EntityPopulator($entity);
+ }
+
+ $entity->columnFormatters = $entity->guessColumnFormatters($this);
+ if ($customColumnFormatters) {
+ $entity->mergeColumnFormattersWith($customColumnFormatters);
+ }
+
+ $entity->modifiers = $entity->guessModifiers($this);
+ if ($customModifiers) {
+ $entity->mergeModifiersWith($customModifiers);
+ }
+
+ $class = $entity->class;
+ $this->entities[$class] = $entity;
+ $this->quantities[$class] = $number;
+ return $this;
+ }
+
+ /**
+ * @param array $options
+ * @return array
+ */
+ public function execute($options = [])
+ {
+ $insertedEntities = [];
+
+ foreach ($this->quantities as $class => $number) {
+ for ($i = 0; $i < $number; $i++) {
+ $insertedEntities[$class][] = $this->entities[$class]->execute($class, $insertedEntities, $options);
+ }
+ }
+
+ return $insertedEntities;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Doctrine/ColumnTypeGuesser.php b/vendor/fakerphp/faker/src/Faker/ORM/Doctrine/ColumnTypeGuesser.php
new file mode 100644
index 00000000..f00d541d
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Doctrine/ColumnTypeGuesser.php
@@ -0,0 +1,79 @@
+generator = $generator;
+ }
+
+ /**
+ * @param ClassMetadata $class
+ * @return \Closure|null
+ */
+ public function guessFormat($fieldName, ClassMetadata $class)
+ {
+ $generator = $this->generator;
+ $type = $class->getTypeOfField($fieldName);
+ switch ($type) {
+ case 'boolean':
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ case 'decimal':
+ $size = $class->fieldMappings[$fieldName]['precision'] ?? 2;
+
+ return function () use ($generator, $size) {
+ return $generator->randomNumber($size + 2) / 100;
+ };
+ case 'smallint':
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 65535);
+ };
+ case 'integer':
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 2147483647);
+ };
+ case 'bigint':
+ return function () use ($generator) {
+ return $generator->numberBetween(0, PHP_INT_MAX);
+ };
+ case 'float':
+ return function () use ($generator) {
+ return $generator->randomFloat();
+ };
+ case 'string':
+ $size = $class->fieldMappings[$fieldName]['length'] ?? 255;
+
+ return function () use ($generator, $size) {
+ return $generator->text($size);
+ };
+ case 'text':
+ return function () use ($generator) {
+ return $generator->text;
+ };
+ case 'datetime':
+ case 'date':
+ case 'time':
+ return function () use ($generator) {
+ return $generator->datetime;
+ };
+ case 'datetime_immutable':
+ case 'date_immutable':
+ case 'time_immutable':
+ return function () use ($generator) {
+ return \DateTimeImmutable::createFromMutable($generator->datetime);
+ };
+ default:
+ // no smart way to guess what the user expects here
+ return null;
+ }
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Doctrine/EntityPopulator.php b/vendor/fakerphp/faker/src/Faker/ORM/Doctrine/EntityPopulator.php
new file mode 100644
index 00000000..0d140ee8
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Doctrine/EntityPopulator.php
@@ -0,0 +1,245 @@
+class = $class;
+ }
+
+ /**
+ * @return string
+ */
+ public function getClass()
+ {
+ return $this->class->getName();
+ }
+
+ public function setColumnFormatters($columnFormatters)
+ {
+ $this->columnFormatters = $columnFormatters;
+ }
+
+ /**
+ * @return array
+ */
+ public function getColumnFormatters()
+ {
+ return $this->columnFormatters;
+ }
+
+ public function mergeColumnFormattersWith($columnFormatters)
+ {
+ $this->columnFormatters = array_merge($this->columnFormatters, $columnFormatters);
+ }
+
+ /**
+ * @param array $modifiers
+ */
+ public function setModifiers(array $modifiers)
+ {
+ $this->modifiers = $modifiers;
+ }
+
+ /**
+ * @return array
+ */
+ public function getModifiers()
+ {
+ return $this->modifiers;
+ }
+
+ /**
+ * @param array $modifiers
+ */
+ public function mergeModifiersWith(array $modifiers)
+ {
+ $this->modifiers = array_merge($this->modifiers, $modifiers);
+ }
+
+ /**
+ * @param \Faker\Generator $generator
+ * @return array
+ */
+ public function guessColumnFormatters(\Faker\Generator $generator)
+ {
+ $formatters = [];
+ $nameGuesser = new \Faker\Guesser\Name($generator);
+ $columnTypeGuesser = new ColumnTypeGuesser($generator);
+ foreach ($this->class->getFieldNames() as $fieldName) {
+ if ($this->class->isIdentifier($fieldName) || !$this->class->hasField($fieldName)) {
+ continue;
+ }
+
+ $size = $this->class->fieldMappings[$fieldName]['length'] ?? null;
+ if ($formatter = $nameGuesser->guessFormat($fieldName, $size)) {
+ $formatters[$fieldName] = $formatter;
+ continue;
+ }
+ if ($formatter = $columnTypeGuesser->guessFormat($fieldName, $this->class)) {
+ $formatters[$fieldName] = $formatter;
+ continue;
+ }
+ }
+
+ foreach ($this->class->getAssociationNames() as $assocName) {
+ if ($this->class->isCollectionValuedAssociation($assocName)) {
+ continue;
+ }
+
+ $relatedClass = $this->class->getAssociationTargetClass($assocName);
+
+ $unique = $optional = false;
+ if ($this->class instanceof \Doctrine\ORM\Mapping\ClassMetadata) {
+ $mappings = $this->class->getAssociationMappings();
+ foreach ($mappings as $mapping) {
+ if ($mapping['targetEntity'] == $relatedClass) {
+ if ($mapping['type'] == \Doctrine\ORM\Mapping\ClassMetadata::ONE_TO_ONE) {
+ $unique = true;
+ $optional = $mapping['joinColumns'][0]['nullable'] ?? false;
+ break;
+ }
+ }
+ }
+ } elseif ($this->class instanceof \Doctrine\ODM\MongoDB\Mapping\ClassMetadata) {
+ $mappings = $this->class->associationMappings;
+ foreach ($mappings as $mapping) {
+ if ($mapping['targetDocument'] == $relatedClass) {
+ if ($mapping['type'] == \Doctrine\ODM\MongoDB\Mapping\ClassMetadata::ONE && $mapping['association'] == \Doctrine\ODM\MongoDB\Mapping\ClassMetadata::REFERENCE_ONE) {
+ $unique = true;
+ $optional = $mapping['nullable'] ?? false;
+ break;
+ }
+ }
+ }
+ }
+
+ $index = 0;
+ $formatters[$assocName] = function ($inserted) use ($relatedClass, &$index, $unique, $optional, $generator) {
+ if (isset($inserted[$relatedClass])) {
+ if ($unique) {
+ $related = null;
+ if (isset($inserted[$relatedClass][$index]) || !$optional) {
+ $related = $inserted[$relatedClass][$index];
+ }
+
+ $index++;
+
+ return $related;
+ }
+
+ return $generator->randomElement($inserted[$relatedClass]);
+ }
+
+ return null;
+ };
+ }
+
+ return $formatters;
+ }
+
+ /**
+ * Insert one new record using the Entity class.
+ * @param ObjectManager $manager
+ * @param bool $generateId
+ * @return EntityPopulator
+ */
+ public function execute(ObjectManager $manager, $insertedEntities, $generateId = false)
+ {
+ $obj = $this->class->newInstance();
+
+ $this->fillColumns($obj, $insertedEntities);
+ $this->callMethods($obj, $insertedEntities);
+
+ if ($generateId) {
+ $idsName = $this->class->getIdentifier();
+ foreach ($idsName as $idName) {
+ $id = $this->generateId($obj, $idName, $manager);
+ $this->class->reflFields[$idName]->setValue($obj, $id);
+ }
+ }
+
+ $manager->persist($obj);
+
+ return $obj;
+ }
+
+ private function fillColumns($obj, $insertedEntities)
+ {
+ foreach ($this->columnFormatters as $field => $format) {
+ if (null !== $format) {
+ // Add some extended debugging information to any errors thrown by the formatter
+ try {
+ $value = is_callable($format) ? $format($insertedEntities, $obj) : $format;
+ } catch (\InvalidArgumentException $ex) {
+ throw new \InvalidArgumentException(sprintf(
+ 'Failed to generate a value for %s::%s: %s',
+ get_class($obj),
+ $field,
+ $ex->getMessage()
+ ));
+ }
+ // Try a standard setter if it's available, otherwise fall back on reflection
+ $setter = sprintf('set%s', ucfirst($field));
+ if (is_callable([$obj, $setter])) {
+ $obj->$setter($value);
+ } else {
+ $this->class->reflFields[$field]->setValue($obj, $value);
+ }
+ }
+ }
+ }
+
+ private function callMethods($obj, $insertedEntities)
+ {
+ foreach ($this->getModifiers() as $modifier) {
+ $modifier($obj, $insertedEntities);
+ }
+ }
+
+ /**
+ * @param ObjectManager $manager
+ * @return int|null
+ */
+ private function generateId($obj, $column, ObjectManager $manager)
+ {
+ /* @var $repository \Doctrine\Common\Persistence\ObjectRepository */
+ $repository = $manager->getRepository(get_class($obj));
+ $result = $repository->createQueryBuilder('e')
+ ->select(sprintf('e.%s', $column))
+ ->getQuery()
+ ->execute();
+ $ids = array_map('current', $result->toArray());
+
+ $id = null;
+ do {
+ $id = mt_rand();
+ } while (in_array($id, $ids));
+
+ return $id;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Doctrine/Populator.php b/vendor/fakerphp/faker/src/Faker/ORM/Doctrine/Populator.php
new file mode 100644
index 00000000..8aa9e922
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Doctrine/Populator.php
@@ -0,0 +1,108 @@
+generator = $generator;
+ $this->manager = $manager;
+ $this->batchSize = $batchSize;
+ }
+
+ /**
+ * Add an order for the generation of $number records for $entity.
+ *
+ * @param mixed $entity A Doctrine classname, or a \Faker\ORM\Doctrine\EntityPopulator instance
+ * @param int $number The number of entities to populate
+ */
+ public function addEntity($entity, $number, $customColumnFormatters = [], $customModifiers = [], $generateId = false)
+ {
+ if (!$entity instanceof \Faker\ORM\Doctrine\EntityPopulator) {
+ if (null === $this->manager) {
+ throw new \InvalidArgumentException('No entity manager passed to Doctrine Populator.');
+ }
+ $entity = new \Faker\ORM\Doctrine\EntityPopulator($this->manager->getClassMetadata($entity));
+ }
+ $entity->setColumnFormatters($entity->guessColumnFormatters($this->generator));
+ if ($customColumnFormatters) {
+ $entity->mergeColumnFormattersWith($customColumnFormatters);
+ }
+ $entity->mergeModifiersWith($customModifiers);
+ $this->generateId[$entity->getClass()] = $generateId;
+
+ $class = $entity->getClass();
+ $this->entities[$class] = $entity;
+ $this->quantities[$class] = $number;
+ }
+
+ /**
+ * Populate the database using all the Entity classes previously added.
+ *
+ * Please note that large amounts of data will result in more memory usage since the the Populator will return
+ * all newly created primary keys after executing.
+ *
+ * @param null|EntityManager $entityManager A Doctrine connection object
+ *
+ * @return array A list of the inserted PKs
+ */
+ public function execute($entityManager = null)
+ {
+ if (null === $entityManager) {
+ $entityManager = $this->manager;
+ }
+ if (null === $entityManager) {
+ throw new \InvalidArgumentException('No entity manager passed to Doctrine Populator.');
+ }
+
+ $insertedEntities = [];
+ foreach ($this->quantities as $class => $number) {
+ $generateId = $this->generateId[$class];
+ for ($i=0; $i < $number; $i++) {
+ $insertedEntities[$class][]= $this->entities[$class]->execute(
+ $entityManager,
+ $insertedEntities,
+ $generateId
+ );
+ if (count($insertedEntities) % $this->batchSize === 0) {
+ $entityManager->flush();
+ }
+ }
+ $entityManager->flush();
+ }
+
+ return $insertedEntities;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Mandango/ColumnTypeGuesser.php b/vendor/fakerphp/faker/src/Faker/ORM/Mandango/ColumnTypeGuesser.php
new file mode 100644
index 00000000..ead23b45
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Mandango/ColumnTypeGuesser.php
@@ -0,0 +1,54 @@
+generator = $generator;
+ }
+
+ /**
+ * @return \Closure|null
+ */
+ public function guessFormat($field)
+ {
+ $generator = $this->generator;
+ switch ($field['type']) {
+ case 'boolean':
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ case 'integer':
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 4294967295);
+ };
+ case 'float':
+ return function () use ($generator) {
+ return $generator->randomFloat();
+ };
+ case 'string':
+ return function () use ($generator) {
+ return $generator->text(255);
+ };
+ case 'date':
+ return function () use ($generator) {
+ return $generator->dateTime;
+ };
+ default:
+ // no smart way to guess what the user expects here
+ return null;
+ }
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Mandango/EntityPopulator.php b/vendor/fakerphp/faker/src/Faker/ORM/Mandango/EntityPopulator.php
new file mode 100644
index 00000000..88ae76ac
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Mandango/EntityPopulator.php
@@ -0,0 +1,122 @@
+class = $class;
+ }
+
+ /**
+ * @return string
+ */
+ public function getClass()
+ {
+ return $this->class;
+ }
+
+ public function setColumnFormatters($columnFormatters)
+ {
+ $this->columnFormatters = $columnFormatters;
+ }
+
+ /**
+ * @return array
+ */
+ public function getColumnFormatters()
+ {
+ return $this->columnFormatters;
+ }
+
+ public function mergeColumnFormattersWith($columnFormatters)
+ {
+ $this->columnFormatters = array_merge($this->columnFormatters, $columnFormatters);
+ }
+
+ /**
+ * @param \Faker\Generator $generator
+ * @param Mandango $mandango
+ * @return array
+ */
+ public function guessColumnFormatters(\Faker\Generator $generator, Mandango $mandango)
+ {
+ $formatters = [];
+ $nameGuesser = new \Faker\Guesser\Name($generator);
+ $columnTypeGuesser = new \Faker\ORM\Mandango\ColumnTypeGuesser($generator);
+
+ $metadata = $mandango->getMetadata($this->class);
+
+ // fields
+ foreach ($metadata['fields'] as $fieldName => $field) {
+ if ($formatter = $nameGuesser->guessFormat($fieldName)) {
+ $formatters[$fieldName] = $formatter;
+ continue;
+ }
+ if ($formatter = $columnTypeGuesser->guessFormat($field)) {
+ $formatters[$fieldName] = $formatter;
+ continue;
+ }
+ }
+
+ // references
+ foreach (array_merge($metadata['referencesOne'], $metadata['referencesMany']) as $referenceName => $reference) {
+ if (!isset($reference['class'])) {
+ continue;
+ }
+ $referenceClass = $reference['class'];
+
+ $formatters[$referenceName] = function ($insertedEntities) use ($referenceClass) {
+ if (isset($insertedEntities[$referenceClass])) {
+ return Base::randomElement($insertedEntities[$referenceClass]);
+ }
+
+ return null;
+ };
+ }
+
+ return $formatters;
+ }
+
+ /**
+ * Insert one new record using the Entity class.
+ * @param Mandango $mandango
+ */
+ public function execute(Mandango $mandango, $insertedEntities)
+ {
+ $metadata = $mandango->getMetadata($this->class);
+
+ $obj = $mandango->create($this->class);
+ foreach ($this->columnFormatters as $column => $format) {
+ if (null !== $format) {
+ $value = is_callable($format) ? $format($insertedEntities, $obj) : $format;
+
+ if (isset($metadata['fields'][$column]) ||
+ isset($metadata['referencesOne'][$column])) {
+ $obj->set($column, $value);
+ }
+
+ if (isset($metadata['referencesMany'][$column])) {
+ $adder = 'add' . ucfirst($column);
+ $obj->$adder($value);
+ }
+ }
+ }
+ $mandango->persist($obj);
+
+ return $obj;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Mandango/Populator.php b/vendor/fakerphp/faker/src/Faker/ORM/Mandango/Populator.php
new file mode 100644
index 00000000..0e33ea33
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Mandango/Populator.php
@@ -0,0 +1,65 @@
+generator = $generator;
+ $this->mandango = $mandango;
+ }
+
+ /**
+ * Add an order for the generation of $number records for $entity.
+ *
+ * @param mixed $entity A Propel ActiveRecord classname, or a \Faker\ORM\Propel\EntityPopulator instance
+ * @param int $number The number of entities to populate
+ */
+ public function addEntity($entity, $number, $customColumnFormatters = [])
+ {
+ if (!$entity instanceof \Faker\ORM\Mandango\EntityPopulator) {
+ $entity = new \Faker\ORM\Mandango\EntityPopulator($entity);
+ }
+ $entity->setColumnFormatters($entity->guessColumnFormatters($this->generator, $this->mandango));
+ if ($customColumnFormatters) {
+ $entity->mergeColumnFormattersWith($customColumnFormatters);
+ }
+ $class = $entity->getClass();
+ $this->entities[$class] = $entity;
+ $this->quantities[$class] = $number;
+ }
+
+ /**
+ * Populate the database using all the Entity classes previously added.
+ *
+ * @return array A list of the inserted entities.
+ */
+ public function execute()
+ {
+ $insertedEntities = [];
+ foreach ($this->quantities as $class => $number) {
+ for ($i=0; $i < $number; $i++) {
+ $insertedEntities[$class][]= $this->entities[$class]->execute($this->mandango, $insertedEntities);
+ }
+ }
+ $this->mandango->flush();
+
+ return $insertedEntities;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Propel/ColumnTypeGuesser.php b/vendor/fakerphp/faker/src/Faker/ORM/Propel/ColumnTypeGuesser.php
new file mode 100644
index 00000000..205a42c0
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Propel/ColumnTypeGuesser.php
@@ -0,0 +1,104 @@
+generator = $generator;
+ }
+
+ /**
+ * @param ColumnMap $column
+ * @return \Closure|null
+ */
+ public function guessFormat(ColumnMap $column)
+ {
+ $generator = $this->generator;
+ if ($column->isTemporal()) {
+ if ($column->isEpochTemporal()) {
+ return function () use ($generator) {
+ return $generator->dateTime;
+ };
+ }
+
+ return function () use ($generator) {
+ return $generator->dateTimeAD;
+ };
+ }
+ $type = $column->getType();
+ switch ($type) {
+ case PropelColumnTypes::BOOLEAN:
+ case PropelColumnTypes::BOOLEAN_EMU:
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ case PropelColumnTypes::NUMERIC:
+ case PropelColumnTypes::DECIMAL:
+ $size = $column->getSize();
+
+ return function () use ($generator, $size) {
+ return $generator->randomNumber($size + 2) / 100;
+ };
+ case PropelColumnTypes::TINYINT:
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 127);
+ };
+ case PropelColumnTypes::SMALLINT:
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 32767);
+ };
+ case PropelColumnTypes::INTEGER:
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 2147483647);
+ };
+ case PropelColumnTypes::BIGINT:
+ return function () use ($generator) {
+ return $generator->numberBetween(0, PHP_INT_MAX);
+ };
+ case PropelColumnTypes::FLOAT:
+ case PropelColumnTypes::DOUBLE:
+ case PropelColumnTypes::REAL:
+ return function () use ($generator) {
+ return $generator->randomFloat();
+ };
+ case PropelColumnTypes::CHAR:
+ case PropelColumnTypes::VARCHAR:
+ case PropelColumnTypes::BINARY:
+ case PropelColumnTypes::VARBINARY:
+ $size = $column->getSize();
+
+ return function () use ($generator, $size) {
+ return $generator->text($size);
+ };
+ case PropelColumnTypes::LONGVARCHAR:
+ case PropelColumnTypes::LONGVARBINARY:
+ case PropelColumnTypes::CLOB:
+ case PropelColumnTypes::CLOB_EMU:
+ case PropelColumnTypes::BLOB:
+ return function () use ($generator) {
+ return $generator->text;
+ };
+ case PropelColumnTypes::ENUM:
+ $valueSet = $column->getValueSet();
+
+ return function () use ($generator, $valueSet) {
+ return $generator->randomElement($valueSet);
+ };
+ case PropelColumnTypes::OBJECT:
+ case PropelColumnTypes::PHP_ARRAY:
+ default:
+ // no smart way to guess what the user expects here
+ return null;
+ }
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Propel/EntityPopulator.php b/vendor/fakerphp/faker/src/Faker/ORM/Propel/EntityPopulator.php
new file mode 100644
index 00000000..3111d061
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Propel/EntityPopulator.php
@@ -0,0 +1,188 @@
+class = $class;
+ }
+
+ /**
+ * @return string
+ */
+ public function getClass()
+ {
+ return $this->class;
+ }
+
+ public function setColumnFormatters($columnFormatters)
+ {
+ $this->columnFormatters = $columnFormatters;
+ }
+
+ /**
+ * @return array
+ */
+ public function getColumnFormatters()
+ {
+ return $this->columnFormatters;
+ }
+
+ public function mergeColumnFormattersWith($columnFormatters)
+ {
+ $this->columnFormatters = array_merge($this->columnFormatters, $columnFormatters);
+ }
+
+ /**
+ * @param \Faker\Generator $generator
+ * @return array
+ */
+ public function guessColumnFormatters(\Faker\Generator $generator)
+ {
+ $formatters = [];
+ $class = $this->class;
+ $peerClass = $class::PEER;
+ $tableMap = $peerClass::getTableMap();
+ $nameGuesser = new \Faker\Guesser\Name($generator);
+ $columnTypeGuesser = new \Faker\ORM\Propel\ColumnTypeGuesser($generator);
+ foreach ($tableMap->getColumns() as $columnMap) {
+ // skip behavior columns, handled by modifiers
+ if ($this->isColumnBehavior($columnMap)) {
+ continue;
+ }
+ if ($columnMap->isForeignKey()) {
+ $relatedClass = $columnMap->getRelation()->getForeignTable()->getClassname();
+ $formatters[$columnMap->getPhpName()] = function ($inserted) use ($relatedClass, $generator) {
+ return isset($inserted[$relatedClass]) ? $generator->randomElement($inserted[$relatedClass]) : null;
+ };
+ continue;
+ }
+ if ($columnMap->isPrimaryKey()) {
+ continue;
+ }
+ if ($formatter = $nameGuesser->guessFormat($columnMap->getPhpName(), $columnMap->getSize())) {
+ $formatters[$columnMap->getPhpName()] = $formatter;
+ continue;
+ }
+ if ($formatter = $columnTypeGuesser->guessFormat($columnMap)) {
+ $formatters[$columnMap->getPhpName()] = $formatter;
+ continue;
+ }
+ }
+
+ return $formatters;
+ }
+
+ /**
+ * @param ColumnMap $columnMap
+ * @return bool
+ */
+ protected function isColumnBehavior(ColumnMap $columnMap)
+ {
+ foreach ($columnMap->getTable()->getBehaviors() as $name => $params) {
+ $columnName = Base::toLower($columnMap->getName());
+ switch ($name) {
+ case 'nested_set':
+ $columnNames = [$params['left_column'], $params['right_column'], $params['level_column']];
+ if (in_array($columnName, $columnNames)) {
+ return true;
+ }
+ break;
+ case 'timestampable':
+ $columnNames = [$params['create_column'], $params['update_column']];
+ if (in_array($columnName, $columnNames)) {
+ return true;
+ }
+ break;
+ }
+ }
+
+ return false;
+ }
+
+ public function setModifiers($modifiers)
+ {
+ $this->modifiers = $modifiers;
+ }
+
+ /**
+ * @return array
+ */
+ public function getModifiers()
+ {
+ return $this->modifiers;
+ }
+
+ public function mergeModifiersWith($modifiers)
+ {
+ $this->modifiers = array_merge($this->modifiers, $modifiers);
+ }
+
+ /**
+ * @param \Faker\Generator $generator
+ * @return array
+ */
+ public function guessModifiers(\Faker\Generator $generator)
+ {
+ $modifiers = [];
+ $class = $this->class;
+ $peerClass = $class::PEER;
+ $tableMap = $peerClass::getTableMap();
+ foreach ($tableMap->getBehaviors() as $name => $params) {
+ switch ($name) {
+ case 'nested_set':
+ $modifiers['nested_set'] = function ($obj, $inserted) use ($class, $generator) {
+ if (isset($inserted[$class])) {
+ $queryClass = $class . 'Query';
+ $parent = $queryClass::create()->findPk($generator->randomElement($inserted[$class]));
+ $obj->insertAsLastChildOf($parent);
+ } else {
+ $obj->makeRoot();
+ }
+ };
+ break;
+ case 'sortable':
+ $modifiers['sortable'] = function ($obj, $inserted) use ($class, $generator) {
+ $obj->insertAtRank($generator->numberBetween(1, count($inserted[$class] ?? []) + 1));
+ };
+ break;
+ }
+ }
+
+ return $modifiers;
+ }
+
+ /**
+ * Insert one new record using the Entity class.
+ */
+ public function execute($con, $insertedEntities)
+ {
+ $obj = new $this->class();
+ foreach ($this->getColumnFormatters() as $column => $format) {
+ if (null !== $format) {
+ $obj->setByName($column, is_callable($format) ? $format($insertedEntities, $obj) : $format);
+ }
+ }
+ foreach ($this->getModifiers() as $modifier) {
+ $modifier($obj, $insertedEntities);
+ }
+ $obj->save($con);
+
+ return $obj->getPrimaryKey();
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Propel/Populator.php b/vendor/fakerphp/faker/src/Faker/ORM/Propel/Populator.php
new file mode 100644
index 00000000..77cc8646
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Propel/Populator.php
@@ -0,0 +1,89 @@
+generator = $generator;
+ }
+
+ /**
+ * Add an order for the generation of $number records for $entity.
+ *
+ * @param mixed $entity A Propel ActiveRecord classname, or a \Faker\ORM\Propel\EntityPopulator instance
+ * @param int $number The number of entities to populate
+ */
+ public function addEntity($entity, $number, $customColumnFormatters = [], $customModifiers = [])
+ {
+ if (!$entity instanceof \Faker\ORM\Propel\EntityPopulator) {
+ $entity = new \Faker\ORM\Propel\EntityPopulator($entity);
+ }
+ $entity->setColumnFormatters($entity->guessColumnFormatters($this->generator));
+ if ($customColumnFormatters) {
+ $entity->mergeColumnFormattersWith($customColumnFormatters);
+ }
+ $entity->setModifiers($entity->guessModifiers($this->generator));
+ if ($customModifiers) {
+ $entity->mergeModifiersWith($customModifiers);
+ }
+ $class = $entity->getClass();
+ $this->entities[$class] = $entity;
+ $this->quantities[$class] = $number;
+ }
+
+ /**
+ * Populate the database using all the Entity classes previously added.
+ *
+ * @param PropelPDO $con A Propel connection object
+ *
+ * @return array A list of the inserted PKs
+ */
+ public function execute($con = null)
+ {
+ if (null === $con) {
+ $con = $this->getConnection();
+ }
+ $isInstancePoolingEnabled = \Propel::isInstancePoolingEnabled();
+ \Propel::disableInstancePooling();
+ $insertedEntities = [];
+ $con->beginTransaction();
+ foreach ($this->quantities as $class => $number) {
+ for ($i=0; $i < $number; $i++) {
+ $insertedEntities[$class][]= $this->entities[$class]->execute($con, $insertedEntities);
+ }
+ }
+ $con->commit();
+ if ($isInstancePoolingEnabled) {
+ \Propel::enableInstancePooling();
+ }
+
+ return $insertedEntities;
+ }
+
+ protected function getConnection()
+ {
+ // use the first connection available
+ $class = key($this->entities);
+
+ if (!$class) {
+ throw new \RuntimeException('No class found from entities. Did you add entities to the Populator ?');
+ }
+
+ $peer = $class::PEER;
+
+ return \Propel::getConnection($peer::DATABASE_NAME, \Propel::CONNECTION_WRITE);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Propel2/ColumnTypeGuesser.php b/vendor/fakerphp/faker/src/Faker/ORM/Propel2/ColumnTypeGuesser.php
new file mode 100644
index 00000000..8bd30449
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Propel2/ColumnTypeGuesser.php
@@ -0,0 +1,104 @@
+generator = $generator;
+ }
+
+ /**
+ * @param ColumnMap $column
+ * @return \Closure|null
+ */
+ public function guessFormat(ColumnMap $column)
+ {
+ $generator = $this->generator;
+ if ($column->isTemporal()) {
+ if ($column->getType() == PropelTypes::BU_DATE || $column->getType() == PropelTypes::BU_TIMESTAMP) {
+ return function () use ($generator) {
+ return $generator->dateTime;
+ };
+ }
+
+ return function () use ($generator) {
+ return $generator->dateTimeAD;
+ };
+ }
+ $type = $column->getType();
+ switch ($type) {
+ case PropelTypes::BOOLEAN:
+ case PropelTypes::BOOLEAN_EMU:
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ case PropelTypes::NUMERIC:
+ case PropelTypes::DECIMAL:
+ $size = $column->getSize();
+
+ return function () use ($generator, $size) {
+ return $generator->randomNumber($size + 2) / 100;
+ };
+ case PropelTypes::TINYINT:
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 127);
+ };
+ case PropelTypes::SMALLINT:
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 32767);
+ };
+ case PropelTypes::INTEGER:
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 2147483647);
+ };
+ case PropelTypes::BIGINT:
+ return function () use ($generator) {
+ return $generator->numberBetween(0, PHP_INT_MAX);
+ };
+ case PropelTypes::FLOAT:
+ case PropelTypes::DOUBLE:
+ case PropelTypes::REAL:
+ return function () use ($generator) {
+ return $generator->randomFloat();
+ };
+ case PropelTypes::CHAR:
+ case PropelTypes::VARCHAR:
+ case PropelTypes::BINARY:
+ case PropelTypes::VARBINARY:
+ $size = $column->getSize();
+
+ return function () use ($generator, $size) {
+ return $generator->text($size);
+ };
+ case PropelTypes::LONGVARCHAR:
+ case PropelTypes::LONGVARBINARY:
+ case PropelTypes::CLOB:
+ case PropelTypes::CLOB_EMU:
+ case PropelTypes::BLOB:
+ return function () use ($generator) {
+ return $generator->text;
+ };
+ case PropelTypes::ENUM:
+ $valueSet = $column->getValueSet();
+
+ return function () use ($generator, $valueSet) {
+ return $generator->randomElement($valueSet);
+ };
+ case PropelTypes::OBJECT:
+ case PropelTypes::PHP_ARRAY:
+ default:
+ // no smart way to guess what the user expects here
+ return null;
+ }
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Propel2/EntityPopulator.php b/vendor/fakerphp/faker/src/Faker/ORM/Propel2/EntityPopulator.php
new file mode 100644
index 00000000..e87de0e6
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Propel2/EntityPopulator.php
@@ -0,0 +1,189 @@
+class = $class;
+ }
+
+ /**
+ * @return string
+ */
+ public function getClass()
+ {
+ return $this->class;
+ }
+
+ public function setColumnFormatters($columnFormatters)
+ {
+ $this->columnFormatters = $columnFormatters;
+ }
+
+ /**
+ * @return array
+ */
+ public function getColumnFormatters()
+ {
+ return $this->columnFormatters;
+ }
+
+ public function mergeColumnFormattersWith($columnFormatters)
+ {
+ $this->columnFormatters = array_merge($this->columnFormatters, $columnFormatters);
+ }
+
+ /**
+ * @param \Faker\Generator $generator
+ * @return array
+ */
+ public function guessColumnFormatters(\Faker\Generator $generator)
+ {
+ $formatters = [];
+ $class = $this->class;
+ $peerClass = $class::TABLE_MAP;
+ $tableMap = $peerClass::getTableMap();
+ $nameGuesser = new \Faker\Guesser\Name($generator);
+ $columnTypeGuesser = new \Faker\ORM\Propel2\ColumnTypeGuesser($generator);
+ foreach ($tableMap->getColumns() as $columnMap) {
+ // skip behavior columns, handled by modifiers
+ if ($this->isColumnBehavior($columnMap)) {
+ continue;
+ }
+ if ($columnMap->isForeignKey()) {
+ $relatedClass = $columnMap->getRelation()->getForeignTable()->getClassname();
+ $formatters[$columnMap->getPhpName()] = function ($inserted) use ($relatedClass, $generator) {
+ $relatedClass = trim($relatedClass, '\\');
+ return isset($inserted[$relatedClass]) ? $generator->randomElement($inserted[$relatedClass]) : null;
+ };
+ continue;
+ }
+ if ($columnMap->isPrimaryKey()) {
+ continue;
+ }
+ if ($formatter = $nameGuesser->guessFormat($columnMap->getPhpName(), $columnMap->getSize())) {
+ $formatters[$columnMap->getPhpName()] = $formatter;
+ continue;
+ }
+ if ($formatter = $columnTypeGuesser->guessFormat($columnMap)) {
+ $formatters[$columnMap->getPhpName()] = $formatter;
+ continue;
+ }
+ }
+
+ return $formatters;
+ }
+
+ /**
+ * @param ColumnMap $columnMap
+ * @return bool
+ */
+ protected function isColumnBehavior(ColumnMap $columnMap)
+ {
+ foreach ($columnMap->getTable()->getBehaviors() as $name => $params) {
+ $columnName = Base::toLower($columnMap->getName());
+ switch ($name) {
+ case 'nested_set':
+ $columnNames = [$params['left_column'], $params['right_column'], $params['level_column']];
+ if (in_array($columnName, $columnNames)) {
+ return true;
+ }
+ break;
+ case 'timestampable':
+ $columnNames = [$params['create_column'], $params['update_column']];
+ if (in_array($columnName, $columnNames)) {
+ return true;
+ }
+ break;
+ }
+ }
+
+ return false;
+ }
+
+ public function setModifiers($modifiers)
+ {
+ $this->modifiers = $modifiers;
+ }
+
+ /**
+ * @return array
+ */
+ public function getModifiers()
+ {
+ return $this->modifiers;
+ }
+
+ public function mergeModifiersWith($modifiers)
+ {
+ $this->modifiers = array_merge($this->modifiers, $modifiers);
+ }
+
+ /**
+ * @param \Faker\Generator $generator
+ * @return array
+ */
+ public function guessModifiers(\Faker\Generator $generator)
+ {
+ $modifiers = [];
+ $class = $this->class;
+ $peerClass = $class::TABLE_MAP;
+ $tableMap = $peerClass::getTableMap();
+ foreach ($tableMap->getBehaviors() as $name => $params) {
+ switch ($name) {
+ case 'nested_set':
+ $modifiers['nested_set'] = function ($obj, $inserted) use ($class, $generator) {
+ if (isset($inserted[$class])) {
+ $queryClass = $class . 'Query';
+ $parent = $queryClass::create()->findPk($generator->randomElement($inserted[$class]));
+ $obj->insertAsLastChildOf($parent);
+ } else {
+ $obj->makeRoot();
+ }
+ };
+ break;
+ case 'sortable':
+ $modifiers['sortable'] = function ($obj, $inserted) use ($class, $generator) {
+ $obj->insertAtRank($generator->numberBetween(1, count($inserted[$class] ?? []) + 1));
+ };
+ break;
+ }
+ }
+
+ return $modifiers;
+ }
+
+ /**
+ * Insert one new record using the Entity class.
+ */
+ public function execute($con, $insertedEntities)
+ {
+ $obj = new $this->class();
+ foreach ($this->getColumnFormatters() as $column => $format) {
+ if (null !== $format) {
+ $obj->setByName($column, is_callable($format) ? $format($insertedEntities, $obj) : $format);
+ }
+ }
+ foreach ($this->getModifiers() as $modifier) {
+ $modifier($obj, $insertedEntities);
+ }
+ $obj->save($con);
+
+ return $obj->getPrimaryKey();
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Propel2/Populator.php b/vendor/fakerphp/faker/src/Faker/ORM/Propel2/Populator.php
new file mode 100644
index 00000000..5a68d829
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Propel2/Populator.php
@@ -0,0 +1,92 @@
+generator = $generator;
+ }
+
+ /**
+ * Add an order for the generation of $number records for $entity.
+ *
+ * @param mixed $entity A Propel ActiveRecord classname, or a \Faker\ORM\Propel2\EntityPopulator instance
+ * @param int $number The number of entities to populate
+ */
+ public function addEntity($entity, $number, $customColumnFormatters = [], $customModifiers = [])
+ {
+ if (!$entity instanceof \Faker\ORM\Propel2\EntityPopulator) {
+ $entity = new \Faker\ORM\Propel2\EntityPopulator($entity);
+ }
+ $entity->setColumnFormatters($entity->guessColumnFormatters($this->generator));
+ if ($customColumnFormatters) {
+ $entity->mergeColumnFormattersWith($customColumnFormatters);
+ }
+ $entity->setModifiers($entity->guessModifiers($this->generator));
+ if ($customModifiers) {
+ $entity->mergeModifiersWith($customModifiers);
+ }
+ $class = $entity->getClass();
+ $this->entities[$class] = $entity;
+ $this->quantities[$class] = $number;
+ }
+
+ /**
+ * Populate the database using all the Entity classes previously added.
+ *
+ * @param PropelPDO $con A Propel connection object
+ *
+ * @return array A list of the inserted PKs
+ */
+ public function execute($con = null)
+ {
+ if (null === $con) {
+ $con = $this->getConnection();
+ }
+ $isInstancePoolingEnabled = Propel::isInstancePoolingEnabled();
+ Propel::disableInstancePooling();
+ $insertedEntities = [];
+ $con->beginTransaction();
+ foreach ($this->quantities as $class => $number) {
+ for ($i=0; $i < $number; $i++) {
+ $insertedEntities[$class][]= $this->entities[$class]->execute($con, $insertedEntities);
+ }
+ }
+ $con->commit();
+ if ($isInstancePoolingEnabled) {
+ Propel::enableInstancePooling();
+ }
+
+ return $insertedEntities;
+ }
+
+ protected function getConnection()
+ {
+ // use the first connection available
+ $class = key($this->entities);
+
+ if (!$class) {
+ throw new \RuntimeException('No class found from entities. Did you add entities to the Populator ?');
+ }
+
+ $peer = $class::TABLE_MAP;
+
+ return Propel::getConnection($peer::DATABASE_NAME, ServiceContainerInterface::CONNECTION_WRITE);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Spot/ColumnTypeGuesser.php b/vendor/fakerphp/faker/src/Faker/ORM/Spot/ColumnTypeGuesser.php
new file mode 100644
index 00000000..fe4e15ea
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Spot/ColumnTypeGuesser.php
@@ -0,0 +1,77 @@
+generator = $generator;
+ }
+
+ /**
+ * @param array $field
+ * @return \Closure|null
+ */
+ public function guessFormat(array $field)
+ {
+ $generator = $this->generator;
+ $type = $field['type'];
+ switch ($type) {
+ case 'boolean':
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ case 'decimal':
+ $size = $field['precision'] ?? 2;
+
+ return function () use ($generator, $size) {
+ return $generator->randomNumber($size + 2) / 100;
+ };
+ case 'smallint':
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 65535);
+ };
+ case 'integer':
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 2147483647);
+ };
+ case 'bigint':
+ return function () use ($generator) {
+ return $generator->numberBetween(0, PHP_INT_MAX);
+ };
+ case 'float':
+ return function () use ($generator) {
+ return $generator->randomFloat(null, 0, 4294967295);
+ };
+ case 'string':
+ $size = $field['length'] ?? 255;
+
+ return function () use ($generator, $size) {
+ return $generator->text($size);
+ };
+ case 'text':
+ return function () use ($generator) {
+ return $generator->text;
+ };
+ case 'datetime':
+ case 'date':
+ case 'time':
+ return function () use ($generator) {
+ return $generator->datetime;
+ };
+ default:
+ // no smart way to guess what the user expects here
+ return null;
+ }
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Spot/EntityPopulator.php b/vendor/fakerphp/faker/src/Faker/ORM/Spot/EntityPopulator.php
new file mode 100644
index 00000000..1ea2cddf
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Spot/EntityPopulator.php
@@ -0,0 +1,202 @@
+mapper = $mapper;
+ $this->locator = $locator;
+ $this->useExistingData = $useExistingData;
+ }
+
+ /**
+ * @return string
+ */
+ public function getMapper()
+ {
+ return $this->mapper;
+ }
+
+ public function setColumnFormatters($columnFormatters)
+ {
+ $this->columnFormatters = $columnFormatters;
+ }
+
+ /**
+ * @return array
+ */
+ public function getColumnFormatters()
+ {
+ return $this->columnFormatters;
+ }
+
+ public function mergeColumnFormattersWith($columnFormatters)
+ {
+ $this->columnFormatters = array_merge($this->columnFormatters, $columnFormatters);
+ }
+
+ /**
+ * @param array $modifiers
+ */
+ public function setModifiers(array $modifiers)
+ {
+ $this->modifiers = $modifiers;
+ }
+
+ /**
+ * @return array
+ */
+ public function getModifiers()
+ {
+ return $this->modifiers;
+ }
+
+ /**
+ * @param array $modifiers
+ */
+ public function mergeModifiersWith(array $modifiers)
+ {
+ $this->modifiers = array_merge($this->modifiers, $modifiers);
+ }
+
+ /**
+ * @param Generator $generator
+ * @return array
+ */
+ public function guessColumnFormatters(Generator $generator)
+ {
+ $formatters = [];
+ $nameGuesser = new Name($generator);
+ $columnTypeGuesser = new ColumnTypeGuesser($generator);
+ $fields = $this->mapper->fields();
+ foreach ($fields as $fieldName => $field) {
+ if ($field['primary'] === true) {
+ continue;
+ }
+ if ($formatter = $nameGuesser->guessFormat($fieldName)) {
+ $formatters[$fieldName] = $formatter;
+ continue;
+ }
+ if ($formatter = $columnTypeGuesser->guessFormat($field)) {
+ $formatters[$fieldName] = $formatter;
+ continue;
+ }
+ }
+ $entityName = $this->mapper->entity();
+ $entity = $this->mapper->build([]);
+ $relations = $entityName::relations($this->mapper, $entity);
+ foreach ($relations as $relation) {
+ // We don't need any other relation here.
+ if ($relation instanceof BelongsTo) {
+ $fieldName = $relation->localKey();
+ $entityName = $relation->entityName();
+ $field = $fields[$fieldName];
+ $required = $field['required'];
+
+ $locator = $this->locator;
+
+ $formatters[$fieldName] = function ($inserted) use ($required, $entityName, $locator, $generator) {
+ if (!empty($inserted[$entityName])) {
+ return $generator->randomElement($inserted[$entityName])->get('id');
+ }
+
+ if ($required && $this->useExistingData) {
+ // We did not add anything like this, but it's required,
+ // So let's find something existing in DB.
+ $mapper = $locator->mapper($entityName);
+ $records = $mapper->all()->limit(self::RELATED_FETCH_COUNT)->toArray();
+ if (empty($records)) {
+ return null;
+ }
+
+ return $generator->randomElement($records)['id'];
+ }
+
+ return null;
+ };
+ }
+ }
+
+ return $formatters;
+ }
+
+ /**
+ * Insert one new record using the Entity class.
+ *
+ * @return string
+ */
+ public function execute($insertedEntities)
+ {
+ $obj = $this->mapper->build([]);
+
+ $this->fillColumns($obj, $insertedEntities);
+ $this->callMethods($obj, $insertedEntities);
+
+ $this->mapper->insert($obj);
+
+
+ return $obj;
+ }
+
+ private function fillColumns($obj, $insertedEntities)
+ {
+ foreach ($this->columnFormatters as $field => $format) {
+ if (null !== $format) {
+ $value = is_callable($format) ? $format($insertedEntities, $obj) : $format;
+ $obj->set($field, $value);
+ }
+ }
+ }
+
+ private function callMethods($obj, $insertedEntities)
+ {
+ foreach ($this->getModifiers() as $modifier) {
+ $modifier($obj, $insertedEntities);
+ }
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ORM/Spot/Populator.php b/vendor/fakerphp/faker/src/Faker/ORM/Spot/Populator.php
new file mode 100644
index 00000000..f224d6d1
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ORM/Spot/Populator.php
@@ -0,0 +1,87 @@
+generator = $generator;
+ $this->locator = $locator;
+ }
+
+ /**
+ * Add an order for the generation of $number records for $entity.
+ *
+ * @param string $entityName Name of Entity object to generate
+ * @param int $number The number of entities to populate
+ * @param array $customColumnFormatters
+ * @param array $customModifiers
+ * @param bool $useExistingData Should we use existing rows (e.g. roles) to populate relations?
+ */
+ public function addEntity(
+ $entityName,
+ $number,
+ $customColumnFormatters = [],
+ $customModifiers = [],
+ $useExistingData = false
+ ) {
+ $mapper = $this->locator->mapper($entityName);
+ if (null === $mapper) {
+ throw new \InvalidArgumentException('No mapper can be found for entity ' . $entityName);
+ }
+ $entity = new EntityPopulator($mapper, $this->locator, $useExistingData);
+
+ $entity->setColumnFormatters($entity->guessColumnFormatters($this->generator));
+ if ($customColumnFormatters) {
+ $entity->mergeColumnFormattersWith($customColumnFormatters);
+ }
+ $entity->mergeModifiersWith($customModifiers);
+
+ $this->entities[$entityName] = $entity;
+ $this->quantities[$entityName] = $number;
+ }
+
+ /**
+ * Populate the database using all the Entity classes previously added.
+ *
+ * @param Locator $locator A Spot locator
+ *
+ * @return array A list of the inserted PKs
+ */
+ public function execute($locator = null)
+ {
+ if (null === $locator) {
+ $locator = $this->locator;
+ }
+ if (null === $locator) {
+ throw new \InvalidArgumentException('No entity manager passed to Spot Populator.');
+ }
+
+ $insertedEntities = [];
+ foreach ($this->quantities as $entityName => $number) {
+ for ($i = 0; $i < $number; $i++) {
+ $insertedEntities[$entityName][] = $this->entities[$entityName]->execute(
+ $insertedEntities
+ );
+ }
+ }
+
+ return $insertedEntities;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/Address.php
new file mode 100644
index 00000000..6ecbcde2
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/Address.php
@@ -0,0 +1,139 @@
+generator->parse($format);
+ }
+
+ /**
+ * @example 'Crist Parks'
+ */
+ public function streetName()
+ {
+ $format = static::randomElement(static::$streetNameFormats);
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * @example '791 Crist Parks'
+ */
+ public function streetAddress()
+ {
+ $format = static::randomElement(static::$streetAddressFormats);
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * @example 86039-9874
+ */
+ public static function postcode()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$postcode)));
+ }
+
+ /**
+ * @example '791 Crist Parks, Sashabury, IL 86039-9874'
+ */
+ public function address()
+ {
+ $format = static::randomElement(static::$addressFormats);
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * @example 'Japan'
+ */
+ public static function country()
+ {
+ return static::randomElement(static::$country);
+ }
+
+ /**
+ * @example '77.147489'
+ * @param float|int $min
+ * @param float|int $max
+ * @return float Uses signed degrees format (returns a float number between -90 and 90)
+ */
+ public static function latitude($min = -90, $max = 90)
+ {
+ return static::randomFloat(6, $min, $max);
+ }
+
+ /**
+ * @example '86.211205'
+ * @param float|int $min
+ * @param float|int $max
+ * @return float Uses signed degrees format (returns a float number between -180 and 180)
+ */
+ public static function longitude($min = -180, $max = 180)
+ {
+ return static::randomFloat(6, $min, $max);
+ }
+
+ /**
+ * @example array('77.147489', '86.211205')
+ * @return array | latitude, longitude
+ */
+ public static function localCoordinates()
+ {
+ return [
+ 'latitude' => static::latitude(),
+ 'longitude' => static::longitude()
+ ];
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/Barcode.php b/vendor/fakerphp/faker/src/Faker/Provider/Barcode.php
new file mode 100644
index 00000000..f5110eb7
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/Barcode.php
@@ -0,0 +1,98 @@
+ean(13);
+ }
+
+ /**
+ * Get a random EAN8 barcode.
+ * @return string
+ * @example '73513537'
+ */
+ public function ean8()
+ {
+ return $this->ean(8);
+ }
+
+ /**
+ * Get a random ISBN-10 code
+ * @link http://en.wikipedia.org/wiki/International_Standard_Book_Number
+ *
+ * @return string
+ * @example '4881416324'
+ */
+ public function isbn10()
+ {
+ $code = static::numerify(str_repeat('#', 9));
+
+ return $code . Isbn::checksum($code);
+ }
+
+ /**
+ * Get a random ISBN-13 code
+ * @link http://en.wikipedia.org/wiki/International_Standard_Book_Number
+ *
+ * @return string
+ * @example '9790404436093'
+ */
+ public function isbn13()
+ {
+ $code = '97' . self::numberBetween(8, 9) . static::numerify(str_repeat('#', 9));
+
+ return $code . Ean::checksum($code);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/Base.php b/vendor/fakerphp/faker/src/Faker/Provider/Base.php
new file mode 100644
index 00000000..aec07862
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/Base.php
@@ -0,0 +1,610 @@
+generator = $generator;
+ }
+
+ /**
+ * Returns a random number between 0 and 9
+ *
+ * @return int
+ */
+ public static function randomDigit()
+ {
+ return mt_rand(0, 9);
+ }
+
+ /**
+ * Returns a random number between 1 and 9
+ *
+ * @return int
+ */
+ public static function randomDigitNotNull()
+ {
+ return mt_rand(1, 9);
+ }
+
+ /**
+ * Generates a random digit, which cannot be $except
+ *
+ * @param int $except
+ * @return int
+ */
+ public static function randomDigitNot($except)
+ {
+ $result = self::numberBetween(0, 8);
+ if ($result >= $except) {
+ $result++;
+ }
+ return $result;
+ }
+
+ /**
+ * Returns a random integer with 0 to $nbDigits digits.
+ *
+ * The maximum value returned is mt_getrandmax()
+ *
+ * @param int $nbDigits Defaults to a random number between 1 and 9
+ * @param bool $strict Whether the returned number should have exactly $nbDigits
+ * @example 79907610
+ *
+ * @return int
+ */
+ public static function randomNumber($nbDigits = null, $strict = false)
+ {
+ if (!is_bool($strict)) {
+ throw new \InvalidArgumentException('randomNumber() generates numbers of fixed width. To generate numbers between two boundaries, use numberBetween() instead.');
+ }
+ if (null === $nbDigits) {
+ $nbDigits = static::randomDigitNotNull();
+ }
+ $max = 10 ** $nbDigits - 1;
+ if ($max > mt_getrandmax()) {
+ throw new \InvalidArgumentException('randomNumber() can only generate numbers up to mt_getrandmax()');
+ }
+ if ($strict) {
+ return mt_rand(10 ** ($nbDigits - 1), $max);
+ }
+
+ return mt_rand(0, $max);
+ }
+
+ /**
+ * Return a random float number
+ *
+ * @param int $nbMaxDecimals
+ * @param int|float $min
+ * @param int|float $max
+ * @example 48.8932
+ *
+ * @return float
+ */
+ public static function randomFloat($nbMaxDecimals = null, $min = 0, $max = null)
+ {
+ if (null === $nbMaxDecimals) {
+ $nbMaxDecimals = static::randomDigit();
+ }
+
+ if (null === $max) {
+ $max = static::randomNumber();
+ if ($min > $max) {
+ $max = $min;
+ }
+ }
+
+ if ($min > $max) {
+ $tmp = $min;
+ $min = $max;
+ $max = $tmp;
+ }
+
+ return round($min + mt_rand() / mt_getrandmax() * ($max - $min), $nbMaxDecimals);
+ }
+
+ /**
+ * Returns a random number between $int1 and $int2 (any order)
+ *
+ * @param int $int1 default to 0
+ * @param int $int2 defaults to 32 bit max integer, ie 2147483647
+ * @example 79907610
+ *
+ * @return int
+ */
+ public static function numberBetween($int1 = 0, $int2 = 2147483647)
+ {
+ $min = $int1 < $int2 ? $int1 : $int2;
+ $max = $int1 < $int2 ? $int2 : $int1;
+ return mt_rand($min, $max);
+ }
+
+ /**
+ * Returns the passed value
+ *
+ * @param mixed $value
+ *
+ * @return mixed
+ */
+ public static function passthrough($value)
+ {
+ return $value;
+ }
+
+ /**
+ * Returns a random letter from a to z
+ *
+ * @return string
+ */
+ public static function randomLetter()
+ {
+ return chr(mt_rand(97, 122));
+ }
+
+ /**
+ * Returns a random ASCII character (excluding accents and special chars)
+ */
+ public static function randomAscii()
+ {
+ return chr(mt_rand(33, 126));
+ }
+
+ /**
+ * Returns randomly ordered subsequence of $count elements from a provided array
+ *
+ * @param array $array Array to take elements from. Defaults to a-c
+ * @param int $count Number of elements to take.
+ * @param bool $allowDuplicates Allow elements to be picked several times. Defaults to false
+ * @throws \LengthException When requesting more elements than provided
+ *
+ * @return array New array with $count elements from $array
+ */
+ public static function randomElements($array = ['a', 'b', 'c'], $count = 1, $allowDuplicates = false)
+ {
+ $traversables = [];
+
+ if ($array instanceof \Traversable) {
+ foreach ($array as $element) {
+ $traversables[] = $element;
+ }
+ }
+
+ $arr = count($traversables) ? $traversables : $array;
+
+ $allKeys = array_keys($arr);
+ $numKeys = count($allKeys);
+
+ if (!$allowDuplicates && $numKeys < $count) {
+ throw new \LengthException(sprintf('Cannot get %d elements, only %d in array', $count, $numKeys));
+ }
+
+ $highKey = $numKeys - 1;
+ $keys = $elements = [];
+ $numElements = 0;
+
+ while ($numElements < $count) {
+ $num = mt_rand(0, $highKey);
+
+ if (!$allowDuplicates) {
+ if (isset($keys[$num])) {
+ continue;
+ }
+ $keys[$num] = true;
+ }
+
+ $elements[] = $arr[$allKeys[$num]];
+ $numElements++;
+ }
+
+ return $elements;
+ }
+
+ /**
+ * Returns a random element from a passed array
+ *
+ * @param array $array
+ * @return mixed
+ */
+ public static function randomElement($array = ['a', 'b', 'c'])
+ {
+ if (!$array || ($array instanceof \Traversable && !count($array))) {
+ return null;
+ }
+ $elements = static::randomElements($array, 1);
+
+ return $elements[0];
+ }
+
+ /**
+ * Returns a random key from a passed associative array
+ *
+ * @param array $array
+ * @return int|string|null
+ */
+ public static function randomKey($array = [])
+ {
+ if (!$array) {
+ return null;
+ }
+ $keys = array_keys($array);
+ return $keys[mt_rand(0, count($keys) - 1)];
+ }
+
+ /**
+ * Returns a shuffled version of the argument.
+ *
+ * This function accepts either an array, or a string.
+ *
+ * @example $faker->shuffle([1, 2, 3]); // [2, 1, 3]
+ * @example $faker->shuffle('hello, world'); // 'rlo,h eold!lw'
+ *
+ * @see shuffleArray()
+ * @see shuffleString()
+ *
+ * @param array|string $arg The set to shuffle
+ * @return array|string The shuffled set
+ */
+ public static function shuffle($arg = '')
+ {
+ if (is_array($arg)) {
+ return static::shuffleArray($arg);
+ }
+ if (is_string($arg)) {
+ return static::shuffleString($arg);
+ }
+ throw new \InvalidArgumentException('shuffle() only supports strings or arrays');
+ }
+
+ /**
+ * Returns a shuffled version of the array.
+ *
+ * This function does not mutate the original array. It uses the
+ * Fisher–Yates algorithm, which is unbiased, together with a Mersenne
+ * twister random generator. This function is therefore more random than
+ * PHP's shuffle() function, and it is seedable.
+ *
+ * @link http://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle
+ *
+ * @example $faker->shuffleArray([1, 2, 3]); // [2, 1, 3]
+ *
+ * @param array $array The set to shuffle
+ * @return array The shuffled set
+ */
+ public static function shuffleArray($array = [])
+ {
+ $shuffledArray = [];
+ $i = 0;
+ reset($array);
+ foreach ($array as $key => $value) {
+ if ($i == 0) {
+ $j = 0;
+ } else {
+ $j = mt_rand(0, $i);
+ }
+ if ($j == $i) {
+ $shuffledArray[]= $value;
+ } else {
+ $shuffledArray[]= $shuffledArray[$j];
+ $shuffledArray[$j] = $value;
+ }
+ $i++;
+ }
+ return $shuffledArray;
+ }
+
+ /**
+ * Returns a shuffled version of the string.
+ *
+ * This function does not mutate the original string. It uses the
+ * Fisher–Yates algorithm, which is unbiased, together with a Mersenne
+ * twister random generator. This function is therefore more random than
+ * PHP's shuffle() function, and it is seedable. Additionally, it is
+ * UTF8 safe if the mb extension is available.
+ *
+ * @link http://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle
+ *
+ * @example $faker->shuffleString('hello, world'); // 'rlo,h eold!lw'
+ *
+ * @param string $string The set to shuffle
+ * @param string $encoding The string encoding (defaults to UTF-8)
+ * @return string The shuffled set
+ */
+ public static function shuffleString($string = '', $encoding = 'UTF-8')
+ {
+ if (function_exists('mb_strlen')) {
+ // UTF8-safe str_split()
+ $array = [];
+ $strlen = mb_strlen($string, $encoding);
+ for ($i = 0; $i < $strlen; $i++) {
+ $array []= mb_substr($string, $i, 1, $encoding);
+ }
+ } else {
+ $array = str_split($string, 1);
+ }
+ return implode('', static::shuffleArray($array));
+ }
+
+ private static function replaceWildcard($string, $wildcard = '#', $callback = 'static::randomDigit')
+ {
+ if (($pos = strpos($string, $wildcard)) === false) {
+ return $string;
+ }
+ for ($i = $pos, $last = strrpos($string, $wildcard, $pos) + 1; $i < $last; $i++) {
+ if ($string[$i] === $wildcard) {
+ $string[$i] = call_user_func($callback);
+ }
+ }
+ return $string;
+ }
+
+ /**
+ * Replaces all hash sign ('#') occurrences with a random number
+ * Replaces all percentage sign ('%') occurrences with a not null number
+ *
+ * @param string $string String that needs to bet parsed
+ * @return string
+ */
+ public static function numerify($string = '###')
+ {
+ // instead of using randomDigit() several times, which is slow,
+ // count the number of hashes and generate once a large number
+ $toReplace = [];
+ if (($pos = strpos($string, '#')) !== false) {
+ for ($i = $pos, $last = strrpos($string, '#', $pos) + 1; $i < $last; $i++) {
+ if ($string[$i] === '#') {
+ $toReplace[] = $i;
+ }
+ }
+ }
+ if ($nbReplacements = count($toReplace)) {
+ $maxAtOnce = strlen((string) mt_getrandmax()) - 1;
+ $numbers = '';
+ $i = 0;
+ while ($i < $nbReplacements) {
+ $size = min($nbReplacements - $i, $maxAtOnce);
+ $numbers .= str_pad(static::randomNumber($size), $size, '0', STR_PAD_LEFT);
+ $i += $size;
+ }
+ for ($i = 0; $i < $nbReplacements; $i++) {
+ $string[$toReplace[$i]] = $numbers[$i];
+ }
+ }
+ $string = self::replaceWildcard($string, '%', 'static::randomDigitNotNull');
+
+ return $string;
+ }
+
+ /**
+ * Replaces all question mark ('?') occurrences with a random letter
+ *
+ * @param string $string String that needs to bet parsed
+ * @return string
+ */
+ public static function lexify($string = '????')
+ {
+ return self::replaceWildcard($string, '?', 'static::randomLetter');
+ }
+
+ /**
+ * Replaces hash signs ('#') and question marks ('?') with random numbers and letters
+ * An asterisk ('*') is replaced with either a random number or a random letter
+ *
+ * @param string $string String that needs to bet parsed
+ * @return string
+ */
+ public static function bothify($string = '## ??')
+ {
+ $string = self::replaceWildcard($string, '*', function () {
+ return mt_rand(0, 1) ? '#' : '?';
+ });
+ return static::lexify(static::numerify($string));
+ }
+
+ /**
+ * Replaces * signs with random numbers and letters and special characters
+ *
+ * @example $faker->asciify(''********'); // "s5'G!uC3"
+ *
+ * @param string $string String that needs to bet parsed
+ * @return string
+ */
+ public static function asciify($string = '****')
+ {
+ return preg_replace_callback('/\*/u', 'static::randomAscii', $string);
+ }
+
+ /**
+ * Transforms a basic regular expression into a random string satisfying the expression.
+ *
+ * @example $faker->regexify('[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,4}'); // sm0@y8k96a.ej
+ *
+ * Regex delimiters '/.../' and begin/end markers '^...$' are ignored.
+ *
+ * Only supports a small subset of the regex syntax. For instance,
+ * unicode, negated classes, unbounded ranges, subpatterns, back references,
+ * assertions, recursive patterns, and comments are not supported. Escaping
+ * support is extremely fragile.
+ *
+ * This method is also VERY slow. Use it only when no other formatter
+ * can generate the fake data you want. For instance, prefer calling
+ * `$faker->email` rather than `regexify` with the previous regular
+ * expression.
+ *
+ * Also note than `bothify` can probably do most of what this method does,
+ * but much faster. For instance, for a dummy email generation, try
+ * `$faker->bothify('?????????@???.???')`.
+ *
+ * @see https://github.com/icomefromthenet/ReverseRegex for a more robust implementation
+ *
+ * @param string $regex A regular expression (delimiters are optional)
+ * @return string
+ */
+ public static function regexify($regex = '')
+ {
+ // ditch the anchors
+ $regex = preg_replace('/^\/?\^?/', '', $regex);
+ $regex = preg_replace('/\$?\/?$/', '', $regex);
+ // All {2} become {2,2}
+ $regex = preg_replace('/\{(\d+)\}/', '{\1,\1}', $regex);
+ // Single-letter quantifiers (?, *, +) become bracket quantifiers ({0,1}, {0,rand}, {1, rand})
+ $regex = preg_replace('/(? 0 && $weight < 1 && mt_rand() / mt_getrandmax() <= $weight) {
+ return $this->generator;
+ }
+
+ // new system with percentage
+ if (is_int($weight) && mt_rand(1, 100) <= $weight) {
+ return $this->generator;
+ }
+
+ return new DefaultGenerator($default);
+ }
+
+ /**
+ * Chainable method for making any formatter unique.
+ *
+ *
+ * // will never return twice the same value
+ * $faker->unique()->randomElement(array(1, 2, 3));
+ *
+ *
+ * @param bool $reset If set to true, resets the list of existing values
+ * @param int $maxRetries Maximum number of retries to find a unique value,
+ * After which an OverflowException is thrown.
+ * @throws \OverflowException When no unique value can be found by iterating $maxRetries times
+ *
+ * @return UniqueGenerator A proxy class returning only non-existing values
+ */
+ public function unique($reset = false, $maxRetries = 10000)
+ {
+ if ($reset || !$this->unique) {
+ $this->unique = new UniqueGenerator($this->generator, $maxRetries);
+ }
+
+ return $this->unique;
+ }
+
+ /**
+ * Chainable method for forcing any formatter to return only valid values.
+ *
+ * The value validity is determined by a function passed as first argument.
+ *
+ *
+ * $values = array();
+ * $evenValidator = function ($digit) {
+ * return $digit % 2 === 0;
+ * };
+ * for ($i=0; $i < 10; $i++) {
+ * $values []= $faker->valid($evenValidator)->randomDigit;
+ * }
+ * print_r($values); // [0, 4, 8, 4, 2, 6, 0, 8, 8, 6]
+ *
+ *
+ * @param Closure $validator A function returning true for valid values
+ * @param int $maxRetries Maximum number of retries to find a unique value,
+ * After which an OverflowException is thrown.
+ * @throws \OverflowException When no valid value can be found by iterating $maxRetries times
+ *
+ * @return ValidGenerator A proxy class returning only valid values
+ */
+ public function valid($validator = null, $maxRetries = 10000)
+ {
+ return new ValidGenerator($this->generator, $validator, $maxRetries);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/Biased.php b/vendor/fakerphp/faker/src/Faker/Provider/Biased.php
new file mode 100644
index 00000000..dfe86fb8
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/Biased.php
@@ -0,0 +1,64 @@
+generator->parse($format);
+ }
+
+ /**
+ * @example 'Ltd'
+ *
+ * @return string
+ */
+ public static function companySuffix()
+ {
+ return static::randomElement(static::$companySuffix);
+ }
+
+ /**
+ * @example 'Job'
+ *
+ * @return string
+ */
+ public function jobTitle()
+ {
+ $format = static::randomElement(static::$jobTitleFormat);
+
+ return $this->generator->parse($format);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/DateTime.php b/vendor/fakerphp/faker/src/Faker/Provider/DateTime.php
new file mode 100644
index 00000000..b68c6d50
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/DateTime.php
@@ -0,0 +1,340 @@
+getTimestamp();
+ }
+
+ return strtotime(empty($max) ? 'now' : $max);
+ }
+
+ /**
+ * Get a timestamp between January 1, 1970 and now
+ *
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return int
+ *
+ * @example 1061306726
+ */
+ public static function unixTime($max = 'now')
+ {
+ return self::numberBetween(0, static::getMaxTimestamp($max));
+ }
+
+ /**
+ * Get a datetime object for a date between January 1, 1970 and now
+ *
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @param string $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('2005-08-16 20:39:21')
+ * @return \DateTime
+ * @see http://php.net/manual/en/timezones.php
+ * @see http://php.net/manual/en/function.date-default-timezone-get.php
+ */
+ public static function dateTime($max = 'now', $timezone = null)
+ {
+ return static::setTimezone(
+ new \DateTime('@' . static::unixTime($max)),
+ $timezone
+ );
+ }
+
+ /**
+ * Get a datetime object for a date between January 1, 001 and now
+ *
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('1265-03-22 21:15:52')
+ * @return \DateTime
+ * @see http://php.net/manual/en/timezones.php
+ * @see http://php.net/manual/en/function.date-default-timezone-get.php
+ */
+ public static function dateTimeAD($max = 'now', $timezone = null)
+ {
+ $min = (PHP_INT_SIZE > 4 ? -62135597361 : -PHP_INT_MAX);
+ return static::setTimezone(
+ new \DateTime('@' . self::numberBetween($min, static::getMaxTimestamp($max))),
+ $timezone
+ );
+ }
+
+ /**
+ * get a date string formatted with ISO8601
+ *
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '2003-10-21T16:05:52+0000'
+ */
+ public static function iso8601($max = 'now')
+ {
+ return static::date(\DateTime::ISO8601, $max);
+ }
+
+ /**
+ * Get a date string between January 1, 1970 and now
+ *
+ * @param string $format
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '2008-11-27'
+ */
+ public static function date($format = 'Y-m-d', $max = 'now')
+ {
+ return static::dateTime($max)->format($format);
+ }
+
+ /**
+ * Get a time string (24h format by default)
+ *
+ * @param string $format
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '15:02:34'
+ */
+ public static function time($format = 'H:i:s', $max = 'now')
+ {
+ return static::dateTime($max)->format($format);
+ }
+
+ /**
+ * Get a DateTime object based on a random date between two given dates.
+ * Accepts date strings that can be recognized by strtotime().
+ *
+ * @param \DateTime|string $startDate Defaults to 30 years ago
+ * @param \DateTime|string $endDate Defaults to "now"
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('1999-02-02 11:42:52')
+ * @return \DateTime
+ * @see http://php.net/manual/en/timezones.php
+ * @see http://php.net/manual/en/function.date-default-timezone-get.php
+ */
+ public static function dateTimeBetween($startDate = '-30 years', $endDate = 'now', $timezone = null)
+ {
+ $startTimestamp = $startDate instanceof \DateTime ? $startDate->getTimestamp() : strtotime($startDate);
+ $endTimestamp = static::getMaxTimestamp($endDate);
+
+ if ($startTimestamp > $endTimestamp) {
+ throw new \InvalidArgumentException('Start date must be anterior to end date.');
+ }
+
+ $timestamp = self::numberBetween($startTimestamp, $endTimestamp);
+
+ return static::setTimezone(
+ new \DateTime('@' . $timestamp),
+ $timezone
+ );
+ }
+
+ /**
+ * Get a DateTime object based on a random date between one given date and
+ * an interval
+ * Accepts date string that can be recognized by strtotime().
+ *
+ * @param \DateTime|string $date Defaults to 30 years ago
+ * @param string $interval Defaults to 5 days after
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example dateTimeInInterval('1999-02-02 11:42:52', '+ 5 days')
+ * @return \DateTime
+ * @see http://php.net/manual/en/timezones.php
+ * @see http://php.net/manual/en/function.date-default-timezone-get.php
+ */
+ public static function dateTimeInInterval($date = '-30 years', $interval = '+5 days', $timezone = null)
+ {
+ $intervalObject = \DateInterval::createFromDateString($interval);
+ $datetime = $date instanceof \DateTime ? $date : new \DateTime($date);
+ $otherDatetime = clone $datetime;
+ $otherDatetime->add($intervalObject);
+
+ $begin = $datetime > $otherDatetime ? $otherDatetime : $datetime;
+ $end = $datetime === $begin ? $otherDatetime : $datetime;
+
+ return static::dateTimeBetween(
+ $begin,
+ $end,
+ $timezone
+ );
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('1964-04-04 11:02:02')
+ * @return \DateTime
+ */
+ public static function dateTimeThisCentury($max = 'now', $timezone = null)
+ {
+ return static::dateTimeBetween('-100 year', $max, $timezone);
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('2010-03-10 05:18:58')
+ * @return \DateTime
+ */
+ public static function dateTimeThisDecade($max = 'now', $timezone = null)
+ {
+ return static::dateTimeBetween('-10 year', $max, $timezone);
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('2011-09-19 09:24:37')
+ * @return \DateTime
+ */
+ public static function dateTimeThisYear($max = 'now', $timezone = null)
+ {
+ return static::dateTimeBetween('first day of january this year', $max, $timezone);
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('2011-10-05 12:51:46')
+ * @return \DateTime
+ */
+ public static function dateTimeThisMonth($max = 'now', $timezone = null)
+ {
+ return static::dateTimeBetween('-1 month', $max, $timezone);
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example 'am'
+ */
+ public static function amPm($max = 'now')
+ {
+ return static::dateTime($max)->format('a');
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '22'
+ */
+ public static function dayOfMonth($max = 'now')
+ {
+ return static::dateTime($max)->format('d');
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example 'Tuesday'
+ */
+ public static function dayOfWeek($max = 'now')
+ {
+ return static::dateTime($max)->format('l');
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '7'
+ */
+ public static function month($max = 'now')
+ {
+ return static::dateTime($max)->format('m');
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example 'September'
+ */
+ public static function monthName($max = 'now')
+ {
+ return static::dateTime($max)->format('F');
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '1673'
+ */
+ public static function year($max = 'now')
+ {
+ return static::dateTime($max)->format('Y');
+ }
+
+ /**
+ * @return string
+ * @example 'XVII'
+ */
+ public static function century()
+ {
+ return static::randomElement(static::$century);
+ }
+
+ /**
+ * @return string
+ * @example 'Europe/Paris'
+ */
+ public static function timezone()
+ {
+ return static::randomElement(\DateTimeZone::listIdentifiers());
+ }
+
+ /**
+ * Internal method to set the time zone on a DateTime.
+ *
+ * @param \DateTime $dt
+ * @param string|null $timezone
+ *
+ * @return \DateTime
+ */
+ private static function setTimezone(\DateTime $dt, $timezone)
+ {
+ return $dt->setTimezone(new \DateTimeZone(static::resolveTimezone($timezone)));
+ }
+
+ /**
+ * Sets default time zone.
+ *
+ * @param string $timezone
+ *
+ * @return void
+ */
+ public static function setDefaultTimezone($timezone = null)
+ {
+ static::$defaultTimezone = $timezone;
+ }
+
+ /**
+ * Gets default time zone.
+ *
+ * @return string|null
+ */
+ public static function getDefaultTimezone()
+ {
+ return static::$defaultTimezone;
+ }
+
+ /**
+ * @param string|null $timezone
+ * @return null|string
+ */
+ private static function resolveTimezone($timezone)
+ {
+ return ((null === $timezone) ? ((null === static::$defaultTimezone) ? date_default_timezone_get() : static::$defaultTimezone) : $timezone);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/File.php b/vendor/fakerphp/faker/src/Faker/Provider/File.php
new file mode 100644
index 00000000..9c58ae30
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/File.php
@@ -0,0 +1,606 @@
+ file extension(s)
+ * @link http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types
+ */
+ protected static $mimeTypes = [
+ 'application/atom+xml' => 'atom',
+ 'application/ecmascript' => 'ecma',
+ 'application/emma+xml' => 'emma',
+ 'application/epub+zip' => 'epub',
+ 'application/java-archive' => 'jar',
+ 'application/java-vm' => 'class',
+ 'application/javascript' => 'js',
+ 'application/json' => 'json',
+ 'application/jsonml+json' => 'jsonml',
+ 'application/lost+xml' => 'lostxml',
+ 'application/mathml+xml' => 'mathml',
+ 'application/mets+xml' => 'mets',
+ 'application/mods+xml' => 'mods',
+ 'application/mp4' => 'mp4s',
+ 'application/msword' => ['doc', 'dot'],
+ 'application/octet-stream' => [
+ 'bin',
+ 'dms',
+ 'lrf',
+ 'mar',
+ 'so',
+ 'dist',
+ 'distz',
+ 'pkg',
+ 'bpk',
+ 'dump',
+ 'elc',
+ 'deploy'
+ ],
+ 'application/ogg' => 'ogx',
+ 'application/omdoc+xml' => 'omdoc',
+ 'application/pdf' => 'pdf',
+ 'application/pgp-encrypted' => 'pgp',
+ 'application/pgp-signature' => ['asc', 'sig'],
+ 'application/pkix-pkipath' => 'pkipath',
+ 'application/pkixcmp' => 'pki',
+ 'application/pls+xml' => 'pls',
+ 'application/postscript' => ['ai', 'eps', 'ps'],
+ 'application/pskc+xml' => 'pskcxml',
+ 'application/rdf+xml' => 'rdf',
+ 'application/reginfo+xml' => 'rif',
+ 'application/rss+xml' => 'rss',
+ 'application/rtf' => 'rtf',
+ 'application/sbml+xml' => 'sbml',
+ 'application/vnd.adobe.air-application-installer-package+zip' => 'air',
+ 'application/vnd.adobe.xdp+xml' => 'xdp',
+ 'application/vnd.adobe.xfdf' => 'xfdf',
+ 'application/vnd.ahead.space' => 'ahead',
+ 'application/vnd.dart' => 'dart',
+ 'application/vnd.data-vision.rdz' => 'rdz',
+ 'application/vnd.dece.data' => ['uvf', 'uvvf', 'uvd', 'uvvd'],
+ 'application/vnd.dece.ttml+xml' => ['uvt', 'uvvt'],
+ 'application/vnd.dece.unspecified' => ['uvx', 'uvvx'],
+ 'application/vnd.dece.zip' => ['uvz', 'uvvz'],
+ 'application/vnd.denovo.fcselayout-link' => 'fe_launch',
+ 'application/vnd.dna' => 'dna',
+ 'application/vnd.dolby.mlp' => 'mlp',
+ 'application/vnd.dpgraph' => 'dpg',
+ 'application/vnd.dreamfactory' => 'dfac',
+ 'application/vnd.ds-keypoint' => 'kpxx',
+ 'application/vnd.dvb.ait' => 'ait',
+ 'application/vnd.dvb.service' => 'svc',
+ 'application/vnd.dynageo' => 'geo',
+ 'application/vnd.ecowin.chart' => 'mag',
+ 'application/vnd.enliven' => 'nml',
+ 'application/vnd.epson.esf' => 'esf',
+ 'application/vnd.epson.msf' => 'msf',
+ 'application/vnd.epson.quickanime' => 'qam',
+ 'application/vnd.epson.salt' => 'slt',
+ 'application/vnd.epson.ssf' => 'ssf',
+ 'application/vnd.ezpix-album' => 'ez2',
+ 'application/vnd.ezpix-package' => 'ez3',
+ 'application/vnd.fdf' => 'fdf',
+ 'application/vnd.fdsn.mseed' => 'mseed',
+ 'application/vnd.fdsn.seed' => ['seed', 'dataless'],
+ 'application/vnd.flographit' => 'gph',
+ 'application/vnd.fluxtime.clip' => 'ftc',
+ 'application/vnd.hal+xml' => 'hal',
+ 'application/vnd.hydrostatix.sof-data' => 'sfd-hdstx',
+ 'application/vnd.ibm.minipay' => 'mpy',
+ 'application/vnd.ibm.secure-container' => 'sc',
+ 'application/vnd.iccprofile' => ['icc', 'icm'],
+ 'application/vnd.igloader' => 'igl',
+ 'application/vnd.immervision-ivp' => 'ivp',
+ 'application/vnd.kde.karbon' => 'karbon',
+ 'application/vnd.kde.kchart' => 'chrt',
+ 'application/vnd.kde.kformula' => 'kfo',
+ 'application/vnd.kde.kivio' => 'flw',
+ 'application/vnd.kde.kontour' => 'kon',
+ 'application/vnd.kde.kpresenter' => ['kpr', 'kpt'],
+ 'application/vnd.kde.kspread' => 'ksp',
+ 'application/vnd.kde.kword' => ['kwd', 'kwt'],
+ 'application/vnd.kenameaapp' => 'htke',
+ 'application/vnd.kidspiration' => 'kia',
+ 'application/vnd.kinar' => ['kne', 'knp'],
+ 'application/vnd.koan' => ['skp', 'skd', 'skt', 'skm'],
+ 'application/vnd.kodak-descriptor' => 'sse',
+ 'application/vnd.las.las+xml' => 'lasxml',
+ 'application/vnd.llamagraphics.life-balance.desktop' => 'lbd',
+ 'application/vnd.llamagraphics.life-balance.exchange+xml' => 'lbe',
+ 'application/vnd.lotus-1-2-3' => '123',
+ 'application/vnd.lotus-approach' => 'apr',
+ 'application/vnd.lotus-freelance' => 'pre',
+ 'application/vnd.lotus-notes' => 'nsf',
+ 'application/vnd.lotus-organizer' => 'org',
+ 'application/vnd.lotus-screencam' => 'scm',
+ 'application/vnd.mozilla.xul+xml' => 'xul',
+ 'application/vnd.ms-artgalry' => 'cil',
+ 'application/vnd.ms-cab-compressed' => 'cab',
+ 'application/vnd.ms-excel' => [
+ 'xls',
+ 'xlm',
+ 'xla',
+ 'xlc',
+ 'xlt',
+ 'xlw'
+ ],
+ 'application/vnd.ms-excel.addin.macroenabled.12' => 'xlam',
+ 'application/vnd.ms-excel.sheet.binary.macroenabled.12' => 'xlsb',
+ 'application/vnd.ms-excel.sheet.macroenabled.12' => 'xlsm',
+ 'application/vnd.ms-excel.template.macroenabled.12' => 'xltm',
+ 'application/vnd.ms-fontobject' => 'eot',
+ 'application/vnd.ms-htmlhelp' => 'chm',
+ 'application/vnd.ms-ims' => 'ims',
+ 'application/vnd.ms-lrm' => 'lrm',
+ 'application/vnd.ms-officetheme' => 'thmx',
+ 'application/vnd.ms-pki.seccat' => 'cat',
+ 'application/vnd.ms-pki.stl' => 'stl',
+ 'application/vnd.ms-powerpoint' => ['ppt', 'pps', 'pot'],
+ 'application/vnd.ms-powerpoint.addin.macroenabled.12' => 'ppam',
+ 'application/vnd.ms-powerpoint.presentation.macroenabled.12' => 'pptm',
+ 'application/vnd.ms-powerpoint.slide.macroenabled.12' => 'sldm',
+ 'application/vnd.ms-powerpoint.slideshow.macroenabled.12' => 'ppsm',
+ 'application/vnd.ms-powerpoint.template.macroenabled.12' => 'potm',
+ 'application/vnd.ms-project' => ['mpp', 'mpt'],
+ 'application/vnd.ms-word.document.macroenabled.12' => 'docm',
+ 'application/vnd.ms-word.template.macroenabled.12' => 'dotm',
+ 'application/vnd.ms-works' => ['wps', 'wks', 'wcm', 'wdb'],
+ 'application/vnd.ms-wpl' => 'wpl',
+ 'application/vnd.ms-xpsdocument' => 'xps',
+ 'application/vnd.mseq' => 'mseq',
+ 'application/vnd.musician' => 'mus',
+ 'application/vnd.oasis.opendocument.chart' => 'odc',
+ 'application/vnd.oasis.opendocument.chart-template' => 'otc',
+ 'application/vnd.oasis.opendocument.database' => 'odb',
+ 'application/vnd.oasis.opendocument.formula' => 'odf',
+ 'application/vnd.oasis.opendocument.formula-template' => 'odft',
+ 'application/vnd.oasis.opendocument.graphics' => 'odg',
+ 'application/vnd.oasis.opendocument.graphics-template' => 'otg',
+ 'application/vnd.oasis.opendocument.image' => 'odi',
+ 'application/vnd.oasis.opendocument.image-template' => 'oti',
+ 'application/vnd.oasis.opendocument.presentation' => 'odp',
+ 'application/vnd.oasis.opendocument.presentation-template' => 'otp',
+ 'application/vnd.oasis.opendocument.spreadsheet' => 'ods',
+ 'application/vnd.oasis.opendocument.spreadsheet-template' => 'ots',
+ 'application/vnd.oasis.opendocument.text' => 'odt',
+ 'application/vnd.oasis.opendocument.text-master' => 'odm',
+ 'application/vnd.oasis.opendocument.text-template' => 'ott',
+ 'application/vnd.oasis.opendocument.text-web' => 'oth',
+ 'application/vnd.olpc-sugar' => 'xo',
+ 'application/vnd.oma.dd2+xml' => 'dd2',
+ 'application/vnd.openofficeorg.extension' => 'oxt',
+ 'application/vnd.openxmlformats-officedocument.presentationml.presentation' => 'pptx',
+ 'application/vnd.openxmlformats-officedocument.presentationml.slide' => 'sldx',
+ 'application/vnd.openxmlformats-officedocument.presentationml.slideshow' => 'ppsx',
+ 'application/vnd.openxmlformats-officedocument.presentationml.template' => 'potx',
+ 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' => 'xlsx',
+ 'application/vnd.openxmlformats-officedocument.spreadsheetml.template' => 'xltx',
+ 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' => 'docx',
+ 'application/vnd.openxmlformats-officedocument.wordprocessingml.template' => 'dotx',
+ 'application/vnd.pvi.ptid1' => 'ptid',
+ 'application/vnd.quark.quarkxpress' => [
+ 'qxd',
+ 'qxt',
+ 'qwd',
+ 'qwt',
+ 'qxl',
+ 'qxb'
+ ],
+ 'application/vnd.realvnc.bed' => 'bed',
+ 'application/vnd.recordare.musicxml' => 'mxl',
+ 'application/vnd.recordare.musicxml+xml' => 'musicxml',
+ 'application/vnd.rig.cryptonote' => 'cryptonote',
+ 'application/vnd.rim.cod' => 'cod',
+ 'application/vnd.rn-realmedia' => 'rm',
+ 'application/vnd.rn-realmedia-vbr' => 'rmvb',
+ 'application/vnd.route66.link66+xml' => 'link66',
+ 'application/vnd.sailingtracker.track' => 'st',
+ 'application/vnd.seemail' => 'see',
+ 'application/vnd.sema' => 'sema',
+ 'application/vnd.semd' => 'semd',
+ 'application/vnd.semf' => 'semf',
+ 'application/vnd.shana.informed.formdata' => 'ifm',
+ 'application/vnd.shana.informed.formtemplate' => 'itp',
+ 'application/vnd.shana.informed.interchange' => 'iif',
+ 'application/vnd.shana.informed.package' => 'ipk',
+ 'application/vnd.simtech-mindmapper' => ['twd', 'twds'],
+ 'application/vnd.smaf' => 'mmf',
+ 'application/vnd.stepmania.stepchart' => 'sm',
+ 'application/vnd.sun.xml.calc' => 'sxc',
+ 'application/vnd.sun.xml.calc.template' => 'stc',
+ 'application/vnd.sun.xml.draw' => 'sxd',
+ 'application/vnd.sun.xml.draw.template' => 'std',
+ 'application/vnd.sun.xml.impress' => 'sxi',
+ 'application/vnd.sun.xml.impress.template' => 'sti',
+ 'application/vnd.sun.xml.math' => 'sxm',
+ 'application/vnd.sun.xml.writer' => 'sxw',
+ 'application/vnd.sun.xml.writer.global' => 'sxg',
+ 'application/vnd.sun.xml.writer.template' => 'stw',
+ 'application/vnd.sus-calendar' => ['sus', 'susp'],
+ 'application/vnd.svd' => 'svd',
+ 'application/vnd.symbian.install' => ['sis', 'sisx'],
+ 'application/vnd.syncml+xml' => 'xsm',
+ 'application/vnd.syncml.dm+wbxml' => 'bdm',
+ 'application/vnd.syncml.dm+xml' => 'xdm',
+ 'application/vnd.tao.intent-module-archive' => 'tao',
+ 'application/vnd.tcpdump.pcap' => ['pcap', 'cap', 'dmp'],
+ 'application/vnd.tmobile-livetv' => 'tmo',
+ 'application/vnd.trid.tpt' => 'tpt',
+ 'application/vnd.triscape.mxs' => 'mxs',
+ 'application/vnd.trueapp' => 'tra',
+ 'application/vnd.ufdl' => ['ufd', 'ufdl'],
+ 'application/vnd.uiq.theme' => 'utz',
+ 'application/vnd.umajin' => 'umj',
+ 'application/vnd.unity' => 'unityweb',
+ 'application/vnd.uoml+xml' => 'uoml',
+ 'application/vnd.vcx' => 'vcx',
+ 'application/vnd.visio' => ['vsd', 'vst', 'vss', 'vsw'],
+ 'application/vnd.visionary' => 'vis',
+ 'application/vnd.vsf' => 'vsf',
+ 'application/vnd.wap.wbxml' => 'wbxml',
+ 'application/vnd.wap.wmlc' => 'wmlc',
+ 'application/vnd.wap.wmlscriptc' => 'wmlsc',
+ 'application/vnd.webturbo' => 'wtb',
+ 'application/vnd.wolfram.player' => 'nbp',
+ 'application/vnd.wordperfect' => 'wpd',
+ 'application/vnd.wqd' => 'wqd',
+ 'application/vnd.wt.stf' => 'stf',
+ 'application/vnd.xara' => 'xar',
+ 'application/vnd.xfdl' => 'xfdl',
+ 'application/voicexml+xml' => 'vxml',
+ 'application/widget' => 'wgt',
+ 'application/winhlp' => 'hlp',
+ 'application/wsdl+xml' => 'wsdl',
+ 'application/wspolicy+xml' => 'wspolicy',
+ 'application/x-7z-compressed' => '7z',
+ 'application/x-bittorrent' => 'torrent',
+ 'application/x-blorb' => ['blb', 'blorb'],
+ 'application/x-bzip' => 'bz',
+ 'application/x-cdlink' => 'vcd',
+ 'application/x-cfs-compressed' => 'cfs',
+ 'application/x-chat' => 'chat',
+ 'application/x-chess-pgn' => 'pgn',
+ 'application/x-conference' => 'nsc',
+ 'application/x-cpio' => 'cpio',
+ 'application/x-csh' => 'csh',
+ 'application/x-debian-package' => ['deb', 'udeb'],
+ 'application/x-dgc-compressed' => 'dgc',
+ 'application/x-director' => [
+ 'dir',
+ 'dcr',
+ 'dxr',
+ 'cst',
+ 'cct',
+ 'cxt',
+ 'w3d',
+ 'fgd',
+ 'swa'
+ ],
+ 'application/x-font-ttf' => ['ttf', 'ttc'],
+ 'application/x-font-type1' => ['pfa', 'pfb', 'pfm', 'afm'],
+ 'application/x-font-woff' => 'woff',
+ 'application/x-freearc' => 'arc',
+ 'application/x-futuresplash' => 'spl',
+ 'application/x-gca-compressed' => 'gca',
+ 'application/x-glulx' => 'ulx',
+ 'application/x-gnumeric' => 'gnumeric',
+ 'application/x-gramps-xml' => 'gramps',
+ 'application/x-gtar' => 'gtar',
+ 'application/x-hdf' => 'hdf',
+ 'application/x-install-instructions' => 'install',
+ 'application/x-iso9660-image' => 'iso',
+ 'application/x-java-jnlp-file' => 'jnlp',
+ 'application/x-latex' => 'latex',
+ 'application/x-lzh-compressed' => ['lzh', 'lha'],
+ 'application/x-mie' => 'mie',
+ 'application/x-mobipocket-ebook' => ['prc', 'mobi'],
+ 'application/x-ms-application' => 'application',
+ 'application/x-ms-shortcut' => 'lnk',
+ 'application/x-ms-wmd' => 'wmd',
+ 'application/x-ms-wmz' => 'wmz',
+ 'application/x-ms-xbap' => 'xbap',
+ 'application/x-msaccess' => 'mdb',
+ 'application/x-msbinder' => 'obd',
+ 'application/x-mscardfile' => 'crd',
+ 'application/x-msclip' => 'clp',
+ 'application/x-msdownload' => ['exe', 'dll', 'com', 'bat', 'msi'],
+ 'application/x-msmediaview' => [
+ 'mvb',
+ 'm13',
+ 'm14'
+ ],
+ 'application/x-msmetafile' => ['wmf', 'wmz', 'emf', 'emz'],
+ 'application/x-rar-compressed' => 'rar',
+ 'application/x-research-info-systems' => 'ris',
+ 'application/x-sh' => 'sh',
+ 'application/x-shar' => 'shar',
+ 'application/x-shockwave-flash' => 'swf',
+ 'application/x-silverlight-app' => 'xap',
+ 'application/x-sql' => 'sql',
+ 'application/x-stuffit' => 'sit',
+ 'application/x-stuffitx' => 'sitx',
+ 'application/x-subrip' => 'srt',
+ 'application/x-sv4cpio' => 'sv4cpio',
+ 'application/x-sv4crc' => 'sv4crc',
+ 'application/x-t3vm-image' => 't3',
+ 'application/x-tads' => 'gam',
+ 'application/x-tar' => 'tar',
+ 'application/x-tcl' => 'tcl',
+ 'application/x-tex' => 'tex',
+ 'application/x-tex-tfm' => 'tfm',
+ 'application/x-texinfo' => ['texinfo', 'texi'],
+ 'application/x-tgif' => 'obj',
+ 'application/x-ustar' => 'ustar',
+ 'application/x-wais-source' => 'src',
+ 'application/x-x509-ca-cert' => ['der', 'crt'],
+ 'application/x-xfig' => 'fig',
+ 'application/x-xliff+xml' => 'xlf',
+ 'application/x-xpinstall' => 'xpi',
+ 'application/x-xz' => 'xz',
+ 'application/x-zmachine' => 'z1',
+ 'application/xaml+xml' => 'xaml',
+ 'application/xcap-diff+xml' => 'xdf',
+ 'application/xenc+xml' => 'xenc',
+ 'application/xhtml+xml' => ['xhtml', 'xht'],
+ 'application/xml' => ['xml', 'xsl'],
+ 'application/xml-dtd' => 'dtd',
+ 'application/xop+xml' => 'xop',
+ 'application/xproc+xml' => 'xpl',
+ 'application/xslt+xml' => 'xslt',
+ 'application/xspf+xml' => 'xspf',
+ 'application/xv+xml' => ['mxml', 'xhvml', 'xvml', 'xvm'],
+ 'application/yang' => 'yang',
+ 'application/yin+xml' => 'yin',
+ 'application/zip' => 'zip',
+ 'audio/adpcm' => 'adp',
+ 'audio/basic' => ['au', 'snd'],
+ 'audio/midi' => ['mid', 'midi', 'kar', 'rmi'],
+ 'audio/mp4' => 'mp4a',
+ 'audio/mpeg' => [
+ 'mpga',
+ 'mp2',
+ 'mp2a',
+ 'mp3',
+ 'm2a',
+ 'm3a'
+ ],
+ 'audio/ogg' => ['oga', 'ogg', 'spx'],
+ 'audio/vnd.dece.audio' => ['uva', 'uvva'],
+ 'audio/vnd.rip' => 'rip',
+ 'audio/webm' => 'weba',
+ 'audio/x-aac' => 'aac',
+ 'audio/x-aiff' => ['aif', 'aiff', 'aifc'],
+ 'audio/x-caf' => 'caf',
+ 'audio/x-flac' => 'flac',
+ 'audio/x-matroska' => 'mka',
+ 'audio/x-mpegurl' => 'm3u',
+ 'audio/x-ms-wax' => 'wax',
+ 'audio/x-ms-wma' => 'wma',
+ 'audio/x-pn-realaudio' => ['ram', 'ra'],
+ 'audio/x-pn-realaudio-plugin' => 'rmp',
+ 'audio/x-wav' => 'wav',
+ 'audio/xm' => 'xm',
+ 'image/bmp' => 'bmp',
+ 'image/cgm' => 'cgm',
+ 'image/g3fax' => 'g3',
+ 'image/gif' => 'gif',
+ 'image/ief' => 'ief',
+ 'image/jpeg' => ['jpeg', 'jpg', 'jpe'],
+ 'image/ktx' => 'ktx',
+ 'image/png' => 'png',
+ 'image/prs.btif' => 'btif',
+ 'image/sgi' => 'sgi',
+ 'image/svg+xml' => ['svg', 'svgz'],
+ 'image/tiff' => ['tiff', 'tif'],
+ 'image/vnd.adobe.photoshop' => 'psd',
+ 'image/vnd.dece.graphic' => ['uvi', 'uvvi', 'uvg', 'uvvg'],
+ 'image/vnd.dvb.subtitle' => 'sub',
+ 'image/vnd.djvu' => ['djvu', 'djv'],
+ 'image/vnd.dwg' => 'dwg',
+ 'image/vnd.dxf' => 'dxf',
+ 'image/vnd.fastbidsheet' => 'fbs',
+ 'image/vnd.fpx' => 'fpx',
+ 'image/vnd.fst' => 'fst',
+ 'image/vnd.fujixerox.edmics-mmr' => 'mmr',
+ 'image/vnd.fujixerox.edmics-rlc' => 'rlc',
+ 'image/vnd.ms-modi' => 'mdi',
+ 'image/vnd.ms-photo' => 'wdp',
+ 'image/vnd.net-fpx' => 'npx',
+ 'image/vnd.wap.wbmp' => 'wbmp',
+ 'image/vnd.xiff' => 'xif',
+ 'image/webp' => 'webp',
+ 'image/x-3ds' => '3ds',
+ 'image/x-cmu-raster' => 'ras',
+ 'image/x-cmx' => 'cmx',
+ 'image/x-freehand' => ['fh', 'fhc', 'fh4', 'fh5', 'fh7'],
+ 'image/x-icon' => 'ico',
+ 'image/x-mrsid-image' => 'sid',
+ 'image/x-pcx' => 'pcx',
+ 'image/x-pict' => ['pic', 'pct'],
+ 'image/x-portable-anymap' => 'pnm',
+ 'image/x-portable-bitmap' => 'pbm',
+ 'image/x-portable-graymap' => 'pgm',
+ 'image/x-portable-pixmap' => 'ppm',
+ 'image/x-rgb' => 'rgb',
+ 'image/x-tga' => 'tga',
+ 'image/x-xbitmap' => 'xbm',
+ 'image/x-xpixmap' => 'xpm',
+ 'image/x-xwindowdump' => 'xwd',
+ 'message/rfc822' => ['eml', 'mime'],
+ 'model/iges' => ['igs', 'iges'],
+ 'model/mesh' => ['msh', 'mesh', 'silo'],
+ 'model/vnd.collada+xml' => 'dae',
+ 'model/vnd.dwf' => 'dwf',
+ 'model/vnd.gdl' => 'gdl',
+ 'model/vnd.gtw' => 'gtw',
+ 'model/vnd.mts' => 'mts',
+ 'model/vnd.vtu' => 'vtu',
+ 'model/vrml' => ['wrl', 'vrml'],
+ 'model/x3d+binary' => 'x3db',
+ 'model/x3d+vrml' => 'x3dv',
+ 'model/x3d+xml' => 'x3d',
+ 'text/cache-manifest' => 'appcache',
+ 'text/calendar' => ['ics', 'ifb'],
+ 'text/css' => 'css',
+ 'text/csv' => 'csv',
+ 'text/html' => ['html', 'htm'],
+ 'text/n3' => 'n3',
+ 'text/plain' => [
+ 'txt',
+ 'text',
+ 'conf',
+ 'def',
+ 'list',
+ 'log',
+ 'in'
+ ],
+ 'text/prs.lines.tag' => 'dsc',
+ 'text/richtext' => 'rtx',
+ 'text/sgml' => ['sgml', 'sgm'],
+ 'text/tab-separated-values' => 'tsv',
+ 'text/troff' => [
+ 't',
+ 'tr',
+ 'roff',
+ 'man',
+ 'me',
+ 'ms'
+ ],
+ 'text/turtle' => 'ttl',
+ 'text/uri-list' => ['uri', 'uris', 'urls'],
+ 'text/vcard' => 'vcard',
+ 'text/vnd.curl' => 'curl',
+ 'text/vnd.curl.dcurl' => 'dcurl',
+ 'text/vnd.curl.scurl' => 'scurl',
+ 'text/vnd.curl.mcurl' => 'mcurl',
+ 'text/vnd.dvb.subtitle' => 'sub',
+ 'text/vnd.fly' => 'fly',
+ 'text/vnd.fmi.flexstor' => 'flx',
+ 'text/vnd.graphviz' => 'gv',
+ 'text/vnd.in3d.3dml' => '3dml',
+ 'text/vnd.in3d.spot' => 'spot',
+ 'text/vnd.sun.j2me.app-descriptor' => 'jad',
+ 'text/vnd.wap.wml' => 'wml',
+ 'text/vnd.wap.wmlscript' => 'wmls',
+ 'text/x-asm' => ['s', 'asm'],
+ 'text/x-fortran' => ['f', 'for', 'f77', 'f90'],
+ 'text/x-java-source' => 'java',
+ 'text/x-opml' => 'opml',
+ 'text/x-pascal' => ['p', 'pas'],
+ 'text/x-nfo' => 'nfo',
+ 'text/x-setext' => 'etx',
+ 'text/x-sfv' => 'sfv',
+ 'text/x-uuencode' => 'uu',
+ 'text/x-vcalendar' => 'vcs',
+ 'text/x-vcard' => 'vcf',
+ 'video/3gpp' => '3gp',
+ 'video/3gpp2' => '3g2',
+ 'video/h261' => 'h261',
+ 'video/h263' => 'h263',
+ 'video/h264' => 'h264',
+ 'video/jpeg' => 'jpgv',
+ 'video/jpm' => ['jpm', 'jpgm'],
+ 'video/mj2' => 'mj2',
+ 'video/mp4' => 'mp4',
+ 'video/mpeg' => ['mpeg', 'mpg', 'mpe', 'm1v', 'm2v'],
+ 'video/ogg' => 'ogv',
+ 'video/quicktime' => ['qt', 'mov'],
+ 'video/vnd.dece.hd' => ['uvh', 'uvvh'],
+ 'video/vnd.dece.mobile' => ['uvm', 'uvvm'],
+ 'video/vnd.dece.pd' => ['uvp', 'uvvp'],
+ 'video/vnd.dece.sd' => ['uvs', 'uvvs'],
+ 'video/vnd.dece.video' => ['uvv', 'uvvv'],
+ 'video/vnd.dvb.file' => 'dvb',
+ 'video/vnd.fvt' => 'fvt',
+ 'video/vnd.mpegurl' => ['mxu', 'm4u'],
+ 'video/vnd.ms-playready.media.pyv' => 'pyv',
+ 'video/vnd.uvvu.mp4' => ['uvu', 'uvvu'],
+ 'video/vnd.vivo' => 'viv',
+ 'video/webm' => 'webm',
+ 'video/x-f4v' => 'f4v',
+ 'video/x-fli' => 'fli',
+ 'video/x-flv' => 'flv',
+ 'video/x-m4v' => 'm4v',
+ 'video/x-matroska' => ['mkv', 'mk3d', 'mks'],
+ 'video/x-mng' => 'mng',
+ 'video/x-ms-asf' => ['asf', 'asx'],
+ 'video/x-ms-vob' => 'vob',
+ 'video/x-ms-wm' => 'wm',
+ 'video/x-ms-wmv' => 'wmv',
+ 'video/x-ms-wmx' => 'wmx',
+ 'video/x-ms-wvx' => 'wvx',
+ 'video/x-msvideo' => 'avi',
+ 'video/x-sgi-movie' => 'movie',
+ ];
+
+ /**
+ * Get a random MIME type
+ *
+ * @return string
+ * @example 'video/avi'
+ */
+ public static function mimeType()
+ {
+ return static::randomElement(array_keys(static::$mimeTypes));
+ }
+
+ /**
+ * Get a random file extension (without a dot)
+ *
+ * @example avi
+ * @return string
+ */
+ public static function fileExtension()
+ {
+ $random_extension = static::randomElement(array_values(static::$mimeTypes));
+
+ return is_array($random_extension) ? static::randomElement($random_extension) : $random_extension;
+ }
+
+ /**
+ * Copy a random file from the source directory to the target directory and returns the filename/fullpath
+ *
+ * @param string $sourceDirectory The directory to look for random file taking
+ * @param string $targetDirectory
+ * @param bool $fullPath Whether to have the full path or just the filename
+ * @return string
+ */
+ public static function file($sourceDirectory = '/tmp', $targetDirectory = '/tmp', $fullPath = true)
+ {
+ if (!is_dir($sourceDirectory)) {
+ throw new \InvalidArgumentException(sprintf('Source directory %s does not exist or is not a directory.', $sourceDirectory));
+ }
+
+ if (!is_dir($targetDirectory)) {
+ throw new \InvalidArgumentException(sprintf('Target directory %s does not exist or is not a directory.', $targetDirectory));
+ }
+
+ if ($sourceDirectory == $targetDirectory) {
+ throw new \InvalidArgumentException('Source and target directories must differ.');
+ }
+
+ // Drop . and .. and reset array keys
+ $files = array_filter(array_values(array_diff(scandir($sourceDirectory), ['.', '..'])), function ($file) use ($sourceDirectory) {
+ return is_file($sourceDirectory . DIRECTORY_SEPARATOR . $file) && is_readable($sourceDirectory . DIRECTORY_SEPARATOR . $file);
+ });
+
+ if (empty($files)) {
+ throw new \InvalidArgumentException(sprintf('Source directory %s is empty.', $sourceDirectory));
+ }
+
+ $sourceFullPath = $sourceDirectory . DIRECTORY_SEPARATOR . static::randomElement($files);
+
+ $destinationFile = Uuid::uuid() . '.' . pathinfo($sourceFullPath, PATHINFO_EXTENSION);
+ $destinationFullPath = $targetDirectory . DIRECTORY_SEPARATOR . $destinationFile;
+
+ if (false === copy($sourceFullPath, $destinationFullPath)) {
+ return false;
+ }
+
+ return $fullPath ? $destinationFullPath : $destinationFile;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/HtmlLorem.php b/vendor/fakerphp/faker/src/Faker/Provider/HtmlLorem.php
new file mode 100644
index 00000000..cce2608f
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/HtmlLorem.php
@@ -0,0 +1,273 @@
+addProvider(new Lorem($generator));
+ $generator->addProvider(new Internet($generator));
+ }
+
+ /**
+ * @param int $maxDepth
+ * @param int $maxWidth
+ *
+ * @return string
+ */
+ public function randomHtml($maxDepth = 4, $maxWidth = 4)
+ {
+ $document = new \DOMDocument();
+ $this->idGenerator = new UniqueGenerator($this->generator);
+
+ $head = $document->createElement('head');
+ $this->addRandomTitle($head);
+
+ $body = $document->createElement('body');
+ $this->addLoginForm($body);
+ $this->addRandomSubTree($body, $maxDepth, $maxWidth);
+
+ $html = $document->createElement('html');
+ $html->appendChild($head);
+ $html->appendChild($body);
+
+ $document->appendChild($html);
+ return $document->saveHTML();
+ }
+
+ private function addRandomSubTree(\DOMElement $root, $maxDepth, $maxWidth)
+ {
+ $maxDepth--;
+ if ($maxDepth <= 0) {
+ return $root;
+ }
+
+ $siblings = self::numberBetween(1, $maxWidth);
+ for ($i = 0; $i < $siblings; $i++) {
+ if ($maxDepth == 1) {
+ $this->addRandomLeaf($root);
+ } else {
+ $sibling = $root->ownerDocument->createElement('div');
+ $root->appendChild($sibling);
+ $this->addRandomAttribute($sibling);
+ $this->addRandomSubTree($sibling, self::numberBetween(0, $maxDepth), $maxWidth);
+ }
+ }
+ return $root;
+ }
+
+ private function addRandomLeaf(\DOMElement $node)
+ {
+ $rand = self::numberBetween(1, 10);
+ switch ($rand) {
+ case 1:
+ $this->addRandomP($node);
+ break;
+ case 2:
+ $this->addRandomA($node);
+ break;
+ case 3:
+ $this->addRandomSpan($node);
+ break;
+ case 4:
+ $this->addRandomUL($node);
+ break;
+ case 5:
+ $this->addRandomH($node);
+ break;
+ case 6:
+ $this->addRandomB($node);
+ break;
+ case 7:
+ $this->addRandomI($node);
+ break;
+ case 8:
+ $this->addRandomTable($node);
+ break;
+ default:
+ $this->addRandomText($node);
+ break;
+ }
+ }
+
+ private function addRandomAttribute(\DOMElement $node)
+ {
+ $rand = self::numberBetween(1, 2);
+ switch ($rand) {
+ case 1:
+ $node->setAttribute('class', $this->generator->word);
+ break;
+ case 2:
+ $node->setAttribute('id', (string) $this->idGenerator->randomNumber(5));
+ break;
+ }
+ }
+
+ private function addRandomP(\DOMElement $element, $maxLength = 10)
+ {
+ $node = $element->ownerDocument->createElement(static::P_TAG);
+ $node->textContent = $this->generator->sentence(self::numberBetween(1, $maxLength));
+ $element->appendChild($node);
+ }
+
+ private function addRandomText(\DOMElement $element, $maxLength = 10)
+ {
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(self::numberBetween(1, $maxLength)));
+ $element->appendChild($text);
+ }
+
+ private function addRandomA(\DOMElement $element, $maxLength = 10)
+ {
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(self::numberBetween(1, $maxLength)));
+ $node = $element->ownerDocument->createElement(static::A_TAG);
+ $node->setAttribute('href', $this->generator->safeEmailDomain);
+ $node->appendChild($text);
+ $element->appendChild($node);
+ }
+
+ private function addRandomTitle(\DOMElement $element, $maxLength = 10)
+ {
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(self::numberBetween(1, $maxLength)));
+ $node = $element->ownerDocument->createElement(static::TITLE_TAG);
+ $node->appendChild($text);
+ $element->appendChild($node);
+ }
+
+ private function addRandomH(\DOMElement $element, $maxLength = 10)
+ {
+ $h = static::H_TAG . (string) self::numberBetween(1, 3);
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(self::numberBetween(1, $maxLength)));
+ $node = $element->ownerDocument->createElement($h);
+ $node->appendChild($text);
+ $element->appendChild($node);
+ }
+
+ private function addRandomB(\DOMElement $element, $maxLength = 10)
+ {
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(self::numberBetween(1, $maxLength)));
+ $node = $element->ownerDocument->createElement(static::B_TAG);
+ $node->appendChild($text);
+ $element->appendChild($node);
+ }
+
+ private function addRandomI(\DOMElement $element, $maxLength = 10)
+ {
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(self::numberBetween(1, $maxLength)));
+ $node = $element->ownerDocument->createElement(static::I_TAG);
+ $node->appendChild($text);
+ $element->appendChild($node);
+ }
+
+ private function addRandomSpan(\DOMElement $element, $maxLength = 10)
+ {
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(self::numberBetween(1, $maxLength)));
+ $node = $element->ownerDocument->createElement(static::SPAN_TAG);
+ $node->appendChild($text);
+ $element->appendChild($node);
+ }
+
+ private function addLoginForm(\DOMElement $element)
+ {
+ $textInput = $element->ownerDocument->createElement(static::INPUT_TAG);
+ $textInput->setAttribute('type', 'text');
+ $textInput->setAttribute('id', 'username');
+
+ $textLabel = $element->ownerDocument->createElement(static::LABEL_TAG);
+ $textLabel->setAttribute('for', 'username');
+ $textLabel->textContent = $this->generator->word;
+
+ $passwordInput = $element->ownerDocument->createElement(static::INPUT_TAG);
+ $passwordInput->setAttribute('type', 'password');
+ $passwordInput->setAttribute('id', 'password');
+
+ $passwordLabel = $element->ownerDocument->createElement(static::LABEL_TAG);
+ $passwordLabel->setAttribute('for', 'password');
+ $passwordLabel->textContent = $this->generator->word;
+
+ $submit = $element->ownerDocument->createElement(static::INPUT_TAG);
+ $submit->setAttribute('type', 'submit');
+ $submit->setAttribute('value', $this->generator->word);
+
+ $submit = $element->ownerDocument->createElement(static::FORM_TAG);
+ $submit->setAttribute('action', $this->generator->safeEmailDomain);
+ $submit->setAttribute('method', 'POST');
+ $submit->appendChild($textLabel);
+ $submit->appendChild($textInput);
+ $submit->appendChild($passwordLabel);
+ $submit->appendChild($passwordInput);
+ $element->appendChild($submit);
+ }
+
+ private function addRandomTable(\DOMElement $element, $maxRows = 10, $maxCols = 6, $maxTitle = 4, $maxLength = 10)
+ {
+ $rows = self::numberBetween(1, $maxRows);
+ $cols = self::numberBetween(1, $maxCols);
+
+ $table = $element->ownerDocument->createElement(static::TABLE_TAG);
+ $thead = $element->ownerDocument->createElement(static::THEAD_TAG);
+ $tbody = $element->ownerDocument->createElement(static::TBODY_TAG);
+
+ $table->appendChild($thead);
+ $table->appendChild($tbody);
+
+ $tr = $element->ownerDocument->createElement(static::TR_TAG);
+ $thead->appendChild($tr);
+ for ($i = 0; $i < $cols; $i++) {
+ $th = $element->ownerDocument->createElement(static::TH_TAG);
+ $th->textContent = $this->generator->sentence(self::numberBetween(1, $maxTitle));
+ $tr->appendChild($th);
+ }
+ for ($i = 0; $i < $rows; $i++) {
+ $tr = $element->ownerDocument->createElement(static::TR_TAG);
+ $tbody->appendChild($tr);
+ for ($j = 0; $j < $cols; $j++) {
+ $th = $element->ownerDocument->createElement(static::TD_TAG);
+ $th->textContent = $this->generator->sentence(self::numberBetween(1, $maxLength));
+ $tr->appendChild($th);
+ }
+ }
+ $element->appendChild($table);
+ }
+
+ private function addRandomUL(\DOMElement $element, $maxItems = 11, $maxLength = 4)
+ {
+ $num = self::numberBetween(1, $maxItems);
+ $ul = $element->ownerDocument->createElement(static::UL_TAG);
+ for ($i = 0; $i < $num; $i++) {
+ $li = $element->ownerDocument->createElement(static::LI_TAG);
+ $li->textContent = $this->generator->sentence(self::numberBetween(1, $maxLength));
+ $ul->appendChild($li);
+ }
+ $element->appendChild($ul);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/Image.php b/vendor/fakerphp/faker/src/Faker/Provider/Image.php
new file mode 100644
index 00000000..6e6d8510
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/Image.php
@@ -0,0 +1,126 @@
+ 0 ? '?text=' . urlencode(implode(' ', $imageParts)) : ''
+ );
+ }
+
+ /**
+ * Download a remote random image to disk and return its location
+ *
+ * Requires curl, or allow_url_fopen to be on in php.ini.
+ *
+ * @example '/path/to/dir/13b73edae8443990be1aa8f1a483bc27.png'
+ */
+ public static function image(
+ $dir = null,
+ $width = 640,
+ $height = 480,
+ $category = null,
+ $fullPath = true,
+ $randomize = true,
+ $word = null,
+ $gray = false
+ ) {
+ $dir = is_null($dir) ? sys_get_temp_dir() : $dir; // GNU/Linux / OS X / Windows compatible
+ // Validate directory path
+ if (!is_dir($dir) || !is_writable($dir)) {
+ throw new \InvalidArgumentException(sprintf('Cannot write to directory "%s"', $dir));
+ }
+
+ // Generate a random filename. Use the server address so that a file
+ // generated at the same time on a different server won't have a collision.
+ $name = md5(uniqid(empty($_SERVER['SERVER_ADDR']) ? '' : $_SERVER['SERVER_ADDR'], true));
+ $filename = $name . '.png';
+ $filepath = $dir . DIRECTORY_SEPARATOR . $filename;
+
+ $url = static::imageUrl($width, $height, $category, $randomize, $word, $gray);
+
+ // save file
+ if (function_exists('curl_exec')) {
+ // use cURL
+ $fp = fopen($filepath, 'w');
+ $ch = curl_init($url);
+ curl_setopt($ch, CURLOPT_FILE, $fp);
+ $success = curl_exec($ch) && curl_getinfo($ch, CURLINFO_HTTP_CODE) === 200;
+ fclose($fp);
+ curl_close($ch);
+
+ if (!$success) {
+ unlink($filepath);
+
+ // could not contact the distant URL or HTTP error - fail silently.
+ return false;
+ }
+ } elseif (ini_get('allow_url_fopen')) {
+ // use remote fopen() via copy()
+ $success = copy($url, $filepath);
+ } else {
+ return new \RuntimeException('The image formatter downloads an image from a remote HTTP server. Therefore, it requires that PHP can request remote hosts, either via cURL or fopen()');
+ }
+
+ return $fullPath ? $filepath : $filename;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/Internet.php
new file mode 100644
index 00000000..51963f22
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/Internet.php
@@ -0,0 +1,368 @@
+generator->parse($format);
+ }
+
+ /**
+ * @example 'jdoe@example.com'
+ */
+ final public function safeEmail()
+ {
+ return preg_replace('/\s/u', '', $this->userName() . '@' . static::safeEmailDomain());
+ }
+
+ /**
+ * @example 'jdoe@gmail.com'
+ */
+ public function freeEmail()
+ {
+ return preg_replace('/\s/u', '', $this->userName() . '@' . static::freeEmailDomain());
+ }
+
+ /**
+ * @example 'jdoe@dawson.com'
+ */
+ public function companyEmail()
+ {
+ return preg_replace('/\s/u', '', $this->userName() . '@' . $this->domainName());
+ }
+
+ /**
+ * @example 'gmail.com'
+ */
+ public static function freeEmailDomain()
+ {
+ return static::randomElement(static::$freeEmailDomain);
+ }
+
+ /**
+ * @example 'example.org'
+ */
+ final public static function safeEmailDomain()
+ {
+ $domains = [
+ 'example.com',
+ 'example.org',
+ 'example.net'
+ ];
+
+ return static::randomElement($domains);
+ }
+ /**
+ * @example 'jdoe'
+ */
+ public function userName()
+ {
+ $format = static::randomElement(static::$userNameFormats);
+ $username = static::bothify($this->generator->parse($format));
+
+ $username = strtolower(static::transliterate($username));
+
+ // check if transliterate() didn't support the language and removed all letters
+ if (trim($username, '._') === '') {
+ throw new \Exception('userName failed with the selected locale. Try a different locale or activate the "intl" PHP extension.');
+ }
+
+ // clean possible trailing dots from first/last names
+ $username = str_replace('..', '.', $username);
+ $username = rtrim($username, '.');
+
+ return $username;
+ }
+ /**
+ * @example 'fY4èHdZv68'
+ */
+ public function password($minLength = 6, $maxLength = 20)
+ {
+ $pattern = str_repeat('*', $this->numberBetween($minLength, $maxLength));
+
+ return $this->asciify($pattern);
+ }
+
+ /**
+ * @example 'tiramisu.com'
+ */
+ public function domainName()
+ {
+ return $this->domainWord() . '.' . $this->tld();
+ }
+
+ /**
+ * @example 'faber'
+ */
+ public function domainWord()
+ {
+ $lastName = $this->generator->format('lastName');
+
+ $lastName = strtolower(static::transliterate($lastName));
+
+ // check if transliterate() didn't support the language and removed all letters
+ if (trim($lastName, '._') === '') {
+ throw new \Exception('domainWord failed with the selected locale. Try a different locale or activate the "intl" PHP extension.');
+ }
+
+ // clean possible trailing dot from last name
+ $lastName = rtrim($lastName, '.');
+
+ return $lastName;
+ }
+
+ /**
+ * @example 'com'
+ */
+ public function tld()
+ {
+ return static::randomElement(static::$tld);
+ }
+
+ /**
+ * @example 'http://www.runolfsdottir.com/'
+ */
+ public function url()
+ {
+ $format = static::randomElement(static::$urlFormats);
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * @example 'aut-repellat-commodi-vel-itaque-nihil-id-saepe-nostrum'
+ */
+ public function slug($nbWords = 6, $variableNbWords = true)
+ {
+ if ($nbWords <= 0) {
+ return '';
+ }
+ if ($variableNbWords) {
+ $nbWords = (int) ($nbWords * self::numberBetween(60, 140) / 100) + 1;
+ }
+ $words = $this->generator->words($nbWords);
+
+ return implode('-', $words);
+ }
+
+ /**
+ * @example '237.149.115.38'
+ */
+ public function ipv4()
+ {
+ return long2ip(Miscellaneous::boolean() ? self::numberBetween(-2147483648, -2) : self::numberBetween(16777216, 2147483647));
+ }
+
+ /**
+ * @example '35cd:186d:3e23:2986:ef9f:5b41:42a4:e6f1'
+ */
+ public function ipv6()
+ {
+ $res = [];
+ for ($i=0; $i < 8; $i++) {
+ $res []= dechex(self::numberBetween(0, 65535));
+ }
+
+ return implode(':', $res);
+ }
+
+ /**
+ * @example '10.1.1.17'
+ */
+ public static function localIpv4()
+ {
+ $ipBlock = self::randomElement(static::$localIpBlocks);
+
+ return long2ip(static::numberBetween(ip2long($ipBlock[0]), ip2long($ipBlock[1])));
+ }
+
+ /**
+ * @example '32:F1:39:2F:D6:18'
+ */
+ public static function macAddress()
+ {
+ $mac = [];
+
+ for ($i=0; $i < 6; $i++) {
+ $mac[] = sprintf('%02X', self::numberBetween(0, 0xff));
+ }
+
+ return implode(':', $mac);
+ }
+
+ protected static function transliterate($string)
+ {
+ if (0 === preg_match('/[^A-Za-z0-9_.]/', $string)) {
+ return $string;
+ }
+
+ $transId = 'Any-Latin; Latin-ASCII; NFD; [:Nonspacing Mark:] Remove; NFC;';
+ if (class_exists('Transliterator', false) && $transliterator = \Transliterator::create($transId)) {
+ $transString = $transliterator->transliterate($string);
+ } else {
+ $transString = static::toAscii($string);
+ }
+
+ return preg_replace('/[^A-Za-z0-9_.]/u', '', $transString);
+ }
+
+ protected static function toAscii($string)
+ {
+ static $arrayFrom, $arrayTo;
+
+ if (empty($arrayFrom)) {
+ $transliterationTable = [
+ 'IJ'=>'I', 'Ö'=>'O', 'Œ'=>'O', 'Ü'=>'U', 'ä'=>'a', 'æ'=>'a',
+ 'ij'=>'i', 'ö'=>'o', 'œ'=>'o', 'ü'=>'u', 'ß'=>'s', 'ſ'=>'s',
+ 'À'=>'A', 'Á'=>'A', 'Â'=>'A', 'Ã'=>'A', 'Ä'=>'A', 'Å'=>'A',
+ 'Æ'=>'A', 'Ā'=>'A', 'Ą'=>'A', 'Ă'=>'A', 'Ç'=>'C', 'Ć'=>'C',
+ 'Č'=>'C', 'Ĉ'=>'C', 'Ċ'=>'C', 'Ď'=>'D', 'Đ'=>'D', 'È'=>'E',
+ 'É'=>'E', 'Ê'=>'E', 'Ë'=>'E', 'Ē'=>'E', 'Ę'=>'E', 'Ě'=>'E',
+ 'Ĕ'=>'E', 'Ė'=>'E', 'Ĝ'=>'G', 'Ğ'=>'G', 'Ġ'=>'G', 'Ģ'=>'G',
+ 'Ĥ'=>'H', 'Ħ'=>'H', 'Ì'=>'I', 'Í'=>'I', 'Î'=>'I', 'Ï'=>'I',
+ 'Ī'=>'I', 'Ĩ'=>'I', 'Ĭ'=>'I', 'Į'=>'I', 'İ'=>'I', 'Ĵ'=>'J',
+ 'Ķ'=>'K', 'Ľ'=>'K', 'Ĺ'=>'K', 'Ļ'=>'K', 'Ŀ'=>'K', 'Ł'=>'L',
+ 'Ñ'=>'N', 'Ń'=>'N', 'Ň'=>'N', 'Ņ'=>'N', 'Ŋ'=>'N', 'Ò'=>'O',
+ 'Ó'=>'O', 'Ô'=>'O', 'Õ'=>'O', 'Ø'=>'O', 'Ō'=>'O', 'Ő'=>'O',
+ 'Ŏ'=>'O', 'Ŕ'=>'R', 'Ř'=>'R', 'Ŗ'=>'R', 'Ś'=>'S', 'Ş'=>'S',
+ 'Ŝ'=>'S', 'Ș'=>'S', 'Š'=>'S', 'Ť'=>'T', 'Ţ'=>'T', 'Ŧ'=>'T',
+ 'Ț'=>'T', 'Ù'=>'U', 'Ú'=>'U', 'Û'=>'U', 'Ū'=>'U', 'Ů'=>'U',
+ 'Ű'=>'U', 'Ŭ'=>'U', 'Ũ'=>'U', 'Ų'=>'U', 'Ŵ'=>'W', 'Ŷ'=>'Y',
+ 'Ÿ'=>'Y', 'Ý'=>'Y', 'Ź'=>'Z', 'Ż'=>'Z', 'Ž'=>'Z', 'à'=>'a',
+ 'á'=>'a', 'â'=>'a', 'ã'=>'a', 'ā'=>'a', 'ą'=>'a', 'ă'=>'a',
+ 'å'=>'a', 'ç'=>'c', 'ć'=>'c', 'č'=>'c', 'ĉ'=>'c', 'ċ'=>'c',
+ 'ď'=>'d', 'đ'=>'d', 'è'=>'e', 'é'=>'e', 'ê'=>'e', 'ë'=>'e',
+ 'ē'=>'e', 'ę'=>'e', 'ě'=>'e', 'ĕ'=>'e', 'ė'=>'e', 'ƒ'=>'f',
+ 'ĝ'=>'g', 'ğ'=>'g', 'ġ'=>'g', 'ģ'=>'g', 'ĥ'=>'h', 'ħ'=>'h',
+ 'ì'=>'i', 'í'=>'i', 'î'=>'i', 'ï'=>'i', 'ī'=>'i', 'ĩ'=>'i',
+ 'ĭ'=>'i', 'į'=>'i', 'ı'=>'i', 'ĵ'=>'j', 'ķ'=>'k', 'ĸ'=>'k',
+ 'ł'=>'l', 'ľ'=>'l', 'ĺ'=>'l', 'ļ'=>'l', 'ŀ'=>'l', 'ñ'=>'n',
+ 'ń'=>'n', 'ň'=>'n', 'ņ'=>'n', 'ʼn'=>'n', 'ŋ'=>'n', 'ò'=>'o',
+ 'ó'=>'o', 'ô'=>'o', 'õ'=>'o', 'ø'=>'o', 'ō'=>'o', 'ő'=>'o',
+ 'ŏ'=>'o', 'ŕ'=>'r', 'ř'=>'r', 'ŗ'=>'r', 'ś'=>'s', 'š'=>'s',
+ 'ť'=>'t', 'ù'=>'u', 'ú'=>'u', 'û'=>'u', 'ū'=>'u', 'ů'=>'u',
+ 'ű'=>'u', 'ŭ'=>'u', 'ũ'=>'u', 'ų'=>'u', 'ŵ'=>'w', 'ÿ'=>'y',
+ 'ý'=>'y', 'ŷ'=>'y', 'ż'=>'z', 'ź'=>'z', 'ž'=>'z', 'Α'=>'A',
+ 'Ά'=>'A', 'Ἀ'=>'A', 'Ἁ'=>'A', 'Ἂ'=>'A', 'Ἃ'=>'A', 'Ἄ'=>'A',
+ 'Ἅ'=>'A', 'Ἆ'=>'A', 'Ἇ'=>'A', 'ᾈ'=>'A', 'ᾉ'=>'A', 'ᾊ'=>'A',
+ 'ᾋ'=>'A', 'ᾌ'=>'A', 'ᾍ'=>'A', 'ᾎ'=>'A', 'ᾏ'=>'A', 'Ᾰ'=>'A',
+ 'Ᾱ'=>'A', 'Ὰ'=>'A', 'ᾼ'=>'A', 'Β'=>'B', 'Γ'=>'G', 'Δ'=>'D',
+ 'Ε'=>'E', 'Έ'=>'E', 'Ἐ'=>'E', 'Ἑ'=>'E', 'Ἒ'=>'E', 'Ἓ'=>'E',
+ 'Ἔ'=>'E', 'Ἕ'=>'E', 'Ὲ'=>'E', 'Ζ'=>'Z', 'Η'=>'I', 'Ή'=>'I',
+ 'Ἠ'=>'I', 'Ἡ'=>'I', 'Ἢ'=>'I', 'Ἣ'=>'I', 'Ἤ'=>'I', 'Ἥ'=>'I',
+ 'Ἦ'=>'I', 'Ἧ'=>'I', 'ᾘ'=>'I', 'ᾙ'=>'I', 'ᾚ'=>'I', 'ᾛ'=>'I',
+ 'ᾜ'=>'I', 'ᾝ'=>'I', 'ᾞ'=>'I', 'ᾟ'=>'I', 'Ὴ'=>'I', 'ῌ'=>'I',
+ 'Θ'=>'T', 'Ι'=>'I', 'Ί'=>'I', 'Ϊ'=>'I', 'Ἰ'=>'I', 'Ἱ'=>'I',
+ 'Ἲ'=>'I', 'Ἳ'=>'I', 'Ἴ'=>'I', 'Ἵ'=>'I', 'Ἶ'=>'I', 'Ἷ'=>'I',
+ 'Ῐ'=>'I', 'Ῑ'=>'I', 'Ὶ'=>'I', 'Κ'=>'K', 'Λ'=>'L', 'Μ'=>'M',
+ 'Ν'=>'N', 'Ξ'=>'K', 'Ο'=>'O', 'Ό'=>'O', 'Ὀ'=>'O', 'Ὁ'=>'O',
+ 'Ὂ'=>'O', 'Ὃ'=>'O', 'Ὄ'=>'O', 'Ὅ'=>'O', 'Ὸ'=>'O', 'Π'=>'P',
+ 'Ρ'=>'R', 'Ῥ'=>'R', 'Σ'=>'S', 'Τ'=>'T', 'Υ'=>'Y', 'Ύ'=>'Y',
+ 'Ϋ'=>'Y', 'Ὑ'=>'Y', 'Ὓ'=>'Y', 'Ὕ'=>'Y', 'Ὗ'=>'Y', 'Ῠ'=>'Y',
+ 'Ῡ'=>'Y', 'Ὺ'=>'Y', 'Φ'=>'F', 'Χ'=>'X', 'Ψ'=>'P', 'Ω'=>'O',
+ 'Ώ'=>'O', 'Ὠ'=>'O', 'Ὡ'=>'O', 'Ὢ'=>'O', 'Ὣ'=>'O', 'Ὤ'=>'O',
+ 'Ὥ'=>'O', 'Ὦ'=>'O', 'Ὧ'=>'O', 'ᾨ'=>'O', 'ᾩ'=>'O', 'ᾪ'=>'O',
+ 'ᾫ'=>'O', 'ᾬ'=>'O', 'ᾭ'=>'O', 'ᾮ'=>'O', 'ᾯ'=>'O', 'Ὼ'=>'O',
+ 'ῼ'=>'O', 'α'=>'a', 'ά'=>'a', 'ἀ'=>'a', 'ἁ'=>'a', 'ἂ'=>'a',
+ 'ἃ'=>'a', 'ἄ'=>'a', 'ἅ'=>'a', 'ἆ'=>'a', 'ἇ'=>'a', 'ᾀ'=>'a',
+ 'ᾁ'=>'a', 'ᾂ'=>'a', 'ᾃ'=>'a', 'ᾄ'=>'a', 'ᾅ'=>'a', 'ᾆ'=>'a',
+ 'ᾇ'=>'a', 'ὰ'=>'a', 'ᾰ'=>'a', 'ᾱ'=>'a', 'ᾲ'=>'a', 'ᾳ'=>'a',
+ 'ᾴ'=>'a', 'ᾶ'=>'a', 'ᾷ'=>'a', 'β'=>'b', 'γ'=>'g', 'δ'=>'d',
+ 'ε'=>'e', 'έ'=>'e', 'ἐ'=>'e', 'ἑ'=>'e', 'ἒ'=>'e', 'ἓ'=>'e',
+ 'ἔ'=>'e', 'ἕ'=>'e', 'ὲ'=>'e', 'ζ'=>'z', 'η'=>'i', 'ή'=>'i',
+ 'ἠ'=>'i', 'ἡ'=>'i', 'ἢ'=>'i', 'ἣ'=>'i', 'ἤ'=>'i', 'ἥ'=>'i',
+ 'ἦ'=>'i', 'ἧ'=>'i', 'ᾐ'=>'i', 'ᾑ'=>'i', 'ᾒ'=>'i', 'ᾓ'=>'i',
+ 'ᾔ'=>'i', 'ᾕ'=>'i', 'ᾖ'=>'i', 'ᾗ'=>'i', 'ὴ'=>'i', 'ῂ'=>'i',
+ 'ῃ'=>'i', 'ῄ'=>'i', 'ῆ'=>'i', 'ῇ'=>'i', 'θ'=>'t', 'ι'=>'i',
+ 'ί'=>'i', 'ϊ'=>'i', 'ΐ'=>'i', 'ἰ'=>'i', 'ἱ'=>'i', 'ἲ'=>'i',
+ 'ἳ'=>'i', 'ἴ'=>'i', 'ἵ'=>'i', 'ἶ'=>'i', 'ἷ'=>'i', 'ὶ'=>'i',
+ 'ῐ'=>'i', 'ῑ'=>'i', 'ῒ'=>'i', 'ῖ'=>'i', 'ῗ'=>'i', 'κ'=>'k',
+ 'λ'=>'l', 'μ'=>'m', 'ν'=>'n', 'ξ'=>'k', 'ο'=>'o', 'ό'=>'o',
+ 'ὀ'=>'o', 'ὁ'=>'o', 'ὂ'=>'o', 'ὃ'=>'o', 'ὄ'=>'o', 'ὅ'=>'o',
+ 'ὸ'=>'o', 'π'=>'p', 'ρ'=>'r', 'ῤ'=>'r', 'ῥ'=>'r', 'σ'=>'s',
+ 'ς'=>'s', 'τ'=>'t', 'υ'=>'y', 'ύ'=>'y', 'ϋ'=>'y', 'ΰ'=>'y',
+ 'ὐ'=>'y', 'ὑ'=>'y', 'ὒ'=>'y', 'ὓ'=>'y', 'ὔ'=>'y', 'ὕ'=>'y',
+ 'ὖ'=>'y', 'ὗ'=>'y', 'ὺ'=>'y', 'ῠ'=>'y', 'ῡ'=>'y', 'ῢ'=>'y',
+ 'ῦ'=>'y', 'ῧ'=>'y', 'φ'=>'f', 'χ'=>'x', 'ψ'=>'p', 'ω'=>'o',
+ 'ώ'=>'o', 'ὠ'=>'o', 'ὡ'=>'o', 'ὢ'=>'o', 'ὣ'=>'o', 'ὤ'=>'o',
+ 'ὥ'=>'o', 'ὦ'=>'o', 'ὧ'=>'o', 'ᾠ'=>'o', 'ᾡ'=>'o', 'ᾢ'=>'o',
+ 'ᾣ'=>'o', 'ᾤ'=>'o', 'ᾥ'=>'o', 'ᾦ'=>'o', 'ᾧ'=>'o', 'ὼ'=>'o',
+ 'ῲ'=>'o', 'ῳ'=>'o', 'ῴ'=>'o', 'ῶ'=>'o', 'ῷ'=>'o', 'А'=>'A',
+ 'Б'=>'B', 'В'=>'V', 'Г'=>'G', 'Д'=>'D', 'Е'=>'E', 'Ё'=>'E',
+ 'Ж'=>'Z', 'З'=>'Z', 'И'=>'I', 'Й'=>'I', 'К'=>'K', 'Л'=>'L',
+ 'М'=>'M', 'Н'=>'N', 'О'=>'O', 'П'=>'P', 'Р'=>'R', 'С'=>'S',
+ 'Т'=>'T', 'У'=>'U', 'Ф'=>'F', 'Х'=>'K', 'Ц'=>'T', 'Ч'=>'C',
+ 'Ш'=>'S', 'Щ'=>'S', 'Ы'=>'Y', 'Э'=>'E', 'Ю'=>'Y', 'Я'=>'Y',
+ 'а'=>'A', 'б'=>'B', 'в'=>'V', 'г'=>'G', 'д'=>'D', 'е'=>'E',
+ 'ё'=>'E', 'ж'=>'Z', 'з'=>'Z', 'и'=>'I', 'й'=>'I', 'к'=>'K',
+ 'л'=>'L', 'м'=>'M', 'н'=>'N', 'о'=>'O', 'п'=>'P', 'р'=>'R',
+ 'с'=>'S', 'т'=>'T', 'у'=>'U', 'ф'=>'F', 'х'=>'K', 'ц'=>'T',
+ 'ч'=>'C', 'ш'=>'S', 'щ'=>'S', 'ы'=>'Y', 'э'=>'E', 'ю'=>'Y',
+ 'я'=>'Y', 'ð'=>'d', 'Ð'=>'D', 'þ'=>'t', 'Þ'=>'T', 'ა'=>'a',
+ 'ბ'=>'b', 'გ'=>'g', 'დ'=>'d', 'ე'=>'e', 'ვ'=>'v', 'ზ'=>'z',
+ 'თ'=>'t', 'ი'=>'i', 'კ'=>'k', 'ლ'=>'l', 'მ'=>'m', 'ნ'=>'n',
+ 'ო'=>'o', 'პ'=>'p', 'ჟ'=>'z', 'რ'=>'r', 'ს'=>'s', 'ტ'=>'t',
+ 'უ'=>'u', 'ფ'=>'p', 'ქ'=>'k', 'ღ'=>'g', 'ყ'=>'q', 'შ'=>'s',
+ 'ჩ'=>'c', 'ც'=>'t', 'ძ'=>'d', 'წ'=>'t', 'ჭ'=>'c', 'ხ'=>'k',
+ 'ჯ'=>'j', 'ჰ'=>'h', 'ţ'=>'t', 'ʼ'=>"'", '̧'=>'', 'ḩ'=>'h',
+ '‘'=>"'", '’'=>"'", 'ừ'=>'u', '/'=>'', 'ế'=>'e', 'ả'=>'a',
+ 'ị'=>'i', 'ậ'=>'a', 'ệ'=>'e', 'ỉ'=>'i', 'ồ'=>'o', 'ề'=>'e',
+ 'ơ'=>'o', 'ạ'=>'a', 'ẵ'=>'a', 'ư'=>'u', 'ằ'=>'a', 'ầ'=>'a',
+ 'ḑ'=>'d', 'Ḩ'=>'H', 'Ḑ'=>'D', 'ș'=>'s', 'ț'=>'t', 'ộ'=>'o',
+ 'ắ'=>'a', 'ş'=>'s', "'"=>'', 'ու'=>'u', 'ա'=>'a', 'բ'=>'b',
+ 'գ'=>'g', 'դ'=>'d', 'ե'=>'e', 'զ'=>'z', 'է'=>'e', 'ը'=>'y',
+ 'թ'=>'t', 'ժ'=>'zh', 'ի'=>'i', 'լ'=>'l', 'խ'=>'kh', 'ծ'=>'ts',
+ 'կ'=>'k', 'հ'=>'h', 'ձ'=>'dz', 'ղ'=>'gh', 'ճ'=>'ch', 'մ'=>'m',
+ 'յ'=>'y', 'ն'=>'n', 'շ'=>'sh', 'ո'=>'o', 'չ'=>'ch', 'պ'=>'p',
+ 'ջ'=>'j', 'ռ'=>'r', 'ս'=>'s', 'վ'=>'v', 'տ'=>'t', 'ր'=>'r',
+ 'ց'=>'ts', 'փ'=>'p', 'ք'=>'q', 'և'=>'ev', 'օ'=>'o', 'ֆ'=>'f',
+ ];
+ $arrayFrom = array_keys($transliterationTable);
+ $arrayTo = array_values($transliterationTable);
+ }
+
+ return str_replace($arrayFrom, $arrayTo, $string);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/Lorem.php b/vendor/fakerphp/faker/src/Faker/Provider/Lorem.php
new file mode 100644
index 00000000..6c36461c
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/Lorem.php
@@ -0,0 +1,203 @@
+generator->parse('{{bloodType}}{{bloodRh}}');
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/Miscellaneous.php b/vendor/fakerphp/faker/src/Faker/Provider/Miscellaneous.php
new file mode 100644
index 00000000..ed2a5594
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/Miscellaneous.php
@@ -0,0 +1,323 @@
+ [
+ '4539###########',
+ '4556###########',
+ '4916###########',
+ '4532###########',
+ '4929###########',
+ '40240071#######',
+ '4485###########',
+ '4716###########',
+ '4##############'
+ ],
+ 'Visa Retired' => [
+ '4539########',
+ '4556########',
+ '4916########',
+ '4532########',
+ '4929########',
+ '40240071####',
+ '4485########',
+ '4716########',
+ '4###########',
+ ],
+ 'MasterCard' => [
+ '2221###########',
+ '23#############',
+ '24#############',
+ '25#############',
+ '26#############',
+ '2720###########',
+ '51#############',
+ '52#############',
+ '53#############',
+ '54#############',
+ '55#############'
+ ],
+ 'American Express' => [
+ '34############',
+ '37############'
+ ],
+ 'Discover Card' => [
+ '6011###########'
+ ],
+ 'JCB' => [
+ '3528###########',
+ '3589###########',
+ ],
+ ];
+
+ /**
+ * @var array list of IBAN formats, source: @link https://www.swift.com/standards/data-standards/iban
+ */
+ protected static $ibanFormats = [
+ 'AD' => [['n', 4], ['n', 4], ['c', 12]],
+ 'AE' => [['n', 3], ['n', 16]],
+ 'AL' => [['n', 8], ['c', 16]],
+ 'AT' => [['n', 5], ['n', 11]],
+ 'AZ' => [['a', 4], ['c', 20]],
+ 'BA' => [['n', 3], ['n', 3], ['n', 8], ['n', 2]],
+ 'BE' => [['n', 3], ['n', 7], ['n', 2]],
+ 'BG' => [['a', 4], ['n', 4], ['n', 2], ['c', 8]],
+ 'BH' => [['a', 4], ['c', 14]],
+ 'BR' => [['n', 8], ['n', 5], ['n', 10], ['a', 1], ['c', 1]],
+ 'CH' => [['n', 5], ['c', 12]],
+ 'CR' => [['n', 4], ['n', 14]],
+ 'CY' => [['n', 3], ['n', 5], ['c', 16]],
+ 'CZ' => [['n', 4], ['n', 6], ['n', 10]],
+ 'DE' => [['n', 8], ['n', 10]],
+ 'DK' => [['n', 4], ['n', 9], ['n', 1]],
+ 'DO' => [['c', 4], ['n', 20]],
+ 'EE' => [['n', 2], ['n', 2], ['n', 11], ['n', 1]],
+ 'ES' => [['n', 4], ['n', 4], ['n', 1], ['n', 1], ['n', 10]],
+ 'FI' => [['n', 6], ['n', 7], ['n', 1]],
+ 'FR' => [['n', 5], ['n', 5], ['c', 11], ['n', 2]],
+ 'GB' => [['a', 4], ['n', 6], ['n', 8]],
+ 'GE' => [['a', 2], ['n', 16]],
+ 'GI' => [['a', 4], ['c', 15]],
+ 'GR' => [['n', 3], ['n', 4], ['c', 16]],
+ 'GT' => [['c', 4], ['c', 20]],
+ 'HR' => [['n', 7], ['n', 10]],
+ 'HU' => [['n', 3], ['n', 4], ['n', 1], ['n', 15], ['n', 1]],
+ 'IE' => [['a', 4], ['n', 6], ['n', 8]],
+ 'IL' => [['n', 3], ['n', 3], ['n', 13]],
+ 'IS' => [['n', 4], ['n', 2], ['n', 6], ['n', 10]],
+ 'IT' => [['a', 1], ['n', 5], ['n', 5], ['c', 12]],
+ 'KW' => [['a', 4], ['n', 22]],
+ 'KZ' => [['n', 3], ['c', 13]],
+ 'LB' => [['n', 4], ['c', 20]],
+ 'LI' => [['n', 5], ['c', 12]],
+ 'LT' => [['n', 5], ['n', 11]],
+ 'LU' => [['n', 3], ['c', 13]],
+ 'LV' => [['a', 4], ['c', 13]],
+ 'MC' => [['n', 5], ['n', 5], ['c', 11], ['n', 2]],
+ 'MD' => [['c', 2], ['c', 18]],
+ 'ME' => [['n', 3], ['n', 13], ['n', 2]],
+ 'MK' => [['n', 3], ['c', 10], ['n', 2]],
+ 'MR' => [['n', 5], ['n', 5], ['n', 11], ['n', 2]],
+ 'MT' => [['a', 4], ['n', 5], ['c', 18]],
+ 'MU' => [['a', 4], ['n', 2], ['n', 2], ['n', 12], ['n', 3], ['a', 3]],
+ 'NL' => [['a', 4], ['n', 10]],
+ 'NO' => [['n', 4], ['n', 6], ['n', 1]],
+ 'PK' => [['a', 4], ['c', 16]],
+ 'PL' => [['n', 8], ['n', 16]],
+ 'PS' => [['a', 4], ['c', 21]],
+ 'PT' => [['n', 4], ['n', 4], ['n', 11], ['n', 2]],
+ 'RO' => [['a', 4], ['c', 16]],
+ 'RS' => [['n', 3], ['n', 13], ['n', 2]],
+ 'SA' => [['n', 2], ['c', 18]],
+ 'SE' => [['n', 3], ['n', 16], ['n', 1]],
+ 'SI' => [['n', 5], ['n', 8], ['n', 2]],
+ 'SK' => [['n', 4], ['n', 6], ['n', 10]],
+ 'SM' => [['a', 1], ['n', 5], ['n', 5], ['c', 12]],
+ 'TN' => [['n', 2], ['n', 3], ['n', 13], ['n', 2]],
+ 'TR' => [['n', 5], ['n', 1], ['c', 16]],
+ 'VG' => [['a', 4], ['n', 16]],
+ ];
+
+ /**
+ * @return string Returns a credit card vendor name
+ *
+ * @example 'MasterCard'
+ */
+ public static function creditCardType()
+ {
+ return static::randomElement(static::$cardVendors);
+ }
+
+ /**
+ * Returns the String of a credit card number.
+ *
+ * @param string $type Supporting any of 'Visa', 'MasterCard', 'American Express', 'Discover' and 'JCB'
+ * @param bool $formatted Set to true if the output string should contain one separator every 4 digits
+ * @param string $separator Separator string for formatting card number. Defaults to dash (-).
+ * @return string
+ *
+ * @example '4485480221084675'
+ */
+ public static function creditCardNumber($type = null, $formatted = false, $separator = '-')
+ {
+ if (is_null($type)) {
+ $type = static::creditCardType();
+ }
+ $mask = static::randomElement(static::$cardParams[$type]);
+
+ $number = static::numerify($mask);
+ $number .= Luhn::computeCheckDigit($number);
+
+ if ($formatted) {
+ $p1 = substr($number, 0, 4);
+ $p2 = substr($number, 4, 4);
+ $p3 = substr($number, 8, 4);
+ $p4 = substr($number, 12);
+ $number = $p1 . $separator . $p2 . $separator . $p3 . $separator . $p4;
+ }
+
+ return $number;
+ }
+
+ /**
+ * @param bool $valid True (by default) to get a valid expiration date, false to get a maybe valid date
+ * @return \DateTime
+ * @example 04/13
+ */
+ public function creditCardExpirationDate($valid = true)
+ {
+ if ($valid) {
+ return $this->generator->dateTimeBetween('now', '36 months');
+ }
+
+ return $this->generator->dateTimeBetween('-36 months', '36 months');
+ }
+
+ /**
+ * @param bool $valid True (by default) to get a valid expiration date, false to get a maybe valid date
+ * @param string $expirationDateFormat
+ * @return string
+ * @example '04/13'
+ */
+ public function creditCardExpirationDateString($valid = true, $expirationDateFormat = null)
+ {
+ return $this->creditCardExpirationDate($valid)->format(is_null($expirationDateFormat) ? static::$expirationDateFormat : $expirationDateFormat);
+ }
+
+ /**
+ * @param bool $valid True (by default) to get a valid expiration date, false to get a maybe valid date
+ * @return array
+ */
+ public function creditCardDetails($valid = true)
+ {
+ $type = static::creditCardType();
+
+ return [
+ 'type' => $type,
+ 'number' => static::creditCardNumber($type),
+ 'name' => $this->generator->name(),
+ 'expirationDate' => $this->creditCardExpirationDateString($valid)
+ ];
+ }
+
+ /**
+ * International Bank Account Number (IBAN)
+ *
+ * @link http://en.wikipedia.org/wiki/International_Bank_Account_Number
+ * @param string $countryCode ISO 3166-1 alpha-2 country code
+ * @param string $prefix for generating bank account number of a specific bank
+ * @param int $length total length without country code and 2 check digits
+ * @return string
+ */
+ public static function iban($countryCode = null, $prefix = '', $length = null)
+ {
+ $countryCode = is_null($countryCode) ? self::randomKey(self::$ibanFormats) : strtoupper($countryCode);
+
+ $format = !isset(static::$ibanFormats[$countryCode]) ? null : static::$ibanFormats[$countryCode];
+ if ($length === null) {
+ if ($format === null) {
+ $length = 24;
+ } else {
+ $length = 0;
+ foreach ($format as $part) {
+ list($class, $groupCount) = $part;
+ $length += $groupCount;
+ }
+ }
+ }
+ if ($format === null) {
+ $format = [['n', $length]];
+ }
+
+ $expandedFormat = '';
+ foreach ($format as $item) {
+ list($class, $length) = $item;
+ $expandedFormat .= str_repeat($class, $length);
+ }
+
+ $result = $prefix;
+ $expandedFormat = substr($expandedFormat, strlen($result));
+ foreach (str_split($expandedFormat) as $class) {
+ switch ($class) {
+ default:
+ case 'c':
+ $result .= Miscellaneous::boolean() ? static::randomDigit() : strtoupper(static::randomLetter());
+ break;
+ case 'a':
+ $result .= strtoupper(static::randomLetter());
+ break;
+ case 'n':
+ $result .= static::randomDigit();
+ break;
+ }
+ }
+
+ $checksum = Iban::checksum($countryCode . '00' . $result);
+
+ return $countryCode . $checksum . $result;
+ }
+
+ /**
+ * Return the String of a SWIFT/BIC number
+ *
+ * @example 'RZTIAT22263'
+ * @link http://en.wikipedia.org/wiki/ISO_9362
+ * @return string Swift/Bic number
+ */
+ public static function swiftBicNumber()
+ {
+ return self::regexify('^([A-Z]){4}([A-Z]){2}([0-9A-Z]){2}([0-9A-Z]{3})?$');
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/Person.php b/vendor/fakerphp/faker/src/Faker/Provider/Person.php
new file mode 100644
index 00000000..a44490fe
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/Person.php
@@ -0,0 +1,126 @@
+generator->parse($format);
+ }
+
+ /**
+ * @param string|null $gender 'male', 'female' or null for any
+ * @return string
+ * @example 'John'
+ */
+ public function firstName($gender = null)
+ {
+ if ($gender === static::GENDER_MALE) {
+ return static::firstNameMale();
+ } elseif ($gender === static::GENDER_FEMALE) {
+ return static::firstNameFemale();
+ }
+
+ return $this->generator->parse(static::randomElement(static::$firstNameFormat));
+ }
+
+ public static function firstNameMale()
+ {
+ return static::randomElement(static::$firstNameMale);
+ }
+
+ public static function firstNameFemale()
+ {
+ return static::randomElement(static::$firstNameFemale);
+ }
+
+ /**
+ * @example 'Doe'
+ * @return string
+ */
+ public function lastName()
+ {
+ return static::randomElement(static::$lastName);
+ }
+
+ /**
+ * @example 'Mrs.'
+ * @param string|null $gender 'male', 'female' or null for any
+ * @return string
+ */
+ public function title($gender = null)
+ {
+ if ($gender === static::GENDER_MALE) {
+ return static::titleMale();
+ } elseif ($gender === static::GENDER_FEMALE) {
+ return static::titleFemale();
+ }
+
+ return $this->generator->parse(static::randomElement(static::$titleFormat));
+ }
+
+ /**
+ * @example 'Mr.'
+ */
+ public static function titleMale()
+ {
+ return static::randomElement(static::$titleMale);
+ }
+
+ /**
+ * @example 'Mrs.'
+ */
+ public static function titleFemale()
+ {
+ return static::randomElement(static::$titleFemale);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/PhoneNumber.php
new file mode 100644
index 00000000..1adc4063
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/PhoneNumber.php
@@ -0,0 +1,43 @@
+generator->parse(static::randomElement(static::$formats)));
+ }
+
+ /**
+ * @example +27113456789
+ * @return string
+ */
+ public function e164PhoneNumber()
+ {
+ $formats = ['+%############'];
+ return static::numerify($this->generator->parse(static::randomElement($formats)));
+ }
+
+ /**
+ * International Mobile Equipment Identity (IMEI)
+ *
+ * @link http://en.wikipedia.org/wiki/International_Mobile_Station_Equipment_Identity
+ * @link http://imei-number.com/imei-validation-check/
+ * @example '720084494799532'
+ * @return int $imei
+ */
+ public function imei()
+ {
+ $imei = (string) static::numerify('##############');
+ $imei .= Luhn::computeCheckDigit($imei);
+ return $imei;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/Text.php b/vendor/fakerphp/faker/src/Faker/Provider/Text.php
new file mode 100644
index 00000000..6de01239
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/Text.php
@@ -0,0 +1,141 @@
+ 5) {
+ throw new \InvalidArgumentException('indexSize must be at most 5');
+ }
+
+ $words = $this->getConsecutiveWords($indexSize);
+ $result = [];
+ $resultLength = 0;
+ // take a random starting point
+ $next = static::randomKey($words);
+ while ($resultLength < $maxNbChars && isset($words[$next])) {
+ // fetch a random word to append
+ $word = static::randomElement($words[$next]);
+
+ // calculate next index
+ $currentWords = static::explode($next);
+ $currentWords[] = $word;
+ array_shift($currentWords);
+ $next = static::implode($currentWords);
+
+ // ensure text starts with an uppercase letter
+ if ($resultLength == 0 && !static::validStart($word)) {
+ continue;
+ }
+
+ // append the element
+ $result[] = $word;
+ $resultLength += static::strlen($word) + static::$separatorLen;
+ }
+
+ // remove the element that caused the text to overflow
+ array_pop($result);
+
+ // build result
+ $result = static::implode($result);
+
+ return static::appendEnd($result);
+ }
+
+ protected function getConsecutiveWords($indexSize)
+ {
+ if (!isset($this->consecutiveWords[$indexSize])) {
+ $parts = $this->getExplodedText();
+ $words = [];
+ $index = [];
+ for ($i = 0; $i < $indexSize; $i++) {
+ $index[] = array_shift($parts);
+ }
+
+ for ($i = 0, $count = count($parts); $i < $count; $i++) {
+ $stringIndex = static::implode($index);
+ if (!isset($words[$stringIndex])) {
+ $words[$stringIndex] = [];
+ }
+ $word = $parts[$i];
+ $words[$stringIndex][] = $word;
+ array_shift($index);
+ $index[] = $word;
+ }
+ // cache look up words for performance
+ $this->consecutiveWords[$indexSize] = $words;
+ }
+
+ return $this->consecutiveWords[$indexSize];
+ }
+
+ protected function getExplodedText()
+ {
+ if ($this->explodedText === null) {
+ $this->explodedText = static::explode(preg_replace('/\s+/u', ' ', static::$baseText));
+ }
+
+ return $this->explodedText;
+ }
+
+ protected static function explode($text)
+ {
+ return explode(static::$separator, $text);
+ }
+
+ protected static function implode($words)
+ {
+ return implode(static::$separator, $words);
+ }
+
+ protected static function strlen($text)
+ {
+ return function_exists('mb_strlen') ? mb_strlen($text, 'UTF-8') : strlen($text);
+ }
+
+ protected static function validStart($word)
+ {
+ $isValid = true;
+ if (static::$textStartsWithUppercase) {
+ $isValid = preg_match('/^\p{Lu}/u', $word);
+ }
+ return $isValid;
+ }
+
+ protected static function appendEnd($text)
+ {
+ return preg_replace("/([ ,-:;\x{2013}\x{2014}]+$)/us", '', $text) . '.';
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/UserAgent.php b/vendor/fakerphp/faker/src/Faker/Provider/UserAgent.php
new file mode 100644
index 00000000..efd5356d
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/UserAgent.php
@@ -0,0 +1,165 @@
+> 8) | (($tLo & 0xff000000) >> 24);
+ $tMi = (($tMi & 0x00ff) << 8) | (($tMi & 0xff00) >> 8);
+ $tHi = (($tHi & 0x00ff) << 8) | (($tHi & 0xff00) >> 8);
+ }
+
+ // apply version number
+ $tHi &= 0x0fff;
+ $tHi |= (3 << 12);
+
+ // cast to string
+ return sprintf(
+ '%08x-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x',
+ $tLo,
+ $tMi,
+ $tHi,
+ $csHi,
+ $csLo,
+ $byte[10],
+ $byte[11],
+ $byte[12],
+ $byte[13],
+ $byte[14],
+ $byte[15]
+ );
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ar_JO/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/ar_JO/Address.php
new file mode 100644
index 00000000..39839a8c
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ar_JO/Address.php
@@ -0,0 +1,152 @@
+generator->parse($format));
+ }
+
+ /**
+ * @example 'wewebit.jo'
+ */
+ public function domainName()
+ {
+ return static::randomElement(static::$lastNameAscii) . '.' . $this->tld();
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ar_JO/Person.php b/vendor/fakerphp/faker/src/Faker/Provider/ar_JO/Person.php
new file mode 100644
index 00000000..d53c61b9
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ar_JO/Person.php
@@ -0,0 +1,108 @@
+generator->parse($format));
+ }
+
+ /**
+ * @example 'wewebit.jo'
+ */
+ public function domainName()
+ {
+ return static::randomElement(static::$lastNameAscii) . '.' . $this->tld();
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ar_SA/Payment.php b/vendor/fakerphp/faker/src/Faker/Provider/ar_SA/Payment.php
new file mode 100644
index 00000000..77a20990
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ar_SA/Payment.php
@@ -0,0 +1,19 @@
+generator->parse(static::randomElement(static::$lastNameFormat));
+ }
+
+ public static function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ public static function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/bg_BG/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/bg_BG/PhoneNumber.php
new file mode 100644
index 00000000..22051df4
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/bg_BG/PhoneNumber.php
@@ -0,0 +1,20 @@
+generator->parse($format));
+ }
+
+ /**
+ * Generates valid czech IČO
+ *
+ * @see http://phpfashion.com/jak-overit-platne-ic-a-rodne-cislo
+ * @return string
+ */
+ public function ico()
+ {
+ $ico = static::numerify('#######');
+ $split = str_split($ico);
+ $prod = 0;
+ foreach ([8, 7, 6, 5, 4, 3, 2] as $i => $p) {
+ $prod += $p * $split[$i];
+ }
+ $mod = $prod % 11;
+ if ($mod === 0 || $mod === 10) {
+ return "{$ico}1";
+ } elseif ($mod === 1) {
+ return "{$ico}0";
+ }
+
+ return $ico . (11 - $mod);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/cs_CZ/DateTime.php b/vendor/fakerphp/faker/src/Faker/Provider/cs_CZ/DateTime.php
new file mode 100644
index 00000000..89168ddd
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/cs_CZ/DateTime.php
@@ -0,0 +1,61 @@
+format('w')];
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '2'
+ */
+ public static function dayOfMonth($max = 'now')
+ {
+ return static::dateTime($max)->format('j');
+ }
+
+ /**
+ * Full date with inflected month
+ * @return string
+ * @example '16. listopadu 2003'
+ */
+ public function formattedDate()
+ {
+ $format = static::randomElement(static::$formattedDateFormat);
+
+ return $this->generator->parse($format);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/cs_CZ/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/cs_CZ/Internet.php
new file mode 100644
index 00000000..ce5b2661
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/cs_CZ/Internet.php
@@ -0,0 +1,9 @@
+generator->boolean() ? static::GENDER_MALE : static::GENDER_FEMALE;
+ }
+
+ $startTimestamp = strtotime("-${maxAge} year");
+ $endTimestamp = strtotime("-${minAge} year");
+ $randTimestamp = self::numberBetween($startTimestamp, $endTimestamp);
+
+ $year = (int) (date('Y', $randTimestamp));
+ $month = (int) (date('n', $randTimestamp));
+ $day = (int) (date('j', $randTimestamp));
+ $suffix = self::numberBetween(0, 999);
+
+ // women has +50 to month
+ if ($gender == static::GENDER_FEMALE) {
+ $month += 50;
+ }
+ // from year 2004 everyone has +20 to month when birth numbers in one day are exhausted
+ if ($year >= 2004 && $this->generator->boolean(10)) {
+ $month += 20;
+ }
+
+ $birthNumber = sprintf('%02d%02d%02d%03d', $year % 100, $month, $day, $suffix);
+
+ // from year 1954 birth number includes CRC
+ if ($year >= 1954) {
+ $crc = intval($birthNumber, 10) % 11;
+ if ($crc == 10) {
+ $crc = 0;
+ }
+ $birthNumber .= sprintf('%d', $crc);
+ }
+
+ // add slash
+ if ($this->generator->boolean($slashProbability)) {
+ $birthNumber = substr($birthNumber, 0, 6) . '/' . substr($birthNumber, 6);
+ }
+
+ return $birthNumber;
+ }
+
+ public static function birthNumberMale()
+ {
+ return static::birthNumber(static::GENDER_MALE);
+ }
+
+ public static function birthNumberFemale()
+ {
+ return static::birthNumber(static::GENDER_FEMALE);
+ }
+
+ public function title($gender = null)
+ {
+ return static::titleMale();
+ }
+
+ /**
+ * replaced by specific unisex Czech title
+ */
+ public static function titleMale()
+ {
+ return static::randomElement(static::$title);
+ }
+
+ /**
+ * replaced by specific unisex Czech title
+ */
+ public static function titleFemale()
+ {
+ return static::titleMale();
+ }
+
+ /**
+ * @param string|null $gender 'male', 'female' or null for any
+ * @example 'Albrecht'
+ */
+ public function lastName($gender = null)
+ {
+ if ($gender === static::GENDER_MALE) {
+ return static::lastNameMale();
+ } elseif ($gender === static::GENDER_FEMALE) {
+ return static::lastNameFemale();
+ }
+
+ return $this->generator->parse(static::randomElement(static::$lastNameFormat));
+ }
+
+ public static function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ public static function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/cs_CZ/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/cs_CZ/PhoneNumber.php
new file mode 100644
index 00000000..a527a254
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/cs_CZ/PhoneNumber.php
@@ -0,0 +1,14 @@
+
+ */
+class Address extends \Faker\Provider\Address
+{
+ /**
+ * @var array Danish city suffixes.
+ */
+ protected static $citySuffix = [
+ 'sted', 'bjerg', 'borg', 'rød', 'lund', 'by',
+ ];
+
+ /**
+ * @var array Danish street suffixes.
+ */
+ protected static $streetSuffix = [
+ 'vej', 'gade', 'skov', 'haven',
+ ];
+
+ /**
+ * @var array Danish street word suffixes.
+ */
+ protected static $streetSuffixWord = [
+ 'Vej', 'Gade', 'Allé', 'Boulevard', 'Plads', 'Have',
+ ];
+
+ /**
+ * @var array Danish building numbers.
+ */
+ protected static $buildingNumber = [
+ '%##', '%#', '%#', '%', '%', '%', '%?', '% ?',
+ ];
+
+ /**
+ * @var array Danish building level.
+ */
+ protected static $buildingLevel = [
+ 'st.', '%.', '%. sal.',
+ ];
+
+ /**
+ * @var array Danish building sides.
+ */
+ protected static $buildingSide = [
+ 'tv.', 'mf.', 'th.',
+ ];
+
+ /**
+ * @var array Danish zip code.
+ */
+ protected static $postcode = [
+ '%###'
+ ];
+
+ /**
+ * @var array Danish cities.
+ */
+ protected static $cityNames = [
+ 'Aabenraa', 'Aabybro', 'Aakirkeby', 'Aalborg', 'Aalestrup', 'Aars', 'Aarup', 'Agedrup', 'Agerbæk', 'Agerskov',
+ 'Albertslund', 'Allerød', 'Allinge', 'Allingåbro', 'Almind', 'Anholt', 'Ansager', 'Arden', 'Asaa', 'Askeby',
+ 'Asnæs', 'Asperup', 'Assens', 'Augustenborg', 'Aulum', 'Auning', 'Bagenkop', 'Bagsværd', 'Balle', 'Ballerup',
+ 'Bandholm', 'Barrit', 'Beder', 'Bedsted', 'Bevtoft', 'Billum', 'Billund', 'Bindslev', 'Birkerød', 'Bjerringbro',
+ 'Bjert', 'Bjæverskov', 'Blokhus', 'Blommenslyst', 'Blåvand', 'Boeslunde', 'Bogense', 'Bogø', 'Bolderslev', 'Bording',
+ 'Borre', 'Borup', 'Brøndby', 'Brabrand', 'Bramming', 'Brande', 'Branderup', 'Bredebro', 'Bredsten', 'Brenderup',
+ 'Broager', 'Broby', 'Brovst', 'Bryrup', 'Brædstrup', 'Strand', 'Brønderslev', 'Brønshøj', 'Brørup', 'Bække',
+ 'Bækmarksbro', 'Bælum', 'Børkop', 'Bøvlingbjerg', 'Charlottenlund', 'Christiansfeld', 'Dalby', 'Dalmose',
+ 'Dannemare', 'Daugård', 'Dianalund', 'Dragør', 'Dronninglund', 'Dronningmølle', 'Dybvad', 'Dyssegård', 'Ebberup',
+ 'Ebeltoft', 'Egernsund', 'Egtved', 'Egå', 'Ejby', 'Ejstrupholm', 'Engesvang', 'Errindlev', 'Erslev', 'Esbjerg',
+ 'Eskebjerg', 'Eskilstrup', 'Espergærde', 'Faaborg', 'Fanø', 'Farsø', 'Farum', 'Faxe', 'Ladeplads', 'Fejø',
+ 'Ferritslev', 'Fjenneslev', 'Fjerritslev', 'Flemming', 'Fredensborg', 'Fredericia', 'Frederiksberg',
+ 'Frederikshavn', 'Frederikssund', 'Frederiksværk', 'Frørup', 'Frøstrup', 'Fuglebjerg', 'Føllenslev', 'Føvling',
+ 'Fårevejle', 'Fårup', 'Fårvang', 'Gadbjerg', 'Gadstrup', 'Galten', 'Gandrup', 'Gedser', 'Gedsted', 'Gedved', 'Gelsted',
+ 'Gentofte', 'Gesten', 'Gilleleje', 'Gislev', 'Gislinge', 'Gistrup', 'Give', 'Gjerlev', 'Gjern', 'Glamsbjerg',
+ 'Glejbjerg', 'Glesborg', 'Glostrup', 'Glumsø', 'Gram', 'Gredstedbro', 'Grenaa', 'Greve', 'Grevinge', 'Grindsted',
+ 'Græsted', 'Gråsten', 'Gudbjerg', 'Sydfyn', 'Gudhjem', 'Gudme', 'Guldborg', 'Gørding', 'Gørlev', 'Gørløse',
+ 'Haderslev', 'Haderup', 'Hadsten', 'Hadsund', 'Hals', 'Hammel', 'Hampen', 'Hanstholm', 'Harboøre', 'Harlev', 'Harndrup',
+ 'Harpelunde', 'Hasle', 'Haslev', 'Hasselager', 'Havdrup', 'Havndal', 'Hedehusene', 'Hedensted', 'Hejls', 'Hejnsvig',
+ 'Hellebæk', 'Hellerup', 'Helsinge', 'Helsingør', 'Hemmet', 'Henne', 'Herfølge', 'Herlev', 'Herlufmagle', 'Herning',
+ 'Hesselager', 'Hillerød', 'Hinnerup', 'Hirtshals', 'Hjallerup', 'Hjerm', 'Hjortshøj', 'Hjørring', 'Hobro', 'Holbæk',
+ 'Holeby', 'Holmegaard', 'Holstebro', 'Holsted', 'Holte', 'Horbelev', 'Hornbæk', 'Hornslet', 'Hornsyld', 'Horsens',
+ 'Horslunde', 'Hovborg', 'Hovedgård', 'Humble', 'Humlebæk', 'Hundested', 'Hundslund', 'Hurup', 'Hvalsø', 'Hvide',
+ 'Sande', 'Hvidovre', 'Højbjerg', 'Højby', 'Højer', 'Højslev', 'Høng', 'Hørning', 'Hørsholm', 'Hørve', 'Hårlev',
+ 'Idestrup', 'Ikast', 'Ishøj', 'Janderup', 'Vestj', 'Jelling', 'Jerslev', 'Sjælland', 'Jerup', 'Jordrup', 'Juelsminde',
+ 'Jyderup', 'Jyllinge', 'Jystrup', 'Midtsj', 'Jægerspris', 'Kalundborg', 'Kalvehave', 'Karby', 'Karise', 'Karlslunde',
+ 'Karrebæksminde', 'Karup', 'Kastrup', 'Kerteminde', 'Kettinge', 'Kibæk', 'Kirke', 'Hyllinge', 'Såby', 'Kjellerup',
+ 'Klampenborg', 'Klarup', 'Klemensker', 'Klippinge', 'Klovborg', 'Knebel', 'Kokkedal', 'Kolding', 'Kolind', 'Kongens',
+ 'Lyngby', 'Kongerslev', 'Korsør', 'Kruså', 'Kvistgård', 'Kværndrup', 'København', 'Køge', 'Langebæk', 'Langeskov',
+ 'Langå', 'Lejre', 'Lemming', 'Lemvig', 'Lille', 'Skensved', 'Lintrup', 'Liseleje', 'Lundby', 'Lunderskov', 'Lynge',
+ 'Lystrup', 'Læsø', 'Løgstrup', 'Løgstør', 'Løgumkloster', 'Løkken', 'Løsning', 'Låsby', 'Malling', 'Mariager',
+ 'Maribo', 'Marslev', 'Marstal', 'Martofte', 'Melby', 'Mern', 'Mesinge', 'Middelfart', 'Millinge', 'Morud', 'Munke',
+ 'Bjergby', 'Munkebo', 'Møldrup', 'Mørke', 'Mørkøv', 'Måløv', 'Mårslet', 'Nakskov', 'Nexø', 'Nibe', 'Nimtofte',
+ 'Nordborg', 'Nyborg', 'Nykøbing', 'Nyrup', 'Nysted', 'Nærum', 'Næstved', 'Nørager', 'Nørre', 'Aaby', 'Alslev',
+ 'Asmindrup', 'Nebel', 'Snede', 'Nørreballe', 'Nørresundby', 'Odder', 'Odense', 'Oksbøl', 'Otterup', 'Oure', 'Outrup',
+ 'Padborg', 'Pandrup', 'Præstø', 'Randbøl', 'Randers', 'Ranum', 'Rask', 'Mølle', 'Redsted', 'Regstrup', 'Ribe', 'Ringe',
+ 'Ringkøbing', 'Ringsted', 'Risskov', 'Roskilde', 'Roslev', 'Rude', 'Rudkøbing', 'Ruds', 'Vedby', 'Rungsted', 'Kyst',
+ 'Rynkeby', 'Ryomgård', 'Ryslinge', 'Rødby', 'Rødding', 'Rødekro', 'Rødkærsbro', 'Rødovre', 'Rødvig', 'Stevns',
+ 'Rønde', 'Rønne', 'Rønnede', 'Rørvig', 'Sabro', 'Sakskøbing', 'Saltum', 'Samsø', 'Sandved', 'Sejerø', 'Silkeborg',
+ 'Sindal', 'Sjællands', 'Odde', 'Sjølund', 'Skagen', 'Skals', 'Skamby', 'Skanderborg', 'Skibby', 'Skive', 'Skjern',
+ 'Skodsborg', 'Skovlunde', 'Skælskør', 'Skærbæk', 'Skævinge', 'Skødstrup', 'Skørping', 'Skårup', 'Slagelse',
+ 'Slangerup', 'Smørum', 'Snedsted', 'Snekkersten', 'Snertinge', 'Solbjerg', 'Solrød', 'Sommersted', 'Sorring', 'Sorø',
+ 'Spentrup', 'Spjald', 'Sporup', 'Spøttrup', 'Stakroge', 'Stege', 'Stenderup', 'Stenlille', 'Stenløse', 'Stenstrup',
+ 'Stensved', 'Stoholm', 'Jyll', 'Stokkemarke', 'Store', 'Fuglede', 'Heddinge', 'Merløse', 'Storvorde', 'Stouby',
+ 'Strandby', 'Struer', 'Strøby', 'Stubbekøbing', 'Støvring', 'Suldrup', 'Sulsted', 'Sunds', 'Svaneke', 'Svebølle',
+ 'Svendborg', 'Svenstrup', 'Svinninge', 'Sydals', 'Sæby', 'Søborg', 'Søby', 'Ærø', 'Søllested', 'Sønder', 'Felding',
+ 'Sønderborg', 'Søndersø', 'Sørvad', 'Taastrup', 'Tappernøje', 'Tarm', 'Terndrup', 'Them', 'Thisted', 'Thorsø',
+ 'Thyborøn', 'Thyholm', 'Tikøb', 'Tilst', 'Tinglev', 'Tistrup', 'Tisvildeleje', 'Tjele', 'Tjæreborg', 'Toftlund',
+ 'Tommerup', 'Toreby', 'Torrig', 'Tranbjerg', 'Tranekær', 'Trige', 'Trustrup', 'Tune', 'Tureby', 'Tylstrup', 'Tølløse',
+ 'Tønder', 'Tørring', 'Tårs', 'Ugerløse', 'Uldum', 'Ulfborg', 'Ullerslev', 'Ulstrup', 'Vadum', 'Valby', 'Vallensbæk',
+ 'Vamdrup', 'Vandel', 'Vanløse', 'Varde', 'Vedbæk', 'Veflinge', 'Vejby', 'Vejen', 'Vejers', 'Vejle', 'Vejstrup',
+ 'Veksø', 'Vemb', 'Vemmelev', 'Vesløs', 'Vestbjerg', 'Vester', 'Skerninge', 'Vesterborg', 'Vestervig', 'Viborg', 'Viby',
+ 'Videbæk', 'Vildbjerg', 'Vils', 'Vinderup', 'Vipperød', 'Virum', 'Vissenbjerg', 'Viuf', 'Vodskov', 'Vojens', 'Vonge',
+ 'Vorbasse', 'Vordingborg', 'Væggerløse', 'Værløse', 'Ærøskøbing', 'Ølgod', 'Ølsted', 'Ølstykke', 'Ørbæk',
+ 'Ørnhøj', 'Ørsted', 'Djurs', 'Østbirk', 'Øster', 'Assels', 'Ulslev', 'Østermarie', 'Østervrå', 'Åbyhøj',
+ 'Ålbæk', 'Ålsgårde', 'Århus', 'Årre', 'Årslev', 'Haarby', 'Nivå', 'Rømø', 'Omme', 'Vrå', 'Ørum',
+ ];
+
+ /**
+ * @var array Danish municipalities, called 'kommuner' in danish.
+ */
+ protected static $kommuneNames = [
+ 'København', 'Frederiksberg', 'Ballerup', 'Brøndby', 'Dragør', 'Gentofte', 'Gladsaxe', 'Glostrup', 'Herlev',
+ 'Albertslund', 'Hvidovre', 'Høje Taastrup', 'Lyngby-Taarbæk', 'Rødovre', 'Ishøj', 'Tårnby', 'Vallensbæk',
+ 'Allerød', 'Fredensborg', 'Helsingør', 'Hillerød', 'Hørsholm', 'Rudersdal', 'Egedal', 'Frederikssund', 'Greve',
+ 'Halsnæs', 'Roskilde', 'Solrød', 'Gribskov', 'Odsherred', 'Holbæk', 'Faxe', 'Kalundborg', 'Ringsted', 'Slagelse',
+ 'Stevns', 'Sorø', 'Lejre', 'Lolland', 'Næstved', 'Guldborgsund', 'Vordingborg', 'Bornholm', 'Middelfart',
+ 'Christiansø', 'Assens', 'Faaborg-Midtfyn', 'Kerteminde', 'Nyborg', 'Odense', 'Svendborg', 'Nordfyns', 'Langeland',
+ 'Ærø', 'Haderslev', 'Billund', 'Sønderborg', 'Tønder', 'Esbjerg', 'Fanø', 'Varde', 'Vejen', 'Aabenraa',
+ 'Fredericia', 'Horsens', 'Kolding', 'Vejle', 'Herning', 'Holstebro', 'Lemvig', 'Struer', 'Syddjurs', 'Furesø',
+ 'Norddjurs', 'Favrskov', 'Odder', 'Randers', 'Silkeborg', 'Samsø', 'Skanderborg', 'Aarhus', 'Ikast-Brande',
+ 'Ringkøbing-Skjern', 'Hedensted', 'Morsø', 'Skive', 'Thisted', 'Viborg', 'Brønderslev', 'Frederikshavn',
+ 'Vesthimmerlands', 'Læsø', 'Rebild', 'Mariagerfjord', 'Jammerbugt', 'Aalborg', 'Hjørring', 'Køge',
+ ];
+
+ /**
+ * @var array Danish regions.
+ */
+ protected static $regionNames = [
+ 'Region Nordjylland', 'Region Midtjylland', 'Region Syddanmark', 'Region Hovedstaden', 'Region Sjælland',
+ ];
+
+ /**
+ * @link https://github.com/umpirsky/country-list/blob/master/country/cldr/da_DK/country.php
+ *
+ * @var array Some countries in danish.
+ */
+ protected static $country = [
+ 'Andorra', 'Forenede Arabiske Emirater', 'Afghanistan', 'Antigua og Barbuda', 'Anguilla', 'Albanien', 'Armenien',
+ 'Hollandske Antiller', 'Angola', 'Antarktis', 'Argentina', 'Amerikansk Samoa', 'Østrig', 'Australien', 'Aruba',
+ 'Åland', 'Aserbajdsjan', 'Bosnien-Hercegovina', 'Barbados', 'Bangladesh', 'Belgien', 'Burkina Faso', 'Bulgarien',
+ 'Bahrain', 'Burundi', 'Benin', 'Saint Barthélemy', 'Bermuda', 'Brunei Darussalam', 'Bolivia', 'Brasilien', 'Bahamas',
+ 'Bhutan', 'Bouvetø', 'Botswana', 'Hviderusland', 'Belize', 'Canada', 'Cocosøerne', 'Congo-Kinshasa',
+ 'Centralafrikanske Republik', 'Congo', 'Schweiz', 'Elfenbenskysten', 'Cook-øerne', 'Chile', 'Cameroun', 'Kina',
+ 'Colombia', 'Costa Rica', 'Serbien og Montenegro', 'Cuba', 'Kap Verde', 'Juleøen', 'Cypern', 'Tjekkiet', 'Tyskland',
+ 'Djibouti', 'Danmark', 'Dominica', 'Den Dominikanske Republik', 'Algeriet', 'Ecuador', 'Estland', 'Egypten',
+ 'Vestsahara', 'Eritrea', 'Spanien', 'Etiopien', 'Finland', 'Fiji-øerne', 'Falklandsøerne',
+ 'Mikronesiens Forenede Stater', 'Færøerne', 'Frankrig', 'Gabon', 'Storbritannien', 'Grenada', 'Georgien',
+ 'Fransk Guyana', 'Guernsey', 'Ghana', 'Gibraltar', 'Grønland', 'Gambia', 'Guinea', 'Guadeloupe', 'Ækvatorialguinea',
+ 'Grækenland', 'South Georgia og De Sydlige Sandwichøer', 'Guatemala', 'Guam', 'Guinea-Bissau', 'Guyana',
+ 'SAR Hongkong', 'Heard- og McDonald-øerne', 'Honduras', 'Kroatien', 'Haiti', 'Ungarn', 'Indonesien', 'Irland',
+ 'Israel', 'Isle of Man', 'Indien', 'Det Britiske Territorium i Det Indiske Ocean', 'Irak', 'Iran', 'Island',
+ 'Italien', 'Jersey', 'Jamaica', 'Jordan', 'Japan', 'Kenya', 'Kirgisistan', 'Cambodja', 'Kiribati', 'Comorerne',
+ 'Saint Kitts og Nevis', 'Nordkorea', 'Sydkorea', 'Kuwait', 'Caymanøerne', 'Kasakhstan', 'Laos', 'Libanon',
+ 'Saint Lucia', 'Liechtenstein', 'Sri Lanka', 'Liberia', 'Lesotho', 'Litauen', 'Luxembourg', 'Letland', 'Libyen',
+ 'Marokko', 'Monaco', 'Republikken Moldova', 'Montenegro', 'Saint Martin', 'Madagaskar', 'Marshalløerne',
+ 'Republikken Makedonien', 'Mali', 'Myanmar', 'Mongoliet', 'SAR Macao', 'Nordmarianerne', 'Martinique',
+ 'Mauretanien', 'Montserrat', 'Malta', 'Mauritius', 'Maldiverne', 'Malawi', 'Mexico', 'Malaysia', 'Mozambique',
+ 'Namibia', 'Ny Caledonien', 'Niger', 'Norfolk Island', 'Nigeria', 'Nicaragua', 'Holland', 'Norge', 'Nepal', 'Nauru',
+ 'Niue', 'New Zealand', 'Oman', 'Panama', 'Peru', 'Fransk Polynesien', 'Papua Ny Guinea', 'Filippinerne', 'Pakistan',
+ 'Polen', 'Saint Pierre og Miquelon', 'Pitcairn', 'Puerto Rico', 'De palæstinensiske områder', 'Portugal', 'Palau',
+ 'Paraguay', 'Qatar', 'Reunion', 'Rumænien', 'Serbien', 'Rusland', 'Rwanda', 'Saudi-Arabien', 'Salomonøerne',
+ 'Seychellerne', 'Sudan', 'Sverige', 'Singapore', 'St. Helena', 'Slovenien', 'Svalbard og Jan Mayen', 'Slovakiet',
+ 'Sierra Leone', 'San Marino', 'Senegal', 'Somalia', 'Surinam', 'Sao Tome og Principe', 'El Salvador', 'Syrien',
+ 'Swaziland', 'Turks- og Caicosøerne', 'Tchad', 'Franske Besiddelser i Det Sydlige Indiske Ocean', 'Togo',
+ 'Thailand', 'Tadsjikistan', 'Tokelau', 'Timor-Leste', 'Turkmenistan', 'Tunesien', 'Tonga', 'Tyrkiet',
+ 'Trinidad og Tobago', 'Tuvalu', 'Taiwan', 'Tanzania', 'Ukraine', 'Uganda', 'De Mindre Amerikanske Oversøiske Øer',
+ 'USA', 'Uruguay', 'Usbekistan', 'Vatikanstaten', 'St. Vincent og Grenadinerne', 'Venezuela',
+ 'De britiske jomfruøer', 'De amerikanske jomfruøer', 'Vietnam', 'Vanuatu', 'Wallis og Futunaøerne', 'Samoa',
+ 'Yemen', 'Mayotte', 'Sydafrika', 'Zambia', 'Zimbabwe',
+ ];
+
+ /**
+ * @var array Danish city format.
+ */
+ protected static $cityFormats = [
+ '{{cityName}}',
+ ];
+
+ /**
+ * @var array Danish street's name formats.
+ */
+ protected static $streetNameFormats = [
+ '{{lastName}}{{streetSuffix}}',
+ '{{middleName}}{{streetSuffix}}',
+ '{{lastName}} {{streetSuffixWord}}',
+ '{{middleName}} {{streetSuffixWord}}',
+ ];
+
+ /**
+ * @var array Danish street's address formats.
+ */
+ protected static $streetAddressFormats = [
+ '{{streetName}} {{buildingNumber}}',
+ '{{streetName}} {{buildingNumber}}, {{buildingLevel}}',
+ '{{streetName}} {{buildingNumber}}, {{buildingLevel}} {{buildingSide}}',
+ ];
+
+ /**
+ * @var array Danish address format.
+ */
+ protected static $addressFormats = [
+ "{{streetAddress}}\n{{postcode}} {{city}}",
+ ];
+
+ /**
+ * Randomly return a real city name.
+ *
+ * @return string
+ */
+ public static function cityName()
+ {
+ return static::randomElement(static::$cityNames);
+ }
+
+ /**
+ * Randomly return a suffix word.
+ *
+ * @return string
+ */
+ public static function streetSuffixWord()
+ {
+ return static::randomElement(static::$streetSuffixWord);
+ }
+
+ /**
+ * Randomly return a building number.
+ *
+ * @return string
+ */
+ public static function buildingNumber()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$buildingNumber)));
+ }
+
+ /**
+ * Randomly return a building level.
+ *
+ * @return string
+ */
+ public static function buildingLevel()
+ {
+ return static::numerify(static::randomElement(static::$buildingLevel));
+ }
+
+ /**
+ * Randomly return a side of the building.
+ *
+ * @return string
+ */
+ public static function buildingSide()
+ {
+ return static::randomElement(static::$buildingSide);
+ }
+
+ /**
+ * Randomly return a real municipality name, called 'kommune' in danish.
+ *
+ * @return string
+ */
+ public static function kommune()
+ {
+ return static::randomElement(static::$kommuneNames);
+ }
+
+ /**
+ * Randomly return a real region name.
+ *
+ * @return string
+ */
+ public static function region()
+ {
+ return static::randomElement(static::$regionNames);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/da_DK/Company.php b/vendor/fakerphp/faker/src/Faker/Provider/da_DK/Company.php
new file mode 100644
index 00000000..9655ade2
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/da_DK/Company.php
@@ -0,0 +1,70 @@
+
+ */
+class Company extends \Faker\Provider\Company
+{
+ /**
+ * @var array Danish company name formats.
+ */
+ protected static $formats = [
+ '{{lastName}} {{companySuffix}}',
+ '{{lastName}} {{companySuffix}}',
+ '{{lastName}} {{companySuffix}}',
+ '{{firstname}} {{lastName}} {{companySuffix}}',
+ '{{middleName}} {{companySuffix}}',
+ '{{middleName}} {{companySuffix}}',
+ '{{middleName}} {{companySuffix}}',
+ '{{firstname}} {{middleName}} {{companySuffix}}',
+ '{{lastName}} & {{lastName}} {{companySuffix}}',
+ '{{lastName}} og {{lastName}} {{companySuffix}}',
+ '{{lastName}} & {{lastName}} {{companySuffix}}',
+ '{{lastName}} og {{lastName}} {{companySuffix}}',
+ '{{middleName}} & {{middleName}} {{companySuffix}}',
+ '{{middleName}} og {{middleName}} {{companySuffix}}',
+ '{{middleName}} & {{lastName}}',
+ '{{middleName}} og {{lastName}}',
+ ];
+
+ /**
+ * @var array Company suffixes.
+ */
+ protected static $companySuffix = ['ApS', 'A/S', 'I/S', 'K/S'];
+
+ /**
+ * @link http://cvr.dk/Site/Forms/CMS/DisplayPage.aspx?pageid=60
+ *
+ * @var string CVR number format.
+ */
+ protected static $cvrFormat = '%#######';
+
+ /**
+ * @link http://cvr.dk/Site/Forms/CMS/DisplayPage.aspx?pageid=60
+ *
+ * @var string P number (production number) format.
+ */
+ protected static $pFormat = '%#########';
+
+ /**
+ * Generates a CVR number (8 digits).
+ *
+ * @return string
+ */
+ public static function cvr()
+ {
+ return static::numerify(static::$cvrFormat);
+ }
+
+ /**
+ * Generates a P entity number (10 digits).
+ *
+ * @return string
+ */
+ public static function p()
+ {
+ return static::numerify(static::$pFormat);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/da_DK/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/da_DK/Internet.php
new file mode 100644
index 00000000..090cf076
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/da_DK/Internet.php
@@ -0,0 +1,30 @@
+
+ */
+class Internet extends \Faker\Provider\Internet
+{
+ /**
+ * @var array Some safe email TLD.
+ */
+ protected static $safeEmailTld = [
+ 'org', 'com', 'net', 'dk', 'dk', 'dk',
+ ];
+
+ /**
+ * @var array Some email domains in Denmark.
+ */
+ protected static $freeEmailDomain = [
+ 'gmail.com', 'yahoo.com', 'yahoo.dk', 'hotmail.com', 'hotmail.dk', 'mail.dk', 'live.dk'
+ ];
+
+ /**
+ * @var array Some TLD.
+ */
+ protected static $tld = [
+ 'com', 'com', 'com', 'biz', 'info', 'net', 'org', 'dk', 'dk', 'dk',
+ ];
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/da_DK/Payment.php b/vendor/fakerphp/faker/src/Faker/Provider/da_DK/Payment.php
new file mode 100644
index 00000000..d9320a1a
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/da_DK/Payment.php
@@ -0,0 +1,19 @@
+
+ */
+class Person extends \Faker\Provider\Person
+{
+ /**
+ * @var array Danish person name formats.
+ */
+ protected static $maleNameFormats = [
+ '{{firstNameMale}} {{lastName}}',
+ '{{firstNameMale}} {{lastName}}',
+ '{{firstNameMale}} {{lastName}}',
+ '{{firstNameMale}} {{middleName}} {{lastName}}',
+ '{{firstNameMale}} {{middleName}} {{lastName}}',
+ '{{firstNameMale}} {{middleName}}-{{middleName}} {{lastName}}',
+ '{{firstNameMale}} {{middleName}} {{middleName}}-{{lastName}}',
+ ];
+
+ protected static $femaleNameFormats = [
+ '{{firstNameFemale}} {{lastName}}',
+ '{{firstNameFemale}} {{lastName}}',
+ '{{firstNameFemale}} {{lastName}}',
+ '{{firstNameFemale}} {{middleName}} {{lastName}}',
+ '{{firstNameFemale}} {{middleName}} {{lastName}}',
+ '{{firstNameFemale}} {{middleName}}-{{middleName}} {{lastName}}',
+ '{{firstNameFemale}} {{middleName}} {{middleName}}-{{lastName}}',
+ ];
+
+ /**
+ * @var array Danish first names.
+ */
+ protected static $firstNameMale = [
+ 'Aage', 'Adam', 'Adolf', 'Ahmad', 'Ahmed', 'Aksel', 'Albert', 'Alex', 'Alexander', 'Alf', 'Alfred', 'Ali', 'Allan',
+ 'Anders', 'Andreas', 'Anker', 'Anton', 'Arne', 'Arnold', 'Arthur', 'Asbjørn', 'Asger', 'August', 'Axel', 'Benjamin',
+ 'Benny', 'Bent', 'Bernhard', 'Birger', 'Bjarne', 'Bjørn', 'Bo', 'Brian', 'Bruno', 'Børge', 'Carl', 'Carlo',
+ 'Carsten', 'Casper', 'Charles', 'Chris', 'Christian', 'Christoffer', 'Christopher', 'Claus', 'Dan', 'Daniel', 'David', 'Dennis',
+ 'Ebbe', 'Edmund', 'Edvard', 'Egon', 'Einar', 'Ejvind', 'Elias', 'Emanuel', 'Emil', 'Erik', 'Erland', 'Erling',
+ 'Ernst', 'Esben', 'Ferdinand', 'Finn', 'Flemming', 'Frank', 'Freddy', 'Frederik', 'Frits', 'Fritz', 'Frode', 'Georg',
+ 'Gerhard', 'Gert', 'Gunnar', 'Gustav', 'Hans', 'Harald', 'Harry', 'Hassan', 'Heine', 'Heinrich', 'Helge', 'Helmer',
+ 'Helmuth', 'Henning', 'Henrik', 'Henry', 'Herman', 'Hermann', 'Holger', 'Hugo', 'Ib', 'Ibrahim', 'Ivan', 'Jack',
+ 'Jacob', 'Jakob', 'Jan', 'Janne', 'Jens', 'Jeppe', 'Jesper', 'Jimmi', 'Jimmy', 'Joachim', 'Johan', 'Johannes',
+ 'John', 'Johnny', 'Jon', 'Jonas', 'Jonathan', 'Josef', 'Jul', 'Julius', 'Jørgen', 'Jørn', 'Kai', 'Kaj',
+ 'Karl', 'Karlo', 'Karsten', 'Kasper', 'Kenneth', 'Kent', 'Kevin', 'Kjeld', 'Klaus', 'Knud', 'Kristian', 'Kristoffer',
+ 'Kurt', 'Lars', 'Lasse', 'Leif', 'Lennart', 'Leo', 'Leon', 'Louis', 'Lucas', 'Lukas', 'Mads', 'Magnus',
+ 'Malthe', 'Marc', 'Marcus', 'Marinus', 'Marius', 'Mark', 'Markus', 'Martin', 'Martinus', 'Mathias', 'Max', 'Michael',
+ 'Mikael', 'Mike', 'Mikkel', 'Mogens', 'Mohamad', 'Mohamed', 'Mohammad', 'Morten', 'Nick', 'Nicklas', 'Nicolai', 'Nicolaj',
+ 'Niels', 'Niklas', 'Nikolaj', 'Nils', 'Olaf', 'Olav', 'Ole', 'Oliver', 'Oscar', 'Oskar', 'Otto', 'Ove',
+ 'Palle', 'Patrick', 'Paul', 'Peder', 'Per', 'Peter', 'Philip', 'Poul', 'Preben', 'Rasmus', 'Rene', 'René',
+ 'Richard', 'Robert', 'Rolf', 'Rudolf', 'Rune', 'Sebastian', 'Sigurd', 'Simon', 'Simone', 'Steen', 'Stefan', 'Steffen',
+ 'Sten', 'Stig', 'Sune', 'Sven', 'Svend', 'Søren', 'Tage', 'Theodor', 'Thomas', 'Thor', 'Thorvald', 'Tim',
+ 'Tobias', 'Tom', 'Tommy', 'Tonny', 'Torben', 'Troels', 'Uffe', 'Ulrik', 'Vagn', 'Vagner', 'Valdemar', 'Vang',
+ 'Verner', 'Victor', 'Viktor', 'Villy', 'Walther', 'Werner', 'Wilhelm', 'William', 'Willy', 'Åge', 'Bendt', 'Bjarke',
+ 'Chr', 'Eigil', 'Ejgil', 'Ejler', 'Ejnar', 'Ejner', 'Evald', 'Folmer', 'Gunner', 'Gurli', 'Hartvig', 'Herluf', 'Hjalmar',
+ 'Ingemann', 'Ingolf', 'Ingvard', 'Keld', 'Kresten', 'Laurids', 'Laurits', 'Lauritz', 'Ludvig', 'Lynge', 'Oluf', 'Osvald',
+ 'Povl', 'Richardt', 'Sigfred', 'Sofus', 'Thorkild', 'Viggo', 'Vilhelm', 'Villiam',
+ ];
+
+ protected static $firstNameFemale = [
+ 'Aase', 'Agathe', 'Agnes', 'Alberte', 'Alexandra', 'Alice', 'Alma', 'Amalie', 'Amanda', 'Andrea', 'Ane', 'Anette', 'Anita',
+ 'Anja', 'Ann', 'Anna', 'Annalise', 'Anne', 'Anne-Lise', 'Anne-Marie', 'Anne-Mette', 'Annelise', 'Annette', 'Anni', 'Annie',
+ 'Annika', 'Anny', 'Asta', 'Astrid', 'Augusta', 'Benedikte', 'Bente', 'Berit', 'Bertha', 'Betina', 'Bettina', 'Betty',
+ 'Birgit', 'Birgitte', 'Birte', 'Birthe', 'Bitten', 'Bodil', 'Britt', 'Britta', 'Camilla', 'Carina', 'Carla', 'Caroline',
+ 'Cathrine', 'Cecilie', 'Charlotte', 'Christa', 'Christen', 'Christiane', 'Christina', 'Christine', 'Clara', 'Conni', 'Connie', 'Conny',
+ 'Dagmar', 'Dagny', 'Diana', 'Ditte', 'Dora', 'Doris', 'Dorte', 'Dorthe', 'Ebba', 'Edel', 'Edith', 'Eleonora',
+ 'Eli', 'Elin', 'Eline', 'Elinor', 'Elisa', 'Elisabeth', 'Elise', 'Ella', 'Ellen', 'Ellinor', 'Elly', 'Elna',
+ 'Elsa', 'Else', 'Elsebeth', 'Elvira', 'Emilie', 'Emma', 'Emmy', 'Erna', 'Ester', 'Esther', 'Eva', 'Evelyn',
+ 'Frede', 'Frederikke', 'Freja', 'Frida', 'Gerda', 'Gertrud', 'Gitte', 'Grete', 'Grethe', 'Gudrun', 'Hanna', 'Hanne',
+ 'Hardy', 'Harriet', 'Hedvig', 'Heidi', 'Helen', 'Helena', 'Helene', 'Helga', 'Helle', 'Henny', 'Henriette', 'Herdis',
+ 'Hilda', 'Iben', 'Ida', 'Ilse', 'Ina', 'Inga', 'Inge', 'Ingeborg', 'Ingelise', 'Inger', 'Ingrid', 'Irene',
+ 'Iris', 'Irma', 'Isabella', 'Jane', 'Janni', 'Jannie', 'Jeanette', 'Jeanne', 'Jenny', 'Jes', 'Jette', 'Joan',
+ 'Johanna', 'Johanne', 'Jonna', 'Josefine', 'Josephine', 'Juliane', 'Julie', 'Jytte', 'Kaja', 'Kamilla', 'Karen', 'Karin',
+ 'Karina', 'Karla', 'Karoline', 'Kate', 'Kathrine', 'Katja', 'Katrine', 'Ketty', 'Kim', 'Kirsten', 'Kirstine', 'Klara',
+ 'Krista', 'Kristen', 'Kristina', 'Kristine', 'Laila', 'Laura', 'Laurine', 'Lea', 'Lena', 'Lene', 'Lilian', 'Lilli',
+ 'Lillian', 'Lilly', 'Linda', 'Line', 'Lis', 'Lisa', 'Lisbet', 'Lisbeth', 'Lise', 'Liselotte', 'Lissi', 'Lissy',
+ 'Liv', 'Lizzie', 'Lone', 'Lotte', 'Louise', 'Lydia', 'Lykke', 'Lærke', 'Magda', 'Magdalene', 'Mai', 'Maiken',
+ 'Maj', 'Maja', 'Majbritt', 'Malene', 'Maren', 'Margit', 'Margrethe', 'Maria', 'Mariane', 'Marianne', 'Marie', 'Marlene',
+ 'Martha', 'Martine', 'Mary', 'Mathilde', 'Matilde', 'Merete', 'Merethe', 'Meta', 'Mette', 'Mia', 'Michelle', 'Mie',
+ 'Mille', 'Minna', 'Mona', 'Monica', 'Nadia', 'Nancy', 'Nanna', 'Nicoline', 'Nikoline', 'Nina', 'Ninna', 'Oda',
+ 'Olga', 'Olivia', 'Orla', 'Paula', 'Pauline', 'Pernille', 'Petra', 'Pia', 'Poula', 'Ragnhild', 'Randi', 'Rasmine',
+ 'Rebecca', 'Rebekka', 'Rigmor', 'Rikke', 'Rita', 'Rosa', 'Rose', 'Ruth', 'Sabrina', 'Sandra', 'Sanne', 'Sara',
+ 'Sarah', 'Selma', 'Severin', 'Sidsel', 'Signe', 'Sigrid', 'Sine', 'Sofia', 'Sofie', 'Solveig', 'Solvejg', 'Sonja',
+ 'Sophie', 'Stephanie', 'Stine', 'Susan', 'Susanne', 'Tanja', 'Thea', 'Theodora', 'Therese', 'Thi', 'Thyra', 'Tina',
+ 'Tine', 'Tove', 'Trine', 'Ulla', 'Vera', 'Vibeke', 'Victoria', 'Viktoria', 'Viola', 'Vita', 'Vivi', 'Vivian',
+ 'Winnie', 'Yrsa', 'Yvonne', 'Agnete', 'Agnethe', 'Alfrida', 'Alvilda', 'Anine', 'Bolette', 'Dorthea', 'Gunhild',
+ 'Hansine', 'Inge-Lise', 'Jensine', 'Juel', 'Jørgine', 'Kamma', 'Kristiane', 'Maj-Britt', 'Margrete', 'Metha', 'Nielsine',
+ 'Oline', 'Petrea', 'Petrine', 'Pouline', 'Ragna', 'Sørine', 'Thora', 'Valborg', 'Vilhelmine',
+ ];
+
+ /**
+ * @var array Danish middle names.
+ */
+ protected static $middleName = [
+ 'Møller', 'Lund', 'Holm', 'Jensen', 'Juul', 'Nielsen', 'Kjær', 'Hansen', 'Skov', 'Østergaard', 'Vestergaard',
+ 'Nørgaard', 'Dahl', 'Bach', 'Friis', 'Søndergaard', 'Andersen', 'Bech', 'Pedersen', 'Bruun', 'Nygaard', 'Winther',
+ 'Bang', 'Krogh', 'Schmidt', 'Christensen', 'Hedegaard', 'Toft', 'Damgaard', 'Holst', 'Sørensen', 'Juhl', 'Munk',
+ 'Skovgaard', 'Søgaard', 'Aagaard', 'Berg', 'Dam', 'Petersen', 'Lind', 'Overgaard', 'Brandt', 'Larsen', 'Bak', 'Schou',
+ 'Vinther', 'Bjerregaard', 'Riis', 'Bundgaard', 'Kruse', 'Mølgaard', 'Hjorth', 'Ravn', 'Madsen', 'Rasmussen',
+ 'Jørgensen', 'Kristensen', 'Bonde', 'Bay', 'Hougaard', 'Dalsgaard', 'Kjærgaard', 'Haugaard', 'Munch', 'Bjerre', 'Due',
+ 'Sloth', 'Leth', 'Kofoed', 'Thomsen', 'Kragh', 'Højgaard', 'Dalgaard', 'Hjort', 'Kirkegaard', 'Bøgh', 'Beck', 'Nissen',
+ 'Rask', 'Høj', 'Brix', 'Storm', 'Buch', 'Bisgaard', 'Birch', 'Gade', 'Kjærsgaard', 'Hald', 'Lindberg', 'Høgh', 'Falk',
+ 'Koch', 'Thorup', 'Borup', 'Knudsen', 'Vedel', 'Poulsen', 'Bøgelund', 'Juel', 'Frost', 'Hvid', 'Bjerg', 'Bæk', 'Elkjær',
+ 'Hartmann', 'Kirk', 'Sand', 'Sommer', 'Skou', 'Nedergaard', 'Meldgaard', 'Brink', 'Lindegaard', 'Fischer', 'Rye',
+ 'Hoffmann', 'Daugaard', 'Gram', 'Johansen', 'Meyer', 'Schultz', 'Fogh', 'Bloch', 'Lundgaard', 'Brøndum', 'Jessen',
+ 'Busk', 'Holmgaard', 'Lindholm', 'Krog', 'Egelund', 'Engelbrecht', 'Buus', 'Korsgaard', 'Ellegaard', 'Tang', 'Steen',
+ 'Kvist', 'Olsen', 'Nørregaard', 'Fuglsang', 'Wulff', 'Damsgaard', 'Hauge', 'Sonne', 'Skytte', 'Brun', 'Kronborg',
+ 'Abildgaard', 'Fabricius', 'Bille', 'Skaarup', 'Rahbek', 'Borg', 'Torp', 'Klitgaard', 'Nørskov', 'Greve', 'Hviid',
+ 'Mørch', 'Buhl', 'Rohde', 'Mørk', 'Vendelbo', 'Bjørn', 'Laursen', 'Egede', 'Rytter', 'Lehmann', 'Guldberg', 'Rosendahl',
+ 'Krarup', 'Krogsgaard', 'Westergaard', 'Rosendal', 'Fisker', 'Højer', 'Rosenberg', 'Svane', 'Storgaard', 'Pihl',
+ 'Mohamed', 'Bülow', 'Birk', 'Hammer', 'Bro', 'Kaas', 'Clausen', 'Nymann', 'Egholm', 'Ingemann', 'Haahr', 'Olesen',
+ 'Nøhr', 'Brinch', 'Bjerring', 'Christiansen', 'Schrøder', 'Guldager', 'Skjødt', 'Højlund', 'Ørum', 'Weber',
+ 'Bødker', 'Bruhn', 'Stampe', 'Astrup', 'Schack', 'Mikkelsen', 'Høyer', 'Husted', 'Skriver', 'Lindgaard', 'Yde',
+ 'Sylvest', 'Lykkegaard', 'Ploug', 'Gammelgaard', 'Pilgaard', 'Brogaard', 'Degn', 'Kaae', 'Kofod', 'Grønbæk',
+ 'Lundsgaard', 'Bagge', 'Lyng', 'Rømer', 'Kjeldgaard', 'Hovgaard', 'Groth', 'Hyldgaard', 'Ladefoged', 'Jacobsen',
+ 'Linde', 'Lange', 'Stokholm', 'Bredahl', 'Hein', 'Mose', 'Bækgaard', 'Sandberg', 'Klarskov', 'Kamp', 'Green',
+ 'Iversen', 'Riber', 'Smedegaard', 'Nyholm', 'Vad', 'Balle', 'Kjeldsen', 'Strøm', 'Borch', 'Lerche', 'Grønlund',
+ 'Vestergård', 'Østergård', 'Nyborg', 'Qvist', 'Damkjær', 'Kold', 'Sønderskov', 'Bank',
+ ];
+
+ /**
+ * @var array Danish last names.
+ */
+ protected static $lastName = [
+ 'Jensen', 'Nielsen', 'Hansen', 'Pedersen', 'Andersen', 'Christensen', 'Larsen', 'Sørensen', 'Rasmussen', 'Petersen',
+ 'Jørgensen', 'Madsen', 'Kristensen', 'Olsen', 'Christiansen', 'Thomsen', 'Poulsen', 'Johansen', 'Knudsen', 'Mortensen',
+ 'Møller', 'Jacobsen', 'Jakobsen', 'Olesen', 'Frederiksen', 'Mikkelsen', 'Henriksen', 'Laursen', 'Lund', 'Schmidt',
+ 'Eriksen', 'Holm', 'Kristiansen', 'Clausen', 'Simonsen', 'Svendsen', 'Andreasen', 'Iversen', 'Jeppesen', 'Mogensen',
+ 'Jespersen', 'Nissen', 'Lauridsen', 'Frandsen', 'Østergaard', 'Jepsen', 'Kjær', 'Carlsen', 'Vestergaard', 'Jessen',
+ 'Nørgaard', 'Dahl', 'Christoffersen', 'Skov', 'Søndergaard', 'Bertelsen', 'Bruun', 'Lassen', 'Bach', 'Gregersen',
+ 'Friis', 'Johnsen', 'Steffensen', 'Kjeldsen', 'Bech', 'Krogh', 'Lauritsen', 'Danielsen', 'Mathiesen', 'Andresen',
+ 'Brandt', 'Winther', 'Toft', 'Ravn', 'Mathiasen', 'Dam', 'Holst', 'Nilsson', 'Lind', 'Berg', 'Schou', 'Overgaard',
+ 'Kristoffersen', 'Schultz', 'Klausen', 'Karlsen', 'Paulsen', 'Hermansen', 'Thorsen', 'Koch', 'Thygesen', 'Bak', 'Kruse',
+ 'Bang', 'Juhl', 'Davidsen', 'Berthelsen', 'Nygaard', 'Lorentzen', 'Villadsen', 'Lorenzen', 'Damgaard', 'Bjerregaard',
+ 'Lange', 'Hedegaard', 'Bendtsen', 'Lauritzen', 'Svensson', 'Justesen', 'Juul', 'Hald', 'Beck', 'Kofoed', 'Søgaard',
+ 'Meyer', 'Kjærgaard', 'Riis', 'Johannsen', 'Carstensen', 'Bonde', 'Ibsen', 'Fischer', 'Andersson', 'Bundgaard',
+ 'Johannesen', 'Eskildsen', 'Hemmingsen', 'Andreassen', 'Thomassen', 'Schrøder', 'Persson', 'Hjorth', 'Enevoldsen',
+ 'Nguyen', 'Henningsen', 'Jønsson', 'Olsson', 'Asmussen', 'Michelsen', 'Vinther', 'Markussen', 'Kragh', 'Thøgersen',
+ 'Johansson', 'Dalsgaard', 'Gade', 'Bjerre', 'Ali', 'Laustsen', 'Buch', 'Ludvigsen', 'Hougaard', 'Kirkegaard', 'Marcussen',
+ 'Mølgaard', 'Ipsen', 'Sommer', 'Ottosen', 'Müller', 'Krog', 'Hoffmann', 'Clemmensen', 'Nikolajsen', 'Brodersen',
+ 'Therkildsen', 'Leth', 'Michaelsen', 'Graversen', 'Frost', 'Dalgaard', 'Albertsen', 'Laugesen', 'Due', 'Ebbesen',
+ 'Munch', 'Svenningsen', 'Ottesen', 'Fisker', 'Albrechtsen', 'Axelsen', 'Erichsen', 'Sloth', 'Bentsen', 'Westergaard',
+ 'Bisgaard', 'Nicolaisen', 'Magnussen', 'Thuesen', 'Povlsen', 'Thorup', 'Høj', 'Bentzen', 'Johannessen', 'Vilhelmsen',
+ 'Isaksen', 'Bendixen', 'Ovesen', 'Villumsen', 'Lindberg', 'Thomasen', 'Kjærsgaard', 'Buhl', 'Kofod', 'Ahmed', 'Smith',
+ 'Storm', 'Christophersen', 'Bruhn', 'Matthiesen', 'Wagner', 'Bjerg', 'Gram', 'Nedergaard', 'Dinesen', 'Mouritsen',
+ 'Boesen', 'Borup', 'Abrahamsen', 'Wulff', 'Gravesen', 'Rask', 'Pallesen', 'Greve', 'Korsgaard', 'Haugaard', 'Josefsen',
+ 'Bæk', 'Espersen', 'Thrane', 'Mørch', 'Frank', 'Lynge', 'Rohde', 'Larsson', 'Hammer', 'Torp', 'Sonne', 'Boysen', 'Bay',
+ 'Pihl', 'Fabricius', 'Høyer', 'Birch', 'Skou', 'Kirk', 'Antonsen', 'Høgh', 'Damsgaard', 'Dall', 'Truelsen', 'Daugaard',
+ 'Fuglsang', 'Martinsen', 'Therkelsen', 'Jansen', 'Karlsson', 'Caspersen', 'Steen', 'Callesen', 'Balle', 'Bloch', 'Smidt',
+ 'Rahbek', 'Hjort', 'Bjørn', 'Skaarup', 'Sand', 'Storgaard', 'Willumsen', 'Busk', 'Hartmann', 'Ladefoged', 'Skovgaard',
+ 'Philipsen', 'Damm', 'Haagensen', 'Hviid', 'Duus', 'Kvist', 'Adamsen', 'Mathiassen', 'Degn', 'Borg', 'Brix', 'Troelsen',
+ 'Ditlevsen', 'Brøndum', 'Svane', 'Mohamed', 'Birk', 'Brink', 'Hassan', 'Vester', 'Elkjær', 'Lykke', 'Nørregaard',
+ 'Meldgaard', 'Mørk', 'Hvid', 'Abildgaard', 'Nicolajsen', 'Bengtsson', 'Stokholm', 'Ahmad', 'Wind', 'Rømer', 'Gundersen',
+ 'Carlsson', 'Grøn', 'Khan', 'Skytte', 'Bagger', 'Hendriksen', 'Rosenberg', 'Jonassen', 'Severinsen', 'Jürgensen',
+ 'Boisen', 'Groth', 'Bager', 'Fogh', 'Hussain', 'Samuelsen', 'Pilgaard', 'Bødker', 'Dideriksen', 'Brogaard', 'Lundberg',
+ 'Hansson', 'Schwartz', 'Tran', 'Skriver', 'Klitgaard', 'Hauge', 'Højgaard', 'Qvist', 'Voss', 'Strøm', 'Wolff', 'Krarup',
+ 'Green', 'Odgaard', 'Tønnesen', 'Blom', 'Gammelgaard', 'Jæger', 'Kramer', 'Astrup', 'Würtz', 'Lehmann', 'Koefoed',
+ 'Skøtt', 'Lundsgaard', 'Bøgh', 'Vang', 'Martinussen', 'Sandberg', 'Weber', 'Holmgaard', 'Bidstrup', 'Meier', 'Drejer',
+ 'Schneider', 'Joensen', 'Dupont', 'Lorentsen', 'Bro', 'Bagge', 'Terkelsen', 'Kaspersen', 'Keller', 'Eliasen', 'Lyberth',
+ 'Husted', 'Mouritzen', 'Krag', 'Kragelund', 'Nørskov', 'Vad', 'Jochumsen', 'Hein', 'Krogsgaard', 'Kaas', 'Tolstrup',
+ 'Ernst', 'Hermann', 'Børgesen', 'Skjødt', 'Holt', 'Buus', 'Gotfredsen', 'Kjeldgaard', 'Broberg', 'Roed', 'Sivertsen',
+ 'Bergmann', 'Bjerrum', 'Petersson', 'Smed', 'Jeremiassen', 'Nyborg', 'Borch', 'Foged', 'Terp', 'Mark', 'Busch',
+ 'Lundgaard', 'Boye', 'Yde', 'Hinrichsen', 'Matzen', 'Esbensen', 'Hertz', 'Westh', 'Holmberg', 'Geertsen', 'Raun',
+ 'Aagaard', 'Kock', 'Falk', 'Munk',
+ ];
+
+ /**
+ * Randomly return a danish name.
+ *
+ * @return string
+ */
+ public static function middleName()
+ {
+ return static::randomElement(static::$middleName);
+ }
+
+ /**
+ * Randomly return a danish CPR number (Personnal identification number) format.
+ *
+ * @link http://cpr.dk/cpr/site.aspx?p=16
+ * @link http://en.wikipedia.org/wiki/Personal_identification_number_%28Denmark%29
+ *
+ * @return string
+ */
+ public static function cpr()
+ {
+ $birthdate = DateTime::dateTimeThisCentury();
+
+ return sprintf('%s-%s', $birthdate->format('dmy'), static::numerify('%###'));
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/da_DK/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/da_DK/PhoneNumber.php
new file mode 100644
index 00000000..e5af8ed6
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/da_DK/PhoneNumber.php
@@ -0,0 +1,21 @@
+
+ */
+class PhoneNumber extends \Faker\Provider\PhoneNumber
+{
+ /**
+ * @var array Danish phonenumber formats.
+ */
+ protected static $formats = [
+ '+45 ## ## ## ##',
+ '+45 #### ####',
+ '+45########',
+ '## ## ## ##',
+ '#### ####',
+ '########',
+ ];
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/de_AT/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/de_AT/Address.php
new file mode 100644
index 00000000..46fb9d5c
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/de_AT/Address.php
@@ -0,0 +1,141 @@
+format('dmy');
+
+ do {
+ $consecutiveNumber = (string) self::numberBetween(100, 999);
+
+ $verificationNumber = (
+ (int) $consecutiveNumber[0] * 3
+ + (int) $consecutiveNumber[1] * 7
+ + (int) $consecutiveNumber[2] * 9
+ + (int) $birthDateString[0] * 5
+ + (int) $birthDateString[1] * 8
+ + (int) $birthDateString[2] * 4
+ + (int) $birthDateString[3] * 2
+ + (int) $birthDateString[4] * 1
+ + (int) $birthDateString[5] * 6
+ ) % 11;
+ } while ($verificationNumber == 10);
+
+ return sprintf('%s%s%s', $consecutiveNumber, $verificationNumber, $birthDateString);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/de_AT/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/de_AT/PhoneNumber.php
new file mode 100644
index 00000000..87a68a22
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/de_AT/PhoneNumber.php
@@ -0,0 +1,19 @@
+ 'Aargau'],
+ ['AI' => 'Appenzell Innerrhoden'],
+ ['AR' => 'Appenzell Ausserrhoden'],
+ ['BE' => 'Bern'],
+ ['BL' => 'Basel-Landschaft'],
+ ['BS' => 'Basel-Stadt'],
+ ['FR' => 'Freiburg'],
+ ['GE' => 'Genf'],
+ ['GL' => 'Glarus'],
+ ['GR' => 'Graubünden'],
+ ['JU' => 'Jura'],
+ ['LU' => 'Luzern'],
+ ['NE' => 'Neuenburg'],
+ ['NW' => 'Nidwalden'],
+ ['OW' => 'Obwalden'],
+ ['SG' => 'St. Gallen'],
+ ['SH' => 'Schaffhausen'],
+ ['SO' => 'Solothurn'],
+ ['SZ' => 'Schwyz'],
+ ['TG' => 'Thurgau'],
+ ['TI' => 'Tessin'],
+ ['UR' => 'Uri'],
+ ['VD' => 'Waadt'],
+ ['VS' => 'Wallis'],
+ ['ZG' => 'Zug'],
+ ['ZH' => 'Zürich']
+ ];
+
+ protected static $country = [
+ 'Afghanistan', 'Alandinseln', 'Albanien', 'Algerien', 'Amerikanisch-Ozeanien', 'Amerikanisch-Samoa', 'Amerikanische Jungferninseln', 'Andorra', 'Angola', 'Anguilla', 'Antarktis', 'Antigua und Barbuda', 'Argentinien', 'Armenien', 'Aruba', 'Aserbaidschan', 'Australien', 'Ägypten', 'Äquatorialguinea', 'Äthiopien', 'Äusseres Ozeanien',
+ 'Bahamas', 'Bahrain', 'Bangladesch', 'Barbados', 'Belarus', 'Belgien', 'Belize', 'Benin', 'Bermuda', 'Bhutan', 'Bolivien', 'Bosnien und Herzegowina', 'Botsuana', 'Bouvetinsel', 'Brasilien', 'Britische Jungferninseln', 'Britisches Territorium im Indischen Ozean', 'Brunei Darussalam', 'Bulgarien', 'Burkina Faso', 'Burundi',
+ 'Chile', 'China', 'Cookinseln', 'Costa Rica', 'Côte d’Ivoire',
+ 'Demokratische Republik Kongo', 'Demokratische Volksrepublik Korea', 'Deutschland', 'Dominica', 'Dominikanische Republik', 'Dschibuti', 'Dänemark',
+ 'Ecuador', 'El Salvador', 'Eritrea', 'Estland', 'Europäische Union',
+ 'Falklandinseln', 'Fidschi', 'Finnland', 'Frankreich', 'Französisch-Guayana', 'Französisch-Polynesien', 'Französische Süd- und Antarktisgebiete', 'Färöer',
+ 'Gabun', 'Gambia', 'Georgien', 'Ghana', 'Gibraltar', 'Grenada', 'Griechenland', 'Grönland', 'Guadeloupe', 'Guam', 'Guatemala', 'Guernsey', 'Guinea', 'Guinea-Bissau', 'Guyana',
+ 'Haiti', 'Heard- und McDonald-Inseln', 'Honduras',
+ 'Indien', 'Indonesien', 'Irak', 'Iran', 'Irland', 'Island', 'Isle of Man', 'Israel', 'Italien',
+ 'Jamaika', 'Japan', 'Jemen', 'Jersey', 'Jordanien',
+ 'Kaimaninseln', 'Kambodscha', 'Kamerun', 'Kanada', 'Kap Verde', 'Kasachstan', 'Katar', 'Kenia', 'Kirgisistan', 'Kiribati', 'Kokosinseln', 'Kolumbien', 'Komoren', 'Kongo', 'Kroatien', 'Kuba', 'Kuwait',
+ 'Laos', 'Lesotho', 'Lettland', 'Libanon', 'Liberia', 'Libyen', 'Liechtenstein', 'Litauen', 'Luxemburg',
+ 'Madagaskar', 'Malawi', 'Malaysia', 'Malediven', 'Mali', 'Malta', 'Marokko', 'Marshallinseln', 'Martinique', 'Mauretanien', 'Mauritius', 'Mayotte', 'Mazedonien', 'Mexiko', 'Mikronesien', 'Monaco', 'Mongolei', 'Montenegro', 'Montserrat', 'Mosambik', 'Myanmar',
+ 'Namibia', 'Nauru', 'Nepal', 'Neukaledonien', 'Neuseeland', 'Nicaragua', 'Niederlande', 'Niederländische Antillen', 'Niger', 'Nigeria', 'Niue', 'Norfolkinsel', 'Norwegen', 'Nördliche Marianen',
+ 'Oman', 'Osttimor', 'Österreich',
+ 'Pakistan', 'Palau', 'Palästinensische Gebiete', 'Panama', 'Papua-Neuguinea', 'Paraguay', 'Peru', 'Philippinen', 'Pitcairn', 'Polen', 'Portugal', 'Puerto Rico',
+ 'Republik Korea', 'Republik Moldau', 'Ruanda', 'Rumänien', 'Russische Föderation', 'Réunion',
+ 'Salomonen', 'Sambia', 'Samoa', 'San Marino', 'Saudi-Arabien', 'Schweden', 'Schweiz', 'Senegal', 'Serbien', 'Serbien und Montenegro', 'Seychellen', 'Sierra Leone', 'Simbabwe', 'Singapur', 'Slowakei', 'Slowenien', 'Somalia', 'Sonderverwaltungszone Hongkong', 'Sonderverwaltungszone Macao', 'Spanien', 'Sri Lanka', 'St. Barthélemy', 'St. Helena', 'St. Kitts und Nevis', 'St. Lucia', 'St. Martin', 'St. Pierre und Miquelon', 'St. Vincent und die Grenadinen', 'Sudan', 'Suriname', 'Svalbard und Jan Mayen', 'Swasiland', 'Syrien', 'São Tomé und Príncipe', 'Südafrika', 'Südgeorgien und die Südlichen Sandwichinseln',
+ 'Tadschikistan', 'Taiwan', 'Tansania', 'Thailand', 'Togo', 'Tokelau', 'Tonga', 'Trinidad und Tobago', 'Tschad', 'Tschechische Republik', 'Tunesien', 'Turkmenistan', 'Turks- und Caicosinseln', 'Tuvalu', 'Türkei',
+ 'Uganda', 'Ukraine', 'Unbekannte oder ungültige Region', 'Ungarn', 'Uruguay', 'Usbekistan',
+ 'Vanuatu', 'Vatikanstadt', 'Venezuela', 'Vereinigte Arabische Emirate', 'Vereinigte Staaten', 'Vereinigtes Königreich', 'Vietnam',
+ 'Wallis und Futuna', 'Weihnachtsinsel', 'Westsahara',
+ 'Zentralafrikanische Republik', 'Zypern',
+ ];
+
+ protected static $cityFormats = [
+ '{{cityName}}',
+ ];
+
+ protected static $streetNameFormats = [
+ '{{lastName}}{{streetSuffixShort}}',
+ '{{cityName}}{{streetSuffixShort}}',
+ '{{firstName}}-{{lastName}}-{{streetSuffixLong}}'
+ ];
+
+ protected static $streetAddressFormats = [
+ '{{streetName}} {{buildingNumber}}',
+ ];
+ protected static $addressFormats = [
+ "{{streetAddress}}\n{{postcode}} {{city}}",
+ ];
+
+ /**
+ * Returns a random city name.
+ * @example Luzern
+ * @return string
+ */
+ public function cityName()
+ {
+ return static::randomElement(static::$cityNames);
+ }
+
+ /**
+ * Returns a random street suffix.
+ * @example str.
+ * @return string
+ */
+ public function streetSuffixShort()
+ {
+ return static::randomElement(static::$streetSuffixShort);
+ }
+
+ /**
+ * Returns a random street suffix.
+ * @example Strasse
+ * @return string
+ */
+ public function streetSuffixLong()
+ {
+ return static::randomElement(static::$streetSuffixLong);
+ }
+
+ /**
+ * Returns a canton
+ * @example array('BE' => 'Bern')
+ * @return array
+ */
+ public static function canton()
+ {
+ return static::randomElement(static::$canton);
+ }
+
+ /**
+ * Returns the abbreviation of a canton.
+ * @return string
+ */
+ public static function cantonShort()
+ {
+ $canton = static::canton();
+ return key($canton);
+ }
+
+ /**
+ * Returns the name of canton.
+ * @return string
+ */
+ public static function cantonName()
+ {
+ $canton = static::canton();
+ return current($canton);
+ }
+
+ public static function buildingNumber()
+ {
+ return static::regexify(self::numerify(static::randomElement(static::$buildingNumber)));
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/de_CH/Company.php b/vendor/fakerphp/faker/src/Faker/Provider/de_CH/Company.php
new file mode 100644
index 00000000..ead2781e
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/de_CH/Company.php
@@ -0,0 +1,15 @@
+generator->parse(static::randomElement(static::$lastNameFormat));
+ }
+
+ /**
+ * @example 'Θεωδωρόπουλος'
+ */
+ public static function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ /**
+ * @example 'Κοκκίνου'
+ */
+ public static function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/el_GR/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/el_GR/PhoneNumber.php
new file mode 100644
index 00000000..9067bdf0
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/el_GR/PhoneNumber.php
@@ -0,0 +1,324 @@
+generator->parse(
+ static::randomElement(static::$fixedLineFormats)
+ )));
+ }
+
+ /**
+ * Generate a code for a mobile number.
+ *
+ * @internal Used to generate mobile numbers.
+ *
+ * @return string
+ */
+ public static function mobileCode()
+ {
+ return static::randomElement(static::$mobileCodes);
+ }
+
+ /**
+ * Generate a mobile number.
+ *
+ * @example A mobile number: '6901234567'
+ * @example A mobile number with spaces: '690 123 4567'
+ * @example A mobile number with international code prefix: '+306901234567'
+ * @example A mobile number with international code prefix and spaces: '+30 690 123 4567'
+ *
+ * @return string
+ */
+ public function mobileNumber()
+ {
+ return ltrim(static::numerify($this->generator->parse(
+ static::randomElement(static::$mobileFormats)
+ )));
+ }
+
+ /**
+ * @deprecated Use PhoneNumber::mobileNumber() instead.
+ */
+ public static function mobilePhoneNumber()
+ {
+ return static::numerify(
+ strtr(static::randomElement(static::$mobileFormats), [
+ '{{internationalCodePrefix}}' => static::internationalCodePrefix(),
+ '{{mobileCode}}' => static::mobileCode(),
+ ])
+ );
+ }
+
+ /**
+ * Generate a personal number.
+ *
+ * @example A personal number: '7012345678'
+ * @example A personal number with spaces: '70 1234 5678'
+ * @example A personal number with international code prefix: '+307012345678'
+ * @example A personal number with international code prefix and spaces: '+30 70 1234 5678'
+ *
+ * @return string
+ */
+ public function personalNumber()
+ {
+ return ltrim(static::numerify($this->generator->parse(
+ static::randomElement(static::$personalFormats)
+ )));
+ }
+
+ /**
+ * Generate a toll-free number.
+ *
+ * @example A toll-free number: '8001234567'
+ * @example A toll-free number with spaces: '800 123 4567'
+ * @example A toll-free number with international code prefix: '+308001234567'
+ * @example A toll-free number with international code prefix and spaces: '+30 800 123 4567'
+ *
+ * @return string
+ */
+ public static function tollFreeNumber()
+ {
+ return ltrim(static::numerify(
+ strtr(static::randomElement(static::$tollFreeFormats), [
+ '{{internationalCodePrefix}}' => static::internationalCodePrefix(),
+ ])
+ ));
+ }
+
+ /**
+ * Generate a code for a shared-cost number.
+ *
+ * @internal Used to generate shared-cost numbers.
+ *
+ * @return string
+ */
+ public static function sharedCostCode()
+ {
+ return static::randomElement(static::$sharedCostCodes);
+ }
+
+ /**
+ * Generate a shared-cost number.
+ *
+ * @example A shared-cost number: '8011234567'
+ * @example A shared-cost number with spaces: '801 123 4567'
+ * @example A shared-cost number with international code prefix: '+308011234567'
+ * @example A shared-cost number with international code prefix and spaces: '+30 801 123 4567'
+ *
+ * @return string
+ */
+ public function sharedCostNumber()
+ {
+ return ltrim(static::numerify($this->generator->parse(
+ static::randomElement(static::$sharedCostFormats)
+ )));
+ }
+
+ /**
+ * Generate a code for a premium-rate number.
+ *
+ * @internal Used to generate premium-rate numbers.
+ *
+ * @return string
+ */
+ public static function premiumRateCode()
+ {
+ return static::randomElement(static::$premiumRateCodes);
+ }
+
+ /**
+ * Generate a premium-rate number.
+ *
+ * @example A premium-rate number: '9011234567'
+ * @example A premium-rate number with spaces: '901 123 4567'
+ * @example A premium-rate number with international code prefix: '+309011234567'
+ * @example A premium-rate number with international code prefix and spaces: '+30 901 123 4567'
+ *
+ * @return string
+ */
+ public function premiumRateNumber()
+ {
+ return ltrim(static::numerify($this->generator->parse(
+ static::randomElement(static::$premiumRateFormats)
+ )));
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/el_GR/Text.php b/vendor/fakerphp/faker/src/Faker/Provider/el_GR/Text.php
new file mode 100644
index 00000000..c6dd3f55
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/el_GR/Text.php
@@ -0,0 +1,2582 @@
+generator->parse(static::randomElement(static::$towns));
+ }
+
+ public function syllable()
+ {
+ return static::randomElement(static::$syllables);
+ }
+
+ public function direction()
+ {
+ return static::randomElement(static::$directions);
+ }
+
+ public function englishStreetName()
+ {
+ return static::randomElement(static::$englishStreetNames);
+ }
+
+ public function villageSuffix()
+ {
+ return static::randomElement(static::$villageSuffixes);
+ }
+
+ public function estateSuffix()
+ {
+ return static::randomElement(static::$estateSuffixes);
+ }
+
+ public function village()
+ {
+ return $this->generator->parse(static::randomElement(static::$villageNameFormats));
+ }
+
+ public function estate()
+ {
+ return $this->generator->parse(static::randomElement(static::$estateNameFormats));
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/en_HK/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/en_HK/Internet.php
new file mode 100644
index 00000000..478457a7
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/en_HK/Internet.php
@@ -0,0 +1,14 @@
+generator->parse(static::randomElement(static::$societyNameFormat));
+ }
+
+ /**
+ * @example Mumbai
+ */
+ public function city()
+ {
+ return static::randomElement(static::$city);
+ }
+
+ /**
+ * @example Vaishali Nagar
+ */
+ public function locality()
+ {
+ return $this->generator->parse(static::randomElement(static::$localityFormats));
+ }
+
+ /**
+ * @example Kharadi
+ */
+ public function localityName()
+ {
+ return $this->generator->parse(static::randomElement(static::$localityName));
+ }
+
+ /**
+ * @example Nagar
+ */
+ public function areaSuffix()
+ {
+ return static::randomElement(static::$areaSuffix);
+ }
+
+ /**
+ * @example 'Delhi'
+ */
+ public static function state()
+ {
+ return static::randomElement(static::$state);
+ }
+
+ /**
+ * @example 'DL'
+ */
+ public static function stateAbbr()
+ {
+ return static::randomElement(static::$stateAbbr);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/en_IN/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/en_IN/Internet.php
new file mode 100644
index 00000000..a5435352
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/en_IN/Internet.php
@@ -0,0 +1,9 @@
+format('y');
+ $checksumArr = ['J', 'Z', 'I', 'H', 'G', 'F', 'E', 'D', 'C', 'B', 'A'];
+ }
+
+ $length = count($weights);
+ for ($i = strlen($result); $i < $length; ++$i) {
+ $result .= static::randomDigit();
+ }
+
+ $checksum = in_array($prefix, ['G', 'T'], true) ? 4 : 0;
+ for ($i = 0; $i < $length; $i++) {
+ $checksum += (int) $result[$i] * $weights[$i];
+ }
+
+ return $prefix . $result . $checksumArr[$checksum % 11];
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/en_SG/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/en_SG/PhoneNumber.php
new file mode 100644
index 00000000..9415c9d5
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/en_SG/PhoneNumber.php
@@ -0,0 +1,105 @@
+generator->parse($format));
+ }
+
+ public function fixedLineNumber()
+ {
+ $format = static::randomElement(static::$fixedLineNumberFormats);
+
+ return static::numerify($this->generator->parse($format));
+ }
+
+ public function voipNumber()
+ {
+ $format = static::randomElement(static::$voipNumber);
+
+ return static::numerify($this->generator->parse($format));
+ }
+
+ public function internationalCodePrefix()
+ {
+ return static::randomElement(static::$internationalCodePrefix);
+ }
+
+ public function zeroToEight()
+ {
+ return static::randomElement(static::$zeroToEight);
+ }
+
+ public function oneToEight()
+ {
+ return static::randomElement(static::$oneToEight);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/en_UG/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/en_UG/Address.php
new file mode 100644
index 00000000..e20c3e63
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/en_UG/Address.php
@@ -0,0 +1,101 @@
+generator->parse($format));
+ }
+
+ /**
+ * @return string
+ * @example '555-123-546 x123'
+ */
+ public function phoneNumberWithExtension()
+ {
+ return static::numerify($this->generator->parse(static::randomElement(static::$formatsWithExtension)));
+ }
+
+ /**
+ * NPA-format area code
+ *
+ * @see https://en.wikipedia.org/wiki/North_American_Numbering_Plan#Numbering_system
+ *
+ * @return string
+ */
+ public static function areaCode()
+ {
+ $digits[] = self::numberBetween(2, 9);
+ $digits[] = self::randomDigit();
+ $digits[] = self::randomDigitNot($digits[1]);
+
+ return implode('', $digits);
+ }
+
+ /**
+ * NXX-format central office exchange code
+ *
+ * @see https://en.wikipedia.org/wiki/North_American_Numbering_Plan#Numbering_system
+ *
+ * @return string
+ */
+ public static function exchangeCode()
+ {
+ $digits[] = self::numberBetween(2, 9);
+ $digits[] = self::randomDigit();
+
+ if ($digits[1] === 1) {
+ $digits[] = self::randomDigitNot(1);
+ } else {
+ $digits[] = self::randomDigit();
+ }
+
+ return implode('', $digits);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/en_US/Text.php b/vendor/fakerphp/faker/src/Faker/Provider/en_US/Text.php
new file mode 100644
index 00000000..b3c52582
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/en_US/Text.php
@@ -0,0 +1,3720 @@
+format('Y'),
+ static::randomNumber(6, true),
+ static::randomElement(static::$legalEntities)
+ );
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/en_ZA/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/en_ZA/Internet.php
new file mode 100644
index 00000000..f5508a8f
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/en_ZA/Internet.php
@@ -0,0 +1,18 @@
+generator->dateTimeThisCentury();
+ }
+ $birthDateString = $birthdate->format('ymd');
+ switch (strtolower($gender)) {
+ case static::GENDER_FEMALE:
+ $genderDigit = self::numberBetween(0, 4);
+ break;
+ case static::GENDER_MALE:
+ $genderDigit = self::numberBetween(5, 9);
+ break;
+ default:
+ $genderDigit = self::numberBetween(0, 9);
+ }
+ $sequenceDigits = str_pad(self::randomNumber(3), 3, 0, STR_PAD_BOTH);
+ $citizenDigit = ($citizen === true) ? '0' : '1';
+ $raceDigit = self::numberBetween(8, 9);
+
+ $partialIdNumber = $birthDateString . $genderDigit . $sequenceDigits . $citizenDigit . $raceDigit;
+
+ return $partialIdNumber . Luhn::computeCheckDigit($partialIdNumber);
+ }
+
+ /**
+ * @see https://en.wikipedia.org/wiki/Driving_licence_in_South_Africa
+ *
+ * @return string
+ */
+ public function licenceCode()
+ {
+ return static::randomElement(static::$licenceCodes);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/en_ZA/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/en_ZA/PhoneNumber.php
new file mode 100644
index 00000000..ce50a782
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/en_ZA/PhoneNumber.php
@@ -0,0 +1,100 @@
+generator->parse($format));
+ }
+
+ public function tollFreeNumber()
+ {
+ $format = static::randomElement(static::$specialFormats);
+
+ return self::numerify($this->generator->parse($format));
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/es_AR/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/es_AR/Address.php
new file mode 100644
index 00000000..5381b92a
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/es_AR/Address.php
@@ -0,0 +1,68 @@
+numberBetween(10000, 100000000);
+ }
+
+ return $id . $separator . $this->numberBetween(80000000, 100000000);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/es_VE/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/es_VE/PhoneNumber.php
new file mode 100644
index 00000000..cfe6438f
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/es_VE/PhoneNumber.php
@@ -0,0 +1,29 @@
+
+ */
+class Person extends \Faker\Provider\Person
+{
+ /**
+ * @link https://news.err.ee/114745/most-popular-baby-names-of-2014
+ * @link https://www.stat.ee/public/apps/nimed/TOP
+ */
+ protected static $firstNameMale = [
+ 'Andrei', 'Aleksei', 'Andres', 'Alexander', 'Aivar', 'Aleksander', 'Artur', 'Andrus', 'Ants', 'Artjom', 'Anatoli', 'Anton', 'Arvo', 'Aare', 'Ain', 'Aleksandr',
+ 'Dmitri', 'Daniil', 'Daniel',
+ 'Eduard', 'Erik', 'Enn',
+ 'Fjodorov',
+ 'Gennadi',
+ 'Heino', 'Henri', 'Hugo',
+ 'Igor', 'Indrek', 'Ivan', 'Ilja',
+ 'Jüri', 'Jaan', 'Jevgeni', 'Jaanus', 'Janek', 'Jaak',
+ 'Kristjan', 'Kalev', 'Karl', 'Kalle', 'Kaido', 'Kevin', 'Konstantin', 'Kaspar', 'Kirill', 'Kristo', 'Kalju', 'Kristofer',
+ 'Lauri', 'Lembit', 'Laur',
+ 'Martin', 'Margus', 'Maksim', 'Marko', 'Mati', 'Meelis', 'Mihhail', 'Marek', 'Mihkel', 'Mart', 'Madis', 'Markus', 'Mark', 'Marten',
+ 'Nikolai', 'Nikita', 'Nikolay',
+ 'Oleg', 'Oliver', 'Oskar',
+ 'Peeter', 'Priit', 'Pavel',
+ 'Rein', 'Roman', 'Raivo', 'Rasmus', 'Raul', 'Robert', 'Riho', 'Robin', 'Romet',
+ 'Sergei', 'Sander', 'Sergey', 'Siim', 'Silver', 'Sebastian',
+ 'Toomas', 'Tarmo', 'Tõnu', 'Tiit', 'Tanel', 'Taavi', 'Toivo', 'Tõnis',
+ 'Urmas', 'Ülo',
+ 'Vladimir', 'Viktor', 'Valeri', 'Vello', 'Vadim', 'Vitali', 'Vladislav', 'Vjatšeslav', 'Victor',
+ ];
+
+ /**
+ * @link https://news.err.ee/114745/most-popular-baby-names-of-2014
+ * @link https://www.stat.ee/public/apps/nimed/TOP
+ */
+ protected static $firstNameFemale = [
+ 'Aino', 'Aleksandra', 'Alisa', 'Anastasia', 'Anna', 'Anne', 'Anneli', 'Anu', 'Arina', 'Annika', 'Anastassia', 'Alla', 'Aili', 'Alina', 'Aime', 'Antonina',
+ 'Darja', 'Diana',
+ 'Elena', 'Eliise', 'Elisabeth', 'Emma', 'Ene', 'Eve', 'Eha', 'Evi',
+ 'Galina',
+ 'Hanna', 'Helen', 'Heli', 'Helle', 'Helgi',
+ 'Irina', 'Inna', 'Ingrid',
+ 'Jekaterina', 'Jelena', 'Julia', 'Jana',
+ 'Kadri', 'Katrin', 'Kristi', 'Kristiina', 'Kristina', 'Karin', 'Kersti', 'Kristel', 'Kaja', 'Külli', 'Kätlin', 'Krista',
+ 'Laura', 'Lenna', 'Liisa', 'Linda', 'Lisandra', 'Ljubov', 'Ljudmila', 'Liina', 'Ljudmilla', 'Larissa', 'Liis', 'Lea', 'Laine', 'Liudmila',
+ 'Maie', 'Malle', 'Mare', 'Maria', 'Marina', 'Marleen', 'Marta', 'Merike', 'Mia', 'Milana', 'Mirtel', 'Marika', 'Merle', 'Margit', 'Milvi', 'Maire', 'Margarita', 'Mari', 'Maarja',
+ 'Natalia', 'Niina', 'Nora', 'Natalja', 'Nadežda', 'Nina',
+ 'Olga', 'Oksana',
+ 'Piret', 'Polina', 'Pille',
+ 'Reet', 'Riina',
+ 'Sandra', 'Sirje', 'Sofia', 'Svetlana', 'Silvi',
+ 'Tamara', 'Tatiana', 'Tiina', 'Tiiu', 'Triin', 'Tatjana', 'Tiia',
+ 'Ülle', 'Urve',
+ 'Valentina', 'Viktoria', 'Veera', 'Veronika', 'Vaike',
+ 'Zinaida',
+ ];
+
+ /**
+ * @link https://en.wikipedia.org/wiki/Category:Estonian-language_surnames
+ * @link https://www.stat.ee/public/apps/nimed/pere/TOP
+ */
+ protected static $lastName = [
+ 'Aleksejev', 'Andrejev', 'Allik', 'Aas', 'Aleksandrov', 'Aare', 'Aarma', 'Aas', 'Aasmäe', 'Aav', 'Aavik', 'Allik', 'Alver', 'Andrejeva', 'Aleksejeva', 'Aleksandrova', 'Allik', 'Aas',
+ 'Bogdanova', 'Bogdanov',
+ 'Eenpalu', 'Eskola',
+ 'Fjodorov', 'Fjodorov', 'Fjodorova', 'Fjodorova',
+ 'Grigorjev', 'Grigorjeva',
+ 'Hunt', 'Hein', 'Hein', 'Härma',
+ 'Ivanov', 'Ilves', 'Ilves', 'Ivanov', 'Ivanova', 'Ivanova', 'Ilves',
+ 'Jõgi', 'Jakobson', 'Jakovlev', 'Jürgenson', 'Jegorov', 'Järv', 'Johanson', 'Järve', 'Jakobson', 'Jänes', 'Järve', 'Järvis', 'Jõgi', 'Jõgi', 'Johanson', 'Jürgenson', 'Järv', 'Jakovleva', 'Jegorova', 'Järve', 'Jakobson',
+ 'Kuzmina', 'Kalda', 'Kozlova', 'Kruus', 'Kask', 'Kukk', 'Kuznetsov', 'Koppel', 'Kaasik', 'Kuusk', 'Karu', 'Kütt', 'Kallas', 'Kivi', 'Kangur', 'Kuusik', 'Kõiv', 'Kozlov', 'Kull', 'Kuzmin', 'Kalda', 'Kaaleste', 'Kaasik', 'Käbin', 'Kalda', 'Kaljulaid', 'Kaljurand', 'Kallas', 'Kallaste', 'Kangro', 'Kangur', 'Kapp', 'Kärner', 'Karu', 'Kask', 'Käsper', 'Kass', 'Keres', 'Keskküla', 'Kesküla', 'Kikkas', 'Kingsepp', 'Kirs', 'Kirsipuu', 'Kivi', 'Klavan', 'Kõiv', 'Kokk', 'Kontaveit', 'Koppel', 'Korjus', 'Kotkas', 'Kreek', 'Kross', 'Kruus', 'Kukk', 'Kull', 'Kütt', 'Kuusik', 'Kuusk', 'Kuznetsov', 'Kuznetsova', 'Kask', 'Kukk', 'Kuznetsova', 'Koppel', 'Kaasik', 'Kuusk', 'Karu', 'Kütt', 'Kallas', 'Kivi', 'Kuusik', 'Kangur', 'Kõiv', 'Kull',
+ 'Luik', 'Lepik', 'Lepp', 'Lõhmus', 'Liiv', 'Laur', 'Leppik', 'Lebedev', 'Laas', 'Laar', 'Laht', 'Lass', 'Laur', 'Laurits', 'Lemsalu', 'Lepik', 'Lepmets', 'Lepp', 'Leppik', 'Levandi', 'Liiv', 'Lill', 'Lindmaa', 'Linna', 'Lipp', 'Lippmaa', 'Lõhmus', 'Loo', 'Lõoke', 'Luik', 'Luts', 'Luik', 'Lepik', 'Lepp', 'Lõhmus', 'Laur', 'Liiv', 'Leppik', 'Lebedeva', 'Laas',
+ 'Männik', 'Mänd', 'Mitt', 'Makarova', 'Mägi', 'Mets', 'Mihhailov', 'Mölder', 'Morozov', 'Mitt', 'Männik', 'Mõttus', 'Mänd', 'Makarov', 'Mägi', 'Mälk', 'Mänd', 'Männik', 'Margiste', 'Mark', 'Masing', 'Mets', 'Mihhailov', 'Mihhailova', 'Mölder', 'Must', 'Mägi', 'Mets', 'Mihhailova', 'Mölder', 'Morozova',
+ 'Nikolajev', 'Nõmm', 'Nikitin', 'Novikov', 'Nõmmik', 'Nurme', 'Nurmsalu', 'Nõmm', 'Nikitina', 'Nikolajeva',
+ 'Orlova', 'Orav', 'Oja', 'Ots', 'Orav', 'Orlov', 'Oja', 'Olesk', 'Öpik', 'Orav', 'Ots', 'Oja', 'Ots',
+ 'Petrov', 'Pärn', 'Põder', 'Pavlov', 'Popov', 'Peterson', 'Puusepp', 'Paju', 'Põld', 'Pukk', 'Paas', 'Palm', 'Pääsuke', 'Padar', 'Pärn', 'Pavlov', 'Pavlova', 'Peebo', 'Peetre', 'Peterson', 'Petrov', 'Petrova', 'Pihlak', 'Piho', 'Piip', 'Põder', 'Põld', 'Popov', 'Popova', 'Poska', 'Puhvel', 'Pütsep', 'Puusepp', 'Petrova', 'Pärn', 'Pavlova', 'Põder', 'Peterson', 'Popova', 'Puusepp', 'Paas', 'Paju', 'Pukk', 'Parts', 'Palm', 'Põld',
+ 'Romanova', 'Rand', 'Roos', 'Rebane', 'Raudsepp', 'Raud', 'Rand', 'Roos', 'Rätsep', 'Raag', 'Raud', 'Raudsepp', 'Rebane', 'Reek', 'Reinsalu', 'Rooba', 'Roolaid', 'Rootare', 'Rummo', 'Rüütel', 'Rüütli', 'Rebane', 'Raudsepp', 'Raud',
+ 'Saar', 'Sepp', 'Smirnov', 'Stepanov', 'Semjonov', 'Sokolov', 'Sild', 'Sarapuu', 'Saks', 'Saar', 'Salumäe', 'Semjonov', 'Sepp', 'Sibul', 'Siimar', 'Simm', 'Sirel', 'Sisask', 'Smirnov', 'Smirnova', 'Sokk', 'Sokolov', 'Soosaar', 'Stepanov', 'Stepanova', 'Susi', 'Saar', 'Sepp', 'Smirnova', 'Stepanova', 'Sokolova', 'Saks', 'Sarapuu', 'Sild', 'Semjonova',
+ 'Tamme', 'Tomson', 'Tamm', 'Teder', 'Toom', 'Tomson', 'Tamme', 'Talts', 'Tamm', 'Tamme', 'Tarvas', 'Teder', 'Toom', 'Toome', 'Toots', 'Tamm', 'Teder', 'Toom',
+ 'Uibo', 'Uibo',
+ 'Vassiljev', 'Vaher', 'Volkov', 'Valk', 'Vaher', 'Vahtra', 'Vaino', 'Vainola', 'Välbe', 'Valdma', 'Väljas', 'Valk', 'Vassiljev', 'Vassiljeva', 'Vesik', 'Veski', 'Viiding', 'Vitsut', 'Võigemast', 'Volkov', 'Volkova', 'Võsu', 'Vassiljeva', 'Vaher', 'Volkova',
+ ];
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/fa_IR/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/fa_IR/Address.php
new file mode 100644
index 00000000..31538a18
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/fa_IR/Address.php
@@ -0,0 +1,100 @@
+generator->parse($format);
+ }
+
+ /**
+ * @example 'کد پستی'
+ */
+ public static function postcodePrefix()
+ {
+ return static::randomElement(static::$postcodePrefix);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/fa_IR/Company.php b/vendor/fakerphp/faker/src/Faker/Provider/fa_IR/Company.php
new file mode 100644
index 00000000..55066964
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/fa_IR/Company.php
@@ -0,0 +1,57 @@
+generator->parse($format));
+ }
+
+ /**
+ * @example 'ahmad.ir'
+ */
+ public function domainName()
+ {
+ return static::randomElement(static::$lastNameAscii) . '.' . $this->tld();
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/fa_IR/Person.php b/vendor/fakerphp/faker/src/Faker/Provider/fa_IR/Person.php
new file mode 100644
index 00000000..a492a9da
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/fa_IR/Person.php
@@ -0,0 +1,201 @@
+ 1; $i--) {
+ $sum += $subNationalCodeString[$count] * ($i);
+ $count++;
+ }
+
+ if (($sum % 11) < 2) {
+ return $sum % 11;
+ }
+ return 11 - ($sum % 11);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/fa_IR/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/fa_IR/PhoneNumber.php
new file mode 100644
index 00000000..6f37e0d7
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/fa_IR/PhoneNumber.php
@@ -0,0 +1,75 @@
+ 5) {
+ throw new \InvalidArgumentException('indexSize must be at most 5');
+ }
+
+ $words = $this->getConsecutiveWords($indexSize);
+ $result = [];
+ $resultLength = 0;
+ // take a random starting point
+ $next = static::randomKey($words);
+ while ($resultLength < $maxNbChars && isset($words[$next])) {
+ // fetch a random word to append
+ $word = static::randomElement($words[$next]);
+
+ // calculate next index
+ $currentWords = explode(' ', $next);
+
+ $currentWords[] = $word;
+ array_shift($currentWords);
+ $next = implode(' ', $currentWords);
+
+ if ($resultLength == 0 && !preg_match('/^[\x{0600}-\x{06FF}]/u', $word)) {
+ continue;
+ }
+ // append the element
+ $result[] = $word;
+ $resultLength += strlen($word) + 1;
+ }
+
+ // remove the element that caused the text to overflow
+ array_pop($result);
+
+ // build result
+ $result = implode(' ', $result);
+
+ return $result . '.';
+ }
+
+ /**
+ * License: Creative Commons Attribution-ShareAlike License
+ *
+ * Title: مدیر مدرسه
+ * Author: جلال آلاحمد
+ * Language: Persian
+ *
+ * @see http://fa.wikisource.org/wiki/%D9%85%D8%AF%DB%8C%D8%B1_%D9%85%D8%AF%D8%B1%D8%B3%D9%87
+ * @var string
+ */
+ protected static $baseText = <<<'EOT'
+از در که وارد شدم سیگارم دستم بود. زورم آمد سلام کنم. همین طوری دنگم گرفته بود قد باشم. رئیس فرهنگ که اجازهی نشستن داد، نگاهش لحظهای روی دستم مکث کرد و بعد چیزی را که مینوشت، تمام کرد و میخواست متوجه من بشود که رونویس حکم را روی میزش گذاشته بودم. حرفی نزدیم. رونویس را با کاغذهای ضمیمهاش زیر و رو کرد و بعد غبغب انداخت و آرام و مثلاً خالی از عصبانیت گفت:
+
+- جا نداریم آقا. این که نمیشه! هر روز یه حکم میدند دست یکی میفرستنش سراغ من... دیروز به آقای مدیر کل...
+
+حوصلهی این اباطیل را نداشتم. حرفش را بریدم که:
+
+- ممکنه خواهش کنم زیر همین ورقه مرقوم بفرمایید؟
+
+و سیگارم را توی زیرسیگاری براق روی میزش تکاندم. روی میز، پاک و مرتب بود. درست مثل اتاق همان مهمانخانهی تازهعروسها. هر چیز به جای خود و نه یک ذره گرد. فقط خاکستر سیگار من زیادی بود. مثل تفی در صورت تازه تراشیدهای.... قلم را برداشت و زیر حکم چیزی نوشت و امضا کرد و من از در آمده بودم بیرون. خلاص. تحمل این یکی را نداشتم. با اداهایش. پیدا بود که تازه رئیس شده. زورکی غبغب میانداخت و حرفش را آهسته توی چشم آدم میزد. انگار برای شنیدنش گوش لازم نیست. صد و پنجاه تومان در کارگزینی کل مایه گذاشته بودم تا این حکم را به امضا رسانده بودم. توصیه هم برده بودم و تازه دو ماه هم دویده بودم. مو، لای درزش نمیرفت. میدانستم که چه او بپذیرد، چه نپذیرد، کار تمام است. خودش هم میدانست. حتماً هم دستگیرش شد که با این نک و نالی که میکرد، خودش را کنف کرده. ولی کاری بود و شده بود. در کارگزینی کل، سفارش کرده بودند که برای خالی نبودن عریضه رونویس را به رؤیت رئیس فرهنگ هم برسانم تازه این طور شد. و گر نه بالی حکم کارگزینی کل چه کسی میتوانست حرفی بزند؟ یک وزارت خانه بود و یک کارگزینی! شوخی که نبود. ته دلم قرصتر از اینها بود که محتاج به این استدلالها باشم. اما به نظرم همهی این تقصیرها از این سیگار لعنتی بود که به خیال خودم خواسته بودم خرجش را از محل اضافه حقوق شغل جدیدم در بیاورم. البته از معلمی، هم اُقم نشسته بود. ده سال «الف.ب.» درس دادن و قیافههای بهتزدهی بچههای مردم برای مزخرفترین چرندی که میگویی... و استغناء با غین و استقراء با قاف و خراسانی و هندی و قدیمیترین شعر دری و صنعت ارسال مثل و ردالعجز... و از این مزخرفات! دیدم دارم خر میشوم. گفتم مدیر بشوم. مدیر دبستان! دیگر نه درس خواهم داد و نه مجبور خواهم بود برای فرار از اتلاف وقت، در امتحان تجدیدی به هر احمق بیشعوری هفت بدهم تا ایام آخر تابستانم را که لذیذترین تکهی تعطیلات است، نجات داده باشم. این بود که راه افتادم. رفتم و از اهلش پرسیدم. از یک کار چاق کن. دستم را توی دست کارگزینی گذاشت و قول و قرار و طرفین خوش و خرم و یک روز هم نشانی مدرسه را دستم دادند که بروم وارسی، که باب میلم هست یا نه.
+
+و رفتم. مدرسه دو طبقه بود و نوساز بود و در دامنهی کوه تنها افتاده بود و آفتابرو بود. یک فرهنگدوست خرپول، عمارتش را وسط زمین خودش ساخته بود و بیست و پنج سال هم در اختیار فرهنگ گذاشته بود که مدرسهاش کنند و رفت و آمد بشود و جادهها کوبیده بشود و این قدر ازین بشودها بشود، تا دل ننه باباها بسوزد و برای اینکه راه بچههاشان را کوتاه بکنند، بیایند همان اطراف مدرسه را بخرند و خانه بسازند و زمین یارو از متری یک عباسی بشود صد تومان. یارو اسمش را هم روی دیوار مدرسه کاشیکاری کرده بود. هنوز در و همسایه پیدا نکرده بودند که حرفشان بشود و لنگ و پاچهی سعدی و باباطاهر را بکشند میان و یک ورق دیگر از تاریخالشعرا را بکوبند روی نبش دیوار کوچهشان. تابلوی مدرسه هم حسابی و بزرگ و خوانا. از صد متری داد میزد که توانا بود هر.... هر چه دلتان بخواهد! با شیر و خورشیدش که آن بالا سر، سه پا ایستاده بود و زورکی تعادل خودش را حفظ میکرد و خورشید خانم روی کولش با ابروهای پیوسته و قمچیلی که به دست داشت و تا سه تیر پرتاب، اطراف مدرسه بیابان بود. درندشت و بی آب و آبادانی و آن ته رو به شمال، ردیف کاجهای درهم فرو رفتهای که از سر دیوار گلی یک باغ پیدا بود روی آسمان لکهی دراز و تیرهای زده بود. حتماً تا بیست و پنج سال دیگر همهی این اطراف پر میشد و بوق ماشین و ونگ ونگ بچهها و فریاد لبویی و زنگ روزنامهفروشی و عربدهی گل به سر دارم خیار! نان یارو توی روغن بود.
+
+- راستی شاید متری ده دوازده شاهی بیشتر نخریده باشد؟ شاید هم زمینها را همین جوری به ثبت داده باشد؟ هان؟
+
+- احمق به توچه؟!...
+
+بله این فکرها را همان روزی کردم که ناشناس به مدرسه سر زدم و آخر سر هم به این نتیجه رسیدم که مردم حق دارند جایی بخوابند که آب زیرشان نرود.
+
+- تو اگر مردی، عرضه داشته باش مدیر همین مدرسه هم بشو.
+
+و رفته بودم و دنبال کار را گرفته بودم تا رسیده بودم به اینجا. همان روز وارسی فهمیده بودم که مدیر قبلی مدرسه زندانی است. لابد کلهاش بوی قرمهسبزی میداده و باز لابد حالا دارد کفارهی گناهانی را میدهد که یا خودش نکرده یا آهنگری در بلخ کرده. جزو پر قیچیهای رئیس فرهنگ هم کسی نبود که با مدیرشان، اضافه حقوقی نصیبش بشود و ناچار سر و دستی برای این کار بشکند. خارج از مرکز هم نداشت. این معلومات را توی کارگزینی به دست آورده بودم. هنوز «گه خوردم نامهنویسی» هم مد نشده بود که بگویم یارو به این زودیها از سولدونی در خواهد آمد. فکر نمیکردم که دیگری هم برای این وسط بیابان دلش لک زده باشد با زمستان سختش و با رفت و آمد دشوارش.
+
+این بود که خیالم راحت بود. از همهی اینها گذشته کارگزینی کل موافقت کرده بود! دست است که پیش از بلند شدن بوی اسکناس، آن جا هم دو سه تا عیب شرعی و عرفی گرفته بودند و مثلاً گفته بودن لابد کاسهای زیر نیم کاسه است که فلانی یعنی من، با ده سال سابقهی تدریس، میخواهد مدیر دبستان بشود! غرضشان این بود که لابد خل شدم که از شغل مهم و محترم دبیری دست میشویم. ماهی صد و پنجاه تومان حق مقام در آن روزها پولی نبود که بتوانم نادیده بگیرم. و تازه اگر ندیده میگرفتم چه؟ باز باید بر میگشتم به این کلاسها و این جور حماقتها. این بود که پیش رئیس فرهنگ، صاف برگشتم به کارگزینی کل، سراغ آن که بفهمی نفهمی، دلال کارم بود. و رونویس حکم را گذاشتم و گفتم که چه طور شد و آمدم بیرون.
+
+دو روز بعد رفتم سراغش. معلوم شد که حدسم درست بوده است و رئیس فرهنگ گفته بوده: «من از این لیسانسههای پر افاده نمیخواهم که سیگار به دست توی هر اتاقی سر میکنند.»
+
+و یارو برایش گفته بود که اصلاً وابدا..! فلانی همچین و همچون است و مثقالی هفت صنار با دیگران فرق دارد و این هندوانهها و خیال من راحت باشد و پنجشنبه یک هفتهی دیگر خودم بروم پهلوی او... و این کار را کردم. این بار رئیس فرهنگ جلوی پایم بلند شد که: «ای آقا... چرا اول نفرمودید؟!...» و از کارمندهایش گله کرد و به قول خودش، مرا «در جریان موقعیت محل» گذاشت و بعد با ماشین خودش مرا به مدرسه رساند و گفت زنگ را زودتر از موعد زدند و در حضور معلمها و ناظم، نطق غرایی در خصائل مدیر جدید – که من باشم – کرد و بعد هم مرا گذاشت و رفت با یک مدرسهی شش کلاسهی «نوبنیاد» و یک ناظم و هفت تا معلم و دویست و سی و پنج تا شاگرد. دیگر حسابی مدیر مدرسه شده بودم!
+
+ناظم، جوان رشیدی بود که بلند حرف میزد و به راحتی امر و نهی میکرد و بیا و برویی داشت و با شاگردهای درشت، روی هم ریخته بود که خودشان ترتیب کارها را میدادند و پیدا بود که به سر خر احتیاجی ندارد و بیمدیر هم میتواند گلیم مدرسه را از آب بکشد. معلم کلاس چهار خیلی گنده بود. دو تای یک آدم حسابی. توی دفتر، اولین چیزی که به چشم میآمد. از آنهایی که اگر توی کوچه ببینی، خیال میکنی مدیر کل است. لفظ قلم حرف میزد و شاید به همین دلیل بود که وقتی رئیس فرهنگ رفت و تشریفات را با خودش برد، از طرف همکارانش تبریک ورود گفت و اشاره کرد به اینکه «انشاءالله زیر سایهی سرکار، سال دیگر کلاسهای دبیرستان را هم خواهیم داشت.» پیدا بود که این هیکل کمکم دارد از سر دبستان زیادی میکند! وقتی حرف میزد همهاش درین فکر بودم که با نان آقا معلمی چه طور میشد چنین هیکلی به هم زد و چنین سر و تیپی داشت؟ و راستش تصمیم گرفتم که از فردا صبح به صبح ریشم را بتراشم و یخهام تمیز باشد و اتوی شلوارم تیز.
+
+معلم کلاس اول باریکهای بود، سیاه سوخته. با ته ریشی و سر ماشین کردهای و یخهی بسته. بیکراوات. شبیه میرزابنویسهای دم پستخانه. حتی نوکر باب مینمود. و من آن روز نتوانستم بفهمم وقتی حرف میزند کجا را نگاه میکند. با هر جیغ کوتاهی که میزد هرهر میخندید. با این قضیه نمیشد کاری کرد. معلم کلاس سه، یک جوان ترکهای بود؛ بلند و با صورت استخوانی و ریش از ته تراشیده و یخهی بلند آهاردار. مثل فرفره میجنبید. چشمهایش برق عجیبی میزد که فقط از هوش نبود، چیزی از ناسلامتی در برق چشمهایش بود که مرا واداشت از ناظم بپرسم مبادا مسلول باشد. البته مسلول نبود، تنها بود و در دانشگاه درس میخواند. کلاسهای پنجم و ششم را دو نفر با هم اداره میکردند. یکی فارسی و شرعیات و تاریخ، جغرافی و کاردستی و این جور سرگرمیها را میگفت، که جوانکی بود بریانتین زده، با شلوار پاچه تنگ و پوشت و کراوات زرد و پهنی که نعش یک لنگر بزرگ آن را روی سینهاش نگه داشته بود و دائماً دستش حمایل موهای سرش بود و دم به دم توی شیشهها نگاه میکرد. و آن دیگری که حساب و مرابحه و چیزهای دیگر میگفت، جوانی بود موقر و سنگین مازندرانی به نظر میآمد و به خودش اطمینان داشت. غیر از اینها، یک معلم ورزش هم داشتیم که دو هفته بعد دیدمش و اصفهانی بود و از آن قاچاقها.
+
+رئیس فرهنگ که رفت، گرم و نرم از همهشان حال و احوال پرسیدم. بعد به همه سیگار تعارف کردم. سراپا همکاری و همدردی بود. از کار و بار هر کدامشان پرسیدم. فقط همان معلم کلاس سه، دانشگاه میرفت. آن که لنگر به سینه انداخته بود، شبها انگلیسی میخواند که برود آمریکا. چای و بساطی در کار نبود و ربع ساعتهای تفریح، فقط توی دفتر جمع میشدند و دوباره از نو. و این نمیشد. باید همهی سنن را رعایت کرد. دست کردم و یک پنج تومانی روی میز گذاشتم و قرار شد قبل و منقلی تهیه کنند و خودشان چای را راه بیندازند.
+
+بعد از زنگ قرار شد من سر صف نطقی بکنم. ناظم قضیه را در دو سه کلمه برای بچهها گفت که من رسیدم و همه دست زدند. چیزی نداشتم برایشان بگویم. فقط یادم است اشارهای به این کردم که مدیر خیلی دلش میخواست یکی از شما را به جای فرزند داشته باشد و حالا نمیداند با این همه فرزند چه بکند؟! که بیصدا خندیدند و در میان صفهای عقب یکی پکی زد به خنده. واهمه برم داشت که «نه بابا. کار سادهای هم نیست!» قبلاً فکر کرده بودم که میروم و فارغ از دردسر ادارهی کلاس، در اتاق را روی خودم میبندم و کار خودم را میکنم. اما حالا میدیدم به این سادگیها هم نیست. اگر فردا یکیشان زد سر اون یکی را شکست، اگر یکی زیر ماشین رفت؛ اگر یکی از ایوان افتاد؛ چه خاکی به سرم خواهم ریخت؟
+
+حالا من مانده بودم و ناظم که چیزی از لای در آهسته خزید تو. کسی بود؛ فراش مدرسه با قیافهای دهاتی و ریش نتراشیده و قدی کوتاه و گشاد گشاد راه میرفت و دستهایش را دور از بدن نگه میداشت. آمد و همان کنار در ایستاد. صاف توی چشمم نگاه میکرد. حال او را هم پرسیدم. هر چه بود او هم میتوانست یک گوشهی این بار را بگیرد. در یک دقیقه همهی درد دلهایش را کرد و التماس دعاهایش که تمام شد، فرستادمش برایم چای درست کند و بیاورد. بعد از آن من به ناظم پرداختم. سال پیش، از دانشسرای مقدماتی در آمده بود. یک سال گرمسار و کرج کار کرده بود و امسال آمده بود اینجا. پدرش دو تا زن داشته. از اولی دو تا پسر که هر دو تا چاقوکش از آب در آمدهاند و از دومی فقط او مانده بود که درسخوان شده و سرشناس و نان مادرش را میدهد که مریض است و از پدر سالهاست که خبری نیست و... یک اتاق گرفتهاند به پنجاه تومان و صد و پنجاه تومان حقوق به جایی نمیرسد و تازه زور که بزند سه سال دیگر میتواند از حق فنی نظامت مدرسه استفاده کند
+
+... بعد بلند شدیم که به کلاسها سرکشی کنیم. بعد با ناظم به تک تک کلاسها سر زدیم در این میان من به یاد دوران دبستان خودم افتادم. در کلاس ششم را باز کردیم «... ت بی پدرو مادر» جوانک بریانتین زده خورد توی صورتمان. یکی از بچهها صورتش مثل چغندر قرمز بود. لابد بزک فحش هنوز باقی بود. قرائت فارسی داشتند. معلم دستهایش توی جیبش بود و سینهاش را پیش داده بود و زبان به شکایت باز کرد:
+
+- آقای مدیر! اصلاً دوستی سرشون نمیشه. تو سَری میخوان. ملاحظه کنید بنده با چه صمیمیتی...
+
+حرفش را در تشدید «ایت» بریدم که:
+
+- صحیح میفرمایید. این بار به من ببخشید.
+
+و از در آمدیم بیرون. بعد از آن به اطاقی که در آینده مال من بود سر زدیم. بهتر از این نمیشد. بی سر و صدا، آفتابرو، دور افتاده.
+
+وسط حیاط، یک حوض بزرگ بود و کمعمق. تنها قسمت ساختمان بود که رعایت حال بچههای قد و نیم قد در آن شده بود. دور حیاط دیوار بلندی بود درست مثل دیوار چین. سد مرتفعی در مقابل فرار احتمالی فرهنگ و ته حیاط مستراح و اتاق فراش بغلش و انبار زغال و بعد هم یک کلاس. به مستراح هم سر کشیدیم. همه بی در و سقف و تیغهای میان آنها. نگاهی به ناظم کردم که پا به پایم میآمد. گفت:
+
+- دردسر عجیبی شده آقا. تا حالا صد تا کاغذ به ادارفردا صبح رفتم مدرسه. بچهها با صفهاشان به طرف کلاسها میرفتند و ناظم چوب به دست توی ایوان ایستاده بود و توی دفتر دو تا از معلمها بودند. معلوم شد کار هر روزهشان است. ناظم را هم فرستادم سر یک کلاس دیگر و خودم آمدم دم در مدرسه به قدم زدن؛ فکر کردم از هر طرف که بیایند مرا این ته، دم در مدرسه خواهند دید و تمام طول راه در این خجالت خواهند ماند و دیگر دیر نخواهند آمد. یک سیاهی از ته جادهی جنوبی پیداشد. جوانک بریانتین زده بود. مسلماً او هم مرا میدید، ولی آهستهتر از آن میآمد که یک معلم تأخیر کرده جلوی مدیرش میآمد. جلوتر که آمد حتی شنیدم که سوت میزد. اما بیانصاف چنان سلانه سلانه میآمد که دیدم هیچ جای گذشت نیست. اصلاً محل سگ به من نمیگذاشت. داشتم از کوره در میرفتم که یک مرتبه احساس کردم تغییری در رفتار خود داد و تند کرد.
+
+به خیر گذشت و گرنه خدا عالم است چه اتفاقی میافتاد. سلام که کرد مثل این که میخواست چیزی بگوید که پیش دستی کردم:
+
+- بفرمایید آقا. بفرمایید، بچهها منتظرند.
+
+واقعاً به خیر گذشت. شاید اتوبوسش دیر کرده. شاید راهبندان بوده؛ جاده قرق بوده و باز یک گردنکلفتی از اقصای عالم میآمده که ازین سفرهی مرتضی علی بینصیب نماند. به هر صورت در دل بخشیدمش. چه خوب شد که بد و بیراهی نگفتی! که از دور علم افراشتهی هیکل معلم کلاس چهارم نمایان شد. از همان ته مرا دیده بود. تقریباً میدوید. تحمل این یکی را نداشتم. «بدکاری میکنی. اول بسمالله و مته به خشخاش!» رفتم و توی دفتر نشستم و خودم را به کاری مشغول کردم که هن هن کنان رسید. چنان عرق از پیشانیاش میریخت که راستی خجالت کشیدم. یک لیوان آب از کوه به دستش دادم و مسخشدهی خندهاش را با آب به خوردش دادم و بلند که شد برود، گفتم:
+
+- عوضش دو کیلو لاغر شدید.
+
+برگشت نگاهی کرد و خندهای و رفت. ناگهان ناظم از در وارد شد و از را ه نرسیده گفت:
+
+- دیدید آقا! این جوری میآند مدرسه. اون قرتی که عین خیالش هم نبود آقا! اما این یکی...
+
+از او پرسیدم:
+
+- انگار هنوز دو تا از کلاسها ولند؟
+
+- بله آقا. کلاس سه ورزش دارند. گفتم بنشینند دیکته بنویسند آقا. معلم حساب پنج و شش هم که نیومده آقا.
+
+در همین حین یکی از عکسهای بزرگ دخمههای هخامنشی را که به دیوار کوبیده بود پس زد و:
+
+- نگاه کنید آقا...
+
+روی گچ دیوار با مداد قرمز و نه چندان درشت، به عجله و ناشیانه علامت داس کشیده بودند. همچنین دنبال کرد:
+
+- از آثار دورهی اوناست آقا. کارشون همین چیزها بود. روزنومه بفروشند. تبلیغات کنند و داس چکش بکشند آقا. رئیسشون رو که گرفتند چه جونی کندم آقا تا حالیشون کنم که دست ور دارند آقا. و از روی میز پرید پایین.
+
+- گفتم مگه باز هم هستند؟
+
+- آره آقا، پس چی! یکی همین آقازاده که هنوز نیومده آقا. هر روز نیم ساعت تأخیر داره آقا. یکی هم مثل کلاس سه.
+
+- خوب چرا تا حالا پاکش نکردی؟
+
+- به! آخه آدم درد دلشو واسهی کی بگه؟ آخه آقا در میان تو روی آدم میگند جاسوس، مأمور! باهاش حرفم شده آقا. کتک و کتککاری!
+
+و بعد یک سخنرانی که چه طور مدرسه را خراب کردهاند و اعتماد اهل محله را چه طور از بین بردهاند که نه انجمنی، نه کمکی به بیبضاعتها؛ و از این حرف ها.
+
+بعد از سخنرانی آقای ناظم دستمالم را دادم که آن عکسها را پاک کند و بعد هم راه افتادم که بروم سراغ اتاق خودم. در اتاقم را که باز کردم، داشتم دماغم با بوی خاک نم کشیدهاش اخت میکرد که آخرین معلم هم آمد. آمدم توی ایوان و با صدای بلند، جوری که در تمام مدرسه بشنوند، ناظم را صدا زدم و گفتم با قلم قرمز برای آقا یک ساعت تأخیر بگذارند.هی ساختمان نوشتیم آقا. میگند نمیشه پول دولت رو تو ملک دیگرون خرج کرد.
+
+- گفتم راست میگند.
+
+دیگه کافی بود. آمدیم بیرون. همان توی حیاط تا نفسی تازه کنیم وضع مالی و بودجه و ازین حرفهای مدرسه را پرسیدم. هر اتاق ماهی پانزده ریال حق نظافت داشت. لوازمالتحریر و دفترها را هم ادارهی فرهنگ میداد. ماهی بیست و پنج تومان هم برای آب خوردن داشتند که هنوز وصول نشده بود. برای نصب هر بخاری سالی سه تومان. ماهی سی تومان هم تنخواهگردان مدرسه بود که مثل پول آب سوخت شده بود و حالا هم ماه دوم سال بود. اواخر آبان. حالیش کردم که حوصلهی این کارها را ندارم و غرضم را از مدیر شدن برایش خلاصه کردم و گفتم حاضرم همهی اختیارات را به او بدهم. «اصلاً انگار که هنوز مدیر نیامده.» مهر مدرسه هم پهلوی خودش باشد. البته او را هنوز نمیشناختم. شنیده بودم که مدیرها قبلاً ناظم خودشان را انتخاب میکنند، اما من نه کسی را سراغ داشتم و نه حوصلهاش را. حکم خودم را هم به زور گرفته بودم. سنگهامان را وا کندیم و به دفتر رفتیم و چایی را که فراش از بساط خانهاش درست کرده بود، خوردیم تا زنگ را زدند و باز هم زدند و من نگاهی به پروندههای شاگردها کردم که هر کدام عبارت بود از دو برگ کاغذ. از همین دو سه برگ کاغذ دانستم که اولیای بچهها اغلب زارع و باغبان و اویارند و قبل از اینکه زنگ آخر را بزنند و مدرسه تعطیل بشود بیرون آمدم. برای روز اول خیلی زیاد بود.
+
+فردا صبح رفتم مدرسه. بچهها با صفهاشان به طرف کلاسها میرفتند و ناظم چوب به دست توی ایوان ایستاده بود و توی دفتر دو تا از معلمها بودند. معلوم شد کار هر روزهشان است. ناظم را هم فرستادم سر یک کلاس دیگر و خودم آمدم دم در مدرسه به قدم زدن؛ فکر کردم از هر طرف که بیایند مرا این ته، دم در مدرسه خواهند دید و تمام طول راه در این خجالت خواهند ماند و دیگر دیر نخواهند آمد. یک سیاهی از ته جادهی جنوبی پیداشد. جوانک بریانتین زده بود. مسلماً او هم مرا میدید، ولی آهستهتر از آن میآمد که یک معلم تأخیر کرده جلوی مدیرش میآمد. جلوتر که آمد حتی شنیدم که سوت میزد. اما بیانصاف چنان سلانه سلانه میآمد که دیدم هیچ جای گذشت نیست. اصلاً محل سگ به من نمیگذاشت. داشتم از کوره در میرفتم که یک مرتبه احساس کردم تغییری در رفتار خود داد و تند کرد.
+
+به خیر گذشت و گرنه خدا عالم است چه اتفاقی میافتاد. سلام که کرد مثل این که میخواست چیزی بگوید که پیش دستی کردم:
+
+- بفرمایید آقا. بفرمایید، بچهها منتظرند.
+
+واقعاً به خیر گذشت. شاید اتوبوسش دیر کرده. شاید راهبندان بوده؛ جاده قرق بوده و باز یک گردنکلفتی از اقصای عالم میآمده که ازین سفرهی مرتضی علی بینصیب نماند. به هر صورت در دل بخشیدمش. چه خوب شد که بد و بیراهی نگفتی! که از دور علم افراشتهی هیکل معلم کلاس چهارم نمایان شد. از همان ته مرا دیده بود. تقریباً میدوید. تحمل این یکی را نداشتم. «بدکاری میکنی. اول بسمالله و مته به خشخاش!» رفتم و توی دفتر نشستم و خودم را به کاری مشغول کردم که هن هن کنان رسید. چنان عرق از پیشانیاش میریخت که راستی خجالت کشیدم. یک لیوان آب از کوه به دستش دادم و مسخشدهی خندهاش را با آب به خوردش دادم و بلند که شد برود، گفتم:
+
+- عوضش دو کیلو لاغر شدید.
+
+برگشت نگاهی کرد و خندهای و رفت. ناگهان ناظم از در وارد شد و از را ه نرسیده گفت:
+
+- دیدید آقا! این جوری میآند مدرسه. اون قرتی که عین خیالش هم نبود آقا! اما این یکی...
+
+از او پرسیدم:
+
+- انگار هنوز دو تا از کلاسها ولند؟
+
+- بله آقا. کلاس سه ورزش دارند. گفتم بنشینند دیکته بنویسند آقا. معلم حساب پنج و شش هم که نیومده آقا.
+
+در همین حین یکی از عکسهای بزرگ دخمههای هخامنشی را که به دیوار کوبیده بود پس زد و:
+
+- نگاه کنید آقا...
+
+روی گچ دیوار با مداد قرمز و نه چندان درشت، به عجله و ناشیانه علامت داس کشیده بودند. همچنین دنبال کرد:
+
+- از آثار دورهی اوناست آقا. کارشون همین چیزها بود. روزنومه بفروشند. تبلیغات کنند و داس چکش بکشند آقا. رئیسشون رو که گرفتند چه جونی کندم آقا تا حالیشون کنم که دست ور دارند آقا. و از روی میز پرید پایین.
+
+- گفتم مگه باز هم هستند؟
+
+- آره آقا، پس چی! یکی همین آقازاده که هنوز نیومده آقا. هر روز نیم ساعت تأخیر داره آقا. یکی هم مثل کلاس سه.
+
+- خوب چرا تا حالا پاکش نکردی؟
+
+- به! آخه آدم درد دلشو واسهی کی بگه؟ آخه آقا در میان تو روی آدم میگند جاسوس، مأمور! باهاش حرفم شده آقا. کتک و کتککاری!
+
+و بعد یک سخنرانی که چه طور مدرسه را خراب کردهاند و اعتماد اهل محله را چه طور از بین بردهاند که نه انجمنی، نه کمکی به بیبضاعتها؛ و از این حرف ها.
+
+بعد از سخنرانی آقای ناظم دستمالم را دادم که آن عکسها را پاک کند و بعد هم راه افتادم که بروم سراغ اتاق خودم. در اتاقم را که باز کردم، داشتم دماغم با بوی خاک نم کشیدهاش اخت میکرد که آخرین معلم هم آمد. آمدم توی ایوان و با صدای بلند، جوری که در تمام مدرسه بشنوند، ناظم را صدا زدم و گفتم با قلم قرمز برای آقا یک ساعت تأخیر بگذارند.
+
+روز سوم باز اول وقت مدرسه بودم. هنوز از پشت دیوار نپیچیده بودم که صدای سوز و بریز بچهها به پیشبازم آمد. تند کردم. پنج تا از بچهها توی ایوان به خودشان میپیچیدند و ناظم ترکهای به دست داشت و به نوبت به کف دستشان میزد. بچهها التماس میکردند؛ گریه میکردند؛ اما دستشان را هم دراز میکردند. نزدیک بود داد بزنم یا با لگد بزنم و ناظم را پرت کنم آن طرف. پشتش به من بود و من را نمیدید. ناگهان زمزمهای توی صفها افتاد که یک مرتبه مرا به صرافت انداخت که در مقام مدیریت مدرسه، به سختی میشود ناظم را کتک زد. این بود که خشمم را فرو خوردم و آرام از پلهها رفتم بالا. ناظم، تازه متوجه من شده بود در همین حین دخالتم را کردم و خواهش کردم این بار همهشان را به من ببخشند.
+
+نمیدانم چه کار خطایی از آنها سر زده بود که ناظم را تا این حد عصبانی کرده بود. بچهها سکسکهکنان رفتند توی صفها و بعد زنگ را زدند و صفها رفتند به کلاسها و دنبالشان هم معلمها که همه سر وقت حاضر بودند. نگاهی به ناظم انداختم که تازه حالش سر جا آمده بود و گفتم در آن حالی که داشت، ممکن بود گردن یک کدامشان را بشکند. که مرتبه براق شد:
+
+- اگه یک روز جلوشونو نگیرید سوارتون میشند آقا. نمیدونید چه قاطرهای چموشی شدهاند آقا.
+
+مثل بچه مدرسهایها آقا آقا میکرد. موضوع را برگرداندم و احوال مادرش را پرسیدم. خنده، صورتش را از هم باز کرد و صدا زد فراش برایش آب بیاورد. یادم هست آن روز نیم ساعتی برای آقای ناظم صحبت کردم. پیرانه. و او جوان بود و زود میشد رامش کرد. بعد ازش خواستم که ترکهها را بشکند و آن وقت من رفتم سراغ اتاق خودم.
+
+در همان هفتهی اول به کارها وارد شدم. فردای زمستان و نه تا بخاری زغال سنگی و روزی چهار بار آب آوردن و آب و جاروی اتاقها با یک فراش جور در نمیآید. یک فراش دیگر از اداره ی فرهنگ خواستم که هر روز منتظر ورودش بودیم. بعد از ظهرها را نمیرفتم. روزهای اول با دست و دل لرزان، ولی سه چهار روزه جرأت پیدا کردم. احساس میکردم که مدرسه زیاد هم محض خاطر من نمیگردد. کلاس اول هم یکسره بود و به خاطر بچههای جغله دلهرهای نداشتم. در بیابانهای اطراف مدرسه هم ماشینی آمد و رفت نداشت و گرچه پست و بلند بود اما به هر صورت از حیاط مدرسه که بزرگتر بود. معلم ها هم، هر بعد از ظهری دو تاشان به نوبت میرفتند یک جوری باهم کنار آمده بودند. و ترسی هم از این نبود که بچهها از علم و فرهنگ ثقل سرد بکنند. یک روز هم بازرس آمد و نیم ساعتی پیزر لای پالان هم گذاشتیم و چای و احترامات متقابل! و در دفتر بازرسی تصدیق کرد که مدرسه «با وجود عدم وسایل» بسیار خوب اداره میشود.
+
+بچهها مدام در مدرسه زمین میخوردند، بازی میکردند، زمین میخوردند. مثل اینکه تاتوله خورده بودند. سادهترین شکل بازیهایشان در ربع ساعتهای تفریح، دعوا بود. فکر میکردم علت این همه زمین خوردن شاید این باشد که بیشترشان کفش حسابی ندارند. آنها هم که داشتند، بچهننه بودند و بلد نبودند بدوند و حتی راه بروند. این بود که روزی دو سه بار، دست و پایی خراش بر میداشت. پروندهی برق و تلفن مدرسه را از بایگانی بسیار محقر مدرسه بیرون کشیده بودم و خوانده بودم. اگر یک خرده میدویدی تا دو سه سال دیگر هم برق مدرسه درست میشد و هم تلفنش. دوباره سری به اداره ساختمان زدم و موضوع را تازه کردم و به رفقایی که دورادور در ادارهی برق و تلفن داشتم، یکی دو بار رو انداختم که اول خیال میکردند کار خودم را میخواهم به اسم مدرسه راه بیندازم و ناچار رها کردم. این قدر بود که ادای وظیفهای میکرد. مدرسه آب نداشت. نه آب خوراکی و نه آب جاری. با هرزاب بهاره، آب انبار زیر حوض را میانباشتند که تلمبهای سرش بود و حوض را با همان پر میکردند و خود بچهها. اما برای آب خوردن دو تا منبع صد لیتری داشتیم از آهن سفید که مثل امامزادهای یا سقاخانهای دو قلو، روی چهار پایه کنار حیاط بود و روزی دو بار پر و خالی میشد. این آب را از همان باغی میآوردیم که ردیف کاجهایش روی آسمان، لکهی دراز سیاه انداخته بود. البته فراش میآورد. با یک سطل بزرگ و یک آبپاش که سوراخ بود و تا به مدرسه میرسید، نصف شده بود. هر دو را از جیب خودم دادم تعمیر کردند.
+
+یک روز هم مالک مدرسه آمد. پیرمردی موقر و سنگین که خیال میکرد برای سرکشی به خانهی مستأجرنشینش آمده. از در وارد نشده فریادش بلند شد و فحش را کشید به فراش و به فرهنگ که چرا بچهها دیوار مدرسه را با زغال سیاه کردهاند واز همین توپ و تشرش شناختمش. کلی با او صحبت کردیم البته او دو برابر سن من را داشت. برایش چای هم آوردیم و با معلمها آشنا شد و قولها داد و رفت. کنهای بود. درست یک پیرمرد. یک ساعت و نیم درست نشست. ماهی یک بار هم این برنامه را داشتند که بایست پیهاش را به تن میمالیدم.
+
+اما معلمها. هر کدام یک ابلاغ بیست و چهار ساعته در دست داشتند، ولی در برنامه به هر کدامشان بیست ساعت درس بیشتر نرسیده بود. کم کم قرار شد که یک معلم از فرهنگ بخواهیم و به هر کدامشان هجده ساعت درس بدهیم، به شرط آنکه هیچ بعد از ظهری مدرسه تعطیل نباشد. حتی آن که دانشگاه میرفت میتوانست با هفتهای هجده ساعت درس بسازد. و دشوارترین کار همین بود که با کدخدامنشی حل شد و من یک معلم دیگر از فرهنگ خواستم.
+
+اواخر هفتهی دوم، فراش جدید آمد. مرد پنجاه سالهای باریک و زبر و زرنگ که شبکلاه میگذاشت و لباس آبی میپوشید و تسبیح میگرداند و از هر کاری سر رشته داشت. آب خوردن را نوبتی میآوردند. مدرسه تر و تمیز شد و رونقی گرفت. فراش جدید سرش توی حساب بود. هر دو مستخدم با هم تمام بخاریها را راه انداختند و یک کارگر هم برای کمک به آنها آمد. فراش قدیمی را چهار روز پشت سر هم، سر ظهر میفرستادیم ادارهی فرهنگ و هر آن منتظر زغال بودیم. هنوز یک هفته از آمدن فراش جدید نگذشته بود که صدای همهی معلمها در آمده بود. نه به هیچ کدامشان سلام میکرد و نه به دنبال خرده فرمایشهایشان میرفت. درست است که به من سلام میکرد، اما معلمها هم، لابد هر کدام در حدود من صاحب فضایل و عنوان و معلومات بودند که از یک فراش مدرسه توقع سلام داشته باشند. اما انگار نه انگار.
+
+بدتر از همه این که سر خر معلمها بود. من که از همان اول، خرجم را سوا کرده بودم و آنها را آزاد گذاشته بودم که در مواقع بیکاری در دفتر را روی خودشان ببندند و هر چه میخواهند بگویند و هر کاری میخواهند بکنند. اما او در فاصلهی ساعات درس، همچه که معلمها میآمدند، میآمد توی دفتر و همین طوری گوشهی اتاق میایستاد و معلمها کلافه میشدند. نه میتوانستند شلکلکهای معلمیشان را در حضور او کنار بگذارند و نه جرأت میکردند به او چیزی بگویند. بدزبان بود و از عهدهی همهشان بر میآمد. یکی دوبار دنبال نخود سیاه فرستاده بودندش. اما زرنگ بود و فوری کار را انجام میداد و بر میگشت. حسابی موی دماغ شده بود. ده سال تجربه این حداقل را به من آموخته بود که اگر معلمها در ربع ساعتهای تفریح نتوانند بخندند، سر کلاس، بچههای مردم را کتک خواهند زد. این بود که دخالت کردم. یک روز فراش جدید را صدا زدم. اول حال و احوالپرسی و بعد چند سال سابقه دارد و چند تا بچه و چه قدر میگیرد... که قضیه حل شد. سی صد و خردهای حقوق میگرفت. با بیست و پنج سال سابقه. کار از همین جا خراب بود. پیدا بود که معلمها حق دارند او را غریبه بدانند. نه دیپلمی، نه کاغذپارهای، هر چه باشد یک فراش که بیشتر نبود! و تازه قلدر هم بود و حق هم داشت. اول به اشاره و کنایه و بعد با صراحت بهش فهماندم که گر چه معلم جماعت اجر دنیایی ندارد، اما از او که آدم متدین و فهمیدهای است بعید است و از این حرفها... که یک مرتبه پرید توی حرفم که:
+
+- ای آقا! چه میفرمایید؟ شما نه خودتون این کارهاید و نه اینارو میشناسید. امروز میخواند سیگار براشون بخرم، فردا میفرستنم سراغ عرق. من اینها رو میشناسم.
+
+راست میگفت. زودتر از همه، او دندانهای مرا شمرده بود. فهمیده بود که در مدرسه هیچکارهام. میخواستم کوتاه بیایم، ولی مدیر مدرسه بودن و در مقابل یک فراش پررو ساکت ماندن!... که خر خر کامیون زغال به دادم رسید. ترمز که کرد و صدا خوابید گفتم:
+
+- این حرفها قباحت داره. معلم جماعت کجا پولش به عرق میرسه؟ حالا بدو زغال آوردهاند.
+
+و همین طور که داشت بیرون میرفت، افزودم:
+
+- دو روز دیگه که محتاجت شدند و ازت قرض خواستند با هم رفیق میشید.
+
+و آمدم توی ایوان. در بزرگ آهنی مدرسه را باز کرده بودند و کامیون آمده بود تو و داشتند بارش را جلوی انبار ته حیاط خالی میکردند و راننده، کاغذی به دست ناظم داد که نگاهی به آن انداخت و مرا نشان داد که در ایوان بالا ایستاده بودم و فرستادش بالا. کاغذش را با سلام به دستم داد. بیجک زغال بود. رسید رسمی ادارهی فرهنگ بود در سه نسخه و روی آن ورقهی ماشین شدهی «باسکول» که میگفت کامیون و محتویاتش جمعاً دوازده خروار است. اما رسیدهای رسمی اداری فرهنگ ساکت بودند. جای مقدار زغالی که تحویل مدرسه داده شده بود، در هر سه نسخه خالی بود. پیدا بود که تحویل گیرنده باید پرشان کند. همین کار را کردم. اوراق را بردم توی اتاق و با خودنویسم عدد را روی هر سه ورق نوشتم و امضا کردم و به دست راننده دادم که راه افتاد و از همان بالا به ناظم گفتم:
+
+- اگر مهر هم بایست زد، خودت بزن بابا.
+
+و رفتم سراغ کارم که ناگهان در باز شد و ناظم آمد تو؛ بیجک زغال دستش بود و:
+
+- مگه نفهمیدین آقا؟ مخصوصاً جاش رو خالی گذاشته بودند آقا...
+
+نفهمیده بودم. اما اگر هم فهمیده بودم، فرقی نمیکرد و به هر صورت از چنین کودنی نا به هنگام از جا در رفتم و به شدت گفتم:
+
+- خوب؟
+
+- هیچ چی آقا.... رسمشون همینه آقا. اگه باهاشون کنار نیایید کارمونو لنگ میگذارند آقا...
+
+که از جا در رفتم. به چنین صراحتی مرا که مدیر مدرسه بودم در معامله شرکت میداد. و فریاد زدم:
+
+- عجب! حالا سرکار برای من تکلیف هم معین میکنید؟... خاک بر سر این فرهنگ با مدیرش که من باشم! برو ورقه رو بده دستشون، گورشون رو گم کنند. پدر سوختهها...
+
+چنان فریاد زده بودم که هیچ کس در مدرسه انتظار نداشت. مدیر سر به زیر و پا به راهی بودم که از همه خواهش میکردم و حالا ناظم مدرسه، داشت به من یاد میداد که به جای نه خروار زغال مثلا هجده خروار تحویل بگیرم و بعد با ادارهی فرهنگ کنار بیایم. هی هی!.... تا ظهر هیچ کاری نتوانستم بکنم، جز اینکه چند بار متن استعفانامهام را بنویسم و پاره کنم... قدم اول را این جور جلوی پای آدم میگذارند.
+
+بارندگی که شروع شد دستور دادم بخاریها را از هفت صبح بسوزانند. بچهها همیشه زود میآمدند. حتی روزهای بارانی. مثل اینکه اول آفتاب از خانه بیرونشان میکنند. یا ناهارنخورده. خیلی سعی کردم یک روز زودتر از بچهها مدرسه باشم. اما عاقبت نشد که مدرسه را خالی از نفسِ به علمآلودهی بچهها استنشاق کنم. از راه که میرسیدند دور بخاری جمع میشدند و گیوههاشان را خشک میکردند. و خیلی زود فهمیدم که ظهر در مدرسه ماندن هم مسأله کفش بود. هر که داشت نمیماند.این قاعده در مورد معلمها هم صدق میکرد اقلاً یک پول واکس جلو بودند. وقتی که باران میبارید تمام کوهپایه و بدتر از آن تمام حیاط مدرسه گل میشد. بازی و دویدن متوقف شده بود. مدرسه سوت و کور بود. این جا هم مسأله کفش بود. چشم اغلبشان هم قرمز بود. پیدا بود باز آن روز صبح یک فصل گریه کردهاند و در خانهشان علم صراطی بوده است.
+
+مدرسه داشت تخته میشد. عدهی غایبهای صبح ده برابر شده بود و ساعت اول هیچ معلمی نمیتوانست درس بدهد. دستهای ورمکرده و سرمازده کار نمیکرد. حتی معلم کلاس اولمان هم میدانست که فرهنگ و معلومات مدارس ما صرفاً تابع تمرین است. مشق و تمرین. ده بار بیست بار. دست یخکرده بیل و رنده را هم نمیتواند به کار بگیرد که خیلی هم زمختاند و دست پر کن. این بود که به فکر افتادیم. فراش جدید واردتر از همهی ما بود. یک روز در اتاق دفتر، شورامانندی داشتیم که البته او هم بود. خودش را کمکم تحمیل کرده بود. گفت حاضر است یکی از دُمکلفتهای همسایهی مدرسه را وادارد که شن برایمان بفرستد به شرط آن که ما هم برویم و از انجمن محلی برای بچهها کفش و لباس بخواهیم. قرار شد خودش قضیه را دنبال کند که هفتهی آینده جلسهشان کجاست و حتی بخواهد که دعوتمانندی از ما بکنند. دو روز بعد سه تا کامیون شن آمد. دوتایش را توی حیاط مدرسه، خالی کردیم و سومی را دم در مدرسه، و خود بچهها نیم ساعته پهنش کردند. با پا و بیل و هر چه که به دست میرسید.
+
+عصر همان روز ما را به انجمن دعوت کردند. خود من و ناظم باید میرفتیم. معلم کلاس چهارم را هم با خودمان بردیم. خانهای که محل جلسهی آن شب انجمن بود، درست مثل مدرسه، دور افتاده و تنها بود. قالیها و کنارهها را به فرهنگ میآلودیم و میرفتیم. مثل اینکه سه تا سه تا روی هم انداخته بودند. اولی که کثیف شد دومی. به بالا که رسیدیم یک حاجی آقا در حال نماز خواندن بود. و صاحبخانه با لهجهی غلیظ یزدی به استقبالمان آمد. همراهانم را معرفی کردم و لابد خودش فهمید مدیر کیست. برای ما چای آوردند. سیگارم را چاق کردم و با صاحبخانه از قالیهایش حرف زدیم. ناظم به بچههایی میماند که در مجلس بزرگترها خوابشان میگیرد و دلشان هم نمیخواست دست به سر شوند. سر اعضای انجمن باز شده بود. حاجی آقا صندوقدار بود. من و ناظم عین دو طفلان مسلم بودیم و معلم کلاس چهارم عین خولی وسطمان نشسته. اغلب اعضای انجمن به زبان محلی صحبت میکردند و رفتار ناشی داشتند. حتی یک کدامشان نمیدانستند که دست و پاهای خود را چه جور ضبط و ربط کنند. بلند بلند حرف میزدند. درست مثل اینکه وزارتخانهی دواب سه تا حیوان تازه برای باغ وحش محلهشان وارد کرده. جلسه که رسمی شد، صاحبخانه معرفیمان کرد و شروع کردند. مدام از خودشان صحبت میکردند از اینکه دزد دیشب فلان جا را گرفته و باید درخواست پاسبان شبانه کنیم و...
+
+همین طور یک ساعت حرف زدند و به مهام امور رسیدگی کردند و من و معلم کلاس چهارم سیگار کشیدیم. انگار نه انگار که ما هم بودیم. نوکرشان که آمد استکانها را جمع کند، چیزی روی جلد اشنو نوشتم و برای صاحبخانه فرستادم که یک مرتبه به صرافت ما افتاد و اجازه خواست و:
+
+- آقایان عرضی دارند. بهتر است کارهای خودمان را بگذاریم برای بعد.
+
+مثلاً میخواست بفهماند که نباید همهی حرفها را در حضور ما زده باشند. و اجازه دادند معلم کلاس چهار شروع کرد به نطق و او هم شروع کرد که هر چه باشد ما زیر سایهی آقایانیم و خوشآیند نیست که بچههایی باشند که نه لباس داشته باشند و نه کفش درست و حسابی و از این حرفها و مدام حرف میزد. ناظم هم از چُرت در آمد چیزهایی را که از حفظ کرده بود گفت و التماس دعا و کار را خراب کرد.تشری به ناظم زدم که گدابازی را بگذارد کنار و حالیشان کردم که صحبت از تقاضا نیست و گدایی. بلکه مدرسه دور افتاده است و مستراح بی در و پیکر و از این اباطیل... چه خوب شد که عصبانی نشدم. و قرار شد که پنج نفرشان فردا عصر بیایند که مدرسه را وارسی کنند و تشکر و اظهار خوشحالی و در آمدیم.
+
+در تاریکی بیابان هفت تا سواری پشت در خانه ردیف بودند و رانندهها توی یکی از آنها جمع شده بودند و اسرار اربابهاشان را به هم میگفتند. در این حین من مدام به خودم میگفتم من چرا رفتم؟ به من چه؟ مگر من در بی کفش و کلاهیشان مقصر بودم؟ میبینی احمق؟ مدیر مدرسه هم که باشی باید شخصیت و غرورت را لای زرورق بپیچی و طاق کلاهت بگذاری که اقلاً نپوسد. حتی اگر بخواهی یک معلم کوفتی باشی، نه چرا دور میزنی؟ حتی اگر یک فراش ماهی نود تومانی باشی، باید تا خرخره توی لجن فرو بروی.در همین حین که من در فکر بودم ناظم گفت:
+
+- دیدید آقا چه طور باهامون رفتار کردند؟ با یکی از قالیهاشون آقا تمام مدرسه رو میخرید.
+
+گفتم:
+
+- تا سر و کارت با الف.ب است بهپا قیاس نکنی. خودخوری میآره.
+
+و معلم کلاس چهار گفت:
+
+- اگه فحشمون هم میدادند من باز هم راضی بودم، باید واقعبین بود. خدا کنه پشیمون نشند.
+
+بعد هم مدتی درد دل کردیم و تا اتوبوس برسد و سوار بشیم، معلوم شد که معلم کلاس چهار با زنش متارکه کرده و مادر ناظم را سرطانی تشخیص دادند. و بعد هم شب بخیر...
+
+دو روز تمام مدرسه نرفتم. خجالت میکشیدم توی صورت یک کدامشان نگاه کنم. و در همین دو روز حاجی آقا با دو نفر آمده بودند، مدرسه را وارسی و صورتبرداری و ناظم میگفت که حتی بچههایی هم که کفش و کلاهی داشتند پاره و پوره آمده بودند. و برای بچهها کفش و لباس خریدند. روزهای بعد احساس کردم زنهایی که سر راهم لب جوی آب ظرف میشستند، سلام میکنند و یک بار هم دعای خیر یکیشان را از عقب سر شنیدم.اما چنان از خودم بدم آمده بود که رغبتم نمیشد به کفش و لباسهاشان نگاه کنم. قربان همان گیوههای پاره! بله، نان گدایی فرهنگ را نو نوار کرده بود.
+
+تازه از دردسرهای اول کار مدرسه فارغ شده بودم که شنیدم که یک روز صبح، یکی از اولیای اطفال آمد. بعد از سلام و احوالپرسی دست کرد توی جیبش و شش تا عکس در آورد، گذاشت روی میزم. شش تا عکس زن . و هر کدام به یک حالت. یعنی چه؟ نگاه تندی به او کردم. آدم مرتبی بود. اداری مانند. کسر شأن خودم میدانستم که این گوشهی از زندگی را طبق دستور عکاسباشی فلان خانهی بندری ببینم. اما حالا یک مرد اتو کشیدهی مرتب آمده بود و شش تا از همین عکسها را روی میزم پهن کرده بود و به انتظار آن که وقاحت عکسها چشمهایم را پر کند داشت سیگار چاق میکرد.
+
+حسابی غافلگیر شده بودم... حتماً تا هر شش تای عکسها را ببینم، بیش از یک دقیقه طول کشید. همه از یک نفر بود. به این فکر گریختم که الان هزار ها یا میلیون ها نسخهی آن، توی جیب چه جور آدمهایی است و در کجاها و چه قدر خوب بود که همهی این آدمها را میشناختم یا میدیدم. بیش ازین نمیشد گریخت. یارو به تمام وزنه وقاحتش، جلوی رویم نشسته بود. سیگاری آتش زدم و چشم به او دوختم. کلافه بود و پیدا بود برای کتککاری هم آماده باشد. سرخ شده بود و داشت در دود سیگارش تکیهگاهی برای جسارتی که میخواست به خرج بدهد میجست. عکسها را با یک ورقه از اباطیلی که همان روز سیاه کرده بودم، پوشاندم و بعد با لحنی که دعوا را با آن شروع میکنند؛ پرسیدم:
+
+- خوب، غرض؟
+
+و صدایم توی اتاق پیچید. حرکتی از روی بیچارگی به خودش داد و همهی جسارتها را با دستش توی جیبش کرد و آرامتر از آن چیزی که با خودش تو آورده بود، گفت:
+
+- چه عرض کنم؟... از معلم کلاس پنج تون بپرسید.
+
+که راحت شدم و او شروع کرد به این که «این چه فرهنگی است؟ خراب بشود. پس بچههای مردم با چه اطمینانی به مدرسه بیایند؟
+
+و از این حرفها...
+
+خلاصه این آقا معلم کاردستی کلاس پنجم، این عکسها را داده به پسر آقا تا آنها را روی تخته سه لایی بچسباند و دورش را سمباده بکشد و بیاورد. به هر صورت معلم کلاس پنج بیگدار به آب زده. و حالا من چه بکنم؟ به او چه جوابی بدهم؟ بگویم معلم را اخراج میکنم؟ که نه میتوانم و نه لزومی دارد. او چه بکند؟ حتماً در این شهر کسی را ندارد که به این عکسها دلخوش کرده. ولی آخر چرا این جور؟ یعنی این قدر احمق است که حتی شاگردهایش را نمیشناسد؟... پاشدم ناظم را صدا بزنم که خودش آمده بود بالا، توی ایوان منتظر ایستاده بود. من آخرین کسی بودم که از هر اتفاقی در مدرسه خبردار میشدم. حضور این ولی طفل گیجم کرده بود که چنین عکسهایی را از توی جیب پسرش، و لابد به همین وقاحتی که آنها را روی میز من ریخت، در آورده بوده. وقتی فهمید هر دو در ماندهایم سوار بر اسب شد که اله میکنم و بله میکنم، در مدرسه را میبندم، و از این جفنگیات....
+
+حتماً نمیدانست که اگر در هر مدرسه بسته بشود، در یک اداره بسته شده است. اما من تا او بود نمیتوانستم فکرم را جمع کنم. میخواست پسرش را بخواهیم تا شهادت بدهد و چه جانی کندیم تا حالیش کنیم که پسرش هر چه خفت کشیده، بس است و وعدهها دادیم که معلمش را دم خورشید کباب کنیم و از نان خوردن بیندازیم. یعنی اول ناظم شروع کرد که از دست او دل پری داشت و من هم دنبالش را گرفتم. برای دک کردن او چارهای جز این نبود. و بعد رفت، ما دو نفری ماندیم با شش تا عکس زن . حواسم که جمع شد به ناظم سپردم صدایش را در نیاورد و یک هفتهی تمام مطلب را با عکسها، توی کشوی میزم قفل کردم و بعد پسرک را صدا زدم. نه عزیزدُردانه مینمود و نه هیچ جور دیگر. داد میزد که از خانوادهی عیالواری است. کمخونی و فقر. دیدم معلمش زیاد هم بد تشخیص نداده. یعنی زیاد بیگدار به آب نزده. گفتم:
+
+- خواهر برادر هم داری؟
+
+- آ... آ...آقا داریم آقا.
+
+- چند تا؟
+
+- آ... آقا چهار تا آقا.
+
+- عکسها رو خودت به بابات نشون دادی؟
+
+- نه به خدا آقا... به خدا قسم...
+
+- پس چه طور شد؟
+
+و دیدم از ترس دارد قالب تهی میکند. گرچه چوبهای ناظم شکسته بود، اما ترس او از من که مدیر باشم و از ناظم و از مدرسه و از تنبیه سالم مانده بود.
+
+- نترس بابا. کاریت نداریم. تقصیر آقا معلمه که عکسها رو داده... تو کار بدی نکردی بابا جان. فهمیدی؟ اما میخواهم ببینم چه طور شد که عکسها دست بابات افتاد.
+
+- آ.. آ... آخه آقا... آخه...
+
+میدانستم که باید کمکش کنم تا به حرف بیاید.
+
+گفتم:
+
+- میدونی بابا؟ عکسهام چیز بدی نبود. تو خودت فهمیدی چی بود؟
+
+- آخه آقا...نه آقا.... خواهرم آقا... خواهرم میگفت...
+
+- خواهرت؟ از تو کوچکتره؟
+
+- نه آقا. بزرگتره. میگفتش که آقا... میگفتش که آقا... هیچ چی سر عکسها دعوامون شد.
+
+دیگر تمام بود. عکسها را به خواهرش نشان داده بود که لای دفترچه پر بوده از عکس آرتیستها. به او پز داده بوده. اما حاضر نبوده، حتی یکی از آنها را به خواهرش بدهد. آدم مورد اعتماد معلم باشد و چنین خبطی بکند؟ و تازه جواب معلم را چه بدهد؟ ناچار خواهر او را لو داده بوده. بعد از او معلم را احضار کردم. علت احضار را میدانست. و داد میزد که چیزی ندارد بگوید. پس از یک هفته مهلت، هنوز از وقاحتی که من پیدا کرده بودم، تا از آدم خلع سلاحشدهای مثل او، دست بر ندارم، در تعجب بود. به او سیگار تعارف کردم و این قصه را برایش تعریف کردم که در اوایل تأسیس وزارت معارف، یک روز به وزیر خبر میدهند که فلان معلم با فلان بچه روابطی دارد. وزیر فوراً او را میخواهد و حال و احوال او را میپرسد و اینکه چرا تا به حال زن نگرفته و ناچار تقصیر گردن بیپولی میافتد و دستور که فلان قدر به او کمک کنند تا عروسی راه بیندازد و خود او هم دعوت بشود و قضیه به همین سادگی تمام میشود. و بعد گفتم که خیلی جوانها هستند که نمیتوانند زن بگیرند و وزرای فرهنگ هم این روزها گرفتار مصاحبههای روزنامهای و رادیویی هستند. اما در نجیبخانهها که باز است و ازین مزخرفات... و همدردی و نگذاشتم یک کلمه حرف بزند. بعد هم عکس را که توی پاکت گذاشته بودم، به دستش دادم و وقاحت را با این جمله به حد اعلا رساندم که:
+
+- اگر به تخته نچسبونید، ضررشون کمتره.
+
+تا حقوقم به لیست ادارهی فرهنگ برسه، سه ماه طول کشید. فرهنگیهای گداگشنه و خزانهی خالی و دستهای از پا درازتر! اما خوبیش این بود که در مدرسهی ما فراش جدیدمان پولدار بود و به همهشان قرض داد. کم کم بانک مدرسه شده بود. از سیصد و خردهای تومان که میگرفت، پنجاه تومان را هم خرج نمیکرد. نه سیگار میکشید و نه اهل سینما بود و نه برج دیگری داشت. از این گذشته، باغبان یکی از دمکلفتهای همان اطراف بود و باغی و دستگاهی و سور و ساتی و لابد آشپزخانهی مرتبی. خیلی زود معلمها فهمیدند که یک فراش پولدار خیلی بیشتر به درد میخورد تا یک مدیر بیبو و خاصیت.
+
+این از معلمها. حقوق مرا هم هنوز از مرکز میدادند. با حقوق ماه بعد هم اسم مرا هم به لیست اداره منتقل کردند. درین مدت خودم برای خودم ورقه انجام کار مینوشتم و امضا میکردم و میرفتم از مدرسهای که قبلاً در آن درس میدادم، حقوقم را میگرفتم. سر و صدای حقوق که بلند میشد معلمها مرتب میشدند و کلاس ماهی سه چهار روز کاملاً دایر بود. تا ورقهی انجام کار به دستشان بدهم. غیر از همان یک بار - در اوایل کار- که برای معلم حساب پنج و شش قرمز توی دفتر گذاشتیم، دیگر با مداد قرمز کاری نداشتیم و خیال همهشان راحت بود. وقتی برای گرفتن حقوقم به اداره رفتم، چنان شلوغی بود که به خودم گفتم کاش اصلاً حقوقم را منتقل نکرده بودم. نه میتوانستم سر صف بایستم و نه میتوانستم از حقوقم بگذرم. تازه مگر مواجببگیر دولت چیزی جز یک انبان گشادهی پای صندوق است؟..... و اگر هم میماندی با آن شلوغی باید تا دو بعداز ظهر سر پا بایستی. همهی جیرهخوارهای اداره بو برده بودند که مدیرم. و لابد آنقدر ساده لوح بودند که فکر کنند روزی گذارشان به مدرسهی ما بیفتد. دنبال سفتهها میگشتند، به حسابدار قبلی فحش میدادند، التماس میکردند که این ماه را ندیده بگیرید و همهی حق و حسابدان شده بودند و یکی که زودتر از نوبت پولش را میگرفت صدای همه در میآمد. در لیست مدرسه، بزرگترین رقم مال من بود. درست مثل بزرگترین گناه در نامهی عمل. دو برابر فراش جدیدمان حقوق میگرفتم. از دیدن رقمهای مردنی حقوق دیگران چنان خجالت کشیدم که انگار مال آنها را دزدیدهام. و تازه خلوت که شد و ده پانزده تا امضا که کردم، صندوقدار چشمش به من افتاد و با یک معذرت، شش صد تومان پول دزدی را گذاشت کف دستم... مرده شور!
+
+هنوز برف اول نباریده بود که یک روز عصر، معلم کلاس چهار رفت زیر ماشین. زیر یک سواری. مثل همهی عصرها من مدرسه نبودم. دم غروب بود که فراش قدیمی مدرسه دم در خونهمون، خبرش را آورد. که دویدم به طرف لباسم و تا حاضر بشوم، میشنیدم که دارد قضیه را برای زنم تعریف میکند. ماشین برای یکی از آمریکاییها بوده. باقیش را از خانه که در آمدیم برایم تعریف کرد. گویا یارو خودش پشت فرمون بوده و بعد هم هول شده و در رفته. بچهها خبر را به مدرسه برگرداندهاند و تا فراش و زنش برسند، جمعیت و پاسبانها سوارش کرده بودند و فرستاده بودهاند مریضخانه. به اتوبوس که رسیدم، دیدم لاک پشت است. فراش را مرخص کردم و پریدم توی تاکسی. اول رفتم سراغ پاسگاه جدید کلانتری. تعاریف تکه و پارهای از پرونده مطلع بود. اما پرونده تصریحی نداشت که راننده که بوده. اما هیچ کس نمیدانست عاقبت چه بلایی بر سر معلم کلاس چهار ما آمده است. کشیک پاسگاه همین قدر مطلع بود که درین جور موارد «طبق جریان اداری» اول میروند سرکلانتری، بعد دایرهی تصادفات و بعد بیمارستان. اگر آشنا در نمیآمدیم، کشیک پاسگاه مسلماً نمیگذاشت به پرونده نگاه چپ بکنم. احساس کردم میان اهل محل کمکم دارم سرشناس میشوم. و از این احساس خندهام گرفت.
+
+ساعت ۸ دم در بیمارستان بودم، اگر سالم هم بود حتماً یه چیزیش شده بود. همان طور که من یه چیزیم میشد. روی در بیمارستان نوشته شده بود: «از ساعت ۷ به بعد ورود ممنوع». در زدم. از پشت در کسی همین آیه را صادر کرد. دیدم فایده ندارد و باید از یک چیزی کمک بگیرم. از قدرتی، از مقامی، از هیکلی، از یک چیزی. صدایم را کلفت کردم و گفتم:« من...» میخواستم بگویم من مدیر مدرسهام. ولی فوراً پشیمان شدم. یارو لابد میگفت مدیر مدرسه کدام سگی است؟ این بود با کمی مکث و طمطراق فراوان جملهام را این طور تمام کردم:
+
+- ...بازرس وزارت فرهنگم.
+
+که کلون صدایی کرد و لای در باز شد. یارو با چشمهایش سلام کرد. رفتم تو و با همان صدا پرسیدم:
+
+- این معلمه مدرسه که تصادف کرده...
+
+تا آخرش را خواند. یکی را صدا زد و دنبالم فرستاد که طبقهی فلان، اتاق فلان. از حیاط به راهرو و باز به حیاط دیگر که نصفش را برف پوشانده بود و من چنان میدویدم که یارو از عقب سرم هن هن میکرد. طبقهی اول و دوم و چهارم. چهار تا پله یکی. راهرو تاریک بود و پر از بوهای مخصوص بود. هن هن کنان دری را نشان داد که هل دادم و رفتم تو. بو تندتر بود و تاریکی بیشتر. تالاری بود پر از تخت و جیرجیر کفش و خرخر یک نفر. دور یک تخت چهار نفر ایستاده بودند. حتماً خودش بود. پای تخت که رسیدم، احساس کردم همهی آنچه از خشونت و تظاهر و ابهت به کمک خواسته بودم آب شد و بر سر و صورتم راه افتاد. و این معلم کلاس چهارم مدرسهام بود. سنگین و با شکم بر آمده دراز کشیده بود. خیلی کوتاهتر از زمانی که سر پا بود به نظرم آمد. صورت و سینهاش از روپوش چرکمُرد بیرون بود. صورتش را که شسته بودند کبود کبود بود، درست به رنگ جای سیلی روی صورت بچهها. مرا که دید، لبخند و چه لبخندی! شاید میخواست بگوید مدرسهای که مدیرش عصرها سر کار نباشد، باید همین جورها هم باشد. خنده توی صورت او همین طور لرزید و لرزید تا یخ زد.
+
+«آخر چرا تصادف کردی؟...»
+
+مثل این که سوال را ازو کردم. اما وقتی که دیدم نمیتواند حرف بزند و به جای هر جوابی همان خندهی یخبسته را روی صورت دارد، خودم را به عنوان او دم چک گرفتم. «آخه چرا؟ چرا این هیکل مدیر کلی را با خودت این قد این ور و آن ور میبری تا بزنندت؟ تا زیرت کنند؟ مگر نمیدانستی که معلم حق ندارد این قدر خوشهیکل باشد؟ آخر چرا تصادف کردی؟» به چنان عتاب و خطابی اینها را میگفتم که هیچ مطمئن نیستم بلند بلند به خودش نگفته باشم. و یک مرتبه به کلهام زد که «مبادا خودت چشمش زده باشی؟» و بعد: «احمق خاک بر سر! بعد از سی و چند سال عمر، تازه خرافاتی شدی!» و چنان از خودم بیزاریم گرفت که میخواستم به یکی فحش بدهم، کسی را بزنم. که چشمم به دکتر کشیک افتاد.
+
+- مرده شور این مملکتو ببره. ساعت چهار تا حالا از تن این مرد خون میره. حیفتون نیومد؟...
+
+دستی روی شانهام نشست و فریادم را خواباند. برگشتم پدرش بود. او هم میخندید. دو نفر دیگر هم با او بودند. همه دهاتیوار؛ همه خوش قد و قواره. حظ کردم! آن دو تا پسرهایش بودند یا برادرزادههایش یا کسان دیگرش. تازه داشت گل از گلم میشکفت که شنیدم:
+
+- آقا کی باشند؟
+
+این راهم دکتر کشیک گفت که من باز سوار شدم:
+
+- مرا میگید آقا؟ من هیشکی. یک آقا مدیر کوفتی. این هم معلمم.
+
+که یک مرتبه عقل هی زد و «پسر خفه شو» و خفه شدم. بغض توی گلویم بود. دلم میخواست یک کلمه دیگر بگوید. یک کنایه بزند... نسبت به مهارت هیچ دکتری تا کنون نتوانستهام قسم بخورم. دستش را دراز کرد که به اکراه فشار دادم و بعد شیشهی بزرگی را نشانم داد که وارونه بالای تخت آویزان بود و خرفهمم کرد که این جوری غذا به او میرسانند و عکس هم گرفتهاند و تا فردا صبح اگر زخمها چرک نکند، جا خواهند انداخت و گچ خواهند کرد. که یکی دیگر از راه رسید. گوشی به دست و سفید پوش و معطر. با حرکاتی مثل آرتیست سینما. سلامم کرد. صدایش در ته ذهنم چیزی را مختصر تکانی داد. اما احتیاجی به کنجکاوی نبود. یکی از شاگردهای نمیدانم چند سال پیشم بود. خودش خودش را معرفی کرد. آقای دکتر...! عجب روزگاری! هر تکه از وجودت را با مزخرفی از انبان مزخرفاتت، مثل ذرهای روزی در خاکی ریختهای که حالا سبز کرده. چشم داری احمق. این تویی که روی تخت دراز کشیدهای. ده سال آزگار از پلکان ساعات و دقایق عمرت هر لحظه یکی بالا رفته و تو فقط خستگی این بار را هنوز در تن داری. این جوجهفکلی و جوجههای دیگر که نمیشناسیشان، همه از تخمی سر در آوردهاند که روزی حصار جوانی تو بوده و حالا شکسته و خالی مانده. دستش را گرفتم و کشیدمش کناری و در گوشش هر چه بد و بیراه میدانستم، به او و همکارش و شغلش دادم. مثلاً میخواستم سفارش معلم کلاس چهار مدرسهام را کرده باشم. بعد هم سری برای پدر تکان دادم و گریختم. از در که بیرون آمدم، حیاط بود و هوای بارانی. از در بزرگ که بیرون آمدم به این فکر میکردم که «اصلا به تو چه؟ اصلاً چرا آمدی؟ میخواستی کنجکاویات را سیرکنی؟» و دست آخر به این نتیجه رسیدم که «طعمهای برای میزنشینهای شهربانی و دادگستری به دست آمده و تو نه میتوانی این طعمه را از دستشان بیرون بیاوری و نه هیچ کار دیگری میتوانی بکنی...»
+
+و داشتم سوار تاکسی میشدم تا برگردم خانه که یک دفعه به صرافت افتادم که اقلاً چرا نپرسیدی چه بلایی به سرش آمده؟» خواستم عقبگرد کنم، اما هیکل کبود معلم کلاس چهارم روی تخت بود و دیدم نمیتوانم. خجالت میکشیدم و یا میترسیدم. آن شب تا ساعت دو بیدار بودم و فردا یک گزارش مفصل به امضای مدیر مدرسه و شهادت همهی معلمها برای ادارهی فرهنگ و کلانتری محل و بعد هم دوندگی در ادارهی بیمه و قرار بر این که روزی نه تومان بودجه برای خرج بیمارستان او بدهند و عصر پس از مدتی رفتم مدرسه و کلاسها را تعطیل کردم و معلمها و بچههای ششم را فرستادم عیادتش و دسته گل و ازین بازیها... و یک ساعتی در مدرسه تنها ماندم و فارغ از همه چیز برای خودم خیال بافتم.... و فردا صبح پدرش آمد سلام و احوالپرسی و گفت یک دست و یک پایش شکسته و کمی خونریزی داخل مغز و از طرف یارو آمریکاییه آمدهاند عیادتش و وعده و وعید که وقتی خوب شد، در اصل چهار استخدامش کنند و با زبان بیزبانی حالیم کرد که گزارش را بیخود دادهام و حالا هم دادهام، دنبالش نکنم و رضایت طرفین و کاسهی از آش داغتر و از این حرفها... خاک بر سر مملکت.
+
+اوایل امر توجهی به بچهها نداشتم. خیال میکردم اختلاف سِنی میانمان آن قدر هست که کاری به کار همدیگر نداشته باشیم. همیشه سرم به کار خودم بود. در دفتر را میبستم و در گرمای بخاری دولت قلم صد تا یک غاز میزدم. اما این کار مرتب سه چهار هفته بیشتر دوام نکرد. خسته شدم. ناچار به مدرسه بیشتر میرسیدم. یاد روزهای قدیمی با دوستان قدیمی به خیر چه آدمهای پاک و بیآلایشی بودند، چه شخصیتهای بینام و نشانی و هر کدام با چه زبانی و با چه ادا و اطوارهای مخصوص به خودشان و این جوانهای چلفتهای. چه مقلدهای بیدردسری برای فرهنگیمابی! نه خبری از دیروزشان داشتند و نه از املاک تازهای که با هفتاد واسطه به دستشان داده بودند، چیزی سرشان میشد. بدتر از همه بیدست و پاییشان بود. آرام و مرتب درست مثل واگن شاه عبدالعظیم میآمدند و میرفتند. فقط بلد بودند روزی ده دقیقه دیرتر بیایند و همین. و از این هم بدتر تنگنظریشان بود.
+
+سه بار شاهد دعواهایی بودم که سر یک گلدان میخک یا شمعدانی بود. بچهباغبانها زیاد بودند و هر کدامشان حداقل ماهی یک گلدان میخک یا شمعدانی میآوردند که در آن برف و سرما نعمتی بود. اول تصمیم گرفتم، مدرسه را با آنها زینت دهم. ولی چه فایده؟ نه کسی آبشان میداد و نه مواظبتی. و باز بدتر از همهی اینها، بیشخصیتی معلمها بود که درماندهام کرده بود. دو کلمه نمیتوانستند حرف بزنند. عجب هیچکارههایی بودند! احساس کردم که روز به روز در کلاسها معلمها به جای دانشآموزان جاافتادهتر میشوند. در نتیجه گفتم بیشتر متوجه بچهها باشم.
+
+آنها که تنها با ناظم سر و کار داشتند و مثل این بود که به من فقط یک سلام نیمهجویده بدهکارند. با این همه نومیدکننده نبودند. توی کوچه مواظبشان بودم. میخواستم حرف و سخنها و درد دلها و افکارشان را از یک فحش نیمهکاره یا از یک ادای نیمهتمام حدس بزنم، که سلامنکرده در میرفتند. خیلی کم تنها به مدرسه میآمدند. پیدا بود که سر راه همدیگر میایستند یا در خانهی یکدیگر میروند. سه چهار نفرشان هم با اسکورت میآمدند. از بیست سی نفری که ناهار میماندند، فقط دو نفرشان چلو خورش میآوردند؛ فراش اولی مدرسه برایم خبر میآورد. بقیه گوشتکوبیده، پنیر گردوئی، دم پختکی و از این جور چیزها. دو نفرشان هم بودند که نان سنگک خالی میآوردند. برادر بودند. پنجم و سوم. صبح که میآمدند، جیبهاشان باد کرده بود. سنگک را نصف میکردند و توی جیبهاشان میتپاندند و ظهر میشد، مثل آنهایی که ناهارشان را در خانه میخورند، میرفتند بیرون. من فقط بیرون رفتنشان را میدیدم. اما حتی همینها هر کدام روزی، یکی دو قران از فراش مدرسه خرت و خورت میخریدند. از همان فراش قدیمی مدرسه که ماهی پنج تومان سرایداریش را وصول کرده بودم. هر روز که وارد اتاقم میشدم پشت سر من میآمد بارانیام را بر میداشت و شروع میکرد به گزارش دادن، که دیروز باز دو نفر از معلمها سر یک گلدان دعوا کردهاند یا مأمور فرماندار نظامی آمده یا دفتردار عوض شده و از این اباطیل... پیدا بود که فراش جدید هم در مطالبی که او میگفت، سهمی دارد.
+
+یک روز در حین گزارش دادن، اشارهای کرد به این مطلب که دیروز عصر یکی از بچههای کلاس چهار دو تا کله قند به او فروخته است. درست مثل اینکه سر کلاف را به دستم داده باشد پرسیدم:
+
+- چند؟
+
+- دو تومنش دادم آقا.
+
+- زحمت کشیدی. نگفتی از کجا آورده؟
+
+- من که ضامن بهشت و جهنمش نبودم آقا.
+
+بعد پرسیدم:
+
+- چرا به آقای ناظم خبر ندادی؟
+
+میدانستم که هم او و هم فراش جدید، ناظم را هووی خودشان میدانند و خیلی چیزهاشان از او مخفی بود. این بود که میان من و ناظم خاصهخرجی میکردند. در جوابم همین طور مردد مانده بود که در باز شد و فراش جدید آمد تو. که:
+
+- اگه خبرش میکرد آقا بایست سهمش رو میداد...
+
+اخمم را درهم کشیدم و گفتم:
+
+- تو باز رفتی تو کوک مردم! اونم این جوری سر نزده که نمیآیند تو اتاق کسی، پیرمرد!
+
+و بعد اسم پسرک را ازشان پرسیدم و حالیشان کردم که چندان مهم نیست و فرستادمشان برایم چای بیاورند. بعد کارم را زودتر تمام کردم و رفتم به اتاق دفتر احوالی از مادر ناظم پرسیدم و به هوای ورق زدن پروندهها فهمیدم که پسرک شاگرد دوساله است و پدرش تاجر بازار. بعد برگشتم به اتاقم. یادداشتی برای پدر نوشتم که پس فردا صبح، بیاید مدرسه و دادم دست فراش جدید که خودش برساند و رسیدش را بیاورد.
+
+و پس فردا صبح یارو آمد. باید مدیر مدرسه بود تا دانست که اولیای اطفال چه راحت تن به کوچکترین خردهفرمایشهای مدرسه میدهند. حتم دارم که اگر از اجرای ثبت هم دنبالشان بفرستی به این زودیها آفتابی نشوند. چهل و پنج ساله مردی بود با یخهی بسته بیکراوات و پالتویی که بیشتر به قبا میماند. و خجالتی مینمود. هنوز ننشسته، پرسیدم:
+
+- شما دو تا زن دارید آقا؟
+
+دربارهی پسرش برای خودم پیشگوییهایی کرده بودم و گفتم این طوری به او رودست میزنم. پیدا بود که از سؤالم زیاد یکه نخورده است. گفتم برایش چای آوردند و سیگاری تعارفش کردم که ناشیانه دود کرد از ترس این که مبادا جلویم در بیاید که - به شما چه مربوط است و از این اعتراضها - امانش ندادم و سؤالم را این جور دنبال کردم:
+
+- البته میبخشید. چون لابد به همین علت بچه شما دو سال در یک کلاس مانده.
+
+شروع کرده بودم برایش یک میتینگ بدهم که پرید وسط حرفم:
+
+- به سر شما قسم، روزی چهار زار پول تو جیبی داره آقا. پدرسوختهی نمک به حروم...!
+
+حالیش کردم که علت، پول تو جیبی نیست و خواستم که عصبانی نشود و قول گرفتم که اصلاً به روی پسرش هم نیاورد و آن وقت میتینگم را برایش دادم که لابد پسر در خانه مهر و محبتی نمیبیند و غیبگوییهای دیگر... تا عاقبت یارو خجالتش ریخت و سرِ درد دلش باز شد که عفریته زن اولش همچه بوده و همچون بوده و پسرش هم به خودش برده و کی طلاقش داده و از زن دومش چند تا بچه دارد و این نرهخر حالا باید برای خودش نانآور شده باشد و زنش حق دارد که با دو تا بچهی خردهپا به او نرسد... من هم کلی برایش صحبت کردم. چایی دومش را هم سر کشید و قولهایش را که داد و رفت، من به این فکر افتادم که «نکند علمای تعلیم و تربیت هم، همین جورها تخم دوزرده میکنند!»
+
+یک روز صبح که رسیدم، ناظم هنوز نیامده بود. از این اتفاقها کم میافتاد. ده دقیقهای از زنگ میگذشت و معلمها در دفتر سرگرم اختلاط بودند. خودم هم وقتی معلم بودم به این مرض دچار بودم. اما وقتی مدیر شدم تازه فهمیدم که معلمها چه لذتی میبرند. حق هم داشتند. آدم وقتی مجبور باشد شکلکی را به صورت بگذارد که نه دیگران از آن میخندند و نه خود آدم لذتی میبرد، پیداست که رفع تکلیف میکند. زنگ را گفتم زدند و بچهها سر کلاس رفتند. دو تا از کلاسها بیمعلم بود. یکی از ششمیها را فرستادم سر کلاس سوم که برایشان دیکته بگوید و خودم رفتم سر کلاس چهار. مدیر هم که باشی، باز باید تمرین کنی که مبادا فوت و فن معلمی از یادت برود. در حال صحبت با بچهها بودم که فراش خبر آورد که خانمی توی دفتر منتظرم است. خیال کردم لابد همان زنکهی بیکارهای است که هفتهای یک بار به هوای سرکشی، به وضع درس و مشق بچهاش سری میزند. زن سفیدرویی بود با چشمهای درشت محزون و موی بور. بیست و پنج ساله هم نمینمود. اما بچهاش کلاس سوم بود. روز اول که دیدمش لباس نارنجی به تن داشت و تن بزک کرده بود. از زیارت من خیلی خوشحال شد و از مراتب فضل و ادبم خبر داشت.
+
+خیلی ساده آمده بود تا با دو تا مرد حرفی زده باشد. آن طور که ناظم خبر میداد، یک سالی طلاق گرفته بود و روی هم رفته آمد و رفتنش به مدرسه باعث دردسر بود. وسط بیابان و مدرسهای پر از معلمهای عزب و بیدست و پا و یک زن زیبا... ناچار جور در نمیآمد. این بود که دفعات بعد دست به سرش میکردم، اما از رو نمیرفت. سراغ ناظم و اتاق دفتر را میگرفت و صبر میکرد تا زنگ را بزنند و معلمها جمع بشوند و لابد حرف و سخنی و خندهای و بعد از معلم کلاس سوم سراغ کار و بار و بچهاش را میگرفت و زنگ بعد را که میزدند، خداحافظی میکرد و میرفت. آزاری نداشت. با چشمهایش نفس معلمها را میبرید. و حالا باز هم همان زن بود و آمده بود و من تا از پلکان پایین بروم در ذهنم جملات زنندهای ردیف میکردم، تا پایش را از مدرسه ببرد که در را باز کردم و سلام...
+
+عجب! او نبود. دخترک یکی دو سالهای بود با دهان گشاد و موهای زبرش را به زحمت عقب سرش گلوله کرده بود و بفهمی نفهمی دستی توی صورتش برده بود. روی هم رفته زشت نبود. اما داد میزد که معلم است. گفتم که مدیر مدرسهام و حکمش را داد دستم که دانشسرا دیده بود و تازه استخدام شده بود. برایمان معلم فرستاده بودند. خواستم بگویم «مگر رئیس فرهنگ نمیداند که این جا بیش از حد مرد است» ولی دیدم لزومی ندارد و فکر کردم این هم خودش تنوعی است.
+
+به هر صورت زنی بود و میتوانست محیط خشن مدرسه را که به طرز ناشیانهای پسرانه بود، لطافتی بدهد و خوشآمد گفتم و چای آوردند که نخورد و بردمش کلاسهای سوم و چهارم را نشانش دادم که هر کدام را مایل است، قبول کند و صحبت از هجده ساعت درس که در انتظار او بود و برگشتیم به دفتر .پرسید غیر از او هم، معلم زن داریم. گفتم:
+
+- متأسفانه راه مدرسهی ما را برای پاشنهی کفش خانمها نساختهاند.
+
+که خندید و احساس کردم زورکی میخندد. بعد کمی این دست و آن دست کرد و عاقبت:
+
+- آخه من شنیده بودم شما با معلماتون خیلی خوب تا میکنید.
+
+صدای جذابی داشت. فکر کردم حیف که این صدا را پای تخته سیاه خراب خواهد کرد. و گفتم:
+
+- اما نه این قدر که مدرسه تعطیل بشود خانم! و لابد به عرضتون رسیده که همکارهای شما، خودشون نشستهاند و تصمیم گرفتهاند که هجده ساعت درس بدهند. بنده هیچکارهام.
+
+- اختیار دارید.
+
+و نفهمیدم با این «اختیار دارید» چه میخواست بگوید. اما پیدا بود که بحث سر ساعات درس نیست. آناً تصمیم گرفتم، امتحانی بکنم:
+
+- این را هم اطلاع داشته باشید که فقط دو تا از معلمهای ما متأهلاند.
+
+که قرمز شد و برای این که کار دیگری نکرده باشد، برخاست و حکمش را از روی میز برداشت. پا به پا میشد که دیدم باید به دادش برسم. ساعت را از او پرسیدم. وقت زنگ بود. فراش را صدا کردم که زنگ را بزند و بعد به او گفتم، بهتر است مشورت دیگری هم با رئیس فرهنگ بکند و ما به هر صورت خوشحال خواهیم شد که افتخار همکاری با خانمی مثل ایشان را داشته باشیم و خداحافظ شما. از در دفتر که بیرون رفت، صدای زنگ برخاست و معلمها انگار موشان را آتش زدهاند، به عجله رسیدند و هر کدام از پشت سر، آن قدر او را پاییدند تا از در بزرگ آهنی مدرسه بیرون رفت.
+
+فردا صبح معلوم شد که ناظم، دنبال کار مادرش بوده است که قرار بود بستری شود، تا جای سرطان گرفته را یک دوره برق بگذارند. کل کار بیمارستان را من به کمک دوستانم انجام دادم و موقع آن رسیده بود که مادرش برود بیمارستان اما وحشتش گرفته بود و حاضر نبود به بیمارستان برود. و ناظم میخواست رسماً دخالت کنم و با هم برویم خانهشان و با زبان چرب و نرمی که به قول ناظم داشتم مادرش را راضی کنم. چارهای نبود. مدرسه را به معلمها سپردیم و راه افتادیم. بالاخره به خانهی آنها رسیدیم. خانهای بسیار کوچک و اجارهای. مادر با چشمهای گود نشسته و انگار زغال به صورت مالیده! سیاه نبود اما رنگش چنان تیره بود که وحشتم گرفت. اصلاً صورت نبود. زخم سیاه شدهای بود که انگار از جای چشمها و دهان سر باز کرده است. کلی با مادرش صحبت کردم. از پسرش و کلی دروغ و دونگ، و چادرش را روی چارقدش انداختیم و علی... و خلاصه در بیمارستان بستری شدند.
+
+فردا که به مدرسه آمدم، ناظم سرحال بود و پیدا بود که از شر چیزی خلاص شده است و خبر داد که معلم کلاس سه را گرفتهاند. یک ماه و خردهای میشد که مخفی بود و ما ورقهی انجام کارش را به جانشین غیر رسمیاش داده بودیم و حقوقش لنگ نشده بود و تا خبر رسمی بشنود و در روزنامهای بیابد و قضیه به ادارهی فرهنگ و لیست حقوق بکشد، باز هم میدادیم. اما خبر که رسمی شد، جانشین واجد شرایط هم نمیتوانست بفرستد و باید طبق مقررات رفتار میکردیم و بدیش همین بود. کم کم احساس کردم که مدرسه خلوت شده است و کلاسها اغلب اوقات بیکارند. جانشین معلم کلاس چهار هنوز سر و صورتی به کارش نداده بود و حالا یک کلاس دیگر هم بیمعلم شد. این بود که باز هم به سراغ رئیس فرهنگ رفتم. معلوم شد آن دخترک ترسیده و «نرسیده متلک پیچش کردهاید» رئیس فرهنگ این طور میگفت. و ترجیح داده بود همان زیر نظر خودش دفترداری کند. و بعد قول و قرار و فردا و پس فردا و عاقبت چهار روز دوندگی تا دو تا معلم گرفتم. یکی جوانکی رشتی که گذاشتیمش کلاس چهار و دیگری باز یکی ازین آقاپسرهای بریانتینزده که هر روز کراوات عوض میکرد، با نقشها و طرحهای عجیب. عجب فرهنگ را با قرتیها در آمیخته بودند! باداباد. او را هم گذاشتیم سر کلاس سه. اواخر بهمن، یک روز ناظم آمد اتاقم که بودجهی مدرسه را زنده کرده است. گفتم:
+
+- مبارکه، چه قدر گرفتی؟
+
+- هنوز هیچ چی آقا. قراره فردا سر ظهر بیاند این جا آقا و همین جا قالش رو بکنند.
+
+و فردا اصلاً مدرسه نرفتم. حتماً میخواست من هم باشم و در بده بستان ماهی پانزده قران، حق نظافت هر اتاق نظارت کنم و از مدیریتم مایه بگذارم تا تنخواهگردان مدرسه و حق آب و دیگر پولهای عقبافتاده وصول بشود... فردا سه نفری آمده بودند مدرسه. ناهار هم به خرج ناظم خورده بودند. و قرار دیگری برای یک سور حسابی گذاشته بودند و رفته بودند و ناظم با زبان بیزبانی حالیم کرد که این بار حتماً باید باشم و آن طور که میگفت، جای شکرش باقی بود که مراعات کرده بودند و حق بوقی نخواسته بودند. اولین باری بود که چنین اهمیتی پیدا میکردم. این هم یک مزیت دیگر مدیری مدرسه بود! سی صد تومان از بودجهی دولت بسته به این بود که به فلان مجلس بروی یا نروی. تا سه روز دیگر موعد سور بود، اصلاً یادم نیست چه کردم. اما همهاش در این فکر بودم که بروم یا نروم؟ یک بار دیگر استعفانامهام را توی جیبم گذاشتم و بی این که صدایش را در بیاورم، روز سور هم نرفتم.
+
+بعد دیدم این طور که نمیشود. گفتم بروم قضایا را برای رئیس فرهنگ بگویم. و رفتم. سلام و احوالپرسی نشستم. اما چه بگویم؟ بگویم چون نمیخواستم در خوردن سور شرکت کنم، استعفا میدهم؟... دیدم چیزی ندارم که بگویم. و از این گذشته خفتآور نبود که به خاطر سیصد تومان جا بزنم و استعفا بدهم؟ و «خداحافظ؛ فقط آمده بودم سلام عرض کنم.» و از این دروغها و استعفانامهام را توی جوی آب انداختم. اما ناظم؛ یک هفتهای مثل سگ بود. عصبانی، پر سر و صدا و شارت و شورت! حتی نرفتم احوال مادرش را بپرسم. یک هفتهی تمام میرفتم و در اتاقم را میبستم و سوراخهای گوشم را میگرفتم و تا اِز و چِزّ بچهها بخوابد، از این سر تا آن سر اتاق را میکوبیدم. ده روز تمام، قلب من و بچهها با هم و به یک اندازه از ترس و وحشت تپید. تا عاقبت پولها وصول شد. منتها به جای سیصد و خردهای، فقط صد و پنجاه تومان. علت هم این بود که در تنظیم صورت حسابها اشتباهاتی رخ داده بود که ناچار اصلاحش کرده بودند!
+
+غیر از آن زنی که هفتهای یک بار به مدرسه سری میزد، از اولیای اطفال دو سه نفر دیگر هم بودند که مرتب بودند. یکی همان پاسبانی که با کمربند، پاهای پسرش را بست و فلک کرد. یکی هم کارمند پست و تلگرافی بود که ده روزی یک بار میآمد و پدر همان بچهی شیطان. و یک استاد نجار که پسرش کلاس اول بود و خودش سواد داشت و به آن میبالید و کارآمد مینمود. یک مقنی هم بود درشت استخوان و بلندقد که بچهاش کلاس سوم بود و هفتهای یک بار میآمد و همان توی حیاط، ده پانزده دقیقهای با فراشها اختلاط میکرد و بی سر و صدا میرفت. نه کاری داشت، نه چیزی از آدم میخواست و همان طور که آمده بود چند دقیقهای را با فراش صحبت میکرد و بعد می رفت. فقط یک روز نمیدانم چرا رفته بود بالای دیوار مدرسه. البته اول فکر کردم مأمور اداره برق است ولی بعد متوجه شدم که همان مرد مقنی است. بچهها جیغ و فریاد میکردند و من همهاش درین فکر بودم که چه طور به سر دیوار رفته است؟ ماحصل داد و فریادش این بود که چرا اسم پسر او را برای گرفتن کفش و لباس به انجمن ندادیم. وقتی به او رسیدم نگاهی به او انداختم و بعد تشری به ناظم و معلم ها زدم که ولش کردند و بچهها رفتند سر کلاس و بعد بی این که نگاهی به او بکنم، گفتم:
+
+- خسته نباشی اوستا.
+
+و همان طور که به طرف دفتر میرفتم رو به ناظم و معلمها افزودم:
+
+- لابد جواب درست و حسابی نشنیده که رفته سر دیوار.
+
+که پشت سرم گرپ صدایی آمد و از در دفتر که رفتم تو، او و ناظم با هم وارد شدند. گفتم نشست. و به جای اینکه حرفی بزند به گریه افتاد. هرگز گمان نمیکردم از چنان قد و قامتی صدای گریه در بیاید. این بود که از اتاق بیرون آمدم و فراش را صدا زدم که آب برایش بیاورد و حالش که جا آمد، بیاوردش پهلوی من. اما دیگر از او خبری نشد که نشد. نه آن روز و نه هیچ روز دیگر. آن روز چند دقیقهای بعد از شیشهی اتاق خودم دیدمش که دمش را لای پایش گذاشته بود از در مدرسه بیرون میرفت و فراش جدید آمد که بله میگفتند از پسرش پنج تومان خواسته بودند تا اسمش را برای کفش و لباس به انجمن بدهند. پیدا بود باز توی کوک ناظم رفته است. مرخصش کردم و ناظم را خواستم. معلوم شد میخواسته ناظم را بزند. همین جوری و بیمقدمه.
+
+اواخر بهمن بود که یکی از روزهای برفی با یکی دیگر از اولیای اطفال آشنا شدم. یارو مرد بسیار کوتاهی بود؛ فرنگ مآب و بزک کرده و اتو کشیده که ننشسته از تحصیلاتش و از سفرهای فرنگش حرف زد. میخواست پسرش را آن وقت سال از مدرسهی دیگر به آن جا بیاورد. پسرش از آن بچههایی بود که شیر و مربای صبحانهاش را با قربان صدقه توی حلقشان میتپانند. کلاس دوم بود و ثلث اول دو تا تجدید آورده بود. میگفت در باغ ییلاقیاش که نزدیک مدرسه است، باغبانی دارند که پسرش شاگرد ماست و درسخوان است و پیدا است که بچهها زیر سایه شما خوب پیشرفت میکنند. و از این پیزرها. و حال به خاطر همین بچه، توی این برف و سرما، آمدهاند ساکن باغ ییلاقی شدهاند. بلند شدم ناظم را صدا کردم و دست او و بچهاش را توی دست ناظم گذاشتم و خداحافظ شما... و نیم ساعت بعد ناظم برگشت که یارو خانهی شهرش را به یک دبیرستان اجاره داده، به ماهی سه هزار و دویست تومان، و التماس دعا داشته، یعنی معلم سرخانه میخواسته و حتی بدش نمیآمده است که خود مدیر زحمت بکشند و ازین گندهگوزیها... احساس کردم که ناظم دهانش آب افتاده است. و من به ناظم حالی کردم خودش برود بهتر است و فقط کاری بکند که نه صدای معلمها در بیاید و نه آخر سال، برای یک معدل ده احتیاجی به من بمیرم و تو بمیری پیدا کند. همان روز عصر ناظم رفته بود و قرار و مدار برای هر روز عصر یک ساعت به ماهی صد و پنجاه تومان.
+
+دیگر دنیا به کام ناظم بود. حال مادرش هم بهتر بود و از بیمارستان مرخصش کرده بودند و به فکر زن گرفتن افتاده بود. و هر روز هم برای یک نفر نقشه میکشید حتی برای من هم. یک روز در آمد که چرا ما خودمان «انجمن خانه و مدرسه» نداشته باشیم؟ نشسته بود و حسابش را کرده بود دیده بود که پنجاه شصت نفری از اولیای مدرسه دستشان به دهانشان میرسد و از آن هم که به پسرش درس خصوصی میداد قول مساعد گرفته بود. حالیش کردم که مواظب حرف و سخن ادارهای باشد و هر کار دلش میخواهد بکند. کاغذ دعوت را هم برایش نوشتم با آب و تاب و خودش برای ادارهی فرهنگ، داد ماشین کردند و به وسیلهی خود بچهها فرستاد. و جلسه با حضور بیست و چند نفری از اولیای بچهها رسمی شد. خوبیش این بود که پاسبان کشیک پاسگاه هم آمده بود و دم در برای همه، پاشنههایش را به هم میکوبید و معلمها گوش تا گوش نشسته بودند و مجلس ابهتی داشت و ناظم، چای و شیرینی تهیه کرده بود و چراغ زنبوری کرایه کرده بود و باران هم گذاشت پشتش و سالون برای اولین بار در عمرش به نوایی رسید.
+
+یک سرهنگ بود که رئیسش کردیم و آن زن را که هفتهای یک بار میآمد نایب رئیس. آن که ناظم به پسرش درس خصوصی میداد نیامده بود. اما پاکت سربستهای به اسم مدیر فرستاده بود که فیالمجلس بازش کردیم. عذرخواهی از اینکه نتوانسته بود بیاید و وجه ناقابلی جوف پاکت. صد و پنجاه تومان. و پول را روی میز صندوقدار گذاشتیم که ضبط و ربط کند. نائب رئیس بزک کرده و معطر شیرینی تعارف میکرد و معلمها با هر بار که شیرینی بر میداشتند، یک بار تا بناگوش سرخ میشدند و فراشها دست به دست چای میآوردند.
+
+در فکر بودم که یک مرتبه احساس کردم، سیصد چهارصد تومان پول نقد، روی میز است و هشت صد تومان هم تعهد کرده بودند. پیرزن صندوقدار که کیف پولش را همراهش نیاورده بود ناچار حضار تصویب کردند که پولها فعلاً پیش ناظم باشد. و صورت مجلس مرتب شد و امضاها ردیف پای آن و فردا فهمیدم که ناظم همان شب روی خشت نشسته بوده و به معلمها سور داده بوده است. اولین کاری که کردم رونوشت مجلس آن شب را برای ادارهی فرهنگ فرستادم. و بعد همان استاد نجار را صدا کردم و دستور دادم برای مستراحها دو روزه در بسازد که ناظم خیلی به سختی پولش را داد. و بعد در کوچهی مدرسه درخت کاشتیم. تور والیبال را تعویض و تعدادی توپ در اختیار بچهها گذاشتیم برای تمرین در بعد از ظهرها و آمادگی برای مسابقه با دیگر مدارس و در همین حین سر و کلهی بازرس تربیت بدنی هم پیدا شد و هر روز سرکشی و بیا و برو. تا یک روز که به مدرسه رسیدم شنیدم که از سالون سر و صدا میآید. صدای هالتر بود. ناظم سر خود رفته بود و سرخود دویست سیصد تومان داده بود و هالتر خریده بود و بچههای لاغر زیر بار آن گردن خود را خرد میکردند. من در این میان حرفی نزدم. میتوانستم حرفی بزنم؟ من چیکاره بودم؟ اصلاً به من چه ربطی داشت؟ هر کار که دلشان میخواهد بکنند. مهم این بود که سالون مدرسه رونقی گرفته بود. ناظم هم راضی بود و معلمها هم. چون نه خبر از حسادتی بود و نه حرف و سخنی پیش آمد. فقط میبایست به ناظم سفارش می کردم که فکر فراشها هم باشد.
+
+کم کم خودمان را برای امتحانهای ثلث دوم آماده میکردیم. این بود که اوایل اسفند، یک روز معلمها را صدا زدم و در شورا مانندی که کردیم بیمقدمه برایشان داستان یکی از همکاران سابقم را گفتم که هر وقت بیست میداد تا دو روز تب داشت. البته معلمها خندیدند. ناچار تشویق شدم و داستان آخوندی را گفتم که در بچگی معلم شرعیاتمان بود و زیر عبایش نمره میداد و دستش چنان میلرزید که عبا تکان میخورد و درست ده دقیقه طول میکشید. و تازه چند؟ بهترین شاگردها دوازده. و البته باز هم خندیدند. که این بار کلافهام کرد. و بعد حالیشان کردم که بد نیست در طرح سؤالها مشورت کنیم و از این حرفها...
+
+و از شنبهی بعد، امتحانات شروع شد. درست از نیمهی دوم اسفند. سؤالها را سه نفری میدیدیم. خودم با معلم هر کلاس و ناظم. در سالون میزها را چیده بودیم البته از وقتی هالتردار شده بود خیلی زیباتر شده بود. در سالون کاردستیهای بچهها در همه جا به چشم میخورد. هر کسی هر چیزی را به عنوان کاردستی درست کرده بودند و آورده بودند. که برای این کاردستیها چه پولها که خرج نشده بود و چه دستها که نبریده بود و چه دعواها که نشده بود و چه عرقها که ریخته نشده بود. پیش از هر امتحان که میشد، خودم یک میتینگ برای بچهها میدادم که ترس از معلم و امتحان بیجا است و باید اعتماد به نفس داشت و ازین مزخرفات....ولی مگر حرف به گوش کسی میرفت؟ از در که وارد میشدند، چنان هجومی میبردند که نگو! به جاهای دور از نظر. یک بار چنان بود که احساس کردم مثل اینکه از ترس، لذت میبرند. اگر معلم نبودی یا مدیر، به راحتی میتوانستی حدس بزنی که کیها با هم قرار و مداری دارند و کدام یک پهلو دست کدام یک خواهد نشست. یکی دو بار کوشیدم بالای دست یکیشان بایستم و ببینم چه مینویسد. ولی چنان مضطرب میشدند و دستشان به لرزه میافتاد که از نوشتن باز میماندند. میدیدم که این مردان آینده، درین کلاسها و امتحانها آن قدر خواهند ترسید که وقتی دیپلمه بشوند یا لیسانسه، اصلاً آدم نوع جدیدی خواهند شد. آدمی انباشته از وحشت، انبانی از ترس و دلهره. به این ترتیب یک روز بیشتر دوام نیاوردم. چون دیدم نمیتوانم قلب بچگانهای داشته باشم تا با آن ترس و وحشت بچهها را درک کنم و همدردی نشان بدهم.این جور بود که میدیدم که معلم مدرسه هم نمیتوانم باشم.
+
+دو روز قبل از عید کارنامهها آماده بود و منتظر امضای مدیر. دویست و سی و شش تا امضا اقلاً تا ظهر طول میکشید. پیش از آن هم تا میتوانستم از امضای دفترهای حضور و غیاب میگریختم. خیلی از جیرهخورهای دولت در ادارات دیگر یا در میان همکارانم دیده بودم که در مواقع بیکاری تمرین امضا میکنند. پیش از آن نمیتوانستم بفهمم چه طور از مدیری یک مدرسه یا کارمندی ساده یک اداره میشود به وزارت رسید. یا اصلاً آرزویش را داشت. نیمقراضه امضای آماده و هر کدام معرف یک شخصیت، بعد نیمذرع زبان چرب و نرم که با آن، مار را از سوراخ بیرون بکشی، یا همه جا را بلیسی و یک دست هم قیافه. نه یک جور. دوازده جور.
+
+در این فکرها بودم که ناگهان در میان کارنامهها چشمم به یک اسم آشنا افتاد. به اسم پسران جناب سرهنگ که رئیس انجمن بود. رفتم توی نخ نمراتش. همه متوسط بود و جای ایرادی نبود. و یک مرتبه به صرافت افتادم که از اول سال تا به حال بچههای مدرسه را فقط به اعتبار وضع مالی پدرشان قضاوت کردهام. درست مثل این پسر سرهنگ که به اعتبار کیابیای پدرش درس نمیخواند. دیدم هر کدام که پدرشان فقیرتر است به نظر من باهوشتر میآمدهاند. البته ناظم با این حرفها کاری نداشت. مر قانونی را عمل میکرد. از یکی چشم میپوشید به دیگری سخت میگرفت.
+
+اما من مثل این که قضاوتم را دربارهی بچهها از پیش کرده باشم و چه خوب بود که نمرهها در اختیار من نبود و آن یکی هم «انظباط» مال آخر سال بود. مسخرهترین کارها آن است که کسی به اصلاح وضعی دست بزند، اما در قلمروی که تا سر دماغش بیشتر نیست. و تازه مدرسهی من، این قلمروی فعالیت من، تا سر دماغم هم نبود. به همان توی ذهنم ختم میشد. وضعی را که دیگران ترتیب داده بودند. به این ترتیب بعد از پنج شش ماه، میفهمیدم که حسابم یک حساب عقلایی نبوده است. احساساتی بوده است. ضعفهای احساساتی مرا خشونتهای عملی ناظم جبران میکرد و این بود که جمعاً نمیتوانستم ازو بگذرم. مرد عمل بود. کار را میبرید و پیش میرفت. در زندگی و در هر کاری، هر قدمی بر میداشت، برایش هدف بود. و چشم از وجوه دیگر قضیه میپوشید. این بود که برش داشت. و من نمیتوانستم. چرا که اصلاً مدیر نبودم. خلاص...
+
+و کارنامهی پسر سرهنگ را که زیر دستم عرق کرده بود، به دقت و احتیاج خشک کردم و امضایی زیر آن گذاشتم به قدری بد خط و مسخره بود که به یاد امضای فراش جدیدمان افتادم. حتماً جناب سرهنگ کلافه میشد که چرا چنین آدم بیسوادی را با این خط و ربط امضا مدیر مدرسه کردهاند. آخر یک جناب سرهنگ هم میداند که امضای آدم معرف شخصیت آدم است.
+
+اواخر تعطیلات نوروز رفتم به ملاقات معلم ترکهای کلاس سوم. ناظم که با او میانهی خوشی نداشت. ناچار با معلم حساب کلاس پنج و شش قرار و مداری گذاشته بودم که مختصری علاقهای هم به آن حرف و سخنها داشت. هم به وسیلهی او بود که میدانستم نشانیاش کجا است و توی کدام زندان است. در راه قبل از هر چیز خبر داد که رئیس فرهنگ عوض شده و این طور که شایع است یکی از هم دورهایهای من، جایش آمده. گفتم:
+
+- عجب! چرا؟ مگه رئیس قبلی چپش کم بود؟
+
+- چه عرض کنم. میگند پا تو کفش یکی از نمایندهها کرده. شما خبر ندارید؟
+
+- چه طور؟ از کجا خبر داشته باشم؟
+
+- هیچ چی... می گند دو تا از کارچاقکنهای انتخاباتی یارو از صندوق فرهنگ حقوق میگرفتهاند؛ شب عیدی رئیس فرهنگ حقوقشون رو زده.
+
+- عجب! پس اونم میخواسته اصلاحات کنه! بیچاره.
+
+و بعد از این حرف زدیم که الحمدالله مدرسه مرتب است و آرام و معلمها همکاری میکنند و ناظم بیش از اندازه همهکاره شده است. و من فهمیدم که باز لابد مشتری خصوصی تازهای پیدا شده است که سر و صدای همه همکارها بلند شده. دم در زندان شلوغ بود. کلاه مخملیها، عمقزی گلبتهها، خاله خانباجیها و... اسم نوشتیم و نوبت گرفتیم و به جای پاها، دستهامان زیر بار کوچکی که داشتیم، خسته شد و خواب رفت تا نوبتمان شد. از این اتاق به آن اتاق و عاقبت نردههای آهنی و پشت آن معلم کلاس سه و... عجب چاق شده بود!درست مثل یک آدم حسابی شده بود. خوشحال شدیم و احوالپرسی و تشکر؛ و دیگر چه بگویم؟ بگویم چرا خودت را به دردسر انداختی؟ پیدا بود از مدرسه و کلاس به او خوشتر میگذرد. ایمانی بود و او آن را داشت و خوشبخت بود و دردسری نمیدید و زندان حداقل برایش کلاس درس بود. عاقبت پرسیدم:
+
+- پروندهای هم برات درست کردند یا هنوز بلاتکلیفی؟
+
+- امتحانمو دادم آقا مدیر، بد از آب در نیومد.
+
+- یعنی چه؟
+
+- یعنی بیتکلیف نیستم. چون اسمم تو لیست جیرهی زندون رفته. خیالم راحته. چون سختیهاش گذشته.
+
+دیگر چه بگویم. دیدم چیزی ندارم خداحافظی کردم و او را با معلم حساب تنها گذاشتم و آمدم بیرون و تا مدت ملاقات تمام بشود، دم در زندان قدم زدم و به زندانی فکر کردم که برای خودم ساخته بودم. یعنی آن خرپول فرهنگدوست ساخته بود. و من به میل و رغبت خودم را در آن زندانی کرده بودم. این یکی را به ضرب دگنک این جا آورده بودند. ناچار حق داشت که خیالش راحت باشد. اما من به میل و رغبت رفته بودم و چه بکنم؟ ناظم چه طور؟ راستی اگر رئیس فرهنگ از هم دورهایهای خودم باشد؛ چه طور است بروم و ازو بخواهم که ناظم را جای من بگذارد، یا همین معلم حساب را؟... که معلم حساب در آمد و راه افتادیم. با او هم دیگر حرفی نداشتم. سر پیچ خداحافظ شما و تاکسی گرفتم و یک سر به ادارهی فرهنگ زدم. گرچه دهم عید بود، اما هنوز رفت و آمد سال نو تمام نشده بود. برو و بیا و شیرینی و چای دو جانبه. رفتم تو. سلام و تبریک و همین تعارفات را پراندم.
+
+بله خودش بود. یکی از پخمههای کلاس. که آخر سال سوم کشتیارش شدم دو بیت شعر را حفظ کند، نتوانست که نتوانست. و حالا او رئیس بود و من آقا مدیر. راستی حیف از من، که حتی وزیر چنین رئیس فرهنگهایی باشم! میز همان طور پاک بود و رفته. اما زیرسیگاری انباشته از خاکستر و ته سیگار. بلند شد و چلپ و چولوپ روبوسی کردیم و پهلوی خودش جا باز کرد و گوش تا گوش جیرهخورهای فرهنگ تبریکات صمیمانه و بدگویی از ماسبق و هندوانه و پیزرها! و دو نفر که قد و قوارهشان به درد گود زورخانه میخورد یا پای صندوق انتخابات شیرینی به مردم میدادند. نزدیک بود شیرینی را توی ظرفش بیندازم که دیدم بسیار احمقانه است. سیگارم که تمام شد قضیهی رئیس فرهنگ قبلی و آن دو نفر را در گوشی ازش پرسیدم، حرفی نزد. فقط نگاهی میکرد که شبیه التماس بود و من فرصت جستم تا وضع معلم کلاس سوم را برایش روشن کنم و از او بخواهم تا آن جا که میتواند جلوی حقوقش را نگیرد. و از در که آمدم بیرون، تازه یادم آمد که برای کار دیگری پیش رئیس فرهنگ بودم.
+
+باز دیروز افتضاحی به پا شد. معقول یک ماههی فروردین راحت بودیم. اول اردیبهشت ماه جلالی و کوس رسوایی سر دیوار مدرسه. نزدیک آخر وقت یک جفت پدر و مادر، بچهشان در میان، وارد اتاق شدند. یکی بر افروخته و دیگری رنگ و رو باخته و بچهشان عیناً مثل این عروسکهای کوکی. سلام و علیک و نشستند. خدایا دیگر چه اتفاقی افتاده است؟
+
+- چه خبر شده که با خانوم سرافرازمون کردید؟
+
+مرد اشارهای به زنش کرد که بلند شد و دست بچه را گرفت و رفت بیرون و من ماندم و پدر. اما حرف نمیزد. به خودش فرصت میداد تا عصبانیتش بپزد. سیگارم را در آوردم و تعارفش کردم. مثل این که مگس مزاحمی را از روی دماغش بپراند، سیگار را رد کرد و من که سیگارم را آتش میزدم، فکر کردم لابد دردی دارد که چنین دست و پا بسته و چنین متکی به خانواده به مدرسه آمده. باز پرسیدم:
+
+- خوب، حالا چه فرمایش داشتید؟
+
+که یک مرتبه ترکید:
+
+- اگه من مدیر مدرسه بودم و همچه اتفاقی میافتاد، شیکم خودمو پاره میکردم. خجالت بکش مرد! برو استعفا بده. تا اهل محل نریختن تیکه تیکهات کنند، دو تا گوشتو وردار و دررو. بچههای مردم میآن این جا درس بخونن و حسن اخلاق. نمیآن که...
+
+- این مزخرفات کدومه آقا! حرف حساب سرکار چیه؟
+
+و حرکتی کردم که او را از در بیندازم بیرون. اما آخر باید میفهمیدم چه مرگش است. «ولی آخر با من چه کار دارد؟»
+
+- آبروی من رفته. آبروی صد سالهی خونوادهام رفته. اگه در مدرسهی تو رو تخته نکنم، تخم بابام نیستم. آخه من دیگه با این بچه چی کار کنم؟ تو این مدرسه ناموس مردم در خطره. کلانتری فهمیده؛ پزشک قانونی فهمیده؛ یک پرونده درست شده پنجاه ورق؛ تازه میگی حرف حسابم چیه؟ حرف حسابم اینه که صندلی و این مقام از سر تو زیاده. حرف حسابم اینه که میدم محاکمهات کنند و از نون خوردن بندازنت...
+
+او میگفت و من گوش میکردم و مثل دو تا سگ هار به جان هم افتاده بودیم که در باز شد و ناظم آمد تو. به دادم رسید. در همان حال که من و پدر بچه در حال دعوا بودیم زن و بچه همان آقا رفته بودند و قضایا را برای ناظم تعریف کرده بودند و او فرستاده بوده فاعل را از کلاس کشیده بودند بیرون... و گفت چه طور است زنگ بزنیم و جلوی بچهها ادبش کنیم و کردیم. یعنی این بار خود من رفتم میدان. پسرک نرهخری بود از پنجمیها با لباس مرتب و صورت سرخ و سفید و سالکی به گونه. جلوی روی بچهها کشیدمش زیر مشت و لگد و بعد سه تا از ترکهها را که فراش جدید فوری از باغ همسایه آورده بود، به سر و صورتش خرد کردم. چنان وحشی شده بودم که اگر ترکهها نمیرسید، پسرک را کشته بودم. این هم بود که ناظم به دادش رسید و وساطت کرد و لاشهاش را توی دفتر بردند و بچهها را مرخص کردند و من به اتاقم برگشتم و با حالی زار روی صندلی افتادم، نه از پدر خبری بود و نه از مادر و نه از عروسکهای کوکیشان که ناموسش دست کاری شده بود. و تازه احساس کردم که این کتککاری را باید به او میزدم. خیس عرق بودم و دهانم تلخ بود. تمام فحشهایی که میبایست به آن مردکهی دبنگ میدادم و نداده بودم، در دهانم رسوب کرده بود و مثل دم مار تلخ شده بود. اصلاً چرا زدمش؟ چرا نگذاشتم مثل همیشه ناظم میدانداری کند که هم کارکشتهتر بود و هم خونسردتر. لابد پسرک با دخترعمهاش هم نمیتواند بازی کند. لابد توی خانوادهشان، دخترها سر ده دوازده سالگی باید از پسرهای هم سن رو بگیرند. نکند عیبی کرده باشد؟ و یک مرتبه به صرافت افتادم که بروم ببینم چه بلایی به سرش آوردهام. بلند شدم و یکی از فراشها را صدا کردم که فهمیدم روانهاش کردهاند. آبی آورد که روی دستم میریخت و صورتم را میشستم و میکوشیدم که لرزش دستهایم را نبیند. و در گوشم آهسته گفت که پسر مدیر شرکت اتوبوسرانی است و بدجوری کتک خورده و آنها خیلی سعی کردهاند که تر و تمیزش کنند...
+
+احمق مثلا داشت توی دل مرا خالی میکرد. نمیدانست که من اول تصمیم را گرفتم، بعد مثل سگ هار شدم. و تازه میفهمیدم کسی را زدهام که لیاقتش را داشته. حتماً از این اتفاقها جای دیگر هم میافتد. آدم بردارد پایین تنه بچهی خودش را، یا به قول خودش ناموسش را بگذارد سر گذر که کلانتر محل و پزشک معاینه کنند! تا پرونده درست کنند؟ با این پدرو مادرها بچهها حق دارند که قرتی و دزد و دروغگو از آب در بیایند. این مدرسهها را اول برای پدر و مادرها باز کنند...
+
+با این افکار به خانه رسیدم. زنم در را که باز کرد؛ چشمهایش گرد شد. همیشه وقتی میترسد این طور میشود. برای اینکه خیال نکند آدم کشتهام، زود قضایا را برایش گفتم. و دیدم که در ماند. یعنی ساکت ماند. آب سرد، عرق بیدمشک، سیگار پشت سیگار فایده نداشت، لقمه از گلویم پایین نمیرفت و دستها هنوز میلرزید. هر کدام به اندازهی یک ماه فعالیت کرده بودند. با سیگار چهارم شروع کردم:
+
+- میدانی زن؟ بابای یارو پولداره. مسلماً کار به دادگستری و این جور خنسها میکشه. مدیریت که الفاتحه. اما خیلی دلم میخواد قضیه به دادگاه برسه. یک سال آزگار رو دل کشیدهام و دیگه خسته شدهام. دلم میخواد یکی بپرسه چرا بچهی مردم رو این طوری زدی، چرا تنبیه بدنی کردی! آخه یک مدیر مدرسه هم حرفهایی داره که باید یک جایی بزنه...
+
+که بلند شد و رفت سراغ تلفن. دو سه تا از دوستانم را که در دادگستری کارهای بودند، گرفت و خودم قضیه را برایشان گفتم که مواظب باشند. فردا پسرک فاعل به مدرسه نیامده بود. و ناظم برایم گفت که قضیه ازین قرار بوده است که دوتایی به هوای دیدن مجموعه تمبرهای فاعل با هم به خانهای میروند و قضایا همان جا اتفاق میافتد و داد و هوار و دخالت پدر و مادرهای طرفین و خط و نشان و شبانه کلانتری؛ و تمام اهل محل خبر دارند. او هم نظرش این بود که کار به دادگستری خواهد کشید.
+
+و من یک هفتهی تمام به انتظار اخطاریهی دادگستری صبح و عصر به مدرسه رفتم و مثل بختالنصر پشت پنجره ایستادم. اما در تمام این مدت نه از فاعل خبری شد، نه از مفعول و نه از پدر و مادر ناموسپرست و نه از مدیر شرکت اتوبوسرانی. انگار نه انگار که اتفاقی افتاده. بچهها میآمدند و میرفتند؛ برای آب خوردن عجله میکردند؛ به جای بازی کتککاری میکردند و همه چیز مثل قبل بود. فقط من ماندم و یک دنیا حرف و انتظار. تا عاقبت رسید.... احضاریهای با تعیین وقت قبلی برای دو روز بعد، در فلان شعبه و پیش فلان بازپرس دادگستری. آخر کسی پیدا شده بود که به حرفم گوش کند.
+
+تا دو روز بعد که موعد احضار بود، اصلاً از خانه در نیامدم. نشستم و ماحصل حرفهایم را روی کاغذ آوردم. حرفهایی که با همهی چرندی هر وزیر فرهنگی میتوانست با آن یک برنامهی هفت ساله برای کارش بریزد. و سر ساعت معین رفتم دادگستری. اتاق معین و بازپرس معین. در را باز کردم و سلام، و تا آمدم خودم را معرفی کنم و احضاریه را در بیاورم، یارو پیشدستی کرد و صندلی آورد و چای سفارش داد و «احتیاجی به این حرفها نیست و قضیهی کوچک بود و حل شد و راضی به زحمت شما نبودیم...»
+
+که عرق سرد بر بدن من نشست. چاییام را که خوردم، روی همان کاغذ نشاندار دادگستری استعفانامهام را نوشتم و به نام همکلاسی پخمهام که تازه رئیس شده بود، دم در پست کردم.
+EOT;
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/fi_FI/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/fi_FI/Address.php
new file mode 100644
index 00000000..4061ac01
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/fi_FI/Address.php
@@ -0,0 +1,85 @@
+format('dmy');
+
+ switch ((int) ($birthdate->format('Y') / 100)) {
+ case 18:
+ $centurySign = '+';
+ break;
+ case 19:
+ $centurySign = '-';
+ break;
+ case 20:
+ $centurySign = 'A';
+ break;
+ default:
+ throw new \InvalidArgumentException('Year must be between 1800 and 2099 inclusive.');
+ }
+
+ $randomDigits = self::numberBetween(0, 89);
+ if ($gender && $gender == static::GENDER_MALE) {
+ if ($randomDigits === 0) {
+ $randomDigits .= static::randomElement([3, 5, 7, 9]);
+ } else {
+ $randomDigits .= static::randomElement([1, 3, 5, 7, 9]);
+ }
+ } elseif ($gender && $gender == static::GENDER_FEMALE) {
+ if ($randomDigits === 0) {
+ $randomDigits .= static::randomElement([2, 4, 6, 8]);
+ } else {
+ $randomDigits .= static::randomElement([0, 2, 4, 6, 8]);
+ }
+ } else {
+ if ($randomDigits === 0) {
+ $randomDigits .= self::numberBetween(2, 9);
+ } else {
+ $randomDigits .= (string) static::numerify('#');
+ }
+ }
+ $randomDigits = str_pad($randomDigits, 3, '0', STR_PAD_LEFT);
+
+ $checksum = $checksumCharacters[(int) ($datePart . $randomDigits) % strlen($checksumCharacters)];
+
+ return $datePart . $centurySign . $randomDigits . $checksum;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/fi_FI/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/fi_FI/PhoneNumber.php
new file mode 100644
index 00000000..19399c5f
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/fi_FI/PhoneNumber.php
@@ -0,0 +1,99 @@
+ 'Argovie'],
+ ['AI' => 'Appenzell Rhodes-Intérieures'],
+ ['AR' => 'Appenzell Rhodes-Extérieures'],
+ ['BE' => 'Berne'],
+ ['BL' => 'Bâle-Campagne'],
+ ['BS' => 'Bâle-Ville'],
+ ['FR' => 'Fribourg'],
+ ['GE' => 'Genève'],
+ ['GL' => 'Glaris'],
+ ['GR' => 'Grisons'],
+ ['JU' => 'Jura'],
+ ['LU' => 'Lucerne'],
+ ['NE' => 'Neuchâtel'],
+ ['NW' => 'Nidwald'],
+ ['OW' => 'Obwald'],
+ ['SG' => 'Saint-Gall'],
+ ['SH' => 'Schaffhouse'],
+ ['SO' => 'Soleure'],
+ ['SZ' => 'Schwytz'],
+ ['TG' => 'Thurgovie'],
+ ['TI' => 'Tessin'],
+ ['UR' => 'Uri'],
+ ['VD' => 'Vaud'],
+ ['VS' => 'Valais'],
+ ['ZG' => 'Zoug'],
+ ['ZH' => 'Zurich']
+ ];
+
+ protected static $cityFormats = [
+ '{{cityName}}',
+ ];
+
+ protected static $streetNameFormats = [
+ '{{streetPrefix}} {{lastName}}',
+ '{{streetPrefix}} de {{cityName}}',
+ '{{streetPrefix}} de {{lastName}}'
+ ];
+
+ protected static $streetAddressFormats = [
+ '{{streetName}} {{buildingNumber}}',
+ ];
+ protected static $addressFormats = [
+ "{{streetAddress}}\n{{postcode}} {{city}}",
+ ];
+
+ /**
+ * Returns a random street prefix
+ * @example Rue
+ * @return string
+ */
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ /**
+ * Returns a random city name.
+ * @example Luzern
+ * @return string
+ */
+ public function cityName()
+ {
+ return static::randomElement(static::$cityNames);
+ }
+
+ /**
+ * Returns a canton
+ * @example array('BE' => 'Bern')
+ * @return array
+ */
+ public static function canton()
+ {
+ return static::randomElement(static::$canton);
+ }
+
+ /**
+ * Returns the abbreviation of a canton.
+ * @return string
+ */
+ public static function cantonShort()
+ {
+ $canton = static::canton();
+ return key($canton);
+ }
+
+ /**
+ * Returns the name of canton.
+ * @return string
+ */
+ public static function cantonName()
+ {
+ $canton = static::canton();
+ return current($canton);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/fr_CH/Company.php b/vendor/fakerphp/faker/src/Faker/Provider/fr_CH/Company.php
new file mode 100644
index 00000000..fe2d2551
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/fr_CH/Company.php
@@ -0,0 +1,15 @@
+ 'Ain'], ['02' => 'Aisne'], ['03' => 'Allier'], ['04' => 'Alpes-de-Haute-Provence'], ['05' => 'Hautes-Alpes'],
+ ['06' => 'Alpes-Maritimes'], ['07' => 'Ardèche'], ['08' => 'Ardennes'], ['09' => 'Ariège'], ['10' => 'Aube'],
+ ['11' => 'Aude'], ['12' => 'Aveyron'], ['13' => 'Bouches-du-Rhône'], ['14' => 'Calvados'], ['15' => 'Cantal'],
+ ['16' => 'Charente'], ['17' => 'Charente-Maritime'], ['18' => 'Cher'], ['19' => 'Corrèze'], ['2A' => 'Corse-du-Sud'],
+ ['2B' => 'Haute-Corse'], ['21' => "Côte-d'Or"], ['22' => "Côtes-d'Armor"], ['23' => 'Creuse'], ['24' => 'Dordogne'],
+ ['25' => 'Doubs'], ['26' => 'Drôme'], ['27' => 'Eure'], ['28' => 'Eure-et-Loir'], ['29' => 'Finistère'], ['30' => 'Gard'],
+ ['31' => 'Haute-Garonne'], ['32' => 'Gers'], ['33' => 'Gironde'], ['34' => 'Hérault'], ['35' => 'Ille-et-Vilaine'],
+ ['36' => 'Indre'], ['37' => 'Indre-et-Loire'], ['38' => 'Isère'], ['39' => 'Jura'], ['40' => 'Landes'], ['41' => 'Loir-et-Cher'],
+ ['42' => 'Loire'], ['43' => 'Haute-Loire'], ['44' => 'Loire-Atlantique'], ['45' => 'Loiret'], ['46' => 'Lot'],
+ ['47' => 'Lot-et-Garonne'], ['48' => 'Lozère'], ['49' => 'Maine-et-Loire'], ['50' => 'Manche'], ['51' => 'Marne'],
+ ['52' => 'Haute-Marne'], ['53' => 'Mayenne'], ['54' => 'Meurthe-et-Moselle'], ['55' => 'Meuse'], ['56' => 'Morbihan'],
+ ['57' => 'Moselle'], ['58' => 'Nièvre'], ['59' => 'Nord'], ['60' => 'Oise'], ['61' => 'Orne'], ['62' => 'Pas-de-Calais'],
+ ['63' => 'Puy-de-Dôme'], ['64' => 'Pyrénées-Atlantiques'], ['65' => 'Hautes-Pyrénées'], ['66' => 'Pyrénées-Orientales'],
+ ['67' => 'Bas-Rhin'], ['68' => 'Haut-Rhin'], ['69' => 'Rhône'], ['70' => 'Haute-Saône'], ['71' => 'Saône-et-Loire'],
+ ['72' => 'Sarthe'], ['73' => 'Savoie'], ['74' => 'Haute-Savoie'], ['75' => 'Paris'], ['76' => 'Seine-Maritime'],
+ ['77' => 'Seine-et-Marne'], ['78' => 'Yvelines'], ['79' => 'Deux-Sèvres'], ['80' => 'Somme'], ['81' => 'Tarn'],
+ ['82' => 'Tarn-et-Garonne'], ['83' => 'Var'], ['84' => 'Vaucluse'], ['85' => 'Vendée'], ['86' => 'Vienne'],
+ ['87' => 'Haute-Vienne'], ['88' => 'Vosges'], ['89' => 'Yonne'], ['90' => 'Territoire de Belfort'], ['91' => 'Essonne'],
+ ['92' => 'Hauts-de-Seine'], ['93' => 'Seine-Saint-Denis'], ['94' => 'Val-de-Marne'], ['95' => "Val-d'Oise"],
+ ['971' => 'Guadeloupe'], ['972' => 'Martinique'], ['973' => 'Guyane'], ['974' => 'La Réunion'], ['976' => 'Mayotte']
+ ];
+
+ protected static $secondaryAddressFormats = ['Apt. ###', 'Suite ###', 'Étage ###', 'Bât. ###', 'Chambre ###'];
+
+ /**
+ * @example 'Appt. 350'
+ */
+ public static function secondaryAddress()
+ {
+ return static::numerify(static::randomElement(static::$secondaryAddressFormats));
+ }
+
+ /**
+ * @example 'rue'
+ */
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ /**
+ * Randomly returns a french region.
+ *
+ * @example 'Guadeloupe'
+ *
+ * @return string
+ */
+ public static function region()
+ {
+ return static::randomElement(static::$regions);
+ }
+
+ /**
+ * Randomly returns a french department ('departmentNumber' => 'departmentName').
+ *
+ * @example array('2B' => 'Haute-Corse')
+ *
+ * @return array
+ */
+ public static function department()
+ {
+ return static::randomElement(static::$departments);
+ }
+
+ /**
+ * Randomly returns a french department name.
+ *
+ * @example 'Ardèche'
+ *
+ * @return string
+ */
+ public static function departmentName()
+ {
+ $randomDepartmentName = array_values(static::department());
+
+ return $randomDepartmentName[0];
+ }
+
+ /**
+ * Randomly returns a french department number.
+ *
+ * @example '59'
+ *
+ * @return string
+ */
+ public static function departmentNumber()
+ {
+ $randomDepartmentNumber = array_keys(static::department());
+
+ return $randomDepartmentNumber[0];
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/fr_FR/Company.php b/vendor/fakerphp/faker/src/Faker/Provider/fr_FR/Company.php
new file mode 100644
index 00000000..4edc7878
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/fr_FR/Company.php
@@ -0,0 +1,476 @@
+generator->parse($format));
+
+ if ($this->isCatchPhraseValid($catchPhrase)) {
+ break;
+ }
+ } while (true);
+
+ return $catchPhrase;
+ }
+
+ /**
+ * Generates a siret number (14 digits) that passes the Luhn check.
+ *
+ * @see http://fr.wikipedia.org/wiki/Syst%C3%A8me_d'identification_du_r%C3%A9pertoire_des_%C3%A9tablissements
+ * @return string
+ */
+ public function siret($formatted = true)
+ {
+ $siret = self::siren(false);
+ $nicFormat = static::randomElement(static::$siretNicFormats);
+ $siret .= $this->numerify($nicFormat);
+ $siret .= Luhn::computeCheckDigit($siret);
+ if ($formatted) {
+ $siret = substr($siret, 0, 3) . ' ' . substr($siret, 3, 3) . ' ' . substr($siret, 6, 3) . ' ' . substr($siret, 9, 5);
+ }
+
+ return $siret;
+ }
+
+ /**
+ * Generates a siren number (9 digits) that passes the Luhn check.
+ *
+ * @see http://fr.wikipedia.org/wiki/Syst%C3%A8me_d%27identification_du_r%C3%A9pertoire_des_entreprises
+ * @return string
+ */
+ public static function siren($formatted = true)
+ {
+ $siren = self::numerify('%#######');
+ $siren .= Luhn::computeCheckDigit($siren);
+ if ($formatted) {
+ $siren = substr($siren, 0, 3) . ' ' . substr($siren, 3, 3) . ' ' . substr($siren, 6, 3);
+ }
+
+ return $siren;
+ }
+
+ /**
+ * @var array An array containing string which should not appear twice in a catch phrase.
+ */
+ protected static $wordsWhichShouldNotAppearTwice = ['sécurité', 'simpl'];
+
+ /**
+ * Validates a french catch phrase.
+ *
+ * @param string $catchPhrase The catch phrase to validate.
+ *
+ * @return bool (true if valid, false otherwise)
+ */
+ protected static function isCatchPhraseValid($catchPhrase)
+ {
+ foreach (static::$wordsWhichShouldNotAppearTwice as $word) {
+ // Fastest way to check if a piece of word does not appear twice.
+ $beginPos = strpos($catchPhrase, $word);
+ $endPos = strrpos($catchPhrase, $word);
+
+ if ($beginPos !== false && $beginPos != $endPos) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * @link http://www.pole-emploi.fr/candidat/le-code-rome-et-les-fiches-metiers-@/article.jspz?id=60702
+ * @note Randomly took 300 from this list
+ */
+ protected static $jobTitleFormat = [
+ 'Agent d\'accueil',
+ 'Agent d\'enquêtes',
+ 'Agent d\'entreposage',
+ 'Agent de curage',
+ 'Agro-économiste',
+ 'Aide couvreur',
+ 'Aide à domicile',
+ 'Aide-déménageur',
+ 'Ambassadeur',
+ 'Analyste télématique',
+ 'Animateur d\'écomusée',
+ 'Animateur web',
+ 'Appareilleur-gazier',
+ 'Archéologue',
+ 'Armurier d\'art',
+ 'Armurier spectacle',
+ 'Artificier spectacle',
+ 'Artiste dramatique',
+ 'Aspigiculteur',
+ 'Assistant de justice',
+ 'Assistant des ventes',
+ 'Assistant logistique',
+ 'Assistant styliste',
+ 'Assurance',
+ 'Auteur-adaptateur',
+ 'Billettiste voyages',
+ 'Brigadier',
+ 'Bruiteur',
+ 'Bâtonnier d\'art',
+ 'Bûcheron',
+ 'Cameraman',
+ 'Capitaine de pêche',
+ 'Carrier',
+ 'Caviste',
+ 'Chansonnier',
+ 'Chanteur',
+ 'Chargé de recherche',
+ 'Chasseur-bagagiste',
+ 'Chef de fabrication',
+ 'Chef de scierie',
+ 'Chef des ventes',
+ 'Chef du personnel',
+ 'Chef géographe',
+ 'Chef monteur son',
+ 'Chef porion',
+ 'Chiropraticien',
+ 'Choréologue',
+ 'Chromiste',
+ 'Cintrier-machiniste',
+ 'Clerc hors rang',
+ 'Coach sportif',
+ 'Coffreur béton armé',
+ 'Coffreur-ferrailleur',
+ 'Commandant de police',
+ 'Commandant marine',
+ 'Commis de coupe',
+ 'Comptable unique',
+ 'Conception et études',
+ 'Conducteur de jumbo',
+ 'Conseiller culinaire',
+ 'Conseiller funéraire',
+ 'Conseiller relooking',
+ 'Consultant ergonome',
+ 'Contrebassiste',
+ 'Convoyeur garde',
+ 'Copiste offset',
+ 'Corniste',
+ 'Costumier-habilleur',
+ 'Coutelier d\'art',
+ 'Cueilleur de cerises',
+ 'Céramiste concepteur',
+ 'Danse',
+ 'Danseur',
+ 'Data manager',
+ 'Dee-jay',
+ 'Designer produit',
+ 'Diététicien conseil',
+ 'Diététique',
+ 'Doreur sur métaux',
+ 'Décorateur-costumier',
+ 'Défloqueur d\'amiante',
+ 'Dégustateur',
+ 'Délégué vétérinaire',
+ 'Délégué à la tutelle',
+ 'Désamianteur',
+ 'Détective',
+ 'Développeur web',
+ 'Ecotoxicologue',
+ 'Elagueur-botteur',
+ 'Elagueur-grimpeur',
+ 'Elastiqueur',
+ 'Eleveur d\'insectes',
+ 'Eleveur de chats',
+ 'Eleveur de volailles',
+ 'Embouteilleur',
+ 'Employé d\'accueil',
+ 'Employé d\'étage',
+ 'Employé de snack-bar',
+ 'Endivier',
+ 'Endocrinologue',
+ 'Epithésiste',
+ 'Essayeur-retoucheur',
+ 'Etainier',
+ 'Etancheur',
+ 'Etancheur-bardeur',
+ 'Etiqueteur',
+ 'Expert back-office',
+ 'Exploitant de tennis',
+ 'Extraction',
+ 'Facteur',
+ 'Facteur de clavecins',
+ 'Facteur de secteur',
+ 'Fantaisiste',
+ 'Façadier-bardeur',
+ 'Façadier-ravaleur',
+ 'Feutier',
+ 'Finance',
+ 'Flaconneur',
+ 'Foreur pétrole',
+ 'Formateur d\'italien',
+ 'Fossoyeur',
+ 'Fraiseur',
+ 'Fraiseur mouliste',
+ 'Frigoriste maritime',
+ 'Fromager',
+ 'Galeriste',
+ 'Gardien de résidence',
+ 'Garçon de chenil',
+ 'Garçon de hall',
+ 'Gendarme mobile',
+ 'Guitariste',
+ 'Gynécologue',
+ 'Géodésien',
+ 'Géologue prospecteur',
+ 'Géomètre',
+ 'Géomètre du cadastre',
+ 'Gérant d\'hôtel',
+ 'Gérant de tutelle',
+ 'Gériatre',
+ 'Hydrothérapie',
+ 'Hématologue',
+ 'Hôte de caisse',
+ 'Ingénieur bâtiment',
+ 'Ingénieur du son',
+ 'Ingénieur géologue',
+ 'Ingénieur géomètre',
+ 'Ingénieur halieute',
+ 'Ingénieur logistique',
+ 'Instituteur',
+ 'Jointeur de placage',
+ 'Juge des enfants',
+ 'Juriste financier',
+ 'Kiwiculteur',
+ 'Lexicographe',
+ 'Liftier',
+ 'Litigeur transport',
+ 'Logistique',
+ 'Logopède',
+ 'Magicien',
+ 'Manager d\'artiste',
+ 'Mannequin détail',
+ 'Maquilleur spectacle',
+ 'Marbrier-poseur',
+ 'Marin grande pêche',
+ 'Matelassier',
+ 'Maçon',
+ 'Maçon-fumiste',
+ 'Maçonnerie',
+ 'Maître de ballet',
+ 'Maïeuticien',
+ 'Menuisier',
+ 'Miroitier',
+ 'Modéliste industriel',
+ 'Moellonneur',
+ 'Moniteur de sport',
+ 'Monteur audiovisuel',
+ 'Monteur de fermettes',
+ 'Monteur de palettes',
+ 'Monteur en siège',
+ 'Monteur prototypiste',
+ 'Monteur-frigoriste',
+ 'Monteur-truquiste',
+ 'Mouleur sable',
+ 'Mouliste drapeur',
+ 'Mécanicien-armurier',
+ 'Médecin du sport',
+ 'Médecin scolaire',
+ 'Médiateur judiciaire',
+ 'Médiathécaire',
+ 'Net surfeur surfeuse',
+ 'Oenologue',
+ 'Opérateur de plateau',
+ 'Opérateur du son',
+ 'Opérateur géomètre',
+ 'Opérateur piquage',
+ 'Opérateur vidéo',
+ 'Ouvrier d\'abattoir',
+ 'Ouvrier serriste',
+ 'Ouvrier sidérurgiste',
+ 'Palefrenier',
+ 'Paléontologue',
+ 'Pareur en abattoir',
+ 'Parfumeur',
+ 'Parqueteur',
+ 'Percepteur',
+ 'Photographe d\'art',
+ 'Pilote automobile',
+ 'Pilote de soutireuse',
+ 'Pilote fluvial',
+ 'Piqueur en ganterie',
+ 'Pisteur secouriste',
+ 'Pizzaïolo',
+ 'Plaquiste enduiseur',
+ 'Plasticien',
+ 'Plisseur',
+ 'Poissonnier-traiteur',
+ 'Pontonnier',
+ 'Porion',
+ 'Porteur de hottes',
+ 'Porteur de journaux',
+ 'Portier',
+ 'Poseur de granit',
+ 'Posticheur spectacle',
+ 'Potier',
+ 'Praticien dentaire',
+ 'Praticiens médicaux',
+ 'Premier clerc',
+ 'Preneur de son',
+ 'Primeuriste',
+ 'Professeur d\'italien',
+ 'Projeteur béton armé',
+ 'Promotion des ventes',
+ 'Présentateur radio',
+ 'Pyrotechnicien',
+ 'Pédicure pour bovin',
+ 'Pédologue',
+ 'Pédopsychiatre',
+ 'Quincaillier',
+ 'Radio chargeur',
+ 'Ramasseur d\'asperges',
+ 'Ramasseur d\'endives',
+ 'Ravaleur-ragréeur',
+ 'Recherche',
+ 'Recuiseur',
+ 'Relieur-doreur',
+ 'Responsable de salle',
+ 'Responsable télécoms',
+ 'Revenue Manager',
+ 'Rippeur spectacle',
+ 'Rogneur',
+ 'Récupérateur',
+ 'Rédacteur des débats',
+ 'Régleur funéraire',
+ 'Régleur sur tour',
+ 'Sapeur-pompier',
+ 'Scannériste',
+ 'Scripte télévision',
+ 'Sculpteur sur verre',
+ 'Scénariste',
+ 'Second de cuisine',
+ 'Secrétaire juridique',
+ 'Semencier',
+ 'Sertisseur',
+ 'Services funéraires',
+ 'Solier-moquettiste',
+ 'Sommelier',
+ 'Sophrologue',
+ 'Staffeur',
+ 'Story boarder',
+ 'Stratifieur',
+ 'Stucateur',
+ 'Styliste graphiste',
+ 'Surjeteur-raseur',
+ 'Séismologue',
+ 'Technicien agricole',
+ 'Technicien bovin',
+ 'Technicien géomètre',
+ 'Technicien plateau',
+ 'Technicien énergie',
+ 'Terminologue',
+ 'Testeur informatique',
+ 'Toiliste',
+ 'Topographe',
+ 'Toréro',
+ 'Traducteur d\'édition',
+ 'Traffic manager',
+ 'Trieur de métaux',
+ 'Turbinier',
+ 'Téléconseiller',
+ 'Tôlier-traceur',
+ 'Vendeur carreau',
+ 'Vendeur en lingerie',
+ 'Vendeur en meubles',
+ 'Vendeur en épicerie',
+ 'Verrier d\'art',
+ 'Verrier à la calotte',
+ 'Verrier à la main',
+ 'Verrier à main levée',
+ 'Vidéo-jockey',
+ 'Vitrier',
+ ];
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/fr_FR/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/fr_FR/Internet.php
new file mode 100644
index 00000000..adf26ce8
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/fr_FR/Internet.php
@@ -0,0 +1,9 @@
+numberBetween(1, 2);
+ }
+
+ $nir .=
+ // Year of birth (aa)
+ $this->numerify('##') .
+ // Mont of birth (mm)
+ sprintf('%02d', $this->numberBetween(1, 12));
+
+ // Department
+ $department = key(Address::department());
+ $nir .= $department;
+
+ // Town number, depends on department length
+ if (strlen($department) === 2) {
+ $nir .= $this->numerify('###');
+ } elseif (strlen($department) === 3) {
+ $nir .= $this->numerify('##');
+ }
+
+ // Born number (depending of town and month of birth)
+ $nir .= $this->numerify('###');
+
+ /**
+ * The key for a given NIR is `97 - 97 % NIR`
+ * NIR has to be an integer, so we have to do a little replacment
+ * for departments 2A and 2B
+ */
+ if ($department === '2A') {
+ $nirInteger = str_replace('2A', '19', $nir);
+ } elseif ($department === '2B') {
+ $nirInteger = str_replace('2B', '18', $nir);
+ } else {
+ $nirInteger = $nir;
+ }
+ $nir .= sprintf('%02d', 97 - $nirInteger % 97);
+
+ // Format is x xx xx xx xxx xxx xx
+ if ($formatted) {
+ $nir = substr($nir, 0, 1) . ' ' . substr($nir, 1, 2) . ' ' . substr($nir, 3, 2) . ' ' . substr($nir, 5, 2) . ' ' . substr($nir, 7, 3) . ' ' . substr($nir, 10, 3) . ' ' . substr($nir, 13, 2);
+ }
+
+ return $nir;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/fr_FR/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/fr_FR/PhoneNumber.php
new file mode 100644
index 00000000..62af6884
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/fr_FR/PhoneNumber.php
@@ -0,0 +1,141 @@
+phoneNumber07WithSeparator();
+ $phoneNumber = str_replace(' ', '', $phoneNumber);
+ return $phoneNumber;
+ }
+
+ /**
+ * Only 073 to 079 are acceptable prefixes with 07
+ *
+ * @see http://www.arcep.fr/index.php?id=8146
+ */
+ public function phoneNumber07WithSeparator()
+ {
+ $phoneNumber = $this->generator->numberBetween(3, 9);
+ $phoneNumber .= $this->numerify('# ## ## ##');
+ return $phoneNumber;
+ }
+
+ public function phoneNumber08()
+ {
+ $phoneNumber = $this->phoneNumber08WithSeparator();
+ $phoneNumber = str_replace(' ', '', $phoneNumber);
+ return $phoneNumber;
+ }
+
+ /**
+ * Valid formats for 08:
+ *
+ * 0# ## ## ##
+ * 1# ## ## ##
+ * 2# ## ## ##
+ * 91 ## ## ##
+ * 92 ## ## ##
+ * 93 ## ## ##
+ * 97 ## ## ##
+ * 98 ## ## ##
+ * 99 ## ## ##
+ *
+ * Formats 089(4|6)## ## ## are valid, but will be
+ * attributed when other 089 resource ranges are exhausted.
+ *
+ * @see https://www.arcep.fr/index.php?id=8146#c9625
+ * @see https://issuetracker.google.com/u/1/issues/73269839
+ */
+ public function phoneNumber08WithSeparator()
+ {
+ $regex = '([012]{1}\d{1}|(9[1-357-9])( \d{2}){3}';
+ return $this->regexify($regex);
+ }
+
+ /**
+ * @example '0601020304'
+ */
+ public function mobileNumber()
+ {
+ $format = static::randomElement(static::$mobileFormats);
+
+ return static::numerify($this->generator->parse($format));
+ }
+ /**
+ * @example '0891951357'
+ */
+ public function serviceNumber()
+ {
+ $format = static::randomElement(static::$serviceFormats);
+
+ return static::numerify($this->generator->parse($format));
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/fr_FR/Text.php b/vendor/fakerphp/faker/src/Faker/Provider/fr_FR/Text.php
new file mode 100644
index 00000000..9403f168
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/fr_FR/Text.php
@@ -0,0 +1,15531 @@
+ static::latitude(46.262740, 47.564721),
+ 'longitude' => static::longitude(17.077949, 20.604560)
+ ];
+ }
+
+ /* ----------- DATA -------------------- */
+
+ protected static $streetSuffix = [
+ 'árok', 'átjáró', 'dűlősor', 'dűlőút', 'erdősor', 'fasor', 'forduló', 'gát', 'határsor', 'határút', 'híd', 'játszótér', 'kert', 'körönd', 'körtér', 'körút', 'köz', 'lakótelep', 'lejáró', 'lejtő', 'lépcső', 'liget', 'mélyút', 'orom', 'országút', 'ösvény', 'park', 'part', 'pincesor', 'rakpart', 'sétány', 'sétaút', 'sor', 'sugárút', 'tér', 'tere', 'turistaút', 'udvar', 'út', 'útja', 'utca', 'üdülőpart'
+ ];
+ protected static $postcode = ['####'];
+ protected static $state = [
+ 'Budapest', 'Bács-Kiskun', 'Baranya', 'Békés', 'Borsod-Abaúj-Zemplén', 'Csongrád', 'Fejér', 'Győr-Moson-Sopron', 'Hajdú-Bihar', 'Heves', 'Jász-Nagykun-Szolnok', 'Komárom-Esztergom', 'Nógrád', 'Pest', 'Somogy', 'Szabolcs-Szatmár-Bereg', 'Tolna', 'Vas', 'Veszprém', 'Zala'
+ ];
+ protected static $country = [
+ 'Afganisztán', 'Albánia', 'Algéria', 'Amerikai Egyesült Államok', 'Andorra', 'Angola', 'Antigua és Barbuda', 'Argentína', 'Ausztria', 'Ausztrália', 'Azerbajdzsán',
+ 'Bahama-szigetek', 'Bahrein', 'Banglades', 'Barbados', 'Belgium', 'Belize', 'Benin', 'Bhután', 'Bolívia', 'Bosznia-Hercegovina', 'Botswana', 'Brazília', 'Brunei', 'Bulgária', 'Burkina Faso', 'Burma', 'Burundi',
+ 'Chile', 'Ciprus', 'Costa Rica', 'Csehország', 'Csád',
+ 'Dominikai Köztársaság', 'Dominikai Közösség', 'Dzsibuti', 'Dánia', 'Dél-Afrika', 'Dél-Korea', 'Dél-Szudán',
+ 'Ecuador', 'Egyenlítői-Guinea', 'Egyesült Arab Emírségek', 'Egyesült Királyság', 'Egyiptom', 'Elefántcsontpart', 'Eritrea', 'Etiópia',
+ 'Fehéroroszország', 'Fidzsi-szigetek', 'Finnország', 'Franciaország', 'Fülöp-szigetek',
+ 'Gabon', 'Gambia', 'Ghána', 'Grenada', 'Grúzia', 'Guatemala', 'Guinea', 'Guyana', 'Görögország',
+ 'Haiti', 'Hollandia', 'Horvátország',
+ 'India', 'Indonézia', 'Irak', 'Irán', 'Izland', 'Izrael',
+ 'Japán', 'Jemen', 'Jordánia',
+ 'Kambodzsa', 'Kamerun', 'Kanada', 'Katar', 'Kazahsztán', 'Kelet-Timor', 'Kenya', 'Kirgizisztán', 'Kiribati', 'Kolumbia', 'Kongói Demokratikus Köztársaság', 'Kongói Köztársaság', 'Kuba', 'Kuvait', 'Kína', 'Közép-Afrika',
+ 'Laosz', 'Lengyelország', 'Lesotho', 'Lettország', 'Libanon', 'Libéria', 'Liechtenstein', 'Litvánia', 'Luxemburg', 'Líbia',
+ 'Macedónia', 'Madagaszkár', 'Magyarország', 'Malawi', 'Maldív-szigetek', 'Mali', 'Malájzia', 'Marokkó', 'Marshall-szigetek', 'Mauritánia', 'Mexikó', 'Mikronézia', 'Moldova', 'Monaco', 'Mongólia', 'Montenegró', 'Mozambik', 'Málta',
+ 'Namíbia', 'Nauru', 'Nepál', 'Nicaragua', 'Niger', 'Nigéria', 'Norvégia', 'Németország',
+ 'Olaszország', 'Omán', 'Oroszország',
+ 'Pakisztán', 'Palau', 'Panama', 'Paraguay', 'Peru', 'Portugália', 'Pápua Új-Guinea',
+ 'Románia', 'Ruanda',
+ 'Saint Kitts és Nevis', 'Saint Vincent', 'Salamon-szigetek', 'Salvador', 'San Marino', 'Seychelle-szigetek', 'Spanyolország', 'Srí Lanka', 'Suriname', 'Svájc', 'Svédország', 'Szamoa', 'Szaúd-Arábia', 'Szenegál', 'Szerbia', 'Szingapúr', 'Szlovákia', 'Szlovénia', 'Szomália', 'Szudán', 'Szváziföld', 'Szíria', 'São Tomé és Príncipe',
+ 'Tadzsikisztán', 'Tanzánia', 'Thaiföld', 'Togo', 'Tonga', 'Trinidad és Tobago', 'Tunézia', 'Tuvalu', 'Törökország', 'Türkmenisztán',
+ 'Uganda', 'Ukrajna', 'Uruguay',
+ 'Vanuatu', 'Venezuela', 'Vietnám',
+ 'Zambia', 'Zimbabwe', 'Zöld-foki-szigetek',
+ 'Észak-Korea', 'Észtország', 'Írország', 'Örményország', 'Új-Zéland', 'Üzbegisztán'
+ ];
+
+ /**
+ * Source: https://hu.wikipedia.org/wiki/Magyarorsz%C3%A1g_v%C3%A1rosainak_list%C3%A1ja
+ */
+ protected static $capitals = ['Budapest'];
+ protected static $bigCities = [
+ 'Békéscsaba', 'Debrecen', 'Dunaújváros', 'Eger', 'Érd', 'Győr', 'Hódmezővásárhely', 'Kaposvár', 'Kecskemét', 'Miskolc', 'Nagykanizsa', 'Nyíregyháza', 'Pécs', 'Salgótarján', 'Sopron', 'Szeged', 'Székesfehérvár', 'Szekszárd', 'Szolnok', 'Szombathely', 'Tatabánya', 'Veszprém', 'Zalaegerszeg'
+ ];
+ protected static $smallerCities = [
+ 'Ajka', 'Aszód', 'Bácsalmás',
+ 'Baja', 'Baktalórántháza', 'Balassagyarmat', 'Balatonalmádi', 'Balatonfüred', 'Balmazújváros', 'Barcs', 'Bátonyterenye', 'Békés', 'Bélapátfalva', 'Berettyóújfalu', 'Bicske', 'Bóly', 'Bonyhád', 'Budakeszi',
+ 'Cegléd', 'Celldömölk', 'Cigánd', 'Csenger', 'Csongrád', 'Csorna', 'Csurgó',
+ 'Dabas', 'Derecske', 'Devecser', 'Dombóvár', 'Dunakeszi',
+ 'Edelény', 'Encs', 'Enying', 'Esztergom',
+ 'Fehérgyarmat', 'Fonyód', 'Füzesabony',
+ 'Gárdony', 'Gödöllő', 'Gönc', 'Gyál', 'Gyomaendrőd', 'Gyöngyös', 'Gyula',
+ 'Hajdúböszörmény', 'Hajdúhadház', 'Hajdúnánás', 'Hajdúszoboszló', 'Hatvan', 'Heves',
+ 'Ibrány',
+ 'Jánoshalma', 'Jászapáti', 'Jászberény',
+ 'Kalocsa', 'Kapuvár', 'Karcag', 'Kazincbarcika', 'Kemecse', 'Keszthely', 'Kisbér', 'Kiskőrös', 'Kiskunfélegyháza', 'Kiskunhalas', 'Kiskunmajsa', 'Kistelek', 'Kisvárda', 'Komárom', 'Komló', 'Körmend', 'Kőszeg', 'Kunhegyes', 'Kunszentmárton', 'Kunszentmiklós',
+ 'Lenti', 'Letenye',
+ 'Makó', 'Marcali', 'Martonvásár', 'Mátészalka', 'Mezőcsát', 'Mezőkovácsháza', 'Mezőkövesd', 'Mezőtúr', 'Mohács', 'Monor', 'Mór', 'Mórahalom', 'Mosonmagyaróvár',
+ 'Nagyatád', 'Nagykálló', 'Nagykáta', 'Nagykőrös', 'Nyíradony', 'Nyírbátor',
+ 'Orosháza', 'Oroszlány', 'Ózd',
+ 'Paks', 'Pannonhalma', 'Pápa', 'Pásztó', 'Pécsvárad', 'Pétervására', 'Pilisvörösvár', 'Polgárdi', 'Püspökladány', 'Putnok',
+ 'Ráckeve', 'Rétság',
+ 'Sárbogárd', 'Sarkad', 'Sárospatak', 'Sárvár', 'Sásd', 'Sátoraljaújhely', 'Sellye', 'Siklós', 'Siófok', 'Sümeg', 'Szarvas', 'Szécsény', 'Szeghalom', 'Szentendre', 'Szentes', 'Szentgotthárd', 'Szentlőrinc', 'Szerencs', 'Szigetszentmiklós', 'Szigetvár', 'Szikszó', 'Szob',
+ 'Tab', 'Tamási', 'Tapolca', 'Tata', 'Tét', 'Tiszafüred', 'Tiszakécske', 'Tiszaújváros', 'Tiszavasvári', 'Tokaj', 'Tolna', 'Törökszentmiklós',
+ 'Vác', 'Várpalota', 'Vásárosnamény', 'Vasvár', 'Vecsés',
+ 'Záhony', 'Zalaszentgrót', 'Zirc'
+ ];
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/hu_HU/Company.php b/vendor/fakerphp/faker/src/Faker/Provider/hu_HU/Company.php
new file mode 100644
index 00000000..ccda8aac
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/hu_HU/Company.php
@@ -0,0 +1,13 @@
+generator->parse($format);
+ }
+
+ public static function country()
+ {
+ return static::randomElement(static::$country);
+ }
+
+ public static function postcode()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$postcode)));
+ }
+
+ public static function regionSuffix()
+ {
+ return static::randomElement(static::$regionSuffix);
+ }
+
+ public static function region()
+ {
+ return static::randomElement(static::$region);
+ }
+
+ public static function cityPrefix()
+ {
+ return static::randomElement(static::$cityPrefix);
+ }
+
+ public function city()
+ {
+ return static::randomElement(static::$city);
+ }
+
+ public function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ public static function street()
+ {
+ return static::randomElement(static::$street);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/hy_AM/Color.php b/vendor/fakerphp/faker/src/Faker/Provider/hy_AM/Color.php
new file mode 100644
index 00000000..ebdda0da
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/hy_AM/Color.php
@@ -0,0 +1,12 @@
+generator->parse(static::randomElement(static::$formats)));
+ }
+
+ public function code()
+ {
+ return static::randomElement(static::$codes);
+ }
+
+ /**
+ * @return mixed
+ */
+ public function numberFormat()
+ {
+ return static::randomElement(static::$numberFormats);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/id_ID/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/id_ID/Address.php
new file mode 100644
index 00000000..11f7f379
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/id_ID/Address.php
@@ -0,0 +1,317 @@
+generator->parse($format);
+ }
+
+ public static function street()
+ {
+ return static::randomElement(static::$street);
+ }
+
+ public static function buildingNumber()
+ {
+ return self::numberBetween(1, 999);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/id_ID/Color.php b/vendor/fakerphp/faker/src/Faker/Provider/id_ID/Color.php
new file mode 100644
index 00000000..3bb2193d
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/id_ID/Color.php
@@ -0,0 +1,41 @@
+generator->parse($lastNameRandomElement);
+ }
+
+ /**
+ * Return last name for male
+ *
+ * @access public
+ * @return string last name
+ */
+ public static function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ /**
+ * Return last name for female
+ *
+ * @access public
+ * @return string last name
+ */
+ public static function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+
+ /**
+ * For academic title
+ *
+ * @access public
+ * @return string suffix
+ */
+ public static function suffix()
+ {
+ return static::randomElement(static::$suffix);
+ }
+
+ /**
+ * Generates Nomor Induk Kependudukan (NIK)
+ *
+ * @link https://en.wikipedia.org/wiki/National_identification_number#Indonesia
+ *
+ * @param null|string $gender
+ * @param null|\DateTime $birthDate
+ * @return string
+ */
+ public function nik($gender = null, $birthDate = null)
+ {
+ # generate first numbers (region data)
+ $nik = $this->birthPlaceCode();
+ $nik .= $this->generator->numerify('##');
+
+ if (!$birthDate) {
+ $birthDate = $this->generator->dateTimeBetween();
+ }
+
+ if (!$gender) {
+ $gender = $this->generator->randomElement([self::GENDER_MALE, self::GENDER_FEMALE]);
+ }
+
+ # if gender is female, add 40 to days
+ if ($gender == self::GENDER_FEMALE) {
+ $nik .= $birthDate->format('d') + 40;
+ } else {
+ $nik .= $birthDate->format('d');
+ }
+
+ $nik .= $birthDate->format('my');
+
+ # add last random digits
+ $nik .= $this->generator->numerify('####');
+
+ return $nik;
+ }
+
+ /**
+ * Generates birth place code for NIK
+ *
+ * @link https://id.wikipedia.org/wiki/Nomor_Induk_Kependudukan
+ * @link http://informasipedia.com/wilayah-indonesia/daftar-kabupaten-kota-di-indonesia/
+ */
+ protected function birthPlaceCode()
+ {
+ return static::randomElement(static::$birthPlaceCode);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/id_ID/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/id_ID/PhoneNumber.php
new file mode 100644
index 00000000..c0bfaf5b
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/id_ID/PhoneNumber.php
@@ -0,0 +1,55 @@
+
+ */
+class Address extends \Faker\Provider\Address
+{
+ /**
+ * @var array Countries in icelandic
+ */
+ protected static $country = [
+ 'Afganistan', 'Albanía', 'Alsír', 'Andorra', 'Angóla', 'Angvilla', 'Antígva og Barbúda', 'Argentína',
+ 'Armenía', 'Arúba', 'Aserbaídsjan', 'Austur-Kongó', 'Austurríki', 'Austur-Tímor', 'Álandseyjar',
+ 'Ástralía', 'Bahamaeyjar', 'Bandaríkin', 'Bandaríska Samóa', 'Bangladess', 'Barbados', 'Barein',
+ 'Belgía', 'Belís', 'Benín', 'Bermúdaeyjar', 'Bosnía og Hersegóvína', 'Botsvana', 'Bouvet-eyja', 'Bólivía',
+ 'Brasilía', 'Bresku Indlandshafseyjar', 'Bretland', 'Brúnei', 'Búlgaría', 'Búrkína Fasó', 'Búrúndí', 'Bútan',
+ 'Cayman-eyjar', 'Chile', 'Cooks-eyjar', 'Danmörk', 'Djíbútí', 'Dóminíka', 'Dóminíska lýðveldið', 'Egyptaland',
+ 'Eistland', 'Ekvador', 'El Salvador', 'England', 'Erítrea', 'Eþíópía', 'Falklandseyjar', 'Filippseyjar',
+ 'Finnland', 'Fídjieyjar', 'Fílabeinsströndin', 'Frakkland', 'Franska Gvæjana', 'Franska Pólýnesía',
+ 'Frönsku suðlægu landsvæðin', 'Færeyjar', 'Gabon', 'Gambía', 'Gana', 'Georgía', 'Gíbraltar', 'Gínea',
+ 'Gínea-Bissá', 'Grenada', 'Grikkland', 'Grænhöfðaeyjar', 'Grænland', 'Gvadelúpeyjar', 'Gvam', 'Gvatemala',
+ 'Gvæjana', 'Haítí', 'Heard og McDonalds-eyjar', 'Holland', 'Hollensku Antillur', 'Hondúras', 'Hong Kong',
+ 'Hvíta-Rússland', 'Indland', 'Indónesía', 'Írak', 'Íran', 'Írland', 'Ísland', 'Ísrael', 'Ítalía', 'Jamaíka',
+ 'Japan', 'Jemen', 'Jólaey', 'Jómfrúaeyjar', 'Jórdanía', 'Kambódía', 'Kamerún', 'Kanada', 'Kasakstan', 'Katar',
+ 'Kenía', 'Kirgisistan', 'Kína', 'Kíribatí', 'Kongó', 'Austur-Kongó', 'Vestur-Kongó', 'Kostaríka', 'Kókoseyjar',
+ 'Kólumbía', 'Kómoreyjar', 'Kórea', 'Norður-Kórea;', 'Suður-Kórea', 'Króatía', 'Kúba', 'Kúveit', 'Kýpur',
+ 'Laos', 'Lesótó', 'Lettland', 'Liechtenstein', 'Litháen', 'Líbanon', 'Líbería', 'Líbía', 'Lúxemborg',
+ 'Madagaskar', 'Makaó', 'Makedónía', 'Malasía', 'Malaví', 'Maldíveyjar', 'Malí', 'Malta', 'Marokkó',
+ 'Marshall-eyjar', 'Martiník', 'Mayotte', 'Máritanía', 'Máritíus', 'Mexíkó', 'Mið-Afríkulýðveldið',
+ 'Miðbaugs-Gínea', 'Míkrónesía', 'Mjanmar', 'Moldóva', 'Mongólía', 'Montserrat', 'Mónakó', 'Mósambík',
+ 'Namibía', 'Nárú', 'Nepal', 'Niue', 'Níger', 'Nígería', 'Níkaragva', 'Norður-Írland', 'Norður-Kórea',
+ 'Norður-Maríanaeyjar', 'Noregur', 'Norfolkeyja', 'Nýja-Kaledónía', 'Nýja-Sjáland', 'Óman', 'Pakistan',
+ 'Palá', 'Palestína', 'Panama', 'Papúa Nýja-Gínea', 'Paragvæ', 'Páfagarður', 'Perú', 'Pitcairn', 'Portúgal',
+ 'Pólland', 'Púertó Ríkó', 'Réunion', 'Rúanda', 'Rúmenía', 'Rússland', 'Salómonseyjar', 'Sambía',
+ 'Sameinuðu arabísku furstadæmin', 'Samóa', 'San Marínó', 'Sankti Helena', 'Sankti Kristófer og Nevis',
+ 'Sankti Lúsía', 'Sankti Pierre og Miquelon', 'Sankti Vinsent og Grenadíneyjar', 'Saó Tóme og Prinsípe',
+ 'Sádi-Arabía', 'Senegal', 'Serbía', 'Seychelles-eyjar', 'Simbabve', 'Singapúr', 'Síerra Leóne', 'Skotland',
+ 'Slóvakía', 'Slóvenía', 'Smáeyjar Bandaríkjanna', 'Sómalía', 'Spánn', 'Srí Lanka', 'Suður-Afríka',
+ 'Suður-Georgía og Suður-Sandvíkureyjar', 'Suður-Kórea', 'Suðurskautslandið', 'Súdan', 'Súrínam', 'Jan Mayen',
+ 'Svartfjallaland', 'Svasíland', 'Sviss', 'Svíþjóð', 'Sýrland', 'Tadsjikistan', 'Taíland', 'Taívan', 'Tansanía',
+ 'Tékkland', 'Tonga', 'Tógó', 'Tókelá', 'Trínidad og Tóbagó', 'Tsjad', 'Tsjetsjenía', 'Turks- og Caicos-eyjar',
+ 'Túnis', 'Túrkmenistan', 'Túvalú', 'Tyrkland', 'Ungverjaland', 'Úganda', 'Úkraína', 'Úrúgvæ', 'Úsbekistan',
+ 'Vanúatú', 'Venesúela', 'Vestur-Kongó', 'Vestur-Sahara', 'Víetnam', 'Wales', 'Wallis- og Fútúnaeyjar', 'Þýskaland'
+ ];
+
+ /**
+ * @var array Icelandic cities.
+ */
+ protected static $cityNames = [
+ 'Reykjavík', 'Seltjarnarnes', 'Vogar', 'Kópavogur', 'Garðabær', 'Hafnarfjörður', 'Reykjanesbær', 'Grindavík',
+ 'Sandgerði', 'Garður', 'Reykjanesbær', 'Mosfellsbær', 'Akranes', 'Borgarnes', 'Reykholt', 'Stykkishólmur',
+ 'Flatey', 'Grundarfjörður', 'Ólafsvík', 'Snæfellsbær', 'Hellissandur', 'Búðardalur', 'Reykhólahreppur',
+ 'Ísafjörður', 'Hnífsdalur', 'Bolungarvík', 'Súðavík', 'Flateyri', 'Suðureyri', 'Patreksfjörður',
+ 'Tálknafjörður', 'Bíldudalur', 'Þingeyri', 'Staður', 'Hólmavík', 'Drangsnes', 'Árneshreppur', 'Hvammstangi',
+ 'Blönduós', 'Skagaströnd', 'Sauðárkrókur', 'Varmahlíð', 'Hofsós', 'Fljót', 'Siglufjörður', 'Akureyri',
+ 'Grenivík', 'Grímsey', 'Dalvík', 'Ólafsfjörður', 'Hrísey', 'Húsavík', 'Fosshóll', 'Laugar', 'Mývatn',
+ 'Kópasker', 'Raufarhöfn', 'Þórshöfn', 'Bakkafjörður', 'Vopnafjörður', 'Egilsstaðir', 'Seyðisfjörður',
+ 'Mjóifjörður', 'Borgarfjörður', 'Reyðarfjörður', 'Eskifjörður', 'Neskaupstaður', 'Fáskrúðsfjörður',
+ 'Stöðvarfjörður', 'Breiðdalsvík', 'Djúpivogur', 'Höfn', 'Selfoss', 'Hveragerði', 'Þorlákshöfn', 'Ölfus',
+ 'Eyrarbakki', 'Stokkseyri', 'Laugarvatn', 'Flúðir', 'Hella', 'Hvolsvöllur', 'Vík', 'Kirkjubæjarklaustur',
+ 'Vestmannaeyjar'
+ ];
+
+ /**
+ * @var array Street name suffix.
+ */
+ protected static $streetSuffix = [
+ 'ás', 'bakki', 'braut', 'bær', 'brún', 'berg', 'fold', 'gata', 'gróf',
+ 'garðar', 'höfði', 'heimar', 'hamar', 'hólar', 'háls', 'kvísl', 'lækur',
+ 'leiti', 'land', 'múli', 'nes', 'rimi', 'stígur', 'stræti', 'stekkur',
+ 'slóð', 'skógar', 'sel', 'teigur', 'tún', 'vangur', 'vegur', 'vogur',
+ 'vað'
+ ];
+
+ /**
+ * @var array Street name prefix.
+ */
+ protected static $streetPrefix = [
+ 'Aðal', 'Austur', 'Bakka', 'Braga', 'Báru', 'Brunn', 'Fiski', 'Leifs',
+ 'Týs', 'Birki', 'Suður', 'Norður', 'Vestur', 'Austur', 'Sanda', 'Skógar',
+ 'Stór', 'Sunnu', 'Tungu', 'Tangar', 'Úlfarfells', 'Vagn', 'Vind', 'Ysti',
+ 'Þing', 'Hamra', 'Hóla', 'Kríu', 'Iðu', 'Spóa', 'Starra', 'Uglu', 'Vals'
+ ];
+
+ /**
+ * @var Icelandic zip code.
+ **/
+ protected static $postcode = [
+ '%##'
+ ];
+
+ /**
+ * @var array Icelandic regions.
+ */
+ protected static $regionNames = [
+ 'Höfuðborgarsvæðið', 'Norðurland', 'Suðurland', 'Vesturland', 'Vestfirðir', 'Austurland', 'Suðurnes'
+ ];
+
+ /**
+ * @var array Icelandic building numbers.
+ */
+ protected static $buildingNumber = [
+ '%##', '%#', '%#', '%', '%', '%', '%?', '% ?',
+ ];
+
+ /**
+ * @var array Icelandic city format.
+ */
+ protected static $cityFormats = [
+ '{{cityName}}',
+ ];
+
+ /**
+ * @var array Icelandic street's name formats.
+ */
+ protected static $streetNameFormats = [
+ '{{streetPrefix}}{{streetSuffix}}',
+ '{{streetPrefix}}{{streetSuffix}}',
+ '{{firstNameMale}}{{streetSuffix}}',
+ '{{firstNameFemale}}{{streetSuffix}}'
+ ];
+
+ /**
+ * @var array Icelandic street's address formats.
+ */
+ protected static $streetAddressFormats = [
+ '{{streetName}} {{buildingNumber}}'
+ ];
+
+ /**
+ * @var array Icelandic address format.
+ */
+ protected static $addressFormats = [
+ "{{streetAddress}}\n{{postcode}} {{city}}",
+ ];
+
+ /**
+ * Randomly return a real city name.
+ *
+ * @return string
+ */
+ public static function cityName()
+ {
+ return static::randomElement(static::$cityNames);
+ }
+
+ /**
+ * Randomly return a street prefix.
+ *
+ * @return string
+ */
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ /**
+ * Randomly return a building number.
+ *
+ * @return string
+ */
+ public static function buildingNumber()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$buildingNumber)));
+ }
+
+ /**
+ * Randomly return a real region name.
+ *
+ * @return string
+ */
+ public static function region()
+ {
+ return static::randomElement(static::$regionNames);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/is_IS/Company.php b/vendor/fakerphp/faker/src/Faker/Provider/is_IS/Company.php
new file mode 100644
index 00000000..073ae99e
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/is_IS/Company.php
@@ -0,0 +1,53 @@
+
+ */
+class Company extends \Faker\Provider\Company
+{
+ /**
+ * @var array Danish company name formats.
+ */
+ protected static $formats = [
+ '{{lastName}} {{companySuffix}}',
+ '{{lastName}} {{companySuffix}}',
+ '{{lastName}} {{companySuffix}}',
+ '{{firstname}} {{lastName}} {{companySuffix}}',
+ '{{middleName}} {{companySuffix}}',
+ '{{middleName}} {{companySuffix}}',
+ '{{middleName}} {{companySuffix}}',
+ '{{firstname}} {{middleName}} {{companySuffix}}',
+ '{{lastName}} & {{lastName}} {{companySuffix}}',
+ '{{lastName}} og {{lastName}} {{companySuffix}}',
+ '{{lastName}} & {{lastName}} {{companySuffix}}',
+ '{{lastName}} og {{lastName}} {{companySuffix}}',
+ '{{middleName}} & {{middleName}} {{companySuffix}}',
+ '{{middleName}} og {{middleName}} {{companySuffix}}',
+ '{{middleName}} & {{lastName}}',
+ '{{middleName}} og {{lastName}}',
+ ];
+
+ /**
+ * @var array Company suffixes.
+ */
+ protected static $companySuffix = ['ehf.', 'hf.', 'sf.'];
+
+ /**
+ * @link http://www.rsk.is/atvinnurekstur/virdisaukaskattur/
+ *
+ * @var string VSK number format.
+ */
+ protected static $vskFormat = '%####';
+
+ /**
+ * Generates a VSK number (5 digits).
+ *
+ * @return string
+ */
+ public static function vsk()
+ {
+ return static::numerify(static::$vskFormat);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/is_IS/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/is_IS/Internet.php
new file mode 100644
index 00000000..96c215b7
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/is_IS/Internet.php
@@ -0,0 +1,23 @@
+
+ */
+class Internet extends \Faker\Provider\Internet
+{
+ /**
+ * @var array Some email domains in Denmark.
+ */
+ protected static $freeEmailDomain = [
+ 'gmail.com', 'yahoo.com', 'hotmail.com', 'visir.is', 'simnet.is', 'internet.is'
+ ];
+
+ /**
+ * @var array Some TLD.
+ */
+ protected static $tld = [
+ 'com', 'com', 'com', 'net', 'is', 'is', 'is',
+ ];
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/is_IS/Payment.php b/vendor/fakerphp/faker/src/Faker/Provider/is_IS/Payment.php
new file mode 100644
index 00000000..2f70033b
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/is_IS/Payment.php
@@ -0,0 +1,19 @@
+
+ */
+class Person extends \Faker\Provider\Person
+{
+ /**
+ * @var array Icelandic person name formats.
+ */
+ protected static $maleNameFormats = [
+ '{{firstNameMale}} {{lastNameMale}}',
+ '{{firstNameMale}} {{lastNameMale}}',
+ '{{firstNameMale}} {{middleName}} {{lastNameMale}}',
+ '{{firstNameMale}} {{middleName}} {{lastNameMale}}',
+ ];
+
+ protected static $femaleNameFormats = [
+ '{{firstNameFemale}} {{lastNameFemale}}',
+ '{{firstNameFemale}} {{lastNameFemale}}',
+ '{{firstNameFemale}} {{middleName}} {{lastNameFemale}}',
+ '{{firstNameFemale}} {{middleName}} {{lastNameFemale}}',
+ ];
+
+ /**
+ * @var string Icelandic women names.
+ */
+ protected static $firstNameFemale = ['Aagot', 'Abela', 'Abigael', 'Ada', 'Adda', 'Addý', 'Adela', 'Adelía', 'Adríana', 'Aðalbjörg', 'Aðalbjört', 'Aðalborg', 'Aðaldís', 'Aðalfríður', 'Aðalheiður', 'Aðalrós', 'Aðalsteina', 'Aðalsteinunn', 'Aðalveig', 'Agata', 'Agatha', 'Agða', 'Agla', 'Agnea', 'Agnes', 'Agneta', 'Alanta', 'Alba', 'Alberta', 'Albína', 'Alda', 'Aldís', 'Aldný', 'Aleta', 'Aletta', 'Alexa', 'Alexandra', 'Alexandría', 'Alexis', 'Alexía', 'Alfa', 'Alfífa', 'Alice', 'Alida', 'Alída', 'Alína', 'Alís', 'Alísa', 'Alla', 'Allý', 'Alma', 'Alrún', 'Alva', 'Alvilda', 'Amadea', 'Amal', 'Amalía', 'Amanda', 'Amelía', 'Amilía', 'Amíra', 'Amy', 'Amý', 'Analía', 'Anastasía', 'Andra', 'Andrá', 'Andrea', 'Anetta', 'Angela', 'Angelíka', 'Anika', 'Anita', 'Aníka', 'Anína', 'Aníta', 'Anja', 'Ann', 'Anna', 'Annabella', 'Annalísa', 'Anne', 'Annelí', 'Annetta', 'Anney', 'Annika', 'Annía', 'Anný', 'Antonía', 'Apríl', 'Ardís', 'Arey', 'Arinbjörg', 'Aris', 'Arisa', 'Aría', 'Aríanna', 'Aríella', 'Arín', 'Arína', 'Arís', 'Armenía', 'Arna', 'Arnbjörg', 'Arnborg', 'Arndís', 'Arney', 'Arnfinna', 'Arnfríður', 'Arngerður', 'Arngunnur', 'Arnheiður', 'Arnhildur', 'Arnika', 'Arnkatla', 'Arnlaug', 'Arnleif', 'Arnlín', 'Arnljót', 'Arnóra', 'Arnrós', 'Arnrún', 'Arnþóra', 'Arnþrúður', 'Asírí', 'Askja', 'Assa', 'Astrid', 'Atalía', 'Atena', 'Athena', 'Atla', 'Atlanta', 'Auðbjörg', 'Auðbjört', 'Auðdís', 'Auðlín', 'Auðna', 'Auðný', 'Auðrún', 'Auður', 'Aurora', 'Axelía', 'Axelma', 'Aþena', 'Ágústa', 'Ágústína', 'Álfdís', 'Álfey', 'Álfgerður', 'Álfheiður', 'Álfhildur', 'Álfrós', 'Álfrún', 'Álfsól', 'Árbjörg', 'Árbjört', 'Árdís', 'Árelía', 'Árlaug', 'Ármey', 'Árna', 'Árndís', 'Árney', 'Árnheiður', 'Árnína', 'Árný', 'Áróra', 'Ársól', 'Ársæl', 'Árún', 'Árveig', 'Árvök', 'Árþóra', 'Ása', 'Ásbjörg', 'Ásborg', 'Ásdís', 'Ásfríður', 'Ásgerður', 'Áshildur', 'Áskatla', 'Ásla', 'Áslaug', 'Ásleif', 'Ásný', 'Ásrós', 'Ásrún', 'Ást', 'Ásta', 'Ástbjörg', 'Ástbjört', 'Ástdís', 'Ástfríður', 'Ástgerður', 'Ástheiður', 'Ásthildur', 'Ástríður', 'Ástrós', 'Ástrún', 'Ástveig', 'Ástþóra', 'Ástþrúður', 'Ásvör', 'Baldey', 'Baldrún', 'Baldvina', 'Barbara', 'Barbára', 'Bassí', 'Bára', 'Bebba', 'Begga', 'Belinda', 'Bella', 'Benedikta', 'Bengta', 'Benidikta', 'Benía', 'Beníta', 'Benna', 'Benney', 'Benný', 'Benta', 'Bentey', 'Bentína', 'Bera', 'Bergdís', 'Bergey', 'Bergfríður', 'Bergheiður', 'Berghildur', 'Berglaug', 'Berglind', 'Berglín', 'Bergljót', 'Bergmannía', 'Bergný', 'Bergrán', 'Bergrín', 'Bergrós', 'Bergrún', 'Bergþóra', 'Berit', 'Bernódía', 'Berta', 'Bertha', 'Bessí', 'Bestla', 'Beta', 'Betanía', 'Betsý', 'Bettý', 'Bil', 'Birgit', 'Birgitta', 'Birna', 'Birta', 'Birtna', 'Bíbí', 'Bína', 'Bjargdís', 'Bjargey', 'Bjargheiður', 'Bjarghildur', 'Bjarglind', 'Bjarkey', 'Bjarklind', 'Bjarma', 'Bjarndís', 'Bjarney', 'Bjarnfríður', 'Bjarngerður', 'Bjarnheiður', 'Bjarnhildur', 'Bjarnlaug', 'Bjarnrún', 'Bjarnveig', 'Bjarný', 'Bjarnþóra', 'Bjarnþrúður', 'Bjartey', 'Bjartmey', 'Björg', 'Björgey', 'Björgheiður', 'Björghildur', 'Björk', 'Björney', 'Björnfríður', 'Björt', 'Bláey', 'Blíða', 'Blín', 'Blómey', 'Blædís', 'Blær', 'Bobba', 'Boga', 'Bogdís', 'Bogey', 'Bogga', 'Boghildur', 'Borg', 'Borgdís', 'Borghildur', 'Borgný', 'Borgrún', 'Borgþóra', 'Botnía', 'Bóel', 'Bót', 'Bóthildur', 'Braga', 'Braghildur', 'Branddís', 'Brá', 'Brák', 'Brigitta', 'Brimdís', 'Brimhildur', 'Brimrún', 'Brit', 'Britt', 'Britta', 'Bríana', 'Bríanna', 'Bríet', 'Bryndís', 'Brynfríður', 'Bryngerður', 'Brynheiður', 'Brynhildur', 'Brynja', 'Brynný', 'Burkney', 'Bylgja', 'Camilla', 'Carla', 'Carmen', 'Cecilia', 'Cecilía', 'Charlotta', 'Charlotte', 'Christina', 'Christine', 'Clara', 'Daðey', 'Daðína', 'Dagbjörg', 'Dagbjört', 'Dagfríður', 'Daggrós', 'Dagheiður', 'Dagmar', 'Dagmey', 'Dagný', 'Dagrún', 'Daldís', 'Daley', 'Dalía', 'Dalla', 'Dallilja', 'Dalrós', 'Dana', 'Daney', 'Danfríður', 'Danheiður', 'Danhildur', 'Danía', 'Daníela', 'Daníella', 'Dara', 'Debora', 'Debóra', 'Dendý', 'Didda', 'Dilja', 'Diljá', 'Dimmblá', 'Dimmey', 'Día', 'Díana', 'Díanna', 'Díma', 'Dís', 'Dísa', 'Dísella', 'Donna', 'Doris', 'Dorothea', 'Dóa', 'Dómhildur', 'Dóra', 'Dórey', 'Dóris', 'Dórothea', 'Dórótea', 'Dóróthea', 'Drauma', 'Draumey', 'Drífa', 'Droplaug', 'Drótt', 'Dröfn', 'Dúa', 'Dúfa', 'Dúna', 'Dýrborg', 'Dýrfinna', 'Dýrleif', 'Dýrley', 'Dýrunn', 'Dæja', 'Dögg', 'Dögun', 'Ebba', 'Ebonney', 'Edda', 'Edel', 'Edil', 'Edit', 'Edith', 'Eðna', 'Efemía', 'Egedía', 'Eggrún', 'Egla', 'Eiðný', 'Eiðunn', 'Eik', 'Einbjörg', 'Eindís', 'Einey', 'Einfríður', 'Einhildur', 'Einína', 'Einrún', 'Eir', 'Eirdís', 'Eirfinna', 'Eiríka', 'Eirný', 'Eirún', 'Elba', 'Eldbjörg', 'Eldey', 'Eldlilja', 'Eldrún', 'Eleina', 'Elektra', 'Elena', 'Elenborg', 'Elfa', 'Elfur', 'Elina', 'Elinborg', 'Elisabeth', 'Elía', 'Elíana', 'Elín', 'Elína', 'Elíná', 'Elínbet', 'Elínbjörg', 'Elínbjört', 'Elínborg', 'Elíndís', 'Elíngunnur', 'Elínheiður', 'Elínrós', 'Elírós', 'Elísa', 'Elísabet', 'Elísabeth', 'Elka', 'Ella', 'Ellen', 'Elley', 'Ellisif', 'Ellín', 'Elly', 'Ellý', 'Elma', 'Elna', 'Elsa', 'Elsabet', 'Elsie', 'Elsí', 'Elsý', 'Elva', 'Elvi', 'Elvíra', 'Elvý', 'Embla', 'Emelía', 'Emelíana', 'Emelína', 'Emeralda', 'Emilía', 'Emilíana', 'Emilíanna', 'Emilý', 'Emma', 'Emmý', 'Emý', 'Enea', 'Eneka', 'Engilbjört', 'Engilráð', 'Engilrós', 'Engla', 'Enika', 'Enja', 'Enóla', 'Eres', 'Erika', 'Erin', 'Erla', 'Erlen', 'Erlín', 'Erna', 'Esja', 'Esmeralda', 'Ester', 'Esther', 'Estiva', 'Ethel', 'Etna', 'Eufemía', 'Eva', 'Evelyn', 'Evey', 'Evfemía', 'Evgenía', 'Evíta', 'Evlalía', 'Ey', 'Eybjörg', 'Eybjört', 'Eydís', 'Eyfríður', 'Eygerður', 'Eygló', 'Eyhildur', 'Eyja', 'Eyjalín', 'Eyleif', 'Eylín', 'Eyrós', 'Eyrún', 'Eyveig', 'Eyvör', 'Eyþóra', 'Eyþrúður', 'Fanndís', 'Fanney', 'Fannlaug', 'Fanny', 'Fanný', 'Febrún', 'Fema', 'Filipía', 'Filippa', 'Filippía', 'Finna', 'Finnbjörg', 'Finnbjörk', 'Finnboga', 'Finnborg', 'Finndís', 'Finney', 'Finnfríður', 'Finnlaug', 'Finnrós', 'Fía', 'Fídes', 'Fífa', 'Fjalldís', 'Fjóla', 'Flóra', 'Folda', 'Fransiska', 'Franziska', 'Frán', 'Fregn', 'Freydís', 'Freygerður', 'Freyja', 'Freylaug', 'Freyleif', 'Friðbjörg', 'Friðbjört', 'Friðborg', 'Friðdís', 'Friðdóra', 'Friðey', 'Friðfinna', 'Friðgerður', 'Friðjóna', 'Friðlaug', 'Friðleif', 'Friðlín', 'Friðmey', 'Friðný', 'Friðrika', 'Friðrikka', 'Friðrós', 'Friðrún', 'Friðsemd', 'Friðveig', 'Friðþóra', 'Frigg', 'Fríða', 'Fríður', 'Frostrós', 'Fróðný', 'Fura', 'Fönn', 'Gabríela', 'Gabríella', 'Gauja', 'Gauthildur', 'Gefjun', 'Gefn', 'Geira', 'Geirbjörg', 'Geirdís', 'Geirfinna', 'Geirfríður', 'Geirhildur', 'Geirlaug', 'Geirlöð', 'Geirný', 'Geirríður', 'Geirrún', 'Geirþrúður', 'Georgía', 'Gerða', 'Gerður', 'Gestheiður', 'Gestný', 'Gestrún', 'Gillý', 'Gilslaug', 'Gissunn', 'Gía', 'Gígja', 'Gísela', 'Gísla', 'Gísley', 'Gíslína', 'Gíslný', 'Gíslrún', 'Gíslunn', 'Gíta', 'Gjaflaug', 'Gloría', 'Gló', 'Glóa', 'Glóbjört', 'Glódís', 'Glóð', 'Glóey', 'Gná', 'Góa', 'Gógó', 'Grein', 'Gret', 'Greta', 'Grélöð', 'Grét', 'Gréta', 'Gríma', 'Grímey', 'Grímheiður', 'Grímhildur', 'Gróa', 'Guðbjörg', 'Guðbjört', 'Guðborg', 'Guðdís', 'Guðfinna', 'Guðfríður', 'Guðjóna', 'Guðlaug', 'Guðleif', 'Guðlín', 'Guðmey', 'Guðmunda', 'Guðmundína', 'Guðný', 'Guðríður', 'Guðrún', 'Guðsteina', 'Guðveig', 'Gullbrá', 'Gullveig', 'Gullý', 'Gumma', 'Gunnbjörg', 'Gunnbjört', 'Gunnborg', 'Gunndís', 'Gunndóra', 'Gunnella', 'Gunnfinna', 'Gunnfríður', 'Gunnharða', 'Gunnheiður', 'Gunnhildur', 'Gunnjóna', 'Gunnlaug', 'Gunnleif', 'Gunnlöð', 'Gunnrún', 'Gunnur', 'Gunnveig', 'Gunnvör', 'Gunný', 'Gunnþóra', 'Gunnþórunn', 'Gurrý', 'Gúa', 'Gyða', 'Gyðja', 'Gyðríður', 'Gytta', 'Gæfa', 'Gæflaug', 'Hadda', 'Haddý', 'Hafbjörg', 'Hafborg', 'Hafdís', 'Hafey', 'Hafliða', 'Haflína', 'Hafný', 'Hafrós', 'Hafrún', 'Hafsteina', 'Hafþóra', 'Halla', 'Hallbera', 'Hallbjörg', 'Hallborg', 'Halldís', 'Halldóra', 'Halley', 'Hallfríður', 'Hallgerður', 'Hallgunnur', 'Hallkatla', 'Hallný', 'Hallrún', 'Hallveig', 'Hallvör', 'Hanna', 'Hanney', 'Hansa', 'Hansína', 'Harpa', 'Hauður', 'Hákonía', 'Heba', 'Hedda', 'Hedí', 'Heiða', 'Heiðbjörg', 'Heiðbjörk', 'Heiðbjört', 'Heiðbrá', 'Heiðdís', 'Heiðlaug', 'Heiðlóa', 'Heiðný', 'Heiðrós', 'Heiðrún', 'Heiður', 'Heiðveig', 'Hekla', 'Helen', 'Helena', 'Helga', 'Hella', 'Helma', 'Hendrikka', 'Henný', 'Henrietta', 'Henrika', 'Henríetta', 'Hera', 'Herbjörg', 'Herbjört', 'Herborg', 'Herdís', 'Herfríður', 'Hergerður', 'Herlaug', 'Hermína', 'Hersilía', 'Herta', 'Hertha', 'Hervör', 'Herþrúður', 'Hilda', 'Hildegard', 'Hildibjörg', 'Hildigerður', 'Hildigunnur', 'Hildiríður', 'Hildisif', 'Hildur', 'Hilma', 'Himinbjörg', 'Hind', 'Hinrika', 'Hinrikka', 'Hjalta', 'Hjaltey', 'Hjálmdís', 'Hjálmey', 'Hjálmfríður', 'Hjálmgerður', 'Hjálmrós', 'Hjálmrún', 'Hjálmveig', 'Hjördís', 'Hjörfríður', 'Hjörleif', 'Hjörný', 'Hjörtfríður', 'Hlaðgerður', 'Hlédís', 'Hlíf', 'Hlín', 'Hlökk', 'Hólmbjörg', 'Hólmdís', 'Hólmfríður', 'Hrafna', 'Hrafnborg', 'Hrafndís', 'Hrafney', 'Hrafngerður', 'Hrafnheiður', 'Hrafnhildur', 'Hrafnkatla', 'Hrafnlaug', 'Hrafntinna', 'Hraundís', 'Hrefna', 'Hreindís', 'Hróðný', 'Hrólfdís', 'Hrund', 'Hrönn', 'Hugbjörg', 'Hugbjört', 'Hugborg', 'Hugdís', 'Hugljúf', 'Hugrún', 'Huld', 'Hulda', 'Huldís', 'Huldrún', 'Húnbjörg', 'Húndís', 'Húngerður', 'Hvönn', 'Hödd', 'Högna', 'Hörn', 'Ida', 'Idda', 'Iða', 'Iðunn', 'Ilmur', 'Immý', 'Ina', 'Inda', 'India', 'Indiana', 'Indía', 'Indíana', 'Indíra', 'Indra', 'Inga', 'Ingdís', 'Ingeborg', 'Inger', 'Ingey', 'Ingheiður', 'Inghildur', 'Ingibjörg', 'Ingibjört', 'Ingiborg', 'Ingifinna', 'Ingifríður', 'Ingigerður', 'Ingilaug', 'Ingileif', 'Ingilín', 'Ingimaría', 'Ingimunda', 'Ingiríður', 'Ingirós', 'Ingisól', 'Ingiveig', 'Ingrid', 'Ingrún', 'Ingunn', 'Ingveldur', 'Inna', 'Irena', 'Irene', 'Irja', 'Irma', 'Irmý', 'Irpa', 'Isabel', 'Isabella', 'Ída', 'Íma', 'Ína', 'Ír', 'Íren', 'Írena', 'Íris', 'Írunn', 'Ísabel', 'Ísabella', 'Ísadóra', 'Ísafold', 'Ísalind', 'Ísbjörg', 'Ísdís', 'Ísey', 'Ísfold', 'Ísgerður', 'Íshildur', 'Ísis', 'Íslaug', 'Ísleif', 'Ísmey', 'Ísold', 'Ísól', 'Ísrún', 'Íssól', 'Ísveig', 'Íunn', 'Íva', 'Jakobína', 'Jana', 'Jane', 'Janetta', 'Jannika', 'Jara', 'Jarún', 'Jarþrúður', 'Jasmín', 'Járnbrá', 'Járngerður', 'Jenetta', 'Jenna', 'Jenný', 'Jensína', 'Jessý', 'Jovina', 'Jóa', 'Jóanna', 'Jódís', 'Jófríður', 'Jóhanna', 'Jólín', 'Jóna', 'Jónanna', 'Jónasína', 'Jónbjörg', 'Jónbjört', 'Jóndís', 'Jóndóra', 'Jóney', 'Jónfríður', 'Jóngerð', 'Jónheiður', 'Jónhildur', 'Jóninna', 'Jónída', 'Jónína', 'Jónný', 'Jóný', 'Jóra', 'Jóríður', 'Jórlaug', 'Jórunn', 'Jósebína', 'Jósefín', 'Jósefína', 'Judith', 'Júdea', 'Júdit', 'Júlía', 'Júlíana', 'Júlíanna', 'Júlíetta', 'Júlírós', 'Júnía', 'Júníana', 'Jökla', 'Jökulrós', 'Jörgína', 'Kaðlín', 'Kaja', 'Kalla', 'Kamilla', 'Kamí', 'Kamma', 'Kapitola', 'Kapítóla', 'Kara', 'Karen', 'Karin', 'Karitas', 'Karí', 'Karín', 'Karína', 'Karítas', 'Karla', 'Karlinna', 'Karlína', 'Karlotta', 'Karolína', 'Karó', 'Karólín', 'Karólína', 'Kassandra', 'Kata', 'Katarína', 'Katerína', 'Katharina', 'Kathinka', 'Katinka', 'Katla', 'Katrín', 'Katrína', 'Katý', 'Kára', 'Kellý', 'Kendra', 'Ketilbjörg', 'Ketilfríður', 'Ketilríður', 'Kiddý', 'Kira', 'Kirsten', 'Kirstín', 'Kittý', 'Kjalvör', 'Klara', 'Kládía', 'Klementína', 'Kleópatra', 'Kolbjörg', 'Kolbrá', 'Kolbrún', 'Koldís', 'Kolfinna', 'Kolfreyja', 'Kolgríma', 'Kolka', 'Konkordía', 'Konný', 'Korka', 'Kormlöð', 'Kornelía', 'Kókó', 'Krista', 'Kristbjörg', 'Kristborg', 'Kristel', 'Kristensa', 'Kristey', 'Kristfríður', 'Kristgerður', 'Kristin', 'Kristine', 'Kristíana', 'Kristíanna', 'Kristín', 'Kristína', 'Kristjana', 'Kristjóna', 'Kristlaug', 'Kristlind', 'Kristlín', 'Kristný', 'Kristólína', 'Kristrós', 'Kristrún', 'Kristveig', 'Kristvina', 'Kristþóra', 'Kría', 'Kæja', 'Laila', 'Laíla', 'Lana', 'Lara', 'Laufey', 'Laufheiður', 'Laufhildur', 'Lauga', 'Laugey', 'Laugheiður', 'Lára', 'Lárensína', 'Láretta', 'Lárey', 'Lea', 'Leikný', 'Leila', 'Lena', 'Leonóra', 'Leóna', 'Leónóra', 'Lilja', 'Liljá', 'Liljurós', 'Lill', 'Lilla', 'Lillian', 'Lillý', 'Lily', 'Lilý', 'Lind', 'Linda', 'Linddís', 'Lingný', 'Lisbeth', 'Listalín', 'Liv', 'Líba', 'Líf', 'Lífdís', 'Lín', 'Lína', 'Línbjörg', 'Líndís', 'Líneik', 'Líney', 'Línhildur', 'Lísa', 'Lísabet', 'Lísandra', 'Lísbet', 'Lísebet', 'Lív', 'Ljósbjörg', 'Ljósbrá', 'Ljótunn', 'Lofn', 'Loftveig', 'Logey', 'Lokbrá', 'Lotta', 'Louisa', 'Lousie', 'Lovísa', 'Lóa', 'Lóreley', 'Lukka', 'Lúcía', 'Lúðvíka', 'Lúísa', 'Lúna', 'Lúsinda', 'Lúsía', 'Lúvísa', 'Lydia', 'Lydía', 'Lyngheiður', 'Lýdía', 'Læla', 'Maddý', 'Magda', 'Magdalena', 'Magðalena', 'Magga', 'Maggey', 'Maggý', 'Magna', 'Magndís', 'Magnea', 'Magnes', 'Magney', 'Magnfríður', 'Magnheiður', 'Magnhildur', 'Magnúsína', 'Magný', 'Magnþóra', 'Maía', 'Maídís', 'Maísól', 'Maj', 'Maja', 'Malen', 'Malena', 'Malía', 'Malín', 'Malla', 'Manda', 'Manúela', 'Mara', 'Mardís', 'Marela', 'Marella', 'Maren', 'Marey', 'Marfríður', 'Margit', 'Margot', 'Margret', 'Margrét', 'Margrjet', 'Margunnur', 'Marheiður', 'Maria', 'Marie', 'Marikó', 'Marinella', 'Marit', 'Marí', 'María', 'Maríam', 'Marían', 'Maríana', 'Maríanna', 'Marín', 'Marína', 'Marínella', 'Maríon', 'Marísa', 'Marísól', 'Marít', 'Maríuerla', 'Marja', 'Markrún', 'Marlaug', 'Marlena', 'Marlín', 'Marlís', 'Marólína', 'Marsa', 'Marselía', 'Marselína', 'Marsibil', 'Marsilía', 'Marsý', 'Marta', 'Martha', 'Martína', 'Mary', 'Marý', 'Matta', 'Mattea', 'Matthea', 'Matthilda', 'Matthildur', 'Matthía', 'Mattíana', 'Mattína', 'Mattý', 'Maxima', 'Mábil', 'Málfríður', 'Málhildur', 'Málmfríður', 'Mánadís', 'Máney', 'Mára', 'Meda', 'Mekkin', 'Mekkín', 'Melinda', 'Melissa', 'Melkorka', 'Melrós', 'Messíana', 'Metta', 'Mey', 'Mikaela', 'Mikaelína', 'Mikkalína', 'Milda', 'Mildríður', 'Milla', 'Millý', 'Minerva', 'Minna', 'Minney', 'Minný', 'Miriam', 'Mirja', 'Mirjam', 'Mirra', 'Mist', 'Mía', 'Mínerva', 'Míra', 'Míranda', 'Mítra', 'Mjaðveig', 'Mjalldís', 'Mjallhvít', 'Mjöll', 'Mona', 'Monika', 'Módís', 'Móeiður', 'Móey', 'Móheiður', 'Móna', 'Mónika', 'Móníka', 'Munda', 'Mundheiður', 'Mundhildur', 'Mundína', 'Myrra', 'Mýr', 'Mýra', 'Mýrún', 'Mörk', 'Nadia', 'Nadía', 'Nadja', 'Nana', 'Nanna', 'Nanný', 'Nansý', 'Naomí', 'Naómí', 'Natalie', 'Natalía', 'Náttsól', 'Nella', 'Nellý', 'Nenna', 'Nicole', 'Niðbjörg', 'Nikíta', 'Nikoletta', 'Nikólína', 'Ninja', 'Ninna', 'Nína', 'Níní', 'Njála', 'Njóla', 'Norma', 'Nóa', 'Nóra', 'Nótt', 'Nýbjörg', 'Odda', 'Oddbjörg', 'Oddfreyja', 'Oddfríður', 'Oddgerður', 'Oddhildur', 'Oddlaug', 'Oddleif', 'Oddný', 'Oddrún', 'Oddveig', 'Oddvör', 'Oktavía', 'Októvía', 'Olga', 'Ollý', 'Ora', 'Orka', 'Ormheiður', 'Ormhildur', 'Otkatla', 'Otta', 'Óda', 'Ófelía', 'Óla', 'Ólafía', 'Ólafína', 'Ólavía', 'Ólivía', 'Ólína', 'Ólöf', 'Ósa', 'Ósk', 'Ótta', 'Pamela', 'París', 'Patricia', 'Patrisía', 'Pála', 'Páldís', 'Páley', 'Pálfríður', 'Pálhanna', 'Pálheiður', 'Pálhildur', 'Pálín', 'Pálína', 'Pálmey', 'Pálmfríður', 'Pálrún', 'Perla', 'Peta', 'Petra', 'Petrea', 'Petrína', 'Petronella', 'Petrónella', 'Petrós', 'Petrún', 'Petrúnella', 'Pétrína', 'Pétrún', 'Pía', 'Polly', 'Pollý', 'Pría', 'Rafney', 'Rafnhildur', 'Ragna', 'Ragnbjörg', 'Ragney', 'Ragnfríður', 'Ragnheiður', 'Ragnhildur', 'Rakel', 'Ramóna', 'Randalín', 'Randíður', 'Randý', 'Ranka', 'Rannva', 'Rannveig', 'Ráðhildur', 'Rán', 'Rebekka', 'Reginbjörg', 'Regína', 'Rein', 'Renata', 'Reyn', 'Reyndís', 'Reynheiður', 'Reynhildur', 'Rikka', 'Ripley', 'Rita', 'Ríkey', 'Rín', 'Ríta', 'Ronja', 'Rorí', 'Roxanna', 'Róberta', 'Róbjörg', 'Rós', 'Rósa', 'Rósalind', 'Rósanna', 'Rósbjörg', 'Rósborg', 'Róselía', 'Rósey', 'Rósfríður', 'Róshildur', 'Rósinkara', 'Rósinkransa', 'Róska', 'Róslaug', 'Róslind', 'Róslinda', 'Róslín', 'Rósmary', 'Rósmarý', 'Rósmunda', 'Rósný', 'Runný', 'Rut', 'Ruth', 'Rúbý', 'Rún', 'Rúna', 'Rúndís', 'Rúnhildur', 'Rúrí', 'Röfn', 'Rögn', 'Röskva', 'Sabína', 'Sabrína', 'Saga', 'Salbjörg', 'Saldís', 'Salgerður', 'Salín', 'Salína', 'Salka', 'Salma', 'Salný', 'Salome', 'Salóme', 'Salvör', 'Sandra', 'Sanna', 'Santía', 'Sara', 'Sarína', 'Sefanía', 'Selja', 'Selka', 'Selma', 'Senía', 'Septíma', 'Sera', 'Serena', 'Seselía', 'Sesilía', 'Sesselía', 'Sesselja', 'Sessilía', 'Sif', 'Sigdís', 'Sigdóra', 'Sigfríð', 'Sigfríður', 'Sigga', 'Siggerður', 'Sigmunda', 'Signa', 'Signhildur', 'Signý', 'Sigríður', 'Sigrún', 'Sigurást', 'Sigurásta', 'Sigurbára', 'Sigurbirna', 'Sigurbjörg', 'Sigurbjört', 'Sigurborg', 'Sigurdís', 'Sigurdóra', 'Sigurdríf', 'Sigurdrífa', 'Sigurða', 'Sigurey', 'Sigurfinna', 'Sigurfljóð', 'Sigurgeira', 'Sigurhanna', 'Sigurhelga', 'Sigurhildur', 'Sigurjóna', 'Sigurlaug', 'Sigurleif', 'Sigurlilja', 'Sigurlinn', 'Sigurlín', 'Sigurlína', 'Sigurmunda', 'Sigurnanna', 'Sigurósk', 'Sigurrós', 'Sigursteina', 'Sigurunn', 'Sigurveig', 'Sigurvina', 'Sigurþóra', 'Sigyn', 'Sigþóra', 'Sigþrúður', 'Silfa', 'Silfá', 'Silfrún', 'Silja', 'Silka', 'Silla', 'Silva', 'Silvana', 'Silvía', 'Sirra', 'Sirrý', 'Siv', 'Sía', 'Símonía', 'Sísí', 'Síta', 'Sjöfn', 'Skarpheiður', 'Skugga', 'Skuld', 'Skúla', 'Skúlína', 'Snjáfríður', 'Snjáka', 'Snjófríður', 'Snjólaug', 'Snorra', 'Snót', 'Snæbjörg', 'Snæbjört', 'Snæborg', 'Snæbrá', 'Snædís', 'Snæfríður', 'Snælaug', 'Snærós', 'Snærún', 'Soffía', 'Sofie', 'Sofía', 'Solveig', 'Sonja', 'Sonný', 'Sophia', 'Sophie', 'Sól', 'Sóla', 'Sólbjörg', 'Sólbjört', 'Sólborg', 'Sólbrá', 'Sólbrún', 'Sóldís', 'Sóldögg', 'Sóley', 'Sólfríður', 'Sólgerður', 'Sólhildur', 'Sólín', 'Sólkatla', 'Sóllilja', 'Sólný', 'Sólrós', 'Sólrún', 'Sólveig', 'Sólvör', 'Sónata', 'Stefana', 'Stefanía', 'Stefánný', 'Steina', 'Steinbjörg', 'Steinborg', 'Steindís', 'Steindóra', 'Steiney', 'Steinfríður', 'Steingerður', 'Steinhildur', 'Steinlaug', 'Steinrós', 'Steinrún', 'Steinunn', 'Steinvör', 'Steinþóra', 'Stella', 'Stígheiður', 'Stígrún', 'Stína', 'Stjarna', 'Styrgerður', 'Sumarlína', 'Sumarrós', 'Sunna', 'Sunnefa', 'Sunneva', 'Sunniva', 'Sunníva', 'Susan', 'Súla', 'Súsan', 'Súsanna', 'Svafa', 'Svala', 'Svalrún', 'Svana', 'Svanbjörg', 'Svanbjört', 'Svanborg', 'Svandís', 'Svaney', 'Svanfríður', 'Svanheiður', 'Svanhildur', 'Svanhvít', 'Svanlaug', 'Svanrós', 'Svanþrúður', 'Svava', 'Svea', 'Sveina', 'Sveinbjörg', 'Sveinborg', 'Sveindís', 'Sveiney', 'Sveinfríður', 'Sveingerður', 'Sveinhildur', 'Sveinlaug', 'Sveinrós', 'Sveinrún', 'Sveinsína', 'Sveinveig', 'Sylgja', 'Sylva', 'Sylvía', 'Sæbjörg', 'Sæbjört', 'Sæborg', 'Sædís', 'Sæfinna', 'Sæfríður', 'Sæhildur', 'Sælaug', 'Sæmunda', 'Sæný', 'Særós', 'Særún', 'Sæsól', 'Sæunn', 'Sævör', 'Sölva', 'Sölvey', 'Sölvína', 'Tala', 'Talía', 'Tamar', 'Tamara', 'Tanía', 'Tanja', 'Tanya', 'Tanya', 'Tara', 'Tea', 'Teitný', 'Tekla', 'Telma', 'Tera', 'Teresa', 'Teresía', 'Thea', 'Thelma', 'Theodóra', 'Theódóra', 'Theresa', 'Tindra', 'Tinna', 'Tirsa', 'Tía', 'Tíbrá', 'Tína', 'Todda', 'Torbjörg', 'Torfey', 'Torfheiður', 'Torfhildur', 'Tóbý', 'Tóka', 'Tóta', 'Tristana', 'Trú', 'Tryggva', 'Tryggvína', 'Týra', 'Ugla', 'Una', 'Undína', 'Unna', 'Unnbjörg', 'Unndís', 'Unnur', 'Urður', 'Úa', 'Úlfa', 'Úlfdís', 'Úlfey', 'Úlfheiður', 'Úlfhildur', 'Úlfrún', 'Úlla', 'Úna', 'Úndína', 'Úranía', 'Úrsúla', 'Vagna', 'Vagnbjörg', 'Vagnfríður', 'Vaka', 'Vala', 'Valbjörg', 'Valbjörk', 'Valbjört', 'Valborg', 'Valdheiður', 'Valdís', 'Valentína', 'Valería', 'Valey', 'Valfríður', 'Valgerða', 'Valgerður', 'Valhildur', 'Valka', 'Vallý', 'Valný', 'Valrós', 'Valrún', 'Valva', 'Valý', 'Valþrúður', 'Vanda', 'Vár', 'Veig', 'Veiga', 'Venus', 'Vera', 'Veronika', 'Verónika', 'Veróníka', 'Vetrarrós', 'Vébjörg', 'Védís', 'Végerður', 'Vélaug', 'Véný', 'Vibeka', 'Victoría', 'Viðja', 'Vigdís', 'Vigný', 'Viktoria', 'Viktoría', 'Vilborg', 'Vildís', 'Vilfríður', 'Vilgerður', 'Vilhelmína', 'Villa', 'Villimey', 'Vilma', 'Vilný', 'Vinbjörg', 'Vinný', 'Vinsý', 'Virginía', 'Víbekka', 'Víf', 'Vígdögg', 'Víggunnur', 'Víóla', 'Víóletta', 'Vísa', 'Von', 'Von', 'Voney', 'Vordís', 'Ylfa', 'Ylfur', 'Ylja', 'Ylva', 'Ynja', 'Yrja', 'Yrsa', 'Ýja', 'Ýma', 'Ýr', 'Ýrr', 'Þalía', 'Þeba', 'Þeódís', 'Þeódóra', 'Þjóðbjörg', 'Þjóðhildur', 'Þoka', 'Þorbjörg', 'Þorfinna', 'Þorgerður', 'Þorgríma', 'Þorkatla', 'Þorlaug', 'Þorleif', 'Þorsteina', 'Þorstína', 'Þóra', 'Þóranna', 'Þórarna', 'Þórbjörg', 'Þórdís', 'Þórða', 'Þórelfa', 'Þórelfur', 'Þórey', 'Þórfríður', 'Þórgunna', 'Þórgunnur', 'Þórhalla', 'Þórhanna', 'Þórheiður', 'Þórhildur', 'Þórkatla', 'Þórlaug', 'Þórleif', 'Þórný', 'Þórodda', 'Þórsteina', 'Þórsteinunn', 'Þórstína', 'Þórunn', 'Þórveig', 'Þórvör', 'Þrá', 'Þrúða', 'Þrúður', 'Þula', 'Þura', 'Þurí', 'Þuríður', 'Þurý', 'Þúfa', 'Þyri', 'Þyrí', 'Þöll', 'Ægileif', 'Æsa', 'Æsgerður', 'Ögmunda', 'Ögn', 'Ölrún', 'Ölveig', 'Örbrún', 'Örk', 'Ösp'];
+
+ /**
+ * @var string Icelandic men names.
+ */
+ protected static $firstNameMale = ['Aage', 'Abel', 'Abraham', 'Adam', 'Addi', 'Adel', 'Adíel', 'Adólf', 'Adrían', 'Adríel', 'Aðalberg', 'Aðalbergur', 'Aðalbert', 'Aðalbjörn', 'Aðalborgar', 'Aðalgeir', 'Aðalmundur', 'Aðalráður', 'Aðalsteinn', 'Aðólf', 'Agnar', 'Agni', 'Albert', 'Aldar', 'Alex', 'Alexander', 'Alexíus', 'Alfons', 'Alfred', 'Alfreð', 'Ali', 'Allan', 'Alli', 'Almar', 'Alrekur', 'Alvar', 'Alvin', 'Amír', 'Amos', 'Anders', 'Andreas', 'André', 'Andrés', 'Andri', 'Anes', 'Anfinn', 'Angantýr', 'Angi', 'Annar', 'Annarr', 'Annas', 'Annel', 'Annes', 'Anthony', 'Anton', 'Antoníus', 'Aran', 'Arent', 'Ares', 'Ari', 'Arilíus', 'Arinbjörn', 'Aríel', 'Aríus', 'Arnald', 'Arnaldur', 'Arnar', 'Arnberg', 'Arnbergur', 'Arnbjörn', 'Arndór', 'Arnes', 'Arnfinnur', 'Arnfreyr', 'Arngeir', 'Arngils', 'Arngrímur', 'Arnkell', 'Arnlaugur', 'Arnleifur', 'Arnljótur', 'Arnmóður', 'Arnmundur', 'Arnoddur', 'Arnold', 'Arnór', 'Arnsteinn', 'Arnúlfur', 'Arnviður', 'Arnþór', 'Aron', 'Arthur', 'Arthúr', 'Artúr', 'Asael', 'Askur', 'Aspar', 'Atlas', 'Atli', 'Auðbergur', 'Auðbert', 'Auðbjörn', 'Auðgeir', 'Auðkell', 'Auðmundur', 'Auðólfur', 'Auðun', 'Auðunn', 'Austar', 'Austmann', 'Austmar', 'Austri', 'Axel', 'Ágúst', 'Áki', 'Álfar', 'Álfgeir', 'Álfgrímur', 'Álfur', 'Álfþór', 'Ámundi', 'Árbjartur', 'Árbjörn', 'Árelíus', 'Árgeir', 'Árgils', 'Ármann', 'Árni', 'Ársæll', 'Ás', 'Ásberg', 'Ásbergur', 'Ásbjörn', 'Ásgautur', 'Ásgeir', 'Ásgils', 'Ásgrímur', 'Ási', 'Áskell', 'Áslaugur', 'Áslákur', 'Ásmar', 'Ásmundur', 'Ásólfur', 'Ásröður', 'Ástbjörn', 'Ástgeir', 'Ástmar', 'Ástmundur', 'Ástráður', 'Ástríkur', 'Ástvald', 'Ástvaldur', 'Ástvar', 'Ástvin', 'Ástþór', 'Ásvaldur', 'Ásvarður', 'Ásþór', 'Baldur', 'Baldvin', 'Baldwin', 'Baltasar', 'Bambi', 'Barði', 'Barri', 'Bassi', 'Bastían', 'Baugur', 'Bárður', 'Beinir', 'Beinteinn', 'Beitir', 'Bekan', 'Benedikt', 'Benidikt', 'Benjamín', 'Benoný', 'Benóní', 'Benóný', 'Bent', 'Berent', 'Berg', 'Bergfinnur', 'Berghreinn', 'Bergjón', 'Bergmann', 'Bergmar', 'Bergmundur', 'Bergsteinn', 'Bergsveinn', 'Bergur', 'Bergvin', 'Bergþór', 'Bernhard', 'Bernharð', 'Bernharður', 'Berni', 'Bernódus', 'Bersi', 'Bertel', 'Bertram', 'Bessi', 'Betúel', 'Bill', 'Birgir', 'Birkir', 'Birnir', 'Birtingur', 'Birtir', 'Bjargar', 'Bjargmundur', 'Bjargþór', 'Bjarkan', 'Bjarkar', 'Bjarki', 'Bjarmar', 'Bjarmi', 'Bjarnar', 'Bjarnfinnur', 'Bjarnfreður', 'Bjarnharður', 'Bjarnhéðinn', 'Bjarni', 'Bjarnlaugur', 'Bjarnleifur', 'Bjarnólfur', 'Bjarnsteinn', 'Bjarnþór', 'Bjartmann', 'Bjartmar', 'Bjartur', 'Bjartþór', 'Bjólan', 'Bjólfur', 'Björgmundur', 'Björgólfur', 'Björgúlfur', 'Björgvin', 'Björn', 'Björnólfur', 'Blængur', 'Blær', 'Blævar', 'Boði', 'Bogi', 'Bolli', 'Borgar', 'Borgúlfur', 'Borgþór', 'Bóas', 'Bói', 'Bótólfur', 'Bragi', 'Brandur', 'Breki', 'Bresi', 'Brestir', 'Brimar', 'Brimi', 'Brimir', 'Brími', 'Brjánn', 'Broddi', 'Bruno', 'Bryngeir', 'Brynjar', 'Brynjólfur', 'Brynjúlfur', 'Brynleifur', 'Brynsteinn', 'Bryntýr', 'Brynþór', 'Burkni', 'Búi', 'Búri', 'Bæring', 'Bæringur', 'Bæron', 'Böðvar', 'Börkur', 'Carl', 'Cecil', 'Christian', 'Christopher', 'Cýrus', 'Daði', 'Dagbjartur', 'Dagfari', 'Dagfinnur', 'Daggeir', 'Dagmann', 'Dagnýr', 'Dagur', 'Dagþór', 'Dalbert', 'Dalli', 'Dalmann', 'Dalmar', 'Dalvin', 'Damjan', 'Dan', 'Danelíus', 'Daniel', 'Danival', 'Daníel', 'Daníval', 'Dante', 'Daríus', 'Darri', 'Davíð', 'Demus', 'Deníel', 'Dennis', 'Diðrik', 'Díómedes', 'Dofri', 'Dolli', 'Dominik', 'Dómald', 'Dómaldi', 'Dómaldur', 'Dónald', 'Dónaldur', 'Dór', 'Dóri', 'Dósóþeus', 'Draupnir', 'Dreki', 'Drengur', 'Dufgus', 'Dufþakur', 'Dugfús', 'Dúi', 'Dúnn', 'Dvalinn', 'Dýri', 'Dýrmundur', 'Ebbi', 'Ebeneser', 'Ebenezer', 'Eberg', 'Edgar', 'Edilon', 'Edílon', 'Edvard', 'Edvin', 'Edward', 'Eðvald', 'Eðvar', 'Eðvarð', 'Efraím', 'Eggert', 'Eggþór', 'Egill', 'Eiðar', 'Eiður', 'Eikar', 'Eilífur', 'Einar', 'Einir', 'Einvarður', 'Einþór', 'Eiríkur', 'Eivin', 'Elberg', 'Elbert', 'Eldar', 'Eldgrímur', 'Eldjárn', 'Eldmar', 'Eldon', 'Eldór', 'Eldur', 'Elentínus', 'Elfar', 'Elfráður', 'Elimar', 'Elinór', 'Elis', 'Elí', 'Elías', 'Elíeser', 'Elímar', 'Elínbergur', 'Elínmundur', 'Elínór', 'Elís', 'Ellert', 'Elli', 'Elliði', 'Ellís', 'Elmar', 'Elvar', 'Elvin', 'Elvis', 'Emanúel', 'Embrek', 'Emerald', 'Emil', 'Emmanúel', 'Engilbert', 'Engilbjartur', 'Engiljón', 'Engill', 'Enok', 'Eric', 'Erik', 'Erlar', 'Erlendur', 'Erling', 'Erlingur', 'Ernestó', 'Ernir', 'Ernst', 'Eron', 'Erpur', 'Esekíel', 'Esjar', 'Esra', 'Estefan', 'Evald', 'Evan', 'Evert', 'Eyberg', 'Eyjólfur', 'Eylaugur', 'Eyleifur', 'Eymar', 'Eymundur', 'Eyríkur', 'Eysteinn', 'Eyvar', 'Eyvindur', 'Eyþór', 'Fabrisíus', 'Falgeir', 'Falur', 'Fannar', 'Fannberg', 'Fanngeir', 'Fáfnir', 'Fálki', 'Felix', 'Fengur', 'Fenrir', 'Ferdinand', 'Ferdínand', 'Fertram', 'Feykir', 'Filip', 'Filippus', 'Finn', 'Finnbjörn', 'Finnbogi', 'Finngeir', 'Finnjón', 'Finnlaugur', 'Finnur', 'Finnvarður', 'Fífill', 'Fjalar', 'Fjarki', 'Fjólar', 'Fjólmundur', 'Fjölnir', 'Fjölvar', 'Fjörnir', 'Flemming', 'Flosi', 'Flóki', 'Flórent', 'Flóvent', 'Forni', 'Fossmar', 'Fólki', 'Francis', 'Frank', 'Franklín', 'Frans', 'Franz', 'Fránn', 'Frár', 'Freybjörn', 'Freygarður', 'Freymar', 'Freymóður', 'Freymundur', 'Freyr', 'Freysteinn', 'Freyviður', 'Freyþór', 'Friðberg', 'Friðbergur', 'Friðbert', 'Friðbjörn', 'Friðfinnur', 'Friðgeir', 'Friðjón', 'Friðlaugur', 'Friðleifur', 'Friðmann', 'Friðmar', 'Friðmundur', 'Friðrik', 'Friðsteinn', 'Friður', 'Friðvin', 'Friðþjófur', 'Friðþór', 'Friedrich', 'Fritz', 'Frímann', 'Frosti', 'Fróði', 'Fróðmar', 'Funi', 'Fúsi', 'Fylkir', 'Gabriel', 'Gabríel', 'Gael', 'Galdur', 'Gamalíel', 'Garðar', 'Garibaldi', 'Garpur', 'Garri', 'Gaui', 'Gaukur', 'Gauti', 'Gautrekur', 'Gautur', 'Gautviður', 'Geir', 'Geirarður', 'Geirfinnur', 'Geirharður', 'Geirhjörtur', 'Geirhvatur', 'Geiri', 'Geirlaugur', 'Geirleifur', 'Geirmundur', 'Geirólfur', 'Geirröður', 'Geirtryggur', 'Geirvaldur', 'Geirþjófur', 'Geisli', 'Gellir', 'Georg', 'Gerald', 'Gerðar', 'Geri', 'Gestur', 'Gilbert', 'Gilmar', 'Gils', 'Gissur', 'Gizur', 'Gídeon', 'Gígjar', 'Gísli', 'Gjúki', 'Glói', 'Glúmur', 'Gneisti', 'Gnúpur', 'Gnýr', 'Goði', 'Goðmundur', 'Gottskálk', 'Gottsveinn', 'Gói', 'Grani', 'Grankell', 'Gregor', 'Greipur', 'Greppur', 'Gretar', 'Grettir', 'Grétar', 'Grímar', 'Grímkell', 'Grímlaugur', 'Grímnir', 'Grímólfur', 'Grímur', 'Grímúlfur', 'Guðberg', 'Guðbergur', 'Guðbjarni', 'Guðbjartur', 'Guðbjörn', 'Guðbrandur', 'Guðfinnur', 'Guðfreður', 'Guðgeir', 'Guðjón', 'Guðlaugur', 'Guðleifur', 'Guðleikur', 'Guðmann', 'Guðmar', 'Guðmon', 'Guðmundur', 'Guðni', 'Guðráður', 'Guðröður', 'Guðsteinn', 'Guðvarður', 'Guðveigur', 'Guðvin', 'Guðþór', 'Gumi', 'Gunnar', 'Gunnberg', 'Gunnbjörn', 'Gunndór', 'Gunngeir', 'Gunnhallur', 'Gunnlaugur', 'Gunnleifur', 'Gunnólfur', 'Gunnóli', 'Gunnröður', 'Gunnsteinn', 'Gunnvaldur', 'Gunnþór', 'Gustav', 'Gutti', 'Guttormur', 'Gústaf', 'Gústav', 'Gylfi', 'Gyrðir', 'Gýgjar', 'Gýmir', 'Haddi', 'Haddur', 'Hafberg', 'Hafgrímur', 'Hafliði', 'Hafnar', 'Hafni', 'Hafsteinn', 'Hafþór', 'Hagalín', 'Hagbarður', 'Hagbert', 'Haki', 'Hallberg', 'Hallbjörn', 'Halldór', 'Hallfreður', 'Hallgarður', 'Hallgeir', 'Hallgils', 'Hallgrímur', 'Hallkell', 'Hallmann', 'Hallmar', 'Hallmundur', 'Hallsteinn', 'Hallur', 'Hallvarður', 'Hallþór', 'Hamar', 'Hannes', 'Hannibal', 'Hans', 'Harald', 'Haraldur', 'Harri', 'Harry', 'Harrý', 'Hartmann', 'Hartvig', 'Hauksteinn', 'Haukur', 'Haukvaldur', 'Hákon', 'Háleygur', 'Hálfdan', 'Hálfdán', 'Hámundur', 'Hárekur', 'Hárlaugur', 'Hásteinn', 'Hávar', 'Hávarður', 'Hávarr', 'Hávarr', 'Heiðar', 'Heiðarr', 'Heiðberg', 'Heiðbert', 'Heiðlindur', 'Heiðmann', 'Heiðmar', 'Heiðmundur', 'Heiðrekur', 'Heikir', 'Heilmóður', 'Heimir', 'Heinrekur', 'Heisi', 'Hektor', 'Helgi', 'Helmút', 'Hemmert', 'Hendrik', 'Henning', 'Henrik', 'Henry', 'Henrý', 'Herbert', 'Herbjörn', 'Herfinnur', 'Hergeir', 'Hergill', 'Hergils', 'Herjólfur', 'Herlaugur', 'Herleifur', 'Herluf', 'Hermann', 'Hermóður', 'Hermundur', 'Hersir', 'Hersteinn', 'Hersveinn', 'Hervar', 'Hervarður', 'Hervin', 'Héðinn', 'Hilaríus', 'Hilbert', 'Hildar', 'Hildibergur', 'Hildibrandur', 'Hildigeir', 'Hildiglúmur', 'Hildimar', 'Hildimundur', 'Hildingur', 'Hildir', 'Hildiþór', 'Hilmar', 'Hilmir', 'Himri', 'Hinrik', 'Híram', 'Hjallkár', 'Hjalti', 'Hjarnar', 'Hjálmar', 'Hjálmgeir', 'Hjálmtýr', 'Hjálmur', 'Hjálmþór', 'Hjörleifur', 'Hjörtur', 'Hjörtþór', 'Hjörvar', 'Hleiðar', 'Hlégestur', 'Hlér', 'Hlini', 'Hlíðar', 'Hlíðberg', 'Hlífar', 'Hljómur', 'Hlynur', 'Hlöðmundur', 'Hlöður', 'Hlöðvarður', 'Hlöðver', 'Hnefill', 'Hnikar', 'Hnikarr', 'Holgeir', 'Holger', 'Holti', 'Hólm', 'Hólmar', 'Hólmbert', 'Hólmfastur', 'Hólmgeir', 'Hólmgrímur', 'Hólmkell', 'Hólmsteinn', 'Hólmþór', 'Hóseas', 'Hrafn', 'Hrafnar', 'Hrafnbergur', 'Hrafnkell', 'Hrafntýr', 'Hrannar', 'Hrappur', 'Hraunar', 'Hreggviður', 'Hreiðar', 'Hreiðmar', 'Hreimur', 'Hreinn', 'Hringur', 'Hrímnir', 'Hrollaugur', 'Hrolleifur', 'Hróaldur', 'Hróar', 'Hróbjartur', 'Hróðgeir', 'Hróðmar', 'Hróðólfur', 'Hróðvar', 'Hrói', 'Hrólfur', 'Hrómundur', 'Hrútur', 'Hrærekur', 'Hugberg', 'Hugi', 'Huginn', 'Hugleikur', 'Hugo', 'Hugó', 'Huldar', 'Huxley', 'Húbert', 'Húgó', 'Húmi', 'Húnbogi', 'Húni', 'Húnn', 'Húnröður', 'Hvannar', 'Hyltir', 'Hylur', 'Hængur', 'Hænir', 'Höður', 'Högni', 'Hörður', 'Höskuldur', 'Illugi', 'Immanúel', 'Indriði', 'Ingberg', 'Ingi', 'Ingiberg', 'Ingibergur', 'Ingibert', 'Ingibjartur', 'Ingibjörn', 'Ingileifur', 'Ingimagn', 'Ingimar', 'Ingimundur', 'Ingivaldur', 'Ingiþór', 'Ingjaldur', 'Ingmar', 'Ingólfur', 'Ingvaldur', 'Ingvar', 'Ingvi', 'Ingþór', 'Ismael', 'Issi', 'Ían', 'Ígor', 'Ími', 'Ísak', 'Ísar', 'Ísarr', 'Ísbjörn', 'Íseldur', 'Ísgeir', 'Ísidór', 'Ísleifur', 'Ísmael', 'Ísmar', 'Ísólfur', 'Ísrael', 'Ívan', 'Ívar', 'Jack', 'Jafet', 'Jaki', 'Jakob', 'Jakop', 'Jamil', 'Jan', 'Janus', 'Jarl', 'Jason', 'Járngrímur', 'Játgeir', 'Játmundur', 'Játvarður', 'Jenni', 'Jens', 'Jeremías', 'Jes', 'Jesper', 'Jochum', 'Johan', 'John', 'Joshua', 'Jóakim', 'Jóann', 'Jóel', 'Jóhann', 'Jóhannes', 'Jói', 'Jómar', 'Jómundur', 'Jón', 'Jónar', 'Jónas', 'Jónatan', 'Jónbjörn', 'Jóndór', 'Jóngeir', 'Jónmundur', 'Jónsteinn', 'Jónþór', 'Jósafat', 'Jósavin', 'Jósef', 'Jósep', 'Jósteinn', 'Jósúa', 'Jóvin', 'Julian', 'Júlí', 'Júlían', 'Júlíus', 'Júní', 'Júníus', 'Júrek', 'Jökull', 'Jörfi', 'Jörgen', 'Jörmundur', 'Jörri', 'Jörundur', 'Jörvar', 'Jörvi', 'Kaj', 'Kakali', 'Kaktus', 'Kaldi', 'Kaleb', 'Kali', 'Kalman', 'Kalmann', 'Kalmar', 'Kaprasíus', 'Karel', 'Karim', 'Karkur', 'Karl', 'Karles', 'Karli', 'Karvel', 'Kaspar', 'Kasper', 'Kastíel', 'Katarínus', 'Kató', 'Kár', 'Kári', 'Keran', 'Ketilbjörn', 'Ketill', 'Kilían', 'Kiljan', 'Kjalar', 'Kjallakur', 'Kjaran', 'Kjartan', 'Kjarval', 'Kjárr', 'Kjói', 'Klemens', 'Klemenz', 'Klængur', 'Knútur', 'Knörr', 'Koðrán', 'Koggi', 'Kolbeinn', 'Kolbjörn', 'Kolfinnur', 'Kolgrímur', 'Kolmar', 'Kolskeggur', 'Kolur', 'Kolviður', 'Konráð', 'Konstantínus', 'Kormákur', 'Kornelíus', 'Kort', 'Kópur', 'Kraki', 'Kris', 'Kristall', 'Kristberg', 'Kristbergur', 'Kristbjörn', 'Kristdór', 'Kristens', 'Krister', 'Kristfinnur', 'Kristgeir', 'Kristian', 'Kristinn', 'Kristján', 'Kristjón', 'Kristlaugur', 'Kristleifur', 'Kristmann', 'Kristmar', 'Kristmundur', 'Kristofer', 'Kristófer', 'Kristvaldur', 'Kristvarður', 'Kristvin', 'Kristþór', 'Krummi', 'Kveldúlfur', 'Lambert', 'Lars', 'Laufar', 'Laugi', 'Lauritz', 'Lár', 'Lárent', 'Lárentíus', 'Lárus', 'Leiðólfur', 'Leif', 'Leifur', 'Leiknir', 'Leo', 'Leon', 'Leonard', 'Leonhard', 'Leó', 'Leópold', 'Leví', 'Lér', 'Liljar', 'Lindar', 'Lindberg', 'Línberg', 'Líni', 'Ljósálfur', 'Ljótur', 'Ljúfur', 'Loðmundur', 'Loftur', 'Logi', 'Loki', 'Lórens', 'Lórenz', 'Ludvig', 'Lundi', 'Lúðvíg', 'Lúðvík', 'Lúkas', 'Lúter', 'Lúther', 'Lyngar', 'Lýður', 'Lýtingur', 'Maggi', 'Magngeir', 'Magni', 'Magnús', 'Magnþór', 'Makan', 'Manfred', 'Manfreð', 'Manúel', 'Mar', 'Marbjörn', 'Marel', 'Margeir', 'Margrímur', 'Mari', 'Marijón', 'Marinó', 'Marías', 'Marínó', 'Marís', 'Maríus', 'Marjón', 'Markó', 'Markús', 'Markþór', 'Maron', 'Marri', 'Mars', 'Marsellíus', 'Marteinn', 'Marten', 'Marthen', 'Martin', 'Marvin', 'Mathías', 'Matthías', 'Matti', 'Mattías', 'Max', 'Maximus', 'Máni', 'Már', 'Márus', 'Mekkinó', 'Melkíor', 'Melkólmur', 'Melrakki', 'Mensalder', 'Merkúr', 'Methúsalem', 'Metúsalem', 'Meyvant', 'Michael', 'Mikael', 'Mikjáll', 'Mikkael', 'Mikkel', 'Mildinberg', 'Mías', 'Mímir', 'Míó', 'Mír', 'Mjöllnir', 'Mjölnir', 'Moli', 'Morgan', 'Moritz', 'Mosi', 'Móði', 'Móri', 'Mórits', 'Móses', 'Muggur', 'Muni', 'Muninn', 'Múli', 'Myrkvi', 'Mýrkjartan', 'Mörður', 'Narfi', 'Natan', 'Natanael', 'Nataníel', 'Náttmörður', 'Náttúlfur', 'Neisti', 'Nenni', 'Neptúnus', 'Nicolas', 'Nikanor', 'Nikolai', 'Nikolas', 'Nikulás', 'Nils', 'Níels', 'Níls', 'Njáll', 'Njörður', 'Nonni', 'Norbert', 'Norðmann', 'Normann', 'Nóam', 'Nóel', 'Nói', 'Nóni', 'Nóri', 'Nóvember', 'Númi', 'Nývarð', 'Nökkvi', 'Oddbergur', 'Oddbjörn', 'Oddfreyr', 'Oddgeir', 'Oddi', 'Oddkell', 'Oddleifur', 'Oddmar', 'Oddsteinn', 'Oddur', 'Oddvar', 'Oddþór', 'Oktavíus', 'Októ', 'Októvíus', 'Olaf', 'Olav', 'Olgeir', 'Oliver', 'Olivert', 'Orfeus', 'Ormar', 'Ormur', 'Orri', 'Orvar', 'Otkell', 'Otri', 'Otti', 'Ottó', 'Otur', 'Óðinn', 'Ófeigur', 'Ólafur', 'Óli', 'Óliver', 'Ólíver', 'Ómar', 'Ómi', 'Óskar', 'Ósvald', 'Ósvaldur', 'Ósvífur', 'Óttar', 'Óttarr', 'Parmes', 'Patrek', 'Patrekur', 'Patrick', 'Patrik', 'Páll', 'Pálmar', 'Pálmi', 'Pedró', 'Per', 'Peter', 'Pétur', 'Pjetur', 'Príor', 'Rafael', 'Rafn', 'Rafnar', 'Rafnkell', 'Ragnar', 'Ragúel', 'Randver', 'Rannver', 'Rasmus', 'Ráðgeir', 'Ráðvarður', 'Refur', 'Reginbaldur', 'Reginn', 'Reidar', 'Reifnir', 'Reimar', 'Reinar', 'Reinhart', 'Reinhold', 'Reynald', 'Reynar', 'Reynir', 'Reyr', 'Richard', 'Rikharð', 'Rikharður', 'Ríkarður', 'Ríkharð', 'Ríkharður', 'Ríó', 'Robert', 'Rolf', 'Ronald', 'Róbert', 'Rólant', 'Róman', 'Rómeó', 'Rósant', 'Rósar', 'Rósberg', 'Rósenberg', 'Rósi', 'Rósinberg', 'Rósinkar', 'Rósinkrans', 'Rósmann', 'Rósmundur', 'Rudolf', 'Runi', 'Runólfur', 'Rúbar', 'Rúben', 'Rúdólf', 'Rúnar', 'Rúrik', 'Rútur', 'Röðull', 'Rögnvald', 'Rögnvaldur', 'Rögnvar', 'Rökkvi', 'Safír', 'Sakarías', 'Salmann', 'Salmar', 'Salómon', 'Salvar', 'Samson', 'Samúel', 'Sandel', 'Sandri', 'Sandur', 'Saxi', 'Sebastian', 'Sebastían', 'Seifur', 'Seimur', 'Sesar', 'Sesil', 'Sigbergur', 'Sigbert', 'Sigbjartur', 'Sigbjörn', 'Sigdór', 'Sigfastur', 'Sigfinnur', 'Sigfreður', 'Sigfús', 'Siggeir', 'Sighvatur', 'Sigjón', 'Siglaugur', 'Sigmann', 'Sigmar', 'Sigmundur', 'Signar', 'Sigri', 'Sigríkur', 'Sigsteinn', 'Sigtryggur', 'Sigtýr', 'Sigur', 'Sigurbaldur', 'Sigurberg', 'Sigurbergur', 'Sigurbjarni', 'Sigurbjartur', 'Sigurbjörn', 'Sigurbrandur', 'Sigurdór', 'Sigurður', 'Sigurfinnur', 'Sigurgeir', 'Sigurgestur', 'Sigurgísli', 'Sigurgrímur', 'Sigurhans', 'Sigurhjörtur', 'Sigurjón', 'Sigurkarl', 'Sigurlaugur', 'Sigurlás', 'Sigurleifur', 'Sigurliði', 'Sigurlinni', 'Sigurmann', 'Sigurmar', 'Sigurmon', 'Sigurmundur', 'Sigurnýas', 'Sigurnýjas', 'Siguroddur', 'Siguróli', 'Sigurpáll', 'Sigursteinn', 'Sigursveinn', 'Sigurvaldi', 'Sigurvin', 'Sigurþór', 'Sigvaldi', 'Sigvarður', 'Sigþór', 'Silli', 'Sindri', 'Símon', 'Sírnir', 'Sírus', 'Sívar', 'Sjafnar', 'Skafti', 'Skapti', 'Skarphéðinn', 'Skefill', 'Skeggi', 'Skíði', 'Skírnir', 'Skjöldur', 'Skorri', 'Skuggi', 'Skúli', 'Skúta', 'Skær', 'Skæringur', 'Smári', 'Smiður', 'Smyrill', 'Snjóki', 'Snjólaugur', 'Snjólfur', 'Snorri', 'Snæbjartur', 'Snæbjörn', 'Snæhólm', 'Snælaugur', 'Snær', 'Snæringur', 'Snævar', 'Snævarr', 'Snæþór', 'Soffanías', 'Sophanías', 'Sophus', 'Sófónías', 'Sófus', 'Sókrates', 'Sólberg', 'Sólbergur', 'Sólbjartur', 'Sólbjörn', 'Sólimann', 'Sólmar', 'Sólmundur', 'Sólon', 'Sólver', 'Sólvin', 'Spartakus', 'Sporði', 'Spói', 'Stanley', 'Stapi', 'Starkaður', 'Starri', 'Stefan', 'Stefán', 'Stefnir', 'Steinar', 'Steinarr', 'Steinberg', 'Steinbergur', 'Steinbjörn', 'Steindór', 'Steinfinnur', 'Steingrímur', 'Steini', 'Steinkell', 'Steinmann', 'Steinmar', 'Steinmóður', 'Steinn', 'Steinólfur', 'Steinröður', 'Steinvarður', 'Steinþór', 'Stirnir', 'Stígur', 'Stormur', 'Stórólfur', 'Sturla', 'Sturlaugur', 'Sturri', 'Styr', 'Styrbjörn', 'Styrkár', 'Styrmir', 'Styrr', 'Sumarliði', 'Svafar', 'Svali', 'Svan', 'Svanberg', 'Svanbergur', 'Svanbjörn', 'Svangeir', 'Svanhólm', 'Svani', 'Svanlaugur', 'Svanmundur', 'Svanur', 'Svanþór', 'Svavar', 'Sváfnir', 'Sveinar', 'Sveinberg', 'Sveinbjartur', 'Sveinbjörn', 'Sveinjón', 'Sveinlaugur', 'Sveinmar', 'Sveinn', 'Sveinungi', 'Sveinþór', 'Svend', 'Sverre', 'Sverrir', 'Svölnir', 'Svörfuður', 'Sýrus', 'Sæberg', 'Sæbergur', 'Sæbjörn', 'Sæi', 'Sælaugur', 'Sæmann', 'Sæmundur', 'Sær', 'Sævald', 'Sævaldur', 'Sævar', 'Sævarr', 'Sævin', 'Sæþór', 'Sölmundur', 'Sölvar', 'Sölvi', 'Sören', 'Sörli', 'Tandri', 'Tarfur', 'Teitur', 'Theodór', 'Theódór', 'Thomas', 'Thor', 'Thorberg', 'Thór', 'Tindar', 'Tindri', 'Tindur', 'Tinni', 'Tími', 'Tímon', 'Tímoteus', 'Tímóteus', 'Tístran', 'Tjaldur', 'Tjörfi', 'Tjörvi', 'Tobías', 'Tolli', 'Tonni', 'Torfi', 'Tóbías', 'Tói', 'Tóki', 'Tómas', 'Tór', 'Trausti', 'Tristan', 'Trostan', 'Trúmann', 'Tryggvi', 'Tumas', 'Tumi', 'Tyrfingur', 'Týr', 'Ubbi', 'Uggi', 'Ulrich', 'Uni', 'Unnar', 'Unnbjörn', 'Unndór', 'Unnsteinn', 'Unnþór', 'Urðar', 'Uxi', 'Úddi', 'Úlfar', 'Úlfgeir', 'Úlfhéðinn', 'Úlfkell', 'Úlfljótur', 'Úlftýr', 'Úlfur', 'Úlrik', 'Úranus', 'Vagn', 'Vakur', 'Valberg', 'Valbergur', 'Valbjörn', 'Valbrandur', 'Valdemar', 'Valdi', 'Valdimar', 'Valdór', 'Valentín', 'Valentínus', 'Valgarð', 'Valgarður', 'Valgeir', 'Valíant', 'Vallaður', 'Valmar', 'Valmundur', 'Valsteinn', 'Valter', 'Valtýr', 'Valur', 'Valves', 'Valþór', 'Varmar', 'Vatnar', 'Váli', 'Vápni', 'Veigar', 'Veigur', 'Ver', 'Vermundur', 'Vernharð', 'Vernharður', 'Vestar', 'Vestmar', 'Veturliði', 'Vébjörn', 'Végeir', 'Vékell', 'Vélaugur', 'Vémundur', 'Vésteinn', 'Victor', 'Viðar', 'Vigfús', 'Viggó', 'Vignir', 'Vigri', 'Vigtýr', 'Vigur', 'Vikar', 'Viktor', 'Vilberg', 'Vilbergur', 'Vilbert', 'Vilbjörn', 'Vilbogi', 'Vilbrandur', 'Vilgeir', 'Vilhelm', 'Vilhjálmur', 'Vili', 'Viljar', 'Vilji', 'Villi', 'Vilmar', 'Vilmundur', 'Vincent', 'Vinjar', 'Virgill', 'Víðar', 'Víðir', 'Vífill', 'Víglundur', 'Vígmar', 'Vígmundur', 'Vígsteinn', 'Vígþór', 'Víkingur', 'Vopni', 'Vorm', 'Vöggur', 'Völundur', 'Vörður', 'Vöttur', 'Walter', 'Werner', 'Wilhelm', 'Willard', 'William', 'Willum', 'Ylur', 'Ymir', 'Yngvar', 'Yngvi', 'Yrkill', 'Ýmir', 'Ýrar', 'Zakaría', 'Zakarías', 'Zophanías', 'Zophonías', 'Zóphanías', 'Zóphonías', 'Þangbrandur', 'Þengill', 'Þeyr', 'Þiðrandi', 'Þiðrik', 'Þinur', 'Þjálfi', 'Þjóðann', 'Þjóðbjörn', 'Þjóðgeir', 'Þjóðleifur', 'Þjóðmar', 'Þjóðólfur', 'Þjóðrekur', 'Þjóðvarður', 'Þjóstar', 'Þjóstólfur', 'Þorberg', 'Þorbergur', 'Þorbjörn', 'Þorbrandur', 'Þorfinnur', 'Þorgarður', 'Þorgautur', 'Þorgeir', 'Þorgestur', 'Þorgils', 'Þorgísl', 'Þorgnýr', 'Þorgrímur', 'Þorkell', 'Þorlaugur', 'Þorlákur', 'Þorleifur', 'Þorleikur', 'Þormar', 'Þormóður', 'Þormundur', 'Þorri', 'Þorsteinn', 'Þorvaldur', 'Þorvar', 'Þorvarður', 'Þór', 'Þórar', 'Þórarinn', 'Þórbergur', 'Þórbjörn', 'Þórður', 'Þórgnýr', 'Þórgrímur', 'Þórhaddur', 'Þórhalli', 'Þórhallur', 'Þórir', 'Þórlaugur', 'Þórleifur', 'Þórlindur', 'Þórmar', 'Þórmundur', 'Þóroddur', 'Þórormur', 'Þórólfur', 'Þórsteinn', 'Þórörn', 'Þrastar', 'Þráinn', 'Þrándur', 'Þróttur', 'Þrúðmar', 'Þrymur', 'Þröstur', 'Þyrnir', 'Ægir', 'Æsir', 'Ævar', 'Ævarr', 'Ögmundur', 'Ögri', 'Ölnir', 'Ölver', 'Ölvir', 'Öndólfur', 'Önundur', 'Örlaugur', 'Örlygur', 'Örn', 'Örnólfur', 'Örvar', 'Össur', 'Öxar'];
+
+ /**
+ * @var string Icelandic middle names.
+ */
+ protected static $middleName = [
+ 'Aðaldal', 'Aldan', 'Arnberg', 'Arnfjörð', 'Austan', 'Austdal', 'Austfjörð', 'Áss', 'Bakkdal', 'Bakkmann', 'Bald', 'Ben', 'Bergholt', 'Bergland', 'Bíldsfells', 'Bjarg', 'Bjarndal', 'Bjarnfjörð', 'Bláfeld', 'Blómkvist', 'Borgdal', 'Brekkmann', 'Brim', 'Brúnsteð', 'Dalhoff', 'Dan', 'Diljan', 'Ektavon', 'Eldberg', 'Elísberg', 'Elvan', 'Espólín', 'Eyhlíð', 'Eyvík', 'Falk', 'Finndal', 'Fossberg', 'Freydal', 'Friðhólm', 'Giljan', 'Gilsfjörð', 'Gnarr', 'Gnurr', 'Grendal', 'Grindvík', 'Gull', 'Haffjörð', 'Hafnes', 'Hafnfjörð', 'Har', 'Heimdal', 'Heimsberg', 'Helgfell', 'Herberg', 'Hildiberg', 'Hjaltdal', 'Hlíðkvist', 'Hnappdal', 'Hnífsdal', 'Hofland', 'Hofteig', 'Hornfjörð', 'Hólmberg', 'Hrafnan', 'Hrafndal', 'Hraunberg', 'Hreinberg', 'Hreindal', 'Hrútfjörð', 'Hvammdal', 'Hvítfeld', 'Höfðdal', 'Hörðdal', 'Íshólm', 'Júl', 'Kjarrval', 'Knaran', 'Knarran', 'Krossdal', 'Laufkvist', 'Laufland', 'Laugdal', 'Laxfoss', 'Liljan', 'Linddal', 'Línberg', 'Ljós', 'Loðmfjörð', 'Lyngberg', 'Magdal', 'Magg', 'Matt', 'Miðdal', 'Miðvík', 'Mjófjörð', 'Móberg', 'Mýrmann', 'Nesmann', 'Norðland', 'Núpdal', 'Ólfjörð', 'Ósland', 'Ósmann', 'Reginbald', 'Reykfell', 'Reykfjörð', 'Reynholt', 'Salberg', 'Sandhólm', 'Seljan', 'Sigurhólm', 'Skagalín', 'Skíðdal', 'Snæberg', 'Snædahl', 'Sólan', 'Stardal', 'Stein', 'Steinbekk', 'Steinberg', 'Storm', 'Straumberg', 'Svanhild', 'Svarfdal', 'Sædal', 'Val', 'Valagils', 'Vald', 'Varmdal', 'Vatnsfjörð', 'Vattar', 'Vattnes', 'Viðfjörð', 'Vídalín', 'Víking', 'Vopnfjörð', 'Yngling', 'Þor', 'Önfjörð', 'Örbekk', 'Öxdal', 'Öxndal'
+ ];
+
+ /**
+ * Randomly return a icelandic middle name.
+ *
+ * @return string
+ */
+ public static function middleName()
+ {
+ return static::randomElement(static::$middleName);
+ }
+
+ /**
+ * Generate prepared last name for further processing
+ *
+ * @return string
+ */
+ public function lastName()
+ {
+ $name = static::firstNameMale();
+
+ if (substr($name, -2) === 'ur') {
+ $name = substr($name, 0, strlen($name) - 2);
+ }
+
+ if (substr($name, -1) !== 's') {
+ $name .= 's';
+ }
+
+ return $name;
+ }
+
+ /**
+ * Randomly return a icelandic last name for woman.
+ *
+ * @return string
+ */
+ public function lastNameMale()
+ {
+ return $this->lastName() . 'son';
+ }
+
+ /**
+ * Randomly return a icelandic last name for man.
+ *
+ * @return string
+ */
+ public function lastNameFemale()
+ {
+ return $this->lastName() . 'dóttir';
+ }
+
+ /**
+ * Randomly return a icelandic Kennitala (Social Security number) format.
+ *
+ * @link http://en.wikipedia.org/wiki/Kennitala
+ *
+ * @return string
+ */
+ public static function ssn()
+ {
+ // random birth date
+ $birthdate = DateTime::dateTimeThisCentury();
+
+ // last four buffer
+ $lastFour = null;
+
+ // security variable reference
+ $ref = '32765432';
+
+ // valid flag
+ $valid = false;
+
+ while (! $valid) {
+ // make two random numbers
+ $rand = static::randomDigit() . static::randomDigit();
+
+ // 8 char string with birth date and two random numbers
+ $tmp = $birthdate->format('dmy') . $rand;
+
+ // loop through temp string
+ for ($i = 7, $sum = 0; $i >= 0; $i--) {
+ // calculate security variable
+ $sum += ($tmp[$i] * $ref[$i]);
+ }
+
+ // subtract 11 if not 11
+ $chk = ($sum % 11 === 0) ? 0 : (11 - ($sum % 11));
+
+ if ($chk < 10) {
+ $lastFour = $rand . $chk . substr($birthdate->format('Y'), 1, 1);
+
+ $valid = true;
+ }
+ }
+
+ return sprintf('%s-%s', $birthdate->format('dmy'), $lastFour);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/is_IS/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/is_IS/PhoneNumber.php
new file mode 100644
index 00000000..a6f84499
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/is_IS/PhoneNumber.php
@@ -0,0 +1,20 @@
+
+ */
+class PhoneNumber extends \Faker\Provider\PhoneNumber
+{
+ /**
+ * @var array Icelandic phone number formats.
+ */
+ protected static $formats = [
+ '+354 ### ####',
+ '+354 #######',
+ '+354#######',
+ '### ####',
+ '#######',
+ ];
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/it_CH/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/it_CH/Address.php
new file mode 100644
index 00000000..09d90de8
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/it_CH/Address.php
@@ -0,0 +1,139 @@
+ 'Argovia'],
+ ['AI' => 'Appenzello Interno'],
+ ['AR' => 'Appenzello Esterno'],
+ ['BE' => 'Berna'],
+ ['BL' => 'Basilea Campagna'],
+ ['BS' => 'Basilea Città'],
+ ['FR' => 'Friburgo'],
+ ['GE' => 'Ginevra'],
+ ['GL' => 'Glarona'],
+ ['GR' => 'Grigioni'],
+ ['JU' => 'Giura'],
+ ['LU' => 'Lucerna'],
+ ['NE' => 'Neuchâtel'],
+ ['NW' => 'Nidvaldo'],
+ ['OW' => 'Obvaldo'],
+ ['SG' => 'San Gallo'],
+ ['SH' => 'Sciaffusa'],
+ ['SO' => 'Soletta'],
+ ['SZ' => 'Svitto'],
+ ['TG' => 'Turgovia'],
+ ['TI' => 'Ticino'],
+ ['UR' => 'Uri'],
+ ['VD' => 'Vaud'],
+ ['VS' => 'Vallese'],
+ ['ZG' => 'Zugo'],
+ ['ZH' => 'Zurigo']
+ ];
+
+ protected static $cityFormats = [
+ '{{cityName}}',
+ ];
+
+ protected static $streetNameFormats = [
+ '{{streetSuffix}} {{firstName}}',
+ '{{streetSuffix}} {{lastName}}'
+ ];
+
+ protected static $streetAddressFormats = [
+ '{{streetName}} {{buildingNumber}}',
+ ];
+ protected static $addressFormats = [
+ "{{streetAddress}}\n{{postcode}} {{city}}",
+ ];
+
+ /**
+ * Returns a random street prefix
+ * @example Via
+ * @return string
+ */
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ /**
+ * Returns a random city name.
+ * @example Luzern
+ * @return string
+ */
+ public function cityName()
+ {
+ return static::randomElement(static::$cityNames);
+ }
+
+ /**
+ * Returns a canton
+ * @example array('BE' => 'Bern')
+ * @return array
+ */
+ public static function canton()
+ {
+ return static::randomElement(static::$canton);
+ }
+
+ /**
+ * Returns the abbreviation of a canton.
+ * @return string
+ */
+ public static function cantonShort()
+ {
+ $canton = static::canton();
+ return key($canton);
+ }
+
+ /**
+ * Returns the name of canton.
+ * @return string
+ */
+ public static function cantonName()
+ {
+ $canton = static::canton();
+ return current($canton);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/it_CH/Company.php b/vendor/fakerphp/faker/src/Faker/Provider/it_CH/Company.php
new file mode 100644
index 00000000..bb5f9460
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/it_CH/Company.php
@@ -0,0 +1,15 @@
+generator->parse($format);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ja_JP/Company.php b/vendor/fakerphp/faker/src/Faker/Provider/ja_JP/Company.php
new file mode 100644
index 00000000..25e8aa93
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ja_JP/Company.php
@@ -0,0 +1,17 @@
+generator->parse($format));
+ }
+
+ /**
+ * @example 'yamada.jp'
+ */
+ public function domainName()
+ {
+ return static::randomElement(static::$lastNameAscii) . '.' . $this->tld();
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ja_JP/Person.php b/vendor/fakerphp/faker/src/Faker/Provider/ja_JP/Person.php
new file mode 100644
index 00000000..8b44e3eb
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ja_JP/Person.php
@@ -0,0 +1,141 @@
+generator->parse($format);
+ }
+
+ /**
+ * @param string|null $gender 'male', 'female' or null for any
+ * @return string
+ * @example 'アキラ'
+ */
+ public function firstKanaName($gender = null)
+ {
+ if ($gender === static::GENDER_MALE) {
+ return static::firstKanaNameMale();
+ } elseif ($gender === static::GENDER_FEMALE) {
+ return static::firstKanaNameFemale();
+ }
+
+ return $this->generator->parse(static::randomElement(static::$firstKanaNameFormat));
+ }
+
+ /**
+ * @example 'アキラ'
+ */
+ public static function firstKanaNameMale()
+ {
+ return static::randomElement(static::$firstKanaNameMale);
+ }
+
+ /**
+ * @example 'アケミ'
+ */
+ public static function firstKanaNameFemale()
+ {
+ return static::randomElement(static::$firstKanaNameFemale);
+ }
+
+ /**
+ * @example 'アオタ'
+ */
+ public static function lastKanaName()
+ {
+ return static::randomElement(static::$lastKanaName);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ja_JP/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/ja_JP/PhoneNumber.php
new file mode 100644
index 00000000..aa2cbc41
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ja_JP/PhoneNumber.php
@@ -0,0 +1,19 @@
+generator->parse($format);
+ }
+
+ public static function companyPrefix()
+ {
+ return static::randomElement(static::$companyPrefixes);
+ }
+
+ public static function companyNameElement()
+ {
+ return static::randomElement(static::$companyElements);
+ }
+
+ public static function companyNameSuffix()
+ {
+ return static::randomElement(static::$companyNameSuffixes);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ka_GE/DateTime.php b/vendor/fakerphp/faker/src/Faker/Provider/ka_GE/DateTime.php
new file mode 100644
index 00000000..ad25c26d
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ka_GE/DateTime.php
@@ -0,0 +1,41 @@
+ 'კვირა',
+ 'Monday' => 'ორშაბათი',
+ 'Tuesday' => 'სამშაბათი',
+ 'Wednesday' => 'ოთხშაბათი',
+ 'Thursday' => 'ხუთშაბათი',
+ 'Friday' => 'პარასკევი',
+ 'Saturday' => 'შაბათი',
+ ];
+ $week = static::dateTime($max)->format('l');
+ return $map[$week] ?? $week;
+ }
+
+ public static function monthName($max = 'now')
+ {
+ $map = [
+ 'January' => 'იანვარი',
+ 'February' => 'თებერვალი',
+ 'March' => 'მარტი',
+ 'April' => 'აპრილი',
+ 'May' => 'მაისი',
+ 'June' => 'ივნისი',
+ 'July' => 'ივლისი',
+ 'August' => 'აგვისტო',
+ 'September' => 'სექტემბერი',
+ 'October' => 'ოქტომბერი',
+ 'November' => 'ნოემბერი',
+ 'December' => 'დეკემბერი',
+ ];
+ $month = static::dateTime($max)->format('F');
+ return $map[$month] ?? $month;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ka_GE/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/ka_GE/Internet.php
new file mode 100644
index 00000000..97dd4835
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ka_GE/Internet.php
@@ -0,0 +1,15 @@
+generator->parse($format);
+ }
+
+ public static function companyPrefix()
+ {
+ return static::randomElement(static::$companyPrefixes);
+ }
+
+ public static function companyNameElement()
+ {
+ return static::randomElement(static::$companyElements);
+ }
+
+ public static function companyNameSuffix()
+ {
+ return static::randomElement(static::$companyNameSuffixes);
+ }
+
+ /**
+ * National Business Identification Numbers
+ *
+ * @link http://egov.kz/wps/portal/Content?contentPath=%2Fegovcontent%2Fbus_business%2Ffor_businessmen%2Farticle%2Fbusiness_identification_number&lang=en
+ * @param \DateTime $registrationDate
+ * @return string 12 digits, like 150140000019
+ */
+ public static function businessIdentificationNumber(\DateTime $registrationDate = null)
+ {
+ if (!$registrationDate) {
+ $registrationDate = \Faker\Provider\DateTime::dateTimeThisYear();
+ }
+
+ $dateAsString = $registrationDate->format('ym');
+ $legalEntityType = (string) self::numberBetween(4, 6);
+ $legalEntityAdditionalType = (string) self::numberBetween(0, 3);
+ $randomDigits = (string) static::numerify('######');
+
+ return $dateAsString . $legalEntityType . $legalEntityAdditionalType . $randomDigits;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/kk_KZ/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/kk_KZ/Internet.php
new file mode 100644
index 00000000..0328da09
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/kk_KZ/Internet.php
@@ -0,0 +1,9 @@
+ [
+ self::CENTURY_19TH => self::MALE_CENTURY_19TH,
+ self::CENTURY_20TH => self::MALE_CENTURY_20TH,
+ self::CENTURY_21ST => self::MALE_CENTURY_21ST,
+ ],
+ self::GENDER_FEMALE => [
+ self::CENTURY_19TH => self::FEMALE_CENTURY_19TH,
+ self::CENTURY_20TH => self::FEMALE_CENTURY_20TH,
+ self::CENTURY_21ST => self::FEMALE_CENTURY_21ST,
+ ],
+ ];
+
+ /**
+ * @see https://ru.wikipedia.org/wiki/%D0%9A%D0%B0%D0%B7%D0%B0%D1%85%D1%81%D0%BA%D0%B0%D1%8F_%D1%84%D0%B0%D0%BC%D0%B8%D0%BB%D0%B8%D1%8F
+ *
+ * @var array
+ */
+ protected static $maleNameFormats = [
+ '{{lastName}}ұлы {{firstNameMale}}',
+ ];
+
+ /**
+ * @see https://ru.wikipedia.org/wiki/%D0%9A%D0%B0%D0%B7%D0%B0%D1%85%D1%81%D0%BA%D0%B0%D1%8F_%D1%84%D0%B0%D0%BC%D0%B8%D0%BB%D0%B8%D1%8F
+ *
+ * @var array
+ */
+ protected static $femaleNameFormats = [
+ '{{lastName}}қызы {{firstNameFemale}}',
+ ];
+
+ /**
+ * @see http://koshpendi.kz/index.php/nomad/imena/
+ *
+ * @var array
+ */
+ protected static $firstNameMale = [
+ 'Аылғазы',
+ 'Әбдіқадыр',
+ 'Бабағожа',
+ 'Ғайса',
+ 'Дәмен',
+ 'Егізбек',
+ 'Жазылбек',
+ 'Зұлпықар',
+ 'Игісін',
+ 'Кәдіржан',
+ 'Қадырқан',
+ 'Латиф',
+ 'Мағаз',
+ 'Нармағамбет',
+ 'Оңалбай',
+ 'Өндіріс',
+ 'Пердебек',
+ 'Рақат',
+ 'Сағындық',
+ 'Танабай',
+ 'Уайыс',
+ 'Ұйықбай',
+ 'Үрімбай',
+ 'Файзрахман',
+ 'Хангелді',
+ 'Шаттық',
+ 'Ыстамбақы',
+ 'Ібни',
+ ];
+
+ /**
+ * @see http://koshpendi.kz/index.php/nomad/imena/
+ *
+ * @var array
+ */
+ protected static $firstNameFemale = [
+ 'Асылтас',
+ 'Әужа',
+ 'Бүлдіршін',
+ 'Гүлшаш',
+ 'Ғафура',
+ 'Ділдә',
+ 'Еркежан',
+ 'Жібек',
+ 'Зылиқа',
+ 'Ирада',
+ 'Күнсұлу',
+ 'Қырмызы',
+ 'Ләтипа',
+ 'Мүштәри',
+ 'Нұршара',
+ 'Орынша',
+ 'Өрзия',
+ 'Перизат',
+ 'Рухия',
+ 'Сындыбала',
+ 'Тұрсынай',
+ 'Уәсима',
+ 'Ұрқия',
+ 'Үрия',
+ 'Фируза',
+ 'Хафиза',
+ 'Шырынгүл',
+ 'Ырысты',
+ 'Іңкәр',
+ ];
+
+ /**
+ * @see http://koshpendi.kz/index.php/nomad/imena/
+ * @see https://ru.wikipedia.org/wiki/%D0%9A%D0%B0%D0%B7%D0%B0%D1%85%D1%81%D0%BA%D0%B0%D1%8F_%D1%84%D0%B0%D0%BC%D0%B8%D0%BB%D0%B8%D1%8F
+ *
+ * @var array
+ */
+ protected static $lastName = [
+ 'Адырбай',
+ 'Әжібай',
+ 'Байбөрі',
+ 'Ғизат',
+ 'Ділдабек',
+ 'Ешмұхамбет',
+ 'Жігер',
+ 'Зікірия',
+ 'Иса',
+ 'Кунту',
+ 'Қыдыр',
+ 'Лұқпан',
+ 'Мышырбай',
+ 'Нысынбай',
+ 'Ошақбай',
+ 'Өтетілеу',
+ 'Пірәлі',
+ 'Рүстем',
+ 'Сырмұхамбет',
+ 'Тілеміс',
+ 'Уәлі',
+ 'Ұлықбек',
+ 'Үстем',
+ 'Фахир',
+ 'Хұсайын',
+ 'Шілдебай',
+ 'Ыстамбақы',
+ 'Ісмет',
+ ];
+
+ /**
+ * @param int $year
+ *
+ * @return int|null
+ */
+ private static function getCenturyByYear($year)
+ {
+ if ($year >= 2000 && $year <= DateTime::year()) {
+ return self::CENTURY_21ST;
+ } elseif ($year >= 1900) {
+ return self::CENTURY_20TH;
+ } elseif ($year >= 1800) {
+ return self::CENTURY_19TH;
+ }
+
+ return null;
+ }
+
+ /**
+ * National Individual Identification Numbers
+ *
+ * @link http://egov.kz/wps/portal/Content?contentPath=%2Fegovcontent%2Fcitizen_migration%2Fpassport_id_card%2Farticle%2Fiin_info&lang=en
+ * @link https://ru.wikipedia.org/wiki/%D0%98%D0%BD%D0%B4%D0%B8%D0%B2%D0%B8%D0%B4%D1%83%D0%B0%D0%BB%D1%8C%D0%BD%D1%8B%D0%B9_%D0%B8%D0%B4%D0%B5%D0%BD%D1%82%D0%B8%D1%84%D0%B8%D0%BA%D0%B0%D1%86%D0%B8%D0%BE%D0%BD%D0%BD%D1%8B%D0%B9_%D0%BD%D0%BE%D0%BC%D0%B5%D1%80
+ *
+ * @param \DateTime $birthDate
+ * @param int $gender
+ *
+ * @return string 12 digits, like 780322300455
+ */
+ public static function individualIdentificationNumber(\DateTime $birthDate = null, $gender = self::GENDER_MALE)
+ {
+ if (!$birthDate) {
+ $birthDate = DateTime::dateTimeBetween();
+ }
+
+ do {
+ $population = self::numberBetween(1000, 2000);
+ $century = self::getCenturyByYear((int) $birthDate->format('Y'));
+
+ $iin = $birthDate->format('ymd');
+ $iin .= (string) self::$genderCenturyMap[$gender][$century];
+ $iin .= (string) $population;
+ $checksum = self::checkSum($iin);
+ } while ($checksum === 10);
+
+ return $iin . (string) $checksum;
+ }
+
+ /**
+ * @param string $iinValue
+ *
+ * @return int
+ */
+ public static function checkSum($iinValue)
+ {
+ $controlDigit = self::getControlDigit($iinValue, self::$firstSequenceBitWeights);
+
+ if ($controlDigit === 10) {
+ return self::getControlDigit($iinValue, self::$secondSequenceBitWeights);
+ }
+
+ return $controlDigit;
+ }
+
+ /**
+ * @param string $iinValue
+ * @param array $sequence
+ *
+ * @return int
+ */
+ protected static function getControlDigit($iinValue, $sequence)
+ {
+ $sum = 0;
+
+ for ($i = 0; $i <= 10; $i++) {
+ $sum += (int) $iinValue[$i] * $sequence[$i];
+ }
+
+ return $sum % 11;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/kk_KZ/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/kk_KZ/PhoneNumber.php
new file mode 100644
index 00000000..c5d6440d
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/kk_KZ/PhoneNumber.php
@@ -0,0 +1,16 @@
+generator->parse($format));
+ }
+
+ /**
+ * @example 'kim.kr'
+ */
+ public function domainName()
+ {
+ return static::randomElement(static::$lastNameAscii) . '.' . $this->tld();
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ko_KR/Person.php b/vendor/fakerphp/faker/src/Faker/Provider/ko_KR/Person.php
new file mode 100644
index 00000000..78c6ecd2
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ko_KR/Person.php
@@ -0,0 +1,55 @@
+generator->parse($format));
+ }
+
+
+
+ public function cellPhoneNumber()
+ {
+ $format = self::randomElement(array_slice(static::$formats, 6, 1));
+
+ return self::numerify($this->generator->parse($format));
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ko_KR/Text.php b/vendor/fakerphp/faker/src/Faker/Provider/ko_KR/Text.php
new file mode 100644
index 00000000..5f5148e5
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ko_KR/Text.php
@@ -0,0 +1,1723 @@
+에 나오는 요귀의 불빛 모양으로 푸르무레 하게 허공을 비추오. 동경의 불바다는 내 마음을 더욱 음침하게 하였소.
+이 때에 뒤에서,
+"모시모시(여보세요)."
+하는 소리가 들렸소. 그것은 흰 저고리를 입은 호텔 보이였소.
+"왜?"
+하고 나는 고개만 돌렸소.
+"손님이 오셨습니다."
+"손님?"
+하고 나는 보이에게로 한 걸음 가까이 갔소. 나를 찾을 손님이 어디 있나 하고 나는 놀란 것이오.
+"따님께서 오셨습니다. 방으로 모셨습니다."
+하고 보이는 들어가 버리고 말았소.
+"따님?"
+하고 나는 더욱 놀랐소. 순임이가 서울서 나를 따라왔나? 그것은 안 될 말이오. 순임이가 내 뒤를 따라 떠났더라도 아무리 빨리 와도 내일이 아니면 못 왔을 것이오. 그러면 누군가. 정임인가. 정임이가 병원에서 뛰어온 것인가.
+나는 두근거리는 가슴을 억지로 진정하면서 내 방문을 열었소.
+그것은 정임이었소. 정임은 내가 쓰다가 둔 편지를 보고 있다가 벌떡 일어나 내게 달려들어 안겨 버렸소. 나는 얼빠진 듯이 정임이가 하라는 대로 내버려두었소. 그 편지는 부치려고 쓴 것도 아닌데 그 편지를 정임이가 본 것이 안되었다고 생각하였소.
+형! 나를 책망하시오. 심히 부끄러운 말이지마는 나는 정임을 힘껏 껴안아 주고 싶었소. 나는 몇 번이나 정임의 등을 굽어 보면서 내 팔에 힘을 넣으려고 하였소. 정임은 심히 귀여웠소. 정임이가 그처럼 나를 사모하는 것이 심히 기뻤소. 나는 감정이 재우쳐서 눈이 안 보이고 정신이 몽롱하여짐을 깨달았소. 나는 아프고 쓰린 듯한 기쁨을 깨달았소. 영어로 엑스터시라든지, 한문으로 무아의 경지란 이런 것이 아닌가 하였소. 나는 사십 평생에 이러한 경험을 처음 한 것이오.
+형! 형이 아시다시피 나는 내 아내 이외에 젊은 여성에게 이렇게 안겨 본 일이 없소. 물론 안아 본 일도 없소.
+그러나 형! 나는 나를 눌렀소. 내 타오르는 애욕을 차디찬 이지의 입김으로 불어서 끄려고 애를 썼소.
+"글쎄 웬일이냐. 앓는 것이 이 밤중에 비를 맞고 왜 나온단 말이냐. 철없는 것 같으니."
+하고 나는 아버지의 위엄으로 정임의 두 어깨를 붙들어 암체어에 앉혔소. 그리고 나도 테이블을 하나 세워 두고 맞은편에 앉았소.
+정임은 부끄러운 듯이 두 손으로 낯을 가리우고 제 무릎에 엎드려 울기를 시작하오.
+정임은 누런 갈색의 외투를 입었소. 무엇을 타고 왔는지 모르지마는 구두에는 꽤 많이 물이 묻고 모자에는 빗방울 얼룩이 보이오.
+"네가 이러다가 다시 병이 더치면 어찌한단 말이냐. 아이가 왜 그렇게 철이 없니?"
+하고 나는 더욱 냉정한 어조로 책망하고 데스크 위에 놓인 내 편지 초를 집어 박박 찢어 버렸소. 종이 찢는 소리에 정임은 잠깐 고개를 들어서 처음에는 내 손을 보고 다음에는 내 얼굴을 보았소. 그러나 나는 모르는 체하고 도로 교의에 돌아와 앉아서 가만히 눈을 감았소. 그리고 도무지 흥분되지 아니한 모양을 꾸몄소.
+형! 어떻게나 힘드는 일이오? 참으면 참을수록 내 이빨이 마주 부딪고, 얼굴의 근육은 씰룩거리고 손은 불끈불끈 쥐어지오.
+"정말 내일 가세요?"
+하고 아마 오 분 동안이나 침묵을 지키다가 정임이가 고개를 들고 물었소.
+"그럼, 가야지."
+하고 나는 빙그레 웃어 보였소.
+"저도 데리고 가세요!"
+하는 정임의 말은 마치 서릿발이 날리는 칼날과 같았소. 나는 깜짝 놀라서 정임을 바라보았소. 그의 눈은 빛나고 입은 꼭 다물고 얼굴의 근육은 팽팽하게 켕겼소. 정임의 얼굴에는 찬바람이 도는 무서운 기운이 있었소.
+나는 즉각적으로 죽기를 결심한 여자의 모양이라고 생각하였소. 열정으로 불덩어리가 되었던 정임은 내가 보이는 냉랭한 태도로 말미암아 갑자기 얼어 버린 것 같았소.
+"어디를?"
+하고 나는 정임의 `저도 데리고 가세요.' 하는 담대한 말에 놀라면서 물었소.
+"어디든지, 아버지 가시는 데면 어디든지 저를 데리고 가세요. 저는 아버지를 떠나서는 혼자서는 못 살 것을 지나간 반 달 동안에 잘 알았습니다. 아까 아버지 오셨다 가신 뒤에 생각해 보니깐 암만해도 아버지는 다시 저에게 와 보시지 아니하고 가실 것만 같애요. 그리고 저로 해서 아버지께서는 무슨 큰 타격을 당하신 것만 같으셔요. 처음 뵈올 적에 벌써 가슴이 뜨끔했습니다. 그리고 여행을 떠나신다는 말씀을 듣고는 반드시 무슨 큰일이 나셨느니라고만 생각했습니다. 그리고 저어, 저로 해서 그러신 것만 같고, 저를 버리시고 혼자 가시려는 것만 같고, 그래서 달려왔더니 여기 써 놓으신 편지를 보고 그 편지에 다른 말씀은 어찌 됐든지, 네 일기를 보았다 하신 말씀을 보고는 다 알았습니다. 저와 한 방에 있는 애가 암만해도 어머니 스파인가봐요. 제가 입원하기 전에도 제 눈치를 슬슬 보고 또 책상 서랍도 뒤지는 눈치가 보이길래 일기책은 늘 쇠 잠그는 서랍에 넣어 두었는데 아마 제가 정신 없이 앓고 누웠는 동안에 제 핸드백에서 쇳대를 훔쳐 갔던가봐요. 그래서는 그 일기책을 꺼내서 서울로 보냈나봐요. 그걸루 해서 아버지께서는 불명예스러운 누명을 쓰시고 학교일도 내놓으시게 되고 집도 떠나시게 되셨나봐요. 다시는 집에 안 돌아오실 양으로 결심을 하셨나봐요. 아까 병원에서도 하시는 말씀이 모두 유언하시는 것만 같아서 퍽 의심을 가졌었는데 지금 그 쓰시던 편지를 보고는 다 알았습니다. 그렇지만 그렇지만."
+하고 웅변으로 내려 말하던 정임은 갑자기 복받치는 열정을 이기지 못하는 듯이, 한 번 한숨을 지우고,
+"그렇지만 저는 아버지를 따라가요. 절루 해서 아버지께서는 집도 잃으시고 명예도 잃으시고 사업도 잃으시고 인생의 모든 것을 다 잃으셨으니 저는 아버지를 따라가요. 어디를 가시든지 저는 어린 딸로 아버지를 따라다니다가 아버지께서 먼저 돌아가시면 저도 따라 죽어서 아버지 발 밑에 묻힐 테야요. 제가 먼저 죽거든 제가 병이 있으니깐 물론 제가 먼저 죽지요. 죽어도 좋습니다. 병원에서 앓다가 혼자 죽는 건 싫어요. 아버지 곁에서 죽으면 아버지께서, 오 내 딸 정임아 하시고 귀해 주시고 불쌍히 여겨 주시겠지요. 그리고 제 몸을 어디든지 땅에 묻으시고 `사랑하는 내 딸 정임의 무덤'이라고 패라도 손수 쓰셔서 세워 주시지 않겠습니까."
+하고 정임은 비쭉비쭉하다가 그만 무릎 위에 엎더져 울고 마오.
+나는 다만 죽은 사람 모양으로 반쯤 눈을 감고 앉아 있었소. 가슴 속에는 정임의 곁에서 지지 않는 열정을 품으면서도 정임의 말대로 정임을 데리고 아무도 모르는 곳으로 가 버리고 싶으면서도 나는 이 열정의 불길을 내 입김으로 꺼 버리지 아니하면 아니 되는 것이었소.
+"아아, 제가 왜 났어요? 왜 하나님께서 저를 세상에 보내셨어요? 아버지의 일생을 파멸시키려 난 것이지요? 제가 지금 죽어 버려서 아버지의 명예를 회복할 수 있다면 저는 죽어 버릴 터이야요. 기쁘게 죽어 버리겠습니다. 제가 여덟 살부터 오늘날까지 받은 은혜를 제 목숨 하나로 갚을 수가 있다면 저는 지금으로 죽어 버리겠습니다. 그렇지만 그렇지만…….
+그렇지만 그렇지만 저는 다만 얼마라도 다만 하루라도 아버지 곁에서 살고 싶어요 다만 하루만이라도, 아버지! 제가 왜 이렇습니까, 네? 제가 어려서 이렇습니까. 미친 년이 되어서 이렇습니까. 아버지께서는 아실 테니 말씀해 주세요. 하루만이라도 아버지를 모시고 아버지 곁에서 살았으면 죽어도 한이 없겠습니다. 제 생각이 잘못이야요? 제 생각이 죄야요? 왜 죄입니까? 아버지, 저를 버리시고 혼자 가시지 마세요, 네? `정임아, 너를 데리고 가마.' 하고 약속해 주세요, 네."
+정임은 아주 담대하게 제가 하고자 하는 말을 다 하오. 그 얌전한, 수삽한정임의 속에 어디 그러한 용기가 있었던가, 참 이상한 일이오. 나는 귀여운 어린 계집애 정임의 속에 엉큼한 여자가 들어앉은 것을 발견하였소. 그가 몇 가지 재료(내가 여행을 떠난다는 것과 제 일기를 보았다는 것)를 종합하여 나와 저와의 새에, 또 그 때문에 어떠한 일이 일어난 것을 추측하는 그 상상력도 놀랍거니와 그렇게 내 앞에서는 별로 입도 벌리지 아니하던 그가 이처럼 담대하게 제 속에 있는 말을 거리낌없이 다 해 버리는 용기를 아니 놀랄 수 없었소. 내가, 사내요 어른인 내가 도리어 정임에게 리드를 받고 놀림을 받음을 깨달았소.
+그러나 정임을 위해서든지, 중년 남자의 위신을 위해서든지 나는 의지력으로, 도덕력으로, 정임을 누르고 훈계하지 아니하면 아니 되겠다고 생각하였소.
+"정임아."
+하고 나는 비로소 입을 열어서 불렀소. 내 어성은 장중하였소. 나는 할 수 있는 위엄을 다하여 `정임아.' 하고 부른 것이오.
+"정임아, 네 속은 다 알았다. 네 마음 네 뜻은 그만하면 다 알았다. 네가 나를 그처럼 생각해 주는 것을 고맙게 생각한다. 기쁘게도 생각한다. 그러나 정임아."
+하고 나는 일층 태도와 소리를 엄숙하게 하여,
+"네가 청하는 말은 절대로 들을 수 없는 말이다. 내가 너를 친딸같이 사랑하기 때문에 나는 너를 데리고 가지 못하는 것이다. 나는 세상에서 죽고 조선에서 죽더라도 너는 죽어서 아니 된다. 차마 너까지는 죽이고 싶지 아니하단 말이다. 내가 어디 가서 없어져 버리면 세상은 네게 씌운 누명이 애매한 줄을 알게 될 것이 아니냐. 그리되면 너는 조선의 좋은 일꾼이 되어서 일도 많이 하고 또 사랑하는 남편을 맞아서 행복된 생활도 할 수 있을 것이 아니냐. 그것이 내가 네게 바라는 것이다. 내가 어디 가 있든지, 내가 살아 있는 동안 나는 네가 잘되는 것만, 행복되게 사는 것만 바라보고 혼자 기뻐할 것이 아니냐.
+네가 다 옳게 알았다. 나는 네 말대로 조선을 영원히 떠나기로 하였다. 그렇지마는 나는 이렇게 된 것을 조금도 슬퍼하지 아니한다. 너를 위해서 내가 무슨 희생을 한다고 하면 내게는 그것이 큰 기쁨이다. 그뿐 아니라, 나는 인제는 세상이 싫어졌다. 더 살기가 싫어졌다. 내가 십여 년 동안 전생명을 바쳐서 교육한 학생들에게까지 배척을 받을 때에는 나는 지금까지 살아온 것을 생각만 하여도 진저리가 난다. 그렇지마는 나는 이것이 다 내가 부족한 때문인 줄을 잘 안다. 나는 조선을 원망한다든가, 내 동포를 원망한다든가, 그럴 생각은 없다. 원망을 한다면 나 자신의 부족을 원망할 뿐이다. 내가 원체 교육을 한다든지 남의 지도자가 된다든지 할 자격이 없음을 원망한다면 원망할까, 내가 어떻게 조선이나 조선 사람을 원망하느냐. 그러니까 인제 내게 남은 일은 나를 조선에서 없애 버리는 것이다. 감히 십여 년 간 교육가라고 자처해 오던 거짓되고 외람된 생활을 끊어 버리는 것이다. 남편 노릇도 못 하고 아버지 노릇도 못 하는 사람이 남의 스승은 어떻게 되고 지도자는 어떻게 되느냐. 하니까 나는 이제 세상을 떠나 버리는 것이 조금도 슬프지 아니하고 도리어 몸이 가뜬하고 유쾌해지는 것 같다.
+오직 하나 마음에 걸리는 것은 내 선배요 사랑하는 동지이던 남 선생의 유일한 혈육이던 네게다가 누명을 씌우고 가는 것이다."
+"그게 어디 아버지 잘못입니까?"
+하고 정임은 입술을 깨물었소.
+"모두 제가 철이 없어서 저 때문에……."
+하고 정임은 몸을 떨고 울었소.
+"아니! 그렇게 생각하지 마라. 내가 지금 세상을 버릴 때에 무슨 기쁨이 한 가지 남는 것이 있다고 하면 너 하나가, 이 세상에서 오직 너 하나가 나를 따라 주는 것이다. 아마 너도 나를 잘못 알고 따라 주는 것이겠지마는 세상이 다 나를 버리고, 처자까지도 다 나를 버릴 때에 오직 너 하나가 나를 소중히 알아 주니 어찌 고맙지 않겠느냐. 그러니까 정임아 너는 몸을 조심하여서 건강을 회복하여서 오래 잘 살고, 그리고 나를 생각해 다오."
+하고 나도 울었소.
+형! 내가 정임에게 이런 말을 한 것이 잘못이지요. 그러나 나는 그 때에 이런 말을 아니 할 수 없었소. 왜 그런고 하니, 그것이 내 진정이니까. 나도 학교 선생으로, 교장으로, 또 주제넘게 지사로의 일생을 보내노라고 마치 오직 얼음 같은 의지력만 가진 사람 모양으로 사십 평생을 살아 왔지마는 내 속에도 열정은 있었던 것이오. 다만 그 열정을 누르고 죽이고 있었을 뿐이오. 물론 나는 아마 일생에 이 열정의 고삐를 놓아 줄 날이 없겠지요. 만일 내가 이 열정의 고삐를 놓아서 자유로 달리게 한다고 하면 나는 이 경우에 정임을 안고, 내 열정으로 정임을 태워 버렸을는지도 모르오. 그러나 나는 정임이가 열정으로 탈수록 나는 내 열정의 고삐를 두 손으로 꽉 붙들고 이를 악물고 매달릴 결심을 한 것이오.
+열한 시!
+"정임아. 인제 병원으로 가거라."
+하고 나는 엄연하게 명령하였소.
+"내일 저를 보시고 떠나시지요?"
+하고 정임은 눈물을 씻고 물었소.
+"그럼, J조교수도 만나고 너도 보고 떠나지."
+하고 나는 거짓말을 하였소. 이 경우에 내가 거짓말쟁이라는 큰 죄인이 되는 것이 정임에게 대하여 정임을 위하여 가장 옳은 일이라고 생각한 까닭이오.
+정임은, 무서운 직각력과 상상력을 가진 정임은 내 말의 진실성을 의심하는 듯이 나를 뚫어지게 바라보았소. 나는 차마 정임의 시선을 마주 보지 못하여 외면하여 버렸소.
+정임은 수건으로 눈물을 씻고 체경 앞에 가서 화장을 고치고 그리고,
+"저는 가요."
+하고 내 앞에 허리를 굽혀서 작별 인사를 하였소.
+"오, 가 자거라."
+하고 나는 극히 범연하게 대답하였소. 나는 자리옷을 입었기 때문에 현관까지 작별할 수도 없어서 보이를 불러 자동차를 하나 준비하라고 명하고 내 방에서 작별할 생각을 하였소.
+"내일 병원에 오세요?"
+하고 정임은 고개를 숙이고 낙루하였소.
+"오, 가마."
+하고 나는 또 거짓말을 하였소. 세상을 버리기로 결심한 사람의 거짓말은 하나님께서도 용서하시겠지요. 설사 내가 거짓말을 한 죄로 지옥에 간다 하더라도 이 경우에 정임을 위하여 거짓말을 아니 할 수가 없지 않소? 내가 거짓말을 아니 하면 정임은 아니 갈 것이 분명하였소.
+"전 가요."
+하고 정임은 또 한 번 절을 하였으나 소리를 내어서 울었소.
+"울지 마라! 몸 상한다."
+하고 나는 정임에게 대한 최후의 친절을 정임의 곁에 한 걸음 가까이 가서 어깨를 또닥또닥하여 주고, 외투를 입혀 주었소.
+"안녕히 주무세요."
+하고 정임은 문을 열고 나가 버렸소.
+정임의 걸어가는 소리가 차차 멀어졌소.
+나는 얼빠진 사람 모양으로 그 자리에 우두커니 서 있었소.
+창에 부딪히는 빗발 소리가 들리고 자동차 소리가 먼 나라에서 오는 것같이 들리오. 이것이 정임이가 타고 가는 자동차 소리인가. 나는 정임을 따라가서 붙들어 오고 싶었소. 내 몸과 마음은 정임을 따라서 허공에 떠가는 것 같았소.
+아아 이렇게 나는 정임을 곁에 두고 싶을까. 이렇게 내가 정임의 곁에 있고 싶을까. 그러하건마는 나는 정임을 떼어 버리고 가지 아니하면 아니 된다! 그것은 애끓는 일이다. 기막히는 일이다! 그러나 내 도덕적 책임은 엄정하게 그렇게 명령하지 않느냐. 나는 이 도덕적 책임의 명령 그것은 더위가 없는 명령이다 을 털끝만치라도 휘어서는 아니 된다.
+그러나 정임이가 호텔 현관까지 자동차를 타기 전에 한 번만 더 바라보는 것도 못 할 일일까. 한 번만, 잠깐만 더 바라보는 것도 못 할 일일까. 잠깐만 일 분만 아니 일 초만 한 시그마라는 극히 짧은 동안만 바라보는 것도 못 할 일일까. 아니, 정임을 한 시그마 동안만 더 보고 싶다 나는 이렇게 생각하고 벌떡 일어나서 도어의 핸들에 손을 대었소.
+`안 된다! 옳잖다!'
+하고 나는 내 소파에 돌아와서 털썩 몸을 던졌소.
+`최후의 순간이 아니냐. 최후의 순간에 용감히 이겨야 할 것이 아니냐. 아서라! 아서라!'
+하고 나는 혼자 주먹을 불끈불끈 쥐었소.
+이 때에 짜박짜박 하고 걸어오는 소리가 들리오. 내 가슴은 쌍방망이로 두들기는 것같이 뛰었소.
+`설마 정임일까.'
+하면서도 나는 숨을 죽이고 귀를 기울였소.
+그 발자국 소리는 분명 내 문 밖에 와서 그쳤소. 그리고는 소리가 없었소.
+`내 귀의 환각인가.'
+하고 나는 한숨을 내쉬었소.
+그러나 다음 순간 또 두어 번 문을 두드리는 소리가 들렸소.
+"이에스."
+하고 나는 대답하고 문을 바라보았소.
+문이 열렸소.
+들어오는 이는 정임이었소.
+"웬일이냐."
+하고 나는 엄숙한 태도를 지었소. 그것으로 일 초의 일천분지 일이라도 다시 한 번 보고 싶던 정임을 보고 기쁨을 카무플라주한 것이오.
+정임은 서슴지 않고 내 뒤에 와서 내 교의에 몸을 기대며,
+"암만해도 오늘이 마지막인 것만 같아서, 다시 뵈올 기약은 없는 것만 같아서 가다가 도로 왔습니다. 한 번만 더 뵙고 갈 양으로요. 그래 도로 와서도 들어올까 말까 하고 주저주저하다가 이것이 마지막인데 하고 용기를 내어서 들어왔습니다. 내일 저를 보시고 가신다는 것이 부러 하신 말씀만 같고, 마지막 뵈옵고, 뵈온대도 그래도 한 번 더 뵈옵기만 해도……."
+하고 정임의 말은 끝을 아물지 못하였소. 그는 내 등 뒤에 서 있기 때문에 그가 어떠한 표정을 하고 있는지는 볼 수가 없었소. 나는 다만 아버지의 위엄으로 정면을 바라보고 있었을 뿐이오.
+`정임아, 나도 네가 보고 싶었다. 네 뒤를 따라가고 싶었다. 내 몸과 마음은 네 뒤를 따라서 허공으로 날았다. 나는 너를 한 초라도 한 초의 천분지 일 동안이라도 한 번 더 보고 싶었다. 정임아, 내 진정은 너를 언제든지 내 곁에 두고 싶다. 정임아, 지금 내 생명이 가진 것은 오직 너뿐이다.'
+이런 말이라도 하고 싶었소. 그러나 이런 말을 하여서는 아니 되오! 만일 내가 이런 말을 하여 준다면 정임이가 기뻐하겠지요. 그러나 나는 정임이에게 이런 기쁨을 주어서는 아니 되오!
+나는 어디까지든지 아버지의 위엄, 아버지의 냉정함을 아니 지켜서는 아니 되오.
+그렇지마는 내 가슴에 타오르는 이름지을 수 없는 열정의 불길은 내 이성과 의지력을 태워 버리려 하오. 나는 눈이 아뜩아뜩함을 깨닫소. 나는 내 생명의 불길이 깜박깜박함을 깨닫소.
+그렇지마는! 아아 그렇지마는 나는 이 도덕적 책임의 무상 명령의 발령자인 쓴 잔을 마시지 아니하여서는 아니 되는 것이오.
+`산! 바위!'
+나는 정신을 가다듬어서 이것을 염하였소.
+그러나 열정의 파도가 치는 곳에 산은 움직이지 아니하오? 바위는 흔들리지 아니하오? 태산과 반석이 그 흰 불길에 타서 재가 되지는 아니하오? 인생의 모든 힘 가운데 열정보다 더 폭력적인 것이 어디 있소? 아마도 우주의 모든 힘 가운데 사람의 열정과 같이 폭력적, 불가항력적인 것은 없으리라. 뇌성, 벽력, 글쎄 그것에나 비길까. 차라리 천체와 천체가 수학적으로 계산할 수 없는 비상한 속력을 가지고 마주 달려들어서 우리의 귀로 들을 수 없는 큰 소리와 우리가 굳다고 일컫는 금강석이라도 증기를 만들고야 말 만한 열을 발하는 충돌의 순간에나 비길까. 형. 사람이라는 존재가 우주의 모든 존재 중에 가장 비상한 존재인 것 모양으로 사람의 열정의 힘은 우주의 모든 신비한 힘 가운데 가장 신비한 힘이 아니겠소? 대체 우주의 모든 힘은 그것이 아무리 큰 힘이라고 하더라도 저 자신을 깨뜨리는 것은 없소. 그렇지마는 사람이라는 존재의 열정은 능히 제 생명을 깨뜨려 가루를 만들고 제 생명을 살라서 소지를 올리지 아니하오? 여보, 대체 이에서 더 폭력이요, 신비적인 것이 어디 있단 말이오.
+이 때 내 상태, 어깨 뒤에서 열정으로 타고 섰는 정임을 느끼는 내 상태는 바야흐로 대폭발, 대충돌을 기다리는 아슬아슬한 때가 아니었소. 만일 조금만이라도 내가 내 열정의 고삐에 늦춤을 준다고 하면 무서운 대폭발이 일어났을 것이오.
+"정임아!"
+하고 나는 충분히 마음을 진정해 가지고 고개를 옆으로 돌려 정임의 얼굴을 찾았소.
+"네에."
+하고 정임은 입을 약간 내 귀 가까이로 가져와서 그 씨근거리는 소리가 분명히 내 귀에 들리고 그 후끈후끈하는 뜨거운 입김이 내 목과 뺨에 감각되었소.
+억지로 진정하였던 내 가슴은 다시 설레기를 시작하였소. 그 불규칙한 숨소리와 뜨거운 입김 때문이었을까.
+"시간 늦는다. 어서 가거라. 이 아버지는 언제까지든지 너를 사랑하는 딸 로 소중히 소중히 가슴에 품고 있으마. 또 후일에 다시 만날 때도 있을지 아느냐. 설사 다시 만날 때가 없다기로니 그것이 무엇이 그리 대수냐. 나이 많은 사람은 먼저 죽고 젊은 사람은 오래 살아서 인생의 일을 많이 하는 것이 순서가 아니냐. 너는 몸이 아직 약하니 마음을 잘 안정해서 어서 건강을 회복하여라. 그리고 굳세게 굳세게, 힘있게 힘있게 살아 다오. 조선은 사람을 구한다. 나 같은 사람은 인제 조선서 더 일할 자격을 잃어버린 사람이지마는 네야 어떠냐. 설사 누가 무슨 말을 해서 학교에서 학비를 아니 준다거든 내가 네게 준 재산을 가지고 네 마음대로 공부를 하려무나. 네가 그렇게 해 주어야 나를 위하는 것이다. 자 인제 가거라. 네 앞길이 양양하지 아니하냐. 자 인제 가거라. 나는 내일 아침 동경을 떠날란다. 자 어서."
+하고 나는 화평하게 웃는 낯으로 일어섰소.
+정임은 울먹울먹하고 고개를 숙이오.
+밖에서는 바람이 점점 강해져서 소리를 하고 유리창을 흔드오.
+"그럼, 전 가요."
+하고 정임은 고개를 들었소.
+"그래. 어서 가거라. 벌써 열한시 반이다. 병원 문은 아니 닫니!"
+정임은 대답이 없소.
+"어서!"
+하고 나는 보이를 불러 자동차를 하나 준비하라고 일렀소.
+"갈랍니다."
+하고 정임은 고개를 숙여서 내게 인사를 하고 문을 향하여 한 걸음 걷다가 잠깐 주저하더니, 다시 돌아서서,
+"저를 한 번만 안아 주셔요. 아버지가 어린 딸을 안듯이 한 번만 안아 주셔요."
+하고 내 앞으로 가까이 와 서오.
+나는 팔을 벌려 주었소. 정임은 내 가슴을 향하고 몸을 던졌소. 그리고 제 이뺨 저뺨을 내 가슴에 대고 비볐소. 나는 두 팔을 정임의 어깨 위에 가벼이 놓았소.
+이러한 지 몇 분이 지났소. 아마 일 분도 다 못 되었는지 모르오.
+정임은 내 가슴에서 고개를 들어 나를 뚫어지게 우러러보더니, 다시 내 가슴에 낯을 대더니 아마 내 심장이 무섭게 뛰는 소리를 정임은 들었을 것이오 정임은 다시 고개를 들고,
+"어디를 가시든지 편지나 주셔요."
+하고 굵은 눈물을 떨구고는 내게서 물러서서 또 한 번 절하고,
+"안녕히 가셔요. 만주든지 아령이든지 조선 사람 많이 사는 곳에 가셔서 일하고 사셔요. 돌아가실 생각은 마셔요. 제가, 아버지 말씀대로 혼자 떨어져 있으니 아버지도 제 말씀대로 돌아가실 생각은 마셔요, 네, 그렇다고 대답하셔요!"
+하고는 또 한 번 내 가슴에 몸을 기대오.
+죽기를 결심한 나는 `오냐, 그러마.' 하는 대답을 할 수는 없었소. 그래서,
+"오, 내 살도록 힘쓰마."
+하는 약속을 주어서 정임을 돌려보냈소.
+정임의 발자국 소리가 안 들리게 된 때에 나는 빠른 걸음으로 옥상 정원으로 나갔소. 비가 막 뿌리오.
+나는 정임이가 타고 나가는 자동차라도 볼 양으로 호텔 현관 앞이 보이는 꼭대기로 올라갔소. 현관을 떠난 자동차 하나가 전찻길로 나서서는 북을 향하고 달아나서 순식간에 그 꽁무니에 달린 붉은 불조차 스러져 버리고 말았소.
+나는 미친 사람 모양으로,
+"정임아, 정임아!"
+하고 수없이 불렀소. 나는 사 층이나 되는 이 꼭대기에서 뛰어내려서 정임이가 타고 간 자동차의 뒤를 따르고 싶었소.
+"아아 영원한 인생의 이별!"
+나는 그 옥상에 얼마나 오래 섰던지를 모르오. 내 머리와 낯과 배스로브에서는 물이 흐르오. 방에 들어오니 정임이가 끼치고 간 향기와 추억만 남았소.
+나는 방 안 구석구석에 정임의 모양이 보이는 것을 깨달았소. 특별히 정임이가 고개를 숙이고 서 있던 내 교의 뒤에는 분명히 갈색 외투를 입은 정임의 모양이 완연하오.
+"정임아!"
+하고 나는 그 곳으로 따라가오. 그러나 가면 거기는 정임은 없소.
+나는 교의에 앉소. 그러면 정임의 씨근씨근하는 숨소리와 더운 입김이 분명 내 오른편에 감각이 되오. 아아 무서운 환각이여!
+나는 자리에 눕소. 그리고 정임의 환각을 피하려고 불을 끄오. 그러면 정임이가 내게 안기던 자리쯤에 환하게 정임의 모양이 나타나오.
+나는 불을 켜오. 또 불을 끄오.
+날이 밝자 나는 비가 갠 것을 다행으로 비행장에 달려가서 비행기를 얻어 탔소.
+나는 다시 조선의 하늘을 통과하기가 싫어서 북강에서 비행기에서 내려서 문사에 와서 대련으로 가는 배를 탔소.
+나는 대련에서 내려서 하룻밤을 여관에서 자고는 곧 장춘 가는 급행을 탔소. 물론 아무에게도 엽서 한 장 한 일 없었소. 그것은 인연을 끊은 세상에 대하여 연연한 마음을 가지는 것을 부끄럽게 생각한 까닭이오.
+차가 옛날에는 우리 조상네가 살고 문화를 짓던 옛 터전인 만주의 벌판을 달릴 때에는 감회도 없지 아니하였소. 그러나 나는 지금 그런 한가한 감상을 쓸 겨를이 없소.
+내가 믿고 가는 곳은 하얼빈에 있는 어떤 친구요. 그는 R라는 사람으로서 경술년에 A씨 등의 망명객을 따라 나갔다가 아라사에서 무관 학교를 졸업하고 아라사 사관으로서 구주 대전에도 출정을 하였다가, 혁명 후에도 이내 적위군에 머물러서 지금까지 소비에트 장교로 있는 사람이오. 지금은 육군 소장이라던가.
+나는 하얼빈에 그 사람을 찾아가는 것이오. 그 사람을 찾아야 아라사에 들어갈 여행권을 얻을 것이요, 여행권을 얻어야 내가 평소에 이상하게도 그리워하던 바이칼 호를 볼 것이오.
+하얼빈에 내린 것은 해가 뉘엿뉘엿 넘어가는 석양이었소.
+나는 안중근이 이등박문(伊藤博文:이토 히로부미)을 쏜 곳이 어딘가 하고 벌판과 같이 넓은 플랫폼에 내렸소. 과연 국제 도시라 서양 사람, 중국 사람, 일본 사람이 각기 제 말로 지껄이오. 아아 조선 사람도 있을 것이오마는 다들 양복을 입거나 청복을 입거나 하고 또 사람이 많은 곳에서는 말도 잘 하지 아니하여 아무쪼록 조선 사람인 것을 표시하지 아니하는 판이라 그 골격과 표정을 살피기 전에는 어느 것이 조선 사람인지 알 길이 없소. 아마 허름하게 차리고 기운 없이, 비창한 빛을 띠고 사람의 눈을 슬슬 피하는 저 순하게 생긴 사람들이 조선 사람이겠지요. 언제나 한 번 가는 곳마다 동양이든지, 서양이든지,
+`나는 조선 사람이오!'
+하고 뽐내고 다닐 날이 있을까 하면 눈물이 나오. 더구나, 하얼빈과 같은 각색 인종이 모여서 생존 경쟁을 하는 마당에 서서 이런 비감이 간절하오. 아아 이 불쌍한 유랑의 무리 중에 나도 하나를 더 보태는가 하면 눈물을 씻지 아니할 수 없었소.
+나는 역에서 나와서 어떤 아라사 병정 하나를 붙들고 R의 아라사 이름을 불렀소. 그리고 아느냐고 영어로 물었소.
+그 병정은 내 말을 잘못 알아들었는지, 또는 R를 모르는지 무엇이라고 아라사말로 지껄이는 모양이나 나는 물론 그것을 알아들을 수가 없었소. 그러나 나는 그 병정의 표정에서 내게 호의를 가진 것을 짐작하고 한 번 더 분명히,
+"요십 알렉산드로비치 리가이."
+라고 불러 보았소.
+그 병정은 빙그레 웃고 고개를 흔드오. 이 두 외국 사람의 이상한 교섭에 흥미를 가지고 여러 아라사 병정과 동양 사람들이 십여 인이나 우리 주위에 모여드오.
+그 병정이 나를 바라보고 또 한 번 그 이름을 불러 보라는 모양 같기로 나는 이번에는 R의 아라사 이름에 `제너럴'이라는 말을 붙여 불러 보았소.
+그랬더니 어떤 다른 병정이 뛰어들며,
+"게네라우 리가이!"
+하고 안다는 표정을 하오. `게네라우'라는 것이 아마 아라사말로 장군이란 말인가 하였소.
+"예스. 예스."
+하고 나는 기쁘게 대답하였소. 그리고는 아라사 병정들끼리 무에라고 지껄이더니, 그 중에 한 병정이 나서면서 고개를 끄덕끄덕하고, 제가 마차 하나를 불러서 나를 태우고 저도 타고 어디로 달려가오.
+그 아라사 병정은 친절히 알지도 못하는 말로 이것저것을 가리키면서 설명을 하더니 내가 못 알아듣는 줄을 생각하고 내 어깨를 툭 치고 웃소. 어린애와 같이 순한 사람들이구나 하고 나는 고맙다는 표로 고개만 끄덕끄덕하였소.
+어디로 어떻게 가는지 서양 시가로 달려가다가 어떤 큰 저택 앞에 이르러서 마차를 그 현관 앞으로 들이몰았소.
+현관에서는 종졸이 나왔소. 내가 명함을 들여보냈더니 부관인 듯한 아라사 장교가 나와서 나를 으리으리한 응접실로 인도하였소. 얼마 있노라니 중년이 넘은 어떤 대장이 나오는데 군복에 칼끈만 늘였소.
+"이게 누구요."
+하고 그 대장은 달려들어서 나를 껴안았소. 이십오 년 만에 만나는 우리는 서로 알아본 것이오.
+이윽고 나는 그의 부인과 자녀들도 만났소. 그들은 다 아라사 사람이오.
+저녁이 끝난 뒤에 나는 R의 부인과 딸의 음악과 그림 구경과 기타의 관대를 받고 단둘이 이야기할 기회를 얻었소. 경술년 당시 이야기도 나오고, A씨의 이야기도 나오고, R의 신세 타령도 나오고, 내 이십오 년 간의 생활 이야기도 나오고, 소비에트 혁명 이야기도 나오고, 하얼빈 이야기도 나오고, 우리네가 어려서 서로 사귀던 회구담도 나오고 이야기가 그칠 바를 몰랐소. "조선은 그립지 않은가."
+하는 내 말에 쾌활하던 R는 고개를 숙이고 추연한 빛을 보였소.
+나는 R의 추연한 태도를 아마 고국을 그리워하는 것으로만 여겼소. 그래서 나는 그리 침음하는 것을 보고,
+"얼마나 고국이 그립겠나. 나는 고국을 떠난 지가 일 주일도 안 되건마는 못 견디게 그리운데."
+하고 동정하는 말을 하였소.
+했더니, 이 말 보시오. 그는 침음을 깨뜨리고 고개를 번쩍 들며,
+"아니! 나는 고국이 조금도 그립지 아니하이. 내가 지금 생각한 것은 자네 말을 듣고 고국이 그리운가 그리워할 것이 있는가를 생각해 본 것일세. 그랬더니 아무리 생각하여도 나는 고국이 그립다는 생각을 가질 수가 없어. 그야 어려서 자라날 때에 보던 강산이라든지 내 기억에 남은 아는 사람들이라든지, 보고 싶다 하는 생각도 없지 아니하지마는 그것이 고국이 그리운 것이라고 할 수가 있을까. 그 밖에는 나는 아무리 생각하여도 고국이 그리운 것을 찾을 길이 없네. 나도 지금 자네를 보고 또 자네 말을 듣고 오래 잊어버렸던 고국을 좀 그립게, 그립다 하게 생각하려고 해 보았지마는 도무지 나는 고국이 그립다는 생각이 나지 않네."
+이 말에 나는 깜짝 놀랐소. 몸서리치게 무서웠소. 나는 해외에 오래 표랑하는 사람은 으레 고국을 그리워할 것으로 믿고 있었소. 그런데 이 사람이, 일찍은 고국을 사랑하여 목숨까지도 바치려던 이 사람이 도무지 이처럼 고국을 잊어버린다는 것은 놀라운 정도를 지나서 괘씸하기 그지없었소. 나도 비록 조선을 떠난다고, 영원히 버린다고 나서기는 했지마는 나로는 죽기 전에는 아니 비록 죽더라도 잊어버리지 못할 고국을 잊어버린 R의 심사가 난측하고 원망스러웠소.
+"고국이 그립지가 않아?"
+하고 R에게 묻는 내 어성에는 격분한 빛이 있었소.
+"이상하게 생각하시겠지. 하지만 고국에 무슨 그리울 것이 있단 말인가. 그 빈대 끓는 오막살이가 그립단 말인가. 나무 한 개 없는 산이 그립단 말인가. 물보다도 모래가 많은 다 늙어빠진 개천이 그립단 말인가. 그 무기력하고 가난한, 시기 많고 싸우고 하는 그 백성을 그리워한단 말인가. 그렇지 아니하면 무슨 그리워할 음악이 있단 말인가, 미술이 있단 말인가, 문학이 있단 말인가, 사상이 있단 말인가, 사모할 만한 인물이 있단 말인가! 날더러 고국의 무엇을 그리워하란 말인가. 나는 조국이 없는 사람일세. 내가 소비에트 군인으로 있으니 소비에트가 내 조국이겠지. 그러나 진심으로 내 조국이라는 생각은 나지 아니하네."
+하고 저녁 먹을 때에 약간 붉었던 R의 얼굴은 이상한 흥분으로 더욱 붉어지오.유 정유 정
+R는 먹던 담배를 화나는 듯이 재떨이에 집어던지며,
+"내가 하얼빈에 온 지가 인제 겨우 삼사 년밖에 안 되지마는 조선 사람 때문에 나는 견딜 수가 없어. 와서 달라는 것도 달라는 것이지마는 조선 사람이 또 어찌하였느니 또 어찌하였느니 하는 불명예한 말을 들을 때에는 나는 금시에 죽어 버리고 싶단 말일세. 내게 가장 불쾌한 것이 있다고 하면 그것은 고국이라는 기억과 조선 사람의 존잴세. 내가 만일 어느 나라의 독재자가 된다고 하면 나는 첫째로 조선인 입국 금지를 단행하려네. 만일 조선이라는 것을 잊어버릴 약이 있다고 하면 나는 생명과 바꾸어서라도 사 먹고 싶어."
+하고 R는 약간 흥분된 어조를 늦추어서,
+"나도 모스크바에 있다가 처음 원동에 나왔을 적에는 길을 다녀도 혹시 동포가 눈에 뜨이지나 아니하나 하고 찾았네. 그래서 어디서든지 동포를 만나면 반가이 손을 잡았지. 했지만 점점 그들은 오직 귀찮은 존재에 지나지 못하다는 것을 알았단 말일세. 인제는 조선 사람이라고만 하면 만나기가 무섭고 끔찍끔찍하고 진저리가 나는 걸 어떡허나. 자네 명함이 들어온 때에도 조선 사람인가 하고 가슴이 뜨끔했네."
+하고 R는 웃지도 아니하오. 그의 얼굴에는, 군인다운 기운찬 얼굴에는 증오와 분노의 빛이 넘쳤소.
+"나도 자네 집에 환영받는 나그네는 아닐세그려."
+하고 나는 이 견디기 어려운 불쾌하고 무서운 공기를 완화하기 위하여 농담삼아 한 마디를 던지고 웃었소.
+나는 R의 말이 과격함에 놀랐지마는, 또 생각하면 R가 한 말 가운데는 들을 만한 이유도 없지 아니하오. 그것을 생각할 때에 나는 R를 괘씸하게 생각하기 전에 내가 버린다는 조선을 위하여서 가슴이 아팠소. 그렇지만 이제 나 따위가 가슴을 아파한대야 무슨 소용이 있소. 조선에 남아 계신 형이나 R의 말을 참고삼아 쓰시기 바라오. 어쨌으나 나는 R에게서 목적한 여행권을 얻었소. R에게는 다만,
+`나는 피곤한 몸을 좀 정양하고 싶다. 나는 내가 평소에 즐겨하는 바이칼 호반에서 눈과 얼음의 한겨울을 지내고 싶다.'
+는 것을 여행의 이유로 삼았소.
+R는 나의 초췌한 모양을 짐작하고 내 핑계를 그럴듯하게 아는 모양이었소. 그리고 나더러, `이왕 정양하려거든 카프카 지방으로 가거라. 거기는 기후 풍경도 좋고 또 요양원의 설비도 있다.'는 것을 말하였소. 나도 톨스토이의 소설에서, 기타의 여행기 등속에서 이 지방에 관한 말을 못 들은 것이 아니나 지금 내 처지에는 그런 따뜻하고 경치 좋은 지방을 가릴 여유도 없고 또 그러한 지방보다도 눈과 얼음과 바람의 시베리아의 겨울이 합당한 듯하였소.
+그러나 나는 R의 호의를 굳이 사양할 필요도 없어서 그가 써 주는 대로 소개장을 다 받아 넣었소. 그는 나를 처남 매부 간이라고 소개해 주었소.
+나는 모스크바 가는 다음 급행을 기다리는 사흘 동안 R의 집의 손이 되어서 R부처의 친절한 대우를 받았소.
+그 후에는 나는 R와 조선에 관한 토론을 한 일은 없지마는 R가 이름지어 말을 할 때에는 조선을 잊었노라, 그리워할 것이 없노라, 하지마는 무의식적으로 말을 할 때에는 조선을 못 잊고 또 조선을 여러 점으로 그리워하는 양을 보았소. 나는 그것으로써 만족하게 여겼소.
+나는 금요일 오후 세시 모스크바 가는 급행으로 하얼빈을 떠났소. 역두에는 R와 R의 가족이 나와서 꽃과 과일과 여러 가지 선물로 나를 전송하였소. R와 R의 가족은 나를 정말 형제의 예로 대우하여 차가 떠나려 할 때에 포옹과 키스로 작별하여 주었소.
+이 날은 퍽 따뜻하고 일기가 좋은 날이었소. 하늘에 구름 한 점, 땅에 바람 한 점 없이 마치 늦은 봄날과 같이 따뜻한 날이었소.
+차는 떠났소. 판다는 둥 안 판다는 둥 말썽 많은 동중로(지금은 북만 철로라고 하오.)의 국제 열차에 몸을 의탁한 것이오.
+송화강(松花江:쑹화 강)의 철교를 건너오. 아아 그리도 낯익은 송화강! 송화강이 왜 낯이 익소. 이 송화강은 불함산(장백산)에 근원을 발하여 광막한 북만주의 사람도 없는 벌판을 혼자 소리도 없이 흘러가는 것이 내 신세와 같소. 이 북만주의 벌판을 만든 자가 송화강이지마는 나는 그만한 힘이 없는 것이 부끄러울 뿐이오. 이 광막한 북만의 벌판을 내 손으로 개척하여서 조선 사람의 낙원을 만들자 하고 뽐내어 볼까. 그것은 형이 하시오. 내 어린것이 자라거든 그놈에게나 그러한 생각을 넣어 주시오.
+동양의 국제적 괴물인 하얼빈 시가도 까맣게 안개에서 스러져 버리고 말았소. 그러나 그 시가를 싼 까만 기운이 국제적 풍운을 포장한 것이라고 할까요.
+가도가도 벌판. 서리맞은 마른 풀바다. 실개천 하나도 없는 메마른 사막. 어디를 보아도 산 하나 없으니 하늘과 땅이 착 달라붙은 듯한 천지. 구름 한 점 없건만도 그 큰 태양 가지고도 미처 다 비추지 못하여 지평선 호를 그린 지평선 위에는 항상 황혼이 떠도는 듯한 세계. 이 속으로 내가 몸을 담은 열차는 서쪽으로 서쪽으로 해가 가는 걸음을 따라서 달리고 있소. 열차가 달리는 바퀴 소리도 반향할 곳이 없어 힘없는 한숨같이 스러지고 마오.
+기쁨 가진 사람이 지루해서 못 견딜 이 풍경은 나같이 수심 가진 사람에게는 가장 공상의 말을 달리기에 합당한 곳이오.
+이 곳에도 산도 있고 냇물도 있고 삼림도 있고 꽃도 피고 날짐승, 길짐승이 날고 기던 때도 있었겠지요. 그러던 것이 몇만 년 지나는 동안에 산은 낮아지고 골은 높아져서 마침내 이 꼴이 된 것인가 하오. 만일 큰 힘이 있어 이 광야를 파낸다 하면 물 흐르고 고기 놀던 강과, 울고 웃던 생물이 살던 자취가 있을 것이오. 아아 이 모든 기억을 꽉 품고 죽은 듯이 잠잠한 광야에!
+내가 탄 차가 F역에 도착하였을 때에는 북만주 광야의 석양의 아름다움은 그 극도에 달한 것 같았소. 둥긋한 지평선 위에 거의 걸린 커다란 해! 아마 그 신비하고 장엄함이 내 경험으로는 이 곳에서밖에는 볼 수 없는 것이라고생각하오. 이글이글 이글이글 그러면서도 둥글다는 체모를 변치 아니하는 그 지는 해!
+게다가 먼 지평선으로부터 기어드는 황혼은 인제는 대지를 거의 다 덮어 버려서 마른 풀로 된 지면은 가뭇가뭇한 빛을 띠고 사막의 가는 모래를 머금은 지는 해의 광선을 반사하여서 대기는 짙은 자줏빛을 바탕으로 한 가지각색의 명암을 가진, 오색이 영롱한, 도무지 내가 일찍 경험해 보지 못한 색채의 세계를 이루었소. 아 좋다!
+그 속에 수은같이 빛나는, 수없는 작고 큰 호수들의 빛! 그 속으로 날아오는 수없고 이름 모를 새들의 떼도 이 세상의 것이라고는 생각하지 아니하오.
+나는 거의 무의식적으로 차에서 뛰어내렸소. 거의 떠날 시간이 다 되어서 짐의 일부분은 미처 가지지도 못하고 뛰어내렸소. 반쯤 미친 것이오.
+정거장 앞 조그마한 아라사 사람의 여관에다가 짐을 맡겨 버리고 나는 단장을 끌고 철도 선로를 뛰어 건너서 호수의 수은빛 나는 곳을 찾아서 지향 없이 걸었소.
+한 호수를 가서 보면 또 저 편 호수가 더 아름다워 보이오. 원컨대 저 지는 해가 다 지기 전에 이 광야에 있는 호수를 다 돌아보고 싶소.
+내가 호숫 가에 섰을 때에 그 거울같이 잔잔한 호수면에 비치는 내 그림자의 외로움이여, 그러나 아름다움이여! 그 호수는 영원한 우주의 신비를 품고 하늘이 오면 하늘을, 새가 오면 새를, 구름이 오면 구름을, 그리고 내가 오면 나를 비추지 아니하오. 나는 호수가 되고 싶소. 그러나 형! 나는 이 호수면에서 얼마나 정임의 얼굴을 찾았겠소. 그것은 물리학적으로 불가능한 일이겠지요. 동경의 병실에 누워 있는 정임의 모양이 몽고 사막의 호수면에 비칠 리야 있겠소. 없겠지마는 나는 호수마다 정임의 그림자를 찾았소. 그러나 보이는 것은 외로운 내 그림자뿐이오.
+`가자. 끝없는 사막으로 한없이 가자. 가다가 내 기운이 진하는 자리에 나는 내 손으로 모래를 파고 그 속에 내 몸을 묻고 죽어 버리자. 살아서 다시 볼 수 없는 정임의 「이데아」를 안고 이 깨끗한 광야에서 죽어 버리 자.'
+하고 나는 지는 해를 향하고 한정 없이 걸었소. 사막이 받았던 따뜻한 기운은 아직도 다 식지는 아니하였소. 사막에는 바람 한 점도 없소. 소리 하나도 없소. 발자국 밑에서 우는 마른 풀과 모래의 바스락거리는 소리가 들릴 뿐이오.
+나는 허리를 지평선에 걸었소. 그 신비한 광선은 내 가슴으로부터 위에만을 비추고 있소.
+문득 나는 해를 따라가는 별 두 개를 보았소. 하나는 앞을 서고 하나는 뒤를 섰소. 앞의 별은 좀 크고 뒤의 별은 좀 작소. 이런 별들은 산 많은 나라 다시 말하면 서쪽 지평선을 보기 어려운 나라에서만 생장한 나로서는 보지 못하던 별이오. 나는 그 별의 이름을 모르오. `두 별'이오.
+해가 지평선에서 뚝 떨어지자 대기의 자줏빛은 남빛으로 변하였소. 오직 해가 금시 들어간 자리에만 주홍빛의 여광이 있을 뿐이오. 내 눈앞에서는 남빛 안개가 피어오르는 듯하였소. 앞에 보이는 호수만이 유난히 빛나오. 또 한 떼의 이름 모를 새들이 수면을 스치며 날 저문 것을 놀라는 듯이 어지러이 날아 지나가오. 그들은 소리도 아니 하오. 날개치는 소리도 아니 들리오. 그것들은 사막의 황혼의 허깨비인 것 같소.
+나는 자꾸 걷소. 해를 따르던 나는 두 별을 따라서 자꾸 걷소.
+별들은 진 해를 따라서 바삐 걷는 것도 같고, 헤매는 나를 어떤 나라로 끄는 것도 같소.
+아니 두 별 중에 앞선 별이 한 번 반짝하고는 최후로 한 번 반짝하고는 지평선 밑에 숨어 버리고 마오. 뒤에 남은 외별의 외로움이여! 나는 울고 싶었소. 그러나 나는 하나만 남은 작은 별 외로운 작은 별을 따라서 더 빨리 걸음을 걸었소. 그 한 별마저 넘어가 버리면 나는 어찌하오.
+내가 웬일이오. 나는 시인도 아니요, 예술가도 아니오. 나는 정으로 행동한 일은 없다고 믿는 사람이오. 그러나 형! 이 때에 미친 것이 아니요, 내 가슴에는 무엇인지 모를 것을 따를 요샛말로 이른바 동경으로 찼소.
+`아아 저 작은 별!'
+그것도 지평선에 닿았소.
+`아아 저 작은 별. 저것마저 넘어가면 나는 어찌하나.'
+인제는 어둡소. 광야의 황혼은 명색뿐이요, 순식간이요, 해지자 신비하다고 할 만한 극히 짧은 동안에 아름다운 황혼을 조금 보이고는 곧 칠과 같은 암흑이오. 호수의 물만이 어디서 은빛을 받았는지 뿌옇게 나만이 유일한 존재다, 나만이 유일한 빛이다 하는 듯이 인제는 수은빛이 아니라 남빛을 발하고 있을 뿐이오.
+나는 그 중 빛을 많이 받은, 그 중 환해 보이는 호수면을 찾아 두리번거리며, 그러나 빠른 걸음으로 헤매었소. 그러나 내가 좀더 맑은 호수면을 찾는 동안에 이 광야의 어둠은 더욱더욱 짙어지오.
+나는 어떤 조그마한 호숫 가에 펄썩 앉았소. 내 앞에는 짙은 남빛의 수면에 조그마한 거울만한 밝은 데가 있소. 마치 내 눈에서 무슨 빛이 나와서, 아마 정임을 그리워하는 빛이 나와서 그 수면에 반사하는 듯이. 나는 허겁지겁 그 빤한 수면을 들여다보았소. 혹시나 정임의 모양이 거기 나타나지나 아니할까 하고. 세상에는 그러한 기적도 있지 아니한가 하고.
+물에는 정임의 얼굴이 어른거리는 것 같았소. 이따금 정임의 눈도 어른거리고 코도 번뜻거리고 입도 번뜻거리는 것 같소. 그러나 수면은 점점 어두워 가서 그 환영조차 더욱 희미해지오.
+나는 호수면에 빤하던 한 조각조차 캄캄해지는 것을 보고 숨이 막힐 듯함을 깨달으면서 고개를 들었소.
+고개를 들려고 할 때에, 형이여, 이상한 일도 다 있소. 그 수면에 정임의 모양이, 얼굴만 아니라, 그 몸 온통이 그 어깨, 가슴, 팔, 다리까지도, 그 눈과 입까지도, 그 얼굴의 흰 것과 입술이 불그레한 것까지도, 마치 환한 대낮에 실물을 대한 모양으로 소상하게 나타났소.
+"정임이!"
+하고 나는 소리를 지르며 물로 뛰어들려 하였소. 그러나 형, 그 순간에 정임의 모양은 사라져 버리고 말았소.
+나는 이 어둠 속에 어디 정임이가 나를 따라온 것같이 생각했소. 혹시나 정임이가 죽어서 그 몸은 동경의 대학 병원에 벗어 내어던지고 혼이 빠져 나와서 물에 비치었던 것이 아닐까, 나는 가슴이 울렁거림을 진정치 못하면서 호숫 가에서 벌떡 일어나서 어둠 속에 정임을 만져보려는 듯이, 어두워서 눈에 보지는 못하더라도 자꾸 헤매노라면 몸에 부딪히기라도 할 것 같아서 함부로 헤매었소. 그리고는 눈앞에 번뜻거리는 정임의 환영을 팔을 벌려서 안고 소리를 내어서 불렀소.
+"정임이, 정임이."
+하고 나는 수없이 정임을 부르면서 헤매었소.
+그러나 형, 이것도 죄지요. 이것도 하나님께서 금하시는 일이지요. 그러길래 광야에 아주 어둠이 덮이고 새까만 하늘에 별이 총총하게 나고는 영 정임의 헛그림자조차 아니 보이지요. 나는 죄를 피해서 정임을 떠나서 멀리 온 것이니 정임의 헛그림자를 따라다니는 것도 옳지 않지요.
+그렇지만 내가 이렇게 혼자서 정임을 생각만 하는 것이야 무슨 죄 될 것이 있을까요. 내가 정임을 만 리나 떠나서 이렇게 헛그림자나 그리며 그리워하는 것이야 무슨 죄가 될까요. 설사 죄가 되기로서니 낸들 이것까지야 어찌하오. 내가 내 혼을 죽여 버리기 전에야 내 힘으로 어찌하오. 설사 죄가 되어서 내가 지옥의 꺼지지 않는 유황불 속에서 영원한 형벌을 받게 되기로서니 그것을 어찌하오. 형, 이것, 이것도 말아야 옳은가요. 정임의 헛그림자까지도 끊어 버려야 옳은가요.
+이 때요. 바로 이 때요. 내 앞 수십 보나 될까(캄캄한 밤이라 먼지 가까운지 분명히 알 수 없지마는) 하는 곳에 난데없는 등불 하나가 나서오. 나는 깜짝 놀라서 우뚝 섰소. 이 무인지경, 이 밤중에 갑자기 보이는 등불 그것은 마치 이 세상 같지 아니하였소.
+저 등불이 어떤 등불일까, 그 등불이 몇 걸음 가까이 오니, 그 등불 뒤에 사람의 다리가 보이오.
+"누구요?"
+하는 것은 귀에 익은 조선말이오. 어떻게 이 몽고의 광야에서 조선말을 들을까 하고 나는 등불을 처음 볼 때보다 더욱 놀랐소.
+"나는 지나가던 사람이오."
+하고 나도 등불을 향하여 마주 걸어갔소.
+그 사람은 등불을 들어서 내 얼굴을 비추어 보더니,
+"당신 조선 사람이오?"
+하고 묻소.
+"네, 나는 조선 사람이오. 당신도 음성을 들으니 조선 사람인데, 어떻게 이런 광야에, 아닌 밤중에, 여기 계시단 말이오."
+하고 나는 놀라는 표정 그대로 대답하였소.
+"나는 이 근방에 사는 사람이니까 여기 오는 것도 있을 일이지마는 당신이야말로 이 아닌 밤중에."
+하고 육혈포를 집어넣고, 손을 내밀어서 내게 악수를 구하오.
+나는 반갑게 그의 손을 잡았소. 그러나 나는 `죽을 지경에 어떻게 오셨단 말이오.' 하고, 그가 내가 무슨 악의를 가진 흉한이 아닌 줄을 알고 손에 빼어들었던 육혈포로 시기를 잠깐이라도 노린 것을 불쾌하게 생각하였던 것이오.
+그도 내 이름도 묻지 아니하고 또 나도 그의 이름을 묻지 아니하고 나는 그에게 끌려서 그가 인도하는 곳으로 갔소. 그 곳이란 것은 아까 등불이 처음 나타나던 곳인 듯한데, 거기서 또 한 번 놀란 것은 어떤 부인이 있는 것이오. 남자는 아라사식 양복을 입었으나 부인은 중국 옷 비슷한 옷을 입었소. 남자는 나를 끌어서 그 부인에게 인사하게 하고,
+"이는 내 아내요."
+하고 또 그 아내라는 부인에게는,
+"이 이는 조선 양반이오. 성함이 뉘시죠?"
+하고 그는 나를 바라보오. 나는,
+"최석입니다."
+하고 바로 대답하였소.
+"최석 씨?"
+하고 그 남자는 소개하던 것도 잊어버리고 내 얼굴을 들여다보오.
+"네, 최석입니다."
+"아 ●●학교 교장으로 계신 최석 씨."
+하고 그 남자는 더욱 놀라오.
+"네, 어떻게 내 이름을 아세요?"
+하고 나도 그가 혹시 아는 사람이나 아닌가 하고 등불 빛에 얼굴을 들여다 보았으나 도무지 그 얼굴이 본 기억이 없소.
+"최 선생을 내가 압니다. 남 선생한테 말씀을 많이 들었지요. 그런데 남 선생도 돌아가신 지가 벌써 몇 핸가."
+하고 감개무량한 듯이 그 아내를 돌아보오.
+"십오 년이지요."
+하고 곁에 섰던 부인이 말하오.
+"벌써 십오 년인가."
+하고 그 남자는 나를 보고,
+"정임이 잘 자랍니까? 벌써 이십이 넘었지."
+하고 또 부인을 돌아보오.
+"스물세 살이지."
+하고 부인이 확실치 아니한 듯이 대답하오.
+"네, 스물세 살입니다. 지금 동경에 있습니다. 병이 나서 입원한 것을 보고 왔는데."
+하고 나는 번개같이 정임의 병실과 정임의 호텔 장면 등을 생각하고 가슴이 설렘을 깨달았소. 의외인 곳에서 의외인 사람들을 만나서 정임의 말을 하게 된 것을 기뻐하였소.
+"무슨 병입니까. 정임이가 본래 몸이 약해서."
+하고 부인이 직접 내게 묻소.
+"네. 몸이 좀 약합니다. 병이 좀 나은 것을 보고 떠났습니다마는 염려가 됩니다."
+하고 나는 무의식중에 고개를 동경이 있는 방향으로 돌렸소. 마치 고개를 동으로 돌리면 정임이가 보이기나 할 것같이.
+"자, 우리 집으로 갑시다."
+하고 나는 아직 그의 성명도 모르는 남자는, 그의 아내를 재촉하더니,
+"우리가 조선 동포를 만난 것이 십여 년 만이오. 그런데 최 선생, 이것을 좀 보시고 가시지요."
+하고 그는 빙그레 웃으면서 나를 서너 걸음 끌고 가오. 거기는 조그마한 무덤이 있고 그 앞에는 석 자 높이나 되는 목패를 세웠는데 그 목패에는 `두 별 무덤'이라는 넉 자를 썼소.
+내가 이상한 눈으로 그 무덤과 목패를 보고 있는 것을 보고 그는,
+"이게 무슨 무덤인지 아십니까?"
+하고 유쾌하게 묻소.
+"두 별 무덤이라니 무슨 뜻인가요?"
+하고 나도 그의 유쾌한 표정에 전염이 되어서 웃고 물었소.
+"이것은 우리 둘의 무덤이외다."
+하고 그는 아내의 어깨를 치며 유쾌하게 웃었소. 부인은 부끄러운 듯이 웃고 고개를 숙이오.
+도무지 모두 꿈 같고 환영 같소.
+"자 갑시다. 자세한 말은 우리 집에 가서 합시다."
+하고 서너 걸음 어떤 방향으로 걸어가니 거기는 말을 세 필이나 맨 마차가 있소. 몽고 사람들이 가족을 싣고 수초를 따라 돌아다니는 그러한 마차요. 삿자리로 홍예형의 지붕을 만들고 그 속에 들어가 앉게 되었소. 그의 부인과 나와는 이 지붕 속에 들어앉고 그는 손수 어자대에 앉아서 입으로 쮸쮸쮸쮸 하고 말을 모오. 등불도 꺼 버리고 캄캄한 속으로 달리오.
+"불이 있으면 군대에서 의심을 하지요. 도적놈이 엿보지요. 게다가 불이 있으면 도리어 앞이 안 보인단 말요. 쯧쯧쯧쯧!"
+하는 소리가 들리오.
+대체 이 사람은 무슨 사람인가. 또 이 부인은 무슨 사람인가 하고 나는 어두운 속에서 혼자 생각하였소. 다만 잠시 본 인상으로 보아서 그들은 행복된 부부인 것 같았소. 그들이 무엇 하러 이 아닌 밤중에 광야에 나왔던가. 또 그 이상야릇한 두 별 무덤이란 무엇인가.
+나는 불현듯 집을 생각하였소. 내 아내와 어린것들을 생각하였소. 가정과 사회에서 쫓겨난 내가 아니오. 쫓겨난 자의 생각은 언제나 슬픔뿐이었소.
+나는 내 아내를 원망치 아니하오. 그는 결코 악한 여자가 아니오. 다만 보통 여자요. 그는 질투 때문에 이성의 힘을 잃은 것이오. 여자가 질투 때문에 이성을 잃는 것이 천직이 아닐까요. 그가 나를 사랑하길래 나를 위해서 질투를 가지는 것이 아니오.
+설사 질투가 그로 하여금 칼을 들어 내 가슴을 찌르게 하였다 하더라도 나는 감사한 생각을 가지고 눈을 감을 것이오. 사랑하는 자는 질투한다고 하오. 질투를 누르는 것도 아름다운 일이지마는 질투에 타는 것도 아름다운 일이 아닐까요.
+덜크럭덜크럭 하고 차바퀴가 철로길을 넘어가는 소리가 나더니 이윽고 마차는 섰소.
+앞에 빨갛게 불이 비치오.
+"자 이게 우리 집이오."
+하고 그가 마차에서 뛰어내리는 양이 보이오. 내려 보니까 달이 올라오오. 굉장히 큰 달이, 붉은 달이 지평선으로서 넘석하고 올라오오.
+달빛에 비추인 바를 보면 네모나게 담 담이라기보다는 성을 둘러쌓은 달 뜨는 곳으로 열린 대문을 들어서서 넓은 마당에 내린 것을 발견하였소.
+"아버지!"
+"엄마!"
+하고 아이들이 뛰어나오오. 말만큼이나 큰 개가 네 놈이나 꼬리를 치고 나오오. 그놈들이 주인집 마차 소리를 알아듣고 짖지 아니한 모양이오.
+큰 아이는 계집애로 여남은 살, 작은 아이는 사내로 육칠 세, 모두 중국 옷을 입었소.
+우리는 방으로 들어갔소. 방은 아라사식 절반, 중국식 절반으로 세간이 놓여 있고 벽에는 조선 지도와 단군의 초상이 걸려 있소.
+그들 부처는 지도와 단군 초상 앞에 허리를 굽혀 배례하오. 나도 무의식적으로 그대로 하였소.
+그는 차를 마시며 이렇게 말하오.
+"우리는 자식들을 이 흥안령 가까운 무변 광야에서 기르는 것으로 낙을 삼고 있지요. 조선 사람들은 하도 마음이 작아서 걱정이니 이런 호호탕탕한 넓은 벌판에서 길러나면 마음이 좀 커질까 하지요. 또 흥안령 밑에서 지나 중원을 통일한 제왕이 많이 났으니 혹시나 그 정기가 남아 있을까 하지요. 우리 부처의 자손이 몇 대를 두고 퍼지는 동안에는 행여나 마음 큰 인물이 하나 둘 날는지 알겠어요, 하하하하."
+하고 그는 제 말을 제가 비웃는 듯이 한바탕 웃고 나서,
+"그러나 이건 내 진정이외다. 우리도 이렇게 고국을 떠나 있지마는 그래도 고국 소식이 궁금해서 신문 하나는 늘 보지요. 하지만 어디 시원한 소식이 있어요. 그저 조리복소니가 되어가는 것이 아니면 조그마한 생각을 가지고, 눈곱만한 야심을 가지고, 서 푼어치 안 되는 이상을 가지고 찧고 까불고 싸우고 하는 것밖에 안 보이니 이거 어디 살 수가 있나. 그래서 나는 마음 큰 자손을 낳아서 길러 볼까 하고 이를테면 새 민족을 하나 만들어 볼까 하고, 둘째 단군, 둘째 아브라함이나 하나 낳아 볼까 하고 하하하하앗하."
+하고 유쾌하게, 그러나 비통하게 웃소.
+나는 저녁을 굶어서 배가 고프고, 밤길을 걸어서 몸이 곤한 것도 잊고 그의 말을 들었소.
+부인이 김이 무럭무럭 나는 호떡을 큰 뚝배기에 담고 김치를 작은 뚝배기에 담고, 또 돼지고기 삶은 것을 한 접시 담아다가 탁자 위에 놓소.
+건넌방이라고 할 만한 방에서 젖먹이 우는 소리가 들리오. 부인은 삼십이나 되었을까, 남편은 서른댓 되었을 듯한 키가 훨쩍 크고 눈과 코가 크고 손도 큰 건장한 대장부요, 음성이 부드러운 것이 체격에 어울리지 아니하나 그것이 아마 그의 정신 생활이 높은 표겠지요.
+"신문에서 최 선생이 학교를 고만두시게 되었다는 말도 보았지요. 그러나 나는 그것이 다 최 선생에게 대한 중상인 줄을 짐작하였고, 또 오늘 이렇게 만나 보니까 더구나 그것이 다 중상인 줄을 알지요."
+하고 그는 확신 있는 어조로 말하오.
+"고맙습니다."
+나는 이렇게밖에 대답할 말이 없었소.
+"아, 머, 고맙다고 하실 것도 없지요."
+하고 그는 머리를 뒤로 젖히고 한참이나 생각을 하더니 우선 껄껄 한바탕 웃고 나서,
+"내가 최 선생이 당하신 경우와 꼭 같은 경우를 당하였거든요. 이를테면 과부 설움은 동무 과부가 안다는 것이지요."
+하고 그는 자기의 내력을 말하기 시작하오.
+"내 집은 본래 서울입니다. 내가 어렸을 적에 내 선친께서 시국에 대해서 불평을 품고 당신 삼 형제의 가족을 끌고 재산을 모두 팔아 가지고 간도에를 건너오셨지요. 간도에 맨 먼저 ●●학교를 세운 이가 내 선친이지요."
+여기까지 하는 말을 듣고 나는 그가 누구인지를 알았소. 그는 R씨라고 간도 개척자요, 간도에 조선인 문화를 세운 이로 유명한 이의 아들인 것이 분명하오. 나는 그의 이름이 누구인지도 물어 볼 것 없이 알았소.
+"아 그러십니까. 네, 그러세요."
+하고 나는 감탄하였소.
+"네, 내 선친을 혹 아실는지요. 선친의 말씀이 노 그러신단 말씀야요. 조선 사람은 속이 좁아서 못쓴다고 <정감록>에도 그런 말이 있다고 조선은 산이 많고 들이 좁아서 사람의 마음이 작아서 큰일하기가 어렵고, 큰사람이 나기가 어렵다고. 웬만치 큰사람이 나면 서로 시기해서 큰일할 새가 없이 한다고 그렇게 <정감록>에도 있다더군요. 그래서 선친께서 자손에게나 희망을 붙이고 간도로 오신 모양이지요. 거기서 자라났다는 것이 내 꼴입니다마는, 아하하.
+내가 자라서 아버지께서 세우신 K여학교의 교사로 있을 때 일입니다. 지금 내 아내는 그 때 학생으로 있었구. 그러자 내 아버지께서 재산이 다 없어져서 학교를 독담하실 수가 없고, 또 얼마 아니해서 아버지께서 돌아가시고 보니 학교에는 세력 다툼이 생겨서 아버지의 후계자로 추정되는 나를 배척하게 되었단 말씀이오. 거기서 나를 배척하는 자료를 삼은 것이 나와 지금 내 아내가 된 학생의 관계란 것인데 이것은 전연 무근지설인 것은 말할 것도 없소. 나도 총각이요, 그는 처녀니까 혼인을 하자면 못 할 것도 없지마는 그것이 사제 관계라면 중대 문제거든. 그래서 나는 단연히 사직을 하고 내가 사직한 것은 제 죄를 승인한 것이라 하여서 그 학생 지금 내 아내도 출교 처분을 당한 것이오. 그러고 보니, 그 여자의 아버지 내 장인이지요 그 여자의 아버지는 나를 죽일 놈같이 원망을 하고 그 딸을 죽일 년이라고 감금을 하고 어쨌으나 조그마한 간도 사회에서 큰 파문을 일으켰단 말이오.
+이 문제를 더 크게 만든 것은 지금 내 아내인, 그 딸의 자백이오. 무어라고 했는고 하니, 나는 그 사람을 사랑하오, 그 사람한테가 아니면 시집을 안 가오, 하고 뻗댔단 말요.
+나는 이 여자가 이렇게 나를 생각하는가 할 때 의분심이 나서 나는 어떻게 해서든지 이 여자와 혼인하리라고 결심을 하였소. 나는 마침내 정식으로 K장로라는 내 장인에게 청혼을 하였으나 단박에 거절을 당하고 말았지요. K장로는 그 딸을 간도에 두는 것이 옳지 않다고 해서 서울로 보내기로 하였단 말을 들었소. 그래서 나는 최후의 결심으로 그 여자 지금 내 아내 된 사람을 데리고 간도에서 도망하였소. 하하하하. 밤중에 단둘이서.
+지금 같으면야 사제간에 결혼을 하기로 그리 큰 문제가 될 것이 없지마는 그 때에 어디 그랬나요. 사제간에 혼인이란 것은 부녀간에 혼인한다는 것과 같이 생각하였지요. 더구나 그 때 간도 사회에는 청교도적 사상과 열렬한 애국심이 있어서 도덕 표준이 여간 높지 아니하였지요. 그런 시대니까 내가 내 제자인 여학생을 데리고 달아난다는 것은 살인 강도를 하는 이상으로 무서운 일이었지요. 지금도 나는 그렇게 생각합니다마는.
+그래서 우리 두 사람은 우리 두 사람이라는 것보다도 내 생각에는 어찌하였으나 나를 위해서 제 목숨을 버리려는 그에게 사실 나도 마음 속으로는 그를 사랑하였지요. 다만 사제간이니까 영원히 달할 수는 없는 사랑이라고 단념하였을 뿐이지요. 그러니까 비록 부처 생활은 못 하더라도 내가 그의 사랑을 안다는 것과 나도 그를 이만큼 사랑한다는 것만을 보여 주자는 것이지요.
+때는 마침 가을이지마는, 몸에 지닌 돈도 얼마 없고 천신만고로 길림까지를 나와 가지고는 배를 타고 송화강을 내려서 하얼빈에 가 가지고 거 기서 간신히 치타까지의 여비와 여행권을 얻어 가지고 차를 타고 떠나지 않았어요. 그것이 바로 십여 년 전 오늘이란 말이오."
+이 때에 부인이 옥수수로 만든 국수와 감자 삶은 것을 가지고 들어오오.
+나는 R의 말을 듣던 끝이라 유심히 부인을 바라보았소. 그는 중키나 되는 둥근 얼굴이 혈색이 좋고 통통하여 미인이라기보다는 씩씩한 여자요. 그런 중에 조선 여자만이 가지는 아담하고 점잖은 맛이 있소.
+"앉으시지요. 지금 두 분께서 처음 사랑하시던 말씀을 듣고 있습니다."
+하고 나는 부인에게 교의를 권하였소.
+"아이, 그런 말씀은 왜 하시오."
+하고 부인은 갑자기 십 년이나 어려지는 모양으로 수삽한 빛을 보이고 고개를 숙이고 달아나오.
+"그래서요. 그래 오늘이 기념일이외다그려."
+하고 나도 웃었소.
+"그렇지요. 우리는 해마다 오늘이 오면 우리 무덤에 성묘를 가서 하룻밤을 새우지요. 오늘은 손님이 오셔서 중간에 돌아왔지만, 하하하하."
+하고 그는 유쾌하게 웃소.
+"성묘라니?"
+하고 나는 물었소.
+"아까 보신 두 별 무덤 말이오. 그것이 우리 내외의 무덤이지요. 하하하하."
+"…………."
+나는 영문을 모르고 가만히 앉았소.
+"내 이야기를 들으시지요. 그래 둘이서 차를 타고 오지 않았겠어요. 물론 여전히 선생님과 제자지요. 그렇지만 워낙 여러 날 단둘이서 같이 고생을 하고 여행을 했으니 사랑의 불길이 탈 것이야 물론 아니겠어요. 다만 사제라는 굳은 의리가 그것을 겉에 나오지 못하도록 누른 것이지요. ……그런데 꼭 오늘같이 좋은 날인데 여기는 대개 일기가 일정합니다. 좀체로 비가 오는 일도 없고 흐리는 날도 없지요. 헌데 F역에를 오니까 참 석양 경치가 좋단 말이오. 그 때에 불현듯, 에라 여기서 내려서 이 석양 속에 저 호숫 가에 둘이서 헤매다가 깨끗이 사제의 몸으로 이 깨끗한 광야에 묻혀 버리자 하는 생각이 나겠지요. 그래 그 때 말을 내 아내 그 때에는 아직 아내가 아니지요 내 아내에게 그런 말을 하였더니 참 좋다고 박장을 하고 내 어깨에 매달리는구려. 그래서 우리 둘은 차가 거의 떠날 임박해서 차에서 뛰어내렸지요."
+하고 그는 그때 광경을 눈앞에 그리는 모양으로 말을 끊고 우두커니 허공을 바라보오. 그러나 그의 입 언저리에는 유쾌한 회고에서 나오는 웃음이었소.
+"이야기 다 끝났어요?"
+하고 부인이 크바스라는 청량 음료를 들고 들어오오.
+"아니오. 이제부터가 정통이니 당신도 거기 앉으시오. 지금 차에서 내린 데까지 왔는데 당신도 앉아서 한 파트를 맡으시오."
+하고 R는 부인의 손을 잡아서 자리에 앉히오. 부인도 웃으면서 앉소.
+"최 선생 처지가 꼭 나와 같단 말요. 정임의 처지가 당신과 같고."
+하고 그는 말을 계속하오.
+"그래 차에서 내려서 나는 이 양반하고 물을 찾아 헤매었지요. 아따, 석양이 어떻게 좋은지 이 양반은 박장을 하고 노래를 부르고 우리 둘은 마치 유쾌하게 산보하는 사람 같았지요."
+"참 좋았어요. 그 때에는 참 좋았어요. 그 석양에 비친 광야와 호수라는 건 어떻게 좋은지 그 수은 같은 물 속에 텀벙 뛰어들고 싶었어요. 그 후엔 해마다 보아도 그만 못해."
+하고 부인이 참견을 하오.
+아이들은 다 자는 모양이오.
+"그래 지향없이 헤매는데 해는 뉘엿뉘엿 넘어가구, 어스름은 기어들고 그 때 마침 하늘에는 별 둘이 나타났단 말이야. 그것을 이 여학생이 먼저 보고서 갑자기 추연해지면서 선생님 저 별 보셔요, 앞선 큰 별은 선생님이 구 따라가는 작은 별은 저야요, 하겠지요. 그 말이, 또 그 태도가 어떻게 가련한지. 그래서 나는 하늘을 바라보니깐 과연 별 두 개가 지는 해를 따르는 듯이 따라간다 말요. 말을 듣고 보니 과연 우리 신세와도 같지 않아요?
+그리고는 이 사람이 또 이럽니다그려 `선생님, 앞선 큰 별은 아무리 따라도 저 작은 별은 영원히 따라잡지 못하겠지요. 영원히 영원히 따라가다가 따라가다가 못 해서 마침내는 저 작은 별은 죽어서 검은 재가 되고 말겠지요? 저 작은 별이 제 신세와 어쩌면 그리 같을까.' 하고 한탄을 하겠지요. 그 때에 한탄을 하고 눈물을 흘리고 섰는 어린 처녀의 석양빛에 비췬 모양을 상상해 보세요, 하하하하. 그 때에는 당신도 미인이었소. 하하하하."
+하고 내외가 유쾌하게 웃는 것을 보니 나는 더욱 적막하여짐을 깨달았소. 어쩌면 그 석양, 그 두 별이 이들에게와 내게 꼭 같은 인상을 주었을까 하니 참으로 이상하다 하였소.
+"그래 인제."
+하고 R는 다시 이야기를 계속하오.
+"그래 인제 둘이서 그야말로 감개무량하게 두 별을 바라보며 걸었지요. 그러다가 해가 넘어가고 앞선 큰 별이 넘어가고 그리고는 혼자서 깜빡깜빡하고 가던 작은 별이 넘어가니 우리는 그만 땅에 주저앉았소. 거기가 어딘고 하니 그 두 별 무덤이 있는 곳이지요. `선생님 저를 여기다가 파묻어 주시고 가셔요. 선생님 손수 저를 여기다가 묻어 놓고 가 주셔요.' 하고 이 사람이 조르지요."
+하는 것을 부인은,
+"내가 언제."
+하고 남편을 흘겨보오.
+"그럼 무에라고 했소? 어디 본인이 한 번 옮겨 보오."
+하고 R가 말을 끊소.
+"간도를 떠난 지가 한 달이 되도록 단둘이 다녀도 요만큼도 귀해 주는 점이 안 뵈니 그럼 파묻어 달라고 안 해요?"
+하고 부인은 웃소.
+"흥흥."
+하고 R는 부인의 말에 웃고 나서,
+"그 자리에 묻어 달란 말을 들으니까, 어떻게 측은한지, 그럼 나도 함께 묻히자고 그랬지요. 나는 그 때에 참말 그 자리에 함께 묻히고 싶었어요. 그래서 나는 손으로 곧 구덩이를 팠지요. 떡가루 같은 모래판이니까 파기는 힘이 아니 들겠지요. 이이도 물끄러미 내가 땅을 파는 것을 보고 섰더니만 자기도 파기를 시작하겠지요."
+하고 내외가 다 웃소.
+"그래 순식간에……."
+하고 R는 이야기를 계속하오.
+"순식간에 둘이 드러누울 만한 구덩이를 아마 두 자 깊이나 되게, 네모나게 파 놓고는 내가 들어가 누워 보고 그러고는 또 파고 하여 아주 편안한 구덩이를 파고 나서는 나는 아주 세상을 하직할 셈으로 사방을 둘러보 고 사방이래야 컴컴한 어둠밖에 없지만 사방을 둘러보고, 이를테면 세상과 작별을 하고 드러누웠지요. 지금 이렇게 회고담을 할 때에는 우습기도 하지마는 그 때에는 참으로 종교적이라 할 만한 엄숙이었소. 그때 우리 둘의 처지는 앞도 절벽, 뒤도 절벽이어서 죽는 길밖에 없었지요. 또 그뿐 아니라 인생의 가장 깨끗하고 가장 사랑의 맑은 정이 타고 가장 기쁘고도 슬프고도 이를테면 모든 감정이 절정에 달하고, 그러한 순간에 목숨을 끊어 버리는 것이 가장 좋은 일이요, 가장 마땅한 일같이 생각하였지요. 광야에 아름다운 황혼이 순간에 스러지는 모양으로 우리 두 생명의 아름다움도 순간에 스러지자는 우리는 철학자도 시인도 아니지마는 우리들의 환경이 우리 둘에게 그러한 생각을 넣어 준 것이지요.
+그래서 내가 가만히 드러누워 있는 것을 저이가 물끄러미 보고 있더니 자기도 내 곁에 들어와 눕겠지요. 그런 뒤에는 황혼에 남은 빛도 다 스러지고 아주 캄캄한 암흑 세계가 되어 버렸지요. 하늘에 어떻게 그렇게 별이 많은지. 가만히 하늘을 바라보노라면 참 별이 많아요. 우주란 참 커요. 그런데 이 끝없이 큰 우주에 한없이 많은 별들이 다 제자리를 지키고 제 길을 지켜서 서로 부딪지도 아니하고 끝없이 긴 시간에 질서를 유지하고 있는 것을 보면 우주에는 어떤 주재하는 뜻, 섭리하는 뜻이 있다 하는 생각이 나겠지요. 나도 예수교인의 가정에서 자라났지마는 이 때처럼 하나님이라 할까 이름은 무엇이라고 하든지 간에 우주의 섭리자의 존재를 강렬하게 의식한 일은 없었지요.
+그렇지만 `사람의 마음에 비기면 저까짓 별들이 다 무엇이오?' 하고 그때 겨우 열여덟 살밖에 안 된 이이가 내 귀에 입을 대고 말할 때에는 나도 참으로 놀랐습니다. 나이는 나보다 오륙 년 상관밖에 안 되지마는 이십 세 내외에 오륙 년 상관이 적은 것인가요? 게다가 나는 선생이요 자기는 학생이니까 어린애로만 알았던 것이 그런 말을 하니 놀랍지 않아요? 어째서 사람의 마음이 하늘보다도 더 이상할까 하고 내가 물으니까, 그 대답이 `나는 무엇이라고 설명할 수가 없지마는 내 마음 속에 일어나는 것이 하늘이나 땅에 일어나는 모든 것보다도 더 아름답고 더 알 수 없고 더 뜨겁고 그런 것 같아요.' 그러겠지요. 생명이란 모든 아름다운 것 중에 가장 아름다운 것이라는 것을 나는 깨달았어요. 그 말에, `그렇다 하면 이 아름답고 신비한 생명을 내는 우주는 더 아름다운 것이 아니오?' 하고 내가 반문하니까, 당신(부인을 향하여) 말이, `전 모르겠어요, 어쨌으나 전 행복합니다. 저는 이 행복을 깨뜨리고 싶지 않습니다. 놓쳐 버리고 싶지 않습니다. 이 행복 선생님 곁에 있는 이 행복을 꽉 안고 죽고 싶어요.' 그러지 않았소?"
+"누가 그랬어요? 아이 난 다 잊어버렸어요."
+하고 부인은 차를 따르오. R는 인제는 하하하 하는 웃음조차 잊어버리고, 부인에게 농담을 붙이는 것조차 잊어버리고, 그야말로 종교적 엄숙 그대로말을 이어,
+"`자 저는 약을 먹어요.' 하고 손을 입으로 가져가는 동작이 감행되겠지요. 약이란 것은 하얼빈에서 준비한 아편이지요. 하얼빈서 치타까지 가는 동안에 흥안령이나 어느 삼림지대나 어디서나 죽을 자리를 찾자고 준비한 것이니까. 나는 입 근처로 가는 그의 손을 붙들었어요. 붙들면서 나는 `잠깐만 기다리오. 오늘 밤 안으로 그 약을 먹으면 고만이 아니오? 이 행복된 순간을 잠깐이라도 늘립시다. 달 올라올 때까지만.' 나는 이렇게 말했지요. `선생님도 행복되셔요? 선생님은 불행이시지. 저 때문에 불행이시지. 저만 이곳에 묻어 주시구는 선생님은 세상에 돌아가 사셔요, 오래오래 사셔요, 일 많이 하고 사셔요.' 하고 울지 않겠어요. 나는 그 때에 내 아내가 하던 말을 한 마디도 잊지 아니합니다. 그 말을 듣던 때의 내 인상은 아마 일생 두고 잊히지 아니하겠지요.
+나는 자백합니다. 그 순간에 나는 처음으로 내 아내를 안고 키스를 하였지요. 내 속에 눌리고 눌리고 쌓이고 하였던 열정이 그만 일시에 폭발되었던 것이오. 아아 이것이 최초의 것이요, 동시에 최후의 것이로구나 할 때에 내 눈에서는 끓는 듯한 눈물이 흘렀소이다. 두 사람의 심장이 뛰는 소리, 두 사람의 풀무 불길 같은 숨소리.
+이윽고 달이 떠올라 왔습니다. 가이없는 벌판이니까 달이 뜨니까 갑자기 천지가 환해지고 우리 둘이 손으로 파서 쌓아 놓은 흙무더기가 이 산 없는 세상에 산이나 되는 것같이 조그마한 검은 그림자를 지고 있겠지요. `자 우리 달빛을 띠고 좀 돌아다닐까.' 하고 나는 아내를 안아 일으켰지요. 내 팔에 안겨서 고개를 뒤로 젖힌 내 아내의 얼굴이 달빛에 비친 양을 나는 잘 기억합니다. 실신한 듯한, 만족한 듯한, 그리고도 절망한 듯한 그 표정을 무엇으로 그릴지 모릅니다. 그림도 그릴 줄 모르고 조각도 할 줄 모르고 글도 쓸 줄 모르는 내가 그것을 어떻게 그립니까. 그저 가슴 속에 품고 이렇게 오늘의 내 아내를 바라볼 뿐이지요.
+나는 내 아내를 팔에 걸고 네, 걸었다고 하는 것이 가장 합당하지 요 이렇게 팔에다 걸고 달빛을 받은 황량한 벌판, 아무리 하여도 환하게 밝아지지는 아니하는 벌판을 헤매었습니다. 이따금 내 아내가, `어서 죽고 싶어요, 전 죽고만 싶어요.' 하는 말에는 대답도 아니 하고. 죽고 싶다는 그 말은 물론 진정일 것이지요. 아무리 맑은 일기라 하더라도 오후가 되면 흐려지는 법이니까 오래 살아가는 동안에 늘 한 모양으로 이 순간같이 깨끗하고 뜨거운 기분으로 갈 수는 없지 않아요? 불쾌한 일도 생기고, 보기 흉한 일도 생길는지 모르거든. 그러니까 이 완전한 깨끗과 완전한 사랑과 완전한 행복 속에 죽어 버리자는 뜻을 나는 잘 알지요. 더구나 우리들이 살아 남는대야 앞길이 기구하지 평탄할 리는 없지 아니해요? 그래서 나는 `죽지, 우리 이 달밤에 실컷 돌아다니다가, 더 돌아다니기가 싫거든 그 구덩에 돌아가서 약을 먹읍시다.' 이렇게 말하고 우리 둘은 헤맸지요. 낮에 보면 어디까지나 평평한 벌판인 것만 같지마는 달밤에 보면 이 사막에도 아직 채 스러지지 아니한 산의 형적이 남아 있어서 군데군데 거뭇거뭇한 그림자가 있겠지요. 그 그림자 속에는 걸어 들어가면 어떤 데는 우리 허리만큼 그림자에 가리우고 어떤 데는 우리 둘을 다 가리워 버리는 데도 있단 말야요. 죽음의 그림자라는 생각이 나면 그래도 몸에 소름이 끼쳐요.
+차차 달이 높아지고 추위가 심해져서 바람결이 지나갈 때에는 눈에서 눈물이 날 지경이지요. 원체 대기 중에 수분이 적으니까 서리도 많지 않지마는, 그래도 대기 중에 있는 수분은 다 얼어 버려서 얼음가루가 되었는 게지요. 공중에는 반짝반짝하는 수정가루 같은 것이 보입니다. 낮에는 땀이 흐르리만큼 덥던 사막도 밤이 되면 이렇게 기온이 내려가지요. 춥다고 생각은 하면서도 춥다는 말은 아니 하고 우리는 어떤 때에는 달을 따라서, 어떤 때에는 달을 등지고, 어떤 때에는 호수에 비친 달을 굽어보고, 이 모양으로 한없이 말도 없이 돌아다녔지요. 이 세상 생명의 마지막 순간을 힘껏 의식하려는 듯이.
+마침내 `나는 더 못 걸어요.' 하고 이이가 내 어깨에 매달려 버리고 말았지요."
+하고 R가 부인을 돌아보니 부인은 편물하던 손을 쉬고,
+"다리가 아픈 줄은 모르겠는데 다리가 이리 뉘구 저리 뉘구 해서 걸음을 걸을 수가 없었어요. 춥기는 하구."
+하고 소리를 내어서 웃소.
+"그럴 만도 하지."
+하고 R는 긴장한 표정을 약간 풀고 앉은 자세를 잠깐 고치며,
+"그 후에 그 날 밤 돌아다닌 곳을 더듬어 보니까, 자세히는 알 수 없지마는 삼십 리는 더 되는 것 같거든. 다리가 아프지 아니할 리가 있나."
+하고 차를 한 모금 마시고 나서 말을 계속하오.
+"그래서 나는 내 외투를 벗어서, 이이(부인)를 싸서 어린애 안듯이 안고 걸었지요. 외투로 쌌으니 자기도 춥지 않구, 나는 또 무거운 짐을 안았으니 땀이 날 지경이구, 그뿐 아니라 내가 제게 주는 최후의 서비스라 하니 기쁘고, 말하자면 일거 삼득이지요. 하하하하. 지난 일이니 웃지마는 그 때 사정을 생각해 보세요, 어떠했겠나."
+하고 R는 약간 처참한 빛을 띠면서,
+"그러니 그 구덩이를 어디 찾을 수가 있나. 얼마를 찾아 돌아다니다가 아무 데서나 죽을 생각도 해 보았지마는 몸뚱이를 그냥 벌판에 내놓고 죽고 싶지는 아니하고 또 그 구덩이가 우리 두 사람에게 특별한 의미가 있는 것 같아서 기어코 그것을 찾아 내고야 말았지요. 그 때는 벌써 새벽이 가까웠던 모양이오. 열 시나 넘어서 뜬 하현달이 낮이 기울었으니 그렇지 않겠어요. 그 구덩이에 와서 우리는 한 번 더 하늘과 달과 별과, 그리고 마음 속에 떠오른 사람들과 하직하고 약 먹을 준비를 했지요.
+약을 검은 고약과 같은 아편을 맛이 쓰다는 아편을 물도 없이 먹으려 들었지요.
+우리 둘은 아까 모양으로 가지런히 누워서 하늘을 바라보았는데 달이 밝으니까 보이던 별들 중에 숨은 별이 많고 또 별들의 위치 우리에게 낯익은 북두칠성 자리도 변했을 것 아니야요. 이상한 생각이 나요. 우리가 벌판으로 헤매는 동안에 천지가 모두 변한 것 같아요. 사실 변하였지요. 그 변한 것이 우스워서 나는 껄껄 웃었지요. 워낙 내가 웃음이 좀 헤프지만 이 때처럼 헤프게 실컷 웃어 본 일은 없습니다.
+왜 웃느냐고 아내가 좀 성을 낸 듯이 묻기로, `천지와 인생이 변하는 것이 우스워서 웃었소.' 그랬지요. 그랬더니, `천지와 인생은 변할는지 몰라도 내 마음은 안 변해요!' 하고 소리를 지르겠지요. 퍽 분개했던 모양이야."
+하고 R는 그 아내를 보오.
+"그럼 분개 안 해요? 남은 죽을 결심을 하고 발발 떨구 있는데 곁에서 껄껄거리고 웃으니, 어째 분하지가 않아요. 나는 분해서 달아나려고 했어요."
+하고 부인은 아직도 분함이 남은 것같이 말하오.
+"그래 달아나지 않았소?"
+하고 R는 부인이 벌떡 일어나서 비틀거리고 달아나는 흉내를 팔과 다리로 내고 나서,
+"이래서 죽는 시간이 지체가 되었지요. 그래서 내가 빌고 달래고 해서 가까스로 안정을 시키고 나니 손에 쥐었던 아편이 땀에 푹 젖었겠지요. 내가 웃은 것은 죽기 전 한 번 천지와 인생을 웃어 버린 것인데 그렇게 야단이니…… 하하하하."
+R는 식은 차를 한 모금 더 마시며,
+"참 목도 마르기도 하더니. 입에는 침 한 방울 없고. 그러나 못물을 먹을 생각도 없고. 나중에는 말을 하려고 해도 혀가 안 돌아가겠지요.
+이러는 동안에 달빛이 희미해지길래 웬일인가 하고 고개를 번쩍 들었더니 해가 떠오릅니다그려. 어떻게 붉고 둥글고 씩씩한지. `저 해 보오.' 하고 나는 기계적으로 벌떡 일어나서 구덩이에서 뛰어나왔지요."
+하고 빙그레 웃소. R의 빙그레 웃는 양이 참 좋았소.
+"내가 뛰어나오는 것을 보고 이이도 뿌시시 일어났지요. 그 해! 그 해의 새 빛을 받는 하늘과 땅의 빛! 나는 그것을 형용할 말을 가지지 못합니다. 다만 힘껏 소리치고 싶고 기운껏 달음박질치고 싶은 생각이 날 뿐이어요.
+`우리 삽시다, 죽지 말고 삽시다, 살아서 새 세상을 하나 만들어 봅시다.' 이렇게 말하였지요. 하니까 이이가 처음에는 깜짝 놀라는 것 같아요. 그러나 마침내 아내도 죽을 뜻을 변하였지요. 그래서 남 선생을 청하여다가 그 말씀을 여쭈었더니 남 선생께서 고개를 끄덕끄덕하시고 우리 둘의 혼인 주례를 하셨지요. 그 후 십여 년에 우리는 밭 갈고 아이 기르고 이런 생활을 하고 있는데 언제나 여기 새 민족이 생기고 누가 새 단군이 될는지요. 하하하하, 아하하하. 피곤하시겠습니다. 이야기가 너무 길어서."
+하고 R는 말을 끊소.
+나는 R부처가 만류하는 것도 다 뿌리치고 여관으로 돌아왔소. R와 함께 달빛 속, 개 짖는 소리 속을 지나서 아라사 사람의 조그마한 여관으로 돌아왔소. 여관 주인도 R를 아는 모양이어서 반갑게 인사하고 또 내게 대한 부탁도 하는 모양인가 보오.
+R는 내 방에 올라와서 내일 하루 지날 일도 이야기하고 또 남 선생과 정임에게 관한 이야기도 하였으나, 나는 그가 무슨 이야기를 하는지 잘 들을 만한 마음의 여유도 없어서 마음 없는 대답을 할 뿐이었소.
+R가 돌아간 뒤에 나는 옷도 벗지 아니하고 침대에 드러누웠소. 페치카를 때기는 한 모양이나 방이 써늘하기 그지없소.
+`그 두 별 무덤이 정말 R와 그 여학생과 두 사람이 영원히 달치 못할 꿈을 안은 채로 깨끗하게 죽어서 묻힌 무덤이었으면 얼마나 좋을까. 만일 그렇다 하면 내일 한 번 더 가서 보토라도 하고 오련마는.'
+하고 나는 R부처의 생활에 대하여 일종의 불만과 환멸을 느꼈소.
+그리고 내가 정임을 여기나 시베리아나 어떤 곳으로 불러다가 만일 R와 같은 흉내를 낸다 하면, 하고 생각해 보고는 나는 진저리를 쳤소. 나는 내머리 속에 다시 그러한 생각이 한 조각이라도 들어올 것을 두려워하였소.
+급행을 기다리자면 또 사흘을 기다리지 아니하면 아니 되기로 나는 이튿날 새벽에 떠나는 구간차를 타고 F역을 떠나 버렸소. R에게는 고맙다는 편지 한 장만을 써 놓고. 나는 R를 더 보기를 원치 아니하였소. 그것은 반드시 R를 죄인으로 보아서 그런 것은 아니오마는 그저 나는 다시 R를 대면하기를 원치 아니한 것이오.
+나는 차가 R의 집 앞을 지날 때에도 R의 집에 대하여서는 외면하였소.
+이 모양으로 나는 흥안령을 넘고, 하일라르의 솔밭을 지나서 마침내 이 곳에 온 것이오.
+형! 나는 인제는 이 편지를 끝내오. 더 쓸 말도 없거니와 인제는 이것을 쓰기도 싫증이 났소.
+이 편지를 쓰기 시작할 때에는 바이칼에 물결이 흉용하더니 이 편지를 끝내는 지금에는 가의 가까운 물에는 얼음이 얼었소. 그리고 저 멀리 푸른 물이 늠실늠실 하얗게 눈 덮인 산 빛과 어울리게 되었소.
+사흘이나 이어서 오던 눈이 밤새에 개고 오늘 아침에는 칼날 같은 바람이 눈을 날리고 있소.
+나는 이 얼음 위로 걸어서 저 푸른 물 있는 곳까지 가고 싶은 유혹을 금할 수 없소. 더구나 이 편지도 다 쓰고 나니, 인제는 내가 이 세상에서 할 마지막 일까지 다 한 것 같소.
+내가 이 앞에 어디로 가서 어찌 될는지는 나도 모르지마는 희미한 소원을 말하면 눈 덮인 시베리아의 인적 없는 삼림 지대로 한정 없이 헤매다가 기운 진하는 곳에서 이 목숨을 마치고 싶소.
+최석 군은 `끝'이라는 글자를 썼다가 지워 버리고 딴 종이에다가 이런 말을 썼다
+다 쓰고 나니 이런 편지도 다 부질없는 일이오. 내가 이런 말을 한대야 세상이 믿어 줄 리도 없지 않소. 말이란 소용 없는 것이오. 내가 아무리 내 아내에게 말을 했어도 아니 믿었거든 내 아내도 내 말을 아니 믿었거든 하물며 세상이 내 말을 믿을 리가 있소. 믿지 아니할 뿐 아니라 내 말 중에서 자기네 목적에 필요한 부분만은 믿고, 또 자기네 목적에 필요한 부분은 마음대로 고치고 뒤집고 보태고 할 것이니까, 나는 이 편지를 쓴 것이 한 무익하고 어리석은 일인 줄을 깨달았소.
+형이야 이 편지를 아니 보기로니 나를 안 믿겠소? 그 중에는 혹 형이 지금까지 모르던 자료도 없지 아니하니, 형만 혼자 보시고 형만 혼자 내 사정을 알아 주시면 다행이겠소. 세상에 한 믿는 친구를 가지는 것이 저마다 하는 일이겠소?
+나는 이 쓸데없는 편지를 몇 번이나 불살라 버리려고 하였으나 그래도 거기도 일종의 애착심이 생기고 미련이 생기는구려. 형 한 분이라도 보여 드리고 싶은 마음이 생기는구려. 내가 S형무소에 입감해 있을 적에 형무소 벽에 죄수가 손톱으로 성명을 새긴 것을 보았소. 뒤에 물었더니 그것은 흔히 사형수가 하는 짓이라고. 사형수가 교수대에 끌려 나가기 바로 전에 흔히 손톱으로 담벼락이나 마룻바닥에 제 이름을 새기는 일이 있다고 하는 말을 들었소. 내가 형에게 쓰는 이 편지도 그 심리와 비슷한 것일까요?
+형! 나는 보통 사람보다는, 정보다는 지로, 상식보다는 이론으로, 이해보다는 의리로 살아 왔다고 자신하오. 이를테면 논리학적으로 윤리학적으로 살아온 것이라고 할까. 나는 엄격한 교사요, 교장이었소. 내게는 의지력과 이지력밖에 없는 것 같았소. 그러한 생활을 수십 년 해 오지 아니하였소? 나는 이 앞에 몇십 년을 더 살더라도 내 이 성격이나 생활 태도에는 변함이 없으리라고 자신하였소. 불혹지년이 지났으니 그렇게 생각하였을 것이 아니오?
+그런데 형! 참 이상한 일이 있소. 그것은 내가 지금까지 처해 있던 환경을벗어나서 호호 탕탕하게 넓은 세계에 알몸을 내어던짐을 당하니 내 마음 속에는 무서운 여러 가지 변화가 일어나는구려. 나는 이 말도 형에게 아니 하려고 생각하였소. 노여워하지 마시오, 내게까지도 숨기느냐고. 그런 것이 아니오, 형은커녕 나 자신에게까지도 숨기려고 하였던 것이오. 혹시 그런 기다리지 아니 하였던 원, 그런 생각이 내 마음의 하늘에 일어나리라고 상상도 아니하였던, 그런 생각이 일어날 때에는 나는 스스로 놀라고 스스로 슬퍼하였소. 그래서 스스로 숨기기로 하였소.
+그 숨긴다는 것이 무엇이냐 하면 그것은 열정이요, 정의 불길이요, 정의 광풍이요, 정의 물결이오. 만일 내 의식이 세계를 평화로운 풀 있고, 꽃 있고, 나무 있는 벌판이라고 하면 거기 난데없는 미친 짐승들이 불을 뿜고 소리를 지르고 싸우고, 영각을 하고 날쳐서, 이 동산의 평화의 화초를 다 짓밟아 버리고 마는 그러한 모양과 같소.
+형! 그 이상야릇한 짐승들이 여태껏, 사십 년 간을 어느 구석에 숨어 있었소? 그러다가 인제 뛰어나와 각각 제 권리를 주장하오?
+지금 내 가슴 속은 끓소. 내 몸은 바짝 여위었소. 그것은 생리학적으로나 심리학적으로나 타는 것이요, 연소하는 것이오. 그래서 다만 내 몸의 지방만이 타는 것이 아니라, 골수까지 타고, 몸이 탈 뿐이 아니라 생명 그 물건이 타고 있는 것이오. 그러면 어찌할까.
+지위, 명성, 습관, 시대 사조 등등으로 일생에 눌리고 눌렸던 내 자아의 일부분이 혁명을 일으킨 것이오? 한 번도 자유로 권세를 부려 보지 못한 본능과 감정들이 내 생명이 끝나기 전에 한 번 날뛰어 보려는 것이오. 이것이 선이오? 악이오?
+그들은 내가 지금까지 옳다고 여기고 신성하다고 여기던 모든 권위를 모조리 둘러엎으려고 드오. 그러나 형! 나는 도저히 이 혁명을 용인할 수가 없소. 나는 죽기까지 버티기로 결정을 하였소. 내 속에서 두 세력이 싸우다가 싸우다가 승부가 결정이 못 된다면 나는 승부의 결정을 기다리지 아니하고 살기를 그만두려오.
+나는 눈 덮인 삼림 속으로 들어가려오. 나는 V라는 대삼림 지대가 어디인 줄도 알고 거기를 가려면 어느 정거장에서 내릴 것도 다 알아 놓았소.
+만일 단순히 죽는다 하면 구태여 멀리 찾아갈 필요도 없지마는 그래도 나 혼자로는 내 사상과 감정의 청산을 하고 싶소. 살 수 있는 날까지 세상을 떠난 곳에서 살다가 완전한 해결을 얻는 날 나는 혹은 승리의, 혹은 패배의 종막을 닫칠 것이오. 만일 해결이 안 되면 안 되는 대로 그치면 그만이지요.
+나는 이 붓을 놓기 전에 어젯밤에 꾼 꿈 이야기 하나는 하려오. 꿈이 하도 수상해서 마치 내 전도에 대한 신의 계시와도 같기로 하는 말이오. 그 꿈은 이러하였소.
+내가 꽁이깨(꼬이까라는 아라사말로 침대라는 말이 조선 동포의 입으로 변한 말이오.) 짐을 지고 삽을 메고 눈이 덮인 삼림 속을 혼자 걸었소. 이 꽁이깨 짐이란 것은 금점꾼들이 그 여행 중에 소용품, 마른 빵, 소금, 내복 등속을 침대 매트리스에 넣어서 지고 다니는 것이오. 이 짐하고 삽 한 개, 도끼 한 개, 그것이 시베리아로 금을 찾아 헤매는 조선 동포들의 행색이오. 내가 이르쿠츠크에서 이러한 동포를 만났던 것이 꿈으로 되어 나온 모양이오.
+나는 꿈에는 세상을 다 잊어버린, 아주 깨끗하고 침착한 사람으로 이 꽁이깨 짐을 지고 삽을 메고 밤인지 낮인지 알 수 없으나 땅은 눈빛으로 희고, 하늘은 구름빛으로 회색인 삼림 지대를 허덕허덕 걸었소. 길도 없는 데를, 인적도 없는 데를.
+꿈에도 내 몸은 퍽 피곤해서 쉴 자리를 찾는 마음이었소.
+나는 마침내 어떤 언덕 밑 한 군데를 골랐소. 그리고 상시에 이야기에서 들은 대로 삽으로 내가 누울 자리만한 눈을 치고, 그리고는 도끼로 곁에 선 나무 몇 개를 찍어 누이고 거기다가 불을 놓고 그 불김에 녹은 땅을 두어 자나 파내고 그 속에 드러누웠소. 훈훈한 것이 아주 편안하였소.
+하늘에는 별이 반짝거렸소. F역에서 보던 바와 같이 큰 별 작은 별도 보이고 평시에 보지 못하던 붉은 별, 푸른 별 들도 보였소. 나는 이 이상한 하늘, 이상한 별들이 있는 하늘을 보고 드러누워 있노라니까 문득 어디서 발자국 소리가 들렸소. 퉁퉁퉁퉁 우루루루…… 나는 벌떡 일어나려 하였으나 몸이 천 근이나 되어서 움직일 수가 없었소. 가까스로 고개를 조금 들고 보니 뿔이 길다랗고 눈이 불같이 붉은 사슴의 떼가 무엇에 놀랐는지 껑충껑충 뛰어 지나가오. 이것은 아마 크로포트킨의 <상호 부조론> 속에 말한 시베리아의 사슴의 떼가 꿈이 되어 나온 모양이오.
+그러더니 그 사슴의 떼가 다 지나간 뒤에, 그 사슴의 떼가 오던 방향으로서 정임이가 걸어오는 것이 아니라 스르륵 하고 미끄러져 오오. 마치 인형을 밀어 주는 것같이.
+"정임아!"
+하고 나는 소리를 치고 몸을 일으키려 하였소.
+정임의 모양은 나를 잠깐 보고는 미끄러지는 듯이 흘러가 버리오.
+나는 정임아, 정임아를 부르고 팔다리를 부둥거렸소. 그러다가 마침내 내 몸이 번쩍 일으켜짐을 깨달았소. 나는 정임의 뒤를 따랐소.
+나는 눈 위로 삼림 속으로 정임의 그림자를 따랐소. 보일 듯 안 보일 듯, 잡힐 듯 안 잡힐 듯, 나는 무거운 다리를 끌고 정임을 따랐소.
+정임은 이 추운 날이언만 눈과 같이 흰 옷을 입었소. 그 옷은 옛날 로마 여인의 옷과 같이 바람결에 펄렁거렸소.
+"오지 마세요. 저를 따라오지 못하십니다."
+하고 정임은 눈보라 속에 가리워 버리고 말았소. 암만 불러도 대답이 없고 눈보라가 다 지나간 뒤에도 붉은 별, 푸른 별과 뿔 긴 사슴의 떼뿐이오. 정임은 보이지 아니하였소. 나는 미칠 듯이 정임을 찾고 부르다가 잠을 깨었소.
+꿈은 이것뿐이오. 꿈을 깨어서 창 밖을 바라보니 얼음과 눈에 덮인 바이칼호 위에는 새벽의 겨울 달이 비치어 있었소. 저 멀리 검푸르게 보이는 것이 채 얼어붙지 아니한 물이겠지요. 오늘 밤에 바람이 없고 기온이 내리면 그것마저 얼어붙을는지 모르지요. 벌써 살얼음이 잡혔는지도 모르지요. 아아, 그 속은 얼마나 깊을까. 나는 바이칼의 물 속이 관심이 되어서 못 견디겠소.
+형! 나는 자백하지 아니할 수 없소. 이 꿈은 내 마음의 어떤 부분을 설명한 것이라고. 그러나 형! 나는 이것을 부정하려오. 굳세게 부정하려오. 나는 이 꿈을 부정하려오. 억지로라도 부정하려오. 나는 결코 내 속에 일어난 혁명을 용인하지 아니하려오. 나는 그것을 혁명으로 인정하지 아니하려오. 아니오! 아니오! 그것은 반란이오! 내 인격의 통일에 대한 반란이오. 단연코 무단적으로 진정하지 아니하면 아니 될 반란이오. 보시오! 나는 굳게 서서 한 걸음도 뒤로 물러서지 아니할 것이오. 만일에 형이 광야에 구르는 내 시체나 해골을 본다든지, 또는 무슨 인연으로 내 무덤을 발견하는 날이 있다고 하면 그 때에 형은 내가 이 모든 반란을 진정한 개선의 군주로 죽은 것을 알아 주시오.
+인제 바이칼에 겨울의 석양이 비치었소. 눈을 인 나지막한 산들이 지는 햇빛에 자줏빛을 발하고 있소. 극히 깨끗하고 싸늘한 광경이오. 아디유!
+이 편지를 우편에 부치고는 나는 최후의 방랑의 길을 떠나오. 찾을 수도 없고, 편지 받을 수도 없는 곳으로.
+부디 평안히 계시오. 일 많이 하시오. 부인께 문안 드리오. 내 가족과 정임의 일 맡기오. 아디유!
+이것으로 최석 군의 편지는 끝났다.
+나는 이 편지를 받고 울었다. 이것이 일 편의 소설이라 하더라도 슬픈 일이어든, 하물며 내가 가장 믿고 사랑하는 친구의 일임에야.
+이 편지를 받고 나는 곧 최석 군의 집을 찾았다. 주인을 잃은 이 집에서는아이들이 마당에서 떠들고 있었다.
+"삼청동 아자씨 오셨수. 어머니, 삼청동 아자씨."
+하고 최석 군의 작은딸이 나를 보고 뛰어들어갔다.
+최석의 부인이 나와 나를 맞았다.
+부인은 머리도 빗지 아니하고, 얼굴에는 조금도 화장을 아니하고, 매무시도 흘러내릴 지경으로 정돈되지 못하였다. 일 주일이나 못 만난 동안에 부인의 모양은 더욱 초췌하였다.
+"노석헌테서 무슨 기별이나 있습니까."
+하고 나는 무슨 말로 말을 시작할지 몰라서 이런 말을 하였다.
+"아니오. 왜 그이가 집에 편지하나요?"
+하고 부인은 성난 빛을 보이며,
+"집을 떠난 지가 근 사십 일이 되건만 엽서 한 장 있나요. 집안 식구가 다 죽기로 눈이나 깜짝할 인가요. 그저 정임이헌테만 미쳐서 죽을지 살지를 모르지요."
+하고 울먹울먹한다.
+"잘못 아십니다. 부인께서 노석의 마음을 잘못 아십니다. 그런 것이 아닙니다."
+하고 나는 확신 있는 듯이 말을 시작하였다.
+"노석의 생각을 부인께서 오해하신 줄은 벌써부터 알았지마는 오늘 노석의 편지를 받아보고 더욱 분명히 알았습니다."
+하고 나는 부인의 표정의 변화를 엿보았다.
+"편지가 왔어요?"
+하고 부인은 놀라면서,
+"지금 어디 있어요? 일본 있지요?"
+하고 질투의 불길을 눈으로 토하였다.
+"일본이 아닙니다. 노석은 지금 아라사에 있습니다."
+"아라사요?"
+하고 부인은 놀라는 빛을 보이더니,
+"그럼 정임이를 데리고 아주 아라사로 가케오치를 하였군요."
+하고 히스테리컬한 웃음을 보이고는 몸을 한 번 떨었다.
+부인은 남편과 정임의 관계를 말할 때마다 이렇게 경련적인 웃음을 웃고 몸을 떠는 것이 버릇이었다.
+"아닙니다. 노석은 혼자 가 있습니다. 그렇게 오해를 마세요."
+하고 나는 보에 싼 최석의 편지를 내어서 부인의 앞으로 밀어 놓으며,
+"이것을 보시면 다 아실 줄 압니다. 어쨌으나 노석은 결코 정임이를 데리고 간 것이 아니요, 도리어 정임이를 멀리 떠나서 간 것입니다. 그러나 그보다도 중대 문제가 있습니다. 노석은 이 편지를 보면 죽을 결심을 한 모양입니다."
+하고 부인의 주의를 질투로부터 그 남편에게 대한 동정에 끌어 보려 하였다.
+"흥. 왜요? 시체 정사를 하나요? 좋겠습니다. 머리가 허연 것이 딸자식 같은 계집애허구 정사를 한다면 그 꼴 좋겠습니다. 죽으라지요. 죽으래요. 죽는 것이 낫지요. 그리구 살아서 무엇 해요?"
+내 뜻은 틀려 버렸다. 부인의 표정과 말에서는 더욱더욱 독한 질투의 안개와 싸늘한 얼음가루가 날았다.
+나는 부인의 이 태도에 반감을 느꼈다. 아무리 질투의 감정이 강하다 하기로, 사람의 생명이 제 남편의 생명이 위태함에도 불구하고 오직 제 질투의 감정에만 충실하려 하는 그 태도가 불쾌하였다. 그래서 나는,
+"나는 그만큼 말씀해 드렸으니 더 할 말씀은 없습니다. 아무려나 좀더 냉정하게 생각해 보세요. 그리고 이것을 읽어 보세요."
+하고 일어나서 집으로 돌아와 버리고 말았다.
+도무지 불쾌하기 그지없는 날이다. 최석의 태도까지도 불쾌하다. 달아나긴 왜 달아나? 죽기는 왜 죽어? 못난 것! 기운 없는 것! 하고 나는 최석이가 곁에 섰기나 한 것처럼 눈을 흘기고 중얼거렸다.
+최석의 말대로 최석의 부인은 악한 사람이 아니요, 그저 보통인 여성일는지 모른다. 그렇다 하면 여자의 마음이란 너무도 질투의 종이 아닐까. 설사 남편 되는 최석의 사랑이 아내로부터 정임에게로 옮아 갔다고 하더라도 그것을 질투로 회복하려는 것은 어리석은 일이다. 이미 사랑이 떠난 남편을 네 마음대로 가거라 하고 자발적으로 내어버릴 것이지마는 그것을 못 할 사정이 있다고 하면 모르는 체하고 내버려 둘 것이 아닌가. 그래도 이것은 우리네 남자의 이론이요, 여자로는 이런 경우에 질투라는 반응밖에 없도록 생긴 것일까 나는 이런 생각을 하고 있었다.
+시계가 아홉시를 친다.
+남대문 밖 정거장을 떠나는 열차의 기적 소리가 들린다.
+나는 만주를 생각하고, 시베리아를 생각하고 최석을 생각하였다. 마음으로는 정임을 사랑하면서 그 사랑을 발표할 수 없어서 시베리아의 눈 덮인 삼림 속으로 방황하는 최석의 모양이 최석의 꿈 이야기에 있는 대로 눈앞에 선하게 떠나온다.
+`사랑은 목숨을 빼앗는다.'
+하고 나는 사랑일래 일어나는 인생의 비극을 생각하였다. 그러나 최석의 경우는 보통 있는 공식과는 달라서 사랑을 죽이기 위해서 제 목숨을 죽이는 것이었다. 그렇다 하더라도,
+`사랑은 목숨을 빼앗는다.'
+는 데에는 다름이 없다.
+나는 불쾌도 하고 몸도 으스스하여 얼른 자리에 누웠다. 며느리가 들어온 뒤부터 사랑 생활을 하는 지가 벌써 오 년이나 되었다. 우리 부처란 인제는 한 역사적 존재요, 윤리적 관계에 불과하였다. 오래 사귄 친구와 같은 익숙함이 있고, 집에 없지 못할 사람이라는 필요감도 있지마는 젊은 부처가 가지는 듯한 그런 정은 벌써 없는 지 오래였다. 아내도 나를 대하면 본체만체, 나도 아내를 대하면 본체만체, 무슨 필요가 있어서 말을 붙이더라도 아무쪼록 듣기 싫기를 원하는 듯이 톡톡 내던졌다. 아내도 근래에 와서는 옷도 아무렇게나, 머리도 아무렇게나, 어디 출입할 때밖에는 도무지 화장을 아니 하였다.
+그러나 그렇다고 우리 부처의 새가 좋지 못한 것도 아니었다. 서로 소중히 여기는 마음도 있었다. 아내가 안에 있다고 생각하면 마음이 든든하고 또 아내의 말에 의하건대 내가 사랑에 있거니 하면 마음이 든든하다고 한다.
+우리 부처의 관계는 이러한 관계다.
+나는 한 방에서 혼자 잠을 자는 것이 습관이 되어서 누가 곁에 있으면 잠이 잘 들지 아니하였다. 혹시 어린것들이 매를 얻어맞고 사랑으로 피난을 와서 울다가 내 자리에서 잠이 들면 귀엽기는 귀여워도 잠자리는 편안치 아니하였다. 나는 책을 보고 글을 쓰고 공상을 하고 있으면 족하였다. 내게는 아무 애욕적 요구도 없었다. 이것은 내 정력이 쇠모한 까닭인지 모른다.
+그러나 최석의 편지를 본 그 날 밤에는 도무지 잠이 잘 들지 아니하였다. 최석의 편지가 최석의 고민이 내 졸던 의식에 무슨 자극을 준 듯하였다. 적막한 듯하였다. 허전한 듯하였다. 무엇인지 모르나 그리운 것이 있는 것 같았다.
+"어, 이거 안되었군."
+하고 나는 벌떡 일어나 담배를 피워 물었다.
+"나으리 주무셔 곕시오?"
+하고 아범이 전보를 가지고 왔다.
+"명조 경성 착 남정임"
+이라는 것이었다.
+"정임이가 와?"
+하고 나는 전보를 다시 읽었다.
+최석의 그 편지를 보면 최석 부인에게는 어떤 반응이 일어나고 정임에게는 어떤 반응이 일어날까, 하고 생각하면 자못 마음이 편하지 못하였다.
+이튿날 아침에 나는 부산서 오는 차를 맞으려고 정거장에를 나갔다.
+차는 제 시간에 들어왔다. 남정임은 슈트케이스 하나를 들고 차에서 내렸다. 검은 외투에 검은 모자를 쓴 그의 얼굴은 더욱 해쓱해 보였다.
+"선생님!"
+하고 정임은 나를 보고 손에 들었던 짐을 땅바닥에 내려놓고, 내 앞으로 왔다.
+"풍랑이나 없었나?"
+하고 나는 내 손에 잡힌 정임의 손이 싸늘한 것을 근심하였다.
+"네. 아주 잔잔했습니다. 저같이 약한 사람도 밖에 나와서 바다 경치를 구경하였습니다."
+하고 정임은 사교적인 웃음을 웃었다. 그러나 그의 눈에는 눈물이 있는 것 같았다.
+"최 선생님 어디 계신지 아세요?"
+하고 정임은 나를 따라 서면서 물었다.
+"나도 지금까지 몰랐는데 어제 편지를 하나 받았지."
+하는 것이 내 대답이었다.
+"네? 편지 받으셨어요? 어디 계십니까?"
+하고 정임은 걸음을 멈추었다.
+"나도 몰라."
+하고 나도 정임과 같이 걸음을 멈추고,
+"그 편지를 쓴 곳도 알고 부친 곳도 알지마는 지금 어디로 갔는지 그것은 모르지. 찾을 생각도 말고 편지할 생각도 말라고 했으니까."
+하고 사실대로 대답하였다.
+"어디야요? 그 편지 부치신 곳이 어디야요? 저 이 차로 따라갈 테야요."
+하고 정임은 조급하였다.
+"갈 때에는 가더라도 이 차에야 갈 수가 있나."
+하고 나는 겨우 정임을 끌고 들어왔다.
+정임을 집으로 데리고 와서 대강 말을 하고, 이튿날 새벽 차로 떠난다는 것을,
+"가만 있어. 어떻게 계획을 세워 가지고 해야지."
+하여 가까스로 붙들어 놓았다.
+아침을 먹고 나서 최석 집에를 가 보려고 할 즈음에 순임이가 와서 마루 끝에 선 채로,
+"선생님, 어머니가 잠깐만 오십시사구요."
+하였다.
+"정임이가 왔다."
+하고 내가 그러니까,
+"정임이가요?"
+하고 순임은 깜짝 놀라면서,
+"정임이는 아버지 계신 데를 알아요?"
+하고 물었다.
+"정임이도 모른단다. 너 아버지는 시베리아에 계시고 정임이는 동경 있다가 왔는데 알 리가 있니?"
+하고 나는 순임의 생각을 깨뜨리려 하였다. 순임은,
+"정임이가 어디 있어요?"
+하고 방들 있는 곳을 둘러보며,
+"언제 왔어요?"
+하고는 그제야 정임에게 대한 반가운 정이 발하는 듯이,
+"정임아!"
+하고 불러 본다.
+"언니요? 여기 있수."
+하고 정임이가 머릿방 문을 열고 옷을 갈아입던 채로 고개를 내어민다.
+순임은 구두를 차내버리듯이 벗어 놓고 정임의 방으로 뛰어들어간다.
+나는 최석의 집에를 가느라고 외투를 입고 모자를 쓰고 정임의 방문을 열어 보았다. 두 처녀는 울고 있었다.
+"정임이도 가지. 아주머니 뵈러 안 가?"
+하고 나는 정임을 재촉하였다.
+"선생님 먼저 가 계셔요."
+하고 순임이가 눈물을 씻고 일어나면서,
+"이따가 제가 정임이허구 갑니다."
+하고 내게 눈을 끔쩍거려 보였다. 갑자기 정임이가 가면 어머니와 정임이와 사이에 어떠한 파란이 일어나지나 아니할까 하고 순임이가 염려하는 것이었다. 순임도 인제는 노성하여졌다고 나는 생각하였다.
+"선생님 이 편지가 다 참말일까요?"
+하고 나를 보는 길로 최석 부인이 물었다. 최석 부인은 히스테리를 일으킨 사람 모양으로 머리와 손을 떨었다.
+나는 참말이냐 하는 것이 무엇을 가리키는 말인지 분명하지 아니하여서,
+"노석이 거짓말할 사람입니까?"
+하고 대체론으로 대답하였다.
+"앉으십쇼. 앉으시란 말씀도 안 하고."
+하고 부인은 침착한 모양을 보이려고 빙그레 웃었으나, 그것은 실패였다.
+"그게 참말일까요? 정임이가 아기를 뗀 것이 아니라, 폐가 나빠서 피를 토하고 입원하였다는 것이?"
+하고 부인은 중대하다는 표정을 가지고 묻는다.
+"그럼 그것이 참말이 아니구요. 아직도 그런 의심을 가지고 계십니까. 정임이와 한 방에 있는 학생이 모함한 것이라고 안 그랬어요? 그게 말이 됩니까."
+하고 언성을 높여서 대답하였다.
+"그럼 왜 정임이가 호텔에서 왜 아버지한테 한 번 안아 달라고 그래요? 그 편지에 쓴 대로 한 번 안아만 보았을까요?"
+이것은 부인의 둘째 물음이었다.
+"나는 그뿐이라고 믿습니다. 그것이 도리어 깨끗하다는 표라고 믿습니다. 안 그렇습니까?"
+하고 나는 딱하다는 표정을 하였다.
+"글쎄요."
+하고 부인은 한참이나 생각하고 있다가,
+"정말 애 아버지가 혼자 달아났을까요? 정임이를 데리고 가케오치한 것이 아닐까요? 꼭 그랬을 것만 같은데."
+하고 부인은 괴로운 표정을 감추려는 듯이 고개를 숙인다.
+나는 남편에게 대한 아내의 의심이 어떻게 깊은가에 아니 놀랄 수가 없어서,
+"허."
+하고 한 마디 웃고,
+"그렇게 수십 년 동안 부부 생활을 하시고도 그렇게 노석의 인격을 몰라 주십니까. 나는 부인께서 하시는 말씀이 부러 하시는 농담으로밖에 아니 들립니다. 정임이가 지금 서울 있습니다."
+하고 또 한 번 웃었다. 정말 기막힌 웃음이었다.
+"정임이가 서울 있어요?"
+하고 부인은 펄쩍 뛰면서,
+"어디 있다가 언제 왔습니까? 그게 정말입니까?"
+하고 의아한 빛을 보인다. 꼭 최석이하고 함께 달아났을 정임이가 서울에 있을 리가 없는 것이었다.
+"동경서 오늘 아침에 왔습니다. 지금 우리 집에서 순임이허구 이야기를 하고 있으니까 조금 있으면 뵈오러 올 것입니다."
+하고 나는 정임이가 분명히 서울 있는 것을 일일이 증거를 들어서 증명하였다. 그리고 우스운 것을 속으로 참았다. 그러나 다음 순간에는 이 병들고 늙은 아내의 질투와 의심으로 괴로워서 덜덜덜덜 떨고 앉았는 것을 가엾게 생각하였다.
+정임이가 지금 서울에 있는 것이 더 의심할 여지가 없는 사실임이 판명되매, 부인은 도리어 낙망하는 듯하였다. 그가 제 마음대로 그려 놓고 믿고 하던 모든 철학의 계통이 무너진 것이었다.
+한참이나 흩어진 정신을 못 수습하는 듯이 앉아 있더니 아주 기운 없는 어조로,
+"선생님 애 아버지가 정말 죽을까요? 정말 영영 집에를 안 돌아올까요?"
+하고 묻는다. 그 눈에는 벌써 눈물이 어리었다.
+"글쎄요. 내 생각 같아서는 다시는 집에 돌아오지 아니할 것 같습니다. 또 그만치 망신을 했으니, 이제 무슨 낯으로 돌아옵니까. 내라도 다시 집에 돌아올 생각은 아니 내겠습니다."
+하고 나는 의식적으로 악의를 가지고 부인의 가슴에 칼을 하나 박았다.
+그 칼은 분명히 부인의 가슴에 아프게 박힌 모양이었다.
+"선생님. 어떡하면 좋습니까. 애 아버지가 죽지 않게 해 주세요. 그렇지 않아도 순임이년이 제가 걔 아버지를 달아나게나 한 것처럼 원망을 하는데요. 그러다가 정녕 죽으면 어떻게 합니까. 제일 딴 자식들의 원망을 들을까봐 겁이 납니다. 선생님, 어떻게 애 아버지를 붙들어다 주세요."
+하고 마침내 참을 수 없이 울었다. 말은 비록 자식들의 원망이 두렵다고 하지마는 질투의 감정이 스러질 때에 그에게는 남편에게 대한 아내의 애정이 막혔던 물과 같이 터져 나온 것이라고 나는 해석하였다.
+"글쎄, 어디 있는 줄 알고 찾습니까. 노석의 성미에 한번 아니 한다고 했으면 다시 편지할 리는 만무하다고 믿습니다."
+하여 나는 부인의 가슴에 둘째 칼날을 박았다.
+나는 비록 최석의 부인이 청하지 아니하더라도 최석을 찾으러 떠나지 아니하면 아니 될 의무를 진다. 산 최석을 못 찾더라도 최석의 시체라도, 무덤이라도, 죽은 자리라도, 마지막 있던 곳이라도 찾아보지 아니하면 아니 될 의무를 깨닫는다.
+그러나 시국이 변하여 그 때에는 아라사에 가는 것은 여간 곤란한 일이 아니었다. 그 때에는 북만의 풍운이 급박하여 만주리를 통과하기는 사실상 불가능에 가까웠다. 마점산(馬占山) 일파의 군대가 흥안령, 하일라르 등지에 웅거하여 언제 대충돌이 폭발될는지 모르던 때였다. 이 때문에 시베리아에 들어가기는 거의 절망 상태라고 하겠고, 또 관헌도 아라사에 들어가는 여행권을 잘 교부할 것 같지 아니하였다.
+부인은 울고, 나는 이런 생각 저런 생각 하고 있는 동안에 문 밖에는 순임이, 정임이가 들어오는 소리가 들렸다.
+"아이, 정임이냐."
+하고 부인은 반갑게 허리 굽혀 인사하는 정임의 어깨에 손을 대고,
+"자 앉아라. 그래 인제 병이 좀 나으냐…… 수척했구나. 더 노성해지구 반 년도 못 되었는데."
+하고 정임에게 대하여 애정을 표하는 것을 보고 나는 의외지마는 다행으로 생각하였다. 나는 정임이가 오면 보기 싫은 한 신을 연출하지 않나 하고 근심하였던 것이다.
+"희 잘 자라요?"
+하고 정임은 한참이나 있다가 비로소 입을 열었다.
+"응, 잘 있단다. 컸나 가 보아라."
+하고 부인은 더욱 반가운 표정을 보인다.
+"어느 방이야?"
+하고 정임은 선물 보퉁이를 들고 순임과 함께 나가 버린다. 여자인 정임은 희와 순임과 부인과 또 순임의 다른 동생에게 선물 사 오는 것을 잊어버리지 아니하였다.
+정임과 순임은 한 이삼 분 있다가 돌아왔다. 밖에서 희가 무엇이라고 지절대는 소리가 들린다. 아마 정임이가 사다 준 선물을 받고 좋아하는 모양이다.
+정임은 들고 온 보퉁이에서 여자용 배스로브 하나를 내어서 부인에게주며,
+"맞으실까?"
+하였다.
+"아이 그건 무어라고 사 왔니?"
+하고 부인은 좋아라고 입어 보고, 이리 보고 저리 보고 하면서,
+"난 이런 거 처음 입어 본다."
+하고 자꾸 끈을 동여맨다.
+"정임이가 난 파자마를 사다 주었어."
+하고 순임은 따로 쌌던 굵은 줄 있는 융 파자마를 내어서 경매장 사람 모양으로 흔들어 보이며,
+"어머니 그 배스로브 나 주우. 어머닌 늙은이가 그건 입어서 무엇 하우?"
+하고 부인이 입은 배스로브를 벗겨서 제가 입고 두 호주머니에 손을 넣고 어기죽어기죽하고 서양 부인네 흉내를 낸다.
+"저런 말괄량이가 너도 정임이처럼 좀 얌전해 보아라."
+하고 부인은 순임을 향하여 눈을 흘긴다.
+이 모양으로 부인과 정임과의 대면은 가장 원만하게 되었다.
+그러나 부인은 정임에게 최석의 편지를 보이기를 원치 아니하였다. 편지가 왔다는 말조차 입 밖에 내지 아니하였다. 그러나 순임이가 정임에게 대하여 표하는 애정은 여간 깊지 아니하였다. 그 둘은 하루 종일 같이 있었다. 정임은 그 날 저녁에 나를 보고,
+"순임이헌테 최 선생님 편지 사연은 다 들었어요. 순임이가 그 편지를 훔쳐다가 얼른얼른 몇 군데 읽어도 보았습니다. 순임이가 저를 퍽 동정하면서 절더러 최 선생을 따라가 보라고 그래요. 혼자 가기가 어려우면 자기허구 같이 가자고. 가서 최 선생을 데리고 오자고. 어머니가 못 가게 하거든 몰래 둘이 도망해 가자고. 그래서 그러자고 그랬습니다. 안됐지요. 선생님?"
+하고 저희끼리 작정은 다 해 놓고는 슬쩍 내 의향을 물었다.
+"젊은 여자 단둘이서 먼 여행을 어떻게 한단 말이냐? 게다가 지금 북만주 형세가 대단히 위급한 모양인데. 또 정임이는 그 건강 가지고 어디를 가, 이 추운 겨울에?"
+하고 나는 이런 말이 다 쓸데없는 말인 줄 알면서도 어른으로서 한 마디 안 할 수 없어서 하였다. 정임은 더 제 뜻을 주장하지도 아니하였다.
+그 날 저녁에 정임은 순임의 집에서 잤는지 집에 오지를 아니하였다.
+나는 이 일을 어찌하면 좋은가, 이 두 여자의 행동을 어찌하면 좋은가 하고 혼자 끙끙 생각하고 있었다.
+이튿날 나는 궁금해서 최석의 집에를 갔더니 부인이,
+"우리 순임이 댁에 갔어요?"
+하고 의외의 질문을 하였다.
+"아니오."
+하고 나는 놀랐다.
+"그럼, 이것들이 어딜 갔어요? 난 정임이허구 댁에서 잔 줄만 알았는데."
+하고 부인은 무슨 불길한 것이나 본 듯이 몸을 떤다. 히스테리가 일어난 것이었다.
+나는 입맛을 다시었다. 분명히 이 두 여자가 시베리아를 향하고 떠났구나 하였다.
+그 날은 소식이 없이 지났다. 그 이튿날도 소식이 없이 지났다.
+최석 부인은 딸까지 잃어버리고 미친 듯이 울고 애통하다가 머리를 싸매고 누워 버리고 말았다.
+정임이와 순임이가 없어진 지 사흘 만에 아침 우편에 편지 한 장을 받았다. 그 봉투는 봉천 야마도 호텔 것이었다. 그 속에는 편지 두 장이 들어 있었다. 한 장은 ,
+선생님! 저는 아버지를 위하여, 정임을 위하여 정임과 같이 집을 떠났습니다.
+어머님께서 슬퍼하실 줄은 알지마는 저희들이 다행히 아버지를 찾아서 모시고 오면 어머니께서도 기뻐하실 것을 믿습니다. 저희들이 가지 아니하고는 아버지는 살아서 돌아오실 것 같지 아니합니다. 아버지를 이처럼 불행하시게 한 죄는 절반은 어머니께 있고, 절반은 제게 있습니다. 저는 아버지 일을 생각하면 가슴이 미어지고 이가 갈립니다. 저는 아무리 해서라도 아버지를 찾아내어야겠습니다.
+저는 정임을 무한히 동정합니다. 저는 어려서 정임을 미워하고 아버지를 미워하였지마는 지금은 아버지의 마음과 정임의 마음을 알아볼 만치 자랐습니다.
+선생님! 저희들은 둘이 손을 잡고 어디를 가서든지 아버지를 찾아내겠습니다. 하나님의 사자가 낮에는 구름이 되고 밤에는 별이 되어서 반드시 저희들의 앞길을 인도할 줄 믿습니다.
+선생님, 저희 어린것들의 뜻을 불쌍히 여기셔서 돈 천 원만 전보로 보내 주시기를 바랍니다.
+만일 만주리로 가는 길이 끊어지면 몽고로 자동차로라도 가려고 합니다. 아버지 편지에 적힌 F역의 R씨를 찾고, 그리고 바이칼 호반의 바이칼리스코에를 찾아, 이 모양으로 찾으면 반드시 아버지를 찾아 내고야 말 것을 믿습니다.
+선생님, 돈 천 원만 봉천 야마도 호텔 최순임 이름으로 부쳐 주세요. 그리고 어머니헌테는 아직 말씀 말아 주세요.
+선생님. 이렇게 걱정하시게 해서 미안합니다. 용서하세요.
+순임 상서
+이렇게 써 있다. 또 한 장에는,
+선생님! 저는 마침내 돌아오지 못할 길을 떠나나이다. 어디든지 최 선생님을 뵈옵는 곳에서 이 몸을 묻어 버리려 하나이다. 지금 또 몸에 열이 나는 모양이요, 혈담도 보이오나 최 선생을 뵈올 때까지는 아무리 하여서라도 이 목숨을 부지하려 하오며, 최 선생을 뵈옵고 제가 진 은혜를 감사하는 한 말씀만 사뢰면 고대 죽사와도 여한이 없을까 하나이다.
+순임 언니가 제게 주시는 사랑과 동정은 오직 눈물과 감격밖에 더 표할 말씀이 없나이다. 순임 언니가 저를 보호하여 주니 마음이 든든하여이다…….
+이라고 하였다.
+편지를 보아야 별로 놀랄 것은 없었다. 다만 말괄량이로만 알았던 순임의 속에 어느새에 그러한 감정이 발달하였나 하는 것을 놀랄 뿐이었다.
+그러나 걱정은 이것이다. 순임이나 정임이나 다 내가 감독해야 할 처지에 있거늘 그들이 만리 긴 여행을 떠난다고 하니 감독자인 내 태도를 어떻게 할까 하는 것이다.
+나는 편지를 받는 길로 우선 돈 천 원을 은행에 가서 찾아다 놓았다.
+암만해도 내가 서울에 가만히 앉아서 두 아이에게 돈만 부쳐 주는 것이 인정에 어그러지는 것 같아서 나는 여러 가지로 주선을 하여서 여행의 양해를 얻어 가지고 봉천을 향하여 떠났다.
+내가 봉천에 도착한 것은 밤 열시가 지나서였다. 순임과 정임은 자리옷 바람으로 내 방으로 달려와서 반가워하였다. 그들이 반가워하는 양은 실로 눈물이 흐를 만하였다.
+"아이구 선생님!"
+"아이구 어쩌면!"
+하는 것이 그들의 내게 대한 인사의 전부였다.
+"정임이 어떠오?"
+하고 나는 순임의 편지에 정임이가 열이 있단 말을 생각하였다.
+"무어요. 괜찮습니다."
+하고 정임은 웃었다.
+전등빛에 보이는 정임의 얼굴은 그야말로 대리석으로 깎은 듯하였다. 여위고 핏기가 없는 것이 더욱 정임의 용모에 엄숙한 맛을 주었다.
+"돈 가져오셨어요?"
+하고 순임이가 어리광 절반으로 묻다가 내가 웃고 대답이 없음을 보고,
+"우리를 붙들러 오셨어요?"
+하고 성내는 양을 보인다.
+"그래 둘이서들 간다니 어떻게 간단 말인가. 시베리아가 어떤 곳에 붙었는지 알지도 못하면서."
+하고 나는 두 사람이 그리 슬퍼하지 아니하는 순간을 보는 것이 다행하여서 농담삼아 물었다.
+"왜 몰라요? 시베리아가 저기 아니야요?"
+하고 순임이가 산해관 쪽을 가리키며,
+"우리도 지리에서 배워서 다 알아요. 어저께 하루 종일 지도를 사다 놓고 연구를 하였답니다. 봉천서 신경, 신경서 하얼빈, 하얼빈에서 만주리, 만주리에서 이르쿠츠크, 보세요, 잘 알지 않습니까. 또 만일 중동 철도가 불통이면 어떻게 가는고 하니 여기서 산해관을 가고, 산해관서 북경을 가지요. 그리고는 북경서 장가구를 가지 않습니까. 장가구서 자동차를 타고 몽고를 통과해서 가거든요. 잘 알지 않습니까."
+하고 정임의 허리를 안으며,
+"그렇지이?"
+하고 자신 있는 듯이 웃는다.
+"또 몽고로도 못 가게 되어서 구라파를 돌게 되면?"
+하고 나는 교사가 생도에게 묻는 모양으로 물었다.
+"네, 저 인도양으로 해서 지중해로 해서 프랑스로 해서 그렇게 가지요."
+"허, 잘 아는구나."
+하고 나는 웃었다.
+"그렇게만 알아요? 또 해삼위로 해서 가는 길도 알아요. 저희를 어린애로 아시네."
+"잘못했소."
+"하하."
+"후후."
+사실 그들은 벌써 어린애들은 아니었다. 순임도 벌써 그 아버지의 말할 수 없는 사정에 동정할 나이가 되었다. 순임이가 기어다닌 것은 본 나로는 이것도 이상하게 보였다. 나는 벌써 나이 많았구나 하는 생각이 나지 아니할 수 없었다.
+나는 잠 안 드는 하룻밤을 지내면서 옆방에서 정임이가 기침을 짓는 소리를 들었다. 그 소리는 내 가슴을 아프게 하였다.
+이튿날 나는 두 사람에게 돈 천 원을 주어서 신경 가는 급행차를 태워 주었다. 대륙의 이 건조하고 추운 기후에 정임의 병든 폐가 견디어 날까 하고 마음이 놓이지 아니하였다. 그러나 나는 그들을 가라고 권할 수는 있어도 가지 말라고 붙들 수는 없었다. 다만 제 아버지, 제 애인을 죽기 전에 만날 수 있기만 빌 뿐이었다.
+나는 두 아이를 북쪽으로 떠나 보내고 혼자 여관에 들어와서 도무지 정신을 진정하지 못하여 술을 먹고 잊으려 하였다. 그러다가 그 날 밤차로 서울로 돌아왔다.
+이튿날 아침에 나는 최석 부인을 찾아서 순임과 정임이가 시베리아로 갔단 말을 전하였다.
+그 때에 최 부인은 거의 아무 정신이 없는 듯하였다. 아무 말도 하지 아니하고 울고만 있었다.
+얼마 있다가 부인은,
+"그것들이 저희들끼리 가서 괜찮을까요?"
+하는 한 마디를 할 뿐이었다.
+며칠 후에 순임에게서 편지가 왔다. 그것은 하얼빈에서 부친 것이었다.
+하얼빈을 오늘 떠납니다. 하얼빈에 와서 아버지 친구 되시는 R소장을 만나뵈옵고 아버지 일을 물어 보았습니다. 그리고 저희 둘이서 찾아 떠났다는 말씀을 하였더니 R소장이 대단히 동정하여서 여행권도 준비해 주시기로 저희는 아버지를 찾아서 오늘 오후 모스크바 가는 급행으로 떠납니다. 가다가 F역에 내리기는 어려울 듯합니다. 정임의 건강이 대단히 좋지 못합니다. 일기가 갑자기 추워지는 관계인지 정임의 신열이 오후면 삼십팔 도를 넘고 기침도 대단합니다. 저는 염려가 되어서 정임더러 하얼빈에서 입원하여 조리를 하라고 권하였지마는 도무지 듣지를 아니합니다. 어디까지든지 가는 대로 가다가 더 못 가게 되면 그 곳에서 죽는다고 합니다.
+저는 그 동안 며칠 정임과 같이 있는 중에 정임이가 어떻게 아름답고 높고 굳세게 깨끗한 여자인 것을 발견하였습니다. 저는 지금까지 정임을 몰라본 것을 부끄럽게 생각합니다. 그리고 또 제 아버지께서 어떻게 갸륵한 어른이신 것을 인제야 깨달았습니다. 자식 된 저까지도 아버지와 정임과의 관계를 의심하였습니다. 의심하는 것보다는 세상에서 말하는 대로 믿고 있었습니다. 그러나 정임을 만나 보고 정임의 말을 듣고 아버지께서 선생님께 드린 편지가 모두 참인 것을 깨달았습니다. 아버지께서는 친구의 의지 없는 딸인 정임을 당신의 친혈육인 저와 꼭 같이 사랑하려고 하신 것이었습니다. 그것이 얼마나 갸륵한 일입니까. 그런데 제 어머니와 저는 그 갸륵하신 정신을 몰라보고 오해하였습니다. 어머니는 질투하시고 저는 시기하였습니다. 이것이 얼마나 아버지를 그렇게 갸륵하신 아버지를 몰라뵈온 것입니다. 이것이 얼마나 부끄럽고 원통한 일입니까.
+선생님께서도 여러 번 아버지의 인격이 높다는 것을 저희 모녀에게 설명해 주셨습니다마는 마음이 막힌 저는 선생님의 말씀도 믿지 아니하였습니다.
+선생님, 정임은 참으로 아버지를 사랑합니다. 정임에게는 이 세상에 아버지밖에는 사랑하는 아무것도 없이, 그렇게 외●으로, 그렇게 열렬하게 아버지를 사모하고 사랑합니다. 저는 잘 압니다. 정임이가 처음에는 아버지로 사랑하였던 것을, 그러나 어느 새에 정임의 아버지에게 대한 사랑이 무엇인지 모를 사랑으로 변한 것을, 그것이 연애냐 하고 물으면 정임은 아니라고 할 것입니다. 정임의 그 대답은 결코 거짓이 아닙니다. 정임은 숙성하지마는 아직도 극히 순결합니다. 정임은 부모를 잃은 후에 아버지밖에 사랑한 사람이 없습니다. 또 아버지에게밖에 사랑받던 일도 없습니다. 그러니깐 정임은 아버지를 그저 사랑합니다 전적으로 사랑합니다. 선생님, 정임의 사랑에는 아버지에 대한 자식의 사랑, 오라비에 대한 누이의 사랑, 사내 친구에 대한 여자 친구의 사랑, 애인에 대한 애인의 사랑, 이 밖에 존경하고 숭배하는 선생에 대한 제자의 사랑까지, 사랑의 모든 종류가 포함되어 있는 것을 저는 발견하였습니다.
+선생님, 정임의 정상은 차마 볼 수가 없습니다. 아버지의 안부를 근심하는 양은 제 몇십 배나 되는지 모르게 간절합니다. 정임은 저 때문에 아버지가 불행하게 되셨다고 해서 차마 볼 수 없게 애통하고 있습니다. 진정을 말씀하오면 저는 지금 아버지보다도 어머니보다도 정임에게 가장 동정이 끌립니다. 선생님, 저는 아버지를 찾아가는 것이 아니라 정임을 돕기 위하여 간호하기 위하여 가는 것 같습니다.
+선생님, 저는 아직 사랑이란 것이 무엇인지를 모릅니다. 그러나 정임을 보고 사랑이란 것이 어떻게 신비하고 열렬하고 놀라운 것인가를 안 것 같습니다.
+순임의 편지는 계속된다.
+선생님, 하얼빈에 오는 길에 송화강 굽이를 볼 때에는 정임이가 어떻게나 울었는지, 그것은 차마 볼 수가 없었습니다. 아버지께서 송화강을 보시고 감상이 깊으셨더란 것을 생각한 것입니다. 무인지경으로, 허옇게 눈이 덮인 벌판으로 흘러가는 송화강 굽이, 그것은 슬픈 풍경입니다. 아버지께서 여기를 지나실 때에는 마른 풀만 있는 광야였을 것이니 그 때에는 더욱 황량하였을 것이라고 정임은 말하고 웁니다.
+정임은 제가 아버지를 아는 것보다 아버지를 잘 아는 것 같습니다. 평소에 아버지와는 그리 접촉이 없건마는 정임은 아버지의 의지력, 아버지의 숨은 열정, 아버지의 성미까지 잘 압니다. 저는 정임의 말을 듣고야 비로소 참 그래, 하는 감탄을 발한 일이 여러 번 있습니다.
+정임의 말을 듣고야 비로소 아버지가 남보다 뛰어나신 인물인 것을 깨달았습니다. 아버지는 정의감이 굳세고 겉으로는 싸늘하도록 이지적이지마는 속에는 불 같은 열정이 있으시고, 아버지는 쇠 같은 의지력과 칼날 같은 판단력이 있어서 언제나 주저하심이 없고 또 흔들리심이 없다는 것, 아버지께서는 모든 것을 용서하고 모든 것을 호의로 해석하여서 누구를 미워하거나 원망하심이 없는 등, 정임은 아버지의 마음의 목록과 설명서를 따로 외우는 것처럼 아버지의 성격을 설명합니다. 듣고 보아서 비로소 아버지의 딸인 저는 내 아버지가 어떤 아버지인가를 알았습니다.
+선생님, 이해가 사랑을 낳는단 말씀이 있지마는 저는 정임을 보아서 사랑이 이해를 낳는 것이 아닌가 합니다.
+어쩌면 어머니와 저는 평생을 아버지를 모시고 있으면서도 아버지를 몰랐습니까. 이성이 무디고 양심이 흐려서 그랬습니까. 정임은 진실로 존경할 여자입니다. 제가 남자라 하더라도 정임을 아니 사랑하고는 못 견디겠습니다.
+아버지는 분명 정임을 사랑하신 것입니다. 처음에는 친구의 딸로, 다음에는 친딸과 같이, 또 다음에는 무엇인지 모르게 뜨거운 사랑이 생겼으리라고 믿습니다. 그것을 아버지는 죽인 것입니다. 그것을 죽이려고 이 달할 수 없는 사랑을 죽이려고 시베리아로 달아나신 것입니다. 인제야 아버지께서 선생님께 하신 편지의 뜻이 알아진 것 같습니다. 백설이 덮인 시베리아의 삼림 속으로 혼자 헤매며 정임에게로 향하는 사랑을 죽이려고 무진 애를 쓰시는 그 심정이 알아지는 것 같습니다.
+선생님 이것이 얼마나 비참한 일입니까. 저는 정임의 짐에 지니고 온 일기를 보다가 이러한 구절을 발견하였습니다.
+선생님. 저는 세인트 오거스틴의 <참회록>을 절반이나 다 보고 나도 잠이 들지 아니합니다. 잠이 들기 전에 제가 항상 즐겨하는 아베마리아의 노래를 유성기로 듣고 나서 오늘 일기를 쓰려고 하니 슬픈 소리만 나옵니다.
+사랑하는 어른이여. 저는 멀리서 당신을 존경하고 신뢰하는 마음에서만 살아야 할 것을 잘 압니다. 여기에서 영원한 정지를 하지 아니하면 아니 됩니다. 비록 제 생명이 괴로움으로 끊어지고 제 혼이 피어 보지 못하고 스러져 버리더라도 저는 이 멀리서 바라보는 존경과 신뢰의 심경에서 한 발자국이라도 옮기지 않아야 할 것을 잘 압니다. 나를 위하여 놓여진 생의 궤도는 나의 생명을 부인하는 억지의 길입니다. 제가 몇 년 전 기숙사 베드에서 이런 밤에 내다보면 즐겁고 아름답던 내 생의 꿈은 다 깨어졌습니다.
+제 영혼의 한 조각이 먼 세상 알지 못할 세계로 떠다니고 있습니다. 잃어버린 마음 조각 어찌하다가 제가 이렇게 되었는지 모릅니다.
+피어 오르는 생명의 광채를 스스로 사형에 처하지 아니하면 아니 될 때 어찌 슬픔이 없겠습니까. 이것은 현실로 사람의 생명을 죽이는 것보다 더 무서운 죄가 아니오리까. 나의 세계에서 처음이요 마지막으로 발견한 빛을 어둠 속에 소멸해 버리라는 이 일이 얼마나 떨리는 직무오리까. 이 허깨비의 형의 사람이 살기 위하여 내 손으로 칼을 들어 내 영혼의 환희를 쳐야 옳습니까. 저는 하나님을 원망합니다.
+이렇게 씌어 있습니다. 선생님 이것이 얼마나 피 흐르는 고백입니까.
+선생님, 저는 정임의 이 고백을 보고 무조건으로 정임의 사랑을 시인합니다. 선생님, 제 목숨을 바쳐서 하는 일에 누가 시비를 하겠습니까. 더구나 그 동기에 티끌만큼도 불순한 것이 없음에야 무조건으로 시인하지 아니하고 어찌합니까.
+바라기는 정임의 병이 크게 되지 아니하고 아버지께서 무사히 계셔서 속히 만나뵙게 되는 것입니다마는 앞길이 망망하여 가슴이 두근거림을 금치 못합니다. 게다가 오늘은 함박눈이 퍼부어서 천지가 온통 회색으로 한 빛이 되었으니 더욱 전도가 막막합니다. 그러나 선생님 저는 앓는 정임을 데리고 용감하게 시베리아 길을 떠납니다.
+한 일 주일 후에 또 편지 한 장이 왔다. 그것도 순임의 편지여서 이러한 말이 있었다.
+……오늘 새벽에 흥안령을 지났습니다. 플랫폼의 한란계는 영하 이십삼 도를 가리켰습니다. 사람들의 얼굴은 솜털에 성에가 슬어서 남녀 노소 할 것 없이 하얗게 분을 바른 것 같습니다. 유리에 비친 내 얼굴도 그와 같이 흰 것을 보고 놀랐습니다. 숨을 들이쉴 때에는 코털이 얼어서 숨이 끊기고 바람결이 지나가면 눈물이 얼어서 눈썹이 마주 붙습니다. 사람들은 털과 가죽에 싸여서 곰같이 보입니다.
+또 이런 말도 있었다.
+아라사 계집애들이 우유병들을 품에 품고 서서 손님이 사기를 기다리고 있습니다. 저도 두 병을 사서 정임이와 나누어 먹었습니다. 우유는 따뜻합니다. 그것을 식히지 아니할 양으로 품에 품고 섰던 것입니다.
+또 이러한 구절도 있었다.
+정거장에 닿을 때마다 저희들은 밖을 내다봅니다. 행여나 아버지가 거기 계시지나 아니할까 하고요. 차가 어길 때에는 더구나 마음이 조입니다. 아버지가 그 차를 타고 지나가시지나 아니하는가 하고요. 그리고는 정임은 웁니다. 꼭 뵈올 어른을 놓쳐나 버린 듯이.
+그리고는 이 주일 동안이나 소식이 없다가 편지 한 장이 왔다. 그것은 정임의 글씨였다.
+선생님, 저는 지금 최 선생께서 계시던 바이칼 호반의 그 집에 와서 홀로 누웠습니다. 순임은 주인 노파와 함께 F역으로 최 선생을 찾아서 오늘 아침에 떠나고 병든 저만 혼자 누워서 얼음에 싸인 바이칼 호의 눈보라치는 바람 소리를 듣고 있습니다. 열은 삼십팔 도로부터 구 도 사이를 오르내리고 기침은 나고 몸의 괴로움을 견딜 수 없습니다. 그러하오나 선생님, 저는 하나님을 불러서 축원합니다. 이 실낱 같은 생명이 다 타 버리기 전에 최 선생의 낯을 다만 일 초 동안이라도 보여지이라고. 그러하오나 선생님, 이 축원이 이루어지겠습니까.
+저는 한사코 F역까지 가려 하였사오나 순임 형이 울고 막사오며 또 주인 노파가 본래 미국 사람과 살던 사람으로 영어를 알아서 순임 형의 도움이 되겠기로 저는 이 곳에 누워 있습니다. 순임 형은 기어코 아버지를 찾아 모시고 오마고 약속하였사오나 이 넓은 시베리아에서 어디 가서 찾겠습니까.
+선생님, 저는 죽음을 봅니다. 죽음이 바로 제 앞에 와서 선 것을 봅니다. 그의 손은 제 여윈 손을 잡으려고 들먹거림을 봅니다.
+선생님, 죽은 뒤에도 의식이 남습니까. 만일 의식이 남는다 하면 죽은 뒤에도 이 아픔과 괴로움을 계속하지 아니하면 아니 됩니까. 죽은 뒤에는 오직 영원한 어둠과 잊어버림이 있습니까. 죽은 뒤에는 혹시나 생전에 먹었던 마음을 자유로 펼 도리가 있습니까. 이 세상에서 그립고 사모하던 이를 죽은 뒤에는 자유로 만나 보고 언제나 마음껏 같이할 수가 있습니까. 그런 일도 있습니까. 이런 일을 바라는 것도 죄가 됩니까.
+정임의 편지는 더욱 절망적인 어조로 찬다.
+저는 처음 병이 났을 때에는 죽는 것이 싫고 무서웠습니다. 그러나 지금은 죽는 것이 조금도 무섭지 아니합니다. 다만 차마 죽지 못하는 것이 한.
+하고는 `다만 차마' 이하를 박박 지워 버렸다. 그리고는 새로 시작하여 나와내 가족에게 대한 문안을 하고는 끝을 막았다.
+나는 이 편지를 받고 울었다. 무슨 큰 비극이 가까운 것을 예상하게 하였다.
+그 후 한 십여 일이나 지나서 전보가 왔다. 그것은 영문으로 씌었는데,
+"아버지 병이 급하다. 나로는 어쩔 수 없다. 돈 가지고 곧 오기를 바란다."
+하고 그 끝에 B호텔이라고 주소를 적었다. 전보 발신국이 이르쿠츠크인 것을 보니 B호텔이라 함은 이르쿠츠크인 것이 분명하였다.
+나는 최석 부인에게 최석이가 아직 살아 있다는 것을 전하고 곧 여행권 수속을 하였다. 절망으로 알았던 여행권은 사정이 사정인만큼 곧 발부되었다.
+나는 비행기로 여의도를 떠났다. 백설에 개개한 땅을, 남빛으로 푸른 바다를 굽어보는 동안에 대련을 들러 거기서 다른 비행기를 갈아타고 봉천, 신경, 하얼빈을 거쳐, 치치하얼에 들렀다가 만주리로 급행하였다.
+웅대한 대륙의 설경도 나에게 아무러한 인상도 주지 못하였다. 다만 푸른 하늘과 희고 평평한 땅과의 사이로 한량 없이 허공을 날아간다는 생각밖에 없었다. 그것은 사랑하는 두 친구가 목숨이 경각에 달린 것을 생각할 때에 마음에 아무 여유도 없는 까닭이었다.
+만주리에서도 비행기를 타려 하였으나 소비에트 관헌이 허락을 아니 하여 열차로 갈 수밖에 없었다.
+초조한 몇 밤을 지나고 이르쿠츠크에 내린 것이 오전 두시. 나는 B호텔로 이스보스치카라는 마차를 몰았다. 죽음과 같이 고요하게 눈 속에 자는 시간에는 여기저기 전등이 반짝거릴 뿐, 이따금 밤의 시가를 경계하는 병정들의 눈이 무섭게 빛나는 것이 보였다.
+B호텔에서 미스 초이(최 양)를 찾았으나 순임은 없고 어떤 서양 노파가 나와서,
+"유 미스터 Y?"
+하고 의심스러운 눈으로 나를 보았다.
+그렇다는 내 대답을 듣고는 노파는 반갑게 손을 내밀어서 내 손을 잡았다.
+나는 넉넉하지 못한 영어로 그 노파에게서 최석이가 아직 살았다는 말과 정임의 소식은 들은 지 오래라는 말과 최석과 순임은 여기서 삼십 마일이나 떨어진 F역에서도 썰매로 더 가는 삼림 속에 있다는 말을 들었다.
+나는 그 밤을 여기서 지내고 이튿날 아침에 떠나는 완행차로 그 노파와 함께 이르쿠츠크를 떠났다.
+이 날도 천지는 오직 눈뿐이었다. 차는 가끔 삼림 중으로 가는 모양이나 모두 회색빛에 가리워서 분명히 보이지를 아니하였다.
+F역이라는 것은 삼림 속에 있는 조그마한 정거장으로 집이라고는 정거장 집밖에 없었다. 역부 두엇이 털옷에 하얗게 눈을 뒤쓰고 졸리는 듯이 오락가락할 뿐이었다.
+우리는 썰매 하나를 얻어 타고 어디가 길인지 분명치도 아니한 눈 속으로 말을 몰았다.
+바람은 없는 듯하지마는 그래도 눈발을 한편으로 비끼는 모양이어서 아름드리 나무들의 한쪽은 하얗게 눈으로 쌓이고 한쪽은 검은 빛이 더욱 돋보였다. 백 척은 넘을 듯한 꼿꼿한 침엽수(전나무 따윈가)들이 어디까지든지, 하늘에서 곧 내려박은 못 모양으로, 수없이 서 있는 사이로 우리 썰매는 간다. 땅에 덮인 눈은 새로 피워 놓은 솜같이 희지마는 하늘에서 내리는 눈은 구름빛과 공기빛과 어울려서 밥 잦힐 때에 굴뚝에서 나오는 연기와 같이 연회색이다.
+바람도 불지 아니하고 새도 날지 아니하건마는 나무 높은 가지에 쌓인 눈이 이따금 덩치로 떨어져서는 고요한 수풀 속에 작은 동요를 일으킨다.
+우리 썰매가 가는 길이 자연스러운 복잡한 커브를 도는 것을 보면 필시 얼음 언 개천 위로 달리는 모양이었다.
+한 시간이나 달린 뒤에 우리 썰매는 늦은 경사지를 올랐다. 말을 어거하는 아라사 사람은 쭈쭈쭈쭈, 후르르 하고 주문을 외우듯이 입으로 말을 재촉하고 고삐를 이리 들고 저리 들어 말에게 방향을 가리킬 뿐이요, 채찍은 보이기만하고 한 번도 쓰지 아니하였다. 그와 말과는 완전히 뜻과 정이 맞는 동지인 듯하였다.
+처음에는 몰랐으나 차차 추워짐을 깨달았다. 발과 무르팍이 시렸다.
+"얼마나 머오?"
+하고 나는 오래간만에 입을 열어서 노파에게 물었다. 노파는 털수건으로 머리를 싸매고 깊숙한 눈만 남겨 가지고 실신한 사람 모양으로 허공만 바라보고 있다가, 내가 묻는 말에 비로소 잠이나 깬 듯이,
+"멀지 않소. 인젠 한 십오 마일."
+하고는 나를 바라보았다. 그 눈은 아마 웃는 모양이었다.
+그 얼굴, 그 눈, 그 음성이 모두 이 노파가 인생 풍파의 슬픈 일 괴로운 일에 부대끼고 지친 것을 표하였다. 그리고 죽는 날까지 살아간다 하는 듯하였다.
+경사지를 올라서서 보니 그것은 한 산등성이였다. 방향은 알 수 없으나 우리가 가는 방향에는 더 높은 등성이가 있는 모양이나 다른 곳은 다 이보다 낮은 것 같아서 하얀 눈바다가 끝없이 보이는 듯하였다. 그 눈보라는 들쑹날쑹이 있는 것을 보면 삼림의 꼭대기인 것이 분명하였다. 더구나 여기저기 뾰족뾰족 눈송이 붙을 수 없는 마른 나뭇가지가 거뭇거뭇 보이는 것을 보아서 그러하였다. 만일 눈이 걷혀 주었으면 얼마나 안계가 넓으랴, 최석 군이 고민하는 가슴을 안고 이리로 헤매었구나 하면서 나는 목을 둘러서 사방을 바라보았다.
+우리는 그 등성이를 내려갔다. 말이 미처 발을 땅에 놓을 수가 없는 정도로 빨리 내려갔다. 여기는 산불이 났던 자리인 듯하여 거뭇거뭇 불탄 자국 있는 마른 나무들이 드문드문 서 있었다. 그 나무들은 찍어 가는 사람도 없으매 저절로 썩어서 없어지기를 기다릴 수밖에 없었다. 그들은 나서 아주 썩어 버리기까지 천 년 이상은 걸린다고 하니 또한 장한 일이다.
+이 대삼림에 불이 붙는다 하면 그것은 장관일 것이다. 달밤에 높은 곳에서 이 경치를 내려다본다 하면 그도 장관일 것이요, 여름에 한창 기운을 펼 때도 장관일 것이다. 나는 오뉴월경에 시베리아를 여행하는 이들이 끝없는 꽃바다를 보았다는 기록을 생각하였다.
+"저기요!"
+하는 노파의 말에 나는 생각의 줄을 끊었다. 저기라고 가리키는 곳을 보니 거기는 집이라고 생각되는 물건이 나무 사이로 보였다. 창이 있으니 분명 집이었다.
+우리 이스보스치카가 가까이 오는 것을 보았는지, 그 집 같은 물건의 문 같은 것이 열리며 검은 외투 입은 여자 하나가 팔을 허우적거리며 뛰어나온다. 아마 소리도 치는 모양이겠지마는 그 소리는 아니 들렸다. 나는 그것이 순임인 줄을 얼른 알았다. 또 순임이밖에 될 사람도 없었다.
+순임은 한참 달음박질로 오다가 눈이 깊어서 걸음을 걷기가 힘이 드는지 멈칫 섰다. 그의 검은 외투는 어느덧 흰 점으로 얼려져 가지고 어깨는 희게 되는 것이 보였다.
+순임의 갸름한 얼굴이 보였다.
+"선생님!"
+하고 순임도 나를 알아보고는 또 팔을 허우적거리며 소리를 질렀다.
+나도 반가워서 모자를 벗어 둘렀다.
+"아이 선생님!"
+하고 순임은 내가 썰매에서 일어서기도 전에 내게 와서 매달리며 울었다.
+"아버지 어떠시냐?"
+하고 나는 순임의 등을 두드렸다. 나는 다리가 마비가 되어서 곧 일어설 수가 없었다.
+"아버지 어떠시냐?"
+하고 나는 한 번 더 물었다.
+순임은 벌떡 일어나 두 주먹으로 흐르는 눈물을 쳐내 버리며,
+"대단하셔요."
+하고도 울음을 금치 못하였다.
+노파는 벌써 썰매에서 내려서 기운 없는 걸음으로 비틀비틀 걷기를 시작하였다.
+나는 순임을 따라서 언덕을 오르며,
+"그래 무슨 병환이시냐?"
+하고 물었다.
+"몰라요. 신열이 대단하셔요."
+"정신은 차리시든?"
+"처음 제가 여기 왔을 적에는 그렇지 않더니 요새에는 가끔 혼수 상태에 빠지시는 모양이야요."
+이만한 지식을 가지고 나는 최석이가 누워 있는 집 앞에 다다랐다.
+이 집은 통나무를 댓 개 우물 정자로 가로놓고 지붕은 무엇으로 했는지 모르나 눈이 덮이고, 문 하나 창 하나를 내었는데 문은 나무껍질인 모양이나 창은 젖빛 나는 유리창인 줄 알았더니 뒤에 알아본즉 그것은 유리가 아니요, 양목을 바르고 물을 뿜어서 얼려 놓은 것이었다. 그리고 통나무와 통나무 틈바구니에는 쇠털과 같은 마른 풀을 꼭꼭 박아서 바람을 막았다.
+문을 열고 들어서니 부엌에 들어서는 모양으로 쑥 빠졌는데 화끈화끈하는 것이 한증과 같다. 그렇지 않아도 침침한 날에 언 눈으로 광선 부족한 방에 들어오니, 캄캄 절벽이어서 아무것도 보이지 아니하였다.
+순임이가 앞서서 양초에 불을 켠다. 촛불 빛은 방 한편 쪽 침대라고 할 만한 높은 곳에 담요를 덮고 누운 최석의 시체와 같은 흰 얼굴을 비춘다.
+"아버지, 아버지 샌전 아저씨 오셨어요."
+하고 순임은 최석의 귀에 입을 대고 가만히 불렀다.
+그러나 대답이 없었다.
+나는 최석의 이마를 만져 보았다. 축축하게 땀이 흘렀다. 그러나 그리 더운 줄은 몰랐다.
+방 안의 공기는 숨이 막힐 듯하였다. 그 난방 장치는 삼굿의 원리를 이용한 것이었다. 돌멩이로 아궁이를 쌓고 그 위에 큰 돌멩이들을 많이 쌓고 거기다가 불을 때어서 달게 한 뒤에 거기 눈을 부어 뜨거운 증기를 발하는 것이었다.
+이 건축법은 조선 동포들이 시베리아로 금광을 찾아다니면서 하는 법이란 말을 들었으나 최석이가 누구에게서 배워 가지고 어떤 모양으로 지었는지는 최석의 말을 듣기 전에는 알 수 없는 일이다.
+나는 내 힘이 미치는 데까지 최석의 병 치료에 대한 손을 쓰고 어떻게 해서든지 이르쿠츠크의 병원으로 최석을 데려다가 입원시킬 도리를 궁리하였다. 그러나 냉정하게 생각하면 최석은 살아날 가망이 없는 것만 같았다.
+내가 간 지 사흘 만에 최석은 처음으로 정신을 차려서 눈을 뜨고 나를 알아보았다.
+그는 반가운 표정을 하고 빙그레 웃기까지 하였다.
+"다 일없나?"
+이런 말도 알아들을 수가 있었다.
+그러나 심히 기운이 없는 모양이기로 나는 많이 말을 하지 아니하였다.
+최석은 한참이나 눈을 감고 있더니,
+"정임이 소식 들었나?"
+하였다.
+"괜찮대요."
+하고 곁에서 순임이가 말하였다.
+그리고는 또 혼몽하는 듯하였다.
+그 날 또 한 번 최석은 정신을 차리고 순임더러는 저리로 가라는 뜻을 표하고 나더러 귀를 가까이 대라는 뜻을 보이기로 그대로 하였더니,
+"내 가방 속에 일기가 있으니 그걸 자네만 보고는 불살라 버려. 내가 죽은 뒤에라도 그것이 세상 사람의 눈에 들면 안 되지. 순임이가 볼까 걱정이 되지마는 내가 몸을 꼼짝할 수가 있나."
+하는 뜻을 말하였다.
+"그러지."
+하고 나는 고개를 끄덕여 보였다.
+그러고 난 뒤에 나는 최석이가 시킨 대로 가방을 열고 책들을 뒤져서 그 일기책이라는 공책을 꺼내었다.
+"순임이 너 이거 보았니?"
+하고 나는 곁에서 내가 책 찾는 것을 보고 섰던 순임에게 물었다.
+"아니오. 그게 무어여요?"
+하고 순임은 내 손에 든 책을 빼앗으려는 듯이 손을 내밀었다.
+나는 순임의 손이 닿지 않도록 책을 한편으로 비키며,
+"이것이 네 아버지 일기인 모양인데 너는 보이지 말고 나만 보라고 하셨다. 네 아버지가 네가 이것을 보았을까 해서 염려를 하시는데 안 보았으면 다행이다."
+하고 나는 그 책을 들고 밖으로 나왔다.
+날이 밝다. 해는 중천에 있다. 중천이래야 저 남쪽 지평선 가까운 데다. 밤이 열여덟 시간, 낮이 대여섯 시간밖에 안 되는 북쪽 나라다. 멀건 햇빛이다.
+나는 볕이 잘 드는 곳을 골라서 나무에 몸을 기대고 최석의 일기를 읽기 시작하였다. 읽은 중에서 몇 구절을 골라 볼까.
+"집이 다 되었다. 이 집은 내가 생전 살고 그 속에서 이 세상을 마칠 집이다. 마음이 기쁘다. 시끄러운 세상은 여기서 멀지 아니하냐. 내가 여기 홀로 있기로 누가 찾을 사람도 없을 것이다. 내가 여기서 죽기로 누가 슬퍼해 줄 사람도 없을 것이다. 때로 곰이나 찾아올까. 지나가던 사슴이나 들여다볼까.
+이것이 내 소원이 아니냐. 세상의 시끄러움을 떠나는 것이 내 소원이 아니냐. 이 속에서 나는 나를 이기기를 공부하자."
+첫날은 이런 평범한 소리를 썼다.
+그 이튿날에는.
+"어떻게나 나는 약한 사람인고. 제 마음을 제가 지배하지 못하는 사람인고. 밤새도록 나는 정임을 생각하였다. 어두운 허공을 향하여 정임을 불렀다. 정임이가 나를 찾아서 동경을 떠나서 이리로 오지나 아니하나 하고 생각하였다. 어떻게나 부끄러운 일인고? 어떻게나 가증한 일인고?
+나는 아내를 생각하려 하였다. 아이들을 생각하려 하였다. 아내와 아이들을 생각함으로 정임의 생각을 이기려 하였다.
+최석아, 너는 남편이 아니냐. 아버지가 아니냐. 정임은 네 딸이 아니냐. 이런 생각을 하였다.
+그래도 정임의 일류전은 아내와 아이들의 생각을 밀치고 달려오는 절대 위력을 가진 듯하였다.
+아, 나는 어떻게나 파렴치한 사람인고. 나이 사십이 넘어 오십을 바라보는 놈이 아니냐. 사십에 불혹이라고 아니 하느냐. 교육가로 깨끗한 교인으로 일생을 살아 왔다고 자처하는 내가 아니냐 하고 나는 내 입으로 내 손가락을 물어서 두 군데나 피를 내었다."
+최석의 둘째 날 일기는 계속된다.
+"내 손가락에서 피가 날 때에 나는 유쾌하였다. 나는 승첩의 기쁨을 깨달았다.
+그러나 아아 그러나 그 빨간, 참회의 핏방울 속에서도 애욕의 불길이 일지 아니하는가. 나는 마침내 제도할 수 없는 인생인가."
+이 집에 든 지 둘째날에 벌써 이러한 비관적 말을 하였다.
+또 며칠을 지난 뒤 일기에,
+"나는 동경으로 돌아가고 싶다. 정임의 곁으로 가고 싶다. 시베리아의광야의 유혹도 아무 힘이 없다. 어젯밤은 삼림의 좋은 달을 보았으나 그 달을 아름답게 보려 하였으나 아무리 하여도 아름답게 보이지를 아니하였다.
+하늘이나 달이나 삼림이나 모두 무의미한 존재다. 이처럼 무의미한 존재를 나는 경험한 일이 없다. 그것은 다만 기쁨을 자아내지 아니할 뿐더러 슬픔도 자아내지 못하였다. 그것은 잿더미였다. 아무도 듣는 이 없는 데서 내 진정을 말하라면 그것은 이 천지에 내게 의미 있는 것은 정임이밖에 없다는 것이다.
+나는 정임의 곁에 있고 싶다. 정임을 내 곁에 두고 싶다. 왜? 그것은 나도 모른다.
+만일 이 움 속에라도 정임이가 있다 하면 얼마나 이것이 즐거운 곳이 될까.
+그러나 이것은 불가능한 일이다. 이 일이 있어서는 아니 된다. 나는 이 생각을 죽여야 한다. 다시 거두를 못 하도록 목숨을 끊어 버려야 한다.
+이것을 나는 원한다. 원하지마는 내게는 그 힘이 없는 모양이다.
+나는 종교를 생각하여 본다. 철학을 생각하여 본다. 인류를 생각하여 본다. 나라를 생각하여 본다. 이것을 가지고 내 애욕과 바꾸려고 애써 본다. 그렇지마는 내게 그러한 힘이 없다. 나는 완전히 헬플리스함을 깨닫는다.
+아아 나는 어찌할꼬?
+나는 못생긴 사람이다. 그까짓 것을 못 이겨? 그까짓 것을 못 이겨?
+나는 예수의 광야에서의 유혹을 생각한다. 천하를 주마 하는 유혹을 생각한다. 나는 싯다르타 태자가 왕궁을 버리고 나온 것을 생각하고, 또 스토아 철학자의 의지력을 생각하였다.
+그러나 나는 그러한 생각으로도 이 생각을 이길 수가 없는 것 같다.
+나는 혁명가를 생각하였다. 모든 것 사랑도 목숨도 다 헌신짝같이 집어던지고 피 흐르는 마당으로 뛰어나가는 용사를 생각하였다. 나는 이끝없는 삼림 속으로 혁명의 용사 모양으로 달음박질치다가 기운이 진한 곳에서 죽어 버리는 것이 소원이었다. 그러나 거기까지도 이 생각은 따르지 아니할까.
+나는 지금 곧 죽어 버릴까. 나는 육혈포를 손에 들어 보았다. 이 방아쇠를 한 번만 튕기면 내 생명은 없어지는 것이 아닌가. 그리 되면 모든 이 마음의 움직임은 소멸되는 것이 아닌가. 이것으로 만사가 해결되는 것이 아닌가.
+아 하나님이시여, 힘을 주시옵소서. 천하를 이기는 힘보다도 나 자신을 이기는 힘을 주시옵소서. 이 죄인으로 하여금 하나님의 눈에 의롭고 깨끗한 사람으로 이 일생을 마치게 하여 주시옵소서, 이렇게 나는 기도를 한다.
+그러나 하나님께서는 나를 버리셨다. 하나님께서는 내게 힘을 주시지 아니하시었다. 나를 이 비참한 자리에서 썩어져 죽게 하시었다."
+최석은 어떤 날 일기에 또 이런 것도 썼다. 그것은 예전 내게 보낸 편지에 있던 꿈 이야기를 연상시키는 것이었다. 그것은 이러하다.
+"오늘 밤은 달이 좋다. 시베리아의 겨울 해는 참 못생긴 사람과도 같이 기운이 없지마는 하얀 땅, 검푸른 하늘에 저쪽 지평선을 향하고 흘러가는 반달은 참으로 맑음 그것이었다.
+나는 평생 처음 시 비슷한 것을 지었다.
+임과 이별하던 날 밤에는 남쪽 나라에 바람비가 쳤네
+임 타신 자동차의 뒷불이 빨간 뒷불이 빗발에 찢겼네
+임 떠나 혼자 헤매는 시베리아의 오늘 밤에는
+지려는 쪽달이 눈 덮인 삼림에 걸렸구나
+아아 저 쪽달이여
+억지로 반을 갈겨진 것도 같아라
+아아 저 쪽달이여
+잃어진 짝을 찾아
+차디찬 허공 속을 영원히 헤매는 것도 같구나
+나도 저 달과 같이 잃어버린 반쪽을 찾아 무궁한 시간과 공간에서 헤매는 것만 같다.
+에익. 내가 왜 이리 약한가. 어찌하여 크나큰 많은 일을 돌아보지 못하고 요만한 애욕의 포로가 되는가.
+그러나 나는 차마 그 달을 버리고 들어올 수가 없었다. 내가 왜 이렇게 센티멘털하게 되었는고. 내 쇠 같은 의지력이 어디로 갔는고. 내 누를 수 없는 자존심이 어디로 갔는고. 나는 마치 유모의 손에 달린 젖먹이와도 같다. 내 일신은 도시 애욕 덩어리로 화해 버린 것 같다.
+이른바 사랑 사랑이란 말은 종교적 의미인 것 이외에도 입에 담기도 싫어하던 말이다 이런 것은 내 의지력과 자존심을 녹여 버렸는가. 또 이 부자연한 고독의 생활이 나를 이렇게 내 인격을 이렇게 파괴하였는가.
+그렇지 아니하면 내 자존심이라는 것이나, 의지력이라는 것이나, 인격이라는 것이 모두 세상의 습관과 사조에 휩쓸리던 것인가. 남들이 그러니까 남들이 옳다니까 남들이 무서우니까 이 애욕의 무덤에 회를 발랐던 것인가. 그러다가 고독과 반성의 기회를 얻으매 모든 회칠과 가면을 떼어 버리고 빨가벗은 애욕의 뭉텅이가 나온 것인가.
+그렇다 하면, 이것이 참된 나인가. 이것이 하나님께서 지어 주신 대로의 나인가. 가슴에 타오르는 애욕의 불길 이 불길이 곧 내 영혼의 불길인가.
+어쩌면 그 모든 높은 이상들 인류에 대한, 민족에 대한, 도덕에 대한, 신앙에 대한 그 높은 이상들이 이렇게도 만만하게 마치 바람에 불리는 재 모양으로 자취도 없이 흩어져 버리고 말까. 그리고 그 뒤에는 평소에그렇게도 미워하고 천히 여기던 애욕의 검은 흙만 남고 말까.
+아아 저 눈 덮인 땅이여, 차고 맑은 달이여, 허공이여! 나는 너희들을 부러워하노라.
+불교도들의 해탈이라는 것이 이러한 애욕이 불붙는 지옥에서 눈과 같이 싸늘하고 허공과 같이 빈 곳으로 들어감을 이름인가.
+석가의 팔 년 간 설산 고행이 이 애욕의 뿌리를 끊으려 함이라 하고 예수의 사십 일 광야의 고행과 겟세마네의 고민도 이 애욕의 뿌리 때문이었던가.
+그러나 그것을 이기어 낸 사람이 천지 개벽 이래에 몇몇이나 되었는고? 나 같은 것이 그 중에 한 사람 되기를 바랄 수가 있을까.
+나 같아서는 마침내 이 애욕의 불길에 다 타서 재가 되어 버릴 것만 같다. 아아 어떻게나 힘있고 무서운 불길인고."
+이러한 고민의 자백도 있었다.
+또 어떤 날 일기에는 최석은 이런 말을 썼다.
+"나는 단연히 동경으로 돌아가기를 결심하였다."
+그리고는 그 이튿날은,
+"나는 단연히 동경으로 돌아가리란 결심을 한 것을 굳세게 취소한다. 나는 이러한 결심을 하는 나 자신을 굳세게 부인한다."
+또 이런 말도 있다.
+"나는 정임을 시베리아로 부르련다."
+또 그 다음에는,
+"아아 나는 하루바삐 죽어야 한다. 이 목숨을 연장하였다가는 무슨 일을 저지를는지 모른다. 나는 깨끗하게 나를 이기는 도덕적 인격으로 이 일생을 마쳐야 한다. 이 밖에 내 사업이 무엇이냐."
+또 어떤 곳에는,
+"아아 무서운 하룻밤이었다. 나는 지난 하룻밤을 누를 수 없는 애욕의 불길에 탔다. 나는 내 주먹으로 내 가슴을 두드리고 머리를 벽에 부딪쳤다. 나는 주먹으로 담벽을 두드려 손등이 터져서 피가 흘렀다. 나는 내 머리카락을 쥐어뜯었다. 나는 수없이 발을 굴렀다. 나는 이 무서운 유혹을 이기려고 내 몸을 아프게 하였다. 나는 견디다 못하여 문을 박차고 뛰어나갔다. 밖에는 달이 있고 눈이 있었다. 그러나 눈은 핏빛이요, 달은 찌그러진 것 같았다. 나는 눈 속으로 달음박질쳤다. 달을 따라서 엎드러지며 자빠지며 달음질쳤다. 나는 소리를 질렀다. 나는 미친 사람 같았다."
+그러고는 어디까지 갔다가 어느 때에 어떠한 심경의 변화를 얻어 가지고 돌아왔다는 말은 쓰이지 아니하였으나 최석의 병의 원인을 설명하는 것 같았다.
+"열이 나고 기침이 난다. 가슴이 아프다. 이것이 폐렴이 되어서 혼자 깨끗하게 이 생명을 마치게 하여 주소서 하고 빈다. 나는 오늘부터 먹고 마시기를 그치련다."
+이러한 말을 썼다. 그러고는,
+"정임, 정임, 정임, 정임."
+하고 정임의 이름을 수없이 쓴 것도 있고, 어떤 데는,
+"Overcome, Overcome."
+하고 영어로 쓴 것도 있었다.
+그리고 마지막에,
+"나는 죽음과 대면하였다. 사흘째 굶고 앓은 오늘에 나는 극히 맑고 침착한 정신으로 죽음과 대면하였다. 죽음은 검은 옷을 입었으나 그 얼굴에는 자비의 표정이 있었다. 죽음은 곧 검은 옷을 입은 구원의 손이었다. 죽음은 아름다운 그림자였다. 죽음은 반가운 애인이요, 결코 무서운 원수가 아니었다. 나는 죽음의 손을 잡노라. 감사하는 마음으로 죽음의 품에 안기노라. 아멘."
+이것을 쓴 뒤에는 다시는 일기가 없었다. 이것으로 최석이가 그 동안 지난 일을 적어도 심리적 변화만은 대강 추측할 수가 있었다.
+다행히 최석의 병은 점점 돌리는 듯하였다. 열도 내리고 식은땀도 덜 흘렸다. 안 먹는다고 고집하던 음식도 먹기를 시작하였다.
+정임에게로 갔던 노파에게서는 정임도 열이 내리고 일어나 앉을 만하다는 편지가 왔다.
+나는 노파의 편지를 최석에게 읽어 주었다. 최석은 그 편지를 듣고 매우 흥분하는 모양이었으나 곧 안심하는 빛을 보였다.
+나는 최석의 병이 돌리는 것을 보고 정임을 찾아볼 양으로 떠나려 하였으나 순임이가 듣지 아니하였다. 혼자서 앓는 아버지를 맡아 가지고 있을 수는 없다는 것이었다. 그래서 노파가 오기를 기다리기로 하였다.
+나는 최석이가 먹을 음식도 살 겸 우편국에도 들를 겸 시가까지 가기로 하고 이 곳 온 지 일 주일이나 지나서 처음으로 산에서 나왔다.
+나는 이르쿠츠크에 가서 최석을 위하여 약품과 먹을 것을 사고 또 순임을 위해서도 먹을 것과 의복과 또 하모니카와 손풍금도 사 가지고 정거장에 나와서 돌아올 차를 기다리고 있었다.
+나는 순후해 보이는 아라사 사람들이 정거장에서 오락가락하는 것을 보고 속으로는 최석이가 병이 좀 나은 것을 다행으로 생각하고, 또 최석과 정임의 장래가 어찌 될까 하는 것도 생각하면서 뷔페(식당)에서 뜨거운 차이(차)를 마시고 있었다.
+이 때에 밖을 바라보고 있던 내 눈은 문득 이상한 것을 보았다. 그것은 그 노파가 이리로 향하고 걸어오는 것인데 그 노파와 팔을 걸은 젊은 여자가 있는 것이다. 머리를 검은 수건으로 싸매고 입과 코를 가리웠으니 분명히 알 수 없으나 혹은 정임이나 아닌가 할 수밖에 없었다. 정임이가 몸만 기동하게 되면 최석을 보러 올 것은 정임의 열정적인 성격으로 보아서 당연한 일이기 때문이었다.
+나는 반쯤 먹던 차를 놓고 뷔페 밖으로 뛰어나갔다.
+"오 미시즈 체스터필드?"
+하고 나는 노파 앞에 손을 내어밀었다. 노파는 체스터필드라는 미국 남편의 성을 따라서 부르는 것을 기억하였다.
+"선생님!"
+하는 것은 정임이었다. 그 소리만은 변치 아니하였다. 나는 검은 장갑을 낀 정임의 손을 잡았다. 나는 여러 말 아니하고 노파와 정임을 뷔페로 끌고 들어왔다.
+늙은 뷔페 보이는 번쩍번쩍하는 사모바르에서 차 두 잔을 따라다가 노파와 정임의 앞에 놓았다.
+노파는 어린애에게 하는 모양으로 정임의 수건을 벗겨 주었다. 그 속에서는 해쓱하게 여윈 정임의 얼굴이 나왔다. 두 볼에 불그레하게 홍훈이 도는 것도 병 때문인가.
+"어때? 신열은 없나?"
+하고 나는 정임에게 물었다.
+"괜찮아요."
+하고 정임은 웃으며,
+"최 선생님께서는 어떠세요?"
+하고 묻는다.
+"좀 나으신 모양이야. 그래서 나는 오늘 정임을 좀 보러 가려고 했는데 이 체스터필드 부인께서 아니 오시면 순임이가 혼자 있을 수가 없다고 해서, 그래 이렇게 최 선생 자실 것을 사 가지고 가는 길이야."
+하고 말을 하면서도 나는 정임의 눈과 입과 목에서 그의 병과 마음을 알아보려고 애를 썼다.
+중병을 앓은 깐 해서는 한 달 전 남대문서 볼 때보다 얼마 더 초췌한 것 같지는 아니하였다.
+"네에."
+하고 정임은 고개를 숙였다. 그의 안경알에는 이슬이 맺혔다.
+"선생님 댁은 다 안녕하셔요?"
+"응, 내가 떠날 때에는 괜찮았어."
+"최 선생님 댁도?"
+"응."
+"선생님 퍽은 애를 쓰셨어요."
+하고 정임은 울음인지 웃음인지 모를 웃음을 웃는다.
+말을 모르는 노파는 우리가 하는 말을 눈치나 채려는 듯이 멀거니 보고 있다가 서투른 영어로,
+"아직 미스 남은 신열이 있답니다. 그래도 가 본다고, 죽어도 가 본다고 내 말을 안 듣고 따라왔지요."
+하고 정임에게 애정 있는 눈흘김을 주며,
+"유 노티 차일드(말썽꾼이)."
+하고 입을 씰룩하며 정임을 안경 위로 본다.
+"니체워, 마뚜슈까(괜찮아요, 어머니)."
+하고 정임은 노파를 보고 웃었다. 정임의 서양 사람에게 대한 행동은 서양식으로 째었다고 생각하였다.
+정임은 도리어 유쾌한 빛을 보였다. 다만 그의 붉은빛 띤 눈과 마른 입술이 그의 몸에 열이 있음을 보였다. 나는 그의 손끝과 발끝이 싸늘하게 얼었을 것을 상상하였다.
+마침 이 날은 날이 온화하였다. 엷은 햇빛도 오늘은 두꺼워진 듯하였다.
+우리 세 사람은 F역에서 내려서 썰매 하나를 얻어 타고 산으로 향하였다. 산도 아니지마는 산 있는 나라에서 살던 우리는 최석이가 사는 곳을 산이라고 부르는 습관을 지었다. 삼림이 있으니 산같이 생각된 까닭이었다.
+노파가 오른편 끝에 앉고, 가운데다가 정임을 앉히고 왼편 끝에 내가 앉았다.
+쩟쩟쩟 하는 소리에 말은 달리기 시작하였다. 한 필은 키 큰 말이요, 한 필은 키가 작은 말인데 키 큰 말은 아마 늙은 군마 퇴물인가 싶게 허우대는 좋으나 몸이 여위고 털에는 윤이 없었다. 조금만 올라가는 길이 되어도 고개를 숙이고 애를 썼다. 작은 말은 까불어서 가끔 채찍으로 얻어맞았다.
+"아이 삼림이 좋아요."
+하고 정임은 정말 기쁜 듯이 나를 돌아보았다.
+"좋아?"
+하고 나는 멋없이 대꾸하고 나서, 후회되는 듯이,
+"밤낮 삼림 속에서만 사니까 지루한데."
+하는 말을 붙였다.
+"저는 저 눈 있는 삼림 속으로 한정 없이 가고 싶어요. 그러나 저는 인제 기운이 없으니깐 웬걸 그래 보겠어요?"
+하고 한숨을 쉬었다.
+"왜 그런 소릴 해. 인제 나을걸."
+하고 나는 정임의 눈을 들여다보았다. 마치 슬픈 눈물 방울이나 찾으려는 듯이.
+"제가 지금도 열이 삼십팔 도가 넘습니다. 정신이 흐릿해지는 것을 보니까 아마 더 올라가나 봐요. 그래도 괜찮아요. 오늘 하루야 못 살라고요. 오늘 하루만 살면 괜찮아요. 최 선생님만 한 번 뵙고 죽으면 괜찮아요."
+"왜 그런 소릴 해?"
+하고 나는 책망하는 듯이 언성을 높였다.
+정임은 기침을 시작하였다. 한바탕 기침을 하고는 기운이 진한 듯이 노파에게 기대며 조선말로,
+"추워요."
+하였다. 이 여행이 어떻게 정임의 병에 좋지 못할 것은 의사가 아닌 나로도 짐작할 수가 있었다. 그러나 나로는 더 어찌할 수가 없었다.
+나는 외투를 벗어서 정임에게 입혀 주고 노파는 정임을 안아서 몸이 덜 흔들리도록 또 춥지 않도록 하였다.
+나는 정임의 모양을 애처로워서 차마 볼 수가 없었다. 그러나 이것은 하나님밖에는 어찌할 도리가 없는 일이었다.
+얼마를 지나서 정임은 갑자기 고개를 들고 일어나며,
+"인제 몸이 좀 녹았습니다. 선생님 추우시겠어요. 이 외투 입으셔요."
+하고 그의 입만 웃는 웃음을 웃었다.
+"난 춥지 않아. 어서 입고 있어."
+하고 나는 정임이가 외투를 벗는 것을 막았다. 정임은 더 고집하려고도 아니하고,
+"선생님 시베리아의 삼림은 참 좋아요. 눈 덮인 것이 더 좋은 것 같아요. 저는 이 인적 없고 자유로운 삼림 속으로 헤매어 보고 싶어요."
+하고 아까 하던 것과 같은 말을 또 하였다.
+"며칠 잘 정양하여서, 날이나 따뜻하거든 한 번 산보나 해 보지."
+하고 나는 정임의 말 뜻이 다른 데 있는 줄을 알면서도 부러 평범하게 대답하였다.
+정임은 대답이 없었다.
+"여기서도 아직 멀어요?"
+하고 정임은 몸이 흔들리는 것을 심히 괴로워하는 모양으로 두 손을 자리에 짚어 몸을 버티면서 말하였다.
+"고대야, 최 선생이 반가워할 터이지. 오죽이나 반갑겠나."
+하고 나는 정임을 위로하는 뜻으로 말하였다.
+"아이 참 미안해요. 제가 죄인이야요. 저 때문에 애매한 누명을 쓰시고 저렇게 사업도 버리시고 병환까지 나시니 저는 어떡허면 이 죄를 씻습니까?"
+하고 눈물 고인 눈으로 정임은 나를 쳐다보았다.
+나는 정임과 최석을 이 자유로운 시베리아의 삼림 속에 단둘이 살게 하고 싶었다. 그러나 최석은 살아나가겠지마는 정임이가 살아날 수가 있을까, 하고 나는 정임의 어깨를 바라보았다. 그의 목숨은 실낱 같은 것 같았다. 바람받이에 놓인 등잔불과만 같은 것 같았다. 이 목숨이 끊어지기 전에 사랑하는 이의 얼굴을 한 번 대하겠다는 것밖에 아무 소원이 없는 정임은 참으로 가엾어서 가슴이 미어지는 것 같았다.
+"염려 말어. 무슨 걱정이야? 최 선생도 병이 돌리고 정임도 인제 얼마 정양하면 나을 것 아닌가. 아무 염려 말아요."
+하고 나는 더욱 최석과 정임과 두 사람의 사랑을 달하게 할 결심을 하였다. 하나님께서 계시다면 이 가엾은 간절한 두 사람의 마음을 가슴 미어지게 아니 생각할 리가 없다고 생각하였다. 우주의 모든 일 중에 정임의 정경보다 더 슬프고 불쌍한 정경이 또 있을까 하였다. 차디찬 눈으로 덮인 시베리아의 광야에 병든 정임의 사랑으로 타는 불똥과 같이 날아가는 이 정경은 인생이 가질 수 있는 최대한 비극인 것 같았다.
+정임은 지쳐서 고개를 숙이고 있다가도 가끔 고개를 들어서는 기운 나는 양을 보이려고, 유쾌한 양을 보이려고 애를 썼다.
+"저 나무 보셔요. 오백 년은 살았겠지요?"
+이런 말도 하였다. 그러나 그것은 다 억지로 지어서 하는 것이었다. 그러다가는 또 기운이 지쳐서는 고개를 숙이고, 혹은 노파의 어깨에 혹은 내 어깨에 쓰러졌다.
+마침내 우리가 향하고 가는 움집이 보였다.
+"정임이, 저기야."
+하고 나는 움집을 가리켰다.
+"네에?"
+하고 정임은 내 손가락 가는 곳을 보고 다음에는 내 얼굴을 보았다. 잘 보이지 않는 모양이다.
+"저기 저것 말야. 저기 저 고작 큰 전나무 두 개가 있지 않아? 그 사이로 보이는 저, 저거 말야. 옳지 옳지, 순임이 지금 나오지 않아?"
+하였다.
+순임이가 무엇을 가지러 나오는지 문을 열고 나와서는 밥 짓느라고 지어 놓은 이를테면 부엌에를 들어갔다가 나오는 길에 이 쪽을 바라보다가 우리를 발견하였는지 몇 걸음 빨리 오다가는 서서 보고 오다가는 서서 보더니 내가 모자를 내두르는 것을 보고야 우리 일행인 것을 확실히 알고 달음박질을 쳐서 나온다.
+우리 썰매를 만나자,
+"정임이야? 어쩌면 이 추운데."
+하고 순임은 정임을 안고 그 안경으로 정임의 눈을 들여다본다.
+"어쩌면 앓으면서 이렇게 와?"
+하고 순임은 노파와 나를 책망하는 듯이 돌아보았다.
+"아버지 어떠시냐?"
+하고 나는 짐을 들고 앞서서 오면서 뒤따르는 순임에게 물었다.
+"아버지요?"
+하고 순임은 어른에게 대한 경의를 표하노라고 내 곁에 와서 걸으며,
+"아버지께서 오늘은 말씀을 많이 하셨어요. 순임이가 고생하는구나 고맙다, 이런 말씀도 하시고, 지금 같아서는 일어날 것도 같은데 기운이 없어서, 이런 말씀도 하시고, 또 선생님이 이르쿠츠크에를 들어가셨으니 무엇을 사 오실 듯싶으냐, 알아맞혀 보아라, 이런 농담도 하시고, 정임이가 어떤가 한 번 보았으면, 이런 말씀도 하시겠지요. 또 순임아, 내가 죽더라도 정임을 네 친동생으로 알아서 부디 잘 사랑해 주어라, 정임은 불쌍한 애다, 참 정임은 불쌍해! 이런 말씀도 하시겠지요. 그렇게 여러 가지 말씀을 많이 하시더니, 순임아 내가 죽거든 선생님을 아버지로 알고 그 지도를 받아라, 그러시길래 제가 아버지 안 돌아가셔요! 그랬더니 아버지께서 웃으시면서, 죽지 말까, 하시고는 어째 가슴이 좀 거북한가, 하시더니 잠이 드셨어요. 한 시간이나 되었을까, 온."
+집 앞에 거의 다 가서는 순임은 정임의 팔을 꼈던 것을 놓고 빨리 집으로 뛰어들어갔다.
+치마폭을 펄럭거리고 뛰는 양에는 어렸을 적 말괄량이 순임의 모습이 남아 있어서 나는 혼자 웃었다. 순임은 정임이가 왔다는 기쁜 소식을 한 시각이라도 빨리 아버지께 전하고 싶었던 것이다.
+"아버지, 주무시우? 정임이가 왔어요. 정임이가 왔습니다."
+하고 부르는 소리가 밖에서도 들렸다.
+나도 방에 들어서고, 정임도 뒤따라 들어서고, 노파는 부엌으로 물건을 두러 들어갔다.
+방은 절벽같이 어두웠다.
+"순임아, 불을 좀 켜려무나."
+하고 최석의 얼굴을 찾느라고 눈을 크게 뜨고 고개를 숙이며,
+"자나? 정임이가 왔네."
+하고 불렀다.
+정임도 곁에 와서 선다.
+최석은 대답이 없었다.
+순임이가 촛불을 켜자 최석의 얼굴이 환하게 보였다.
+"여보게, 여봐. 자나?"
+하고 나는 무서운 예감을 가지면서 최석의 어깨를 흔들었다.
+그것이 무엇인지 모르지마는 최석은 시체라 하는 것을 나는 내 손을 통해서 깨달았다.
+나는 깜짝 놀라서 이불을 벗기고 최석의 팔을 잡아 맥을 짚어 보았다. 거기는 맥이 없었다.
+나는 최석의 자리옷 가슴을 헤치고 귀를 가슴에 대었다. 그 살은 얼음과 같이 차고 그 가슴은 고요하였다. 심장은 뛰기를 그친 것이었다.
+나는 최석의 가슴에서 귀를 떼고 일어서면서,
+"네 아버지는 돌아가셨다. 네 손으로 눈이나 감겨 드려라."
+하였다. 내 눈에서는 눈물이 흘렀다.
+"선생님!"
+하고 정임은 전연히 절제할 힘을 잃어버린 듯이 최석의 가슴에 엎어졌다. 그러고는 소리를 내어 울었다. 순임은,
+"아버지, 아버지!"
+하고 최석의 베개 곁에 이마를 대고 울었다.
+아라사 노파도 울었다.
+방 안에는 오직 울음 소리뿐이요, 말이 없었다. 최석은 벌써 이 슬픈 광경도 몰라보는 사람이었다.
+최석이가 자기의 싸움을 이기고 죽었는지, 또는 끝까지 지다가 죽었는지 그것은 영원한 비밀이어서 알 도리가 없었다. 그러나 이것만은 확실하다 그의 의식이 마지막으로 끝나는 순간에 그의 의식기에 떠오르던 오직 하나가 정임이었으리라는 것만은.
+지금 정임이가 그의 가슴에 엎어져 울지마는, 정임의 뜨거운 눈물이 그의 가슴을 적시건마는 최석의 가슴은 뛸 줄을 모른다. 이것이 죽음이란 것이다.
+뒤에 경찰의가 와서 검사한 결과에 의하면, 최석은 폐렴으로 앓던 결과로 심장마비를 일으킨 것이라고 하였다.
+나는 최석의 장례를 끝내고 순임과 정임을 데리고 오려 하였으나 정임은 듣지 아니하고 노파와 같이 바이칼 촌으로 가 버렸다.
+그런 뒤로는 정임에게서는 일체 음신이 없다. 때때로 노파에게서 편지가 오는데 정임은 최석이가 있던 방에 가만히 있다고만 하였다.
+서투른 영어가 뜻을 충분히 발표하지 못하는 것이었다.
+나는 정임에게 안심하고 병을 치료하라는 편지도 하고 돈이 필요하거든 청구하라는 편지도 하나 영 답장이 없다.
+만일 정임이가 죽었다는 기별이 오면 나는 한 번 더 시베리아에 가서 둘을 가지런히 묻고 `두 별 무덤'이라는 비를 세워 줄 생각이다. 그러나 나는 정임이가 조선으로 오기를 바란다.
+여러분은 최석과 정임에게 대한 이 기록을 믿고 그 두 사람에게 대한 오해를 풀라.
+EOT;
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/lt_LT/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/lt_LT/Address.php
new file mode 100644
index 00000000..f6cc1764
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/lt_LT/Address.php
@@ -0,0 +1,207 @@
+generator->parse($format);
+ }
+
+ public static function country()
+ {
+ return static::randomElement(static::$country);
+ }
+
+ public static function postcode()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$postcode)));
+ }
+
+ public static function regionSuffix()
+ {
+ return static::randomElement(static::$regionSuffix);
+ }
+
+ public static function region()
+ {
+ return static::randomElement(static::$region);
+ }
+
+ public static function citySuffix()
+ {
+ return static::randomElement(static::$citySuffix);
+ }
+
+ public function city()
+ {
+ return static::randomElement(static::$city);
+ }
+
+ public static function streetSuffix()
+ {
+ return static::randomElement(static::$streetSuffix);
+ }
+
+ public static function street()
+ {
+ return static::randomElement(static::$street);
+ }
+
+ /**
+ * Lithuania municipality
+ * @link https://en.wikipedia.org/wiki/Municipality
+ * @return string
+ */
+ public function municipality()
+ {
+ return static::randomElement(static::$municipality);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/lt_LT/Company.php b/vendor/fakerphp/faker/src/Faker/Provider/lt_LT/Company.php
new file mode 100644
index 00000000..89370b3d
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/lt_LT/Company.php
@@ -0,0 +1,15 @@
+generator->parse(static::randomElement(static::$lastNameFormat));
+ }
+
+ /**
+ * Return male last name
+ * @return string
+ * @example 'Vasiliauskas'
+ */
+ public function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ /**
+ * Return female last name
+ * @return string
+ * @example 'Žukauskaitė'
+ */
+ public function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+
+ /**
+ * Return driver license number
+ * @return string
+ * @example 12345678
+ */
+ public function driverLicence()
+ {
+ return $this->bothify('########');
+ }
+
+ /**
+ * Return passport number
+ * @return string
+ * @example 12345678
+ */
+ public function passportNumber()
+ {
+ return $this->bothify('########');
+ }
+
+ /**
+ * National Personal Identity number (asmens kodas)
+ * @link https://en.wikipedia.org/wiki/National_identification_number#Lithuania
+ * @link https://lt.wikipedia.org/wiki/Asmens_kodas
+ * @param string $gender [male|female]
+ * @param \DateTime $birthdate
+ * @param string $randomNumber three integers
+ * @return string on format XXXXXXXXXXX
+ */
+ public function personalIdentityNumber($gender = 'male', \DateTime $birthdate = null, $randomNumber = '')
+ {
+ if (!$birthdate) {
+ $birthdate = \Faker\Provider\DateTime::dateTimeThisCentury();
+ }
+
+ $genderNumber = ($gender == 'male') ? 1 : 0;
+ $firstNumber = (int) floor($birthdate->format('Y') / 100) * 2 - 34 - $genderNumber;
+
+ $datePart = $birthdate->format('ymd');
+ $randomDigits = (string) (! $randomNumber || strlen($randomNumber) < 3) ? static::numerify('###') : substr($randomNumber, 0, 3);
+ $partOfPerosnalCode = $firstNumber . $datePart . $randomDigits;
+
+ $sum = self::calculateSum($partOfPerosnalCode, 1);
+ $liekana = $sum % 11;
+
+ if ($liekana !== 10) {
+ $lastNumber = $liekana;
+ return $firstNumber . $datePart . $randomDigits . $lastNumber;
+ }
+
+ $sum = self::calculateSum($partOfPerosnalCode, 2);
+ $liekana = $sum % 11;
+
+ $lastNumber = ($liekana !== 10) ? $liekana : 0;
+ return $firstNumber . $datePart . $randomDigits . $lastNumber;
+ }
+
+ /**
+ * Calculate the sum of personal code
+ * @link https://en.wikipedia.org/wiki/National_identification_number#Lithuania
+ * @link https://lt.wikipedia.org/wiki/Asmens_kodas
+ * @param string $numbers
+ * @param int $time [1|2]
+ * @return int
+ */
+ private static function calculateSum($numbers, $time = 1)
+ {
+ if ($time == 1) {
+ $multipliers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 1 ];
+ } else {
+ $multipliers = [3, 4, 5, 6, 7, 8, 9, 1, 2, 3 ];
+ }
+
+ $sum = 0;
+ for ($i=1; $i <= 10; $i++) {
+ $sum += ((int) $numbers[$i - 1]) * $multipliers[$i - 1];
+ }
+
+ return (int) $sum;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/lt_LT/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/lt_LT/PhoneNumber.php
new file mode 100644
index 00000000..05e32d31
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/lt_LT/PhoneNumber.php
@@ -0,0 +1,17 @@
+generator->parse($format);
+ }
+
+ public static function country()
+ {
+ return static::randomElement(static::$country);
+ }
+
+ public static function postcode()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$postcode)));
+ }
+
+ public static function regionSuffix()
+ {
+ return static::randomElement(static::$regionSuffix);
+ }
+
+ public static function region()
+ {
+ return static::randomElement(static::$region);
+ }
+
+ public static function cityPrefix()
+ {
+ return static::randomElement(static::$cityPrefix);
+ }
+
+ public function city()
+ {
+ return static::randomElement(static::$city);
+ }
+
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ public static function street()
+ {
+ return static::randomElement(static::$street);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/lv_LV/Color.php b/vendor/fakerphp/faker/src/Faker/Provider/lv_LV/Color.php
new file mode 100644
index 00000000..9edc9993
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/lv_LV/Color.php
@@ -0,0 +1,19 @@
+format('dmy');
+ $randomDigits = (string) static::numerify('####');
+
+ $checksum = Luhn::computeCheckDigit($datePart . $randomDigits);
+
+ return $datePart . '-' . $randomDigits . $checksum;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/lv_LV/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/lv_LV/PhoneNumber.php
new file mode 100644
index 00000000..c29d39fb
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/lv_LV/PhoneNumber.php
@@ -0,0 +1,15 @@
+ static::latitude(42.43, 42.45),
+ 'longitude' => static::longitude(19.16, 19.27)
+ ];
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/me_ME/Company.php b/vendor/fakerphp/faker/src/Faker/Provider/me_ME/Company.php
new file mode 100644
index 00000000..a0040659
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/me_ME/Company.php
@@ -0,0 +1,49 @@
+generator->parse(static::$idNumberFormat));
+ }
+
+ /**
+ * @return string
+ * @example 'Ф'
+ */
+ public function alphabet()
+ {
+ return static::randomElement(static::$alphabet);
+ }
+
+ /**
+ * @return string
+ * @example 'Э'
+ */
+ public function namePrefix()
+ {
+ return static::randomElement(static::$namePrefix);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/mn_MN/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/mn_MN/PhoneNumber.php
new file mode 100644
index 00000000..e138a09e
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/mn_MN/PhoneNumber.php
@@ -0,0 +1,13 @@
+ Townships
+ * @link https://en.wikipedia.org/wiki/Template:Johor > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Kedah > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Kelantan > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Melaka > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Negeri_Sembilan > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Perak > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Penang > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Selangor > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Terengganu > Townships
+ */
+ protected static $townshipPrefix = [
+ 'Alam', 'Apartment', 'Ara',
+ 'Bandar', 'Bandar', 'Bandar', 'Bandar', 'Bandar', 'Bandar',
+ 'Bandar Bukit', 'Bandar Seri', 'Bandar Sri', 'Bandar Baru', 'Batu', 'Bukit',
+ 'Desa', 'Damansara',
+ 'Kampung', 'Kampung Baru', 'Kampung Baru', 'Kondominium', 'Kota',
+ 'Laman', 'Lembah',
+ 'Medan',
+ 'Pandan', 'Pangsapuri', 'Petaling', 'Puncak',
+ 'Seri', 'Sri',
+ 'Taman', 'Taman', 'Taman', 'Taman', 'Taman', 'Taman',
+ 'Taman Desa',
+ ];
+ protected static $townshipSuffix = [
+ 'Aman', 'Amanjaya', 'Anggerik', 'Angkasa', 'Antarabangsa', 'Awan',
+ 'Bahagia', 'Bangsar', 'Baru', 'Belakong', 'Bendahara', 'Bestari', 'Bintang', 'Brickfields',
+ 'Casa', 'Changkat', 'Country Heights',
+ 'Damansara', 'Damai', 'Dato Harun', 'Delima', 'Duta',
+ 'Flora',
+ 'Gembira', 'Genting',
+ 'Harmoni', 'Hartamas',
+ 'Impian', 'Indah', 'Intan',
+ 'Jasa', 'Jaya',
+ 'Keramat', 'Kerinchi', 'Kiara', 'Kinrara', 'Kuchai',
+ 'Laksamana',
+ 'Mahkota', 'Maluri', 'Manggis', 'Maxwell', 'Medan', 'Melawati', 'Menjalara', 'Meru', 'Mulia', 'Mutiara',
+ 'Pahlawan', 'Perdana', 'Pertama', 'Permai', 'Pelangi', 'Petaling', 'Pinang', 'Puchong', 'Puteri', 'Putra',
+ 'Rahman', 'Rahmat', 'Raya', 'Razak', 'Ria',
+ 'Saujana', 'Segambut', 'Selamat', 'Selatan', 'Semarak', 'Sentosa', 'Seputeh', 'Setapak', 'Setia Jaya', 'Sinar', 'Sungai Besi', 'Sungai Buaya', 'Sungai Long', 'Suria',
+ 'Tasik Puteri', 'Tengah', 'Timur', 'Tinggi', 'Tropika', 'Tun Hussein Onn', 'Tun Perak', 'Tunku',
+ 'Ulu', 'Utama', 'Utara',
+ 'Wangi',
+ ];
+
+ /**
+ * @link https://en.wikipedia.org/wiki/Template:Greater_Kuala_Lumpur
+ * @link https://en.wikipedia.org/wiki/Template:Johor
+ * @link https://en.wikipedia.org/wiki/Template:Kedah
+ * @link https://en.wikipedia.org/wiki/Template:Kelantan
+ * @link https://en.wikipedia.org/wiki/Template:Labuan
+ * @link https://en.wikipedia.org/wiki/Template:Melaka
+ * @link https://en.wikipedia.org/wiki/Template:Negeri_Sembilan
+ * @link https://en.wikipedia.org/wiki/Template:Pahang
+ * @link https://en.wikipedia.org/wiki/Template:Perak
+ * @link https://en.wikipedia.org/wiki/Template:Perlis
+ * @link https://en.wikipedia.org/wiki/Template:Penang
+ * @link https://en.wikipedia.org/wiki/Template:Sabah
+ * @link https://en.wikipedia.org/wiki/Template:Sarawak
+ * @link https://en.wikipedia.org/wiki/Template:Selangor
+ * @link https://en.wikipedia.org/wiki/Template:Terengganu
+ */
+ protected static $towns = [
+ 'johor' => [
+ 'Ayer Hitam',
+ 'Batu Pahat', 'Bukit Gambir', 'Bukit Kepong', 'Bukit Naning',
+ 'Desaru',
+ 'Endau',
+ 'Gelang Patah', 'Gemas Baharu',
+ 'Iskandar Puteri',
+ 'Jementah', 'Johor Lama', 'Johor Bahru',
+ 'Kempas', 'Kluang', 'Kota Iskandar', 'Kota Tinggi', 'Kukup', 'Kulai',
+ 'Labis ', 'Larkin', 'Layang-Layang',
+ 'Mersing', 'Muar',
+ 'Pagoh', 'Paloh', 'Parit Jawa', 'Pasir Gudang', 'Pekan Nanas', 'Permas Jaya', 'Pontian Kechil',
+ 'Renggam',
+ 'Segamat', 'Senai', 'Simpang Renggam', 'Skudai', 'Sri Gading',
+ 'Tangkak', 'Tebrau',
+ 'Ulu Tiram',
+ 'Yong Peng',
+ ],
+ 'kedah' => [
+ 'Alor Setar',
+ 'Baling', 'Bukit Kayu Hitam',
+ 'Changlun',
+ 'Durian Burung',
+ 'Gurun',
+ 'Jitra',
+ 'Kepala Batas', 'Kuah', 'Kuala Kedah', 'Kuala Ketil', 'Kulim',
+ 'Langgar', 'Lunas',
+ 'Merbok',
+ 'Padang Serai', 'Pendang',
+ 'Serdang', 'Sintok', 'Sungai Petani',
+ 'Tawar, Baling',
+ 'Yan',
+ ],
+ 'kelantan' => [
+ 'Bachok', 'Bunut Payong',
+ 'Dabong',
+ 'Gua Musang',
+ 'Jeli',
+ 'Ketereh', 'Kota Bharu', 'Kuala Krai',
+ 'Lojing',
+ 'Machang',
+ 'Pasir Mas', 'Pasir Puteh',
+ 'Rantau Panjang',
+ 'Salor',
+ 'Tok Bali',
+ 'Wakaf Bharu', 'Wakaf Che Yeh',
+ ],
+ 'kl' => [
+ 'Ampang',
+ 'Bandar Tasik Selatan', 'Bandar Tun Razak', 'Bangsar', 'Batu', 'Brickfields', 'Bukit Bintang', 'Bukit Jalil', 'Bukit Tunku',
+ 'Cheras', 'Chow Kit',
+ 'Damansara Town Centre', 'Dang Wangi', 'Desa Petaling', 'Desa Tun Hussein Onn',
+ 'Jinjang',
+ 'Kampung Baru', 'Kampung Kasipillay', 'Kampung Pandan', 'Kampung Sungai Penchala', 'Kepong', 'KLCC', 'Kuchai Lama',
+ 'Lake Gardens', 'Lembah Pantai',
+ 'Medan Tuanku', 'Mid Valley City', 'Mont Kiara',
+ 'Pantai Dalam', 'Pudu',
+ 'Salak South', 'Segambut', 'Semarak', 'Sentul', 'Setapak', 'Setiawangsa', 'Seputeh', 'Sri Hartamas', 'Sri Petaling', 'Sungai Besi',
+ 'Taman Desa', 'Taman Melawati', 'Taman OUG', 'Taman Tun Dr Ismail', 'Taman U-Thant', 'Taman Wahyu', 'Titiwangsa', 'Tun Razak Exchange',
+ 'Wangsa Maju',
+ ],
+ 'labuan' => [
+ 'Batu Manikar',
+ 'Kiamsam',
+ 'Layang-Layang',
+ 'Rancha-Rancha'
+ ],
+ 'melaka' => [
+ 'Alor Gajah',
+ 'Bandaraya Melaka', 'Batu Berendam', 'Bukit Beruang', 'Bukit Katil',
+ 'Cheng',
+ 'Durian Tunggal',
+ 'Hang Tuah Jaya',
+ 'Jasin',
+ 'Klebang',
+ 'Lubuk China',
+ 'Masjid Tanah',
+ 'Naning',
+ 'Pekan Asahan',
+ 'Ramuan China',
+ 'Simpang Ampat',
+ 'Tanjung Bidara', 'Telok Mas',
+ 'Umbai',
+ ],
+ 'nsembilan' => [
+ 'Ayer Kuning', 'Ampangan',
+ 'Bahau', 'Batang Benar',
+ 'Chembong',
+ 'Dangi',
+ 'Gemas',
+ 'Juasseh',
+ 'Kuala Pilah',
+ 'Labu', 'Lenggeng', 'Linggi',
+ 'Mantin',
+ 'Nilai',
+ 'Pajam', 'Pedas', 'Pengkalan Kempas', 'Port Dickson',
+ 'Rantau', 'Rompin',
+ 'Senawang', 'Seremban', 'Sungai Gadut',
+ 'Tampin', 'Tiroi',
+ ],
+ 'pahang' => [
+ 'Bandar Tun Razak', 'Bentong', 'Brinchang', 'Bukit Fraser', 'Bukit Tinggi',
+ 'Chendor',
+ 'Gambang', 'Genting Highlands', 'Genting Sempah',
+ 'Jerantut',
+ 'Karak', 'Kemayan', 'Kota Shahbandar', 'Kuala Lipis', 'Kuala Pahang', 'Kuala Rompin', 'Kuantan',
+ 'Lanchang', 'Lubuk Paku',
+ 'Maran', 'Mengkuang', 'Mentakab',
+ 'Nenasi',
+ 'Panching',
+ 'Pekan', 'Penor',
+ 'Raub',
+ 'Sebertak', 'Sungai Lembing',
+ 'Tanah Rata', 'Tanjung Sepat', 'Tasik Chini', 'Temerloh', 'Teriang', 'Tringkap',
+ ],
+ 'penang' => [
+ 'Air Itam',
+ 'Balik Pulau', 'Batu Ferringhi', 'Batu Kawan', 'Bayan Lepas', 'Bukit Mertajam', 'Butterworth',
+ 'Gelugor', 'George Town',
+ 'Jelutong',
+ 'Kepala Batas',
+ 'Nibong Tebal',
+ 'Permatang Pauh', 'Pulau Tikus',
+ 'Simpang Ampat',
+ 'Tanjung Bungah', 'Tanjung Tokong',
+ ],
+ 'perak' => [
+ 'Ayer Tawar',
+ 'Bagan Serai', 'Batu Gajah', 'Behrang', 'Bidor', 'Bukit Gantang', 'Bukit Merah',
+ 'Changkat Jering', 'Chemor', 'Chenderiang',
+ 'Damar Laut',
+ 'Gerik', 'Gopeng', 'Gua Tempurung',
+ 'Hutan Melintang',
+ 'Ipoh',
+ 'Jelapang',
+ 'Kamunting', 'Kampar', 'Kuala Kangsar',
+ 'Lekir', 'Lenggong', 'Lumut',
+ 'Malim Nawar', 'Manong', 'Menglembu',
+ 'Pantai Remis', 'Parit', 'Parit Buntar', 'Pasir Salak', 'Proton City',
+ 'Simpang Pulai', 'Sitiawan', 'Slim River', 'Sungai Siput', 'Sungkai',
+ 'Taiping', 'Tambun', 'Tanjung Malim', 'Tanjung Rambutan', 'Tapah', 'Teluk Intan',
+ 'Ulu Bernam',
+ ],
+ 'perlis' => [
+ 'Arau',
+ 'Beseri',
+ 'Chuping',
+ 'Kaki Bukit', 'Kangar', 'Kuala Perlis',
+ 'Mata Ayer',
+ 'Padang Besar',
+ 'Sanglang', 'Simpang Empat',
+ 'Wang Kelian',
+ ],
+ 'putrajaya' => [
+ 'Precinct 1', 'Precinct 4', 'Precinct 5',
+ 'Precinct 6', 'Precinct 8', 'Precinct 10',
+ 'Precinct 11', 'Precinct 12', 'Precinct 13',
+ 'Precinct 16', 'Precinct 18', 'Precinct 19',
+ ],
+ 'sabah' => [
+ 'Beaufort', 'Bingkor',
+ 'Donggongon',
+ 'Inanam',
+ 'Kinabatangan', 'Kota Belud', 'Kota Kinabalu', 'Kuala Penyu', 'Kimanis', 'Kundasang',
+ 'Lahad Datu', 'Likas', 'Lok Kawi',
+ 'Manggatal',
+ 'Nabawan',
+ 'Papar', 'Pitas',
+ 'Ranau',
+ 'Sandakan', 'Sapulut', 'Semporna', 'Sepanggar',
+ 'Tambunan', 'Tanjung Aru', 'Tawau', 'Tenom', 'Tuaran',
+ 'Weston',
+ ],
+ 'sarawak' => [
+ 'Asajaya',
+ 'Ba\'kelalan', 'Bario', 'Batu Kawa', 'Batu Niah', 'Betong', 'Bintulu',
+ 'Dalat', 'Daro',
+ 'Engkilili',
+ 'Julau',
+ 'Kapit', 'Kota Samarahan', 'Kuching',
+ 'Lawas', 'Limbang', 'Lubok Antu',
+ 'Marudi', 'Matu', 'Miri',
+ 'Oya',
+ 'Pakan',
+ 'Sadong Jaya', 'Sematan', 'Sibu', 'Siburan', 'Song', 'Sri Aman', 'Sungai Tujoh',
+ 'Tanjung Kidurong', 'Tanjung Manis', 'Tatau',
+ ],
+ 'selangor' => [
+ 'Ampang', 'Assam Jawa',
+ 'Balakong', 'Bandar Baru Bangi', 'Bandar Baru Selayang', 'Bandar Sunway', 'Bangi', 'Banting', 'Batang Kali', 'Batu Caves', 'Bestari Jaya', 'Bukit Lanjan',
+ 'Cheras', 'Cyberjaya',
+ 'Damansara', 'Dengkil',
+ 'Ijok',
+ 'Jenjarom',
+ 'Kajang', 'Kelana Jaya', 'Klang', 'Kuala Kubu Bharu', 'Kuala Selangor', 'Kuang',
+ 'Lagong',
+ 'Morib',
+ 'Pandamaran', 'Paya Jaras', 'Petaling Jaya', 'Port Klang', 'Puchong',
+ 'Rasa', 'Rawang',
+ 'Salak Tinggi', 'Sekinchan', 'Selayang', 'Semenyih', 'Sepang', 'Serendah', 'Seri Kembangan', 'Shah Alam', 'Subang', 'Subang Jaya', 'Sungai Buloh',
+ 'Tanjung Karang', 'Tanjung Sepat',
+ 'Ulu Klang', 'Ulu Yam',
+ ],
+ 'terengganu' => [
+ 'Ajil',
+ 'Bandar Ketengah Jaya', 'Bandar Permaisuri', 'Bukit Besi', 'Bukit Payong',
+ 'Chukai',
+ 'Jerteh',
+ 'Kampung Raja', 'Kerteh', 'Kijal', 'Kuala Besut', 'Kuala Berang', 'Kuala Dungun', 'Kuala Terengganu',
+ 'Marang', 'Merchang',
+ 'Pasir Raja',
+ 'Rantau Abang',
+ 'Teluk Kalung',
+ 'Wakaf Tapai',
+ ]
+ ];
+
+ /**
+ * @link https://en.wikipedia.org/wiki/States_and_federal_territories_of_Malaysia
+ */
+ protected static $states = [
+ 'johor' => [
+ 'Johor Darul Ta\'zim',
+ 'Johor'
+ ],
+ 'kedah' => [
+ 'Kedah Darul Aman',
+ 'Kedah'
+ ],
+ 'kelantan' => [
+ 'Kelantan Darul Naim',
+ 'Kelantan'
+ ],
+ 'kl' => [
+ 'KL',
+ 'Kuala Lumpur',
+ 'WP Kuala Lumpur'
+ ],
+ 'labuan' => [
+ 'Labuan'
+ ],
+ 'melaka' => [
+ 'Malacca',
+ 'Melaka'
+ ],
+ 'nsembilan' => [
+ 'Negeri Sembilan Darul Khusus',
+ 'Negeri Sembilan'
+ ],
+ 'pahang' => [
+ 'Pahang Darul Makmur',
+ 'Pahang'
+ ],
+ 'penang' => [
+ 'Penang',
+ 'Pulau Pinang'
+ ],
+ 'perak' => [
+ 'Perak Darul Ridzuan',
+ 'Perak'
+ ],
+ 'perlis' => [
+ 'Perlis Indera Kayangan',
+ 'Perlis'
+ ],
+ 'putrajaya' => [
+ 'Putrajaya'
+ ],
+ 'sabah' => [
+ 'Sabah'
+ ],
+ 'sarawak' => [
+ 'Sarawak'
+ ],
+ 'selangor' => [
+ 'Selangor Darul Ehsan',
+ 'Selangor'
+ ],
+ 'terengganu' => [
+ 'Terengganu Darul Iman',
+ 'Terengganu'
+ ]
+ ];
+
+ /**
+ * @link https://ms.wikipedia.org/wiki/Senarai_negara_berdaulat
+ */
+ protected static $country = [
+ 'Abkhazia', 'Afghanistan', 'Afrika Selatan', 'Republik Afrika Tengah', 'Akrotiri dan Dhekelia', 'Albania', 'Algeria', 'Amerika Syarikat', 'Andorra', 'Angola', 'Antigua dan Barbuda', 'Arab Saudi', 'Argentina', 'Armenia', 'Australia', 'Austria', 'Azerbaijan',
+ 'Bahamas', 'Bahrain', 'Bangladesh', 'Barbados', 'Belanda', 'Belarus', 'Belgium', 'Belize', 'Benin', 'Bhutan', 'Bolivia', 'Bonaire', 'Bosnia dan Herzegovina', 'Botswana', 'Brazil', 'Brunei Darussalam', 'Bulgaria', 'Burkina Faso', 'Burundi',
+ 'Cameroon', 'Chad', 'Chile', 'Republik Rakyat China', 'Republik China di Taiwan', 'Colombia', 'Comoros', 'Republik Demokratik Congo', 'Republik Congo', 'Kepulauan Cook', 'Costa Rica', 'Côte d\'Ivoire (Ivory Coast)', 'Croatia', 'Cuba', 'Curaçao', 'Cyprus', 'Republik Turki Cyprus Utara', 'Republik Czech',
+ 'Denmark', 'Djibouti', 'Dominika', 'Republik Dominika',
+ 'Ecuador', 'El Salvador', 'Emiriah Arab Bersatu', 'Eritrea', 'Estonia',
+ 'Kepulauan Faroe', 'Fiji', 'Filipina', 'Finland',
+ 'Gabon', 'Gambia', 'Georgia', 'Ghana', 'Grenada', 'Greece (Yunani)', 'Guatemala', 'Guinea', 'Guinea-Bissau', 'Guinea Khatulistiwa', 'Guiana Perancis', 'Guyana',
+ 'Habsyah (Etiopia)', 'Haiti', 'Honduras', 'Hungary',
+ 'Iceland', 'India', 'Indonesia', 'Iran', 'Iraq', 'Ireland', 'Israel', 'Itali',
+ 'Jamaika', 'Jepun', 'Jerman', 'Jordan',
+ 'Kanada', 'Kazakhstan', 'Kemboja', 'Kenya', 'Kiribati', 'Korea Selatan', 'Korea Utara', 'Kosovo', 'Kuwait', 'Kyrgyzstan',
+ 'Laos', 'Latvia', 'Lesotho', 'Liberia', 'Libya', 'Liechtenstein', 'Lithuania', 'Lubnan', 'Luxembourg',
+ 'Macedonia', 'Madagaskar', 'Maghribi', 'Malawi', 'Malaysia', 'Maldives', 'Mali', 'Malta', 'Kepulauan Marshall', 'Mauritania', 'Mauritius', 'Mesir', 'Mexico', 'Persekutuan Micronesia', 'Moldova', 'Monaco', 'Montenegro', 'Mongolia', 'Mozambique', 'Myanmar',
+ 'Namibia', 'Nauru', 'Nepal', 'New Zealand', 'Nicaragua', 'Niger', 'Nigeria', 'Niue', 'Norway',
+ 'Oman', 'Ossetia Selatan',
+ 'Pakistan', 'Palau', 'Palestin', 'Panama', 'Papua New Guinea', 'Paraguay', 'Perancis', 'Peru', 'Poland', 'Portugal',
+ 'Qatar',
+ 'Romania', 'Russia', 'Rwanda',
+ 'Sahara Barat', 'Saint Kitts dan Nevis', 'Saint Lucia', 'Saint Vincent dan Grenadines', 'Samoa', 'San Marino', 'São Tomé dan Príncipe', 'Scotland', 'Senegal', 'Sepanyol', 'Serbia', 'Seychelles', 'Sierra Leone', 'Singapura', 'Slovakia', 'Slovenia', 'Kepulauan Solomon', 'Somalia', 'Somaliland', 'Sri Lanka', 'Sudan', 'Sudan Selatan', 'Suriname', 'Swaziland', 'Sweden', 'Switzerland', 'Syria',
+ 'Tajikistan', 'Tanjung Verde', 'Tanzania', 'Thailand', 'Timor Leste', 'Togo', 'Tonga', 'Transnistria', 'Trinidad dan Tobago', 'Tunisia', 'Turki', 'Turkmenistan', 'Tuvalu',
+ 'Uganda', 'Ukraine', 'United Kingdom', 'Uruguay', 'Uzbekistan',
+ 'Vanuatu', 'Kota Vatican', 'Venezuela', 'Vietnam',
+ 'Yaman',
+ 'Zambia', 'Zimbabwe',
+ ];
+
+ /**
+ * Return a building prefix
+ *
+ * @example 'No.'
+ *
+ * @return string
+ */
+ public static function buildingPrefix()
+ {
+ return static::randomElement(static::$buildingPrefix);
+ }
+
+ /**
+ * Return a building number
+ *
+ * @example '123'
+ *
+ * @return string
+ */
+ public static function buildingNumber()
+ {
+ return static::toUpper(static::lexify(static::numerify(static::randomElement(static::$buildingNumber))));
+ }
+
+ /**
+ * Return a street prefix
+ *
+ * @example 'Jalan'
+ */
+ public function streetPrefix()
+ {
+ $format = static::randomElement(static::$streetPrefix);
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * Return a complete streename
+ *
+ * @example 'Jalan Utama 7'
+ *
+ * @return string
+ */
+ public function streetName()
+ {
+ $format = static::toUpper(static::lexify(static::numerify(static::randomElement(static::$streetNameFormats))));
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * Return a randown township
+ *
+ * @example Taman Bahagia
+ *
+ * @return string
+ */
+ public function township()
+ {
+ $format = static::toUpper(static::lexify(static::numerify(static::randomElement(static::$townshipFormats))));
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * Return a township prefix abbreviation
+ *
+ * @example 'USJ'
+ *
+ * @return string
+ */
+ public function townshipPrefixAbbr()
+ {
+ return static::randomElement(static::$townshipPrefixAbbr);
+ }
+
+ /**
+ * Return a township prefix
+ *
+ * @example 'Taman'
+ *
+ * @return string
+ */
+ public function townshipPrefix()
+ {
+ return static::randomElement(static::$townshipPrefix);
+ }
+
+ /**
+ * Return a township suffix
+ *
+ * @example 'Bahagia'
+ */
+ public function townshipSuffix()
+ {
+ return static::randomElement(static::$townshipSuffix);
+ }
+
+ /**
+ * Return a postcode based on state
+ *
+ * @example '55100'
+ * @link https://en.wikipedia.org/wiki/Postal_codes_in_Malaysia#States
+ *
+ * @param null|string $state 'state' or null
+ *
+ * @return string
+ */
+ public static function postcode($state = null)
+ {
+ $format = [
+ 'perlis' => [ // (01000 - 02800)
+ '0' . self::numberBetween(1000, 2800)
+ ],
+ 'kedah' => [ // (05000 - 09810)
+ '0' . self::numberBetween(5000, 9810)
+ ],
+ 'penang' => [ // (10000 - 14400)
+ self::numberBetween(10000, 14400)
+ ],
+ 'kelantan' => [ // (15000 - 18500)
+ self::numberBetween(15000, 18500)
+ ],
+ 'terengganu' => [ // (20000 - 24300)
+ self::numberBetween(20000, 24300)
+ ],
+ 'pahang' => [ // (25000 - 28800 | 39000 - 39200 | 49000, 69000)
+ self::numberBetween(25000, 28800),
+ self::numberBetween(39000, 39200),
+ self::numberBetween(49000, 69000)
+ ],
+ 'perak' => [ // (30000 - 36810)
+ self::numberBetween(30000, 36810)
+ ],
+ 'selangor' => [ // (40000 - 48300 | 63000 - 68100)
+ self::numberBetween(40000, 48300),
+ self::numberBetween(63000, 68100)
+ ],
+ 'kl' => [ // (50000 - 60000)
+ self::numberBetween(50000, 60000),
+ ],
+ 'putrajaya' => [ // (62000 - 62988)
+ self::numberBetween(62000, 62988)
+ ],
+ 'nsembilan' => [ // (70000 - 73509)
+ self::numberBetween(70000, 73509)
+ ],
+ 'melaka' => [ // (75000 - 78309)
+ self::numberBetween(75000, 78309)
+ ],
+ 'johor' => [ // (79000 - 86900)
+ self::numberBetween(79000, 86900)
+ ],
+ 'labuan' => [ // (87000 - 87033)
+ self::numberBetween(87000, 87033)
+ ],
+ 'sabah' => [ // (88000 - 91309)
+ self::numberBetween(88000, 91309)
+ ],
+ 'sarawak' => [ // (93000 - 98859)
+ self::numberBetween(93000, 98859)
+ ]
+ ];
+
+ $postcode = is_null($state) ? static::randomElement($format) : $format[$state];
+ return (string) static::randomElement($postcode);
+ }
+
+ /**
+ * Return the complete town address with matching postcode and state
+ *
+ * @example 55100 Bukit Bintang, Kuala Lumpur
+ *
+ * @return string
+ */
+ public function townState()
+ {
+ $state = static::randomElement(array_keys(static::$states));
+ $postcode = static::postcode($state);
+ $town = static::randomElement(static::$towns[$state]);
+ $state = static::randomElement(static::$states[$state]);
+
+ return $postcode . ' ' . $town . ', ' . $state;
+ }
+
+ /**
+ * Return a random city (town)
+ *
+ * @example 'Ampang'
+ *
+ * @return string
+ */
+ public function city()
+ {
+ $state = static::randomElement(array_keys(static::$towns));
+ return static::randomElement(static::$towns[$state]);
+ }
+
+ /**
+ * Return a random state
+ *
+ * @example 'Johor'
+ *
+ * @return string
+ */
+ public function state()
+ {
+ $state = static::randomElement(array_keys(static::$states));
+ return static::randomElement(static::$states[$state]);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ms_MY/Company.php b/vendor/fakerphp/faker/src/Faker/Provider/ms_MY/Company.php
new file mode 100644
index 00000000..4e9175fa
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ms_MY/Company.php
@@ -0,0 +1,105 @@
+generator->parse($formats);
+ }
+
+ /**
+ * Return Peninsular prefix alphabet
+ *
+ * @example 'W'
+ *
+ * @return string
+ */
+ public static function peninsularPrefix()
+ {
+ return static::randomElement(static::$peninsularPrefix);
+ }
+
+ /**
+ * Return Sarawak state prefix alphabet
+ *
+ * @example 'QA'
+ *
+ * @return string
+ */
+ public static function sarawakPrefix()
+ {
+ return static::randomElement(static::$sarawakPrefix);
+ }
+
+ /**
+ * Return Sabah state prefix alphabet
+ *
+ * @example 'SA'
+ *
+ * @return string
+ */
+ public static function sabahPrefix()
+ {
+ return static::randomElement(static::$sabahPrefix);
+ }
+
+ /**
+ * Return specialty licence plate prefix
+ *
+ * @example 'G1M'
+ *
+ * @return string
+ */
+ public static function specialPrefix()
+ {
+ return static::randomElement(static::$specialPrefix);
+ }
+
+ /**
+ * Return a valid license plate alphabet
+ *
+ * @example 'A'
+ *
+ * @return string
+ */
+ public static function validAlphabet()
+ {
+ return static::randomElement(static::$validAlphabets);
+ }
+
+ /**
+ * Return a valid number sequence between 1 and 9999
+ *
+ * @example '1234'
+ *
+ * @return int
+ */
+ public static function numberSequence()
+ {
+ return self::numberBetween(1, 9999);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ms_MY/Payment.php b/vendor/fakerphp/faker/src/Faker/Provider/ms_MY/Payment.php
new file mode 100644
index 00000000..5e6c2302
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ms_MY/Payment.php
@@ -0,0 +1,244 @@
+generator->parse($formats);
+ }
+
+ /**
+ * Return a Malaysian Bank account number
+ *
+ * @example '1234567890123456'
+ *
+ * @return string
+ */
+ public function bankAccountNumber()
+ {
+ $formats = static::randomElement(static::$bankAccountNumberFormats);
+
+ return static::numerify($formats);
+ }
+
+ /**
+ * Return a Malaysian Local Bank
+ *
+ * @example 'Public Bank'
+ *
+ * @return string
+ */
+ public static function localBank()
+ {
+ return static::randomElement(static::$localBanks);
+ }
+
+ /**
+ * Return a Malaysian Foreign Bank
+ *
+ * @example 'Citibank Berhad'
+ *
+ * @return string
+ */
+ public static function foreignBank()
+ {
+ return static::randomElement(static::$foreignBanks);
+ }
+
+ /**
+ * Return a Malaysian Government Bank
+ *
+ * @example 'Bank Simpanan Nasional'
+ *
+ * @return string
+ */
+ public static function governmentBank()
+ {
+ return static::randomElement(static::$governmentBanks);
+ }
+
+ /**
+ * Return a Malaysian insurance company
+ *
+ * @example 'AIA Malaysia'
+ *
+ * @return string
+ */
+ public static function insurance()
+ {
+ return static::randomElement(static::$insuranceCompanies);
+ }
+
+ /**
+ * Return a Malaysian Bank SWIFT Code
+ *
+ * @example 'MBBEMYKLXXX'
+ *
+ * @return string
+ */
+ public static function swiftCode()
+ {
+ return static::toUpper(static::lexify(static::randomElement(static::$swiftCodes)));
+ }
+
+ /**
+ * Return the Malaysian currency symbol
+ *
+ * @example 'RM'
+ *
+ * @return string
+ */
+ public static function currencySymbol()
+ {
+ return static::randomElement(static::$currencySymbol);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ms_MY/Person.php b/vendor/fakerphp/faker/src/Faker/Provider/ms_MY/Person.php
new file mode 100644
index 00000000..74001e97
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ms_MY/Person.php
@@ -0,0 +1,811 @@
+generator->parse(static::randomElement($formats));
+ }
+
+ /**
+ * Return a Malaysian I.C. No.
+ *
+ * @example '890123-45-6789'
+ *
+ * @link https://en.wikipedia.org/wiki/Malaysian_identity_card#Structure_of_the_National_Registration_Identity_Card_Number_(NRIC)
+ *
+ * @param string|null $gender 'male', 'female' or null for any
+ * @param bool|string|null $hyphen true, false, or any separator characters
+ *
+ * @return string
+ */
+ public static function myKadNumber($gender = null, $hyphen = false)
+ {
+ // year of birth
+ $yy = self::numberBetween(0, 99);
+
+ // month of birth
+ $mm = DateTime::month();
+
+ // day of birth
+ $dd = DateTime::dayOfMonth();
+
+ // place of birth (1-59 except 17-20)
+ while (in_array($pb = self::numberBetween(1, 59), [17, 18, 19, 20])) {
+ }
+
+ // random number
+ $nnn = self::numberBetween(0, 999);
+
+ // gender digit. Odd = MALE, Even = FEMALE
+ $g = self::numberBetween(0, 9);
+ //Credit: https://gist.github.com/mauris/3629548
+ if ($gender === static::GENDER_MALE) {
+ $g = $g | 1;
+ } elseif ($gender === static::GENDER_FEMALE) {
+ $g = $g & ~1;
+ }
+
+ // formatting with hyphen
+ if ($hyphen === true) {
+ $hyphen = '-';
+ } elseif ($hyphen === false) {
+ $hyphen = '';
+ }
+
+ return sprintf('%02d%02d%02d%s%02d%s%03d%01d', $yy, $mm, $dd, $hyphen, $pb, $hyphen, $nnn, $g);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ms_MY/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/ms_MY/PhoneNumber.php
new file mode 100644
index 00000000..6cc16652
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ms_MY/PhoneNumber.php
@@ -0,0 +1,217 @@
+generator->parse($format));
+ } else {
+ return static::numerify($this->generator->parse($format));
+ }
+ }
+
+ /**
+ * Return prefix digits for 011 numbers
+ *
+ * @example '10'
+ *
+ * @return string
+ */
+ public static function zeroOneOnePrefix()
+ {
+ return static::numerify(static::randomElement(static::$zeroOneOnePrefix));
+ }
+
+ /**
+ * Return prefix digits for 014 numbers
+ *
+ * @example '2'
+ *
+ * @return string
+ */
+ public static function zeroOneFourPrefix()
+ {
+ return static::numerify(static::randomElement(static::$zeroOneFourPrefix));
+ }
+
+ /**
+ * Return prefix digits for 015 numbers
+ *
+ * @example '1'
+ *
+ * @return string
+ */
+ public static function zeroOneFivePrefix()
+ {
+ return static::numerify(static::randomElement(static::$zeroOneFivePrefix));
+ }
+
+ /**
+ * Return a Malaysian Fixed Line Phone Number.
+ *
+ * @example '+603-4567-8912'
+ *
+ * @param bool $countryCodePrefix true, false
+ * @param bool $formatting true, false
+ *
+ * @return string
+ */
+ public function fixedLineNumber($countryCodePrefix = true, $formatting = true)
+ {
+ if ($formatting) {
+ $format = static::randomElement(static::$fixedLineNumberFormatsWithFormatting);
+ } else {
+ $format = static::randomElement(static::$fixedLineNumberFormats);
+ }
+
+ if ($countryCodePrefix) {
+ return static::countryCodePrefix($formatting) . static::numerify($this->generator->parse($format));
+ } else {
+ return static::numerify($this->generator->parse($format));
+ }
+ }
+
+ /**
+ * Return a Malaysian VoIP Phone Number.
+ *
+ * @example '+6015-678-9234'
+ *
+ * @param bool $countryCodePrefix true, false
+ * @param bool $formatting true, false
+ *
+ * @return string
+ */
+ public function voipNumber($countryCodePrefix = true, $formatting = true)
+ {
+ if ($formatting) {
+ $format = static::randomElement(static::$voipNumberWithFormatting);
+ } else {
+ $format = static::randomElement(static::$voipNumber);
+ }
+
+ if ($countryCodePrefix) {
+ return static::countryCodePrefix($formatting) . static::numerify($this->generator->parse($format));
+ } else {
+ return static::numerify($this->generator->parse($format));
+ }
+ }
+
+ /**
+ * Return a Malaysian Country Code Prefix.
+ *
+ * @example '+6'
+ *
+ * @param bool $formatting true, false
+ *
+ * @return string
+ */
+ public static function countryCodePrefix($formatting = true)
+ {
+ if ($formatting) {
+ return static::randomElement(static::$plusSymbol) . static::randomElement(static::$countryCodePrefix);
+ } else {
+ return static::randomElement(static::$countryCodePrefix);
+ }
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/nb_NO/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/nb_NO/Address.php
new file mode 100644
index 00000000..e32099b2
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/nb_NO/Address.php
@@ -0,0 +1,195 @@
+format('dmy');
+
+ /**
+ * @todo These number should be random based on birth year
+ * @link http://no.wikipedia.org/wiki/F%C3%B8dselsnummer
+ */
+ $randomDigits = (string) static::numerify('##');
+
+ switch ($gender) {
+ case static::GENDER_MALE:
+ $genderDigit = static::randomElement([1, 3, 5, 7, 9]);
+ break;
+ case static::GENDER_FEMALE:
+ $genderDigit = static::randomElement([0, 2, 4, 6, 8]);
+ break;
+ default:
+ $genderDigit = (string) static::numerify('#');
+ }
+
+
+ $digits = $datePart . $randomDigits . $genderDigit;
+
+ /**
+ * @todo Calculate modulo 11 of $digits
+ * @link http://no.wikipedia.org/wiki/F%C3%B8dselsnummer
+ */
+ $checksum = (string) static::numerify('##');
+
+
+ return $digits . $checksum;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/nb_NO/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/nb_NO/PhoneNumber.php
new file mode 100644
index 00000000..4767db48
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/nb_NO/PhoneNumber.php
@@ -0,0 +1,41 @@
+generator->parse($format));
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ne_NP/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/ne_NP/Address.php
new file mode 100644
index 00000000..1b284b91
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ne_NP/Address.php
@@ -0,0 +1,129 @@
+format('ymd'));
+ $help = $date->format('Y') >= 2000 ? 2 : null;
+
+ $check = (int) ($help . $dob . $middle);
+ $rest = sprintf('%02d', 97 - ($check % 97));
+
+ return $dob . $middle . $rest;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/nl_BE/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/nl_BE/PhoneNumber.php
new file mode 100644
index 00000000..9e4a3917
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/nl_BE/PhoneNumber.php
@@ -0,0 +1,20 @@
+generator->lastName;
+ break;
+ }
+
+ if (Miscellaneous::boolean()) {
+ return $companyName . ' ' . static::randomElement(static::$companySuffix);
+ }
+
+ return $companyName;
+ }
+
+ /**
+ * Belasting Toegevoegde Waarde (BTW) = VAT
+ *
+ * @example 'NL123456789B01'
+ *
+ * @see https://www.belastingdienst.nl/wps/wcm/connect/bldcontentnl/belastingdienst/zakelijk/btw/administratie_bijhouden/btw_nummers_controleren/uw_btw_nummer
+ *
+ * @return string VAT Number
+ */
+ public static function vat()
+ {
+ return sprintf('%s%d%s%d', 'NL', self::randomNumber(9, true), 'B', self::randomNumber(2, true));
+ }
+
+ /**
+ * Alias dutch vat number format
+ *
+ * @return string
+ */
+ public static function btw()
+ {
+ return self::vat();
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/nl_NL/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/nl_NL/Internet.php
new file mode 100644
index 00000000..bf30e795
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/nl_NL/Internet.php
@@ -0,0 +1,9 @@
+ 9) {
+ if ($nr[1] > 0) {
+ $nr[0] = 8;
+ $nr[1]--;
+ } else {
+ $nr[0] = 1;
+ $nr[1]++;
+ }
+ }
+ return implode('', array_reverse($nr));
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/nl_NL/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/nl_NL/PhoneNumber.php
new file mode 100644
index 00000000..5d4163a0
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/nl_NL/PhoneNumber.php
@@ -0,0 +1,39 @@
+ 'D',
+ 'kujawsko-pomorskie' => 'C',
+ 'lubelskie' => 'L',
+ 'lubuskie' => 'F',
+ 'łódzkie' => 'E',
+ 'małopolskie' => 'K',
+ 'mazowieckie' => 'W',
+ 'opolskie' => 'O',
+ 'podkarpackie' => 'R',
+ 'podlaskie' => 'B',
+ 'pomorskie' => 'G',
+ 'śląskie' => 'S',
+ 'świętokrzyskie' => 'T',
+ 'warmińsko-mazurskie' => 'N',
+ 'wielkopolskie' => 'P',
+ 'zachodniopomorskie' => 'Z',
+ ];
+
+ /**
+ * @var array list of special vehicle registration number prefixes.
+ */
+ protected static $specials = [
+ 'army' => 'U',
+ 'services' => 'H',
+ ];
+
+ /**
+ * @var array list of Polish counties and respective vehicle registration number prefixes.
+ */
+ protected static $counties = [
+ 'D' => [
+ 'Jelenia Góra' => ['J'],
+ 'Legnica' => ['L'],
+ 'Wałbrzych' => ['B'],
+ 'Wrocław' => ['W', 'X'],
+ 'bolesławiecki' => ['BL'],
+ 'dzierżoniowski' => ['DZ'],
+ 'głogowski' => ['GL'],
+ 'górowski' => ['GR'],
+ 'jaworski' => ['JA'],
+ 'jeleniogórski' => ['JE'],
+ 'kamiennogórski' => ['KA'],
+ 'kłodzki' => ['KL'],
+ 'legnicki' => ['LE'],
+ 'lubański' => ['LB'],
+ 'lubiński' => ['LU'],
+ 'lwówecki' => ['LW'],
+ 'milicki' => ['MI'],
+ 'oleśnicki' => ['OL'],
+ 'oławski' => ['OA'],
+ 'polkowicki' => ['PL'],
+ 'strzeliński' => ['ST'],
+ 'średzki' => ['SR'],
+ 'świdnicki' => ['SW'],
+ 'trzebnicki' => ['TR'],
+ 'wałbrzyski' => ['BA'],
+ 'wołowski' => ['WL'],
+ 'wrocławski' => ['WR'],
+ 'ząbkowicki' => ['ZA'],
+ 'zgorzelecki' => ['ZG'],
+ 'złotoryjski' => ['ZL'],
+ ],
+ 'C' => [
+ 'Bydgoszcz' => ['B'],
+ 'Grudziądz' => ['G'],
+ 'Toruń' => ['T'],
+ 'Włocławek' => ['W'],
+ 'aleksandrowski' => ['AL'],
+ 'brodnicki' => ['BR'],
+ 'bydgoski' => ['BY'],
+ 'chełmiński' => ['CH'],
+ 'golubsko-dobrzyński' => ['GD'],
+ 'grudziądzki' => ['GR'],
+ 'inowrocławski' => ['IN'],
+ 'lipnowski' => ['LI'],
+ 'mogileński' => ['MG'],
+ 'nakielski' => ['NA'],
+ 'radziejowski' => ['RA'],
+ 'rypiński' => ['RY'],
+ 'sępoleński' => ['SE'],
+ 'świecki' => ['SW'],
+ 'toruński' => ['TR'],
+ 'tucholski' => ['TU'],
+ 'wąbrzeski' => ['WA'],
+ 'włocławski' => ['WL'],
+ 'żniński' => ['ZN'],
+ ],
+ 'L' => [
+ 'Biała Podlaska' => ['B'],
+ 'Chełm' => ['C'],
+ 'Lublin' => ['U'],
+ 'Zamość' => ['Z'],
+ 'bialski' => ['BI'],
+ 'biłgorajski' => ['BL'],
+ 'chełmski' => ['CH'],
+ 'hrubieszowski' => ['HR'],
+ 'janowski' => ['JA'],
+ 'krasnostawski' => ['KS'],
+ 'kraśnicki' => ['KR'],
+ 'lubartowski' => ['LB'],
+ 'lubelski' => ['UB'],
+ 'łęczyński' => ['LE'],
+ 'łukowski' => ['LU'],
+ 'opolski' => ['OP'],
+ 'parczewski' => ['PA'],
+ 'puławski' => ['PU'],
+ 'radzyński' => ['RA'],
+ 'rycki' => ['RY'],
+ 'świdnicki' => ['SW'],
+ 'tomaszowski' => ['TM'],
+ 'włodawski' => ['WL'],
+ 'zamojski' => ['ZA'],
+ ],
+ 'F' => [
+ 'Gorzów Wielkopolski' => ['G'],
+ 'Zielona Góra' => ['Z'],
+ 'gorzowski' => ['GW'],
+ 'krośnieński' => ['KR'],
+ 'międzyrzecki' => ['MI'],
+ 'nowosolski' => ['NW'],
+ 'słubicki' => ['SL'],
+ 'strzelecko-drezdenecki' => ['SD'],
+ 'sulęciński' => ['SU'],
+ 'świebodziński' => ['SW'],
+ 'wschowski' => ['WS'],
+ 'zielonogórski' => ['ZI'],
+ 'żagański' => ['ZG'],
+ 'żarski' => ['ZA'],
+ ],
+ 'E' => [
+ 'Łódź' => ['L'],
+ 'Piotrków Trybunalski' => ['P'],
+ 'Skierniewice' => ['S'],
+ 'brzeziński' => ['BR'],
+ 'bełchatowski' => ['BE'],
+ 'kutnowski' => ['KU'],
+ 'łaski' => ['LA'],
+ 'łęczycki' => ['LE'],
+ 'łowicki' => ['LC'],
+ 'łódzki wschodni' => ['LW'],
+ 'opoczyński' => ['OP'],
+ 'pabianicki' => ['PA'],
+ 'pajęczański' => ['PJ'],
+ 'piotrkowski' => ['PI'],
+ 'poddębicki' => ['PD'],
+ 'radomszczański' => ['RA'],
+ 'rawski' => ['RW'],
+ 'sieradzki' => ['SI'],
+ 'skierniewicki' => ['SK'],
+ 'tomaszowski' => ['TM'],
+ 'wieluński' => ['WI'],
+ 'wieruszowski' => ['WE'],
+ 'zduńskowolski' => ['ZD'],
+ 'zgierski' => ['ZG'],
+ ],
+ 'K' => [
+ 'Kraków' => ['R'],
+ 'Nowy Sącz' => ['N'],
+ 'Tarnów' => ['T'],
+ 'bocheński' => ['BA', 'BC'],
+ 'brzeski' => ['BR'],
+ 'chrzanowski' => ['CH'],
+ 'dąbrowski' => ['DA'],
+ 'gorlicki' => ['GR'],
+ 'krakowski' => ['RA'],
+ 'limanowski' => ['LI'],
+ 'miechowski' => ['MI'],
+ 'myślenicki' => ['MY'],
+ 'nowosądecki' => ['NS'],
+ 'nowotarski' => ['NT'],
+ 'olkuski' => ['OL'],
+ 'oświęcimski' => ['OS'],
+ 'proszowicki' => ['PR'],
+ 'suski' => ['SU'],
+ 'tarnowski' => ['TA'],
+ 'tatrzański' => ['TT'],
+ 'wadowicki' => ['WA'],
+ 'wielicki' => ['WI'],
+ ],
+ 'W' => [
+ 'Ostrołęka' => ['O'],
+ 'Płock' => ['P'],
+ 'Radom' => ['R'],
+ 'Siedlce' => ['S'],
+ 'białobrzeski' => ['BR'],
+ 'ciechanowski' => ['CI'],
+ 'garwoliński' => ['G'],
+ 'gostyniński' => ['GS'],
+ 'grodziski' => ['GM'],
+ 'grójecki' => ['GR'],
+ 'kozienicki' => ['KZ'],
+ 'legionowski' => ['L'],
+ 'lipski' => ['LI'],
+ 'łosicki' => ['LS'],
+ 'makowski' => ['MA'],
+ 'miński' => ['M'],
+ 'mławski' => ['ML'],
+ 'nowodworski' => ['ND'],
+ 'ostrołęcki' => ['OS'],
+ 'ostrowski' => ['OR'],
+ 'otwocki' => ['OT'],
+ 'piaseczyński' => ['PA', 'PI'],
+ 'płocki' => ['PL'],
+ 'płoński' => ['PN'],
+ 'pruszkowski' => ['PP', 'PR', 'PS'],
+ 'przasnyski' => ['PZ'],
+ 'przysuski' => ['PY'],
+ 'pułtuski' => ['PU'],
+ 'radomski' => ['RA'],
+ 'siedlecki' => ['SI'],
+ 'sierpecki' => ['SE'],
+ 'sochaczewski' => ['SC'],
+ 'sokołowski' => ['SK'],
+ 'szydłowiecki' => ['SZ'],
+ 'warszawski' => ['A', 'B', 'D', 'E', 'F', 'H', 'I', 'J', 'K', 'N', 'T', 'U', 'W', 'X', 'Y'],
+ 'warszawski zachodni' => ['Z'],
+ 'węgrowski' => ['WE'],
+ 'wołomiński' => ['WL', 'V'],
+ 'wyszkowski' => ['WY'],
+ 'zwoleński' => ['ZW'],
+ 'żuromiński' => ['ZU'],
+ 'żyrardowski' => ['ZY'],
+ ],
+ 'O' => [
+ 'Opole' => ['P'],
+ 'brzeski' => ['B'],
+ 'głubczycki' => ['GL'],
+ 'kędzierzyńsko-kozielski' => ['K'],
+ 'kluczborski' => ['KL'],
+ 'krapkowicki' => ['KR'],
+ 'namysłowski' => ['NA'],
+ 'nyski' => ['NY'],
+ 'oleski' => ['OL'],
+ 'opolski' => ['PO'],
+ 'prudnicki' => ['PR'],
+ 'strzelecki' => ['ST'],
+ ],
+ 'R' => [
+ 'Krosno' => ['K'],
+ 'Przemyśl' => ['P'],
+ 'Rzeszów' => ['Z'],
+ 'Tarnobrzeg' => ['T'],
+ 'bieszczadzki' => ['BI'],
+ 'brzozowski' => ['BR'],
+ 'dębicki' => ['DE'],
+ 'jarosławski' => ['JA'],
+ 'jasielski' => ['JS'],
+ 'kolbuszowski' => ['KL'],
+ 'krośnieński' => ['KR'],
+ 'leski' => ['LS'],
+ 'leżajski' => ['LE'],
+ 'lubaczowski' => ['LU'],
+ 'łańcucki' => ['LA'],
+ 'mielecki' => ['MI'],
+ 'niżański' => ['NI'],
+ 'przemyski' => ['PR'],
+ 'przeworski' => ['PZ'],
+ 'ropczycko-sędziszowski' => ['RS'],
+ 'rzeszowski' => ['ZE'],
+ 'sanocki' => ['SA'],
+ 'stalowowolski' => ['ST'],
+ 'strzyżowski' => ['SR'],
+ 'tarnobrzeski' => ['TA'],
+ ],
+ 'B' => [
+ 'Białystok' => ['I'],
+ 'Łomża' => ['L'],
+ 'Suwałki' => ['S'],
+ 'augustowski' => ['AU'],
+ 'białostocki' => ['IA'],
+ 'bielski' => ['BI'],
+ 'grajewski' => ['GR'],
+ 'hajnowski' => ['HA'],
+ 'kolneński' => ['KL'],
+ 'łomżyński' => ['LM'],
+ 'moniecki' => ['MN'],
+ 'sejneński' => ['SE'],
+ 'siemiatycki' => ['SI'],
+ 'sokólski' => ['SK'],
+ 'suwalski' => ['SU'],
+ 'wysokomazowiecki' => ['WM'],
+ 'zambrowski' => ['ZA'],
+ ],
+ 'G' => [
+ 'Gdańsk' => ['D'],
+ 'Gdynia' => ['A'],
+ 'Słupsk' => ['S'],
+ 'Sopot' => ['SP'],
+ 'bytowski' => ['BY'],
+ 'chojnicki' => ['CH'],
+ 'człuchowski' => ['CZ'],
+ 'gdański' => ['DA'],
+ 'kartuski' => ['KY', 'KA'],
+ 'kościerski' => ['KS'],
+ 'kwidzyński' => ['KW'],
+ 'lęborski' => ['LE'],
+ 'malborski' => ['MB'],
+ 'nowodworski' => ['ND'],
+ 'pucki' => ['PU'],
+ 'słupski' => ['SL'],
+ 'starogardzki' => ['ST'],
+ 'sztumski' => ['SZ'],
+ 'tczewski' => ['TC'],
+ 'wejherowski' => ['WE', 'WO'],
+ ],
+ 'S' => [
+ 'Bielsko-Biała' => ['B'],
+ 'Bytom' => ['Y'],
+ 'Chorzów' => ['H'],
+ 'Częstochowa' => ['C'],
+ 'Dąbrowa Górnicza' => ['D'],
+ 'Gliwice' => ['G'],
+ 'Jastrzębie-Zdrój' => ['JZ'],
+ 'Jaworzno' => ['J'],
+ 'Katowice' => ['K'],
+ 'Mysłowice' => ['M'],
+ 'Piekary Śląskie' => ['PI'],
+ 'Ruda Śląska,' => ['L', 'RS'],
+ 'Rybnik' => ['R'],
+ 'Siemianowice Śląskie' => ['I'],
+ 'Sosnowiec' => ['O'],
+ 'Świętochłowice' => ['W'],
+ 'Tychy' => ['T'],
+ 'Zabrze' => ['Z'],
+ 'Żory' => ['ZO'],
+ 'będziński' => ['BE'],
+ 'bielski' => ['BI'],
+ 'cieszyński' => ['CN', 'CI'],
+ 'częstochowski' => ['CZ'],
+ 'gliwicki' => ['GL'],
+ 'kłobucki' => ['KL'],
+ 'lubliniecki' => ['LU'],
+ 'mikołowski' => ['MI'],
+ 'myszkowski' => ['MY'],
+ 'pszczyński' => ['PS'],
+ 'raciborski' => ['RC'],
+ 'rybnicki' => ['RB'],
+ 'tarnogórski' => ['TA'],
+ 'bieruńsko - lędziński' => ['BL'],
+ 'wodzisławski' => ['WD', 'WZ'],
+ 'zawierciański' => ['ZA'],
+ 'żywiecki' => ['ZY'],
+ ],
+ 'T' => [
+ 'Kielce' => ['K'],
+ 'buski' => ['BU'],
+ 'jędrzejowski' => ['JE'],
+ 'kazimierski' => ['KA'],
+ 'kielecki' => ['KI'],
+ 'konecki' => ['KN'],
+ 'opatowski' => ['OP'],
+ 'ostrowiecki' => ['OS'],
+ 'pińczowski' => ['PI'],
+ 'sandomierski' => ['SA'],
+ 'skarżyski' => ['SK'],
+ 'starachowicki' => ['ST'],
+ 'staszowski' => ['SZ'],
+ 'włoszczowski' => ['LW'],
+ ],
+ 'N' => [
+ 'Elbląg' => ['E'],
+ 'Olsztyn' => ['O'],
+ 'bartoszycki' => ['BA'],
+ 'braniewski' => ['BR'],
+ 'działdowski' => ['DZ'],
+ 'elbląski' => ['EB'],
+ 'ełcki' => ['EL'],
+ 'giżycki' => ['GI'],
+ 'iławski' => ['IL'],
+ 'kętrzyński' => ['KE'],
+ 'lidzbarski' => ['LI'],
+ 'mrągowski' => ['MR'],
+ 'nidzicki' => ['NI'],
+ 'nowomiejski' => ['NM'],
+ 'olecki' => ['OE'],
+ 'gołdapski' => ['GO'],
+ 'olsztyński' => ['OL'],
+ 'ostródzki' => ['OS'],
+ 'piski' => ['PI'],
+ 'szczycieński' => ['SZ'],
+ 'węgorzewski' => ['WE'],
+ ],
+ 'P' => [
+ 'Kalisz' => ['A', 'K'],
+ 'Konin' => ['KO', 'N'],
+ 'Leszno' => ['L'],
+ 'Poznań' => ['O', 'Y'],
+ 'chodzieski' => ['CH'],
+ 'czarnkowsko-trzcianecki' => ['CT'],
+ 'gnieźnieński' => ['GN'],
+ 'gostyński' => ['GS'],
+ 'grodziski' => ['GO'],
+ 'jarociński' => ['JA'],
+ 'kaliski' => ['KA'],
+ 'kępiński' => ['KE'],
+ 'kolski' => ['KL'],
+ 'koniński' => ['KN'],
+ 'kościański' => ['KS'],
+ 'krotoszyński' => ['KR'],
+ 'leszczyński' => ['LE'],
+ 'międzychodzki' => ['MI'],
+ 'nowotomyski' => ['NT'],
+ 'obornicki' => ['OB'],
+ 'ostrowski' => ['OS'],
+ 'ostrzeszowski' => ['OT'],
+ 'pilski' => ['P'],
+ 'pleszewski' => ['PL'],
+ 'poznański' => ['OZ', 'Z'],
+ 'rawicki' => ['RA'],
+ 'słupecki' => ['SL'],
+ 'szamotulski' => ['SZ'],
+ 'średzki' => ['SR'],
+ 'śremski' => ['SE'],
+ 'turecki' => ['TU'],
+ 'wągrowiecki' => ['WA'],
+ 'wolsztyński' => ['WL'],
+ 'wrzesiński' => ['WR'],
+ 'złotowski' => ['ZL'],
+ ],
+ 'Z' => [
+ 'Koszalin' => ['K'],
+ 'Szczecin' => ['S', 'Z'],
+ 'Świnoujście' => ['SW'],
+ 'białogardzki' => ['BI'],
+ 'choszczeński' => ['CH'],
+ 'drawski' => ['DR'],
+ 'goleniowski' => ['GL'],
+ 'gryficki' => ['GY'],
+ 'gryfiński' => ['GR'],
+ 'kamieński' => ['KA'],
+ 'kołobrzeski' => ['KL'],
+ 'koszaliński' => ['KO'],
+ 'łobeski' => ['LO'],
+ 'myśliborski' => ['MY'],
+ 'policki' => ['PL'],
+ 'pyrzycki' => ['PY'],
+ 'sławieński' => ['SL'],
+ 'stargardzki' => ['ST'],
+ 'szczecinecki' => ['SZ'],
+ 'świdwiński' => ['SD'],
+ 'wałecki' => ['WA'],
+ ],
+ 'U' => [
+ 'Siły Zbrojne Rzeczypospolitej Polskiej' => ['A', 'B', 'C', 'D', 'E', 'G', 'I', 'J', 'K', 'L'],
+ ],
+ 'H' => [
+ 'Centralne Biuro Antykorupcyjne' => ['A'],
+ 'Służba Ochrony Państwa' => ['BA', 'BB', 'BE', 'BF', 'BG'],
+ 'Służba Celno-Skarbowa' => ['CA', 'CB', 'CC', 'CD', 'CE', 'CF', 'CG', 'CH', 'CJ', 'CK', 'CL', 'CM', 'CN', 'CO', 'CP', 'CR'],
+ 'Agencja Bezpieczeństwa Wewnętrznego' => ['K'],
+ 'Agencja Wywiadu' => ['K'],
+ 'Służba Kontrwywiadu Wojskowego' => ['M'],
+ 'Służba Wywiadu Wojskowego' => ['M'],
+ 'Policja' => ['PA', 'PB', 'PC', 'PD', 'PE', 'PF', 'PG', 'PH', 'PJ', 'PK', 'PL', 'PL', 'PL', 'PL', 'PL', 'PM', 'PN', 'PP', 'PS', 'PT', 'PU', 'PW', 'PZ'],
+ 'Straż Graniczna' => ['WA', 'WK'],
+ ],
+ ];
+
+ /**
+ * @var array list of regex expressions matching Polish license plate suffixess when county code is 1 character long.
+ */
+ protected static $plateSuffixesGroup1 = [
+ '\d{5}',
+ '\d{4}[A-PR-Z]',
+ '\d{3}[A-PR-Z]{2}',
+ '[1-9][A-PR-Z]\d{3}',
+ '[1-9][A-PR-Z]{2}\d{2}',
+ ];
+
+ /**
+ * @var array list of regex expressions matching Polish license plate suffixess when county code is 2 characters long.
+ */
+ protected static $plateSuffixesGroup2 = [
+ '[A-PR-Z]\d{3}',
+ '\d{2}[A-PR-Z]{2}',
+ '[1-9][A-PR-Z]\d{2}',
+ '\d{2}[A-PR-Z][1-9]',
+ '[1-9][A-PR-Z]{2}[1-9]',
+ '[A-PR-Z]{2}\d{2}',
+ '\d{5}',
+ '\d{4}[A-PR-Z]',
+ '\d{3}[A-PR-Z]{2}',
+ '[A-PR-Z]\d{2}[A-PR-Z]',
+ '[A-PR-Z][1-9][A-PR-Z]{2}',
+ ];
+
+ /**
+ * Generates random license plate.
+ *
+ * @param bool $special whether special license plates should be included
+ * @param array|null $voivodeships list of voivodeships license plate should be generated from
+ * @param array|null $counties list of counties license plate should be generated from
+ *
+ * @return string
+ */
+ public static function licensePlate(
+ bool $special = false,
+ ?array $voivodeships = null,
+ ?array $counties = null
+ ): string {
+ $voivodeshipsAvailable = static::$voivodeships + ($special ? static::$specials : []);
+ $voivodeshipCode = static::selectRandomArea($voivodeshipsAvailable, $voivodeships);
+
+ $countiesAvailable = static::$counties[$voivodeshipCode];
+ $countySelected = self::selectRandomArea($countiesAvailable, $counties);
+
+ $countyCode = static::randomElement($countySelected);
+
+ $suffix = static::regexify(static::randomElement(strlen($countyCode) === 1 ? static::$plateSuffixesGroup1 : static::$plateSuffixesGroup2));
+
+ return "{$voivodeshipCode}{$countyCode} {$suffix}";
+ }
+
+ /**
+ * Selects random area from the list of available and requested.
+ *
+ * @param array $available
+ * @param array|null $requested
+ * @return mixed
+ */
+ protected static function selectRandomArea(array $available, ?array $requested)
+ {
+ $requested = array_intersect(array_keys($available), $requested ?? []);
+
+ if (empty($requested)) {
+ $requested = array_keys($available);
+ }
+
+ return $available[static::randomElement($requested)];
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/pl_PL/Payment.php b/vendor/fakerphp/faker/src/Faker/Provider/pl_PL/Payment.php
new file mode 100644
index 00000000..20786afb
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/pl_PL/Payment.php
@@ -0,0 +1,116 @@
+ 'Narodowy Bank Polski',
+ '102' => 'Powszechna Kasa Oszczędności Bank Polski Spółka Akcyjna',
+ '103' => 'Bank Handlowy w Warszawie Spółka Akcyjna',
+ '105' => 'ING Bank Śląski Spółka Akcyjna',
+ '106' => 'Bank BPH Spółka Akcyjna',
+ '109' => 'Santander Bank Polska Spółka Akcyjna',
+ '113' => 'Bank Gospodarstwa Krajowego',
+ '114' => 'mBank Spółka Akcyjna',
+ '116' => 'Bank Millennium Spółka Akcyjna',
+ '122' => 'Bank Handlowo-Kredytowy Spółka Akcyjna w Katowicach w likwidacji',
+ '124' => 'Bank Polska Kasa Opieki Spółka Akcyjna',
+ '132' => 'Bank Pocztowy Spółka Akcyjna',
+ '154' => 'Bank Ochrony Środowiska Spółka Akcyjna',
+ '158' => 'Mercedes-Benz Bank Polska Spółka Akcyjna',
+ '161' => 'SGB-Bank Spółka Akcyjna',
+ '168' => 'PLUS BANK Spółka Akcyjna',
+ '184' => 'Société Générale Spółka Akcyjna Oddział w Polsce',
+ '187' => 'Nest Bank Spółka Akcyjna',
+ '189' => 'Pekao Bank Hipoteczny Spółka Akcyjna',
+ '191' => 'Deutsche Bank Polska Spółka Akcyjna',
+ '193' => 'BANK POLSKIEJ SPÓŁDZIELCZOŚCI SPÓŁKA AKCYJNA',
+ '194' => 'Credit Agricole Bank Polska Spółka Akcyjna',
+ '195' => 'Idea Bank Spółka Akcyjna',
+ '203' => 'BNP Paribas Bank Polska Spółka Akcyjna',
+ '212' => 'Santander Consumer Bank Spółka Akcyjna',
+ '215' => 'mBank Hipoteczny Spółka Akcyjna',
+ '216' => 'Toyota Bank Polska Spółka Akcyjna',
+ '219' => 'DNB Bank Polska Spółka Akcyjna',
+ '224' => 'Banque PSA Finance Spółka Akcyjna Oddział w Polsce',
+ '225' => 'Svenska Handelsbanken AB Spółka Akcyjna Oddział w Polsce',
+ '235' => 'BNP Paribas S.A. Oddział w Polsce ',
+ '236' => 'Danske Bank A/S Spółka Akcyjna Oddział w Polsce',
+ '237' => 'Skandinaviska Enskilda Banken AB (Spółka Akcyjna) - Oddział w Polsce',
+ '239' => 'CAIXABANK, S.A. (SPÓŁKA AKCYJNA) ODDZIAŁ W POLSCE',
+ '241' => 'Elavon Financial Services Designated Activity Company (Spółka z O.O. o Wyznaczonym Przedmiocie Działalności) Oddział w Polsce',
+ '243' => 'BNP Paribas Securities Services Spółka Komandytowo - Akcyjna Oddział w Polsce',
+ '247' => 'HAITONG BANK, S.A. Spółka Akcyjna Oddział w Polsce',
+ '248' => 'Getin Noble Bank Spółka Akcyjna',
+ '249' => 'Alior Bank Spółka Akcyjna',
+ '251' => 'Aareal Bank Aktiengesellschaft (Spółka Akcyjna) - Oddział w Polsce',
+ '254' => 'Citibank Europe plc (Publiczna Spółka Akcyjna) Oddział w Polsce',
+ '255' => 'Ikano Bank AB (publ) Spółka Akcyjna Oddział w Polsce',
+ '256' => 'Nordea Bank Abp Spółka Akcyjna Oddział w Polsce',
+ '258' => 'J.P. Morgan Europe Limited Spółka z ograniczoną odpowiedzialnością Oddział w Polsce',
+ '260' => 'Bank of China (Luxembourg) S.A. Spółka Akcyjna Oddział w Polsce',
+ '262' => 'Industrial and Commercial Bank of China (Europe) S.A. (Spółka Akcyjna) Oddział w Polsce',
+ '264' => 'RCI Banque Spółka Akcyjna Oddział w Polsce',
+ '265' => 'EUROCLEAR Bank SA/NV (Spółka Akcyjna) - Oddział w Polsce',
+ '266' => 'Intesa Sanpaolo S.p.A. Spółka Akcyjna Oddział w Polsce',
+ '267' => 'Western Union International Bank GmbH, Sp. z o.o. Oddział w Polsce',
+ '269' => 'PKO Bank Hipoteczny Spółka Akcyjna',
+ '270' => 'TF BANK AB (Spółka z ograniczoną odpowiedzialnością) Oddział w Polsce',
+ '271' => 'FCE Bank Spółka Akcyjna Oddział w Polsce',
+ '272' => 'AS Inbank Spółka Akcyjna - Oddział w Polsce',
+ '273' => 'China Construction Bank (Europe) S.A. (Spółka Akcyjna) Oddział w Polsce',
+ '274' => 'MUFG Bank (Europe) N.V. S.A. Oddział w Polsce',
+ '275' => 'John Deere Bank S.A. Spółka Akcyjna Oddział w Polsce ',
+ '277' => 'Volkswagen Bank GmbH Spółka z ograniczoną odpowiedzialnością Oddział w Polsce',
+ '278' => 'ING Bank Hipoteczny Spółka Akcyjna',
+ '279' => 'Raiffeisen Bank International AG (Spółka Akcyjna) Oddział w Polsce',
+ '280' => 'HSBC France (Spółka Akcyjna) Oddział w Polsce',
+ '281' => 'Goldman Sachs Bank Europe SE Spółka Europejska Oddział w Polsce',
+ '283' => 'J.P. Morgan AG (Spółka Akcyjna) Oddział w Polsce',
+ '284' => 'UBS Europe SE (Spółka Europejska) Oddział w Polsce',
+ '285' => 'Banca Farmafactoring S.p.A. Spółka Akcyjna Oddział w Polsce',
+ '286' => 'FCA Bank S.p.A. Spółka Akcyjna Oddział w Polsce',
+ '287' => 'Bank Nowy BFG Spółka Akcyjna',
+ '288' => 'ALLFUNDS BANK S.A.U. (SPÓŁKA AKCYJNA) ODDZIAŁ W POLSCE',
+ ];
+
+ /**
+ * @example 'Euro Bank SA'
+ */
+ public static function bank()
+ {
+ return static::randomElement(static::$banks);
+ }
+
+ /**
+ * International Bank Account Number (IBAN)
+ * @link http://en.wikipedia.org/wiki/International_Bank_Account_Number
+ * @param string $prefix for generating bank account number of a specific bank
+ * @param string $countryCode ISO 3166-1 alpha-2 country code
+ * @param int $length total length without country code and 2 check digits
+ * @return string
+ */
+ public static function bankAccountNumber($prefix = '', $countryCode = 'PL', $length = null)
+ {
+ return static::iban($countryCode, $prefix, $length);
+ }
+
+ protected static function addBankCodeChecksum($iban, $countryCode = 'PL')
+ {
+ if ($countryCode != 'PL' || strlen($iban) <= 8) {
+ return $iban;
+ }
+ $checksum = 0;
+ $weights = [7, 1, 3, 9, 7, 1, 3];
+ for ($i = 0; $i < 7; $i++) {
+ $checksum += $weights[$i] * (int) $iban[$i];
+ }
+ $checksum = $checksum % 10;
+
+ return substr($iban, 0, 7) . $checksum . substr($iban, 8);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/pl_PL/Person.php b/vendor/fakerphp/faker/src/Faker/Provider/pl_PL/Person.php
new file mode 100644
index 00000000..1fae8e08
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/pl_PL/Person.php
@@ -0,0 +1,226 @@
+generator->parse(static::randomElement(static::$lastNameFormat));
+ }
+
+ public static function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ public static function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+
+ public function title($gender = null)
+ {
+ return static::randomElement(static::$title);
+ }
+
+ /**
+ * replaced by specific unisex Polish title
+ */
+ public static function titleMale()
+ {
+ return static::title();
+ }
+
+ /**
+ * replaced by specific unisex Polish title
+ */
+ public static function titleFemale()
+ {
+ return static::title();
+ }
+
+ /**
+ * PESEL - Universal Electronic System for Registration of the Population
+ * @link http://en.wikipedia.org/wiki/PESEL
+ * @param DateTime $birthdate
+ * @param string $sex M for male or F for female
+ * @return string 11 digit number, like 44051401358
+ */
+ public static function pesel($birthdate = null, $sex = null)
+ {
+ if ($birthdate === null) {
+ $birthdate = \Faker\Provider\DateTime::dateTimeThisCentury();
+ }
+
+ $weights = [1, 3, 7, 9, 1, 3, 7, 9, 1, 3];
+ $length = count($weights);
+
+ $fullYear = (int) $birthdate->format('Y');
+ $year = (int) $birthdate->format('y');
+ $month = $birthdate->format('m') + (((int) ($fullYear / 100) - 14) % 5) * 20;
+ $day = $birthdate->format('d');
+
+ $result = [(int) ($year / 10), $year % 10, (int) ($month / 10), $month % 10, (int) ($day / 10), $day % 10];
+
+ for ($i = 6; $i < $length; $i++) {
+ $result[$i] = static::randomDigit();
+ }
+
+ $result[$length - 1] |= 1;
+ if ($sex == 'F') {
+ $result[$length - 1] -= 1;
+ }
+
+ $checksum = 0;
+ for ($i = 0; $i < $length; $i++) {
+ $checksum += $weights[$i] * $result[$i];
+ }
+ $checksum = (10 - ($checksum % 10)) % 10;
+ $result[] = $checksum;
+
+ return implode('', $result);
+ }
+
+ /**
+ * National Identity Card number
+ * @link http://en.wikipedia.org/wiki/Polish_National_Identity_Card
+ * @return string 3 letters and 6 digits, like ABA300000
+ */
+ public static function personalIdentityNumber()
+ {
+ $range = str_split('ABCDEFGHIJKLMNPRSTUVWXYZ');
+ $low = ['A', static::randomElement($range), static::randomElement($range)];
+ $high = [static::randomDigit(), static::randomDigit(), static::randomDigit(), static::randomDigit(), static::randomDigit()];
+ $weights = [7, 3, 1, 7, 3, 1, 7, 3];
+ $checksum = 0;
+ for ($i = 0, $size = count($low); $i < $size; $i++) {
+ $checksum += $weights[$i] * (ord($low[$i]) - 55);
+ }
+ for ($i = 0, $size = count($high); $i < $size; $i++) {
+ $checksum += $weights[$i + 3] * $high[$i];
+ }
+ $checksum %= 10;
+
+ return implode('', $low) . $checksum . implode('', $high);
+ }
+
+ /**
+ * Taxpayer Identification Number (NIP in Polish)
+ * @link http://en.wikipedia.org/wiki/PESEL#Other_identifiers
+ * @link http://pl.wikipedia.org/wiki/NIP
+ * @return string 10 digit number
+ */
+ public static function taxpayerIdentificationNumber()
+ {
+ $weights = [6, 5, 7, 2, 3, 4, 5, 6, 7];
+ $result = [];
+ do {
+ $result = [
+ static::randomDigitNotNull(), static::randomDigitNotNull(), static::randomDigitNotNull(),
+ static::randomDigit(), static::randomDigit(), static::randomDigit(),
+ static::randomDigit(), static::randomDigit(), static::randomDigit(),
+ ];
+ $checksum = 0;
+ for ($i = 0, $size = count($result); $i < $size; $i++) {
+ $checksum += $weights[$i] * $result[$i];
+ }
+ $checksum %= 11;
+ } while ($checksum == 10);
+ $result[] = $checksum;
+
+ return implode('', $result);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/pl_PL/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/pl_PL/PhoneNumber.php
new file mode 100644
index 00000000..d421539b
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/pl_PL/PhoneNumber.php
@@ -0,0 +1,18 @@
+
+
+ Prof. Hart will answer or forward your message.
+
+ We would prefer to send you information by email.
+
+
+ **The Legal Small Print**
+
+
+ (Three Pages)
+
+ ***START**THE SMALL PRINT!**FOR PUBLIC DOMAIN EBOOKS**START***
+ Why is this "Small Print!" statement here? You know: lawyers.
+ They tell us you might sue us if there is something wrong with
+ your copy of this eBook, even if you got it for free from
+ someone other than us, and even if what's wrong is not our
+ fault. So, among other things, this "Small Print!" statement
+ disclaims most of our liability to you. It also tells you how
+ you may distribute copies of this eBook if you want to.
+
+ *BEFORE!* YOU USE OR READ THIS EBOOK
+ By using or reading any part of this PROJECT GUTENBERG-tm
+ eBook, you indicate that you understand, agree to and accept
+ this "Small Print!" statement. If you do not, you can receive
+ a refund of the money (if any) you paid for this eBook by
+ sending a request within 30 days of receiving it to the person
+ you got it from. If you received this eBook on a physical
+ medium (such as a disk), you must return it with your request.
+
+ ABOUT PROJECT GUTENBERG-TM EBOOKS
+ This PROJECT GUTENBERG-tm eBook, like most PROJECT GUTENBERG-tm eBooks,
+ is a "public domain" work distributed by Professor Michael S. Hart
+ through the Project Gutenberg Association (the "Project").
+ Among other things, this means that no one owns a United States copyright
+ on or for this work, so the Project (and you!) can copy and
+ distribute it in the United States without permission and
+ without paying copyright royalties. Special rules, set forth
+ below, apply if you wish to copy and distribute this eBook
+ under the "PROJECT GUTENBERG" trademark.
+
+ Please do not use the "PROJECT GUTENBERG" trademark to market
+ any commercial products without permission.
+
+ To create these eBooks, the Project expends considerable
+ efforts to identify, transcribe and proofread public domain
+ works. Despite these efforts, the Project's eBooks and any
+ medium they may be on may contain "Defects". Among other
+ things, Defects may take the form of incomplete, inaccurate or
+ corrupt data, transcription errors, a copyright or other
+ intellectual property infringement, a defective or damaged
+ disk or other eBook medium, a computer virus, or computer
+ codes that damage or cannot be read by your equipment.
+
+ LIMITED WARRANTY; DISCLAIMER OF DAMAGES
+ But for the "Right of Replacement or Refund" described below,
+ [1] Michael Hart and the Foundation (and any other party you may
+ receive this eBook from as a PROJECT GUTENBERG-tm eBook) disclaims
+ all liability to you for damages, costs and expenses, including
+ legal fees, and [2] YOU HAVE NO REMEDIES FOR NEGLIGENCE OR
+ UNDER STRICT LIABILITY, OR FOR BREACH OF WARRANTY OR CONTRACT,
+ INCLUDING BUT NOT LIMITED TO INDIRECT, CONSEQUENTIAL, PUNITIVE
+ OR INCIDENTAL DAMAGES, EVEN IF YOU GIVE NOTICE OF THE
+ POSSIBILITY OF SUCH DAMAGES.
+
+ If you discover a Defect in this eBook within 90 days of
+ receiving it, you can receive a refund of the money (if any)
+ you paid for it by sending an explanatory note within that
+ time to the person you received it from. If you received it
+ on a physical medium, you must return it with your note, and
+ such person may choose to alternatively give you a replacement
+ copy. If you received it electronically, such person may
+ choose to alternatively give you a second opportunity to
+ receive it electronically.
+
+ THIS EBOOK IS OTHERWISE PROVIDED TO YOU "AS-IS". NO OTHER
+ WARRANTIES OF ANY KIND, EXPRESS OR IMPLIED, ARE MADE TO YOU AS
+ TO THE EBOOK OR ANY MEDIUM IT MAY BE ON, INCLUDING BUT NOT
+ LIMITED TO WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A
+ PARTICULAR PURPOSE.
+
+ Some states do not allow disclaimers of implied warranties or
+ the exclusion or limitation of consequential damages, so the
+ above disclaimers and exclusions may not apply to you, and you
+ may have other legal rights.
+
+ INDEMNITY
+ You will indemnify and hold Michael Hart, the Foundation,
+ and its trustees and agents, and any volunteers associated
+ with the production and distribution of Project Gutenberg-tm
+ texts harmless, from all liability, cost and expense, including
+ legal fees, that arise directly or indirectly from any of the
+ following that you do or cause: [1] distribution of this eBook,
+ [2] alteration, modification, or addition to the eBook,
+ or [3] any Defect.
+
+ DISTRIBUTION UNDER "PROJECT GUTENBERG-tm"
+ You may distribute copies of this eBook electronically, or by
+ disk, book or any other medium if you either delete this
+ "Small Print!" and all other references to Project Gutenberg,
+ or:
+
+ [1] Only give exact copies of it. Among other things, this
+ requires that you do not remove, alter or modify the
+ eBook or this "small print!" statement. You may however,
+ if you wish, distribute this eBook in machine readable
+ binary, compressed, mark-up, or proprietary form,
+ including any form resulting from conversion by word
+ processing or hypertext software, but only so long as
+ *EITHER*:
+
+ [*] The eBook, when displayed, is clearly readable, and
+ does *not* contain characters other than those
+ intended by the author of the work, although tilde
+ (~), asterisk (*) and underline (_) characters may
+ be used to convey punctuation intended by the
+ author, and additional characters may be used to
+ indicate hypertext links; OR
+
+ [*] The eBook may be readily converted by the reader at
+ no expense into plain ASCII, EBCDIC or equivalent
+ form by the program that displays the eBook (as is
+ the case, for instance, with most word processors);
+ OR
+
+ [*] You provide, or agree to also provide on request at
+ no additional cost, fee or expense, a copy of the
+ eBook in its original plain ASCII form (or in EBCDIC
+ or other equivalent proprietary form).
+
+ [2] Honor the eBook refund and replacement provisions of this
+ "Small Print!" statement.
+
+ [3] Pay a trademark license fee to the Foundation of 20% of the
+ gross profits you derive calculated using the method you
+ already use to calculate your applicable taxes. If you
+ don't derive profits, no royalty is due. Royalties are
+ payable to "Project Gutenberg Literary Archive Foundation"
+ the 60 days following each date you prepare (or were
+ legally required to prepare) your annual (or equivalent
+ periodic) tax return. Please contact us beforehand to
+ let us know your plans and to work out the details.
+
+ WHAT IF YOU *WANT* TO SEND MONEY EVEN IF YOU DON'T HAVE TO?
+ Project Gutenberg is dedicated to increasing the number of
+ public domain and licensed works that can be freely distributed
+ in machine readable form.
+
+ The Project gratefully accepts contributions of money, time,
+ public domain materials, or royalty free copyright licenses.
+ Money should be paid to the:
+ "Project Gutenberg Literary Archive Foundation."
+
+ If you are interested in contributing scanning equipment or
+ software or other items, please contact Michael Hart at:
+ hart@pobox.com
+
+ [Portions of this eBook's header and trailer may be reprinted only
+ when distributed free of all fees. Copyright (C) 2001, 2002 by
+ Michael S. Hart. Project Gutenberg is a TradeMark and may not be
+ used in any sales of Project Gutenberg eBooks or other materials be
+ they hardware or software or any other related product without
+ express permission.]
+
+ *END THE SMALL PRINT! FOR PUBLIC DOMAIN EBOOKS*Ver.02/11/02*END*
+
+ */
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/Address.php
new file mode 100644
index 00000000..e19aa833
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/Address.php
@@ -0,0 +1,154 @@
+generator->numerify('########0001');
+ $n .= check_digit($n);
+ $n .= check_digit($n);
+
+ return $formatted ? vsprintf('%d%d.%d%d%d.%d%d%d/%d%d%d%d-%d%d', str_split($n)) : $n;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/Internet.php
new file mode 100644
index 00000000..fc68ae66
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/Internet.php
@@ -0,0 +1,9 @@
+ [
+ '4##############'
+ ],
+ 'MasterCard' => [
+ '5##############'
+ ],
+ 'American Express' => [
+ '34############',
+ '37############'
+ ],
+ 'Discover Card' => [
+ '6011###########',
+ '622############',
+ '64#############',
+ '65#############'
+ ],
+ 'Diners' => [
+ '301############',
+ '301##########',
+ '305############',
+ '305##########',
+ '36#############',
+ '36###########',
+ '38#############',
+ '38###########',
+ ],
+ 'Elo' => [
+ '636368#########',
+ '438935#########',
+ '504175#########',
+ '451416#########',
+ '636297#########',
+ '5067###########',
+ '4576###########',
+ '4011###########',
+ ],
+ 'Hipercard' => [
+ '38#############',
+ '60#############',
+ ],
+ 'Aura' => [
+ '50#############'
+ ]
+ ];
+
+ /**
+ * International Bank Account Number (IBAN)
+ * @link http://en.wikipedia.org/wiki/International_Bank_Account_Number
+ * @param string $prefix for generating bank account number of a specific bank
+ * @param string $countryCode ISO 3166-1 alpha-2 country code
+ * @param int $length total length without country code and 2 check digits
+ * @return string
+ */
+ public static function bankAccountNumber($prefix = '', $countryCode = 'BR', $length = null)
+ {
+ return static::iban($countryCode, $prefix, $length);
+ }
+
+
+ /**
+ * @see list of Brazilians banks (2018-02-15), source: https://pt.wikipedia.org/wiki/Lista_de_bancos_do_Brasil
+ */
+ protected static $banks = [
+ 'BADESUL Desenvolvimento S.A. – Agência de Fomento/RS',
+ 'Banco Central do Brasil',
+ 'Banco da Amazônia',
+ 'Banco de Brasília',
+ 'Banco de Desenvolvimento de Minas Gerais',
+ 'Banco de Desenvolvimento do Espírito Santo',
+ 'Banco de Desenvolvimento do Paraná',
+ 'Banco do Brasil',
+ 'Banco do Estado de Sergipe Banese Estadual',
+ 'Banco do Estado do Espírito Santo Banestes',
+ 'Banco do Estado do Pará',
+ 'Banco do Estado do Rio Grande do Sul',
+ 'Banco do Nordeste do Brasil',
+ 'Banco Nacional de Desenvolvimento Econômico e Social',
+ 'Banco Regional de Desenvolvimento do Extremo Sul',
+ 'Caixa Econômica Federal',
+ 'Banco ABN Amro S.A.',
+ 'Banco Alfa',
+ 'Banco Banif',
+ 'Banco BBM',
+ 'Banco BMG',
+ 'Banco Bonsucesso',
+ 'Banco BTG Pactual',
+ 'Banco Cacique',
+ 'Banco Caixa Geral - Brasil',
+ 'Banco Citibank',
+ 'Banco Credibel',
+ 'Banco Credit Suisse',
+ 'Góis Monteiro & Co',
+ 'Banco Fator',
+ 'Banco Fibra',
+ 'Agibank',
+ 'Banco Guanabara',
+ 'Banco Industrial do Brasil',
+ 'Banco Industrial e Comercial',
+ 'Banco Indusval',
+ 'Banco Inter',
+ 'Banco Itaú BBA',
+ 'Banco ItaúBank',
+ 'Banco Itaucred Financiamentos',
+ 'Banco Mercantil do Brasil',
+ 'Banco Modal Modal',
+ 'Banco Morada',
+ 'Banco Pan',
+ 'Banco Paulista',
+ 'Banco Pine',
+ 'Banco Renner',
+ 'Banco Ribeirão Preto',
+ 'Banco Safra',
+ 'Banco Santander',
+ 'Banco Sofisa',
+ 'Banco Topázio',
+ 'Banco Votorantim',
+ 'Bradesco Bradesco',
+ 'Itaú Unibanco',
+ 'Banco Original',
+ 'Banco Neon',
+ 'Nu Pagamentos S.A',
+ 'XP Investimentos Corretora de Câmbio Títulos e Valores Mobiliários S.A',
+ ];
+
+ /**
+ * @example 'Banco Neon'
+ */
+ public static function bank()
+ {
+ return static::randomElement(static::$banks);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/Person.php b/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/Person.php
new file mode 100644
index 00000000..c53ee83b
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/Person.php
@@ -0,0 +1,153 @@
+generator->numerify('#########');
+ $n .= check_digit($n);
+ $n .= check_digit($n);
+
+ return $formatted ? vsprintf('%d%d%d.%d%d%d.%d%d%d-%d%d', str_split($n)) : $n;
+ }
+
+ /**
+ * A random RG number, following Sao Paulo state's rules.
+ * @link http://pt.wikipedia.org/wiki/C%C3%A9dula_de_identidade
+ * @param bool $formatted If the number should have dots/dashes or not.
+ * @return string
+ */
+ public function rg($formatted = true)
+ {
+ $n = $this->generator->numerify('########');
+ $n .= check_digit($n);
+
+ return $formatted ? vsprintf('%d%d.%d%d%d.%d%d%d-%s', str_split($n)) : $n;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/PhoneNumber.php
new file mode 100644
index 00000000..293c029d
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/PhoneNumber.php
@@ -0,0 +1,137 @@
+ '']);
+ }
+
+ return $number;
+ }
+
+ /**
+ * Generates an 9-digit landline number without formatting characters.
+ * @param bool $formatted [def: true] If it should return a formatted number or not.
+ * @return string
+ */
+ public static function landline($formatted = true)
+ {
+ $number = static::numerify(static::randomElement(static::$landlineFormats));
+
+ if (!$formatted) {
+ $number = strtr($number, ['-' => '']);
+ }
+
+ return $number;
+ }
+
+ /**
+ * Randomizes between cellphone and landline numbers.
+ * @param bool $formatted [def: true] If it should return a formatted number or not.
+ * @return mixed
+ */
+ public static function phone($formatted = true)
+ {
+ $options = static::randomElement([
+ ['cellphone', false],
+ ['cellphone', true],
+ ['landline', null],
+ ]);
+
+ return call_user_func("static::{$options[0]}", $formatted, $options[1]);
+ }
+
+ /**
+ * Generates a complete phone number.
+ * @param string $type [def: landline] One of "landline" or "cellphone". Defaults to "landline" on invalid values.
+ * @param bool $formatted [def: true] If the number should be formatted or not.
+ * @return string
+ */
+ protected static function anyPhoneNumber($type, $formatted = true)
+ {
+ $area = static::areaCode();
+ $number = ($type == 'cellphone') ?
+ static::cellphone($formatted) :
+ static::landline($formatted);
+
+ return $formatted ? "($area) $number" : $area . $number;
+ }
+
+ /**
+ * Concatenates {@link areaCode} and {@link cellphone} into a national cellphone number.
+ * @param bool $formatted [def: true] If it should return a formatted number or not.
+ * @return string
+ */
+ public static function cellphoneNumber($formatted = true)
+ {
+ return static::anyPhoneNumber('cellphone', $formatted);
+ }
+
+ /**
+ * Concatenates {@link areaCode} and {@link landline} into a national landline number.
+ * @param bool $formatted [def: true] If it should return a formatted number or not.
+ * @return string
+ */
+ public static function landlineNumber($formatted = true)
+ {
+ return static::anyPhoneNumber('landline', $formatted);
+ }
+
+ /**
+ * Randomizes between complete cellphone and landline numbers.
+ * @return mixed
+ */
+ public function phoneNumber()
+ {
+ $method = static::randomElement(['cellphoneNumber', 'landlineNumber']);
+ return call_user_func("static::$method", true);
+ }
+
+ /**
+ * Randomizes between complete cellphone and landline numbers, cleared from formatting symbols.
+ * @return mixed
+ */
+ public static function phoneNumberCleared()
+ {
+ $method = static::randomElement(['cellphoneNumber', 'landlineNumber']);
+ return call_user_func("static::$method", false);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/check_digit.php b/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/check_digit.php
new file mode 100644
index 00000000..1ba51ccc
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/pt_BR/check_digit.php
@@ -0,0 +1,36 @@
+= 12;
+ $verifier = 0;
+
+ for ($i = 1; $i <= $length; $i++) {
+ if (!$second_algorithm) {
+ $multiplier = $i + 1;
+ } else {
+ $multiplier = ($i >= 9) ? $i - 7 : $i + 1;
+ }
+ $verifier += $numbers[$length - $i] * $multiplier;
+ }
+
+ $verifier = 11 - ($verifier % 11);
+ if ($verifier >= 10) {
+ $verifier = 0;
+ }
+
+ return $verifier;
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/pt_PT/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/pt_PT/Address.php
new file mode 100644
index 00000000..da329108
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/pt_PT/Address.php
@@ -0,0 +1,124 @@
+ 0; $i--) {
+ $numbers[$i] = substr($number, $i - 1, 1);
+ $partial[$i] = $numbers[$i] * $factor;
+ $sum += $partial[$i];
+ if ($factor == $base) {
+ $factor = 1;
+ }
+ $factor++;
+ }
+ $res = $sum % 11;
+
+ if ($res == 0 || $res == 1) {
+ $digit = 0;
+ } else {
+ $digit = 11 - $res;
+ }
+
+ return $digit;
+ }
+
+ /**
+ * @link http://nomesportugueses.blogspot.pt/2012/01/lista-dos-cem-nomes-mais-usados-em.html
+ */
+
+ protected static $firstNameMale = [
+ 'Rodrigo', 'João', 'Martim', 'Afonso', 'Tomás', 'Gonçalo', 'Francisco', 'Tiago',
+ 'Diogo', 'Guilherme', 'Pedro', 'Miguel', 'Rafael', 'Gabriel', 'Santiago', 'Dinis',
+ 'David', 'Duarte', 'José', 'Simão', 'Daniel', 'Lucas', 'Gustavo', 'André', 'Denis',
+ 'Salvador', 'António', 'Vasco', 'Henrique', 'Lourenço', 'Manuel', 'Eduardo', 'Bernardo',
+ 'Leandro', 'Luís', 'Diego', 'Leonardo', 'Alexandre', 'Rúben', 'Mateus', 'Ricardo',
+ 'Vicente', 'Filipe', 'Bruno', 'Nuno', 'Carlos', 'Rui', 'Hugo', 'Samuel', 'Álvaro',
+ 'Matias', 'Fábio', 'Ivo', 'Paulo', 'Jorge', 'Xavier', 'Marco', 'Isaac', 'Raúl', 'Benjamim',
+ 'Renato', 'Artur', 'Mário', 'Frederico', 'Cristiano', 'Ivan', 'Sérgio', 'Micael',
+ 'Vítor', 'Edgar', 'Kevin', 'Joaquim', 'Igor', 'Ângelo', 'Enzo', 'Valentim', 'Flávio',
+ 'Joel', 'Fernando', 'Sebastião', 'Tomé', 'César', 'Cláudio', 'Nelson', 'Lisandro', 'Jaime',
+ 'Gil', 'Mauro', 'Sandro', 'Hélder', 'Matheus', 'William', 'Gaspar', 'Márcio',
+ 'Martinho', 'Emanuel', 'Marcos', 'Telmo', 'Davi', 'Wilson'
+ ];
+
+ protected static $firstNameFemale = [
+ 'Maria', 'Leonor', 'Matilde', 'Mariana', 'Ana', 'Beatriz', 'Inês', 'Lara', 'Carolina', 'Margarida',
+ 'Joana', 'Sofia', 'Diana', 'Francisca', 'Laura', 'Sara', 'Madalena', 'Rita', 'Mafalda', 'Catarina',
+ 'Luana', 'Marta', 'Íris', 'Alice', 'Bianca', 'Constança', 'Gabriela', 'Eva', 'Clara', 'Bruna', 'Daniela',
+ 'Iara', 'Filipa', 'Vitória', 'Ariana', 'Letícia', 'Bárbara', 'Camila', 'Rafaela', 'Carlota', 'Yara',
+ 'Núria', 'Raquel', 'Ema', 'Helena', 'Benedita', 'Érica', 'Isabel', 'Nicole', 'Lia', 'Alícia', 'Mara',
+ 'Jéssica', 'Soraia', 'Júlia', 'Luna', 'Victória', 'Luísa', 'Teresa', 'Miriam', 'Adriana', 'Melissa',
+ 'Andreia', 'Juliana', 'Alexandra', 'Yasmin', 'Tatiana', 'Leticia', 'Luciana', 'Eduarda', 'Cláudia',
+ 'Débora', 'Fabiana', 'Renata', 'Kyara', 'Kelly', 'Irina', 'Mélanie', 'Nádia', 'Cristiana', 'Liliana',
+ 'Patrícia', 'Vera', 'Doriana', 'Ângela', 'Mia', 'Erica', 'Mónica', 'Isabela', 'Salomé', 'Cátia',
+ 'Verónica', 'Violeta', 'Lorena', 'Érika', 'Vanessa', 'Iris', 'Anna', 'Viviane', 'Rebeca', 'Neuza',
+ ];
+
+ protected static $lastName = [
+ 'Abreu', 'Almeida', 'Alves', 'Amaral', 'Amorim', 'Andrade', 'Anjos', 'Antunes', 'Araújo', 'Assunção',
+ 'Azevedo', 'Baptista', 'Barbosa', 'Barros', 'Batista', 'Borges', 'Branco', 'Brito', 'Campos', 'Cardoso',
+ 'Carneiro', 'Carvalho', 'Castro', 'Coelho', 'Correia', 'Costa', 'Cruz', 'Cunha', 'Domingues', 'Esteves',
+ 'Faria', 'Fernandes', 'Ferreira', 'Figueiredo', 'Fonseca', 'Freitas', 'Garcia', 'Gaspar', 'Gomes',
+ 'Gonçalves', 'Guerreiro', 'Henriques', 'Jesus', 'Leal', 'Leite', 'Lima', 'Lopes', 'Loureiro', 'Lourenço',
+ 'Macedo', 'Machado', 'Magalhães', 'Maia', 'Marques', 'Martins', 'Matias', 'Matos', 'Melo', 'Mendes',
+ 'Miranda', 'Monteiro', 'Morais', 'Moreira', 'Mota', 'Moura', 'Nascimento', 'Neto', 'Neves', 'Nogueira',
+ 'Nunes', 'Oliveira', 'Pacheco', 'Paiva', 'Pereira', 'Pinheiro', 'Pinho', 'Pinto', 'Pires', 'Ramos',
+ 'Reis', 'Ribeiro', 'Rocha', 'Rodrigues', 'Santos', 'Silva', 'Simões', 'Soares', 'Sousa',
+ 'Sá', 'Tavares', 'Teixeira', 'Torres', 'Valente', 'Vaz', 'Vicente', 'Vieira',
+ ];
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/pt_PT/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/pt_PT/PhoneNumber.php
new file mode 100644
index 00000000..92dcf57a
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/pt_PT/PhoneNumber.php
@@ -0,0 +1,50 @@
+ '01', 'AR' => '02', 'AG' => '03', 'B' => '40', 'BC' => '04', 'BH' => '05',
+ 'BN' => '06', 'BT' => '07', 'BV' => '08', 'BR' => '09', 'BZ' => '10', 'CS' => '11',
+ 'CL' => '51', 'CJ' => '12', 'CT' => '13', 'CV' => '14', 'DB' => '15', 'DJ' => '16',
+ 'GL' => '17', 'GR' => '52', 'GJ' => '18', 'HR' => '19', 'HD' => '20', 'IL' => '21',
+ 'IS' => '22', 'IF' => '23', 'MM' => '24', 'MH' => '25', 'MS' => '26', 'NT' => '27',
+ 'OT' => '28', 'PH' => '29', 'SM' => '30', 'SJ' => '31', 'SB' => '32', 'SV' => '33',
+ 'TR' => '34', 'TM' => '35', 'TL' => '36', 'VS' => '37', 'VL' => '38', 'VN' => '39',
+
+ 'B1' => '41', 'B2' => '42', 'B3' => '43', 'B4' => '44', 'B5' => '45', 'B6' => '46'
+ ];
+
+ /**
+ * Personal Numerical Code (CNP)
+ *
+ * @link http://ro.wikipedia.org/wiki/Cod_numeric_personal
+ * @example 1111111111118
+ *
+ * @param null|string $gender Person::GENDER_MALE or Person::GENDER_FEMALE
+ * @param null|string $dateOfBirth (1800-2099) 'Y-m-d', 'Y-m', 'Y' I.E. '1981-06-16', '2085-03', '1900'
+ * @param null|string $county county code where the CNP was issued
+ * @param null|bool $isResident flag if the person resides in Romania
+ * @return string 13 digits CNP code
+ */
+ public function cnp($gender = null, $dateOfBirth = null, $county = null, $isResident = true)
+ {
+ $genders = [Person::GENDER_MALE, Person::GENDER_FEMALE];
+ if (empty($gender)) {
+ $gender = static::randomElement($genders);
+ } elseif (!in_array($gender, $genders)) {
+ throw new \InvalidArgumentException("Gender must be '{Person::GENDER_MALE}' or '{Person::GENDER_FEMALE}'");
+ }
+
+ $date = $this->getDateOfBirth($dateOfBirth);
+
+ if (is_null($county)) {
+ $countyCode = static::randomElement(array_values(static::$cnpCountyCodes));
+ } elseif (!array_key_exists($county, static::$cnpCountyCodes)) {
+ throw new \InvalidArgumentException("Invalid county code '{$county}' received");
+ } else {
+ $countyCode = static::$cnpCountyCodes[$county];
+ }
+
+ $cnp = (string) $this->getGenderDigit($date, $gender, $isResident)
+ . $date->format('ymd')
+ . $countyCode
+ . static::numerify('##%')
+ ;
+
+ $checksum = $this->getChecksumDigit($cnp);
+
+ return $cnp . $checksum;
+ }
+
+ /**
+ * @param null|string $dateOfBirth
+ * @return \DateTime
+ */
+ protected function getDateOfBirth($dateOfBirth)
+ {
+ if (empty($dateOfBirth)) {
+ $dateOfBirthParts = [self::numberBetween(1800, 2099)];
+ } else {
+ $dateOfBirthParts = explode('-', $dateOfBirth);
+ }
+ $baseDate = \Faker\Provider\DateTime::dateTimeBetween("first day of January {$dateOfBirthParts[0]}", "last day of December {$dateOfBirthParts[0]}");
+
+ switch (count($dateOfBirthParts)) {
+ case 1:
+ $dateOfBirthParts[] = $baseDate->format('m');
+ //don't break, we need the day also
+ // no break
+ case 2:
+ $dateOfBirthParts[] = $baseDate->format('d');
+ //don't break, next line will
+ // no break
+ case 3:
+ break;
+ default:
+ throw new \InvalidArgumentException("Invalid date of birth - must be null or in the 'Y-m-d', 'Y-m', 'Y' format");
+ }
+
+ if ($dateOfBirthParts[0] < 1800 || $dateOfBirthParts[0] > 2099) {
+ throw new \InvalidArgumentException("Invalid date of birth - year must be between 1800 and 2099, '{$dateOfBirthParts[0]}' received");
+ }
+
+ $dateOfBirthFinal = implode('-', $dateOfBirthParts);
+ $date = \DateTime::createFromFormat('Y-m-d', $dateOfBirthFinal);
+ //a full (invalid) date might have been supplied, check if it converts
+ if ($date->format('Y-m-d') !== $dateOfBirthFinal) {
+ throw new \InvalidArgumentException("Invalid date of birth - '{$date->format('Y-m-d')}' generated based on '{$dateOfBirth}' received");
+ }
+
+ return $date;
+ }
+
+ /**
+ * https://ro.wikipedia.org/wiki/Cod_numeric_personal#S
+ *
+ * @param \DateTime $dateOfBirth
+ * @param bool $isResident
+ * @param string $gender
+ * @return int
+ */
+ protected static function getGenderDigit(\DateTime $dateOfBirth, $gender, $isResident)
+ {
+ if (!$isResident) {
+ return 9;
+ }
+
+ if ($dateOfBirth->format('Y') < 1900) {
+ if ($gender == Person::GENDER_MALE) {
+ return 3;
+ }
+ return 4;
+ }
+
+ if ($dateOfBirth->format('Y') < 2000) {
+ if ($gender == Person::GENDER_MALE) {
+ return 1;
+ }
+ return 2;
+ }
+
+ if ($gender == Person::GENDER_MALE) {
+ return 5;
+ }
+ return 6;
+ }
+
+ /**
+ * Calculates a checksum for the Personal Numerical Code (CNP).
+ *
+ * @param string $value 12 digit CNP
+ * @return int checksum digit
+ */
+ protected function getChecksumDigit($value)
+ {
+ $checkNumber = 279146358279;
+
+ $checksum = 0;
+ foreach (range(0, 11) as $digit) {
+ $checksum += (int) substr($value, $digit, 1) * (int) substr($checkNumber, $digit, 1);
+ }
+ $checksum = $checksum % 11;
+
+ return $checksum == 10 ? 1 : $checksum;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ro_RO/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/ro_RO/PhoneNumber.php
new file mode 100644
index 00000000..36f4256c
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ro_RO/PhoneNumber.php
@@ -0,0 +1,62 @@
+ [
+ '021#######', // Bucharest
+ '023#######',
+ '024#######',
+ '025#######',
+ '026#######',
+ '027#######', // non-geographic
+ '031#######', // Bucharest
+ '033#######',
+ '034#######',
+ '035#######',
+ '036#######',
+ '037#######', // non-geographic
+ ],
+ 'mobile' => [
+ '07########',
+ ]
+ ];
+
+ protected static $specialFormats = [
+ 'toll-free' => [
+ '0800######',
+ '0801######', // shared-cost numbers
+ '0802######', // personal numbering
+ '0806######', // virtual cards
+ '0807######', // pre-paid cards
+ '0870######', // internet dial-up
+ ],
+ 'premium-rate' => [
+ '0900######',
+ '0903######', // financial information
+ '0906######', // adult entertainment
+ ]
+ ];
+
+ /**
+ * @link http://en.wikipedia.org/wiki/Telephone_numbers_in_Romania#Last_years
+ */
+ public function phoneNumber()
+ {
+ $type = static::randomElement(array_keys(static::$normalFormats));
+
+ return static::numerify(static::randomElement(static::$normalFormats[$type]));
+ }
+
+ public static function tollFreePhoneNumber()
+ {
+ return static::numerify(static::randomElement(static::$specialFormats['toll-free']));
+ }
+
+ public static function premiumRatePhoneNumber()
+ {
+ return static::numerify(static::randomElement(static::$specialFormats['premium-rate']));
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ro_RO/Text.php b/vendor/fakerphp/faker/src/Faker/Provider/ro_RO/Text.php
new file mode 100644
index 00000000..410c6f9b
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ro_RO/Text.php
@@ -0,0 +1,154 @@
+generator->parse($format);
+ }
+
+ public static function country()
+ {
+ return static::randomElement(static::$country);
+ }
+
+ public static function postcode()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$postcode)));
+ }
+
+ public static function regionSuffix()
+ {
+ return static::randomElement(static::$regionSuffix);
+ }
+
+ public static function region()
+ {
+ return static::randomElement(static::$region);
+ }
+
+ public static function cityPrefix()
+ {
+ return static::randomElement(static::$cityPrefix);
+ }
+
+ public function city()
+ {
+ return static::randomElement(static::$city);
+ }
+
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ public static function street()
+ {
+ return static::randomElement(static::$street);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ru_RU/Color.php b/vendor/fakerphp/faker/src/Faker/Provider/ru_RU/Color.php
new file mode 100644
index 00000000..2f18a73b
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ru_RU/Color.php
@@ -0,0 +1,23 @@
+generator->parse($format);
+ }
+
+ public static function companyPrefix()
+ {
+ return static::randomElement(static::$companyPrefixes);
+ }
+
+ public static function companyNameElement()
+ {
+ return static::randomElement(static::$companyElements);
+ }
+
+ public static function companyNameSuffix()
+ {
+ return static::randomElement(static::$companyNameSuffixes);
+ }
+
+ public static function inn($area_code = '')
+ {
+ if ($area_code === '' || (int) $area_code == 0) {
+ //Simple generation code for areas in Russian without check for valid
+ $area_code = self::numberBetween(1, 91);
+ } else {
+ $area_code = (int) $area_code;
+ }
+ $area_code = str_pad($area_code, 2, '0', STR_PAD_LEFT);
+ $inn_base = $area_code . static::numerify('#######');
+ return $inn_base . \Faker\Calculator\Inn::checksum($inn_base);
+ }
+
+ public static function kpp($inn = '')
+ {
+ if ($inn == '' || strlen($inn) < 4) {
+ $inn = static::inn();
+ }
+ return substr($inn, 0, 4) . '01001';
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ru_RU/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/ru_RU/Internet.php
new file mode 100644
index 00000000..195ef5f4
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ru_RU/Internet.php
@@ -0,0 +1,9 @@
+.*<' | \
+ * sed -r 's/—//' | sed -r 's/[\<\>]//g' | sed -r "s/(^|$)/'/g" | sed -r 's/$/,/' | sed -r 's/\&(laquo|raquo);/"/g' | \
+ * sed -r 's/\s+/ /g'"
+ */
+ protected static $banks = [
+ 'Новый Промышленный Банк',
+ 'Новый Символ',
+ 'Нокссбанк',
+ 'Ноосфера',
+ 'Нордеа Банк',
+ 'Нота-Банк',
+ 'НС Банк',
+ 'НСТ-Банк',
+ 'Нэклис-Банк',
+ 'Образование',
+ 'Объединенный Банк Промышленных Инвестиций',
+ 'Объединенный Банк Республики',
+ 'Объединенный Капитал',
+ 'Объединенный Кредитный Банк',
+ 'Объединенный Кредитный Банк Московский филиал',
+ 'Объединенный Национальный Банк',
+ 'Объединенный Резервный Банк',
+ 'Океан Банк',
+ 'ОЛМА-Банк',
+ 'Онего',
+ 'Оней Банк',
+ 'ОПМ-Банк',
+ 'Оргбанк',
+ 'Оренбург',
+ 'ОТП Банк',
+ 'ОФК Банк',
+ 'Охабанк',
+ 'Первобанк',
+ 'Первомайский',
+ 'Первоуральскбанк',
+ 'Первый Дортрансбанк',
+ 'Первый Инвестиционный банк',
+ 'Первый Клиентский Банк',
+ 'Первый Чешско-Российский Банк',
+ 'Пересвет',
+ 'Пермь',
+ 'Петербургский Социальный Коммерческий Банк',
+ 'Петрокоммерц',
+ 'ПИР Банк',
+ 'Платина',
+ 'Плато-Банк',
+ 'Плюс Банк',
+ 'Пойдем!',
+ 'Почтобанк',
+ 'Прайм Финанс',
+ 'Преодоление',
+ 'Приморье',
+ 'Примсоцбанк',
+ 'Примтеркомбанк',
+ 'Прио-Внешторгбанк',
+ 'Приобье',
+ 'Приполярный',
+ 'Приско Капитал Банк',
+ 'Пробизнесбанк',
+ 'Проинвестбанк',
+ 'Прокоммерцбанк',
+ 'Проминвестбанк',
+ 'Промрегионбанк',
+ 'Промсвязьбанк',
+ 'Промсвязьинвестбанк',
+ 'Промсельхозбанк',
+ 'Промтрансбанк',
+ 'Промышленно-Финансовое Сотрудничество',
+ 'Промэнергобанк',
+ 'Профессионал Банк',
+ 'Профит Банк',
+ 'Прохладный',
+ 'Пульс Столицы',
+ 'Радиотехбанк',
+ 'Развитие',
+ 'Развитие-Столица',
+ 'Райффайзенбанк',
+ 'Расчетно-Кредитный Банк',
+ 'Расчетный Дом',
+ 'РБА',
+ 'Региональный Банк Развития',
+ 'Региональный Банк Сбережений',
+ 'Региональный Коммерческий Банк',
+ 'Региональный Кредит',
+ 'Регионфинансбанк',
+ 'Регнум',
+ 'Резерв',
+ 'Ренессанс',
+ 'Ренессанс Кредит',
+ 'Рента-Банк',
+ 'РЕСО Кредит',
+ 'Республиканский Кредитный Альянс',
+ 'Ресурс-Траст',
+ 'Риабанк',
+ 'Риал-Кредит',
+ 'Ринвестбанк',
+ 'Ринвестбанк Московский офис',
+ 'РИТ-Банк',
+ 'РН Банк',
+ 'Росавтобанк',
+ 'Росбанк',
+ 'Росбизнесбанк',
+ 'Росгосстрах Банк',
+ 'Росдорбанк',
+ 'РосЕвроБанк',
+ 'РосинтерБанк',
+ 'Роспромбанк',
+ 'Россельхозбанк',
+ 'Российская Финансовая Корпорация',
+ 'Российский Капитал',
+ 'Российский Кредит',
+ 'Российский Национальный Коммерческий Банк',
+ 'Россита-Банк',
+ 'Россия',
+ 'Рост Банк',
+ 'Ростфинанс',
+ 'Росэксимбанк',
+ 'Росэнергобанк',
+ 'Роял Кредит Банк',
+ 'РСКБ',
+ 'РТС-Банк',
+ 'РУБанк',
+ 'Рублев',
+ 'Руна-Банк',
+ 'Рунэтбанк',
+ 'Рускобанк',
+ 'Руснарбанк',
+ 'Русский Банк Сбережений',
+ 'Русский Ипотечный Банк',
+ 'Русский Международный Банк',
+ 'Русский Национальный Банк',
+ 'Русский Стандарт',
+ 'Русский Торговый Банк',
+ 'Русский Трастовый Банк',
+ 'Русский Финансовый Альянс',
+ 'Русский Элитарный Банк',
+ 'Русславбанк',
+ 'Руссобанк',
+ 'Русстройбанк',
+ 'Русфинанс Банк',
+ 'Русь',
+ 'РусьРегионБанк',
+ 'Русьуниверсалбанк',
+ 'РусЮгбанк',
+ 'РФИ Банк',
+ 'Саммит Банк',
+ 'Санкт-Петербургский Банк Инвестиций',
+ 'Саратов',
+ 'Саровбизнесбанк',
+ 'Сбербанк России',
+ 'Связной Банк',
+ 'Связь-Банк',
+ 'СДМ-Банк',
+ 'Севастопольский Морской банк',
+ 'Северный Кредит',
+ 'Северный Народный Банк',
+ 'Северо-Восточный Альянс',
+ 'Северо-Западный 1 Альянс Банк',
+ 'Северстройбанк',
+ 'Севзапинвестпромбанк',
+ 'Сельмашбанк',
+ 'Сервис-Резерв',
+ 'Сетелем Банк',
+ 'СИАБ',
+ 'Сибирский Банк Реконструкции и Развития',
+ 'Сибнефтебанк',
+ 'Сибсоцбанк',
+ 'Сибэс',
+ 'Сибэс Московский офис',
+ 'Синергия',
+ 'Синко-Банк',
+ 'Система',
+ 'Сити Инвест Банк',
+ 'Ситибанк',
+ 'СКА-Банк',
+ 'СКБ-Банк',
+ 'Славия',
+ 'Славянбанк',
+ 'Славянский Кредит',
+ 'Смартбанк',
+ 'СМБ-Банк',
+ 'Смолевич',
+ 'СМП Банк',
+ 'Снежинский',
+ 'Собинбанк',
+ 'Соверен Банк',
+ 'Советский',
+ 'Совкомбанк',
+ 'Современные Стандарты Бизнеса',
+ 'Содружество',
+ 'Соколовский',
+ 'Солид Банк',
+ 'Солидарность (Москва)',
+ 'Солидарность (Самара)',
+ 'Социнвестбанк',
+ 'Социнвестбанк Московский филиал',
+ 'Социум-Банк',
+ 'Союз',
+ 'Союзный',
+ 'Спецстройбанк',
+ 'Спиритбанк',
+ 'Спурт Банк',
+ 'Спутник',
+ 'Ставропольпромстройбанк',
+ 'Сталь Банк',
+ 'Стандарт-Кредит',
+ 'Стар Альянс',
+ 'СтарБанк',
+ 'Старооскольский Агропромбанк',
+ 'Старый Кремль',
+ 'Стелла-Банк',
+ 'Столичный Кредит',
+ 'Стратегия',
+ 'Строительно-Коммерческий Банк',
+ 'Стройлесбанк',
+ 'Сумитомо Мицуи',
+ 'Сургутнефтегазбанк',
+ 'СЭБ Банк',
+ 'Таатта',
+ 'Таврический',
+ 'Таганрогбанк',
+ 'Тагилбанк',
+ 'Тайдон',
+ 'Тайм Банк',
+ 'Тальменка-Банк',
+ 'Тальменка-Банк Московский филиал',
+ 'Тамбовкредитпромбанк',
+ 'Татагропромбанк',
+ 'Татсоцбанк',
+ 'Татфондбанк',
+ 'Таурус Банк',
+ 'ТверьУниверсалБанк',
+ 'Тексбанк',
+ 'Темпбанк',
+ 'Тендер-Банк',
+ 'Терра',
+ 'Тетраполис',
+ 'Тимер Банк',
+ 'Тинькофф Банк',
+ 'Тихоокеанский Внешторгбанк',
+ 'Тойота Банк',
+ 'Тольяттихимбанк',
+ 'Томскпромстройбанк',
+ 'Торгово-Промышленный Банк Китая',
+ 'Торговый Городской Банк',
+ 'Торжокуниверсалбанк',
+ 'Транскапиталбанк',
+ 'Транснациональный Банк',
+ 'Транспортный',
+ 'Трансстройбанк',
+ 'Траст Капитал Банк',
+ 'Тройка-Д Банк',
+ 'Тульский Промышленник',
+ 'Тульский Промышленник Московский офис',
+ 'Тульский Расчетный Центр',
+ 'Турбобанк',
+ 'Тусар',
+ 'ТЭМБР-Банк',
+ 'ТЭСТ',
+ 'Углеметбанк',
+ 'Уздан',
+ 'Унифин',
+ 'Унифондбанк',
+ 'Уралкапиталбанк',
+ 'Уралприватбанк',
+ 'Уралпромбанк',
+ 'Уралсиб',
+ 'Уралтрансбанк',
+ 'Уралфинанс',
+ 'Уральский Банк Реконструкции и Развития',
+ 'Уральский Межрегиональный Банк',
+ 'Уральский Финансовый Дом',
+ 'Ури Банк',
+ 'Уссури',
+ 'ФДБ',
+ 'ФИА-Банк',
+ 'Финам Банк',
+ 'Финанс Бизнес Банк',
+ 'Финансово-Промышленный Капитал',
+ 'Финансовый Капитал',
+ 'Финансовый Стандарт',
+ 'Финарс Банк',
+ 'Финпромбанк (ФПБ Банк)',
+ 'Финтрастбанк',
+ 'ФК Открытие (бывш. НОМОС-Банк)',
+ 'Флора-Москва',
+ 'Фольксваген Банк Рус',
+ 'Фондсервисбанк',
+ 'Фора-Банк',
+ 'Форбанк',
+ 'Форус Банк',
+ 'Форштадт',
+ 'Фьючер',
+ 'Хакасский Муниципальный Банк',
+ 'Ханты-Мансийский банк Открытие',
+ 'Химик',
+ 'Хлынов',
+ 'Хованский',
+ 'Холдинвестбанк',
+ 'Холмск',
+ 'Хоум Кредит Банк',
+ 'Центр-инвест',
+ 'Центрально-Азиатский',
+ 'Центрально-Европейский Банк',
+ 'Центркомбанк',
+ 'ЦентроКредит',
+ 'Церих',
+ 'Чайна Констракшн',
+ 'Чайнасельхозбанк',
+ 'Челиндбанк',
+ 'Челябинвестбанк',
+ 'Черноморский банк развития и реконструкции',
+ 'Чувашкредитпромбанк',
+ 'Эйч-Эс-Би-Си Банк (HSBC)',
+ 'Эко-Инвест',
+ 'Экономбанк',
+ 'Экономикс-Банк',
+ 'Экси-Банк',
+ 'Эксперт Банк',
+ 'Экспобанк',
+ 'Экспресс-Волга',
+ 'Экспресс-Кредит',
+ 'Эл Банк',
+ 'Элита',
+ 'Эльбин',
+ 'Энергобанк',
+ 'Энергомашбанк',
+ 'Энерготрансбанк',
+ 'Эно',
+ 'Энтузиастбанк',
+ 'Эргобанк',
+ 'Ю Би Эс Банк',
+ 'ЮГ-Инвестбанк',
+ 'Югра',
+ 'Южный Региональный Банк',
+ 'ЮМК',
+ 'Юниаструм Банк',
+ 'ЮниКредит Банк',
+ 'Юнистрим',
+ 'Япы Креди Банк Москва',
+ 'ЯР-Банк',
+ 'Яринтербанк',
+ 'Ярославич',
+ 'K2 Банк',
+ 'АББ',
+ 'Абсолют Банк',
+ 'Авангард',
+ 'Аверс',
+ 'Автоградбанк',
+ 'АвтоКредитБанк',
+ 'Автоторгбанк',
+ 'Агроинкомбанк',
+ 'Агропромкредит',
+ 'Агророс',
+ 'Агросоюз',
+ 'Адамон Банк',
+ 'Адамон Банк Московский филиал',
+ 'Аделантбанк',
+ 'Адмиралтейский',
+ 'Азиатско-Тихоокеанский Банк',
+ 'Азимут',
+ 'Азия Банк',
+ 'Азия-Инвест Банк',
+ 'Ай-Си-Ай-Си-Ай Банк (ICICI)',
+ 'Айви Банк',
+ 'АйМаниБанк',
+ 'Ак Барс',
+ 'Акибанк',
+ 'Аккобанк',
+ 'Акрополь',
+ 'Аксонбанк',
+ 'Актив Банк',
+ 'АктивКапитал Банк',
+ 'АктивКапитал Банк Московский филиал',
+ 'АктивКапитал Банк Санкт-Петербургский филиал',
+ 'Акцент',
+ 'Акцепт',
+ 'Акция',
+ 'Алданзолотобанк',
+ 'Александровский',
+ 'Алеф-Банк',
+ 'Алжан',
+ 'Алмазэргиэнбанк',
+ 'АлтайБизнес-Банк',
+ 'Алтайкапиталбанк',
+ 'Алтынбанк',
+ 'Альба Альянс',
+ 'Альта-Банк',
+ 'Альтернатива',
+ 'Альфа-Банк',
+ 'АМБ Банк',
+ 'Америкэн Экспресс Банк',
+ 'Анелик РУ',
+ 'Анкор Банк',
+ 'Анталбанк',
+ 'Апабанк',
+ 'Аресбанк',
+ 'Арзамас',
+ 'Арксбанк',
+ 'Арсенал',
+ 'Аспект',
+ 'Ассоциация',
+ 'БайкалБанк',
+ 'БайкалИнвестБанк',
+ 'Байкалкредобанк',
+ 'Балаково-Банк',
+ 'Балтийский Банк',
+ 'Балтика',
+ 'Балтинвестбанк',
+ 'Банк "Акцент" Московский филиал',
+ 'Банк "МБА-Москва"',
+ 'Банк "Санкт-Петербург"',
+ 'Банк АВБ',
+ 'Банк БКФ',
+ 'Банк БФА',
+ 'Банк БЦК-Москва',
+ 'Банк Город',
+ 'Банк Жилищного Финансирования',
+ 'Банк Инноваций и Развития',
+ 'Банк Интеза',
+ 'Банк ИТБ',
+ 'Банк Казани',
+ 'Банк Китая (Элос)',
+ 'Банк Кредит Свисс',
+ 'Банк МБФИ',
+ 'Банк Москвы',
+ 'Банк на Красных Воротах',
+ 'Банк Оранжевый (бывш. Промсервисбанк)',
+ 'Банк оф Токио-Мицубиси',
+ 'Банк Премьер Кредит',
+ 'Банк ПСА Финанс Рус',
+ 'Банк Развития Технологий',
+ 'Банк Расчетов и Сбережений',
+ 'Банк Раунд',
+ 'Банк РСИ',
+ 'Банк Сберегательно-кредитного сервиса',
+ 'Банк СГБ',
+ 'Банк Торгового Финансирования',
+ 'Банк Финсервис',
+ 'Банк Экономический Союз',
+ 'Банкирский Дом',
+ 'Банкхаус Эрбе',
+ 'Башкомснаббанк',
+ 'Башпромбанк',
+ 'ББР Банк',
+ 'Белгородсоцбанк',
+ 'Бенифит-Банк',
+ 'Берейт',
+ 'Бест Эффортс Банк',
+ 'Бизнес для Бизнеса',
+ 'Бинбанк',
+ 'БИНБАНК кредитные карты',
+ 'Бинбанк Мурманск',
+ 'БКС Инвестиционный Банк',
+ 'БМВ Банк',
+ 'БНП Париба Банк',
+ 'Богородский',
+ 'Богородский Муниципальный Банк',
+ 'Братский АНКБ',
+ 'БСТ-Банк',
+ 'Булгар Банк',
+ 'Бум-Банк',
+ 'Бумеранг',
+ 'БФГ-Кредит',
+ 'БыстроБанк',
+ 'Вакобанк',
+ 'Вега-Банк',
+ 'Век',
+ 'Великие Луки Банк',
+ 'Венец',
+ 'Верхневолжский',
+ 'Верхневолжский Крымский филиал',
+ 'Верхневолжский Московский филиал',
+ 'Верхневолжский Невский филиал',
+ 'Верхневолжский Таврический филиал',
+ 'Верхневолжский Ярославский филиал',
+ 'Веста',
+ 'Вестинтербанк',
+ 'Взаимодействие',
+ 'Викинг',
+ 'Витабанк',
+ 'Витязь',
+ 'Вкабанк',
+ 'Владбизнесбанк',
+ 'Владпромбанк',
+ 'Внешпромбанк',
+ 'Внешфинбанк',
+ 'Внешэкономбанк',
+ 'Военно-Промышленный Банк',
+ 'Возрождение',
+ 'Вокбанк',
+ 'Вологдабанк',
+ 'Вологжанин',
+ 'Воронеж',
+ 'Восточно-Европейский Трастовый Банк',
+ 'Восточный Экспресс Банк',
+ 'ВостСибтранскомбанк',
+ 'ВРБ Москва',
+ 'Всероссийский Банк Развития Регионов',
+ 'ВТБ',
+ 'ВТБ 24',
+ 'ВУЗ-Банк',
+ 'Выборг-Банк',
+ 'Выборг-Банк Московский филиал',
+ 'Вэлтон Банк',
+ 'Вятич',
+ 'Вятка-Банк',
+ 'Гагаринский',
+ 'Газбанк',
+ 'Газнефтьбанк',
+ 'Газпромбанк',
+ 'Газстройбанк',
+ 'Газтрансбанк',
+ 'Газэнергобанк',
+ 'Ганзакомбанк',
+ 'Гарант-Инвест',
+ 'Гаранти Банк Москва',
+ 'Геленджик-Банк',
+ 'Генбанк',
+ 'Геобанк',
+ 'Гефест',
+ 'Глобус',
+ 'Глобэкс',
+ 'Голдман Сакс Банк',
+ 'Горбанк',
+ 'ГПБ-Ипотека',
+ 'Гранд Инвест Банк',
+ 'Гринкомбанк',
+ 'Гринфилдбанк',
+ 'Грис-Банк',
+ 'Гута-Банк',
+ 'Далена',
+ 'Далетбанк',
+ 'Далта-Банк',
+ 'Дальневосточный Банк',
+ 'Данске Банк',
+ 'Девон-Кредит',
+ 'ДельтаКредит',
+ 'Денизбанк Москва',
+ 'Держава',
+ 'Дж. П. Морган Банк',
+ 'Джаст Банк',
+ 'Джей энд Ти Банк',
+ 'Дил-Банк',
+ 'Динамичные Системы',
+ 'Дойче Банк',
+ 'Долинск',
+ 'Дом-Банк',
+ 'Дон-Тексбанк',
+ 'Донкомбанк',
+ 'Донхлеббанк',
+ 'Дорис Банк',
+ 'Дружба',
+ 'ЕАТП Банк',
+ 'Евразийский Банк',
+ 'Евроазиатский Инвестиционный Банк',
+ 'ЕвроАксис Банк',
+ 'Евроальянс',
+ 'Еврокапитал-Альянс',
+ 'Еврокоммерц',
+ 'Еврокредит',
+ 'Евромет',
+ 'Европейский Стандарт',
+ 'Европлан Банк',
+ 'ЕвроситиБанк',
+ 'Еврофинанс Моснарбанк',
+ 'Единственный',
+ 'Единый Строительный Банк',
+ 'Екатеринбург',
+ 'Екатерининский',
+ 'Енисей',
+ 'Енисейский Объединенный Банк',
+ 'Ермак',
+ 'Живаго-Банк',
+ 'Жилкредит',
+ 'Жилстройбанк',
+ 'Запсибкомбанк',
+ 'Заречье',
+ 'Заубер Банк',
+ 'Земкомбанк',
+ 'Земский Банк',
+ 'Зенит',
+ 'Зенит Сочи',
+ 'Зернобанк',
+ 'Зираат Банк',
+ 'Златкомбанк',
+ 'И.Д.Е.А. Банк',
+ 'Иваново',
+ 'Идеалбанк',
+ 'Ижкомбанк',
+ 'ИК Банк',
+ 'Икано Банк',
+ 'Инбанк',
+ 'Инвест-Экобанк',
+ 'Инвестиционный Банк Кубани',
+ 'Инвестиционный Республиканский Банк',
+ 'Инвестиционный Союз',
+ 'Инвесткапиталбанк',
+ 'Инвестсоцбанк',
+ 'Инвестторгбанк',
+ 'ИНГ Банк',
+ 'Индустриальный Сберегательный Банк',
+ 'Инкаробанк',
+ 'Интерактивный Банк',
+ 'Интеркоммерц Банк',
+ 'Интеркоопбанк',
+ 'Интеркредит',
+ 'Интернациональный Торговый Банк',
+ 'Интерпрогрессбанк',
+ 'Интерпромбанк',
+ 'Интехбанк',
+ 'Информпрогресс',
+ 'Ипозембанк',
+ 'ИпоТек Банк',
+ 'Иронбанк',
+ 'ИРС',
+ 'Итуруп',
+ 'Ишбанк',
+ 'Йошкар-Ола',
+ 'Калуга',
+ 'Камский Горизонт',
+ 'Камский Коммерческий Банк',
+ 'Камчаткомагропромбанк',
+ 'Канский',
+ 'Капитал',
+ 'Капиталбанк',
+ 'Кедр',
+ 'Кемсоцинбанк',
+ 'Кетовский Коммерческий Банк',
+ 'Киви Банк',
+ 'Классик Эконом Банк',
+ 'Клиентский',
+ 'Кольцо Урала',
+ 'Коммерцбанк (Евразия)',
+ 'Коммерческий Банк Развития',
+ 'Коммерческий Индо Банк',
+ 'Консервативный Коммерческий Банк',
+ 'Констанс-Банк',
+ 'Континенталь',
+ 'Конфидэнс Банк',
+ 'Кор',
+ 'Кореа Эксчендж Банк Рус',
+ 'Королевский Банк Шотландии',
+ 'Космос',
+ 'Костромаселькомбанк',
+ 'Кошелев-Банк',
+ 'Крайинвестбанк',
+ 'Кранбанк',
+ 'Креди Агриколь КИБ',
+ 'Кредит Европа Банк',
+ 'Кредит Урал Банк',
+ 'Кредит Экспресс',
+ 'Кредит-Москва',
+ 'Кредитинвест',
+ 'Кредо Финанс',
+ 'Кредпромбанк',
+ 'Кремлевский',
+ 'Крокус-Банк',
+ 'Крона-Банк',
+ 'Кросна-Банк',
+ 'Кроссинвестбанк',
+ 'Крыловский',
+ 'КС Банк',
+ 'Кубанский Универсальный Банк',
+ 'Кубань Кредит',
+ 'Кубаньторгбанк',
+ 'Кузбассхимбанк',
+ 'Кузнецкбизнесбанк',
+ 'Кузнецкий',
+ 'Кузнецкий Мост',
+ 'Курган',
+ 'Курскпромбанк',
+ 'Лада-Кредит',
+ 'Лайтбанк',
+ 'Ланта-Банк',
+ 'Левобережный',
+ 'Легион',
+ 'Леноблбанк',
+ 'Лесбанк',
+ 'Лето Банк',
+ 'Липецккомбанк',
+ 'Логос',
+ 'Локо-Банк',
+ 'Лэнд-Банк',
+ 'М2М Прайвет Банк',
+ 'Майкопбанк',
+ 'Майский',
+ 'МАК-Банк',
+ 'Максима',
+ 'Максимум',
+ 'МАСТ-Банк',
+ 'Мастер-Капитал',
+ 'МВС Банк',
+ 'МДМ Банк',
+ 'Мегаполис',
+ 'Международный Акционерный Банк',
+ 'Международный Банк Развития',
+ 'Международный Банк Санкт-Петербурга (МБСП)',
+ 'Международный Коммерческий Банк',
+ 'Международный Расчетный Банк',
+ 'Международный Строительный Банк',
+ 'Международный Финансовый Клуб',
+ 'Межотраслевая Банковская Корпорация',
+ 'Межрегиональный Банк Реконструкции',
+ 'Межрегиональный Клиринговый Банк',
+ 'Межрегиональный Почтовый Банк',
+ 'Межрегиональный промышленно-строительный банк',
+ 'Межрегионбанк',
+ 'Межтопэнергобанк',
+ 'Межтрастбанк',
+ 'Мерседес-Бенц Банк Рус',
+ 'Металлинвестбанк',
+ 'Металлург',
+ 'Меткомбанк (Каменск-Уральский)',
+ 'Меткомбанк (Череповец)',
+ 'Метробанк',
+ 'Метрополь',
+ 'Мидзухо Банк',
+ 'Мико-Банк',
+ 'Милбанк',
+ 'Миллениум Банк',
+ 'Мир Бизнес Банк',
+ 'Мираф-Банк',
+ 'Мираф-Банк Московский филиал',
+ 'Миръ',
+ 'Михайловский ПЖСБ',
+ 'Морган Стэнли Банк',
+ 'Морской Банк',
+ 'Мосводоканалбанк',
+ 'Москва',
+ 'Москва-Сити',
+ 'Московский Вексельный Банк',
+ 'Московский Индустриальный Банк',
+ 'Московский Коммерческий Банк',
+ 'Московский Кредитный Банк',
+ 'Московский Национальный Инвестиционный Банк',
+ 'Московский Нефтехимический Банк',
+ 'Московский Областной Банк',
+ 'Московско-Парижский Банк',
+ 'Московское Ипотечное Агентство',
+ 'Москоммерцбанк',
+ 'Мосстройэкономбанк (М Банк)',
+ 'Мострансбанк',
+ 'Мосуралбанк',
+ 'МС Банк Рус',
+ 'МСП Банк',
+ 'МТИ-Банк',
+ 'МТС Банк',
+ 'Муниципальный Камчатпрофитбанк',
+ 'Мурманский Социальный Коммерческий Банк',
+ 'МФБанк',
+ 'Н-Банк',
+ 'Нальчик',
+ 'Наратбанк',
+ 'Народный Банк',
+ 'Народный Банк Республики Тыва',
+ 'Народный Доверительный Банк',
+ 'Народный Земельно-Промышленный Банк',
+ 'Народный Инвестиционный Банк',
+ 'Натиксис Банк',
+ 'Нацинвестпромбанк',
+ 'Национальная Факторинговая Компания',
+ 'Национальный Банк "Траст"',
+ 'Национальный Банк Взаимного Кредита',
+ 'Национальный Банк Сбережений',
+ 'Национальный Залоговый Банк',
+ 'Национальный Клиринговый Банк',
+ 'Национальный Клиринговый Центр',
+ 'Национальный Корпоративный Банк',
+ 'Национальный Резервный Банк',
+ 'Национальный Стандарт',
+ 'Наш Дом',
+ 'НБД-Банк',
+ 'НБК-Банк',
+ 'Невастройинвест',
+ 'Невский Банк',
+ 'Нейва',
+ 'Нерюнгрибанк',
+ 'Нефтепромбанк',
+ 'Нефтяной Альянс',
+ 'Нижневолжский Коммерческий Банк',
+ 'Нико-Банк',
+ 'НК Банк',
+ 'НоваховКапиталБанк',
+ 'Новация',
+ 'Новикомбанк',
+ 'Новобанк',
+ 'Новое Время',
+ 'Новокиб',
+ 'Новопокровский',
+ 'Новый Век',
+ 'Новый Кредитный Союз',
+ 'Новый Московский Банк',
+ ];
+
+ /**
+ * @example 'Новый Московский Банк'
+ */
+ public static function bank()
+ {
+ return static::randomElement(static::$banks);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ru_RU/Person.php b/vendor/fakerphp/faker/src/Faker/Provider/ru_RU/Person.php
new file mode 100644
index 00000000..b451603c
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ru_RU/Person.php
@@ -0,0 +1,179 @@
+middleNameMale();
+ } elseif ($gender === static::GENDER_FEMALE) {
+ return $this->middleNameFemale();
+ }
+
+ return $this->middleName(static::randomElement([
+ static::GENDER_MALE,
+ static::GENDER_FEMALE,
+ ]));
+ }
+
+ /**
+ * Return last name for the specified gender.
+ *
+ * @param string|null $gender A gender of the last name should be generated
+ * for. If the argument is skipped a random gender will be used.
+ * @return string Last name
+ */
+ public function lastName($gender = null)
+ {
+ $lastName = static::randomElement(static::$lastName);
+
+ if (static::GENDER_FEMALE === $gender) {
+ return $lastName . 'а';
+ } elseif (static::GENDER_MALE === $gender) {
+ return $lastName;
+ }
+
+ return $lastName . static::randomElement(static::$lastNameSuffix);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/ru_RU/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/ru_RU/PhoneNumber.php
new file mode 100644
index 00000000..06f63373
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/ru_RU/PhoneNumber.php
@@ -0,0 +1,14 @@
+generator->parse(static::randomElement(static::$lastNameFormat));
+ }
+
+ public static function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ public static function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+
+ /**
+ * @example 'PhD'
+ */
+ public static function suffix()
+ {
+ return static::randomElement(static::$suffix);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/sk_SK/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/sk_SK/PhoneNumber.php
new file mode 100644
index 00000000..bd195e4f
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/sk_SK/PhoneNumber.php
@@ -0,0 +1,15 @@
+format('ymd');
+
+ if ($gender && $gender == static::GENDER_MALE) {
+ $randomDigits = (string) static::numerify('##') . static::randomElement([1, 3, 5, 7, 9]);
+ } elseif ($gender && $gender == static::GENDER_FEMALE) {
+ $randomDigits = (string) static::numerify('##') . static::randomElement([0, 2, 4, 6, 8]);
+ } else {
+ $randomDigits = (string) static::numerify('###');
+ }
+
+
+ $checksum = Luhn::computeCheckDigit($datePart . $randomDigits);
+
+ return $datePart . '-' . $randomDigits . $checksum;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/sv_SE/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/sv_SE/PhoneNumber.php
new file mode 100644
index 00000000..01cf15d9
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/sv_SE/PhoneNumber.php
@@ -0,0 +1,37 @@
+format('a') === 'am' ? 'öö' : 'ös';
+ }
+
+ public static function dayOfWeek($max = 'now')
+ {
+ $map = [
+ 'Sunday' => 'Pazar',
+ 'Monday' => 'Pazartesi',
+ 'Tuesday' => 'Salı',
+ 'Wednesday' => 'Çarşamba',
+ 'Thursday' => 'Perşembe',
+ 'Friday' => 'Cuma',
+ 'Saturday' => 'Cumartesi',
+ ];
+ $week = static::dateTime($max)->format('l');
+ return $map[$week] ?? $week;
+ }
+
+ public static function monthName($max = 'now')
+ {
+ $map = [
+ 'January' => 'Ocak',
+ 'February' => 'Şubat',
+ 'March' => 'Mart',
+ 'April' => 'Nisan',
+ 'May' => 'Mayıs',
+ 'June' => 'Haziran',
+ 'July' => 'Temmuz',
+ 'August' => 'Ağustos',
+ 'September' => 'Eylül',
+ 'October' => 'Ekim',
+ 'November' => 'Kasım',
+ 'December' => 'Aralık',
+ ];
+ $month = static::dateTime($max)->format('F');
+ return $map[$month] ?? $month;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/tr_TR/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/tr_TR/Internet.php
new file mode 100644
index 00000000..9d821119
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/tr_TR/Internet.php
@@ -0,0 +1,9 @@
+generator->parse($format);
+ }
+
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/uk_UA/Color.php b/vendor/fakerphp/faker/src/Faker/Provider/uk_UA/Color.php
new file mode 100644
index 00000000..203be52e
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/uk_UA/Color.php
@@ -0,0 +1,23 @@
+generator->parse($format);
+ }
+
+ public static function companyPrefix()
+ {
+ return static::randomElement(static::$companyPrefix);
+ }
+
+ public static function companyName()
+ {
+ return static::randomElement(static::$companyName);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/uk_UA/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/uk_UA/Internet.php
new file mode 100644
index 00000000..61193547
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/uk_UA/Internet.php
@@ -0,0 +1,9 @@
+middleNameMale();
+ } elseif ($gender === static::GENDER_FEMALE) {
+ return $this->middleNameFemale();
+ }
+
+ return $this->middleName(static::randomElement([
+ static::GENDER_MALE,
+ static::GENDER_FEMALE,
+ ]));
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/uk_UA/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/uk_UA/PhoneNumber.php
new file mode 100644
index 00000000..d04989d4
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/uk_UA/PhoneNumber.php
@@ -0,0 +1,51 @@
+generator->parse($format));
+ }
+
+ public function hamletPrefix()
+ {
+ return static::randomElement(static::$hamletPrefix);
+ }
+
+ public function wardName()
+ {
+ $format = static::randomElement(static::$wardNameFormats);
+
+ return static::bothify($this->generator->parse($format));
+ }
+
+ public function wardPrefix()
+ {
+ return static::randomElement(static::$wardPrefix);
+ }
+
+ public function districtName()
+ {
+ $format = static::randomElement(static::$districtNameFormats);
+
+ return static::bothify($this->generator->parse($format));
+ }
+
+ public function districtPrefix()
+ {
+ return static::randomElement(static::$districtPrefix);
+ }
+
+ /**
+ * @example 'Hà Nội'
+ */
+ public function city()
+ {
+ return static::randomElement(static::$city);
+ }
+
+ /**
+ * @example 'Bắc Giang'
+ */
+ public static function province()
+ {
+ return static::randomElement(static::$province);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/vi_VN/Color.php b/vendor/fakerphp/faker/src/Faker/Provider/vi_VN/Color.php
new file mode 100644
index 00000000..df788550
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/vi_VN/Color.php
@@ -0,0 +1,36 @@
+generator->parse(static::randomElement(static::$middleNameFormat));
+ }
+
+ public static function middleNameMale()
+ {
+ return static::randomElement(static::$middleNameMale);
+ }
+
+ public static function middleNameFemale()
+ {
+ return static::randomElement(static::$middleNameFemale);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/vi_VN/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/vi_VN/PhoneNumber.php
new file mode 100644
index 00000000..a6f47f15
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/vi_VN/PhoneNumber.php
@@ -0,0 +1,61 @@
+ [
+ '0[a] ### ####',
+ '(0[a]) ### ####',
+ '0[a]-###-####',
+ '(0[a])###-####',
+ '84-[a]-###-####',
+ '(84)([a])###-####',
+ '+84-[a]-###-####',
+ ],
+ '8' => [
+ '0[a] #### ####',
+ '(0[a]) #### ####',
+ '0[a]-####-####',
+ '(0[a])####-####',
+ '84-[a]-####-####',
+ '(84)([a])####-####',
+ '+84-[a]-####-####',
+ ],
+ ];
+
+ public function phoneNumber()
+ {
+ $areaCode = static::randomElement(static::$areaCodes);
+ $areaCodeLength = strlen($areaCode);
+ $digits = 7;
+
+ if ($areaCodeLength < 2) {
+ $digits = 8;
+ }
+
+ return static::numerify(str_replace('[a]', $areaCode, static::randomElement(static::$formats[$digits])));
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/zh_CN/Address.php b/vendor/fakerphp/faker/src/Faker/Provider/zh_CN/Address.php
new file mode 100644
index 00000000..9fe31913
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/zh_CN/Address.php
@@ -0,0 +1,148 @@
+city() . static::area();
+ }
+
+ public static function postcode()
+ {
+ $prefix = str_pad(self::numberBetween(1, 85), 2, 0, STR_PAD_LEFT);
+ $suffix = '00';
+
+ return $prefix . self::numberBetween(10, 88) . $suffix;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/zh_CN/Color.php b/vendor/fakerphp/faker/src/Faker/Provider/zh_CN/Color.php
new file mode 100644
index 00000000..e8596e77
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/zh_CN/Color.php
@@ -0,0 +1,66 @@
+format('a') === 'am' ? '上午' : '下午';
+ }
+
+ public static function dayOfWeek($max = 'now')
+ {
+ $map = [
+ 'Sunday' => '星期日',
+ 'Monday' => '星期一',
+ 'Tuesday' => '星期二',
+ 'Wednesday' => '星期三',
+ 'Thursday' => '星期四',
+ 'Friday' => '星期五',
+ 'Saturday' => '星期六',
+ ];
+ $week = static::dateTime($max)->format('l');
+ return $map[$week] ?? $week;
+ }
+
+ public static function monthName($max = 'now')
+ {
+ $map = [
+ 'January' => '一月',
+ 'February' => '二月',
+ 'March' => '三月',
+ 'April' => '四月',
+ 'May' => '五月',
+ 'June' => '六月',
+ 'July' => '七月',
+ 'August' => '八月',
+ 'September' => '九月',
+ 'October' => '十月',
+ 'November' => '十一月',
+ 'December' => '十二月',
+ ];
+ $month = static::dateTime($max)->format('F');
+ return $map[$month] ?? $month;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/zh_CN/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/zh_CN/Internet.php
new file mode 100644
index 00000000..6227579f
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/zh_CN/Internet.php
@@ -0,0 +1,24 @@
+ [
+ '板橋區', '三重區', '中和區', '永和區',
+ '新莊區', '新店區', '樹林區', '鶯歌區',
+ '三峽區', '淡水區', '汐止區', '瑞芳區',
+ '土城區', '蘆洲區', '五股區', '泰山區',
+ '林口區', '深坑區', '石碇區', '坪林區',
+ '三芝區', '石門區', '八里區', '平溪區',
+ '雙溪區', '貢寮區', '金山區', '萬里區',
+ '烏來區',
+ ],
+ '宜蘭縣' => [
+ '宜蘭市', '羅東鎮', '蘇澳鎮', '頭城鎮', '礁溪鄉',
+ '壯圍鄉', '員山鄉', '冬山鄉', '五結鄉', '三星鄉',
+ '大同鄉', '南澳鄉',
+ ],
+ '桃園市' => [
+ '桃園區', '中壢區', '大溪區', '楊梅區', '蘆竹區',
+ '大園區', '龜山區', '八德區', '龍潭區', '平鎮區',
+ '新屋區', '觀音區', '復興區',
+ ],
+ '新竹縣' => [
+ '竹北市', '竹東鎮', '新埔鎮', '關西鎮', '湖口鄉',
+ '新豐鄉', '芎林鄉', '橫山鄉', '北埔鄉', '寶山鄉',
+ '峨眉鄉', '尖石鄉', '五峰鄉',
+ ],
+ '苗栗縣' => [
+ '苗栗市', '苑裡鎮', '通霄鎮', '竹南鎮', '頭份鎮',
+ '後龍鎮', '卓蘭鎮', '大湖鄉', '公館鄉', '銅鑼鄉',
+ '南庄鄉', '頭屋鄉', '三義鄉', '西湖鄉', '造橋鄉',
+ '三灣鄉', '獅潭鄉', '泰安鄉',
+ ],
+ '臺中市' => [
+ '豐原區', '東勢區', '大甲區', '清水區', '沙鹿區',
+ '梧棲區', '后里區', '神岡區', '潭子區', '大雅區',
+ '新社區', '石岡區', '外埔區', '大安區', '烏日區',
+ '大肚區', '龍井區', '霧峰區', '太平區', '大里區',
+ '和平區', '中區', '東區', '南區', '西區', '北區',
+ '西屯區', '南屯區', '北屯區',
+ ],
+ '彰化縣' => [
+ '彰化市', '鹿港鎮', '和美鎮', '線西鄉', '伸港鄉',
+ '福興鄉', '秀水鄉', '花壇鄉', '芬園鄉', '員林鎮',
+ '溪湖鎮', '田中鎮', '大村鄉', '埔鹽鄉', '埔心鄉',
+ '永靖鄉', '社頭鄉', '二水鄉', '北斗鎮', '二林鎮',
+ '田尾鄉', '埤頭鄉', '芳苑鄉', '大城鄉', '竹塘鄉',
+ '溪州鄉',
+ ],
+ '南投縣' => [
+ '南投市', '埔里鎮', '草屯鎮', '竹山鎮', '集集鎮',
+ '名間鄉', '鹿谷鄉', '中寮鄉', '魚池鄉', '國姓鄉',
+ '水里鄉', '信義鄉', '仁愛鄉',
+ ],
+ '雲林縣' => [
+ '斗六市', '斗南鎮', '虎尾鎮', '西螺鎮', '土庫鎮',
+ '北港鎮', '古坑鄉', '大埤鄉', '莿桐鄉', '林內鄉',
+ '二崙鄉', '崙背鄉', '麥寮鄉', '東勢鄉', '褒忠鄉',
+ '臺西鄉', '元長鄉', '四湖鄉', '口湖鄉', '水林鄉',
+ ],
+ '嘉義縣' => [
+ '太保市', '朴子市', '布袋鎮', '大林鎮', '民雄鄉',
+ '溪口鄉', '新港鄉', '六腳鄉', '東石鄉', '義竹鄉',
+ '鹿草鄉', '水上鄉', '中埔鄉', '竹崎鄉', '梅山鄉',
+ '番路鄉', '大埔鄉', '阿里山鄉',
+ ],
+ '臺南市' => [
+ '新營區', '鹽水區', '白河區', '柳營區', '後壁區',
+ '東山區', '麻豆區', '下營區', '六甲區', '官田區',
+ '大內區', '佳里區', '學甲區', '西港區', '七股區',
+ '將軍區', '北門區', '新化區', '善化區', '新市區',
+ '安定區', '山上區', '玉井區', '楠西區', '南化區',
+ '左鎮區', '仁德區', '歸仁區', '關廟區', '龍崎區',
+ '永康區', '東區', '南區', '西區', '北區', '中區',
+ '安南區', '安平區',
+ ],
+ '高雄市' => [
+ '鳳山區', '林園區', '大寮區', '大樹區', '大社區',
+ '仁武區', '鳥松區', '岡山區', '橋頭區', '燕巢區',
+ '田寮區', '阿蓮區', '路竹區', '湖內區', '茄萣區',
+ '永安區', '彌陀區', '梓官區', '旗山區', '美濃區',
+ '六龜區', '甲仙區', '杉林區', '內門區', '茂林區',
+ '桃源區', '三民區', '鹽埕區', '鼓山區', '左營區',
+ '楠梓區', '三民區', '新興區', '前金區', '苓雅區',
+ '前鎮區', '旗津區', '小港區',
+ ],
+ '屏東縣' => [
+ '屏東市', '潮州鎮', '東港鎮', '恆春鎮', '萬丹鄉',
+ '長治鄉', '麟洛鄉', '九如鄉', '里港鄉', '鹽埔鄉',
+ '高樹鄉', '萬巒鄉', '內埔鄉', '竹田鄉', '新埤鄉',
+ '枋寮鄉', '新園鄉', '崁頂鄉', '林邊鄉', '南州鄉',
+ '佳冬鄉', '琉球鄉', '車城鄉', '滿州鄉', '枋山鄉',
+ '三地門鄉', '霧臺鄉', '瑪家鄉', '泰武鄉', '來義鄉',
+ '春日鄉', '獅子鄉', '牡丹鄉',
+ ],
+ '臺東縣' => [
+ '臺東市', '成功鎮', '關山鎮', '卑南鄉', '鹿野鄉',
+ '池上鄉', '東河鄉', '長濱鄉', '太麻里鄉', '大武鄉',
+ '綠島鄉', '海端鄉', '延平鄉', '金峰鄉', '達仁鄉',
+ '蘭嶼鄉',
+ ],
+ '花蓮縣' => [
+ '花蓮市', '鳳林鎮', '玉里鎮', '新城鄉', '吉安鄉',
+ '壽豐鄉', '光復鄉', '豐濱鄉', '瑞穗鄉', '富里鄉',
+ '秀林鄉', '萬榮鄉', '卓溪鄉',
+ ],
+ '澎湖縣' => [
+ '馬公市', '湖西鄉', '白沙鄉', '西嶼鄉', '望安鄉',
+ '七美鄉',
+ ],
+ '基隆市' => [
+ '中正區', '七堵區', '暖暖區', '仁愛區', '中山區',
+ '安樂區', '信義區',
+ ],
+ '新竹市' => [
+ '東區', '北區', '香山區',
+ ],
+ '嘉義市' => [
+ '東區', '西區',
+ ],
+ '臺北市' => [
+ '松山區', '信義區', '大安區', '中山區', '中正區',
+ '大同區', '萬華區', '文山區', '南港區', '內湖區',
+ '士林區', '北投區',
+ ],
+ '連江縣' => [
+ '南竿鄉', '北竿鄉', '莒光鄉', '東引鄉',
+ ],
+ '金門縣' => [
+ '金城鎮', '金沙鎮', '金湖鎮', '金寧鄉', '烈嶼鄉', '烏坵鄉',
+ ],
+ ];
+
+ /**
+ * @link http://terms.naer.edu.tw/download/287/
+ */
+ protected static $country = [
+ '不丹', '中非', '丹麥', '伊朗', '冰島', '剛果',
+ '加彭', '北韓', '南非', '卡達', '印尼', '印度',
+ '古巴', '哥德', '埃及', '多哥', '寮國', '尼日',
+ '巴曼', '巴林', '巴紐', '巴西', '希臘', '帛琉',
+ '德國', '挪威', '捷克', '教廷', '斐濟', '日本',
+ '智利', '東加', '查德', '汶萊', '法國', '波蘭',
+ '波赫', '泰國', '海地', '瑞典', '瑞士', '祕魯',
+ '秘魯', '約旦', '紐埃', '緬甸', '美國', '聖尼',
+ '聖普', '肯亞', '芬蘭', '英國', '荷蘭', '葉門',
+ '蘇丹', '諾魯', '貝南', '越南', '迦彭',
+ '迦納', '阿曼', '阿聯', '韓國', '馬利',
+ '以色列', '以色利', '伊拉克', '俄羅斯',
+ '利比亞', '加拿大', '匈牙利', '南極洲',
+ '南蘇丹', '厄瓜多', '吉布地', '吐瓦魯',
+ '哈撒克', '哈薩克', '喀麥隆', '喬治亞',
+ '土庫曼', '土耳其', '塔吉克', '塞席爾',
+ '墨西哥', '大西洋', '奧地利', '孟加拉',
+ '安哥拉', '安地卡', '安道爾', '尚比亞',
+ '尼伯爾', '尼泊爾', '巴哈馬', '巴拉圭',
+ '巴拿馬', '巴貝多', '幾內亞', '愛爾蘭',
+ '所在國', '摩洛哥', '摩納哥', '敍利亞',
+ '敘利亞', '新加坡', '東帝汶', '柬埔寨',
+ '比利時', '波扎那', '波札那', '烏克蘭',
+ '烏干達', '烏拉圭', '牙買加', '獅子山',
+ '甘比亞', '盧安達', '盧森堡', '科威特',
+ '科索夫', '科索沃', '立陶宛', '紐西蘭',
+ '維德角', '義大利', '聖文森', '艾塞亞',
+ '菲律賓', '萬那杜', '葡萄牙', '蒲隆地',
+ '蓋亞納', '薩摩亞', '蘇利南', '西班牙',
+ '貝里斯', '賴索托', '辛巴威', '阿富汗',
+ '阿根廷', '馬其頓', '馬拉威', '馬爾他',
+ '黎巴嫩', '亞塞拜然', '亞美尼亞', '保加利亞',
+ '南斯拉夫', '厄利垂亞', '史瓦濟蘭', '吉爾吉斯',
+ '吉里巴斯', '哥倫比亞', '坦尚尼亞', '塞內加爾',
+ '塞内加爾', '塞爾維亞', '多明尼加', '多米尼克',
+ '奈及利亞', '委內瑞拉', '宏都拉斯', '尼加拉瓜',
+ '巴基斯坦', '庫克群島', '愛沙尼亞', '拉脫維亞',
+ '摩爾多瓦', '摩里西斯', '斯洛伐克', '斯里蘭卡',
+ '格瑞那達', '模里西斯', '波多黎各', '澳大利亞',
+ '烏茲別克', '玻利維亞', '瓜地馬拉', '白俄羅斯',
+ '突尼西亞', '納米比亞', '索馬利亞', '索馬尼亞',
+ '羅馬尼亞', '聖露西亞', '聖馬利諾', '莫三比克',
+ '莫三鼻克', '葛摩聯盟', '薩爾瓦多', '衣索比亞',
+ '西薩摩亞', '象牙海岸', '賴比瑞亞', '賽普勒斯',
+ '馬來西亞', '馬爾地夫', '克羅埃西亞',
+ '列支敦斯登', '哥斯大黎加', '布吉納法索',
+ '布吉那法索', '幾內亞比索', '幾內亞比紹',
+ '斯洛維尼亞', '索羅門群島', '茅利塔尼亞',
+ '蒙特內哥羅', '赤道幾內亞', '阿爾及利亞',
+ '阿爾及尼亞', '阿爾巴尼亞', '馬紹爾群島',
+ '馬達加斯加', '密克羅尼西亞', '沙烏地阿拉伯',
+ '千里達及托巴哥',
+ ];
+
+ protected static $postcode = ['###-##', '###'];
+
+ public function street()
+ {
+ return static::randomElement(static::$street);
+ }
+
+ public static function randomChineseNumber()
+ {
+ $digits = [
+ '', '一', '二', '三', '四', '五', '六', '七', '八', '九',
+ ];
+ return $digits[static::randomDigitNotNull()];
+ }
+
+ public static function randomNumber2()
+ {
+ return static::randomNumber(2) + 1;
+ }
+
+ public static function randomNumber3()
+ {
+ return static::randomNumber(3) + 1;
+ }
+
+ public static function localLatitude()
+ {
+ return static::randomFloat(6, 22, 25);
+ }
+
+ public static function localLongitude()
+ {
+ return static::randomFloat(6, 120, 122);
+ }
+
+ public function city()
+ {
+ $county = static::randomElement(array_keys(static::$city));
+ $city = static::randomElement(static::$city[$county]);
+ return $county . $city;
+ }
+
+ public function state()
+ {
+ return '臺灣省';
+ }
+
+ public static function stateAbbr()
+ {
+ return '臺';
+ }
+
+ public static function cityPrefix()
+ {
+ return '';
+ }
+
+ public static function citySuffix()
+ {
+ return '';
+ }
+
+ public static function secondaryAddress()
+ {
+ return (static::randomNumber(2) + 1) . static::randomElement(static::$secondaryAddressSuffix);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/Color.php b/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/Color.php
new file mode 100644
index 00000000..a824c26e
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/Color.php
@@ -0,0 +1,66 @@
+generator->parse($format);
+ }
+
+ public static function companyModifier()
+ {
+ return static::randomElement(static::$companyModifier);
+ }
+
+ public static function companyPrefix()
+ {
+ return static::randomElement(static::$companyPrefix);
+ }
+
+ public function catchPhrase()
+ {
+ return static::randomElement(static::$catchPhrase);
+ }
+
+ public function bs()
+ {
+ $result = '';
+ foreach (static::$bsWords as &$word) {
+ $result .= static::randomElement($word);
+ }
+ return $result;
+ }
+
+ /**
+ * return standard VAT / Tax ID / Uniform Serial Number
+ *
+ * @example 28263822
+ *
+ * @return int
+ */
+ public function VAT()
+ {
+ return static::randomNumber(8, true);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/DateTime.php b/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/DateTime.php
new file mode 100644
index 00000000..8dd66f01
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/DateTime.php
@@ -0,0 +1,46 @@
+format('a') === 'am' ? '上午' : '下午';
+ }
+
+ public static function dayOfWeek($max = 'now')
+ {
+ $map = [
+ 'Sunday' => '星期日',
+ 'Monday' => '星期一',
+ 'Tuesday' => '星期二',
+ 'Wednesday' => '星期三',
+ 'Thursday' => '星期四',
+ 'Friday' => '星期五',
+ 'Saturday' => '星期六',
+ ];
+ $week = static::dateTime($max)->format('l');
+ return $map[$week] ?? $week;
+ }
+
+ public static function monthName($max = 'now')
+ {
+ $map = [
+ 'January' => '一月',
+ 'February' => '二月',
+ 'March' => '三月',
+ 'April' => '四月',
+ 'May' => '五月',
+ 'June' => '六月',
+ 'July' => '七月',
+ 'August' => '八月',
+ 'September' => '九月',
+ 'October' => '十月',
+ 'November' => '十一月',
+ 'December' => '十二月',
+ ];
+ $month = static::dateTime($max)->format('F');
+ return $map[$month] ?? $month;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/Internet.php b/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/Internet.php
new file mode 100644
index 00000000..4035ea85
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/Internet.php
@@ -0,0 +1,16 @@
+userName();
+ }
+
+ public function domainWord()
+ {
+ return \Faker\Factory::create('en_US')->domainWord();
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/Payment.php b/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/Payment.php
new file mode 100644
index 00000000..6b1a5829
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/Payment.php
@@ -0,0 +1,11 @@
+creditCardDetails($valid);
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/Person.php b/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/Person.php
new file mode 100644
index 00000000..1570292c
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/Person.php
@@ -0,0 +1,199 @@
+ 10,
+ 'B' => 11,
+ 'C' => 12,
+ 'D' => 13,
+ 'E' => 14,
+ 'F' => 15,
+ 'G' => 16,
+ 'H' => 17,
+ 'I' => 34,
+ 'J' => 18,
+ 'K' => 19,
+ 'M' => 21,
+ 'N' => 22,
+ 'O' => 35,
+ 'P' => 23,
+ 'Q' => 24,
+ 'T' => 27,
+ 'U' => 28,
+ 'V' => 29,
+ 'W' => 32,
+ 'X' => 30,
+ 'Z' => 33
+ ];
+
+ /**
+ * @see https://zh.wikipedia.org/wiki/%E4%B8%AD%E8%8F%AF%E6%B0%91%E5%9C%8B%E5%9C%8B%E6%B0%91%E8%BA%AB%E5%88%86%E8%AD%89
+ */
+ public static $idDigitValidator = [1, 9, 8, 7, 6, 5, 4, 3, 2, 1, 1];
+
+ protected static $maleNameFormats = [
+ '{{lastName}}{{firstNameMale}}',
+ ];
+
+ protected static $femaleNameFormats = [
+ '{{lastName}}{{firstNameFemale}}',
+ ];
+
+ protected static $titleMale = ['先生', '博士', '教授'];
+ protected static $titleFemale = ['小姐', '太太', '博士', '教授'];
+
+ /**
+ * @link http://zh.wikipedia.org/wiki/%E7%99%BE%E5%AE%B6%E5%A7%93
+ */
+ protected static $lastName = [
+ '趙', '錢', '孫', '李', '周', '吳', '鄭', '王', '馮',
+ '陳', '褚', '衛', '蔣', '沈', '韓', '楊', '朱', '秦',
+ '尤', '許', '何', '呂', '施', '張', '孔', '曹', '嚴',
+ '華', '金', '魏', '陶', '姜', '戚', '謝', '鄒', '喻',
+ '柏', '水', '竇', '章', '雲', '蘇', '潘', '葛',
+ '奚', '范', '彭', '郎', '魯', '韋', '昌', '馬',
+ '苗', '鳳', '花', '方', '俞', '任', '袁', '柳',
+ '酆', '鮑', '史', '唐', '費', '廉', '岑', '薛',
+ '雷', '賀', '倪', '湯', '滕', '殷', '羅', '畢',
+ '郝', '鄔', '安', '常', '樂', '于', '時', '傅',
+ '皮', '卞', '齊', '康', '伍', '余', '元', '卜',
+ '顧', '孟', '平', '黃', '和', '穆', '蕭', '尹',
+ '姚', '邵', '湛', '汪', '祁', '毛', '禹', '狄',
+ '米', '貝', '明', '臧', '計', '伏', '成', '戴',
+ '談', '宋', '茅', '龐', '熊', '紀', '舒', '屈',
+ '項', '祝', '董', '梁', '杜', '阮', '藍', '閔',
+ '席', '季', '麻', '強', '賈', '路', '婁', '危',
+ '江', '童', '顏', '郭', '梅', '盛', '林', '刁',
+ '鍾', '徐', '丘', '駱', '高', '夏', '蔡', '田',
+ '樊', '胡', '凌', '霍', '虞', '萬', '支', '柯',
+ '昝', '管', '盧', '莫', '經', '房', '裘', '繆',
+ '干', '解', '應', '宗', '丁', '宣', '賁', '鄧',
+ '郁', '單', '杭', '洪', '包', '諸', '左', '石',
+ '崔', '吉', '鈕', '龔', '程', '嵇', '邢', '滑',
+ '裴', '陸', '榮', '翁', '荀', '羊', '於', '惠',
+ '甄', '麴', '家', '封', '芮', '羿', '儲', '靳',
+ '汲', '邴', '糜', '松', '井', '段', '富', '巫',
+ '烏', '焦', '巴', '弓', '牧', '隗', '山', '谷',
+ '車', '侯', '宓', '蓬', '全', '郗', '班', '仰',
+ '秋', '仲', '伊', '宮', '甯', '仇', '欒', '暴',
+ '甘', '鈄', '厲', '戎', '祖', '武', '符', '劉',
+ '景', '詹', '束', '龍', '葉', '幸', '司', '韶',
+ '郜', '黎', '薊', '薄', '印', '宿', '白', '懷',
+ '蒲', '邰', '從', '鄂', '索', '咸', '籍', '賴',
+ '卓', '藺', '屠', '蒙', '池', '喬', '陰', '鬱',
+ '胥', '能', '蒼', '雙', '聞', '莘', '黨', '翟',
+ '譚', '貢', '勞', '逄', '姬', '申', '扶', '堵',
+ '冉', '宰', '酈', '雍', '郤', '璩', '桑', '桂',
+ '濮', '牛', '壽', '通', '邊', '扈', '燕', '冀',
+ '郟', '浦', '尚', '農', '溫', '別', '莊', '晏',
+ '柴', '瞿', '閻', '充', '慕', '連', '茹', '習',
+ '宦', '艾', '魚', '容', '向', '古', '易', '慎',
+ '戈', '廖', '庾', '終', '暨', '居', '衡', '步',
+ '都', '耿', '滿', '弘', '匡', '國', '文', '寇',
+ '廣', '祿', '闕', '東', '歐', '殳', '沃', '利',
+ '蔚', '越', '夔', '隆', '師', '鞏', '厙', '聶',
+ '晁', '勾', '敖', '融', '冷', '訾', '辛', '闞',
+ '那', '簡', '饒', '空', '曾', '毋', '沙', '乜',
+ '養', '鞠', '須', '豐', '巢', '關', '蒯', '相',
+ '查', '后', '荊', '紅', '游', '竺', '權', '逯',
+ '蓋', '益', '桓', '公', '万俟', '司馬', '上官',
+ '歐陽', '夏侯', '諸葛', '聞人', '東方', '赫連',
+ '皇甫', '尉遲', '公羊', '澹臺', '公冶', '宗政',
+ '濮陽', '淳于', '單于', '太叔', '申屠', '公孫',
+ '仲孫', '軒轅', '令狐', '鍾離', '宇文', '長孫',
+ '慕容', '鮮于', '閭丘', '司徒', '司空', '亓官',
+ '司寇', '仉', '督', '子車', '顓孫', '端木', '巫馬',
+ '公西', '漆雕', '樂正', '壤駟', '公良', '拓跋',
+ '夾谷', '宰父', '穀梁', '晉', '楚', '閆', '法',
+ '汝', '鄢', '涂', '欽', '段干', '百里', '東郭',
+ '南門', '呼延', '歸', '海', '羊舌', '微生', '岳',
+ '帥', '緱', '亢', '況', '後', '有', '琴', '梁丘',
+ '左丘', '東門', '西門', '商', '牟', '佘', '佴',
+ '伯', '賞', '南宮', '墨', '哈', '譙', '笪', '年',
+ '愛', '陽', '佟', '第五', '言', '福',
+ ];
+
+ /**
+ * @link http://technology.chtsai.org/namefreq/
+ */
+ protected static $characterMale = [
+ '佳', '俊', '信', '偉', '傑', '冠', '君', '哲',
+ '嘉', '威', '宇', '安', '宏', '宗', '宜', '家',
+ '庭', '廷', '建', '彥', '心', '志', '思', '承',
+ '文', '柏', '樺', '瑋', '穎', '美', '翰', '華',
+ '詩', '豪', '賢', '軒', '銘', '霖',
+ ];
+
+ protected static $characterFemale = [
+ '伶', '佩', '佳', '依', '儀', '冠', '君', '嘉',
+ '如', '娟', '婉', '婷', '安', '宜', '家', '庭',
+ '心', '思', '怡', '惠', '慧', '文', '欣', '涵',
+ '淑', '玲', '珊', '琪', '琬', '瑜', '穎', '筑',
+ '筱', '美', '芬', '芳', '華', '萍', '萱', '蓉',
+ '詩', '貞', '郁', '鈺', '雅', '雯', '靜', '馨',
+ ];
+
+ public static function randomName($pool, $n)
+ {
+ $name = '';
+ for ($i = 0; $i < $n; ++$i) {
+ $name .= static::randomElement($pool);
+ }
+ return $name;
+ }
+
+ public static function firstNameMale()
+ {
+ return static::randomName(static::$characterMale, self::numberBetween(1, 2));
+ }
+
+ public static function firstNameFemale()
+ {
+ return static::randomName(static::$characterFemale, self::numberBetween(1, 2));
+ }
+
+ public static function suffix()
+ {
+ return '';
+ }
+
+ /**
+ * @param string $gender Person::GENDER_MALE || Person::GENDER_FEMALE
+ *
+ * @see https://en.wikipedia.org/wiki/National_Identification_Card_(Republic_of_China)
+ *
+ * @return string Length 10 alphanumeric characters, begins with 1 latin character (birthplace),
+ * 1 number (gender) and then 8 numbers (the last one is check digit).
+ */
+ public function personalIdentityNumber($gender = null)
+ {
+ $birthPlace = self::randomKey(self::$idBirthplaceCode);
+ $birthPlaceCode = self::$idBirthplaceCode[$birthPlace];
+
+ $gender = ($gender != null) ? $gender : self::randomElement([self::GENDER_FEMALE, self::GENDER_MALE]);
+ $genderCode = ($gender === self::GENDER_MALE) ? 1 : 2;
+
+ $randomNumberCode = self::randomNumber(7, true);
+
+ $codes = str_split($birthPlaceCode . $genderCode . $randomNumberCode);
+ $total = 0;
+
+ foreach ($codes as $key => $code) {
+ $total += $code * self::$idDigitValidator[$key];
+ }
+
+ $checkSumDigit = 10 - ($total % 10);
+
+ if ($checkSumDigit == 10) {
+ $checkSumDigit = 0;
+ }
+
+ return $birthPlace . $genderCode . $randomNumberCode . $checkSumDigit;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/PhoneNumber.php b/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/PhoneNumber.php
new file mode 100644
index 00000000..db9ac327
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/Provider/zh_TW/PhoneNumber.php
@@ -0,0 +1,19 @@
+ 251:
+ $temp .= $chars[++$i];
+ // no break
+ case $ord > 247:
+ $temp .= $chars[++$i];
+ // no break
+ case $ord > 239:
+ $temp .= $chars[++$i];
+ // no break
+ case $ord > 223:
+ $temp .= $chars[++$i];
+ // no break
+ case $ord > 191:
+ $temp .= $chars[++$i];
+ }
+
+ $encoding[] = $temp;
+ }
+
+ return $encoding;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/UniqueGenerator.php b/vendor/fakerphp/faker/src/Faker/UniqueGenerator.php
new file mode 100644
index 00000000..b4626e3f
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/UniqueGenerator.php
@@ -0,0 +1,58 @@
+unique()
+ */
+class UniqueGenerator
+{
+ protected $generator;
+ protected $maxRetries;
+ protected $uniques = [];
+
+ /**
+ * @param Generator $generator
+ * @param int $maxRetries
+ */
+ public function __construct(Generator $generator, $maxRetries = 10000)
+ {
+ $this->generator = $generator;
+ $this->maxRetries = $maxRetries;
+ }
+
+ /**
+ * Catch and proxy all generator calls but return only unique values
+ * @param string $attribute
+ * @return mixed
+ */
+ public function __get($attribute)
+ {
+ return $this->__call($attribute, []);
+ }
+
+ /**
+ * Catch and proxy all generator calls with arguments but return only unique values
+ * @param string $name
+ * @param array $arguments
+ * @return mixed
+ */
+ public function __call($name, $arguments)
+ {
+ if (!isset($this->uniques[$name])) {
+ $this->uniques[$name] = [];
+ }
+ $i = 0;
+ do {
+ $res = call_user_func_array([$this->generator, $name], $arguments);
+ $i++;
+ if ($i > $this->maxRetries) {
+ throw new \OverflowException(sprintf('Maximum retries of %d reached without finding a unique value', $this->maxRetries));
+ }
+ } while (array_key_exists(serialize($res), $this->uniques[$name]));
+ $this->uniques[$name][serialize($res)]= null;
+
+ return $res;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/Faker/ValidGenerator.php b/vendor/fakerphp/faker/src/Faker/ValidGenerator.php
new file mode 100644
index 00000000..347610ff
--- /dev/null
+++ b/vendor/fakerphp/faker/src/Faker/ValidGenerator.php
@@ -0,0 +1,65 @@
+valid()
+ */
+class ValidGenerator
+{
+ protected $generator;
+ protected $validator;
+ protected $maxRetries;
+
+ /**
+ * @param Generator $generator
+ * @param callable|null $validator
+ * @param int $maxRetries
+ */
+ public function __construct(Generator $generator, $validator = null, $maxRetries = 10000)
+ {
+ if (is_null($validator)) {
+ $validator = function () {
+ return true;
+ };
+ } elseif (!is_callable($validator)) {
+ throw new \InvalidArgumentException('valid() only accepts callables as first argument');
+ }
+ $this->generator = $generator;
+ $this->validator = $validator;
+ $this->maxRetries = $maxRetries;
+ }
+
+ /**
+ * Catch and proxy all generator calls but return only valid values
+ * @param string $attribute
+ *
+ * @return mixed
+ */
+ public function __get($attribute)
+ {
+ return $this->__call($attribute, []);
+ }
+
+ /**
+ * Catch and proxy all generator calls with arguments but return only valid values
+ * @param string $name
+ * @param array $arguments
+ *
+ * @return mixed
+ */
+ public function __call($name, $arguments)
+ {
+ $i = 0;
+ do {
+ $res = call_user_func_array([$this->generator, $name], $arguments);
+ $i++;
+ if ($i > $this->maxRetries) {
+ throw new \OverflowException(sprintf('Maximum retries of %d reached without finding a valid value', $this->maxRetries));
+ }
+ } while (!call_user_func($this->validator, $res));
+
+ return $res;
+ }
+}
diff --git a/vendor/fakerphp/faker/src/autoload.php b/vendor/fakerphp/faker/src/autoload.php
new file mode 100644
index 00000000..f55914de
--- /dev/null
+++ b/vendor/fakerphp/faker/src/autoload.php
@@ -0,0 +1,26 @@
+=5.4.0",
+ "illuminate/contracts": "^5.0|^6.0|^7.0|^8.0|^9.0"
+ },
+ "require-dev": {
+ "illuminate/http": "^5.0|^6.0|^7.0|^8.0|^9.0",
+ "mockery/mockery": "^1.0",
+ "phpunit/phpunit": "^6.0"
+ },
+ "autoload": {
+ "psr-4": {
+ "Fideloper\\Proxy\\": "src/"
+ }
+ },
+ "extra": {
+ "laravel": {
+ "providers": [
+ "Fideloper\\Proxy\\TrustedProxyServiceProvider"
+ ]
+ }
+ },
+ "minimum-stability": "dev",
+ "prefer-stable": true
+}
diff --git a/vendor/fideloper/proxy/config/trustedproxy.php b/vendor/fideloper/proxy/config/trustedproxy.php
new file mode 100644
index 00000000..e618ae24
--- /dev/null
+++ b/vendor/fideloper/proxy/config/trustedproxy.php
@@ -0,0 +1,50 @@
+ null, // [,], '*', ','
+
+ /*
+ * To trust one or more specific proxies that connect
+ * directly to your server, use an array or a string separated by comma of IP addresses:
+ */
+ // 'proxies' => ['192.168.1.1'],
+ // 'proxies' => '192.168.1.1, 192.168.1.2',
+
+ /*
+ * Or, to trust all proxies that connect
+ * directly to your server, use a "*"
+ */
+ // 'proxies' => '*',
+
+ /*
+ * Which headers to use to detect proxy related data (For, Host, Proto, Port)
+ *
+ * Options include:
+ *
+ * - Illuminate\Http\Request::HEADER_X_FORWARDED_ALL (use all x-forwarded-* headers to establish trust)
+ * - Illuminate\Http\Request::HEADER_FORWARDED (use the FORWARDED header to establish trust)
+ * - Illuminate\Http\Request::HEADER_X_FORWARDED_AWS_ELB (If you are using AWS Elastic Load Balancer)
+ *
+ * - 'HEADER_X_FORWARDED_ALL' (use all x-forwarded-* headers to establish trust)
+ * - 'HEADER_FORWARDED' (use the FORWARDED header to establish trust)
+ * - 'HEADER_X_FORWARDED_AWS_ELB' (If you are using AWS Elastic Load Balancer)
+ *
+ * @link https://symfony.com/doc/current/deployment/proxies.html
+ */
+ 'headers' => Illuminate\Http\Request::HEADER_X_FORWARDED_ALL,
+
+];
diff --git a/vendor/fideloper/proxy/src/TrustProxies.php b/vendor/fideloper/proxy/src/TrustProxies.php
new file mode 100644
index 00000000..79c26153
--- /dev/null
+++ b/vendor/fideloper/proxy/src/TrustProxies.php
@@ -0,0 +1,130 @@
+config = $config;
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ *
+ * @throws \Symfony\Component\HttpKernel\Exception\HttpException
+ *
+ * @return mixed
+ */
+ public function handle(Request $request, Closure $next)
+ {
+ $request::setTrustedProxies([], $this->getTrustedHeaderNames()); // Reset trusted proxies between requests
+ $this->setTrustedProxyIpAddresses($request);
+
+ return $next($request);
+ }
+
+ /**
+ * Sets the trusted proxies on the request to the value of trustedproxy.proxies
+ *
+ * @param \Illuminate\Http\Request $request
+ */
+ protected function setTrustedProxyIpAddresses(Request $request)
+ {
+ $trustedIps = $this->proxies ?: $this->config->get('trustedproxy.proxies');
+
+ // Trust any IP address that calls us
+ // `**` for backwards compatibility, but is deprecated
+ if ($trustedIps === '*' || $trustedIps === '**') {
+ return $this->setTrustedProxyIpAddressesToTheCallingIp($request);
+ }
+
+ // Support IPs addresses separated by comma
+ $trustedIps = is_string($trustedIps) ? array_map('trim', explode(',', $trustedIps)) : $trustedIps;
+
+ // Only trust specific IP addresses
+ if (is_array($trustedIps)) {
+ return $this->setTrustedProxyIpAddressesToSpecificIps($request, $trustedIps);
+ }
+ }
+
+ /**
+ * Specify the IP addresses to trust explicitly.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param array $trustedIps
+ */
+ private function setTrustedProxyIpAddressesToSpecificIps(Request $request, $trustedIps)
+ {
+ $request->setTrustedProxies((array) $trustedIps, $this->getTrustedHeaderNames());
+ }
+
+ /**
+ * Set the trusted proxy to be the IP address calling this servers
+ *
+ * @param \Illuminate\Http\Request $request
+ */
+ private function setTrustedProxyIpAddressesToTheCallingIp(Request $request)
+ {
+ $request->setTrustedProxies([$request->server->get('REMOTE_ADDR')], $this->getTrustedHeaderNames());
+ }
+
+ /**
+ * Retrieve trusted header name(s), falling back to defaults if config not set.
+ *
+ * @return int A bit field of Request::HEADER_*, to set which headers to trust from your proxies.
+ */
+ protected function getTrustedHeaderNames()
+ {
+ $headers = $this->headers ?: $this->config->get('trustedproxy.headers');
+ switch ($headers) {
+ case 'HEADER_X_FORWARDED_AWS_ELB':
+ case Request::HEADER_X_FORWARDED_AWS_ELB:
+ return Request::HEADER_X_FORWARDED_AWS_ELB;
+ break;
+ case 'HEADER_FORWARDED':
+ case Request::HEADER_FORWARDED:
+ return Request::HEADER_FORWARDED;
+ break;
+ case 'HEADER_X_FORWARDED_ALL':
+ case Request::HEADER_X_FORWARDED_ALL:
+ return Request::HEADER_X_FORWARDED_ALL;
+ break;
+ }
+
+ return $headers;
+ }
+}
diff --git a/vendor/fideloper/proxy/src/TrustedProxyServiceProvider.php b/vendor/fideloper/proxy/src/TrustedProxyServiceProvider.php
new file mode 100644
index 00000000..26f2631a
--- /dev/null
+++ b/vendor/fideloper/proxy/src/TrustedProxyServiceProvider.php
@@ -0,0 +1,41 @@
+app instanceof LaravelApplication && $this->app->runningInConsole()) {
+ $this->publishes([$source => config_path('trustedproxy.php')]);
+ } elseif ($this->app instanceof LumenApplication) {
+ $this->app->configure('trustedproxy');
+ }
+
+
+ if ($this->app instanceof LaravelApplication && ! $this->app->configurationIsCached()) {
+ $this->mergeConfigFrom($source, 'trustedproxy');
+ }
+ }
+
+ /**
+ * Register the service provider.
+ *
+ * @return void
+ */
+ public function register()
+ {
+ //
+ }
+}
diff --git a/vendor/filp/whoops/.github/FUNDING.yml b/vendor/filp/whoops/.github/FUNDING.yml
new file mode 100644
index 00000000..74f6e857
--- /dev/null
+++ b/vendor/filp/whoops/.github/FUNDING.yml
@@ -0,0 +1 @@
+github: denis-sokolov
diff --git a/vendor/filp/whoops/.github/workflows/tests.yml b/vendor/filp/whoops/.github/workflows/tests.yml
new file mode 100644
index 00000000..de3ed956
--- /dev/null
+++ b/vendor/filp/whoops/.github/workflows/tests.yml
@@ -0,0 +1,56 @@
+name: Tests
+
+on:
+ push:
+ pull_request:
+
+jobs:
+ tests:
+ name: PHP ${{ matrix.php }}
+ runs-on: ubuntu-20.04
+
+ strategy:
+ matrix:
+ php: ['7.0', '7.1', '7.2', '7.3', '7.4', '8.0']
+
+ steps:
+ - name: Checkout Code
+ uses: actions/checkout@v2
+
+ - name: Setup PHP
+ uses: shivammathur/setup-php@v2
+ with:
+ php-version: ${{ matrix.php }}
+ tools: composer:v2
+ coverage: none
+ env:
+ update: true
+
+ - name: Setup Problem Matchers
+ run: echo "::add-matcher::${{ runner.tool_cache }}/phpunit.json"
+
+ - name: Fix PHPUnit Version PHP < 7.4
+ uses: nick-invision/retry@v1
+ with:
+ timeout_minutes: 5
+ max_attempts: 5
+ command: composer require "phpunit/phpunit:^6.5.14 || ^7.5.20 || ^8.5.8" --dev --no-update --no-interaction
+ if: "matrix.php < 7.4"
+
+ - name: Fix PHPUnit Version PHP >= 7.4
+ uses: nick-invision/retry@v1
+ with:
+ timeout_minutes: 5
+ max_attempts: 5
+ command: composer require "phpunit/phpunit:^9.3.3" --dev --no-update --no-interaction
+ if: "matrix.php >= 7.4"
+
+ - name: Install PHP Dependencies
+ uses: nick-invision/retry@v1
+ with:
+ timeout_minutes: 5
+ max_attempts: 5
+ command: composer update --no-interaction --no-progress
+
+ - name: Execute PHPUnit
+ run: vendor/bin/phpunit
diff --git a/vendor/filp/whoops/CHANGELOG.md b/vendor/filp/whoops/CHANGELOG.md
new file mode 100644
index 00000000..78b1b120
--- /dev/null
+++ b/vendor/filp/whoops/CHANGELOG.md
@@ -0,0 +1,86 @@
+# 2.10.0
+
+* Better chaining on handler classes
+
+# 2.9.2
+
+* Fix copy button styles
+
+# 2.9.1
+
+* Fix xdebug function crash on PHP 8
+
+# 2.9.0
+
+* JsonResponseHandler includes the exception code
+
+# 2.8.0
+
+* Support PHP 8
+
+# 2.7.3
+
+* PrettyPageHandler functionality to hide superglobal keys has a clearer name hideSuperglobalKey
+
+# 2.7.2
+
+* PrettyPageHandler now accepts custom js files
+* PrettyPageHandler templateHelper is now accessible through inheritance
+
+# 2.7.1
+
+* Fix a PHP warning in some cases with anonymous classes.
+
+# 2.7.0
+
+* removeFirstHandler and removeLastHandler.
+
+# 2.6.0
+
+* Fix 2.4.0 pushHandler changing the order of handlers.
+
+# 2.5.1
+
+* Fix error messaging in a rare case.
+
+# 2.5.0
+
+* Automatically configure xdebug if available.
+
+# 2.4.1
+
+* Try harder to close all output buffers
+
+# 2.4.0
+
+* Allow to prepend and append handlers.
+
+# 2.3.2
+
+* Various fixes from the community.
+
+# 2.3.1
+
+* Prevent exception in Whoops when caught exception frame is not related to real file
+
+# 2.3.0
+
+* Show previous exception messages.
+
+# 2.2.0
+
+* Support PHP 7.2
+
+# 2.1.0
+
+* Add a `SystemFacade` to allow clients to override Whoops behavior.
+* Show frame arguments in `PrettyPageHandler`.
+* Highlight the line with the error.
+* Add icons to search on Google and Stack Overflow.
+
+# 2.0.0
+
+Backwards compatibility breaking changes:
+
+* `Run` class is now `final`. If you inherited from `Run`, please now instead use a custom `SystemFacade` injected into the `Run` constructor, or contribute your changes to our core.
+* PHP < 5.5 support dropped.
diff --git a/vendor/filp/whoops/LICENSE.md b/vendor/filp/whoops/LICENSE.md
new file mode 100644
index 00000000..80407e71
--- /dev/null
+++ b/vendor/filp/whoops/LICENSE.md
@@ -0,0 +1,19 @@
+# The MIT License
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in
+all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
diff --git a/vendor/filp/whoops/composer.json b/vendor/filp/whoops/composer.json
new file mode 100644
index 00000000..0d90dfc1
--- /dev/null
+++ b/vendor/filp/whoops/composer.json
@@ -0,0 +1,45 @@
+{
+ "name": "filp/whoops",
+ "license": "MIT",
+ "description": "php error handling for cool kids",
+ "keywords": ["library", "error", "handling", "exception", "whoops", "throwable"],
+ "homepage": "https://filp.github.io/whoops/",
+ "authors": [
+ {
+ "name": "Filipe Dobreira",
+ "homepage": "https://github.com/filp",
+ "role": "Developer"
+ }
+ ],
+ "scripts": {
+ "test": "phpunit --testdox tests"
+ },
+ "require": {
+ "php": "^5.5.9 || ^7.0 || ^8.0",
+ "psr/log": "^1.0.1"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^4.8.36 || ^5.7.27 || ^6.5.14 || ^7.5.20 || ^8.5.8 || ^9.3.3",
+ "mockery/mockery": "^0.9 || ^1.0",
+ "symfony/var-dumper": "^2.6 || ^3.0 || ^4.0 || ^5.0"
+ },
+ "suggest": {
+ "symfony/var-dumper": "Pretty print complex values better with var-dumper available",
+ "whoops/soap": "Formats errors as SOAP responses"
+ },
+ "autoload": {
+ "psr-4": {
+ "Whoops\\": "src/Whoops/"
+ }
+ },
+ "autoload-dev": {
+ "psr-4": {
+ "Whoops\\": "tests/Whoops/"
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.7-dev"
+ }
+ }
+}
diff --git a/vendor/filp/whoops/src/Whoops/Exception/ErrorException.php b/vendor/filp/whoops/src/Whoops/Exception/ErrorException.php
new file mode 100644
index 00000000..d74e8231
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Exception/ErrorException.php
@@ -0,0 +1,17 @@
+
+ */
+
+namespace Whoops\Exception;
+
+use ErrorException as BaseErrorException;
+
+/**
+ * Wraps ErrorException; mostly used for typing (at least now)
+ * to easily cleanup the stack trace of redundant info.
+ */
+class ErrorException extends BaseErrorException
+{
+}
diff --git a/vendor/filp/whoops/src/Whoops/Exception/Formatter.php b/vendor/filp/whoops/src/Whoops/Exception/Formatter.php
new file mode 100644
index 00000000..573dda0b
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Exception/Formatter.php
@@ -0,0 +1,74 @@
+
+ */
+
+namespace Whoops\Exception;
+
+class Formatter
+{
+ /**
+ * Returns all basic information about the exception in a simple array
+ * for further convertion to other languages
+ * @param Inspector $inspector
+ * @param bool $shouldAddTrace
+ * @return array
+ */
+ public static function formatExceptionAsDataArray(Inspector $inspector, $shouldAddTrace)
+ {
+ $exception = $inspector->getException();
+ $response = [
+ 'type' => get_class($exception),
+ 'message' => $exception->getMessage(),
+ 'code' => $exception->getCode(),
+ 'file' => $exception->getFile(),
+ 'line' => $exception->getLine(),
+ ];
+
+ if ($shouldAddTrace) {
+ $frames = $inspector->getFrames();
+ $frameData = [];
+
+ foreach ($frames as $frame) {
+ /** @var Frame $frame */
+ $frameData[] = [
+ 'file' => $frame->getFile(),
+ 'line' => $frame->getLine(),
+ 'function' => $frame->getFunction(),
+ 'class' => $frame->getClass(),
+ 'args' => $frame->getArgs(),
+ ];
+ }
+
+ $response['trace'] = $frameData;
+ }
+
+ return $response;
+ }
+
+ public static function formatExceptionPlain(Inspector $inspector)
+ {
+ $message = $inspector->getException()->getMessage();
+ $frames = $inspector->getFrames();
+
+ $plain = $inspector->getExceptionName();
+ $plain .= ' thrown with message "';
+ $plain .= $message;
+ $plain .= '"'."\n\n";
+
+ $plain .= "Stacktrace:\n";
+ foreach ($frames as $i => $frame) {
+ $plain .= "#". (count($frames) - $i - 1). " ";
+ $plain .= $frame->getClass() ?: '';
+ $plain .= $frame->getClass() && $frame->getFunction() ? ":" : "";
+ $plain .= $frame->getFunction() ?: '';
+ $plain .= ' in ';
+ $plain .= ($frame->getFile() ?: '<#unknown>');
+ $plain .= ':';
+ $plain .= (int) $frame->getLine(). "\n";
+ }
+
+ return $plain;
+ }
+}
diff --git a/vendor/filp/whoops/src/Whoops/Exception/Frame.php b/vendor/filp/whoops/src/Whoops/Exception/Frame.php
new file mode 100644
index 00000000..8403209e
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Exception/Frame.php
@@ -0,0 +1,295 @@
+
+ */
+
+namespace Whoops\Exception;
+
+use InvalidArgumentException;
+use Serializable;
+
+class Frame implements Serializable
+{
+ /**
+ * @var array
+ */
+ protected $frame;
+
+ /**
+ * @var string
+ */
+ protected $fileContentsCache;
+
+ /**
+ * @var array[]
+ */
+ protected $comments = [];
+
+ /**
+ * @var bool
+ */
+ protected $application;
+
+ /**
+ * @param array[]
+ */
+ public function __construct(array $frame)
+ {
+ $this->frame = $frame;
+ }
+
+ /**
+ * @param bool $shortened
+ * @return string|null
+ */
+ public function getFile($shortened = false)
+ {
+ if (empty($this->frame['file'])) {
+ return null;
+ }
+
+ $file = $this->frame['file'];
+
+ // Check if this frame occurred within an eval().
+ // @todo: This can be made more reliable by checking if we've entered
+ // eval() in a previous trace, but will need some more work on the upper
+ // trace collector(s).
+ if (preg_match('/^(.*)\((\d+)\) : (?:eval\(\)\'d|assert) code$/', $file, $matches)) {
+ $file = $this->frame['file'] = $matches[1];
+ $this->frame['line'] = (int) $matches[2];
+ }
+
+ if ($shortened && is_string($file)) {
+ // Replace the part of the path that all frames have in common, and add 'soft hyphens' for smoother line-breaks.
+ $dirname = dirname(dirname(dirname(dirname(dirname(dirname(__DIR__))))));
+ if ($dirname !== '/') {
+ $file = str_replace($dirname, "…", $file);
+ }
+ $file = str_replace("/", "/", $file);
+ }
+
+ return $file;
+ }
+
+ /**
+ * @return int|null
+ */
+ public function getLine()
+ {
+ return isset($this->frame['line']) ? $this->frame['line'] : null;
+ }
+
+ /**
+ * @return string|null
+ */
+ public function getClass()
+ {
+ return isset($this->frame['class']) ? $this->frame['class'] : null;
+ }
+
+ /**
+ * @return string|null
+ */
+ public function getFunction()
+ {
+ return isset($this->frame['function']) ? $this->frame['function'] : null;
+ }
+
+ /**
+ * @return array
+ */
+ public function getArgs()
+ {
+ return isset($this->frame['args']) ? (array) $this->frame['args'] : [];
+ }
+
+ /**
+ * Returns the full contents of the file for this frame,
+ * if it's known.
+ * @return string|null
+ */
+ public function getFileContents()
+ {
+ if ($this->fileContentsCache === null && $filePath = $this->getFile()) {
+ // Leave the stage early when 'Unknown' or '[internal]' is passed
+ // this would otherwise raise an exception when
+ // open_basedir is enabled.
+ if ($filePath === "Unknown" || $filePath === '[internal]') {
+ return null;
+ }
+
+ try {
+ $this->fileContentsCache = file_get_contents($filePath);
+ } catch (ErrorException $exception) {
+ // Internal file paths of PHP extensions cannot be opened
+ }
+ }
+
+ return $this->fileContentsCache;
+ }
+
+ /**
+ * Adds a comment to this frame, that can be received and
+ * used by other handlers. For example, the PrettyPage handler
+ * can attach these comments under the code for each frame.
+ *
+ * An interesting use for this would be, for example, code analysis
+ * & annotations.
+ *
+ * @param string $comment
+ * @param string $context Optional string identifying the origin of the comment
+ */
+ public function addComment($comment, $context = 'global')
+ {
+ $this->comments[] = [
+ 'comment' => $comment,
+ 'context' => $context,
+ ];
+ }
+
+ /**
+ * Returns all comments for this frame. Optionally allows
+ * a filter to only retrieve comments from a specific
+ * context.
+ *
+ * @param string $filter
+ * @return array[]
+ */
+ public function getComments($filter = null)
+ {
+ $comments = $this->comments;
+
+ if ($filter !== null) {
+ $comments = array_filter($comments, function ($c) use ($filter) {
+ return $c['context'] == $filter;
+ });
+ }
+
+ return $comments;
+ }
+
+ /**
+ * Returns the array containing the raw frame data from which
+ * this Frame object was built
+ *
+ * @return array
+ */
+ public function getRawFrame()
+ {
+ return $this->frame;
+ }
+
+ /**
+ * Returns the contents of the file for this frame as an
+ * array of lines, and optionally as a clamped range of lines.
+ *
+ * NOTE: lines are 0-indexed
+ *
+ * @example
+ * Get all lines for this file
+ * $frame->getFileLines(); // => array( 0 => ' '...', ...)
+ * @example
+ * Get one line for this file, starting at line 10 (zero-indexed, remember!)
+ * $frame->getFileLines(9, 1); // array( 9 => '...' )
+ *
+ * @throws InvalidArgumentException if $length is less than or equal to 0
+ * @param int $start
+ * @param int $length
+ * @return string[]|null
+ */
+ public function getFileLines($start = 0, $length = null)
+ {
+ if (null !== ($contents = $this->getFileContents())) {
+ $lines = explode("\n", $contents);
+
+ // Get a subset of lines from $start to $end
+ if ($length !== null) {
+ $start = (int) $start;
+ $length = (int) $length;
+ if ($start < 0) {
+ $start = 0;
+ }
+
+ if ($length <= 0) {
+ throw new InvalidArgumentException(
+ "\$length($length) cannot be lower or equal to 0"
+ );
+ }
+
+ $lines = array_slice($lines, $start, $length, true);
+ }
+
+ return $lines;
+ }
+ }
+
+ /**
+ * Implements the Serializable interface, with special
+ * steps to also save the existing comments.
+ *
+ * @see Serializable::serialize
+ * @return string
+ */
+ public function serialize()
+ {
+ $frame = $this->frame;
+ if (!empty($this->comments)) {
+ $frame['_comments'] = $this->comments;
+ }
+
+ return serialize($frame);
+ }
+
+ /**
+ * Unserializes the frame data, while also preserving
+ * any existing comment data.
+ *
+ * @see Serializable::unserialize
+ * @param string $serializedFrame
+ */
+ public function unserialize($serializedFrame)
+ {
+ $frame = unserialize($serializedFrame);
+
+ if (!empty($frame['_comments'])) {
+ $this->comments = $frame['_comments'];
+ unset($frame['_comments']);
+ }
+
+ $this->frame = $frame;
+ }
+
+ /**
+ * Compares Frame against one another
+ * @param Frame $frame
+ * @return bool
+ */
+ public function equals(Frame $frame)
+ {
+ if (!$this->getFile() || $this->getFile() === 'Unknown' || !$this->getLine()) {
+ return false;
+ }
+ return $frame->getFile() === $this->getFile() && $frame->getLine() === $this->getLine();
+ }
+
+ /**
+ * Returns whether this frame belongs to the application or not.
+ *
+ * @return boolean
+ */
+ public function isApplication()
+ {
+ return $this->application;
+ }
+
+ /**
+ * Mark as an frame belonging to the application.
+ *
+ * @param boolean $application
+ */
+ public function setApplication($application)
+ {
+ $this->application = $application;
+ }
+}
diff --git a/vendor/filp/whoops/src/Whoops/Exception/FrameCollection.php b/vendor/filp/whoops/src/Whoops/Exception/FrameCollection.php
new file mode 100644
index 00000000..6cf40738
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Exception/FrameCollection.php
@@ -0,0 +1,203 @@
+
+ */
+
+namespace Whoops\Exception;
+
+use ArrayAccess;
+use ArrayIterator;
+use Countable;
+use IteratorAggregate;
+use Serializable;
+use UnexpectedValueException;
+
+/**
+ * Exposes a fluent interface for dealing with an ordered list
+ * of stack-trace frames.
+ */
+class FrameCollection implements ArrayAccess, IteratorAggregate, Serializable, Countable
+{
+ /**
+ * @var array[]
+ */
+ private $frames;
+
+ /**
+ * @param array $frames
+ */
+ public function __construct(array $frames)
+ {
+ $this->frames = array_map(function ($frame) {
+ return new Frame($frame);
+ }, $frames);
+ }
+
+ /**
+ * Filters frames using a callable, returns the same FrameCollection
+ *
+ * @param callable $callable
+ * @return FrameCollection
+ */
+ public function filter($callable)
+ {
+ $this->frames = array_values(array_filter($this->frames, $callable));
+ return $this;
+ }
+
+ /**
+ * Map the collection of frames
+ *
+ * @param callable $callable
+ * @return FrameCollection
+ */
+ public function map($callable)
+ {
+ // Contain the map within a higher-order callable
+ // that enforces type-correctness for the $callable
+ $this->frames = array_map(function ($frame) use ($callable) {
+ $frame = call_user_func($callable, $frame);
+
+ if (!$frame instanceof Frame) {
+ throw new UnexpectedValueException(
+ "Callable to " . __CLASS__ . "::map must return a Frame object"
+ );
+ }
+
+ return $frame;
+ }, $this->frames);
+
+ return $this;
+ }
+
+ /**
+ * Returns an array with all frames, does not affect
+ * the internal array.
+ *
+ * @todo If this gets any more complex than this,
+ * have getIterator use this method.
+ * @see FrameCollection::getIterator
+ * @return array
+ */
+ public function getArray()
+ {
+ return $this->frames;
+ }
+
+ /**
+ * @see IteratorAggregate::getIterator
+ * @return ArrayIterator
+ */
+ public function getIterator()
+ {
+ return new ArrayIterator($this->frames);
+ }
+
+ /**
+ * @see ArrayAccess::offsetExists
+ * @param int $offset
+ */
+ public function offsetExists($offset)
+ {
+ return isset($this->frames[$offset]);
+ }
+
+ /**
+ * @see ArrayAccess::offsetGet
+ * @param int $offset
+ */
+ public function offsetGet($offset)
+ {
+ return $this->frames[$offset];
+ }
+
+ /**
+ * @see ArrayAccess::offsetSet
+ * @param int $offset
+ */
+ public function offsetSet($offset, $value)
+ {
+ throw new \Exception(__CLASS__ . ' is read only');
+ }
+
+ /**
+ * @see ArrayAccess::offsetUnset
+ * @param int $offset
+ */
+ public function offsetUnset($offset)
+ {
+ throw new \Exception(__CLASS__ . ' is read only');
+ }
+
+ /**
+ * @see Countable::count
+ * @return int
+ */
+ public function count()
+ {
+ return count($this->frames);
+ }
+
+ /**
+ * Count the frames that belongs to the application.
+ *
+ * @return int
+ */
+ public function countIsApplication()
+ {
+ return count(array_filter($this->frames, function (Frame $f) {
+ return $f->isApplication();
+ }));
+ }
+
+ /**
+ * @see Serializable::serialize
+ * @return string
+ */
+ public function serialize()
+ {
+ return serialize($this->frames);
+ }
+
+ /**
+ * @see Serializable::unserialize
+ * @param string $serializedFrames
+ */
+ public function unserialize($serializedFrames)
+ {
+ $this->frames = unserialize($serializedFrames);
+ }
+
+ /**
+ * @param Frame[] $frames Array of Frame instances, usually from $e->getPrevious()
+ */
+ public function prependFrames(array $frames)
+ {
+ $this->frames = array_merge($frames, $this->frames);
+ }
+
+ /**
+ * Gets the innermost part of stack trace that is not the same as that of outer exception
+ *
+ * @param FrameCollection $parentFrames Outer exception frames to compare tail against
+ * @return Frame[]
+ */
+ public function topDiff(FrameCollection $parentFrames)
+ {
+ $diff = $this->frames;
+
+ $parentFrames = $parentFrames->getArray();
+ $p = count($parentFrames)-1;
+
+ for ($i = count($diff)-1; $i >= 0 && $p >= 0; $i--) {
+ /** @var Frame $tailFrame */
+ $tailFrame = $diff[$i];
+ if ($tailFrame->equals($parentFrames[$p])) {
+ unset($diff[$i]);
+ }
+ $p--;
+ }
+ return $diff;
+ }
+}
diff --git a/vendor/filp/whoops/src/Whoops/Exception/Inspector.php b/vendor/filp/whoops/src/Whoops/Exception/Inspector.php
new file mode 100644
index 00000000..85709593
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Exception/Inspector.php
@@ -0,0 +1,323 @@
+
+ */
+
+namespace Whoops\Exception;
+
+use Whoops\Util\Misc;
+
+class Inspector
+{
+ /**
+ * @var \Throwable
+ */
+ private $exception;
+
+ /**
+ * @var \Whoops\Exception\FrameCollection
+ */
+ private $frames;
+
+ /**
+ * @var \Whoops\Exception\Inspector
+ */
+ private $previousExceptionInspector;
+
+ /**
+ * @var \Throwable[]
+ */
+ private $previousExceptions;
+
+ /**
+ * @param \Throwable $exception The exception to inspect
+ */
+ public function __construct($exception)
+ {
+ $this->exception = $exception;
+ }
+
+ /**
+ * @return \Throwable
+ */
+ public function getException()
+ {
+ return $this->exception;
+ }
+
+ /**
+ * @return string
+ */
+ public function getExceptionName()
+ {
+ return get_class($this->exception);
+ }
+
+ /**
+ * @return string
+ */
+ public function getExceptionMessage()
+ {
+ return $this->extractDocrefUrl($this->exception->getMessage())['message'];
+ }
+
+ /**
+ * @return string[]
+ */
+ public function getPreviousExceptionMessages()
+ {
+ return array_map(function ($prev) {
+ /** @var \Throwable $prev */
+ return $this->extractDocrefUrl($prev->getMessage())['message'];
+ }, $this->getPreviousExceptions());
+ }
+
+ /**
+ * @return int[]
+ */
+ public function getPreviousExceptionCodes()
+ {
+ return array_map(function ($prev) {
+ /** @var \Throwable $prev */
+ return $prev->getCode();
+ }, $this->getPreviousExceptions());
+ }
+
+ /**
+ * Returns a url to the php-manual related to the underlying error - when available.
+ *
+ * @return string|null
+ */
+ public function getExceptionDocrefUrl()
+ {
+ return $this->extractDocrefUrl($this->exception->getMessage())['url'];
+ }
+
+ private function extractDocrefUrl($message)
+ {
+ $docref = [
+ 'message' => $message,
+ 'url' => null,
+ ];
+
+ // php embbeds urls to the manual into the Exception message with the following ini-settings defined
+ // http://php.net/manual/en/errorfunc.configuration.php#ini.docref-root
+ if (!ini_get('html_errors') || !ini_get('docref_root')) {
+ return $docref;
+ }
+
+ $pattern = "/\[(?:[^<]+)<\/a>\]/";
+ if (preg_match($pattern, $message, $matches)) {
+ // -> strip those automatically generated links from the exception message
+ $docref['message'] = preg_replace($pattern, '', $message, 1);
+ $docref['url'] = $matches[1];
+ }
+
+ return $docref;
+ }
+
+ /**
+ * Does the wrapped Exception has a previous Exception?
+ * @return bool
+ */
+ public function hasPreviousException()
+ {
+ return $this->previousExceptionInspector || $this->exception->getPrevious();
+ }
+
+ /**
+ * Returns an Inspector for a previous Exception, if any.
+ * @todo Clean this up a bit, cache stuff a bit better.
+ * @return Inspector
+ */
+ public function getPreviousExceptionInspector()
+ {
+ if ($this->previousExceptionInspector === null) {
+ $previousException = $this->exception->getPrevious();
+
+ if ($previousException) {
+ $this->previousExceptionInspector = new Inspector($previousException);
+ }
+ }
+
+ return $this->previousExceptionInspector;
+ }
+
+
+ /**
+ * Returns an array of all previous exceptions for this inspector's exception
+ * @return \Throwable[]
+ */
+ public function getPreviousExceptions()
+ {
+ if ($this->previousExceptions === null) {
+ $this->previousExceptions = [];
+
+ $prev = $this->exception->getPrevious();
+ while ($prev !== null) {
+ $this->previousExceptions[] = $prev;
+ $prev = $prev->getPrevious();
+ }
+ }
+
+ return $this->previousExceptions;
+ }
+
+ /**
+ * Returns an iterator for the inspected exception's
+ * frames.
+ * @return \Whoops\Exception\FrameCollection
+ */
+ public function getFrames()
+ {
+ if ($this->frames === null) {
+ $frames = $this->getTrace($this->exception);
+
+ // Fill empty line/file info for call_user_func_array usages (PHP Bug #44428)
+ foreach ($frames as $k => $frame) {
+ if (empty($frame['file'])) {
+ // Default values when file and line are missing
+ $file = '[internal]';
+ $line = 0;
+
+ $next_frame = !empty($frames[$k + 1]) ? $frames[$k + 1] : [];
+
+ if ($this->isValidNextFrame($next_frame)) {
+ $file = $next_frame['file'];
+ $line = $next_frame['line'];
+ }
+
+ $frames[$k]['file'] = $file;
+ $frames[$k]['line'] = $line;
+ }
+ }
+
+ // Find latest non-error handling frame index ($i) used to remove error handling frames
+ $i = 0;
+ foreach ($frames as $k => $frame) {
+ if ($frame['file'] == $this->exception->getFile() && $frame['line'] == $this->exception->getLine()) {
+ $i = $k;
+ }
+ }
+
+ // Remove error handling frames
+ if ($i > 0) {
+ array_splice($frames, 0, $i);
+ }
+
+ $firstFrame = $this->getFrameFromException($this->exception);
+ array_unshift($frames, $firstFrame);
+
+ $this->frames = new FrameCollection($frames);
+
+ if ($previousInspector = $this->getPreviousExceptionInspector()) {
+ // Keep outer frame on top of the inner one
+ $outerFrames = $this->frames;
+ $newFrames = clone $previousInspector->getFrames();
+ // I assume it will always be set, but let's be safe
+ if (isset($newFrames[0])) {
+ $newFrames[0]->addComment(
+ $previousInspector->getExceptionMessage(),
+ 'Exception message:'
+ );
+ }
+ $newFrames->prependFrames($outerFrames->topDiff($newFrames));
+ $this->frames = $newFrames;
+ }
+ }
+
+ return $this->frames;
+ }
+
+ /**
+ * Gets the backtrace from an exception.
+ *
+ * If xdebug is installed
+ *
+ * @param \Throwable $e
+ * @return array
+ */
+ protected function getTrace($e)
+ {
+ $traces = $e->getTrace();
+
+ // Get trace from xdebug if enabled, failure exceptions only trace to the shutdown handler by default
+ if (!$e instanceof \ErrorException) {
+ return $traces;
+ }
+
+ if (!Misc::isLevelFatal($e->getSeverity())) {
+ return $traces;
+ }
+
+ if (!extension_loaded('xdebug') || !function_exists('xdebug_is_enabled') || !xdebug_is_enabled()) {
+ return $traces;
+ }
+
+ // Use xdebug to get the full stack trace and remove the shutdown handler stack trace
+ $stack = array_reverse(xdebug_get_function_stack());
+ $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS);
+ $traces = array_diff_key($stack, $trace);
+
+ return $traces;
+ }
+
+ /**
+ * Given an exception, generates an array in the format
+ * generated by Exception::getTrace()
+ * @param \Throwable $exception
+ * @return array
+ */
+ protected function getFrameFromException($exception)
+ {
+ return [
+ 'file' => $exception->getFile(),
+ 'line' => $exception->getLine(),
+ 'class' => get_class($exception),
+ 'args' => [
+ $exception->getMessage(),
+ ],
+ ];
+ }
+
+ /**
+ * Given an error, generates an array in the format
+ * generated by ErrorException
+ * @param ErrorException $exception
+ * @return array
+ */
+ protected function getFrameFromError(ErrorException $exception)
+ {
+ return [
+ 'file' => $exception->getFile(),
+ 'line' => $exception->getLine(),
+ 'class' => null,
+ 'args' => [],
+ ];
+ }
+
+ /**
+ * Determine if the frame can be used to fill in previous frame's missing info
+ * happens for call_user_func and call_user_func_array usages (PHP Bug #44428)
+ *
+ * @param array $frame
+ * @return bool
+ */
+ protected function isValidNextFrame(array $frame)
+ {
+ if (empty($frame['file'])) {
+ return false;
+ }
+
+ if (empty($frame['line'])) {
+ return false;
+ }
+
+ if (empty($frame['function']) || !stristr($frame['function'], 'call_user_func')) {
+ return false;
+ }
+
+ return true;
+ }
+}
diff --git a/vendor/filp/whoops/src/Whoops/Handler/CallbackHandler.php b/vendor/filp/whoops/src/Whoops/Handler/CallbackHandler.php
new file mode 100644
index 00000000..cc46e700
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Handler/CallbackHandler.php
@@ -0,0 +1,52 @@
+
+ */
+
+namespace Whoops\Handler;
+
+use InvalidArgumentException;
+
+/**
+ * Wrapper for Closures passed as handlers. Can be used
+ * directly, or will be instantiated automagically by Whoops\Run
+ * if passed to Run::pushHandler
+ */
+class CallbackHandler extends Handler
+{
+ /**
+ * @var callable
+ */
+ protected $callable;
+
+ /**
+ * @throws InvalidArgumentException If argument is not callable
+ * @param callable $callable
+ */
+ public function __construct($callable)
+ {
+ if (!is_callable($callable)) {
+ throw new InvalidArgumentException(
+ 'Argument to ' . __METHOD__ . ' must be valid callable'
+ );
+ }
+
+ $this->callable = $callable;
+ }
+
+ /**
+ * @return int|null
+ */
+ public function handle()
+ {
+ $exception = $this->getException();
+ $inspector = $this->getInspector();
+ $run = $this->getRun();
+ $callable = $this->callable;
+
+ // invoke the callable directly, to get simpler stacktraces (in comparison to call_user_func).
+ // this assumes that $callable is a properly typed php-callable, which we check in __construct().
+ return $callable($exception, $inspector, $run);
+ }
+}
diff --git a/vendor/filp/whoops/src/Whoops/Handler/Handler.php b/vendor/filp/whoops/src/Whoops/Handler/Handler.php
new file mode 100644
index 00000000..cf1f7087
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Handler/Handler.php
@@ -0,0 +1,95 @@
+
+ */
+
+namespace Whoops\Handler;
+
+use Whoops\Exception\Inspector;
+use Whoops\RunInterface;
+
+/**
+ * Abstract implementation of a Handler.
+ */
+abstract class Handler implements HandlerInterface
+{
+ /*
+ Return constants that can be returned from Handler::handle
+ to message the handler walker.
+ */
+ const DONE = 0x10; // returning this is optional, only exists for
+ // semantic purposes
+ /**
+ * The Handler has handled the Throwable in some way, and wishes to skip any other Handler.
+ * Execution will continue.
+ */
+ const LAST_HANDLER = 0x20;
+ /**
+ * The Handler has handled the Throwable in some way, and wishes to quit/stop execution
+ */
+ const QUIT = 0x30;
+
+ /**
+ * @var RunInterface
+ */
+ private $run;
+
+ /**
+ * @var Inspector $inspector
+ */
+ private $inspector;
+
+ /**
+ * @var \Throwable $exception
+ */
+ private $exception;
+
+ /**
+ * @param RunInterface $run
+ */
+ public function setRun(RunInterface $run)
+ {
+ $this->run = $run;
+ }
+
+ /**
+ * @return RunInterface
+ */
+ protected function getRun()
+ {
+ return $this->run;
+ }
+
+ /**
+ * @param Inspector $inspector
+ */
+ public function setInspector(Inspector $inspector)
+ {
+ $this->inspector = $inspector;
+ }
+
+ /**
+ * @return Inspector
+ */
+ protected function getInspector()
+ {
+ return $this->inspector;
+ }
+
+ /**
+ * @param \Throwable $exception
+ */
+ public function setException($exception)
+ {
+ $this->exception = $exception;
+ }
+
+ /**
+ * @return \Throwable
+ */
+ protected function getException()
+ {
+ return $this->exception;
+ }
+}
diff --git a/vendor/filp/whoops/src/Whoops/Handler/HandlerInterface.php b/vendor/filp/whoops/src/Whoops/Handler/HandlerInterface.php
new file mode 100644
index 00000000..0265a85b
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Handler/HandlerInterface.php
@@ -0,0 +1,36 @@
+
+ */
+
+namespace Whoops\Handler;
+
+use Whoops\Exception\Inspector;
+use Whoops\RunInterface;
+
+interface HandlerInterface
+{
+ /**
+ * @return int|null A handler may return nothing, or a Handler::HANDLE_* constant
+ */
+ public function handle();
+
+ /**
+ * @param RunInterface $run
+ * @return void
+ */
+ public function setRun(RunInterface $run);
+
+ /**
+ * @param \Throwable $exception
+ * @return void
+ */
+ public function setException($exception);
+
+ /**
+ * @param Inspector $inspector
+ * @return void
+ */
+ public function setInspector(Inspector $inspector);
+}
diff --git a/vendor/filp/whoops/src/Whoops/Handler/JsonResponseHandler.php b/vendor/filp/whoops/src/Whoops/Handler/JsonResponseHandler.php
new file mode 100644
index 00000000..2966d385
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Handler/JsonResponseHandler.php
@@ -0,0 +1,88 @@
+
+ */
+
+namespace Whoops\Handler;
+
+use Whoops\Exception\Formatter;
+
+/**
+ * Catches an exception and converts it to a JSON
+ * response. Additionally can also return exception
+ * frames for consumption by an API.
+ */
+class JsonResponseHandler extends Handler
+{
+ /**
+ * @var bool
+ */
+ private $returnFrames = false;
+
+ /**
+ * @var bool
+ */
+ private $jsonApi = false;
+
+ /**
+ * Returns errors[[]] instead of error[] to be in compliance with the json:api spec
+ * @param bool $jsonApi Default is false
+ * @return static
+ */
+ public function setJsonApi($jsonApi = false)
+ {
+ $this->jsonApi = (bool) $jsonApi;
+ return $this;
+ }
+
+ /**
+ * @param bool|null $returnFrames
+ * @return bool|static
+ */
+ public function addTraceToOutput($returnFrames = null)
+ {
+ if (func_num_args() == 0) {
+ return $this->returnFrames;
+ }
+
+ $this->returnFrames = (bool) $returnFrames;
+ return $this;
+ }
+
+ /**
+ * @return int
+ */
+ public function handle()
+ {
+ if ($this->jsonApi === true) {
+ $response = [
+ 'errors' => [
+ Formatter::formatExceptionAsDataArray(
+ $this->getInspector(),
+ $this->addTraceToOutput()
+ ),
+ ]
+ ];
+ } else {
+ $response = [
+ 'error' => Formatter::formatExceptionAsDataArray(
+ $this->getInspector(),
+ $this->addTraceToOutput()
+ ),
+ ];
+ }
+
+ echo json_encode($response, defined('JSON_PARTIAL_OUTPUT_ON_ERROR') ? JSON_PARTIAL_OUTPUT_ON_ERROR : 0);
+
+ return Handler::QUIT;
+ }
+
+ /**
+ * @return string
+ */
+ public function contentType()
+ {
+ return 'application/json';
+ }
+}
diff --git a/vendor/filp/whoops/src/Whoops/Handler/PlainTextHandler.php b/vendor/filp/whoops/src/Whoops/Handler/PlainTextHandler.php
new file mode 100644
index 00000000..6c148aa9
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Handler/PlainTextHandler.php
@@ -0,0 +1,359 @@
+
+* Plaintext handler for command line and logs.
+* @author Pierre-Yves Landuré
+*/
+
+namespace Whoops\Handler;
+
+use InvalidArgumentException;
+use Psr\Log\LoggerInterface;
+use Whoops\Exception\Frame;
+
+/**
+* Handler outputing plaintext error messages. Can be used
+* directly, or will be instantiated automagically by Whoops\Run
+* if passed to Run::pushHandler
+*/
+class PlainTextHandler extends Handler
+{
+ const VAR_DUMP_PREFIX = ' | ';
+
+ /**
+ * @var \Psr\Log\LoggerInterface
+ */
+ protected $logger;
+
+ /**
+ * @var callable
+ */
+ protected $dumper;
+
+ /**
+ * @var bool
+ */
+ private $addTraceToOutput = true;
+
+ /**
+ * @var bool|integer
+ */
+ private $addTraceFunctionArgsToOutput = false;
+
+ /**
+ * @var integer
+ */
+ private $traceFunctionArgsOutputLimit = 1024;
+
+ /**
+ * @var bool
+ */
+ private $addPreviousToOutput = true;
+
+ /**
+ * @var bool
+ */
+ private $loggerOnly = false;
+
+ /**
+ * Constructor.
+ * @throws InvalidArgumentException If argument is not null or a LoggerInterface
+ * @param \Psr\Log\LoggerInterface|null $logger
+ */
+ public function __construct($logger = null)
+ {
+ $this->setLogger($logger);
+ }
+
+ /**
+ * Set the output logger interface.
+ * @throws InvalidArgumentException If argument is not null or a LoggerInterface
+ * @param \Psr\Log\LoggerInterface|null $logger
+ */
+ public function setLogger($logger = null)
+ {
+ if (! (is_null($logger)
+ || $logger instanceof LoggerInterface)) {
+ throw new InvalidArgumentException(
+ 'Argument to ' . __METHOD__ .
+ " must be a valid Logger Interface (aka. Monolog), " .
+ get_class($logger) . ' given.'
+ );
+ }
+
+ $this->logger = $logger;
+ }
+
+ /**
+ * @return \Psr\Log\LoggerInterface|null
+ */
+ public function getLogger()
+ {
+ return $this->logger;
+ }
+
+ /**
+ * Set var dumper callback function.
+ *
+ * @param callable $dumper
+ * @return static
+ */
+ public function setDumper(callable $dumper)
+ {
+ $this->dumper = $dumper;
+ return $this;
+ }
+
+ /**
+ * Add error trace to output.
+ * @param bool|null $addTraceToOutput
+ * @return bool|static
+ */
+ public function addTraceToOutput($addTraceToOutput = null)
+ {
+ if (func_num_args() == 0) {
+ return $this->addTraceToOutput;
+ }
+
+ $this->addTraceToOutput = (bool) $addTraceToOutput;
+ return $this;
+ }
+
+ /**
+ * Add previous exceptions to output.
+ * @param bool|null $addPreviousToOutput
+ * @return bool|static
+ */
+ public function addPreviousToOutput($addPreviousToOutput = null)
+ {
+ if (func_num_args() == 0) {
+ return $this->addPreviousToOutput;
+ }
+
+ $this->addPreviousToOutput = (bool) $addPreviousToOutput;
+ return $this;
+ }
+
+ /**
+ * Add error trace function arguments to output.
+ * Set to True for all frame args, or integer for the n first frame args.
+ * @param bool|integer|null $addTraceFunctionArgsToOutput
+ * @return static|bool|integer
+ */
+ public function addTraceFunctionArgsToOutput($addTraceFunctionArgsToOutput = null)
+ {
+ if (func_num_args() == 0) {
+ return $this->addTraceFunctionArgsToOutput;
+ }
+
+ if (! is_integer($addTraceFunctionArgsToOutput)) {
+ $this->addTraceFunctionArgsToOutput = (bool) $addTraceFunctionArgsToOutput;
+ } else {
+ $this->addTraceFunctionArgsToOutput = $addTraceFunctionArgsToOutput;
+ }
+ return $this;
+ }
+
+ /**
+ * Set the size limit in bytes of frame arguments var_dump output.
+ * If the limit is reached, the var_dump output is discarded.
+ * Prevent memory limit errors.
+ * @var integer
+ * @return static
+ */
+ public function setTraceFunctionArgsOutputLimit($traceFunctionArgsOutputLimit)
+ {
+ $this->traceFunctionArgsOutputLimit = (integer) $traceFunctionArgsOutputLimit;
+ return $this;
+ }
+
+ /**
+ * Create plain text response and return it as a string
+ * @return string
+ */
+ public function generateResponse()
+ {
+ $exception = $this->getException();
+ $message = $this->getExceptionOutput($exception);
+
+ if ($this->addPreviousToOutput) {
+ $previous = $exception->getPrevious();
+ while ($previous) {
+ $message .= "\n\nCaused by\n" . $this->getExceptionOutput($previous);
+ $previous = $previous->getPrevious();
+ }
+ }
+
+
+ return $message . $this->getTraceOutput() . "\n";
+ }
+
+ /**
+ * Get the size limit in bytes of frame arguments var_dump output.
+ * If the limit is reached, the var_dump output is discarded.
+ * Prevent memory limit errors.
+ * @return integer
+ */
+ public function getTraceFunctionArgsOutputLimit()
+ {
+ return $this->traceFunctionArgsOutputLimit;
+ }
+
+ /**
+ * Only output to logger.
+ * @param bool|null $loggerOnly
+ * @return static|bool
+ */
+ public function loggerOnly($loggerOnly = null)
+ {
+ if (func_num_args() == 0) {
+ return $this->loggerOnly;
+ }
+
+ $this->loggerOnly = (bool) $loggerOnly;
+ return $this;
+ }
+
+ /**
+ * Test if handler can output to stdout.
+ * @return bool
+ */
+ private function canOutput()
+ {
+ return !$this->loggerOnly();
+ }
+
+ /**
+ * Get the frame args var_dump.
+ * @param \Whoops\Exception\Frame $frame [description]
+ * @param integer $line [description]
+ * @return string
+ */
+ private function getFrameArgsOutput(Frame $frame, $line)
+ {
+ if ($this->addTraceFunctionArgsToOutput() === false
+ || $this->addTraceFunctionArgsToOutput() < $line) {
+ return '';
+ }
+
+ // Dump the arguments:
+ ob_start();
+ $this->dump($frame->getArgs());
+ if (ob_get_length() > $this->getTraceFunctionArgsOutputLimit()) {
+ // The argument var_dump is to big.
+ // Discarded to limit memory usage.
+ ob_clean();
+ return sprintf(
+ "\n%sArguments dump length greater than %d Bytes. Discarded.",
+ self::VAR_DUMP_PREFIX,
+ $this->getTraceFunctionArgsOutputLimit()
+ );
+ }
+
+ return sprintf(
+ "\n%s",
+ preg_replace('/^/m', self::VAR_DUMP_PREFIX, ob_get_clean())
+ );
+ }
+
+ /**
+ * Dump variable.
+ *
+ * @param mixed $var
+ * @return void
+ */
+ protected function dump($var)
+ {
+ if ($this->dumper) {
+ call_user_func($this->dumper, $var);
+ } else {
+ var_dump($var);
+ }
+ }
+
+ /**
+ * Get the exception trace as plain text.
+ * @return string
+ */
+ private function getTraceOutput()
+ {
+ if (! $this->addTraceToOutput()) {
+ return '';
+ }
+ $inspector = $this->getInspector();
+ $frames = $inspector->getFrames();
+
+ $response = "\nStack trace:";
+
+ $line = 1;
+ foreach ($frames as $frame) {
+ /** @var Frame $frame */
+ $class = $frame->getClass();
+
+ $template = "\n%3d. %s->%s() %s:%d%s";
+ if (! $class) {
+ // Remove method arrow (->) from output.
+ $template = "\n%3d. %s%s() %s:%d%s";
+ }
+
+ $response .= sprintf(
+ $template,
+ $line,
+ $class,
+ $frame->getFunction(),
+ $frame->getFile(),
+ $frame->getLine(),
+ $this->getFrameArgsOutput($frame, $line)
+ );
+
+ $line++;
+ }
+
+ return $response;
+ }
+
+ /**
+ * Get the exception as plain text.
+ * @param \Throwable $exception
+ * @return string
+ */
+ private function getExceptionOutput($exception)
+ {
+ return sprintf(
+ "%s: %s in file %s on line %d",
+ get_class($exception),
+ $exception->getMessage(),
+ $exception->getFile(),
+ $exception->getLine()
+ );
+ }
+
+ /**
+ * @return int
+ */
+ public function handle()
+ {
+ $response = $this->generateResponse();
+
+ if ($this->getLogger()) {
+ $this->getLogger()->error($response);
+ }
+
+ if (! $this->canOutput()) {
+ return Handler::DONE;
+ }
+
+ echo $response;
+
+ return Handler::QUIT;
+ }
+
+ /**
+ * @return string
+ */
+ public function contentType()
+ {
+ return 'text/plain';
+ }
+}
diff --git a/vendor/filp/whoops/src/Whoops/Handler/PrettyPageHandler.php b/vendor/filp/whoops/src/Whoops/Handler/PrettyPageHandler.php
new file mode 100644
index 00000000..c26b80bb
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Handler/PrettyPageHandler.php
@@ -0,0 +1,827 @@
+
+ */
+
+namespace Whoops\Handler;
+
+use InvalidArgumentException;
+use RuntimeException;
+use Symfony\Component\VarDumper\Cloner\AbstractCloner;
+use Symfony\Component\VarDumper\Cloner\VarCloner;
+use UnexpectedValueException;
+use Whoops\Exception\Formatter;
+use Whoops\Util\Misc;
+use Whoops\Util\TemplateHelper;
+
+class PrettyPageHandler extends Handler
+{
+ const EDITOR_SUBLIME = "sublime";
+ const EDITOR_TEXTMATE = "textmate";
+ const EDITOR_EMACS = "emacs";
+ const EDITOR_MACVIM = "macvim";
+ const EDITOR_PHPSTORM = "phpstorm";
+ const EDITOR_IDEA = "idea";
+ const EDITOR_VSCODE = "vscode";
+ const EDITOR_ATOM = "atom";
+ const EDITOR_ESPRESSO = "espresso";
+ const EDITOR_XDEBUG = "xdebug";
+
+ /**
+ * Search paths to be scanned for resources.
+ *
+ * Stored in the reverse order they're declared.
+ *
+ * @var array
+ */
+ private $searchPaths = [];
+
+ /**
+ * Fast lookup cache for known resource locations.
+ *
+ * @var array
+ */
+ private $resourceCache = [];
+
+ /**
+ * The name of the custom css file.
+ *
+ * @var string|null
+ */
+ private $customCss = null;
+
+ /**
+ * The name of the custom js file.
+ *
+ * @var string|null
+ */
+ private $customJs = null;
+
+ /**
+ * @var array[]
+ */
+ private $extraTables = [];
+
+ /**
+ * @var bool
+ */
+ private $handleUnconditionally = false;
+
+ /**
+ * @var string
+ */
+ private $pageTitle = "Whoops! There was an error.";
+
+ /**
+ * @var array[]
+ */
+ private $applicationPaths;
+
+ /**
+ * @var array[]
+ */
+ private $blacklist = [
+ '_GET' => [],
+ '_POST' => [],
+ '_FILES' => [],
+ '_COOKIE' => [],
+ '_SESSION' => [],
+ '_SERVER' => [],
+ '_ENV' => [],
+ ];
+
+ /**
+ * An identifier for a known IDE/text editor.
+ *
+ * Either a string, or a calalble that resolves a string, that can be used
+ * to open a given file in an editor. If the string contains the special
+ * substrings %file or %line, they will be replaced with the correct data.
+ *
+ * @example
+ * "txmt://open?url=%file&line=%line"
+ *
+ * @var callable|string $editor
+ */
+ protected $editor;
+
+ /**
+ * A list of known editor strings.
+ *
+ * @var array
+ */
+ protected $editors = [
+ "sublime" => "subl://open?url=file://%file&line=%line",
+ "textmate" => "txmt://open?url=file://%file&line=%line",
+ "emacs" => "emacs://open?url=file://%file&line=%line",
+ "macvim" => "mvim://open/?url=file://%file&line=%line",
+ "phpstorm" => "phpstorm://open?file=%file&line=%line",
+ "idea" => "idea://open?file=%file&line=%line",
+ "vscode" => "vscode://file/%file:%line",
+ "atom" => "atom://core/open/file?filename=%file&line=%line",
+ "espresso" => "x-espresso://open?filepath=%file&lines=%line",
+ ];
+
+ /**
+ * @var TemplateHelper
+ */
+ protected $templateHelper;
+
+ /**
+ * Constructor.
+ *
+ * @return void
+ */
+ public function __construct()
+ {
+ if (ini_get('xdebug.file_link_format') || extension_loaded('xdebug')) {
+ // Register editor using xdebug's file_link_format option.
+ $this->editors['xdebug'] = function ($file, $line) {
+ return str_replace(['%f', '%l'], [$file, $line], ini_get('xdebug.file_link_format'));
+ };
+
+ // If xdebug is available, use it as default editor.
+ $this->setEditor('xdebug');
+ }
+
+ // Add the default, local resource search path:
+ $this->searchPaths[] = __DIR__ . "/../Resources";
+
+ // blacklist php provided auth based values
+ $this->blacklist('_SERVER', 'PHP_AUTH_PW');
+
+ $this->templateHelper = new TemplateHelper();
+
+ if (class_exists('Symfony\Component\VarDumper\Cloner\VarCloner')) {
+ $cloner = new VarCloner();
+ // Only dump object internals if a custom caster exists for performance reasons
+ // https://github.com/filp/whoops/pull/404
+ $cloner->addCasters(['*' => function ($obj, $a, $stub, $isNested, $filter = 0) {
+ $class = $stub->class;
+ $classes = [$class => $class] + class_parents($obj) + class_implements($obj);
+
+ foreach ($classes as $class) {
+ if (isset(AbstractCloner::$defaultCasters[$class])) {
+ return $a;
+ }
+ }
+
+ // Remove all internals
+ return [];
+ }]);
+ $this->templateHelper->setCloner($cloner);
+ }
+ }
+
+ /**
+ * @return int|null
+ */
+ public function handle()
+ {
+ if (!$this->handleUnconditionally()) {
+ // Check conditions for outputting HTML:
+ // @todo: Make this more robust
+ if (PHP_SAPI === 'cli') {
+ // Help users who have been relying on an internal test value
+ // fix their code to the proper method
+ if (isset($_ENV['whoops-test'])) {
+ throw new \Exception(
+ 'Use handleUnconditionally instead of whoops-test'
+ .' environment variable'
+ );
+ }
+
+ return Handler::DONE;
+ }
+ }
+
+ $templateFile = $this->getResource("views/layout.html.php");
+ $cssFile = $this->getResource("css/whoops.base.css");
+ $zeptoFile = $this->getResource("js/zepto.min.js");
+ $prettifyFile = $this->getResource("js/prettify.min.js");
+ $clipboard = $this->getResource("js/clipboard.min.js");
+ $jsFile = $this->getResource("js/whoops.base.js");
+
+ if ($this->customCss) {
+ $customCssFile = $this->getResource($this->customCss);
+ }
+
+ if ($this->customJs) {
+ $customJsFile = $this->getResource($this->customJs);
+ }
+
+ $inspector = $this->getInspector();
+ $frames = $this->getExceptionFrames();
+ $code = $this->getExceptionCode();
+
+ // List of variables that will be passed to the layout template.
+ $vars = [
+ "page_title" => $this->getPageTitle(),
+
+ // @todo: Asset compiler
+ "stylesheet" => file_get_contents($cssFile),
+ "zepto" => file_get_contents($zeptoFile),
+ "prettify" => file_get_contents($prettifyFile),
+ "clipboard" => file_get_contents($clipboard),
+ "javascript" => file_get_contents($jsFile),
+
+ // Template paths:
+ "header" => $this->getResource("views/header.html.php"),
+ "header_outer" => $this->getResource("views/header_outer.html.php"),
+ "frame_list" => $this->getResource("views/frame_list.html.php"),
+ "frames_description" => $this->getResource("views/frames_description.html.php"),
+ "frames_container" => $this->getResource("views/frames_container.html.php"),
+ "panel_details" => $this->getResource("views/panel_details.html.php"),
+ "panel_details_outer" => $this->getResource("views/panel_details_outer.html.php"),
+ "panel_left" => $this->getResource("views/panel_left.html.php"),
+ "panel_left_outer" => $this->getResource("views/panel_left_outer.html.php"),
+ "frame_code" => $this->getResource("views/frame_code.html.php"),
+ "env_details" => $this->getResource("views/env_details.html.php"),
+
+ "title" => $this->getPageTitle(),
+ "name" => explode("\\", $inspector->getExceptionName()),
+ "message" => $inspector->getExceptionMessage(),
+ "previousMessages" => $inspector->getPreviousExceptionMessages(),
+ "docref_url" => $inspector->getExceptionDocrefUrl(),
+ "code" => $code,
+ "previousCodes" => $inspector->getPreviousExceptionCodes(),
+ "plain_exception" => Formatter::formatExceptionPlain($inspector),
+ "frames" => $frames,
+ "has_frames" => !!count($frames),
+ "handler" => $this,
+ "handlers" => $this->getRun()->getHandlers(),
+
+ "active_frames_tab" => count($frames) && $frames->offsetGet(0)->isApplication() ? 'application' : 'all',
+ "has_frames_tabs" => $this->getApplicationPaths(),
+
+ "tables" => [
+ "GET Data" => $this->masked($_GET, '_GET'),
+ "POST Data" => $this->masked($_POST, '_POST'),
+ "Files" => isset($_FILES) ? $this->masked($_FILES, '_FILES') : [],
+ "Cookies" => $this->masked($_COOKIE, '_COOKIE'),
+ "Session" => isset($_SESSION) ? $this->masked($_SESSION, '_SESSION') : [],
+ "Server/Request Data" => $this->masked($_SERVER, '_SERVER'),
+ "Environment Variables" => $this->masked($_ENV, '_ENV'),
+ ],
+ ];
+
+ if (isset($customCssFile)) {
+ $vars["stylesheet"] .= file_get_contents($customCssFile);
+ }
+
+ if (isset($customJsFile)) {
+ $vars["javascript"] .= file_get_contents($customJsFile);
+ }
+
+ // Add extra entries list of data tables:
+ // @todo: Consolidate addDataTable and addDataTableCallback
+ $extraTables = array_map(function ($table) use ($inspector) {
+ return $table instanceof \Closure ? $table($inspector) : $table;
+ }, $this->getDataTables());
+ $vars["tables"] = array_merge($extraTables, $vars["tables"]);
+
+ $plainTextHandler = new PlainTextHandler();
+ $plainTextHandler->setException($this->getException());
+ $plainTextHandler->setInspector($this->getInspector());
+ $vars["preface"] = "";
+
+ $this->templateHelper->setVariables($vars);
+ $this->templateHelper->render($templateFile);
+
+ return Handler::QUIT;
+ }
+
+ /**
+ * Get the stack trace frames of the exception currently being handled.
+ *
+ * @return \Whoops\Exception\FrameCollection
+ */
+ protected function getExceptionFrames()
+ {
+ $frames = $this->getInspector()->getFrames();
+
+ if ($this->getApplicationPaths()) {
+ foreach ($frames as $frame) {
+ foreach ($this->getApplicationPaths() as $path) {
+ if (strpos($frame->getFile(), $path) === 0) {
+ $frame->setApplication(true);
+ break;
+ }
+ }
+ }
+ }
+
+ return $frames;
+ }
+
+ /**
+ * Get the code of the exception currently being handled.
+ *
+ * @return string
+ */
+ protected function getExceptionCode()
+ {
+ $exception = $this->getException();
+
+ $code = $exception->getCode();
+ if ($exception instanceof \ErrorException) {
+ // ErrorExceptions wrap the php-error types within the 'severity' property
+ $code = Misc::translateErrorCode($exception->getSeverity());
+ }
+
+ return (string) $code;
+ }
+
+ /**
+ * @return string
+ */
+ public function contentType()
+ {
+ return 'text/html';
+ }
+
+ /**
+ * Adds an entry to the list of tables displayed in the template.
+ *
+ * The expected data is a simple associative array. Any nested arrays
+ * will be flattened with `print_r`.
+ *
+ * @param string $label
+ * @param array $data
+ *
+ * @return static
+ */
+ public function addDataTable($label, array $data)
+ {
+ $this->extraTables[$label] = $data;
+ return $this;
+ }
+
+ /**
+ * Lazily adds an entry to the list of tables displayed in the table.
+ *
+ * The supplied callback argument will be called when the error is
+ * rendered, it should produce a simple associative array. Any nested
+ * arrays will be flattened with `print_r`.
+ *
+ * @param string $label
+ * @param callable $callback Callable returning an associative array
+ *
+ * @throws InvalidArgumentException If $callback is not callable
+ *
+ * @return static
+ */
+ public function addDataTableCallback($label, /* callable */ $callback)
+ {
+ if (!is_callable($callback)) {
+ throw new InvalidArgumentException('Expecting callback argument to be callable');
+ }
+
+ $this->extraTables[$label] = function (\Whoops\Exception\Inspector $inspector = null) use ($callback) {
+ try {
+ $result = call_user_func($callback, $inspector);
+
+ // Only return the result if it can be iterated over by foreach().
+ return is_array($result) || $result instanceof \Traversable ? $result : [];
+ } catch (\Exception $e) {
+ // Don't allow failure to break the rendering of the original exception.
+ return [];
+ }
+ };
+
+ return $this;
+ }
+
+ /**
+ * Returns all the extra data tables registered with this handler.
+ *
+ * Optionally accepts a 'label' parameter, to only return the data table
+ * under that label.
+ *
+ * @param string|null $label
+ *
+ * @return array[]|callable
+ */
+ public function getDataTables($label = null)
+ {
+ if ($label !== null) {
+ return isset($this->extraTables[$label]) ?
+ $this->extraTables[$label] : [];
+ }
+
+ return $this->extraTables;
+ }
+
+ /**
+ * Set whether to handle unconditionally.
+ *
+ * Allows to disable all attempts to dynamically decide whether to handle
+ * or return prematurely. Set this to ensure that the handler will perform,
+ * no matter what.
+ *
+ * @param bool|null $value
+ *
+ * @return bool|static
+ */
+ public function handleUnconditionally($value = null)
+ {
+ if (func_num_args() == 0) {
+ return $this->handleUnconditionally;
+ }
+
+ $this->handleUnconditionally = (bool) $value;
+ return $this;
+ }
+
+ /**
+ * Adds an editor resolver.
+ *
+ * Either a string, or a closure that resolves a string, that can be used
+ * to open a given file in an editor. If the string contains the special
+ * substrings %file or %line, they will be replaced with the correct data.
+ *
+ * @example
+ * $run->addEditor('macvim', "mvim://open?url=file://%file&line=%line")
+ * @example
+ * $run->addEditor('remove-it', function($file, $line) {
+ * unlink($file);
+ * return "http://stackoverflow.com";
+ * });
+ *
+ * @param string $identifier
+ * @param string|callable $resolver
+ *
+ * @return static
+ */
+ public function addEditor($identifier, $resolver)
+ {
+ $this->editors[$identifier] = $resolver;
+ return $this;
+ }
+
+ /**
+ * Set the editor to use to open referenced files.
+ *
+ * Pass either the name of a configured editor, or a closure that directly
+ * resolves an editor string.
+ *
+ * @example
+ * $run->setEditor(function($file, $line) { return "file:///{$file}"; });
+ * @example
+ * $run->setEditor('sublime');
+ *
+ * @param string|callable $editor
+ *
+ * @throws InvalidArgumentException If invalid argument identifier provided
+ *
+ * @return static
+ */
+ public function setEditor($editor)
+ {
+ if (!is_callable($editor) && !isset($this->editors[$editor])) {
+ throw new InvalidArgumentException(
+ "Unknown editor identifier: $editor. Known editors:" .
+ implode(",", array_keys($this->editors))
+ );
+ }
+
+ $this->editor = $editor;
+ return $this;
+ }
+
+ /**
+ * Get the editor href for a given file and line, if available.
+ *
+ * @param string $filePath
+ * @param int $line
+ *
+ * @throws InvalidArgumentException If editor resolver does not return a string
+ *
+ * @return string|bool
+ */
+ public function getEditorHref($filePath, $line)
+ {
+ $editor = $this->getEditor($filePath, $line);
+
+ if (empty($editor)) {
+ return false;
+ }
+
+ // Check that the editor is a string, and replace the
+ // %line and %file placeholders:
+ if (!isset($editor['url']) || !is_string($editor['url'])) {
+ throw new UnexpectedValueException(
+ __METHOD__ . " should always resolve to a string or a valid editor array; got something else instead."
+ );
+ }
+
+ $editor['url'] = str_replace("%line", rawurlencode($line), $editor['url']);
+ $editor['url'] = str_replace("%file", rawurlencode($filePath), $editor['url']);
+
+ return $editor['url'];
+ }
+
+ /**
+ * Determine if the editor link should act as an Ajax request.
+ *
+ * @param string $filePath
+ * @param int $line
+ *
+ * @throws UnexpectedValueException If editor resolver does not return a boolean
+ *
+ * @return bool
+ */
+ public function getEditorAjax($filePath, $line)
+ {
+ $editor = $this->getEditor($filePath, $line);
+
+ // Check that the ajax is a bool
+ if (!isset($editor['ajax']) || !is_bool($editor['ajax'])) {
+ throw new UnexpectedValueException(
+ __METHOD__ . " should always resolve to a bool; got something else instead."
+ );
+ }
+ return $editor['ajax'];
+ }
+
+ /**
+ * Determines both the editor and if ajax should be used.
+ *
+ * @param string $filePath
+ * @param int $line
+ *
+ * @return array
+ */
+ protected function getEditor($filePath, $line)
+ {
+ if (!$this->editor || (!is_string($this->editor) && !is_callable($this->editor))) {
+ return [];
+ }
+
+ if (is_string($this->editor) && isset($this->editors[$this->editor]) && !is_callable($this->editors[$this->editor])) {
+ return [
+ 'ajax' => false,
+ 'url' => $this->editors[$this->editor],
+ ];
+ }
+
+ if (is_callable($this->editor) || (isset($this->editors[$this->editor]) && is_callable($this->editors[$this->editor]))) {
+ if (is_callable($this->editor)) {
+ $callback = call_user_func($this->editor, $filePath, $line);
+ } else {
+ $callback = call_user_func($this->editors[$this->editor], $filePath, $line);
+ }
+
+ if (empty($callback)) {
+ return [];
+ }
+
+ if (is_string($callback)) {
+ return [
+ 'ajax' => false,
+ 'url' => $callback,
+ ];
+ }
+
+ return [
+ 'ajax' => isset($callback['ajax']) ? $callback['ajax'] : false,
+ 'url' => isset($callback['url']) ? $callback['url'] : $callback,
+ ];
+ }
+
+ return [];
+ }
+
+ /**
+ * Set the page title.
+ *
+ * @param string $title
+ *
+ * @return static
+ */
+ public function setPageTitle($title)
+ {
+ $this->pageTitle = (string) $title;
+ return $this;
+ }
+
+ /**
+ * Get the page title.
+ *
+ * @return string
+ */
+ public function getPageTitle()
+ {
+ return $this->pageTitle;
+ }
+
+ /**
+ * Adds a path to the list of paths to be searched for resources.
+ *
+ * @param string $path
+ *
+ * @throws InvalidArgumentException If $path is not a valid directory
+ *
+ * @return static
+ */
+ public function addResourcePath($path)
+ {
+ if (!is_dir($path)) {
+ throw new InvalidArgumentException(
+ "'$path' is not a valid directory"
+ );
+ }
+
+ array_unshift($this->searchPaths, $path);
+ return $this;
+ }
+
+ /**
+ * Adds a custom css file to be loaded.
+ *
+ * @param string|null $name
+ *
+ * @return static
+ */
+ public function addCustomCss($name)
+ {
+ $this->customCss = $name;
+ return $this;
+ }
+
+ /**
+ * Adds a custom js file to be loaded.
+ *
+ * @param string|null $name
+ *
+ * @return static
+ */
+ public function addCustomJs($name)
+ {
+ $this->customJs = $name;
+ return $this;
+ }
+
+ /**
+ * @return array
+ */
+ public function getResourcePaths()
+ {
+ return $this->searchPaths;
+ }
+
+ /**
+ * Finds a resource, by its relative path, in all available search paths.
+ *
+ * The search is performed starting at the last search path, and all the
+ * way back to the first, enabling a cascading-type system of overrides for
+ * all resources.
+ *
+ * @param string $resource
+ *
+ * @throws RuntimeException If resource cannot be found in any of the available paths
+ *
+ * @return string
+ */
+ protected function getResource($resource)
+ {
+ // If the resource was found before, we can speed things up
+ // by caching its absolute, resolved path:
+ if (isset($this->resourceCache[$resource])) {
+ return $this->resourceCache[$resource];
+ }
+
+ // Search through available search paths, until we find the
+ // resource we're after:
+ foreach ($this->searchPaths as $path) {
+ $fullPath = $path . "/$resource";
+
+ if (is_file($fullPath)) {
+ // Cache the result:
+ $this->resourceCache[$resource] = $fullPath;
+ return $fullPath;
+ }
+ }
+
+ // If we got this far, nothing was found.
+ throw new RuntimeException(
+ "Could not find resource '$resource' in any resource paths."
+ . "(searched: " . join(", ", $this->searchPaths). ")"
+ );
+ }
+
+ /**
+ * @deprecated
+ *
+ * @return string
+ */
+ public function getResourcesPath()
+ {
+ $allPaths = $this->getResourcePaths();
+
+ // Compat: return only the first path added
+ return end($allPaths) ?: null;
+ }
+
+ /**
+ * @deprecated
+ *
+ * @param string $resourcesPath
+ *
+ * @return static
+ */
+ public function setResourcesPath($resourcesPath)
+ {
+ $this->addResourcePath($resourcesPath);
+ return $this;
+ }
+
+ /**
+ * Return the application paths.
+ *
+ * @return array
+ */
+ public function getApplicationPaths()
+ {
+ return $this->applicationPaths;
+ }
+
+ /**
+ * Set the application paths.
+ *
+ * @param array $applicationPaths
+ *
+ * @return void
+ */
+ public function setApplicationPaths($applicationPaths)
+ {
+ $this->applicationPaths = $applicationPaths;
+ }
+
+ /**
+ * Set the application root path.
+ *
+ * @param string $applicationRootPath
+ *
+ * @return void
+ */
+ public function setApplicationRootPath($applicationRootPath)
+ {
+ $this->templateHelper->setApplicationRootPath($applicationRootPath);
+ }
+
+ /**
+ * blacklist a sensitive value within one of the superglobal arrays.
+ * Alias for the hideSuperglobalKey method.
+ *
+ * @param string $superGlobalName The name of the superglobal array, e.g. '_GET'
+ * @param string $key The key within the superglobal
+ * @see hideSuperglobalKey
+ *
+ * @return static
+ */
+ public function blacklist($superGlobalName, $key)
+ {
+ $this->blacklist[$superGlobalName][] = $key;
+ return $this;
+ }
+
+ /**
+ * Hide a sensitive value within one of the superglobal arrays.
+ *
+ * @param string $superGlobalName The name of the superglobal array, e.g. '_GET'
+ * @param string $key The key within the superglobal
+ * @return static
+ */
+ public function hideSuperglobalKey($superGlobalName, $key)
+ {
+ return $this->blacklist($superGlobalName, $key);
+ }
+
+ /**
+ * Checks all values within the given superGlobal array.
+ *
+ * Blacklisted values will be replaced by a equal length string cointaining
+ * only '*' characters. We intentionally dont rely on $GLOBALS as it
+ * depends on the 'auto_globals_jit' php.ini setting.
+ *
+ * @param array $superGlobal One of the superglobal arrays
+ * @param string $superGlobalName The name of the superglobal array, e.g. '_GET'
+ *
+ * @return array $values without sensitive data
+ */
+ private function masked(array $superGlobal, $superGlobalName)
+ {
+ $blacklisted = $this->blacklist[$superGlobalName];
+
+ $values = $superGlobal;
+
+ foreach ($blacklisted as $key) {
+ if (isset($superGlobal[$key]) && is_string($superGlobal[$key])) {
+ $values[$key] = str_repeat('*', strlen($superGlobal[$key]));
+ }
+ }
+
+ return $values;
+ }
+}
diff --git a/vendor/filp/whoops/src/Whoops/Handler/XmlResponseHandler.php b/vendor/filp/whoops/src/Whoops/Handler/XmlResponseHandler.php
new file mode 100644
index 00000000..d695750a
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Handler/XmlResponseHandler.php
@@ -0,0 +1,107 @@
+
+ */
+
+namespace Whoops\Handler;
+
+use SimpleXMLElement;
+use Whoops\Exception\Formatter;
+
+/**
+ * Catches an exception and converts it to an XML
+ * response. Additionally can also return exception
+ * frames for consumption by an API.
+ */
+class XmlResponseHandler extends Handler
+{
+ /**
+ * @var bool
+ */
+ private $returnFrames = false;
+
+ /**
+ * @param bool|null $returnFrames
+ * @return bool|static
+ */
+ public function addTraceToOutput($returnFrames = null)
+ {
+ if (func_num_args() == 0) {
+ return $this->returnFrames;
+ }
+
+ $this->returnFrames = (bool) $returnFrames;
+ return $this;
+ }
+
+ /**
+ * @return int
+ */
+ public function handle()
+ {
+ $response = [
+ 'error' => Formatter::formatExceptionAsDataArray(
+ $this->getInspector(),
+ $this->addTraceToOutput()
+ ),
+ ];
+
+ echo self::toXml($response);
+
+ return Handler::QUIT;
+ }
+
+ /**
+ * @return string
+ */
+ public function contentType()
+ {
+ return 'application/xml';
+ }
+
+ /**
+ * @param SimpleXMLElement $node Node to append data to, will be modified in place
+ * @param array|\Traversable $data
+ * @return SimpleXMLElement The modified node, for chaining
+ */
+ private static function addDataToNode(\SimpleXMLElement $node, $data)
+ {
+ assert(is_array($data) || $data instanceof Traversable);
+
+ foreach ($data as $key => $value) {
+ if (is_numeric($key)) {
+ // Convert the key to a valid string
+ $key = "unknownNode_". (string) $key;
+ }
+
+ // Delete any char not allowed in XML element names
+ $key = preg_replace('/[^a-z0-9\-\_\.\:]/i', '', $key);
+
+ if (is_array($value)) {
+ $child = $node->addChild($key);
+ self::addDataToNode($child, $value);
+ } else {
+ $value = str_replace('&', '&', print_r($value, true));
+ $node->addChild($key, $value);
+ }
+ }
+
+ return $node;
+ }
+
+ /**
+ * The main function for converting to an XML document.
+ *
+ * @param array|\Traversable $data
+ * @return string XML
+ */
+ private static function toXml($data)
+ {
+ assert(is_array($data) || $data instanceof Traversable);
+
+ $node = simplexml_load_string(" ");
+
+ return self::addDataToNode($node, $data)->asXML();
+ }
+}
diff --git a/vendor/filp/whoops/src/Whoops/Resources/css/whoops.base.css b/vendor/filp/whoops/src/Whoops/Resources/css/whoops.base.css
new file mode 100644
index 00000000..d67499e1
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Resources/css/whoops.base.css
@@ -0,0 +1,604 @@
+body {
+ font: 12px "Helvetica Neue", helvetica, arial, sans-serif;
+ color: #131313;
+ background: #eeeeee;
+ padding:0;
+ margin: 0;
+ max-height: 100%;
+
+ text-rendering: optimizeLegibility;
+}
+ a {
+ text-decoration: none;
+ }
+
+.Whoops.container {
+ position: relative;
+ z-index: 9999999999;
+}
+
+.panel {
+ overflow-y: scroll;
+ height: 100%;
+ position: fixed;
+ margin: 0;
+ left: 0;
+ top: 0;
+}
+
+.branding {
+ position: absolute;
+ top: 10px;
+ right: 20px;
+ color: #777777;
+ font-size: 10px;
+ z-index: 100;
+}
+ .branding a {
+ color: #e95353;
+ }
+
+header {
+ color: white;
+ box-sizing: border-box;
+ background-color: #2a2a2a;
+ padding: 35px 40px;
+ max-height: 180px;
+ overflow: hidden;
+ transition: 0.5s;
+}
+
+ header.header-expand {
+ max-height: 1000px;
+ }
+
+ .exc-title {
+ margin: 0;
+ color: #bebebe;
+ font-size: 14px;
+ }
+ .exc-title-primary, .exc-title-secondary {
+ color: #e95353;
+ }
+
+ .exc-message {
+ font-size: 20px;
+ word-wrap: break-word;
+ margin: 4px 0 0 0;
+ color: white;
+ }
+ .exc-message span {
+ display: block;
+ }
+ .exc-message-empty-notice {
+ color: #a29d9d;
+ font-weight: 300;
+ }
+
+.prev-exc-title {
+ margin: 10px 0;
+}
+
+.prev-exc-title + ul {
+ margin: 0;
+ padding: 0 0 0 20px;
+ line-height: 12px;
+}
+
+.prev-exc-title + ul li {
+ font: 12px "Helvetica Neue", helvetica, arial, sans-serif;
+}
+
+.prev-exc-title + ul li .prev-exc-code {
+ display: inline-block;
+ color: #bebebe;
+}
+
+.details-container {
+ left: 30%;
+ width: 70%;
+ background: #fafafa;
+}
+ .details {
+ padding: 5px;
+ }
+
+ .details-heading {
+ color: #4288CE;
+ font-weight: 300;
+ padding-bottom: 10px;
+ margin-bottom: 10px;
+ border-bottom: 1px solid rgba(0, 0, 0, .1);
+ }
+
+ .details pre.sf-dump {
+ white-space: pre;
+ word-wrap: inherit;
+ }
+
+ .details pre.sf-dump,
+ .details pre.sf-dump .sf-dump-num,
+ .details pre.sf-dump .sf-dump-const,
+ .details pre.sf-dump .sf-dump-str,
+ .details pre.sf-dump .sf-dump-note,
+ .details pre.sf-dump .sf-dump-ref,
+ .details pre.sf-dump .sf-dump-public,
+ .details pre.sf-dump .sf-dump-protected,
+ .details pre.sf-dump .sf-dump-private,
+ .details pre.sf-dump .sf-dump-meta,
+ .details pre.sf-dump .sf-dump-key,
+ .details pre.sf-dump .sf-dump-index {
+ color: #463C54;
+ }
+
+.left-panel {
+ width: 30%;
+ background: #ded8d8;
+}
+
+ .frames-description {
+ background: rgba(0, 0, 0, .05);
+ padding: 8px 15px;
+ color: #a29d9d;
+ font-size: 11px;
+ }
+
+ .frames-description.frames-description-application {
+ text-align: center;
+ font-size: 12px;
+ }
+ .frames-container.frames-container-application .frame:not(.frame-application) {
+ display: none;
+ }
+
+ .frames-tab {
+ color: #a29d9d;
+ display: inline-block;
+ padding: 4px 8px;
+ margin: 0 2px;
+ border-radius: 3px;
+ }
+
+ .frames-tab.frames-tab-active {
+ background-color: #2a2a2a;
+ color: #bebebe;
+ }
+
+ .frame {
+ padding: 14px;
+ cursor: pointer;
+ transition: all 0.1s ease;
+ background: #eeeeee;
+ }
+ .frame:not(:last-child) {
+ border-bottom: 1px solid rgba(0, 0, 0, .05);
+ }
+
+ .frame.active {
+ box-shadow: inset -5px 0 0 0 #4288CE;
+ color: #4288CE;
+ }
+
+ .frame:not(.active):hover {
+ background: #BEE9EA;
+ }
+
+ .frame-method-info {
+ margin-bottom: 10px;
+ }
+
+ .frame-class, .frame-function, .frame-index {
+ font-size: 14px;
+ }
+
+ .frame-index {
+ float: left;
+ }
+
+ .frame-method-info {
+ margin-left: 24px;
+ }
+
+ .frame-index {
+ font-size: 11px;
+ color: #a29d9d;
+ background-color: rgba(0, 0, 0, .05);
+ height: 18px;
+ width: 18px;
+ line-height: 18px;
+ border-radius: 5px;
+ padding: 0 1px 0 1px;
+ text-align: center;
+ display: inline-block;
+ }
+
+ .frame-application .frame-index {
+ background-color: #2a2a2a;
+ color: #bebebe;
+ }
+
+ .frame-file {
+ font-family: "Inconsolata", "Fira Mono", "Source Code Pro", Monaco, Consolas, "Lucida Console", monospace;
+ color: #a29d9d;
+ }
+
+ .frame-file .editor-link {
+ color: #a29d9d;
+ }
+
+ .frame-line {
+ font-weight: bold;
+ }
+
+ .frame-line:before {
+ content: ":";
+ }
+
+ .frame-code {
+ padding: 5px;
+ background: #303030;
+ display: none;
+ }
+
+ .frame-code.active {
+ display: block;
+ }
+
+ .frame-code .frame-file {
+ color: #a29d9d;
+ padding: 12px 6px;
+
+ border-bottom: none;
+ }
+
+ .code-block {
+ padding: 10px;
+ margin: 0;
+ border-radius: 6px;
+ box-shadow: 0 3px 0 rgba(0, 0, 0, .05),
+ 0 10px 30px rgba(0, 0, 0, .05),
+ inset 0 0 1px 0 rgba(255, 255, 255, .07);
+ -moz-tab-size: 4;
+ -o-tab-size: 4;
+ tab-size: 4;
+ }
+
+ .linenums {
+ margin: 0;
+ margin-left: 10px;
+ }
+
+ .frame-comments {
+ border-top: none;
+ margin-top: 15px;
+
+ font-size: 12px;
+ }
+
+ .frame-comments.empty {
+ }
+
+ .frame-comments.empty:before {
+ content: "No comments for this stack frame.";
+ font-weight: 300;
+ color: #a29d9d;
+ }
+
+ .frame-comment {
+ padding: 10px;
+ color: #e3e3e3;
+ border-radius: 6px;
+ background-color: rgba(255, 255, 255, .05);
+ }
+ .frame-comment a {
+ font-weight: bold;
+ text-decoration: none;
+ }
+ .frame-comment a:hover {
+ color: #4bb1b1;
+ }
+
+ .frame-comment:not(:last-child) {
+ border-bottom: 1px dotted rgba(0, 0, 0, .3);
+ }
+
+ .frame-comment-context {
+ font-size: 10px;
+ color: white;
+ }
+
+.delimiter {
+ display: inline-block;
+}
+
+.data-table-container label {
+ font-size: 16px;
+ color: #303030;
+ font-weight: bold;
+ margin: 10px 0;
+
+ display: block;
+
+ margin-bottom: 5px;
+ padding-bottom: 5px;
+}
+ .data-table {
+ width: 100%;
+ margin-bottom: 10px;
+ }
+
+ .data-table tbody {
+ font: 13px "Inconsolata", "Fira Mono", "Source Code Pro", Monaco, Consolas, "Lucida Console", monospace;
+ }
+
+ .data-table thead {
+ display: none;
+ }
+
+ .data-table tr {
+ padding: 5px 0;
+ }
+
+ .data-table td:first-child {
+ width: 20%;
+ min-width: 130px;
+ overflow: hidden;
+ font-weight: bold;
+ color: #463C54;
+ padding-right: 5px;
+
+ }
+
+ .data-table td:last-child {
+ width: 80%;
+ -ms-word-break: break-all;
+ word-break: break-all;
+ word-break: break-word;
+ -webkit-hyphens: auto;
+ -moz-hyphens: auto;
+ hyphens: auto;
+ }
+
+ .data-table span.empty {
+ color: rgba(0, 0, 0, .3);
+ font-weight: 300;
+ }
+ .data-table label.empty {
+ display: inline;
+ }
+
+.handler {
+ padding: 4px 0;
+ font: 14px "Inconsolata", "Fira Mono", "Source Code Pro", Monaco, Consolas, "Lucida Console", monospace;
+}
+
+/* prettify code style
+Uses the Doxy theme as a base */
+pre .str, code .str { color: #BCD42A; } /* string */
+pre .kwd, code .kwd { color: #4bb1b1; font-weight: bold; } /* keyword*/
+pre .com, code .com { color: #888; font-weight: bold; } /* comment */
+pre .typ, code .typ { color: #ef7c61; } /* type */
+pre .lit, code .lit { color: #BCD42A; } /* literal */
+pre .pun, code .pun { color: #fff; font-weight: bold; } /* punctuation */
+pre .pln, code .pln { color: #e9e4e5; } /* plaintext */
+pre .tag, code .tag { color: #4bb1b1; } /* html/xml tag */
+pre .htm, code .htm { color: #dda0dd; } /* html tag */
+pre .xsl, code .xsl { color: #d0a0d0; } /* xslt tag */
+pre .atn, code .atn { color: #ef7c61; font-weight: normal;} /* html/xml attribute name */
+pre .atv, code .atv { color: #bcd42a; } /* html/xml attribute value */
+pre .dec, code .dec { color: #606; } /* decimal */
+pre.code-block, code.code-block, .frame-args.code-block, .frame-args.code-block samp {
+ font-family: "Inconsolata", "Fira Mono", "Source Code Pro", Monaco, Consolas, "Lucida Console", monospace;
+ background: #333;
+ color: #e9e4e5;
+}
+ pre.code-block {
+ white-space: pre-wrap;
+ }
+
+ pre.code-block a, code.code-block a {
+ text-decoration:none;
+ }
+
+ .linenums li {
+ color: #A5A5A5;
+ }
+
+ .linenums li.current{
+ background: rgba(255, 100, 100, .07);
+ }
+ .linenums li.current.active {
+ background: rgba(255, 100, 100, .17);
+ }
+
+pre:not(.prettyprinted) {
+ padding-left: 60px;
+}
+
+#plain-exception {
+ display: none;
+}
+
+.rightButton {
+ cursor: pointer;
+ border: 0;
+ opacity: .8;
+ background: none;
+
+ color: rgba(255, 255, 255, 0.1);
+ box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.1);
+
+ border-radius: 3px;
+
+ outline: none !important;
+}
+
+ .rightButton:hover {
+ box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.3);
+ color: rgba(255, 255, 255, 0.3);
+ }
+
+/* inspired by githubs kbd styles */
+kbd {
+ -moz-border-bottom-colors: none;
+ -moz-border-left-colors: none;
+ -moz-border-right-colors: none;
+ -moz-border-top-colors: none;
+ background-color: #fcfcfc;
+ border-color: #ccc #ccc #bbb;
+ border-image: none;
+ border-style: solid;
+ border-width: 1px;
+ color: #555;
+ display: inline-block;
+ font-size: 11px;
+ line-height: 10px;
+ padding: 3px 5px;
+ vertical-align: middle;
+}
+
+
+/* == Media queries */
+
+/* Expand the spacing in the details section */
+@media (min-width: 1000px) {
+ .details, .frame-code {
+ padding: 20px 40px;
+ }
+
+ .details-container {
+ left: 32%;
+ width: 68%;
+ }
+
+ .frames-container {
+ margin: 5px;
+ }
+
+ .left-panel {
+ width: 32%;
+ }
+}
+
+/* Stack panels */
+@media (max-width: 600px) {
+ .panel {
+ position: static;
+ width: 100%;
+ }
+}
+
+/* Stack details tables */
+@media (max-width: 400px) {
+ .data-table,
+ .data-table tbody,
+ .data-table tbody tr,
+ .data-table tbody td {
+ display: block;
+ width: 100%;
+ }
+
+ .data-table tbody tr:first-child {
+ padding-top: 0;
+ }
+
+ .data-table tbody td:first-child,
+ .data-table tbody td:last-child {
+ padding-left: 0;
+ padding-right: 0;
+ }
+
+ .data-table tbody td:last-child {
+ padding-top: 3px;
+ }
+}
+
+.tooltipped {
+ position: relative
+}
+.tooltipped:after {
+ position: absolute;
+ z-index: 1000000;
+ display: none;
+ padding: 5px 8px;
+ color: #fff;
+ text-align: center;
+ text-decoration: none;
+ text-shadow: none;
+ text-transform: none;
+ letter-spacing: normal;
+ word-wrap: break-word;
+ white-space: pre;
+ pointer-events: none;
+ content: attr(aria-label);
+ background: rgba(0, 0, 0, 0.8);
+ border-radius: 3px;
+ -webkit-font-smoothing: subpixel-antialiased
+}
+.tooltipped:before {
+ position: absolute;
+ z-index: 1000001;
+ display: none;
+ width: 0;
+ height: 0;
+ color: rgba(0, 0, 0, 0.8);
+ pointer-events: none;
+ content: "";
+ border: 5px solid transparent
+}
+.tooltipped:hover:before,
+.tooltipped:hover:after,
+.tooltipped:active:before,
+.tooltipped:active:after,
+.tooltipped:focus:before,
+.tooltipped:focus:after {
+ display: inline-block;
+ text-decoration: none
+}
+.tooltipped-s:after {
+ top: 100%;
+ right: 50%;
+ margin-top: 5px
+}
+.tooltipped-s:before {
+ top: auto;
+ right: 50%;
+ bottom: -5px;
+ margin-right: -5px;
+ border-bottom-color: rgba(0, 0, 0, 0.8)
+}
+
+pre.sf-dump {
+ padding: 0px !important;
+ margin: 0px !important;
+}
+
+.search-for-help {
+ width: 85%;
+ padding: 0;
+ margin: 10px 0;
+ list-style-type: none;
+ display: inline-block;
+}
+ .search-for-help li {
+ display: inline-block;
+ margin-right: 5px;
+ }
+ .search-for-help li:last-child {
+ margin-right: 0;
+ }
+ .search-for-help li a {
+
+ }
+ .search-for-help li a i {
+ width: 16px;
+ height: 16px;
+ overflow: hidden;
+ display: block;
+ }
+ .search-for-help li a svg {
+ fill: #fff;
+ }
+ .search-for-help li a svg path {
+ background-size: contain;
+ }
diff --git a/vendor/filp/whoops/src/Whoops/Resources/js/clipboard.min.js b/vendor/filp/whoops/src/Whoops/Resources/js/clipboard.min.js
new file mode 100644
index 00000000..36a75a46
--- /dev/null
+++ b/vendor/filp/whoops/src/Whoops/Resources/js/clipboard.min.js
@@ -0,0 +1,7 @@
+/*!
+ * clipboard.js v1.5.3
+ * https://zenorocha.github.io/clipboard.js
+ *
+ * Licensed MIT © Zeno Rocha
+ */
+!function(t){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=t();else if("function"==typeof define&&define.amd)define([],t);else{var e;e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this,e.Clipboard=t()}}(function(){var t,e,n;return function t(e,n,r){function o(a,c){if(!n[a]){if(!e[a]){var s="function"==typeof require&&require;if(!c&&s)return s(a,!0);if(i)return i(a,!0);var u=new Error("Cannot find module '"+a+"'");throw u.code="MODULE_NOT_FOUND",u}var l=n[a]={exports:{}};e[a][0].call(l.exports,function(t){var n=e[a][1][t];return o(n?n:t)},l,l.exports,t,e,n,r)}return n[a].exports}for(var i="function"==typeof require&&require,a=0;ar;r++)n[r].fn.apply(n[r].ctx,e);return this},off:function(t,e){var n=this.e||(this.e={}),r=n[t],o=[];if(r&&e)for(var i=0,a=r.length;a>i;i++)r[i].fn!==e&&r[i].fn._!==e&&o.push(r[i]);return o.length?n[t]=o:delete n[t],this}},e.exports=r},{}],8:[function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{"default":t}}function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}n.__esModule=!0;var i=function(){function t(t,e){for(var n=0;n122||(e<65||h>90||d.push([Math.max(65,h)|32,Math.min(e,90)|32]),e<97||h>122||d.push([Math.max(97,h)&-33,Math.min(e,122)&-33]))}}d.sort(function(d,a){return d[0]-a[0]||a[1]-d[1]});a=[];c=[];for(f=0;fh[0]&&(h[1]+1>h[0]&&b.push("-"),b.push(g(h[1])));b.push("]");return b.join("")}function t(d){for(var a=d.source.match(/\[(?:[^\\\]]|\\[\S\s])*]|\\u[\dA-Fa-f]{4}|\\x[\dA-Fa-f]{2}|\\\d+|\\[^\dux]|\(\?[!:=]|[()^]|[^()[\\^]+/g),b=a.length,i=[],c=0,h=0;c=2&&d==="["?a[c]=j(e):d!=="\\"&&(a[c]=e.replace(/[A-Za-z]/g,function(d){d=d.charCodeAt(0);return"["+String.fromCharCode(d&-33,d|32)+"]"}));return a.join("")}for(var z=0,w=!1,k=!1,m=0,b=a.length;m=5&&"lang-"===f.substring(0,
+5))&&!(u&&typeof u[1]==="string"))c=!1,f="src";c||(s[v]=f)}h=b;b+=v.length;if(c){c=u[1];var e=v.indexOf(c),p=e+c.length;u[2]&&(p=v.length-u[2].length,e=p-c.length);f=f.substring(5);E(k+h,v.substring(0,e),g,m);E(k+h+e,c,F(f,c),m);E(k+h+p,v.substring(p),g,m)}else m.push(k+h,f)}a.g=m}var j={},t;(function(){for(var g=a.concat(i),k=[],m={},b=0,o=g.length;b=0;)j[q.charAt(d)]=s;s=s[1];q=""+s;m.hasOwnProperty(q)||(k.push(s),m[q]=r)}k.push(/[\S\s]/);t=
+O(k)})();var z=i.length;return g}function l(a){var i=[],g=[];a.tripleQuotedStrings?i.push(["str",/^(?:'''(?:[^'\\]|\\[\S\s]|''?(?=[^']))*(?:'''|$)|"""(?:[^"\\]|\\[\S\s]|""?(?=[^"]))*(?:"""|$)|'(?:[^'\\]|\\[\S\s])*(?:'|$)|"(?:[^"\\]|\\[\S\s])*(?:"|$))/,r,"'\""]):a.multiLineStrings?i.push(["str",/^(?:'(?:[^'\\]|\\[\S\s])*(?:'|$)|"(?:[^"\\]|\\[\S\s])*(?:"|$)|`(?:[^\\`]|\\[\S\s])*(?:`|$))/,r,"'\"`"]):i.push(["str",/^(?:'(?:[^\n\r'\\]|\\.)*(?:'|$)|"(?:[^\n\r"\\]|\\.)*(?:"|$))/,r,"\"'"]);a.verbatimStrings&&
+g.push(["str",/^@"(?:[^"]|"")*(?:"|$)/,r]);var j=a.hashComments;j&&(a.cStyleComments?(j>1?i.push(["com",/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,r,"#"]):i.push(["com",/^#(?:(?:define|e(?:l|nd)if|else|error|ifn?def|include|line|pragma|undef|warning)\b|[^\n\r]*)/,r,"#"]),g.push(["str",/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h(?:h|pp|\+\+)?|[a-z]\w*)>/,r])):i.push(["com",/^#[^\n\r]*/,r,"#"]));a.cStyleComments&&(g.push(["com",/^\/\/[^\n\r]*/,r]),g.push(["com",/^\/\*[\S\s]*?(?:\*\/|$)/,
+r]));a.regexLiterals&&g.push(["lang-regex",/^(?:^^\.?|[+-]|[!=]={0,2}|#|%=?|&&?=?|\(|\*=?|[+-]=|->|\/=?|::?|<=?|>{1,3}=?|[,;?@[{~]|\^\^?=?|\|\|?=?|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\s*(\/(?=[^*/])(?:[^/[\\]|\\[\S\s]|\[(?:[^\\\]]|\\[\S\s])*(?:]|$))+\/)/]);(j=a.types)&&g.push(["typ",j]);a=(""+a.keywords).replace(/^ | $/g,"");a.length&&g.push(["kwd",RegExp("^(?:"+a.replace(/[\s,]+/g,"|")+")\\b"),r]);i.push(["pln",/^\s+/,r," \r\n\t\u00a0"]);g.push(["lit",
+/^@[$_a-z][\w$@]*/i,r],["typ",/^(?:[@_]?[A-Z]+[a-z][\w$@]*|\w+_t\b)/,r],["pln",/^[$_a-z][\w$@]*/i,r],["lit",/^(?:0x[\da-f]+|(?:\d(?:_\d+)*\d*(?:\.\d*)?|\.\d\+)(?:e[+-]?\d+)?)[a-z]*/i,r,"0123456789"],["pln",/^\\[\S\s]?/,r],["pun",/^.[^\s\w"$'./@\\`]*/,r]);return x(i,g)}function G(a,i,g){function j(a){switch(a.nodeType){case 1:if(z.test(a.className))break;if("br"===a.nodeName)t(a),a.parentNode&&a.parentNode.removeChild(a);else for(a=a.firstChild;a;a=a.nextSibling)j(a);break;case 3:case 4:if(g){var b=
+a.nodeValue,f=b.match(n);if(f){var i=b.substring(0,f.index);a.nodeValue=i;(b=b.substring(f.index+f[0].length))&&a.parentNode.insertBefore(k.createTextNode(b),a.nextSibling);t(a);i||a.parentNode.removeChild(a)}}}}function t(a){function i(a,b){var d=b?a.cloneNode(!1):a,e=a.parentNode;if(e){var e=i(e,1),f=a.nextSibling;e.appendChild(d);for(var g=f;g;g=f)f=g.nextSibling,e.appendChild(g)}return d}for(;!a.nextSibling;)if(a=a.parentNode,!a)return;for(var a=i(a.nextSibling,0),f;(f=a.parentNode)&&f.nodeType===
+1;)a=f;b.push(a)}for(var z=/(?:^|\s)nocode(?:\s|$)/,n=/\r\n?|\n/,k=a.ownerDocument,m=k.createElement("li");a.firstChild;)m.appendChild(a.firstChild);for(var b=[m],o=0;o=0;){var j=
+i[g];A.hasOwnProperty(j)?C.console&&console.warn("cannot override language handler %s",j):A[j]=a}}function F(a,i){if(!a||!A.hasOwnProperty(a))a=/^\s*=e&&(j+=2);g>=p&&(s+=2)}}finally{if(c)c.style.display=h}}catch(A){C.console&&console.log(A&&A.stack?A.stack:A)}}var C=window,y=["break,continue,do,else,for,if,return,while"],B=[[y,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"],"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"],I=[B,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"],
+J=[B,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"],K=[J,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,let,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var,virtual,where"],B=[B,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"],
+L=[y,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"],M=[y,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"],y=[y,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"],N=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)\b/,
+Q=/\S/,R=l({keywords:[I,K,B,"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END"+L,M,y],hashComments:!0,cStyleComments:!0,multiLineStrings:!0,regexLiterals:!0}),A={};n(R,["default-code"]);n(x([],[["pln",/^[^]+/],["dec",/^]*(?:>|$)/],["com",/^<\!--[\S\s]*?(?:--\>|$)/],["lang-",/^<\?([\S\s]+?)(?:\?>|$)/],["lang-",/^<%([\S\s]+?)(?:%>|$)/],["pun",/^(?:<[%?]|[%?]>)/],["lang-",
+/^]*>([\S\s]+?)<\/xmp\b[^>]*>/i],["lang-js",/^
+
+
+
+