Skip to content

Commit

Permalink
chore(deps): use nanoid instead of cuid
Browse files Browse the repository at this point in the history
  • Loading branch information
stevenjoezhang committed Apr 18, 2024
1 parent 8009b0a commit 55c92b0
Show file tree
Hide file tree
Showing 4 changed files with 11 additions and 9 deletions.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -30,11 +30,11 @@
"license": "MIT",
"dependencies": {
"bluebird": "^3.7.2",
"cuid": "^2.1.8",
"graceful-fs": "^4.2.10",
"hexo-log": "^4.0.1",
"is-plain-object": "^5.0.0",
"jsonparse": "^1.3.1",
"nanoid": "^3.3.7",
"rfdc": "^1.3.0",
"through2": "^4.0.2"
},
Expand Down
10 changes: 5 additions & 5 deletions src/types/cuid.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
import SchemaType from '../schematype';
import cuid from 'cuid';
import { nanoid } from 'nanoid';
import ValidationError from '../error/validation';

/**
* [CUID](https://github.com/ericelliott/cuid) schema type.
* [CUID](https://github.com/ai/nanoid) schema type.
*/
class SchemaTypeCUID extends SchemaType<string> {

Expand All @@ -16,20 +16,20 @@ class SchemaTypeCUID extends SchemaType<string> {
*/
cast(value?: string): string {
if (value == null && this.options.required) {
return cuid();
return nanoid();
}

return value;
}

/**
* Validates data. A valid CUID must be started with `c` and 25 in length.
* Validates data. A valid CUID must be 21 in length.
*
* @param {*} value
* @return {String|Error}
*/
validate(value?: string): string {
if (value && (value[0] !== 'c' || value.length !== 25)) {
if (value && (value.length !== 21)) {
throw new ValidationError(`\`${value}\` is not a valid CUID`);
}

Expand Down
4 changes: 2 additions & 2 deletions test/scripts/model.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import lodash from 'lodash';
const { sortBy } = lodash;
import Promise from 'bluebird';
import sinon from 'sinon';
import cuid from 'cuid';
import { nanoid } from 'nanoid';
import Database from '../../dist/database';
import type Query from '../../dist/query';
import type Document from '../../dist/document';
Expand Down Expand Up @@ -214,7 +214,7 @@ describe('Model', () => {
}).then(data => User.removeById(data._id)));

it('save() - sync problem', () => {
const id = cuid();
const id = nanoid();

return Promise.all([
User.save({_id: id, age: 1}),
Expand Down
4 changes: 3 additions & 1 deletion test/scripts/types/cuid.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import chai from 'chai';
const should = chai.should(); // eslint-disable-line
import { nanoid } from 'nanoid';
import ValidationError from '../../../dist/error/validation';
import SchemaTypeCUID from '../../../dist/types/cuid';

Expand All @@ -17,7 +18,8 @@ describe('SchemaTypeCUID', () => {
});

it('validate()', () => {
type.validate('ch72gsb320000udocl363eofy').should.eql('ch72gsb320000udocl363eofy');
const id = nanoid();
type.validate(id).should.eql(id);

(() => type.validate('foo')).should.to.throw(ValidationError, '`foo` is not a valid CUID');
});
Expand Down

0 comments on commit 55c92b0

Please sign in to comment.