jason-rails 0.7.2 → 0.7.5.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +9 -2
- data/README.md +14 -0
- data/client/lib/JasonProvider.d.ts +2 -1
- data/client/lib/JasonProvider.js +2 -2
- data/client/lib/createOptDis.js +1 -0
- data/client/lib/createTransportAdapter.d.ts +1 -1
- data/client/lib/createTransportAdapter.js +2 -2
- data/client/lib/index.d.ts +2 -1
- data/client/lib/transportAdapters/actionCableAdapter.d.ts +1 -1
- data/client/lib/transportAdapters/actionCableAdapter.js +11 -4
- data/client/lib/transportAdapters/pusherAdapter.js +12 -3
- data/client/lib/useJason.d.ts +2 -1
- data/client/lib/useJason.js +3 -3
- data/client/package.json +1 -1
- data/client/src/JasonProvider.tsx +2 -2
- data/client/src/createOptDis.ts +2 -0
- data/client/src/createTransportAdapter.ts +2 -2
- data/client/src/transportAdapters/actionCableAdapter.ts +12 -4
- data/client/src/transportAdapters/pusherAdapter.ts +12 -3
- data/client/src/useJason.ts +9 -3
- data/lib/jason/version.rb +1 -1
- data/lib/jason.rb +5 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: c0ca4e6c931fdf041e8bd13a516e11d89699396691ff6328c73a0241f5672cc9
|
4
|
+
data.tar.gz: a0a6680af3dc06b0a5f96ee4f96513c172e12cf84cccc70339c0d46f7f0b742a
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f39c46227135319c3c9bfe81fce8cbda84769bd9de3d14103604c95cb4106dc0ff00a362a340c2f9a981f412947116848b569d64d33c879b094c2bdd8a24a990
|
7
|
+
data.tar.gz: c9cd5cf85a36769697b50f7d68c4204b6d61db2169a3378000bab6b8f1a6c05f3ecc42322c6480ea22a3dced1cbcd4625c8b64eb554ed21b3611a92f203c92fc
|
data/CHANGELOG.md
CHANGED
@@ -1,5 +1,12 @@
|
|
1
|
-
## v0.7.
|
2
|
-
-
|
1
|
+
## v0.7.5.1
|
2
|
+
- Fix bug where axios errors get swallowed
|
3
|
+
|
4
|
+
## v0.7.5
|
5
|
+
- Fixed JS errors when payloads arrive on websockets after the subscription has been unmounted
|
6
|
+
- Fixed errors during initialization due to calling `cache_all` on a Rails model before it had fully initialized.
|
7
|
+
|
8
|
+
## v0.7.3
|
9
|
+
- Added: Add JasonContext to exports, for use in scenarios where you need to forward the context into some other React reconciler (e.g. `react-three-fiber`)
|
3
10
|
- Fixed: Unneeded `reload` in Publisher resulting in extra database calls
|
4
11
|
|
5
12
|
## v0.7.1
|
data/README.md
CHANGED
@@ -52,6 +52,11 @@ Jason.setup do |config|
|
|
52
52
|
end
|
53
53
|
```
|
54
54
|
|
55
|
+
Mount the Jason engine in `routes.rb`
|
56
|
+
```ruby
|
57
|
+
mount Jason::Engine => "/jason"
|
58
|
+
```
|
59
|
+
|
55
60
|
### In your frontend code
|
56
61
|
|
57
62
|
First you need to wrap your root component in a `JasonProvider`.
|
@@ -173,6 +178,15 @@ Development is primarily driven by the needs of projects we're using Jason in. I
|
|
173
178
|
- Assess using RedisGraph for the graph diffing functionality, to see if this would provide a performance boost
|
174
179
|
- Improve the Typescript definitions (ie remove the abundant `any` typing currently used)
|
175
180
|
|
181
|
+
## Publishing a new version
|
182
|
+
- Update `version.rb`
|
183
|
+
- Update CHANGELOG
|
184
|
+
- `gem build`
|
185
|
+
- `gem push`
|
186
|
+
- `npm version [major/minor/patch]`
|
187
|
+
- `npm publish`
|
188
|
+
- Push new version to Github
|
189
|
+
|
176
190
|
## License
|
177
191
|
|
178
192
|
The gem, npm package and source code in the git repository are available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
|
@@ -1,9 +1,10 @@
|
|
1
1
|
import React from 'react';
|
2
|
-
declare const JasonProvider: ({ reducers, middleware, enhancers, extraActions, children }: {
|
2
|
+
declare const JasonProvider: ({ reducers, middleware, enhancers, extraActions, transportOptions, children }: {
|
3
3
|
reducers?: any;
|
4
4
|
middleware?: any;
|
5
5
|
enhancers?: any;
|
6
6
|
extraActions?: any;
|
7
|
+
transportOptions?: any;
|
7
8
|
children?: React.FC<{}> | undefined;
|
8
9
|
}) => JSX.Element;
|
9
10
|
export default JasonProvider;
|
data/client/lib/JasonProvider.js
CHANGED
@@ -7,8 +7,8 @@ const react_1 = __importDefault(require("react"));
|
|
7
7
|
const useJason_1 = __importDefault(require("./useJason"));
|
8
8
|
const react_redux_1 = require("react-redux");
|
9
9
|
const JasonContext_1 = __importDefault(require("./JasonContext"));
|
10
|
-
const JasonProvider = ({ reducers, middleware, enhancers, extraActions, children }) => {
|
11
|
-
const [store, value] = useJason_1.default({ reducers, middleware, enhancers, extraActions });
|
10
|
+
const JasonProvider = ({ reducers, middleware, enhancers, extraActions, transportOptions = {}, children }) => {
|
11
|
+
const [store, value] = useJason_1.default({ reducers, middleware, enhancers, extraActions, transportOptions });
|
12
12
|
if (!(store && value))
|
13
13
|
return react_1.default.createElement("div", null); // Wait for async fetch of schema to complete
|
14
14
|
return react_1.default.createElement(react_redux_1.Provider, { store: store },
|
data/client/lib/createOptDis.js
CHANGED
@@ -29,6 +29,7 @@ function createOptDis(schema, dispatch, restClient, serverActionQueue) {
|
|
29
29
|
.catch(error => {
|
30
30
|
dispatch({ type: 'jason/upsert', payload: { error } });
|
31
31
|
serverActionQueue.itemFailed(id, error);
|
32
|
+
Promise.reject(error);
|
32
33
|
});
|
33
34
|
}
|
34
35
|
setInterval(dispatchServerAction, 10);
|
@@ -1,4 +1,4 @@
|
|
1
|
-
export default function createTransportAdapter(jasonConfig: any, handlePayload: any, dispatch: any, onConnect: any): {
|
1
|
+
export default function createTransportAdapter(jasonConfig: any, handlePayload: any, dispatch: any, onConnect: any, transportOptions: any): {
|
2
2
|
getPayload: (config: any, options: any) => void;
|
3
3
|
createSubscription: (config: any) => void;
|
4
4
|
removeSubscription: (config: any) => void;
|
@@ -5,10 +5,10 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
6
6
|
const actionCableAdapter_1 = __importDefault(require("./transportAdapters/actionCableAdapter"));
|
7
7
|
const pusherAdapter_1 = __importDefault(require("./transportAdapters/pusherAdapter"));
|
8
|
-
function createTransportAdapter(jasonConfig, handlePayload, dispatch, onConnect) {
|
8
|
+
function createTransportAdapter(jasonConfig, handlePayload, dispatch, onConnect, transportOptions) {
|
9
9
|
const { transportService } = jasonConfig;
|
10
10
|
if (transportService === 'action_cable') {
|
11
|
-
return actionCableAdapter_1.default(jasonConfig, handlePayload, dispatch, onConnect);
|
11
|
+
return actionCableAdapter_1.default(jasonConfig, handlePayload, dispatch, onConnect, transportOptions);
|
12
12
|
}
|
13
13
|
else if (transportService === 'pusher') {
|
14
14
|
return pusherAdapter_1.default(jasonConfig, handlePayload, dispatch);
|
data/client/lib/index.d.ts
CHANGED
@@ -7,11 +7,12 @@ export declare const JasonContext: import("react").Context<{
|
|
7
7
|
subscribe: null;
|
8
8
|
eager: (entity: any, id: any, relations: any) => void;
|
9
9
|
}>;
|
10
|
-
export declare const JasonProvider: ({ reducers, middleware, enhancers, extraActions, children }: {
|
10
|
+
export declare const JasonProvider: ({ reducers, middleware, enhancers, extraActions, transportOptions, children }: {
|
11
11
|
reducers?: any;
|
12
12
|
middleware?: any;
|
13
13
|
enhancers?: any;
|
14
14
|
extraActions?: any;
|
15
|
+
transportOptions?: any;
|
15
16
|
children?: import("react").FC<{}> | undefined;
|
16
17
|
}) => JSX.Element;
|
17
18
|
export declare const useAct: typeof _useAct;
|
@@ -1,4 +1,4 @@
|
|
1
|
-
export default function actionCableAdapter(jasonConfig: any, handlePayload: any, dispatch: any, onConnected: any): {
|
1
|
+
export default function actionCableAdapter(jasonConfig: any, handlePayload: any, dispatch: any, onConnected: any, transportOptions: any): {
|
2
2
|
getPayload: (config: any, options: any) => void;
|
3
3
|
createSubscription: (config: any) => void;
|
4
4
|
removeSubscription: (config: any) => void;
|
@@ -7,9 +7,10 @@ const actioncable_1 = require("@rails/actioncable");
|
|
7
7
|
const restClient_1 = __importDefault(require("../restClient"));
|
8
8
|
const uuid_1 = require("uuid");
|
9
9
|
const lodash_1 = __importDefault(require("lodash"));
|
10
|
-
function actionCableAdapter(jasonConfig, handlePayload, dispatch, onConnected) {
|
10
|
+
function actionCableAdapter(jasonConfig, handlePayload, dispatch, onConnected, transportOptions) {
|
11
11
|
const consumerId = uuid_1.v4();
|
12
|
-
const
|
12
|
+
const { cableUrl } = transportOptions;
|
13
|
+
const consumer = cableUrl ? actioncable_1.createConsumer(cableUrl) : actioncable_1.createConsumer();
|
13
14
|
const subscription = (consumer.subscriptions.create({
|
14
15
|
channel: 'Jason::Channel'
|
15
16
|
}, {
|
@@ -33,7 +34,10 @@ function actionCableAdapter(jasonConfig, handlePayload, dispatch, onConnected) {
|
|
33
34
|
}
|
34
35
|
function removeSubscription(config) {
|
35
36
|
restClient_1.default.post('/jason/api/remove_subscription', { config, consumerId })
|
36
|
-
.catch(e =>
|
37
|
+
.catch(e => {
|
38
|
+
console.error(e);
|
39
|
+
Promise.reject(e);
|
40
|
+
});
|
37
41
|
}
|
38
42
|
function getPayload(config, options) {
|
39
43
|
restClient_1.default.post('/jason/api/get_payload', {
|
@@ -45,7 +49,10 @@ function actionCableAdapter(jasonConfig, handlePayload, dispatch, onConnected) {
|
|
45
49
|
handlePayload(payload);
|
46
50
|
});
|
47
51
|
})
|
48
|
-
.catch(e =>
|
52
|
+
.catch(e => {
|
53
|
+
console.error(e);
|
54
|
+
Promise.reject(e);
|
55
|
+
});
|
49
56
|
}
|
50
57
|
function fullChannelName(channelName) {
|
51
58
|
return channelName;
|
@@ -33,13 +33,19 @@ function pusherAdapter(jasonConfig, handlePayload, dispatch) {
|
|
33
33
|
configToChannel[JSON.stringify(config)] = channelName;
|
34
34
|
subscribeToChannel(channelName);
|
35
35
|
})
|
36
|
-
.catch(e =>
|
36
|
+
.catch(e => {
|
37
|
+
console.error(e);
|
38
|
+
Promise.reject(e);
|
39
|
+
});
|
37
40
|
}
|
38
41
|
function removeSubscription(config) {
|
39
42
|
const channelName = configToChannel[JSON.stringify(config)];
|
40
43
|
unsubscribeFromChannel(fullChannelName(channelName));
|
41
44
|
restClient_1.default.post('/jason/api/remove_subscription', { config, consumerId })
|
42
|
-
.catch(e =>
|
45
|
+
.catch(e => {
|
46
|
+
console.error(e);
|
47
|
+
Promise.reject(e);
|
48
|
+
});
|
43
49
|
}
|
44
50
|
function getPayload(config, options) {
|
45
51
|
restClient_1.default.post('/jason/api/get_payload', {
|
@@ -51,7 +57,10 @@ function pusherAdapter(jasonConfig, handlePayload, dispatch) {
|
|
51
57
|
handlePayload(payload);
|
52
58
|
});
|
53
59
|
})
|
54
|
-
.catch(e =>
|
60
|
+
.catch(e => {
|
61
|
+
console.error(e);
|
62
|
+
Promise.reject(e);
|
63
|
+
});
|
55
64
|
}
|
56
65
|
function subscribeToChannel(channelName) {
|
57
66
|
const channel = pusher.subscribe(fullChannelName(channelName));
|
data/client/lib/useJason.d.ts
CHANGED
@@ -1,6 +1,7 @@
|
|
1
|
-
export default function useJason({ reducers, middleware, enhancers, extraActions }: {
|
1
|
+
export default function useJason({ reducers, middleware, enhancers, transportOptions, extraActions }: {
|
2
2
|
reducers?: any;
|
3
3
|
middleware?: any[];
|
4
4
|
enhancers?: any[];
|
5
5
|
extraActions?: any;
|
6
|
+
transportOptions?: any;
|
6
7
|
}): any[];
|
data/client/lib/useJason.js
CHANGED
@@ -16,7 +16,7 @@ const humps_1 = require("humps");
|
|
16
16
|
const blueimp_md5_1 = __importDefault(require("blueimp-md5"));
|
17
17
|
const lodash_1 = __importDefault(require("lodash"));
|
18
18
|
const react_1 = require("react");
|
19
|
-
function useJason({ reducers, middleware = [], enhancers = [], extraActions }) {
|
19
|
+
function useJason({ reducers, middleware = [], enhancers = [], transportOptions = {}, extraActions }) {
|
20
20
|
const [store, setStore] = react_1.useState(null);
|
21
21
|
const [value, setValue] = react_1.useState(null);
|
22
22
|
react_1.useEffect(() => {
|
@@ -37,7 +37,7 @@ function useJason({ reducers, middleware = [], enhancers = [], extraActions }) {
|
|
37
37
|
let subOptions = {};
|
38
38
|
function handlePayload(payload) {
|
39
39
|
const { md5Hash } = payload;
|
40
|
-
const { handlePayload } = payloadHandlers[md5Hash];
|
40
|
+
const { handlePayload } = payloadHandlers[md5Hash] || {};
|
41
41
|
if (handlePayload) {
|
42
42
|
handlePayload(payload);
|
43
43
|
}
|
@@ -45,7 +45,7 @@ function useJason({ reducers, middleware = [], enhancers = [], extraActions }) {
|
|
45
45
|
console.warn("Payload arrived with no handler", payload, payloadHandlers);
|
46
46
|
}
|
47
47
|
}
|
48
|
-
const transportAdapter = createTransportAdapter_1.default(jasonConfig, handlePayload, dispatch, () => lodash_1.default.keys(configs).forEach(md5Hash => createSubscription(configs[md5Hash], subOptions[md5Hash])));
|
48
|
+
const transportAdapter = createTransportAdapter_1.default(jasonConfig, handlePayload, dispatch, () => lodash_1.default.keys(configs).forEach(md5Hash => createSubscription(configs[md5Hash], subOptions[md5Hash])), transportOptions);
|
49
49
|
function createSubscription(config, options = {}) {
|
50
50
|
// We need the hash to be consistent in Ruby / Javascript
|
51
51
|
const hashableConfig = lodash_1.default(Object.assign({ conditions: {}, includes: {} }, config)).toPairs().sortBy(0).fromPairs().value();
|
data/client/package.json
CHANGED
@@ -3,8 +3,8 @@ import useJason from './useJason'
|
|
3
3
|
import { Provider } from 'react-redux'
|
4
4
|
import JasonContext from './JasonContext'
|
5
5
|
|
6
|
-
const JasonProvider = ({ reducers, middleware, enhancers, extraActions, children }: { reducers?: any, middleware?: any, enhancers?: any, extraActions?: any, children?: React.FC }) => {
|
7
|
-
const [store, value] = useJason({ reducers, middleware, enhancers, extraActions })
|
6
|
+
const JasonProvider = ({ reducers, middleware, enhancers, extraActions, transportOptions = {}, children }: { reducers?: any, middleware?: any, enhancers?: any, extraActions?: any, transportOptions?: any, children?: React.FC }) => {
|
7
|
+
const [store, value] = useJason({ reducers, middleware, enhancers, extraActions, transportOptions })
|
8
8
|
|
9
9
|
if(!(store && value)) return <div /> // Wait for async fetch of schema to complete
|
10
10
|
|
data/client/src/createOptDis.ts
CHANGED
@@ -1,10 +1,10 @@
|
|
1
1
|
import actionCableAdapter from './transportAdapters/actionCableAdapter'
|
2
2
|
import pusherAdapter from './transportAdapters/pusherAdapter'
|
3
3
|
|
4
|
-
export default function createTransportAdapter(jasonConfig, handlePayload, dispatch, onConnect) {
|
4
|
+
export default function createTransportAdapter(jasonConfig, handlePayload, dispatch, onConnect, transportOptions) {
|
5
5
|
const { transportService } = jasonConfig
|
6
6
|
if (transportService === 'action_cable') {
|
7
|
-
return actionCableAdapter(jasonConfig, handlePayload, dispatch, onConnect)
|
7
|
+
return actionCableAdapter(jasonConfig, handlePayload, dispatch, onConnect, transportOptions)
|
8
8
|
} else if (transportService === 'pusher') {
|
9
9
|
return pusherAdapter(jasonConfig, handlePayload, dispatch)
|
10
10
|
} else {
|
@@ -3,10 +3,12 @@ import restClient from '../restClient'
|
|
3
3
|
import { v4 as uuidv4 } from 'uuid'
|
4
4
|
import _ from 'lodash'
|
5
5
|
|
6
|
-
export default function actionCableAdapter(jasonConfig, handlePayload, dispatch, onConnected) {
|
6
|
+
export default function actionCableAdapter(jasonConfig, handlePayload, dispatch, onConnected, transportOptions) {
|
7
7
|
const consumerId = uuidv4()
|
8
8
|
|
9
|
-
const
|
9
|
+
const { cableUrl } = transportOptions
|
10
|
+
const consumer = cableUrl ? createConsumer(cableUrl) : createConsumer()
|
11
|
+
|
10
12
|
const subscription = (consumer.subscriptions.create({
|
11
13
|
channel: 'Jason::Channel'
|
12
14
|
}, {
|
@@ -33,7 +35,10 @@ export default function actionCableAdapter(jasonConfig, handlePayload, dispatch,
|
|
33
35
|
|
34
36
|
function removeSubscription(config) {
|
35
37
|
restClient.post('/jason/api/remove_subscription', { config, consumerId })
|
36
|
-
.catch(e =>
|
38
|
+
.catch(e => {
|
39
|
+
console.error(e)
|
40
|
+
Promise.reject(e)
|
41
|
+
})
|
37
42
|
}
|
38
43
|
|
39
44
|
function getPayload(config, options) {
|
@@ -46,7 +51,10 @@ export default function actionCableAdapter(jasonConfig, handlePayload, dispatch,
|
|
46
51
|
handlePayload(payload)
|
47
52
|
})
|
48
53
|
})
|
49
|
-
.catch(e =>
|
54
|
+
.catch(e => {
|
55
|
+
console.error(e)
|
56
|
+
Promise.reject(e)
|
57
|
+
})
|
50
58
|
}
|
51
59
|
|
52
60
|
function fullChannelName(channelName) {
|
@@ -31,14 +31,20 @@ export default function pusherAdapter(jasonConfig, handlePayload, dispatch) {
|
|
31
31
|
configToChannel[JSON.stringify(config)] = channelName
|
32
32
|
subscribeToChannel(channelName)
|
33
33
|
})
|
34
|
-
.catch(e =>
|
34
|
+
.catch(e => {
|
35
|
+
console.error(e)
|
36
|
+
Promise.reject(e)
|
37
|
+
})
|
35
38
|
}
|
36
39
|
|
37
40
|
function removeSubscription(config) {
|
38
41
|
const channelName = configToChannel[JSON.stringify(config)]
|
39
42
|
unsubscribeFromChannel(fullChannelName(channelName))
|
40
43
|
restClient.post('/jason/api/remove_subscription', { config, consumerId })
|
41
|
-
.catch(e =>
|
44
|
+
.catch(e => {
|
45
|
+
console.error(e)
|
46
|
+
Promise.reject(e)
|
47
|
+
})
|
42
48
|
}
|
43
49
|
|
44
50
|
function getPayload(config, options) {
|
@@ -51,7 +57,10 @@ export default function pusherAdapter(jasonConfig, handlePayload, dispatch) {
|
|
51
57
|
handlePayload(payload)
|
52
58
|
})
|
53
59
|
})
|
54
|
-
.catch(e =>
|
60
|
+
.catch(e => {
|
61
|
+
console.error(e)
|
62
|
+
Promise.reject(e)
|
63
|
+
})
|
55
64
|
}
|
56
65
|
|
57
66
|
function subscribeToChannel(channelName) {
|
data/client/src/useJason.ts
CHANGED
@@ -14,7 +14,7 @@ import md5 from 'blueimp-md5'
|
|
14
14
|
import _ from 'lodash'
|
15
15
|
import React, { useState, useEffect } from 'react'
|
16
16
|
|
17
|
-
export default function useJason({ reducers, middleware = [], enhancers = [], extraActions }: { reducers?: any, middleware?: any[], enhancers?: any[], extraActions?: any }) {
|
17
|
+
export default function useJason({ reducers, middleware = [], enhancers = [], transportOptions = {}, extraActions }: { reducers?: any, middleware?: any[], enhancers?: any[], extraActions?: any, transportOptions?: any }) {
|
18
18
|
const [store, setStore] = useState(null as any)
|
19
19
|
const [value, setValue] = useState(null as any)
|
20
20
|
|
@@ -48,7 +48,7 @@ export default function useJason({ reducers, middleware = [], enhancers = [], ex
|
|
48
48
|
function handlePayload(payload) {
|
49
49
|
const { md5Hash } = payload
|
50
50
|
|
51
|
-
const { handlePayload } = payloadHandlers[md5Hash]
|
51
|
+
const { handlePayload } = payloadHandlers[md5Hash] || {}
|
52
52
|
if (handlePayload) {
|
53
53
|
handlePayload(payload)
|
54
54
|
} else {
|
@@ -56,7 +56,13 @@ export default function useJason({ reducers, middleware = [], enhancers = [], ex
|
|
56
56
|
}
|
57
57
|
}
|
58
58
|
|
59
|
-
const transportAdapter = createTransportAdapater(
|
59
|
+
const transportAdapter = createTransportAdapater(
|
60
|
+
jasonConfig,
|
61
|
+
handlePayload,
|
62
|
+
dispatch,
|
63
|
+
() => _.keys(configs).forEach(md5Hash => createSubscription(configs[md5Hash], subOptions[md5Hash])),
|
64
|
+
transportOptions
|
65
|
+
)
|
60
66
|
|
61
67
|
function createSubscription(config, options = {}) {
|
62
68
|
// We need the hash to be consistent in Ruby / Javascript
|
data/lib/jason/version.rb
CHANGED
data/lib/jason.rb
CHANGED
@@ -51,7 +51,11 @@ module Jason
|
|
51
51
|
puts "Old config was #{previous_schema[model]}"
|
52
52
|
puts "New config is #{config}"
|
53
53
|
puts "Rebuilding cache for #{model}"
|
54
|
-
|
54
|
+
|
55
|
+
# This is necessary to ensure all Rails methods have been added to model before we attempt to cache.
|
56
|
+
Rails.configuration.after_initialize do
|
57
|
+
model.classify.constantize.cache_all
|
58
|
+
end
|
55
59
|
puts "Done"
|
56
60
|
end
|
57
61
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: jason-rails
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.7.
|
4
|
+
version: 0.7.5.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- James Rees
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2022-04-12 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|